Unverified Commit f3b1e31c authored by Hans Muller's avatar Hans Muller Committed by GitHub

Remove old button references from the Stepper widget (#63012)

parent bd3a4cc5
...@@ -6,14 +6,16 @@ ...@@ -6,14 +6,16 @@
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'button_theme.dart'; import 'button_style.dart';
import 'color_scheme.dart';
import 'colors.dart'; import 'colors.dart';
import 'debug.dart'; import 'debug.dart';
import 'flat_button.dart';
import 'icons.dart'; import 'icons.dart';
import 'ink_well.dart'; import 'ink_well.dart';
import 'material.dart'; import 'material.dart';
import 'material_localizations.dart'; import 'material_localizations.dart';
import 'material_state.dart';
import 'text_button.dart';
import 'text_theme.dart'; import 'text_theme.dart';
import 'theme.dart'; import 'theme.dart';
...@@ -191,7 +193,7 @@ class Stepper extends StatefulWidget { ...@@ -191,7 +193,7 @@ class Stepper extends StatefulWidget {
/// ///
/// If null, the default controls from the current theme will be used. /// If null, the default controls from the current theme will be used.
/// ///
/// This callback which takes in a context and two functions,[onStepContinue] /// This callback which takes in a context and two functions: [onStepContinue]
/// and [onStepCancel]. These can be used to control the stepper. /// and [onStepCancel]. These can be used to control the stepper.
/// ///
/// {@tool dartpad --template=stateless_widget_scaffold} /// {@tool dartpad --template=stateless_widget_scaffold}
...@@ -201,14 +203,14 @@ class Stepper extends StatefulWidget { ...@@ -201,14 +203,14 @@ class Stepper extends StatefulWidget {
/// Widget build(BuildContext context) { /// Widget build(BuildContext context) {
/// return Stepper( /// return Stepper(
/// controlsBuilder: /// controlsBuilder:
/// (BuildContext context, {VoidCallback onStepContinue, VoidCallback onStepCancel}) { /// (BuildContext context, { VoidCallback onStepContinue, VoidCallback onStepCancel }) {
/// return Row( /// return Row(
/// children: <Widget>[ /// children: <Widget>[
/// FlatButton( /// TextButton(
/// onPressed: onStepContinue, /// onPressed: onStepContinue,
/// child: const Text('NEXT'), /// child: const Text('NEXT'),
/// ), /// ),
/// FlatButton( /// TextButton(
/// onPressed: onStepCancel, /// onPressed: onStepCancel,
/// child: const Text('CANCEL'), /// child: const Text('CANCEL'),
/// ), /// ),
...@@ -407,27 +409,44 @@ class _StepperState extends State<Stepper> with TickerProviderStateMixin { ...@@ -407,27 +409,44 @@ class _StepperState extends State<Stepper> with TickerProviderStateMixin {
assert(cancelColor != null); assert(cancelColor != null);
final ThemeData themeData = Theme.of(context); final ThemeData themeData = Theme.of(context);
final ColorScheme colorScheme = themeData.colorScheme;
final MaterialLocalizations localizations = MaterialLocalizations.of(context); final MaterialLocalizations localizations = MaterialLocalizations.of(context);
const OutlinedBorder buttonShape = RoundedRectangleBorder(borderRadius: BorderRadius.all(Radius.circular(2)));
const EdgeInsets buttonPadding = EdgeInsets.symmetric(horizontal: 16.0);
return Container( return Container(
margin: const EdgeInsets.only(top: 16.0), margin: const EdgeInsets.only(top: 16.0),
child: ConstrainedBox( child: ConstrainedBox(
constraints: const BoxConstraints.tightFor(height: 48.0), constraints: const BoxConstraints.tightFor(height: 48.0),
child: Row( child: Row(
// The Material spec no longer includes a Stepper widget. The continue
// and cancel button styles have been configured to match the original
// version of this widget.
children: <Widget>[ children: <Widget>[
FlatButton( TextButton(
onPressed: widget.onStepContinue, onPressed: widget.onStepContinue,
color: _isDark() ? themeData.backgroundColor : themeData.primaryColor, style: ButtonStyle(
textColor: Colors.white, foregroundColor: MaterialStateProperty.resolveWith<Color>((Set<MaterialState> states) {
textTheme: ButtonTextTheme.normal, return states.contains(MaterialState.disabled) ? null : (_isDark() ? colorScheme.onSurface : colorScheme.onPrimary);
}),
backgroundColor: MaterialStateProperty.resolveWith<Color>((Set<MaterialState> states) {
return _isDark() || states.contains(MaterialState.disabled) ? null : colorScheme.primary;
}),
padding: MaterialStateProperty.all<EdgeInsetsGeometry>(buttonPadding),
shape: MaterialStateProperty.all<OutlinedBorder>(buttonShape),
),
child: Text(localizations.continueButtonLabel), child: Text(localizations.continueButtonLabel),
), ),
Container( Container(
margin: const EdgeInsetsDirectional.only(start: 8.0), margin: const EdgeInsetsDirectional.only(start: 8.0),
child: FlatButton( child: TextButton(
onPressed: widget.onStepCancel, onPressed: widget.onStepCancel,
textColor: cancelColor, style: TextButton.styleFrom(
textTheme: ButtonTextTheme.normal, primary: cancelColor,
padding: buttonPadding,
shape: buttonShape,
),
child: Text(localizations.cancelButtonLabel), child: Text(localizations.cancelButtonLabel),
), ),
), ),
......
...@@ -390,19 +390,14 @@ void main() { ...@@ -390,19 +390,14 @@ void main() {
constraints: const BoxConstraints.tightFor(height: 48.0), constraints: const BoxConstraints.tightFor(height: 48.0),
child: Row( child: Row(
children: <Widget>[ children: <Widget>[
FlatButton( TextButton(
onPressed: onStepContinue, onPressed: onStepContinue,
color: Colors.blue,
textColor: Colors.white,
textTheme: ButtonTextTheme.normal,
child: const Text('Let us continue!'), child: const Text('Let us continue!'),
), ),
Container( Container(
margin: const EdgeInsetsDirectional.only(start: 8.0), margin: const EdgeInsetsDirectional.only(start: 8.0),
child: FlatButton( child: TextButton(
onPressed: onStepCancel, onPressed: onStepCancel,
textColor: Colors.red,
textTheme: ButtonTextTheme.normal,
child: const Text('Cancel This!'), child: const Text('Cancel This!'),
), ),
), ),
...@@ -716,4 +711,110 @@ void main() { ...@@ -716,4 +711,110 @@ void main() {
expect(tester.takeException(), isNull); expect(tester.takeException(), isNull);
}); });
testWidgets('Stepper enabled button styles', (WidgetTester tester) async {
Widget buildFrame(ThemeData theme) {
return MaterialApp(
theme: theme,
home: Material(
child: Stepper(
type: StepperType.horizontal,
onStepCancel: () { },
onStepContinue: () { },
steps: const <Step>[
Step(
title: Text('step1'),
content: SizedBox(width: 100, height: 100),
),
],
),
),
);
}
Material buttonMaterial(String label) {
return tester.widget<Material>(
find.descendant(of: find.widgetWithText(TextButton, label), matching: find.byType(Material))
);
}
// The checks that follow verify that the layout and appearance of
// the default enabled Stepper buttons have not changed even
// though the FlatButtons have been replaced by TextButtons.
const OutlinedBorder buttonShape = RoundedRectangleBorder(borderRadius: BorderRadius.all(Radius.circular(2)));
const Rect continueButtonRect = Rect.fromLTRB(24.0, 212.0, 168.0, 260.0);
const Rect cancelButtonRect = Rect.fromLTRB(176.0, 212.0, 292.0, 260.0);
await tester.pumpWidget(buildFrame(ThemeData.light()));
expect(buttonMaterial('CONTINUE').color.value, 0xff2196f3);
expect(buttonMaterial('CONTINUE').textStyle.color.value, 0xffffffff);
expect(buttonMaterial('CONTINUE').shape, buttonShape);
expect(tester.getRect(find.widgetWithText(TextButton, 'CONTINUE')), continueButtonRect);
expect(buttonMaterial('CANCEL').color.value, 0);
expect(buttonMaterial('CANCEL').textStyle.color.value, 0x8a000000);
expect(buttonMaterial('CANCEL').shape, buttonShape);
expect(tester.getRect(find.widgetWithText(TextButton, 'CANCEL')), cancelButtonRect);
await tester.pumpWidget(buildFrame(ThemeData.dark()));
await tester.pumpAndSettle(); // Complete the theme animation.
expect(buttonMaterial('CONTINUE').color.value, 0);
expect(buttonMaterial('CONTINUE').textStyle.color.value, 0xffffffff);
expect(buttonMaterial('CONTINUE').shape, buttonShape);
expect(tester.getRect(find.widgetWithText(TextButton, 'CONTINUE')), continueButtonRect);
expect(buttonMaterial('CANCEL').color.value, 0);
expect(buttonMaterial('CANCEL').textStyle.color.value, 0xb3ffffff);
expect(buttonMaterial('CANCEL').shape, buttonShape);
expect(tester.getRect(find.widgetWithText(TextButton, 'CANCEL')), cancelButtonRect);
});
testWidgets('Stepper disabled button styles', (WidgetTester tester) async {
Widget buildFrame(ThemeData theme) {
return MaterialApp(
theme: theme,
home: Material(
child: Stepper(
type: StepperType.horizontal,
steps: const <Step>[
Step(
title: Text('step1'),
content: SizedBox(width: 100, height: 100),
),
],
),
),
);
}
Material buttonMaterial(String label) {
return tester.widget<Material>(
find.descendant(of: find.widgetWithText(TextButton, label), matching: find.byType(Material))
);
}
// The checks that follow verify that the appearance of the
// default disabled Stepper buttons have not changed even though
// the FlatButtons have been replaced by TextButtons.
await tester.pumpWidget(buildFrame(ThemeData.light()));
expect(buttonMaterial('CONTINUE').color.value, 0);
expect(buttonMaterial('CONTINUE').textStyle.color.value, 0x61000000);
expect(buttonMaterial('CANCEL').color.value, 0);
expect(buttonMaterial('CANCEL').textStyle.color.value, 0x61000000);
await tester.pumpWidget(buildFrame(ThemeData.dark()));
await tester.pumpAndSettle(); // Complete the theme animation.
expect(buttonMaterial('CONTINUE').color.value, 0);
expect(buttonMaterial('CONTINUE').textStyle.color.value, 0x61ffffff);
expect(buttonMaterial('CANCEL').color.value, 0);
expect(buttonMaterial('CANCEL').textStyle.color.value, 0x61ffffff);
});
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment