Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
0f57cd26
Unverified
Commit
0f57cd26
authored
Jul 13, 2020
by
Hans Muller
Committed by
GitHub
Jul 13, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make ThemeData.shadowColor the default shadowColor in TextButton et al. (#61371)
parent
f8135add
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
221 additions
and
16 deletions
+221
-16
elevated_button.dart
packages/flutter/lib/src/material/elevated_button.dart
+2
-3
outlined_button.dart
packages/flutter/lib/src/material/outlined_button.dart
+2
-2
text_button.dart
packages/flutter/lib/src/material/text_button.dart
+2
-2
theme_data.dart
packages/flutter/lib/src/material/theme_data.dart
+4
-8
elevated_button_theme_test.dart
...ges/flutter/test/material/elevated_button_theme_test.dart
+70
-0
outlined_button_theme_test.dart
...ges/flutter/test/material/outlined_button_theme_test.dart
+71
-1
text_button_theme_test.dart
packages/flutter/test/material/text_button_theme_test.dart
+70
-0
No files found.
packages/flutter/lib/src/material/elevated_button.dart
View file @
0f57cd26
...
@@ -14,7 +14,6 @@ import 'package:flutter/widgets.dart';
...
@@ -14,7 +14,6 @@ import 'package:flutter/widgets.dart';
import
'button_style.dart'
;
import
'button_style.dart'
;
import
'button_style_button.dart'
;
import
'button_style_button.dart'
;
import
'color_scheme.dart'
;
import
'color_scheme.dart'
;
import
'colors.dart'
;
import
'constants.dart'
;
import
'constants.dart'
;
import
'elevated_button_theme.dart'
;
import
'elevated_button_theme.dart'
;
import
'material_state.dart'
;
import
'material_state.dart'
;
...
@@ -220,7 +219,7 @@ class ElevatedButton extends ButtonStyleButton {
...
@@ -220,7 +219,7 @@ class ElevatedButton extends ButtonStyleButton {
/// * `overlayColor`
/// * `overlayColor`
/// * hovered - Theme.colorScheme.onPrimary(0.08)
/// * hovered - Theme.colorScheme.onPrimary(0.08)
/// * focused or pressed - Theme.colorScheme.onPrimary(0.24)
/// * focused or pressed - Theme.colorScheme.onPrimary(0.24)
/// * `shadowColor` -
Colors.black
/// * `shadowColor` -
Theme.shadowColor
/// * `elevation`
/// * `elevation`
/// * disabled - 0
/// * disabled - 0
/// * hovered or focused - 2
/// * hovered or focused - 2
...
@@ -264,7 +263,7 @@ class ElevatedButton extends ButtonStyleButton {
...
@@ -264,7 +263,7 @@ class ElevatedButton extends ButtonStyleButton {
primary:
colorScheme
.
primary
,
primary:
colorScheme
.
primary
,
onPrimary:
colorScheme
.
onPrimary
,
onPrimary:
colorScheme
.
onPrimary
,
onSurface:
colorScheme
.
onSurface
,
onSurface:
colorScheme
.
onSurface
,
shadowColor:
Colors
.
black
,
shadowColor:
theme
.
shadowColor
,
elevation:
2
,
elevation:
2
,
textStyle:
theme
.
textTheme
.
button
,
textStyle:
theme
.
textTheme
.
button
,
padding:
scaledPadding
,
padding:
scaledPadding
,
...
...
packages/flutter/lib/src/material/outlined_button.dart
View file @
0f57cd26
...
@@ -202,7 +202,7 @@ class OutlinedButton extends ButtonStyleButton {
...
@@ -202,7 +202,7 @@ class OutlinedButton extends ButtonStyleButton {
/// * `overlayColor`
/// * `overlayColor`
/// * hovered - Theme.colorScheme.primary(0.04)
/// * hovered - Theme.colorScheme.primary(0.04)
/// * focused or pressed - Theme.colorScheme.primary(0.12)
/// * focused or pressed - Theme.colorScheme.primary(0.12)
/// * `shadowColor` -
Colors.black
/// * `shadowColor` -
Theme.shadowColor
/// * `elevation` - 0
/// * `elevation` - 0
/// * `padding`
/// * `padding`
/// * `textScaleFactor <= 1` - horizontal(16)
/// * `textScaleFactor <= 1` - horizontal(16)
...
@@ -235,7 +235,7 @@ class OutlinedButton extends ButtonStyleButton {
...
@@ -235,7 +235,7 @@ class OutlinedButton extends ButtonStyleButton {
primary:
colorScheme
.
primary
,
primary:
colorScheme
.
primary
,
onSurface:
colorScheme
.
onSurface
,
onSurface:
colorScheme
.
onSurface
,
backgroundColor:
Colors
.
transparent
,
backgroundColor:
Colors
.
transparent
,
shadowColor:
Colors
.
black
,
shadowColor:
theme
.
shadowColor
,
elevation:
0
,
elevation:
0
,
textStyle:
theme
.
textTheme
.
button
,
textStyle:
theme
.
textTheme
.
button
,
padding:
scaledPadding
,
padding:
scaledPadding
,
...
...
packages/flutter/lib/src/material/text_button.dart
View file @
0f57cd26
...
@@ -211,7 +211,7 @@ class TextButton extends ButtonStyleButton {
...
@@ -211,7 +211,7 @@ class TextButton extends ButtonStyleButton {
/// * `overlayColor`
/// * `overlayColor`
/// * hovered - Theme.colorScheme.primary(0.04)
/// * hovered - Theme.colorScheme.primary(0.04)
/// * focused or pressed - Theme.colorScheme.primary(0.12)
/// * focused or pressed - Theme.colorScheme.primary(0.12)
/// * `shadowColor` -
Colors.black
/// * `shadowColor` -
Theme.shadowColor
/// * `elevation` - 0
/// * `elevation` - 0
/// * `padding`
/// * `padding`
/// * `textScaleFactor <= 1` - all(8)
/// * `textScaleFactor <= 1` - all(8)
...
@@ -251,7 +251,7 @@ class TextButton extends ButtonStyleButton {
...
@@ -251,7 +251,7 @@ class TextButton extends ButtonStyleButton {
primary:
colorScheme
.
primary
,
primary:
colorScheme
.
primary
,
onSurface:
colorScheme
.
onSurface
,
onSurface:
colorScheme
.
onSurface
,
backgroundColor:
Colors
.
transparent
,
backgroundColor:
Colors
.
transparent
,
shadowColor:
Colors
.
black
,
shadowColor:
theme
.
shadowColor
,
elevation:
0
,
elevation:
0
,
textStyle:
theme
.
textTheme
.
button
,
textStyle:
theme
.
textTheme
.
button
,
padding:
scaledPadding
,
padding:
scaledPadding
,
...
...
packages/flutter/lib/src/material/theme_data.dart
View file @
0f57cd26
...
@@ -764,19 +764,15 @@ class ThemeData with Diagnosticable {
...
@@ -764,19 +764,15 @@ class ThemeData with Diagnosticable {
/// The default color of [MaterialType.canvas] [Material].
/// The default color of [MaterialType.canvas] [Material].
final
Color
canvasColor
;
final
Color
canvasColor
;
/// The color that [Material] widget uses to draw elevation shadows.
/// The color that
the
[Material] widget uses to draw elevation shadows.
///
///
/// Defaults to fully opaque black.
/// Defaults to fully opaque black.
///
///
/// Shadows can be difficult to see in a dark theme, so the elevation of a
/// Shadows can be difficult to see in a dark theme, so the elevation of a
/// surface should be
portray
ed with an "overlay" in addition to the shadow.
/// surface should be
render
ed with an "overlay" in addition to the shadow.
/// As the elevation of the component increases, the overlay increases in
/// As the elevation of the component increases, the overlay increases in
/// opacity.
/// opacity. The [applyElevationOverlayColor] property turns the elevation
///
/// overlay on or off for dark themes.
/// See also:
///
/// * [applyElevationOverlayColor], which turns elevation overlay on or off
/// for dark themes.
final
Color
shadowColor
;
final
Color
shadowColor
;
/// The foreground color for widgets (knobs, text, overscroll edge effect, etc).
/// The foreground color for widgets (knobs, text, overscroll edge effect, etc).
...
...
packages/flutter/test/material/elevated_button_theme_test.dart
View file @
0f57cd26
...
@@ -179,4 +179,74 @@ void main() {
...
@@ -179,4 +179,74 @@ void main() {
checkButton
(
tester
);
checkButton
(
tester
);
});
});
});
});
testWidgets
(
'Theme shadowColor'
,
(
WidgetTester
tester
)
async
{
const
ColorScheme
colorScheme
=
ColorScheme
.
light
();
const
Color
shadowColor
=
Color
(
0xff000001
);
const
Color
overiddenColor
=
Color
(
0xff000002
);
Widget
buildFrame
({
Color
overallShadowColor
,
Color
themeShadowColor
,
Color
shadowColor
})
{
return
MaterialApp
(
theme:
ThemeData
.
from
(
colorScheme:
colorScheme
).
copyWith
(
shadowColor:
overallShadowColor
,
),
home:
Scaffold
(
body:
Center
(
child:
ElevatedButtonTheme
(
data:
ElevatedButtonThemeData
(
style:
ElevatedButton
.
styleFrom
(
shadowColor:
themeShadowColor
,
),
),
child:
Builder
(
builder:
(
BuildContext
context
)
{
return
ElevatedButton
(
style:
ElevatedButton
.
styleFrom
(
shadowColor:
shadowColor
,
),
onPressed:
()
{
},
child:
const
Text
(
'button'
),
);
},
),
),
),
),
);
}
final
Finder
buttonMaterialFinder
=
find
.
descendant
(
of:
find
.
byType
(
ElevatedButton
),
matching:
find
.
byType
(
Material
),
);
await
tester
.
pumpWidget
(
buildFrame
());
Material
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
Colors
.
black
);
//default
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
overiddenColor
,
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
overiddenColor
,
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
});
}
}
packages/flutter/test/material/outlined_button_theme_test.dart
View file @
0f57cd26
...
@@ -35,7 +35,7 @@ void main() {
...
@@ -35,7 +35,7 @@ void main() {
expect
(
material
.
borderRadius
,
null
);
expect
(
material
.
borderRadius
,
null
);
expect
(
material
.
color
,
Colors
.
transparent
);
expect
(
material
.
color
,
Colors
.
transparent
);
expect
(
material
.
elevation
,
0.0
);
expect
(
material
.
elevation
,
0.0
);
expect
(
material
.
shadowColor
,
const
Color
(
0xff000000
)
);
expect
(
material
.
shadowColor
,
Colors
.
black
);
expect
(
material
.
shape
,
RoundedRectangleBorder
(
expect
(
material
.
shape
,
RoundedRectangleBorder
(
side:
BorderSide
(
width:
1
,
color:
colorScheme
.
onSurface
.
withOpacity
(
0.12
)),
side:
BorderSide
(
width:
1
,
color:
colorScheme
.
onSurface
.
withOpacity
(
0.12
)),
borderRadius:
BorderRadius
.
circular
(
4.0
),
borderRadius:
BorderRadius
.
circular
(
4.0
),
...
@@ -180,4 +180,74 @@ void main() {
...
@@ -180,4 +180,74 @@ void main() {
checkButton
(
tester
);
checkButton
(
tester
);
});
});
});
});
testWidgets
(
'Theme shadowColor'
,
(
WidgetTester
tester
)
async
{
const
ColorScheme
colorScheme
=
ColorScheme
.
light
();
const
Color
shadowColor
=
Color
(
0xff000001
);
const
Color
overiddenColor
=
Color
(
0xff000002
);
Widget
buildFrame
({
Color
overallShadowColor
,
Color
themeShadowColor
,
Color
shadowColor
})
{
return
MaterialApp
(
theme:
ThemeData
.
from
(
colorScheme:
colorScheme
).
copyWith
(
shadowColor:
overallShadowColor
,
),
home:
Scaffold
(
body:
Center
(
child:
OutlinedButtonTheme
(
data:
OutlinedButtonThemeData
(
style:
OutlinedButton
.
styleFrom
(
shadowColor:
themeShadowColor
,
),
),
child:
Builder
(
builder:
(
BuildContext
context
)
{
return
OutlinedButton
(
style:
OutlinedButton
.
styleFrom
(
shadowColor:
shadowColor
,
),
onPressed:
()
{
},
child:
const
Text
(
'button'
),
);
},
),
),
),
),
);
}
final
Finder
buttonMaterialFinder
=
find
.
descendant
(
of:
find
.
byType
(
OutlinedButton
),
matching:
find
.
byType
(
Material
),
);
await
tester
.
pumpWidget
(
buildFrame
());
Material
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
Colors
.
black
);
//default
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
overiddenColor
,
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
overiddenColor
,
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
});
}
}
packages/flutter/test/material/text_button_theme_test.dart
View file @
0f57cd26
...
@@ -177,4 +177,74 @@ void main() {
...
@@ -177,4 +177,74 @@ void main() {
checkButton
(
tester
);
checkButton
(
tester
);
});
});
});
});
testWidgets
(
'Theme shadowColor'
,
(
WidgetTester
tester
)
async
{
const
ColorScheme
colorScheme
=
ColorScheme
.
light
();
const
Color
shadowColor
=
Color
(
0xff000001
);
const
Color
overiddenColor
=
Color
(
0xff000002
);
Widget
buildFrame
({
Color
overallShadowColor
,
Color
themeShadowColor
,
Color
shadowColor
})
{
return
MaterialApp
(
theme:
ThemeData
.
from
(
colorScheme:
colorScheme
).
copyWith
(
shadowColor:
overallShadowColor
,
),
home:
Scaffold
(
body:
Center
(
child:
TextButtonTheme
(
data:
TextButtonThemeData
(
style:
TextButton
.
styleFrom
(
shadowColor:
themeShadowColor
,
),
),
child:
Builder
(
builder:
(
BuildContext
context
)
{
return
TextButton
(
style:
TextButton
.
styleFrom
(
shadowColor:
shadowColor
,
),
onPressed:
()
{
},
child:
const
Text
(
'button'
),
);
},
),
),
),
),
);
}
final
Finder
buttonMaterialFinder
=
find
.
descendant
(
of:
find
.
byType
(
TextButton
),
matching:
find
.
byType
(
Material
),
);
await
tester
.
pumpWidget
(
buildFrame
());
Material
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
Colors
.
black
);
//default
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
overallShadowColor:
overiddenColor
,
themeShadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
await
tester
.
pumpWidget
(
buildFrame
(
themeShadowColor:
overiddenColor
,
shadowColor:
shadowColor
));
await
tester
.
pumpAndSettle
();
// theme animation
material
=
tester
.
widget
<
Material
>(
buttonMaterialFinder
);
expect
(
material
.
shadowColor
,
shadowColor
);
});
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment