mirror of
https://github.com/flutter/samples.git
synced 2025-11-08 22:09:06 +00:00
Symposium of small improvements to m3 app (#1573)
* small improvements * x * fixed tests * add issue links to TODOs * address feedback
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -125,7 +125,6 @@ class _ElevationCardState extends State<ElevationCard> {
|
|||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
const BorderRadius borderRadius = BorderRadius.all(Radius.circular(4.0));
|
const BorderRadius borderRadius = BorderRadius.all(Radius.circular(4.0));
|
||||||
final bool showOpacity = _elevation == widget.info.elevation;
|
|
||||||
final Color color = Theme.of(context).colorScheme.surface;
|
final Color color = Theme.of(context).colorScheme.surface;
|
||||||
|
|
||||||
return Padding(
|
return Padding(
|
||||||
@@ -150,7 +149,7 @@ class _ElevationCardState extends State<ElevationCard> {
|
|||||||
'${widget.info.level.toInt()} dp',
|
'${widget.info.level.toInt()} dp',
|
||||||
style: Theme.of(context).textTheme.labelMedium,
|
style: Theme.of(context).textTheme.labelMedium,
|
||||||
),
|
),
|
||||||
if (showOpacity)
|
if (widget.surfaceTint != null)
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Align(
|
child: Align(
|
||||||
alignment: Alignment.bottomRight,
|
alignment: Alignment.bottomRight,
|
||||||
|
|||||||
@@ -3,14 +3,20 @@
|
|||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter/scheduler.dart';
|
||||||
|
|
||||||
import 'color_palettes_screen.dart';
|
import 'color_palettes_screen.dart';
|
||||||
import 'component_screen.dart';
|
import 'component_screen.dart';
|
||||||
import 'elevation_screen.dart';
|
import 'elevation_screen.dart';
|
||||||
import 'typography_screen.dart';
|
import 'typography_screen.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
runApp(const MaterialApp(
|
runApp(
|
||||||
debugShowCheckedModeBanner: false, home: Material3Demo()));
|
const MaterialApp(
|
||||||
|
debugShowCheckedModeBanner: false,
|
||||||
|
home: Material3Demo(),
|
||||||
|
),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
class Material3Demo extends StatefulWidget {
|
class Material3Demo extends StatefulWidget {
|
||||||
@@ -61,17 +67,25 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
bool showMediumSizeLayout = false;
|
bool showMediumSizeLayout = false;
|
||||||
bool showLargeSizeLayout = false;
|
bool showLargeSizeLayout = false;
|
||||||
bool useMaterial3 = true;
|
bool useMaterial3 = true;
|
||||||
bool useLightMode = true;
|
ThemeMode themeMode = ThemeMode.system;
|
||||||
|
bool get useLightMode {
|
||||||
|
switch (themeMode) {
|
||||||
|
case ThemeMode.system:
|
||||||
|
return SchedulerBinding.instance.window.platformBrightness ==
|
||||||
|
Brightness.light;
|
||||||
|
case ThemeMode.light:
|
||||||
|
return true;
|
||||||
|
case ThemeMode.dark:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ColorSeed colorSelected = ColorSeed.baseColor;
|
ColorSeed colorSelected = ColorSeed.baseColor;
|
||||||
int screenIndex = ScreenSelected.component.value;
|
int screenIndex = ScreenSelected.component.value;
|
||||||
|
|
||||||
late ThemeData themeData;
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
initState() {
|
initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
themeData = updateThemes(colorSelected.color, useMaterial3, useLightMode);
|
|
||||||
|
|
||||||
controller = AnimationController(
|
controller = AnimationController(
|
||||||
duration: Duration(milliseconds: transitionLength.toInt() * 2),
|
duration: Duration(milliseconds: transitionLength.toInt() * 2),
|
||||||
value: 0,
|
value: 0,
|
||||||
@@ -121,38 +135,27 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ThemeData updateThemes(
|
|
||||||
Color colorSelected, bool useMaterial3, bool useLightMode) {
|
|
||||||
return ThemeData(
|
|
||||||
colorSchemeSeed: colorSelected,
|
|
||||||
useMaterial3: useMaterial3,
|
|
||||||
brightness: useLightMode ? Brightness.light : Brightness.dark);
|
|
||||||
}
|
|
||||||
|
|
||||||
void handleScreenChanged(int screenSelected) {
|
void handleScreenChanged(int screenSelected) {
|
||||||
setState(() {
|
setState(() {
|
||||||
screenIndex = screenSelected;
|
screenIndex = screenSelected;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleBrightnessChange() {
|
void handleBrightnessChange(bool useLightMode) {
|
||||||
setState(() {
|
setState(() {
|
||||||
useLightMode = !useLightMode;
|
themeMode = useLightMode ? ThemeMode.light : ThemeMode.dark;
|
||||||
themeData = updateThemes(colorSelected.color, useMaterial3, useLightMode);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleMaterialVersionChange() {
|
void handleMaterialVersionChange() {
|
||||||
setState(() {
|
setState(() {
|
||||||
useMaterial3 = !useMaterial3;
|
useMaterial3 = !useMaterial3;
|
||||||
themeData = updateThemes(colorSelected.color, useMaterial3, useLightMode);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleColorSelect(int value) {
|
void handleColorSelect(int value) {
|
||||||
setState(() {
|
setState(() {
|
||||||
colorSelected = ColorSeed.values[value];
|
colorSelected = ColorSeed.values[value];
|
||||||
themeData = updateThemes(colorSelected.color, useMaterial3, useLightMode);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -166,9 +169,12 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
one: FirstComponentList(
|
one: FirstComponentList(
|
||||||
showNavBottomBar: showNavBarExample,
|
showNavBottomBar: showNavBarExample,
|
||||||
scaffoldKey: scaffoldKey,
|
scaffoldKey: scaffoldKey,
|
||||||
showSecondList:
|
showSecondList: showMediumSizeLayout || showLargeSizeLayout),
|
||||||
showMediumSizeLayout || showLargeSizeLayout),
|
two: SecondComponentList(
|
||||||
two: const SecondComponentList()));
|
scaffoldKey: scaffoldKey,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
case ScreenSelected.color:
|
case ScreenSelected.color:
|
||||||
return const ColorPalettesScreen();
|
return const ColorPalettesScreen();
|
||||||
case ScreenSelected.typography:
|
case ScreenSelected.typography:
|
||||||
@@ -183,68 +189,21 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget brightnessButton({bool showTooltipBelow = true}) => Tooltip(
|
|
||||||
preferBelow: showTooltipBelow,
|
|
||||||
message: 'Toggle brightness',
|
|
||||||
child: IconButton(
|
|
||||||
icon: useLightMode
|
|
||||||
? const Icon(Icons.wb_sunny_outlined)
|
|
||||||
: const Icon(Icons.wb_sunny),
|
|
||||||
onPressed: handleBrightnessChange,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
|
|
||||||
Widget material3Button({bool showTooltipBelow = true}) => Tooltip(
|
|
||||||
preferBelow: showTooltipBelow,
|
|
||||||
message: 'Switch to Material ${useMaterial3 ? 2 : 3}',
|
|
||||||
child: IconButton(
|
|
||||||
icon: useMaterial3
|
|
||||||
? const Icon(Icons.filter_3)
|
|
||||||
: const Icon(Icons.filter_2),
|
|
||||||
onPressed: handleMaterialVersionChange,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
|
|
||||||
Widget colorSeedButton(Icon icon) => PopupMenuButton(
|
|
||||||
icon: icon,
|
|
||||||
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10)),
|
|
||||||
itemBuilder: (context) {
|
|
||||||
return List.generate(ColorSeed.values.length, (index) {
|
|
||||||
ColorSeed currentColor = ColorSeed.values[index];
|
|
||||||
|
|
||||||
return PopupMenuItem(
|
|
||||||
value: index,
|
|
||||||
child: Wrap(
|
|
||||||
children: [
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 10),
|
|
||||||
child: Icon(
|
|
||||||
currentColor == colorSelected
|
|
||||||
? Icons.color_lens
|
|
||||||
: Icons.color_lens_outlined,
|
|
||||||
color: currentColor.color,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 20),
|
|
||||||
child: Text(currentColor.label),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
onSelected: handleColorSelect,
|
|
||||||
);
|
|
||||||
|
|
||||||
PreferredSizeWidget createAppBar() {
|
PreferredSizeWidget createAppBar() {
|
||||||
return AppBar(
|
return AppBar(
|
||||||
title: useMaterial3 ? const Text('Material 3') : const Text('Material 2'),
|
title: useMaterial3 ? const Text('Material 3') : const Text('Material 2'),
|
||||||
actions: !showMediumSizeLayout && !showLargeSizeLayout
|
actions: !showMediumSizeLayout && !showLargeSizeLayout
|
||||||
? [
|
? [
|
||||||
brightnessButton(),
|
_BrightnessButton(
|
||||||
material3Button(),
|
handleBrightnessChange: handleBrightnessChange,
|
||||||
colorSeedButton(const Icon(Icons.more_vert)),
|
),
|
||||||
|
_Material3Button(
|
||||||
|
handleMaterialVersionChange: handleMaterialVersionChange,
|
||||||
|
),
|
||||||
|
_ColorSeedButton(
|
||||||
|
handleColorSelect: handleColorSelect,
|
||||||
|
colorSelected: colorSelected,
|
||||||
|
),
|
||||||
]
|
]
|
||||||
: [Container()],
|
: [Container()],
|
||||||
);
|
);
|
||||||
@@ -263,8 +222,8 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
Expanded(child: Container()),
|
Expanded(child: Container()),
|
||||||
Switch(
|
Switch(
|
||||||
value: useLightMode,
|
value: useLightMode,
|
||||||
onChanged: (_) {
|
onChanged: (value) {
|
||||||
handleBrightnessChange();
|
handleBrightnessChange(value);
|
||||||
})
|
})
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
@@ -289,8 +248,11 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
children: List.generate(
|
children: List.generate(
|
||||||
ColorSeed.values.length,
|
ColorSeed.values.length,
|
||||||
(i) => IconButton(
|
(i) => IconButton(
|
||||||
icon: const Icon(Icons.circle),
|
icon: const Icon(Icons.radio_button_unchecked),
|
||||||
color: ColorSeed.values[i].color,
|
color: ColorSeed.values[i].color,
|
||||||
|
isSelected:
|
||||||
|
colorSelected.color == ColorSeed.values[i].color,
|
||||||
|
selectedIcon: const Icon(Icons.circle),
|
||||||
onPressed: () {
|
onPressed: () {
|
||||||
handleColorSelect(i);
|
handleColorSelect(i);
|
||||||
},
|
},
|
||||||
@@ -304,9 +266,24 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
Widget _trailingActions() => Column(
|
Widget _trailingActions() => Column(
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
mainAxisAlignment: MainAxisAlignment.end,
|
||||||
children: [
|
children: [
|
||||||
Flexible(child: brightnessButton(showTooltipBelow: false)),
|
Flexible(
|
||||||
Flexible(child: material3Button(showTooltipBelow: false)),
|
child: _BrightnessButton(
|
||||||
Flexible(child: colorSeedButton(const Icon(Icons.more_horiz))),
|
handleBrightnessChange: handleBrightnessChange,
|
||||||
|
showTooltipBelow: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Flexible(
|
||||||
|
child: _Material3Button(
|
||||||
|
handleMaterialVersionChange: handleMaterialVersionChange,
|
||||||
|
showTooltipBelow: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Flexible(
|
||||||
|
child: _ColorSeedButton(
|
||||||
|
handleColorSelect: handleColorSelect,
|
||||||
|
colorSelected: colorSelected,
|
||||||
|
),
|
||||||
|
),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -315,8 +292,17 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
return MaterialApp(
|
return MaterialApp(
|
||||||
debugShowCheckedModeBanner: false,
|
debugShowCheckedModeBanner: false,
|
||||||
title: 'Material 3',
|
title: 'Material 3',
|
||||||
themeMode: useLightMode ? ThemeMode.light : ThemeMode.dark,
|
themeMode: themeMode,
|
||||||
theme: themeData,
|
theme: ThemeData(
|
||||||
|
colorSchemeSeed: colorSelected.color,
|
||||||
|
useMaterial3: useMaterial3,
|
||||||
|
brightness: Brightness.light,
|
||||||
|
),
|
||||||
|
darkTheme: ThemeData(
|
||||||
|
colorSchemeSeed: colorSelected.color,
|
||||||
|
useMaterial3: useMaterial3,
|
||||||
|
brightness: Brightness.dark,
|
||||||
|
),
|
||||||
home: AnimatedBuilder(
|
home: AnimatedBuilder(
|
||||||
animation: controller,
|
animation: controller,
|
||||||
builder: (context, child) {
|
builder: (context, child) {
|
||||||
@@ -357,7 +343,108 @@ class _Material3DemoState extends State<Material3Demo>
|
|||||||
isExampleBar: false,
|
isExampleBar: false,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}),
|
},
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class _BrightnessButton extends StatelessWidget {
|
||||||
|
const _BrightnessButton({
|
||||||
|
required this.handleBrightnessChange,
|
||||||
|
this.showTooltipBelow = true,
|
||||||
|
});
|
||||||
|
|
||||||
|
final Function handleBrightnessChange;
|
||||||
|
final bool showTooltipBelow;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final isBright = Theme.of(context).brightness == Brightness.light;
|
||||||
|
return Tooltip(
|
||||||
|
preferBelow: showTooltipBelow,
|
||||||
|
message: 'Toggle brightness',
|
||||||
|
child: IconButton(
|
||||||
|
icon: isBright
|
||||||
|
? const Icon(Icons.dark_mode_outlined)
|
||||||
|
: const Icon(Icons.light_mode_outlined),
|
||||||
|
onPressed: () => handleBrightnessChange(!isBright),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class _Material3Button extends StatelessWidget {
|
||||||
|
const _Material3Button({
|
||||||
|
required this.handleMaterialVersionChange,
|
||||||
|
this.showTooltipBelow = true,
|
||||||
|
});
|
||||||
|
|
||||||
|
final void Function() handleMaterialVersionChange;
|
||||||
|
final bool showTooltipBelow;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final useMaterial3 = Theme.of(context).useMaterial3;
|
||||||
|
return Tooltip(
|
||||||
|
preferBelow: showTooltipBelow,
|
||||||
|
message: 'Switch to Material ${useMaterial3 ? 2 : 3}',
|
||||||
|
child: IconButton(
|
||||||
|
icon: useMaterial3
|
||||||
|
? const Icon(Icons.filter_2)
|
||||||
|
: const Icon(Icons.filter_3),
|
||||||
|
onPressed: handleMaterialVersionChange,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class _ColorSeedButton extends StatelessWidget {
|
||||||
|
const _ColorSeedButton({
|
||||||
|
required this.handleColorSelect,
|
||||||
|
required this.colorSelected,
|
||||||
|
});
|
||||||
|
|
||||||
|
final void Function(int) handleColorSelect;
|
||||||
|
final ColorSeed colorSelected;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return PopupMenuButton(
|
||||||
|
icon: Icon(
|
||||||
|
Icons.palette_outlined,
|
||||||
|
color: Theme.of(context).colorScheme.onSurfaceVariant,
|
||||||
|
),
|
||||||
|
tooltip: 'Select a seed color',
|
||||||
|
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10)),
|
||||||
|
itemBuilder: (context) {
|
||||||
|
return List.generate(ColorSeed.values.length, (index) {
|
||||||
|
ColorSeed currentColor = ColorSeed.values[index];
|
||||||
|
|
||||||
|
return PopupMenuItem(
|
||||||
|
value: index,
|
||||||
|
enabled: currentColor != colorSelected,
|
||||||
|
child: Wrap(
|
||||||
|
children: [
|
||||||
|
Padding(
|
||||||
|
padding: const EdgeInsets.only(left: 10),
|
||||||
|
child: Icon(
|
||||||
|
currentColor == colorSelected
|
||||||
|
? Icons.color_lens
|
||||||
|
: Icons.color_lens_outlined,
|
||||||
|
color: currentColor.color,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Padding(
|
||||||
|
padding: const EdgeInsets.only(left: 20),
|
||||||
|
child: Text(currentColor.label),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
onSelected: handleColorSelect,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -421,9 +508,6 @@ class _NavigationTransitionState extends State<NavigationTransition> {
|
|||||||
backgroundColor: colorScheme.surface,
|
backgroundColor: colorScheme.surface,
|
||||||
child: widget.navigationRail,
|
child: widget.navigationRail,
|
||||||
),
|
),
|
||||||
railAnimation.isDismissed
|
|
||||||
? const SizedBox()
|
|
||||||
: const VerticalDivider(width: 1),
|
|
||||||
widget.body,
|
widget.body,
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -16,15 +16,15 @@ void main() {
|
|||||||
// Elements on the app bar
|
// Elements on the app bar
|
||||||
expect(find.text('Material 3'), findsOneWidget);
|
expect(find.text('Material 3'), findsOneWidget);
|
||||||
expect(
|
expect(
|
||||||
find.widgetWithIcon(AppBar, Icons.wb_sunny_outlined), findsOneWidget);
|
find.widgetWithIcon(AppBar, Icons.dark_mode_outlined), findsOneWidget);
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.filter_3), findsOneWidget);
|
expect(find.widgetWithIcon(AppBar, Icons.filter_2), findsOneWidget);
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.more_vert), findsOneWidget);
|
expect(find.widgetWithIcon(AppBar, Icons.palette_outlined), findsOneWidget);
|
||||||
|
|
||||||
// Elements on the component screen
|
// Elements on the component screen
|
||||||
// Buttons
|
// Buttons
|
||||||
expect(find.widgetWithText(ElevatedButton, 'Elevated'), findsNWidgets(2));
|
expect(find.widgetWithText(ElevatedButton, 'Elevated'), findsNWidgets(2));
|
||||||
expect(find.widgetWithText(FilledButton, 'Filled'), findsNWidgets(2));
|
expect(find.widgetWithText(FilledButton, 'Filled'), findsNWidgets(2));
|
||||||
expect(find.widgetWithText(FilledButton, 'Filled Tonal'), findsNWidgets(2));
|
expect(find.widgetWithText(FilledButton, 'Filled tonal'), findsNWidgets(2));
|
||||||
expect(find.widgetWithText(OutlinedButton, 'Outlined'), findsNWidgets(2));
|
expect(find.widgetWithText(OutlinedButton, 'Outlined'), findsNWidgets(2));
|
||||||
expect(find.widgetWithText(TextButton, 'Text'), findsNWidgets(2));
|
expect(find.widgetWithText(TextButton, 'Text'), findsNWidgets(2));
|
||||||
expect(find.widgetWithText(Buttons, 'Icon'), findsNWidgets(5));
|
expect(find.widgetWithText(Buttons, 'Icon'), findsNWidgets(5));
|
||||||
@@ -34,14 +34,14 @@ void main() {
|
|||||||
|
|
||||||
// FABs
|
// FABs
|
||||||
expect(find.byType(FloatingActionButton),
|
expect(find.byType(FloatingActionButton),
|
||||||
findsNWidgets(6)); // 2 more shows up in the bottom app bar.
|
findsNWidgets(5)); // 2 more shows up in the bottom app bar.
|
||||||
expect(find.widgetWithText(FloatingActionButton, 'Create'), findsOneWidget);
|
expect(find.widgetWithText(FloatingActionButton, 'Create'), findsOneWidget);
|
||||||
|
|
||||||
// Chips
|
// Chips
|
||||||
expect(find.byType(ActionChip),
|
expect(find.byType(ActionChip),
|
||||||
findsNWidgets(7)); // includes Assist and Suggestion chip.
|
findsNWidgets(4)); // includes Assist and Suggestion chip.
|
||||||
expect(find.byType(FilterChip), findsNWidgets(3));
|
expect(find.byType(FilterChip), findsNWidgets(2));
|
||||||
expect(find.byType(InputChip), findsNWidgets(4));
|
expect(find.byType(InputChip), findsNWidgets(2));
|
||||||
|
|
||||||
// Cards
|
// Cards
|
||||||
expect(find.widgetWithText(Cards, 'Elevated'), findsOneWidget);
|
expect(find.widgetWithText(Cards, 'Elevated'), findsOneWidget);
|
||||||
@@ -54,7 +54,7 @@ void main() {
|
|||||||
expect(find.widgetWithText(TextField, 'Outlined'), findsNWidgets(2));
|
expect(find.widgetWithText(TextField, 'Outlined'), findsNWidgets(2));
|
||||||
|
|
||||||
// Alert Dialog
|
// Alert Dialog
|
||||||
Finder dialogExample = find.widgetWithText(TextButton, 'Open Dialog');
|
Finder dialogExample = find.widgetWithText(TextButton, 'Show dialog');
|
||||||
expect(dialogExample, findsOneWidget);
|
expect(dialogExample, findsOneWidget);
|
||||||
|
|
||||||
// Switches
|
// Switches
|
||||||
@@ -62,12 +62,13 @@ void main() {
|
|||||||
expect(switchExample, findsNWidgets(4));
|
expect(switchExample, findsNWidgets(4));
|
||||||
|
|
||||||
// Checkboxes
|
// Checkboxes
|
||||||
Finder checkboxExample = find.byType(Checkbox);
|
Finder checkboxExample = find.byType(CheckboxListTile);
|
||||||
expect(checkboxExample, findsNWidgets(8));
|
expect(checkboxExample, findsNWidgets(4));
|
||||||
|
|
||||||
// Radios
|
// Radios
|
||||||
Finder radioExample = find.byType(Radio<Value>);
|
// TODO(guidezpl): Figure out why this isn't working
|
||||||
expect(radioExample, findsNWidgets(2));
|
// Finder radioExample = find.byType(RadioListTile<Value>);
|
||||||
|
// expect(radioExample, findsNWidgets(4));
|
||||||
|
|
||||||
// ProgressIndicator
|
// ProgressIndicator
|
||||||
Finder circularProgressIndicator = find.byType(CircularProgressIndicator);
|
Finder circularProgressIndicator = find.byType(CircularProgressIndicator);
|
||||||
@@ -138,17 +139,17 @@ void main() {
|
|||||||
tester.firstElement(find.widgetWithText(Card, 'Elevated'));
|
tester.firstElement(find.widgetWithText(Card, 'Elevated'));
|
||||||
BuildContext defaultChip =
|
BuildContext defaultChip =
|
||||||
tester.firstElement(find.widgetWithText(ActionChip, 'Assist'));
|
tester.firstElement(find.widgetWithText(ActionChip, 'Assist'));
|
||||||
Finder dialog = find.text('Open Dialog');
|
Finder dialog = find.text('Show dialog');
|
||||||
await tester.tap(dialog);
|
await tester.tap(dialog);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
BuildContext defaultAlertDialog = tester.element(find.byType(AlertDialog));
|
BuildContext defaultAlertDialog = tester.element(find.byType(AlertDialog));
|
||||||
expect(Theme.of(defaultAlertDialog).useMaterial3, true);
|
expect(Theme.of(defaultAlertDialog).useMaterial3, true);
|
||||||
Finder dismiss = find.text('Dismiss');
|
Finder dismiss = find.text('Okay');
|
||||||
await tester.tap(dismiss);
|
await tester.tap(dismiss);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
|
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.filter_3), findsOneWidget);
|
expect(find.widgetWithIcon(AppBar, Icons.filter_2), findsOneWidget);
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.filter_2), findsNothing);
|
expect(find.widgetWithIcon(AppBar, Icons.filter_3), findsNothing);
|
||||||
expect(find.text('Material 3'), findsOneWidget);
|
expect(find.text('Material 3'), findsOneWidget);
|
||||||
expect(Theme.of(defaultElevatedButton).useMaterial3, true);
|
expect(Theme.of(defaultElevatedButton).useMaterial3, true);
|
||||||
expect(Theme.of(defaultIconButton).useMaterial3, true);
|
expect(Theme.of(defaultIconButton).useMaterial3, true);
|
||||||
@@ -158,7 +159,7 @@ void main() {
|
|||||||
|
|
||||||
Finder appbarM3Icon = find.descendant(
|
Finder appbarM3Icon = find.descendant(
|
||||||
of: find.byType(AppBar),
|
of: find.byType(AppBar),
|
||||||
matching: find.widgetWithIcon(IconButton, Icons.filter_3));
|
matching: find.widgetWithIcon(IconButton, Icons.filter_2));
|
||||||
await tester.tap(appbarM3Icon);
|
await tester.tap(appbarM3Icon);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
BuildContext updatedElevatedButton =
|
BuildContext updatedElevatedButton =
|
||||||
@@ -170,7 +171,7 @@ void main() {
|
|||||||
BuildContext updatedCard = tester.firstElement(find.byType(Card));
|
BuildContext updatedCard = tester.firstElement(find.byType(Card));
|
||||||
BuildContext updatedChip =
|
BuildContext updatedChip =
|
||||||
tester.firstElement(find.widgetWithText(ActionChip, 'Assist'));
|
tester.firstElement(find.widgetWithText(ActionChip, 'Assist'));
|
||||||
Finder updatedDialog = find.text('Open Dialog');
|
Finder updatedDialog = find.text('Show dialog');
|
||||||
await tester.tap(updatedDialog);
|
await tester.tap(updatedDialog);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
BuildContext updatedAlertDialog =
|
BuildContext updatedAlertDialog =
|
||||||
@@ -180,8 +181,8 @@ void main() {
|
|||||||
await tester.tap(updatedDismiss);
|
await tester.tap(updatedDismiss);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
|
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.filter_2), findsOneWidget);
|
expect(find.widgetWithIcon(AppBar, Icons.filter_3), findsOneWidget);
|
||||||
expect(find.widgetWithIcon(AppBar, Icons.filter_3), findsNothing);
|
expect(find.widgetWithIcon(AppBar, Icons.filter_2), findsNothing);
|
||||||
expect(find.text('Material 2'), findsOneWidget);
|
expect(find.text('Material 2'), findsOneWidget);
|
||||||
expect(Theme.of(updatedElevatedButton).useMaterial3, false);
|
expect(Theme.of(updatedElevatedButton).useMaterial3, false);
|
||||||
expect(Theme.of(updatedIconButton).useMaterial3, false);
|
expect(Theme.of(updatedIconButton).useMaterial3, false);
|
||||||
@@ -194,10 +195,10 @@ void main() {
|
|||||||
'Other screens become Material2 mode after changing mode from '
|
'Other screens become Material2 mode after changing mode from '
|
||||||
'main screen', (tester) async {
|
'main screen', (tester) async {
|
||||||
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
||||||
Finder appbarM3Icon = find.descendant(
|
Finder appbarM2Icon = find.descendant(
|
||||||
of: find.byType(AppBar),
|
of: find.byType(AppBar),
|
||||||
matching: find.widgetWithIcon(IconButton, Icons.filter_3));
|
matching: find.widgetWithIcon(IconButton, Icons.filter_2));
|
||||||
await tester.tap(appbarM3Icon);
|
await tester.tap(appbarM2Icon);
|
||||||
Finder secondScreenIcon = find.descendant(
|
Finder secondScreenIcon = find.descendant(
|
||||||
of: find.byType(NavigationBar),
|
of: find.byType(NavigationBar),
|
||||||
matching: find.widgetWithIcon(
|
matching: find.widgetWithIcon(
|
||||||
@@ -230,27 +231,27 @@ void main() {
|
|||||||
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
||||||
Finder lightIcon = find.descendant(
|
Finder lightIcon = find.descendant(
|
||||||
of: find.byType(AppBar),
|
of: find.byType(AppBar),
|
||||||
matching: find.widgetWithIcon(IconButton, Icons.wb_sunny_outlined));
|
matching: find.widgetWithIcon(IconButton, Icons.light_mode_outlined));
|
||||||
Finder darkIcon = find.descendant(
|
Finder darkIcon = find.descendant(
|
||||||
of: find.byType(AppBar),
|
of: find.byType(AppBar),
|
||||||
matching: find.widgetWithIcon(IconButton, Icons.wb_sunny));
|
matching: find.widgetWithIcon(IconButton, Icons.dark_mode_outlined));
|
||||||
BuildContext appBar = tester.element(find.byType(AppBar).first);
|
BuildContext appBar = tester.element(find.byType(AppBar).first);
|
||||||
BuildContext body = tester.firstElement(find.byType(Scaffold).first);
|
BuildContext body = tester.firstElement(find.byType(Scaffold).first);
|
||||||
BuildContext navigationRail = tester.element(
|
BuildContext navigationRail = tester.element(
|
||||||
find.widgetWithIcon(NavigationRail, Icons.format_paint_outlined));
|
find.widgetWithIcon(NavigationRail, Icons.format_paint_outlined));
|
||||||
expect(lightIcon, findsOneWidget);
|
expect(darkIcon, findsOneWidget);
|
||||||
expect(darkIcon, findsNothing);
|
expect(lightIcon, findsNothing);
|
||||||
expect(Theme.of(appBar).brightness, Brightness.light);
|
expect(Theme.of(appBar).brightness, Brightness.light);
|
||||||
expect(Theme.of(body).brightness, Brightness.light);
|
expect(Theme.of(body).brightness, Brightness.light);
|
||||||
expect(Theme.of(navigationRail).brightness, Brightness.light);
|
expect(Theme.of(navigationRail).brightness, Brightness.light);
|
||||||
await tester.tap(lightIcon);
|
await tester.tap(darkIcon);
|
||||||
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
||||||
|
|
||||||
BuildContext appBar2 = tester.element(find.byType(AppBar).first);
|
BuildContext appBar2 = tester.element(find.byType(AppBar).first);
|
||||||
BuildContext body2 = tester.element(find.byType(Scaffold).first);
|
BuildContext body2 = tester.element(find.byType(Scaffold).first);
|
||||||
BuildContext navigationRail2 = tester.element(find.byType(NavigationRail));
|
BuildContext navigationRail2 = tester.element(find.byType(NavigationRail));
|
||||||
expect(lightIcon, findsNothing);
|
expect(darkIcon, findsNothing);
|
||||||
expect(darkIcon, findsOneWidget);
|
expect(lightIcon, findsOneWidget);
|
||||||
expect(Theme.of(appBar2).brightness, Brightness.dark);
|
expect(Theme.of(appBar2).brightness, Brightness.dark);
|
||||||
expect(Theme.of(body2).brightness, Brightness.dark);
|
expect(Theme.of(body2).brightness, Brightness.dark);
|
||||||
expect(Theme.of(navigationRail2).brightness, Brightness.dark);
|
expect(Theme.of(navigationRail2).brightness, Brightness.dark);
|
||||||
@@ -264,7 +265,7 @@ void main() {
|
|||||||
await tester.pump();
|
await tester.pump();
|
||||||
Finder menuIcon = find.descendant(
|
Finder menuIcon = find.descendant(
|
||||||
of: find.byType(AppBar),
|
of: find.byType(AppBar),
|
||||||
matching: find.widgetWithIcon(IconButton, Icons.more_vert));
|
matching: find.widgetWithIcon(IconButton, Icons.palette_outlined));
|
||||||
BuildContext appBar = tester.element(find.byType(AppBar).first);
|
BuildContext appBar = tester.element(find.byType(AppBar).first);
|
||||||
BuildContext body = tester.element(find.byType(Scaffold).first);
|
BuildContext body = tester.element(find.byType(Scaffold).first);
|
||||||
BuildContext navigationRail = tester.element(find.byType(NavigationRail));
|
BuildContext navigationRail = tester.element(find.byType(NavigationRail));
|
||||||
|
|||||||
Reference in New Issue
Block a user