Unverified Commit 3dc8898e authored by Shi-Hao Hong's avatar Shi-Hao Hong Committed by GitHub

Revert "Default colorScheme data in ButtonThemeData (Fix for #38655) (#39627)" (#42854)

This reverts commit 19899db2.
parent 0a7e6056
...@@ -83,7 +83,7 @@ class ButtonTheme extends InheritedTheme { ...@@ -83,7 +83,7 @@ class ButtonTheme extends InheritedTheme {
Color hoverColor, Color hoverColor,
Color highlightColor, Color highlightColor,
Color splashColor, Color splashColor,
ColorScheme colorScheme = const ColorScheme.light(), ColorScheme colorScheme,
MaterialTapTargetSize materialTapTargetSize, MaterialTapTargetSize materialTapTargetSize,
Widget child, Widget child,
}) : assert(textTheme != null), }) : assert(textTheme != null),
...@@ -91,7 +91,6 @@ class ButtonTheme extends InheritedTheme { ...@@ -91,7 +91,6 @@ class ButtonTheme extends InheritedTheme {
assert(height != null && height >= 0.0), assert(height != null && height >= 0.0),
assert(alignedDropdown != null), assert(alignedDropdown != null),
assert(layoutBehavior != null), assert(layoutBehavior != null),
assert(colorScheme != null),
data = ButtonThemeData( data = ButtonThemeData(
textTheme: textTheme, textTheme: textTheme,
minWidth: minWidth, minWidth: minWidth,
...@@ -180,14 +179,13 @@ class ButtonTheme extends InheritedTheme { ...@@ -180,14 +179,13 @@ class ButtonTheme extends InheritedTheme {
Color hoverColor, Color hoverColor,
Color highlightColor, Color highlightColor,
Color splashColor, Color splashColor,
ColorScheme colorScheme = const ColorScheme.light(), ColorScheme colorScheme,
Widget child, Widget child,
ButtonBarLayoutBehavior layoutBehavior = ButtonBarLayoutBehavior.padded, ButtonBarLayoutBehavior layoutBehavior = ButtonBarLayoutBehavior.padded,
}) : assert(textTheme != null), }) : assert(textTheme != null),
assert(minWidth != null && minWidth >= 0.0), assert(minWidth != null && minWidth >= 0.0),
assert(height != null && height >= 0.0), assert(height != null && height >= 0.0),
assert(alignedDropdown != null), assert(alignedDropdown != null),
assert(colorScheme != null),
data = ButtonThemeData( data = ButtonThemeData(
textTheme: textTheme, textTheme: textTheme,
minWidth: minWidth, minWidth: minWidth,
...@@ -219,13 +217,15 @@ class ButtonTheme extends InheritedTheme { ...@@ -219,13 +217,15 @@ class ButtonTheme extends InheritedTheme {
static ButtonThemeData of(BuildContext context) { static ButtonThemeData of(BuildContext context) {
final ButtonTheme inheritedButtonTheme = context.inheritFromWidgetOfExactType(ButtonTheme); final ButtonTheme inheritedButtonTheme = context.inheritFromWidgetOfExactType(ButtonTheme);
ButtonThemeData buttonTheme = inheritedButtonTheme?.data; ButtonThemeData buttonTheme = inheritedButtonTheme?.data;
if (buttonTheme == null) { if (buttonTheme?.colorScheme == null) { // if buttonTheme or buttonTheme.colorScheme is null
final ThemeData theme = Theme.of(context); final ThemeData theme = Theme.of(context);
buttonTheme ??= theme.buttonTheme; buttonTheme ??= theme.buttonTheme;
buttonTheme = buttonTheme.copyWith( if (buttonTheme.colorScheme == null) {
colorScheme: theme.buttonTheme.colorScheme ?? const ColorScheme.light(), buttonTheme = buttonTheme.copyWith(
); colorScheme: theme.buttonTheme.colorScheme ?? theme.colorScheme,
assert(buttonTheme.colorScheme != null); );
assert(buttonTheme.colorScheme != null);
}
} }
return buttonTheme; return buttonTheme;
} }
...@@ -270,14 +270,13 @@ class ButtonThemeData extends Diagnosticable { ...@@ -270,14 +270,13 @@ class ButtonThemeData extends Diagnosticable {
Color hoverColor, Color hoverColor,
Color highlightColor, Color highlightColor,
Color splashColor, Color splashColor,
this.colorScheme = const ColorScheme.light(), this.colorScheme,
MaterialTapTargetSize materialTapTargetSize, MaterialTapTargetSize materialTapTargetSize,
}) : assert(textTheme != null), }) : assert(textTheme != null),
assert(minWidth != null && minWidth >= 0.0), assert(minWidth != null && minWidth >= 0.0),
assert(height != null && height >= 0.0), assert(height != null && height >= 0.0),
assert(alignedDropdown != null), assert(alignedDropdown != null),
assert(layoutBehavior != null), assert(layoutBehavior != null),
assert(colorScheme != null),
_buttonColor = buttonColor, _buttonColor = buttonColor,
_disabledColor = disabledColor, _disabledColor = disabledColor,
_focusColor = focusColor, _focusColor = focusColor,
......
...@@ -18,7 +18,6 @@ void main() { ...@@ -18,7 +18,6 @@ void main() {
)); ));
expect(theme.alignedDropdown, false); expect(theme.alignedDropdown, false);
expect(theme.layoutBehavior, ButtonBarLayoutBehavior.padded); expect(theme.layoutBehavior, ButtonBarLayoutBehavior.padded);
expect(theme.colorScheme, const ColorScheme.light());
}); });
test('ButtonThemeData default overrides', () { test('ButtonThemeData default overrides', () {
...@@ -29,14 +28,12 @@ void main() { ...@@ -29,14 +28,12 @@ void main() {
padding: EdgeInsets.zero, padding: EdgeInsets.zero,
shape: RoundedRectangleBorder(), shape: RoundedRectangleBorder(),
alignedDropdown: true, alignedDropdown: true,
colorScheme: ColorScheme.dark()
); );
expect(theme.textTheme, ButtonTextTheme.primary); expect(theme.textTheme, ButtonTextTheme.primary);
expect(theme.constraints, const BoxConstraints(minWidth: 100.0, minHeight: 200.0)); expect(theme.constraints, const BoxConstraints(minWidth: 100.0, minHeight: 200.0));
expect(theme.padding, EdgeInsets.zero); expect(theme.padding, EdgeInsets.zero);
expect(theme.shape, const RoundedRectangleBorder()); expect(theme.shape, const RoundedRectangleBorder());
expect(theme.alignedDropdown, true); expect(theme.alignedDropdown, true);
expect(theme.colorScheme, const ColorScheme.dark());
}); });
testWidgets('ButtonTheme defaults', (WidgetTester tester) async { testWidgets('ButtonTheme defaults', (WidgetTester tester) async {
...@@ -83,7 +80,7 @@ void main() { ...@@ -83,7 +80,7 @@ void main() {
borderRadius: BorderRadius.all(Radius.circular(2.0)), borderRadius: BorderRadius.all(Radius.circular(2.0)),
)); ));
expect(alignedDropdown, false); expect(alignedDropdown, false);
expect(colorScheme, const ColorScheme.light()); expect(colorScheme, ThemeData.light().colorScheme);
expect(tester.widget<Material>(find.byType(Material)).shape, shape); expect(tester.widget<Material>(find.byType(Material)).shape, shape);
expect(tester.getSize(find.byType(Material)), const Size(88.0, 36.0)); expect(tester.getSize(find.byType(Material)), const Size(88.0, 36.0));
}); });
...@@ -98,7 +95,7 @@ void main() { ...@@ -98,7 +95,7 @@ void main() {
borderRadius: BorderRadius.all(Radius.circular(2.0)), borderRadius: BorderRadius.all(Radius.circular(2.0)),
)); ));
expect(theme.alignedDropdown, false); expect(theme.alignedDropdown, false);
expect(theme.colorScheme, const ColorScheme.light()); expect(theme.colorScheme, null);
theme = const ButtonThemeData().copyWith( theme = const ButtonThemeData().copyWith(
textTheme: ButtonTextTheme.primary, textTheme: ButtonTextTheme.primary,
...@@ -405,80 +402,4 @@ void main() { ...@@ -405,80 +402,4 @@ void main() {
}, },
semanticsEnabled: true, semanticsEnabled: true,
); );
testWidgets('Default RaisedButton text color when textTheme is set to ButtonTextTheme.accent', (WidgetTester tester) async {
// Test for https://github.com/flutter/flutter/issues/38655
const Color defaultEnabledAccentTextColor = Color(0xff2196f3);
await tester.pumpWidget(
MaterialApp(
home: Scaffold(
body: Center(
child: RaisedButton(
child: const Text('RaisedButton'),
onPressed: () {},
textTheme: ButtonTextTheme.accent,
),
),
),
),
);
Color getRaisedButtonTextColor() {
return tester.renderObject<RenderParagraph>(find.text('RaisedButton')).text.style.color;
}
expect(getRaisedButtonTextColor(), equals(defaultEnabledAccentTextColor));
});
testWidgets('default button theme primary color for RaisedButton', (WidgetTester tester) async {
// Test for https://github.com/flutter/flutter/issues/38655
const Color defaultEnabledPrimaryTextColor = Color(0xff000000);
await tester.pumpWidget(
MaterialApp(
home: Scaffold(
body: Center(
child: RaisedButton(
child: const Text('RaisedButton'),
onPressed: () {},
textTheme: ButtonTextTheme.primary,
),
),
),
),
);
Color getRaisedButtonTextColor() {
return tester.renderObject<RenderParagraph>(find.text('RaisedButton')).text.style.color;
}
expect(getRaisedButtonTextColor(), equals(defaultEnabledPrimaryTextColor));
});
testWidgets('default button theme normal color for RaisedButton', (WidgetTester tester) async {
// Test for https://github.com/flutter/flutter/issues/38655
const Color defaultEnabledNormalTextColor = Color(0xffffffff);
await tester.pumpWidget(
MaterialApp(
theme: ThemeData.dark(),
home: Scaffold(
body: Center(
child: RaisedButton(
child: const Text('RaisedButton'),
onPressed: () {},
textTheme: ButtonTextTheme.normal
),
),
),
),
);
Color getRaisedButtonTextColor() {
return tester.renderObject<RenderParagraph>(find.text('RaisedButton')).text.style.color;
}
expect(getRaisedButtonTextColor(), equals(defaultEnabledNormalTextColor));
});
} }
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