Commit 4399fea1 authored by Adam Barth's avatar Adam Barth

Icons in material buttons should match text color (#3551)

Fixes #3186
parent c6942c99
...@@ -7,6 +7,8 @@ import 'package:flutter/widgets.dart'; ...@@ -7,6 +7,8 @@ import 'package:flutter/widgets.dart';
import 'colors.dart'; import 'colors.dart';
import 'constants.dart'; import 'constants.dart';
import 'debug.dart'; import 'debug.dart';
import 'icon_theme_data.dart';
import 'icon_theme.dart';
import 'ink_well.dart'; import 'ink_well.dart';
import 'material.dart'; import 'material.dart';
import 'theme.dart'; import 'theme.dart';
...@@ -168,7 +170,12 @@ abstract class MaterialButtonState<T extends MaterialButton> extends State<T> { ...@@ -168,7 +170,12 @@ abstract class MaterialButtonState<T extends MaterialButton> extends State<T> {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
assert(debugCheckHasMaterial(context)); assert(debugCheckHasMaterial(context));
Widget contents = new InkWell( final Color textColor = _getTextColor(context);
Widget contents = new IconTheme(
data: new IconThemeData(
color: textColor
),
child: new InkWell(
onTap: config.onPressed, onTap: config.onPressed,
onHighlightChanged: _handleHighlightChanged, onHighlightChanged: _handleHighlightChanged,
child: new Container( child: new Container(
...@@ -178,14 +185,15 @@ abstract class MaterialButtonState<T extends MaterialButton> extends State<T> { ...@@ -178,14 +185,15 @@ abstract class MaterialButtonState<T extends MaterialButton> extends State<T> {
child: config.child child: config.child
) )
) )
)
); );
TextStyle style = Theme.of(context).textTheme.button.copyWith(color: _getTextColor(context)); final TextStyle style = Theme.of(context).textTheme.button.copyWith(color: textColor);
int elevation = this.elevation; final int elevation = this.elevation;
Color color = getColor(context); final Color color = getColor(context);
if (elevation > 0 || color != null) { if (elevation > 0 || color != null) {
contents = new Material( contents = new Material(
type: MaterialType.button, type: MaterialType.button,
color: getColor(context), color: color,
elevation: elevation, elevation: elevation,
textStyle: style, textStyle: style,
child: contents child: contents
......
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