flutter95
flutter95 copied to clipboard
Windows95 UI components for Flutter apps. Bring back the nostalgic look and feel of old operating systems with this set of UI components ready to use.
Flutter95
Windows95 UI components for Flutter apps.
UNDER CONSTRUCTION
Screenshots
data:image/s3,"s3://crabby-images/ba355/ba3550ad533df02939533727cd6a3008adb35727" alt="Screenshot"
Components
Scaffold95
Scaffold as a Windows95 styled window.
- Provides title.
- Optional: toolbar that requires
Item95
action items.
data:image/s3,"s3://crabby-images/26411/264110074cad313730b9c7a7df5c086a16c8521b" alt="Screenshot"
- If a scaffold
canPop
(meaning it is not a root of the app) then a close button appears.
data:image/s3,"s3://crabby-images/9dfe9/9dfe905b6f57d4bf610060ee0d2cfe65ecbb949c" alt="Screenshot"
Scaffold95(
title: 'Flutter95',
toolbar: Toolbar95(
actions: [
Item95(
label: 'File',
onTap: () {},
),
],
),
body: Container(),
)
Menu95
Windows95 styled menu.
data:image/s3,"s3://crabby-images/279c1/279c1c1ccec25c5d33d23f4ebd0f80e88a8e66d3" alt="Screenshot"
- Easy API wrapping Material's
showMenu
.
Menu95(
items: [
MenuItem95(
value: 1,
label: 'New',
),
MenuItem95(
value: 2,
label: 'Open',
),
MenuItem95(
value: 3,
label: 'Exit',
),
],
onItemSelected: (item) {},
);
- Display using
show(context, position)
.
menu.show(
context,
Offset(50, 100),
);
- Use it directly with Item95 to be positioned automatically.
Item95(
label: 'File',
menu: Menu95(...),
),
Button95
Windows95 styled button.
- Provides default text style for child widgets.
- Provides default padding for children.
- If
onTap
is null, acts as a disabled button.
Button95(
onTap: () {},
child: Text('Button95'),
)
TextField95
TextField styled as a Windows95 text field.
- Uses a Material TextField internally.
TextField95()
Elevation95
Creates an effect of deepness and elevation around Widgets.
Elevation95(
child: Text('Elevated Text')
)
Flutter95.textStyle
TextStyle ready to use that copies the Windows95 text style.
Text(
'Text with Flutter95.textStyle',
style: Flutter95.textStyle,
);
Acknowledgments
Heavily inspired by React95.