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
4ba35a6e
Unverified
Commit
4ba35a6e
authored
Feb 01, 2019
by
rami-a
Committed by
GitHub
Feb 01, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add elevation/pressElevation to ChipThemeData (#27399)
Allow the theme to provide these values to Chips
parent
fc67f2ef
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
119 additions
and
54 deletions
+119
-54
chip.dart
packages/flutter/lib/src/material/chip.dart
+45
-46
chip_theme.dart
packages/flutter/lib/src/material/chip_theme.dart
+29
-2
chip_test.dart
packages/flutter/test/material/chip_test.dart
+13
-5
chip_theme_test.dart
packages/flutter/test/material/chip_theme_test.dart
+32
-1
No files found.
packages/flutter/lib/src/material/chip.dart
View file @
4ba35a6e
...
@@ -467,8 +467,8 @@ abstract class TappableChipAttributes {
...
@@ -467,8 +467,8 @@ abstract class TappableChipAttributes {
class
Chip
extends
StatelessWidget
implements
ChipAttributes
,
DeletableChipAttributes
{
class
Chip
extends
StatelessWidget
implements
ChipAttributes
,
DeletableChipAttributes
{
/// Creates a material design chip.
/// Creates a material design chip.
///
///
/// The [label]
, [elevation],
and [clipBehavior] arguments must not be null.
/// The [label] and [clipBehavior] arguments must not be null.
///
Additionally, the [elevation] must be
non-negative.
///
The [elevation] must be null or
non-negative.
const
Chip
({
const
Chip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -484,10 +484,10 @@ class Chip extends StatelessWidget implements ChipAttributes, DeletableChipAttri
...
@@ -484,10 +484,10 @@ class Chip extends StatelessWidget implements ChipAttributes, DeletableChipAttri
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
padding
,
this
.
padding
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
})
:
assert
(
label
!=
null
),
})
:
assert
(
label
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
super
(
key:
key
);
super
(
key:
key
);
@override
@override
...
@@ -600,10 +600,9 @@ class InputChip extends StatelessWidget
...
@@ -600,10 +600,9 @@ class InputChip extends StatelessWidget
/// The [onPressed] and [onSelected] callbacks must not both be specified at
/// The [onPressed] and [onSelected] callbacks must not both be specified at
/// the same time.
/// the same time.
///
///
/// The [label], [isEnabled], [selected], [pressElevation], [elevation] and
/// The [label], [isEnabled], [selected], and [clipBehavior] arguments must
/// [clipBehavior] arguments must not be null. Additionally, [pressElevation]
/// not be null. The [pressElevation] and [elevation] must be null or
/// and [elevation] must be non-negative. Typically, [pressElevation] is
/// non-negative. Typically, [pressElevation] is greater than [elevation].
/// greater than [elevation].
const
InputChip
({
const
InputChip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -618,7 +617,7 @@ class InputChip extends StatelessWidget
...
@@ -618,7 +617,7 @@ class InputChip extends StatelessWidget
this
.
deleteIconColor
,
this
.
deleteIconColor
,
this
.
deleteButtonTooltipMessage
,
this
.
deleteButtonTooltipMessage
,
this
.
onPressed
,
this
.
onPressed
,
this
.
pressElevation
=
8.0
,
this
.
pressElevation
,
this
.
disabledColor
,
this
.
disabledColor
,
this
.
selectedColor
,
this
.
selectedColor
,
this
.
tooltip
,
this
.
tooltip
,
...
@@ -627,14 +626,14 @@ class InputChip extends StatelessWidget
...
@@ -627,14 +626,14 @@ class InputChip extends StatelessWidget
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
padding
,
this
.
padding
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
this
.
avatarBorder
=
const
CircleBorder
(),
this
.
avatarBorder
=
const
CircleBorder
(),
})
:
assert
(
selected
!=
null
),
})
:
assert
(
selected
!=
null
),
assert
(
isEnabled
!=
null
),
assert
(
isEnabled
!=
null
),
assert
(
label
!=
null
),
assert
(
label
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
pressElevation
!=
null
&&
pressElevation
>=
0.0
),
assert
(
pressElevation
==
null
||
pressElevation
>=
0.0
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
super
(
key:
key
);
super
(
key:
key
);
@override
@override
...
@@ -777,10 +776,9 @@ class ChoiceChip extends StatelessWidget
...
@@ -777,10 +776,9 @@ class ChoiceChip extends StatelessWidget
DisabledChipAttributes
{
DisabledChipAttributes
{
/// Create a chip that acts like a radio button.
/// Create a chip that acts like a radio button.
///
///
/// The [label], [selected], [pressElevation], [elevation] and [clipBehavior]
/// The [label], [selected], and [clipBehavior] arguments must not be null.
/// arguments must not be null. Additionally, [pressElevation] and [elevation]
/// The [pressElevation] and [elevation] must be null or non-negative.
/// must be non-negative. Typically, [pressElevation] is greater than
/// Typically, [pressElevation] is greater than [elevation].
/// [elevation].
const
ChoiceChip
({
const
ChoiceChip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -788,7 +786,7 @@ class ChoiceChip extends StatelessWidget
...
@@ -788,7 +786,7 @@ class ChoiceChip extends StatelessWidget
this
.
labelStyle
,
this
.
labelStyle
,
this
.
labelPadding
,
this
.
labelPadding
,
this
.
onSelected
,
this
.
onSelected
,
this
.
pressElevation
=
8.0
,
this
.
pressElevation
,
@required
this
.
selected
,
@required
this
.
selected
,
this
.
selectedColor
,
this
.
selectedColor
,
this
.
disabledColor
,
this
.
disabledColor
,
...
@@ -798,13 +796,13 @@ class ChoiceChip extends StatelessWidget
...
@@ -798,13 +796,13 @@ class ChoiceChip extends StatelessWidget
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
padding
,
this
.
padding
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
this
.
avatarBorder
=
const
CircleBorder
(),
this
.
avatarBorder
=
const
CircleBorder
(),
})
:
assert
(
selected
!=
null
),
})
:
assert
(
selected
!=
null
),
assert
(
label
!=
null
),
assert
(
label
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
pressElevation
!=
null
&&
pressElevation
>=
0.0
),
assert
(
pressElevation
==
null
||
pressElevation
>=
0.0
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
super
(
key:
key
);
super
(
key:
key
);
@override
@override
...
@@ -967,10 +965,9 @@ class FilterChip extends StatelessWidget
...
@@ -967,10 +965,9 @@ class FilterChip extends StatelessWidget
DisabledChipAttributes
{
DisabledChipAttributes
{
/// Create a chip that acts like a checkbox.
/// Create a chip that acts like a checkbox.
///
///
/// The [selected], [label], [pressElevation], [elevation] and [clipBehavior]
/// The [selected], [label], and [clipBehavior] arguments must not be null.
/// arguments must not be null. Additionally, [pressElevation] and [elevation]
/// The [pressElevation] and [elevation] must be null or non-negative.
/// must be non-negative. Typically, [pressElevation] is greater than
/// Typically, [pressElevation] is greater than [elevation].
/// [elevation].
const
FilterChip
({
const
FilterChip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -979,7 +976,7 @@ class FilterChip extends StatelessWidget
...
@@ -979,7 +976,7 @@ class FilterChip extends StatelessWidget
this
.
labelPadding
,
this
.
labelPadding
,
this
.
selected
=
false
,
this
.
selected
=
false
,
@required
this
.
onSelected
,
@required
this
.
onSelected
,
this
.
pressElevation
=
8.0
,
this
.
pressElevation
,
this
.
disabledColor
,
this
.
disabledColor
,
this
.
selectedColor
,
this
.
selectedColor
,
this
.
tooltip
,
this
.
tooltip
,
...
@@ -988,13 +985,13 @@ class FilterChip extends StatelessWidget
...
@@ -988,13 +985,13 @@ class FilterChip extends StatelessWidget
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
padding
,
this
.
padding
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
this
.
avatarBorder
=
const
CircleBorder
(),
this
.
avatarBorder
=
const
CircleBorder
(),
})
:
assert
(
selected
!=
null
),
})
:
assert
(
selected
!=
null
),
assert
(
label
!=
null
),
assert
(
label
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
pressElevation
!=
null
&&
pressElevation
>=
0.0
),
assert
(
pressElevation
==
null
||
pressElevation
>=
0.0
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
super
(
key:
key
);
super
(
key:
key
);
@override
@override
...
@@ -1111,10 +1108,9 @@ class FilterChip extends StatelessWidget
...
@@ -1111,10 +1108,9 @@ class FilterChip extends StatelessWidget
class
ActionChip
extends
StatelessWidget
implements
ChipAttributes
,
TappableChipAttributes
{
class
ActionChip
extends
StatelessWidget
implements
ChipAttributes
,
TappableChipAttributes
{
/// Create a chip that acts like a button.
/// Create a chip that acts like a button.
///
///
/// The [label], [onPressed], [pressElevation], [elevation] and [clipBehavior]
/// The [label], [onPressed] and [clipBehavior] arguments must not be null.
/// arguments must not be null. Additionally, [pressElevation] and [elevation]
/// The [pressElevation] and [elevation] must be null or non-negative.
/// must be non-negative. Typically, [pressElevation] is greater than
/// Typically, [pressElevation] is greater than [elevation].
/// [elevation].
const
ActionChip
({
const
ActionChip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -1122,22 +1118,22 @@ class ActionChip extends StatelessWidget implements ChipAttributes, TappableChip
...
@@ -1122,22 +1118,22 @@ class ActionChip extends StatelessWidget implements ChipAttributes, TappableChip
this
.
labelStyle
,
this
.
labelStyle
,
this
.
labelPadding
,
this
.
labelPadding
,
@required
this
.
onPressed
,
@required
this
.
onPressed
,
this
.
pressElevation
=
8.0
,
this
.
pressElevation
,
this
.
tooltip
,
this
.
tooltip
,
this
.
shape
,
this
.
shape
,
this
.
clipBehavior
=
Clip
.
none
,
this
.
clipBehavior
=
Clip
.
none
,
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
padding
,
this
.
padding
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
})
:
assert
(
label
!=
null
),
})
:
assert
(
label
!=
null
),
assert
(
assert
(
onPressed
!=
null
,
onPressed
!=
null
,
'Rather than disabling an ActionChip by setting onPressed to null, '
'Rather than disabling an ActionChip by setting onPressed to null, '
'remove it from the interface entirely.'
,
'remove it from the interface entirely.'
,
),
),
assert
(
pressElevation
!=
null
&&
pressElevation
>=
0.0
),
assert
(
pressElevation
==
null
||
pressElevation
>=
0.0
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
super
(
key:
key
);
super
(
key:
key
);
@override
@override
...
@@ -1231,10 +1227,9 @@ class RawChip extends StatefulWidget
...
@@ -1231,10 +1227,9 @@ class RawChip extends StatefulWidget
/// The [onPressed] and [onSelected] callbacks must not both be specified at
/// The [onPressed] and [onSelected] callbacks must not both be specified at
/// the same time.
/// the same time.
///
///
/// The [label], [pressElevation], [elevation], [isEnabled], and
/// The [label], [isEnabled], and [clipBehavior] arguments must not be null.
/// [clipBehavior] arguments must not be null. Additionally, [pressElevation]
/// The [pressElevation] and [elevation] must be null or non-negative.
/// and [elevation] must be non-negative. Typically, [pressElevation] is
/// Typically, [pressElevation] is greater than [elevation].
/// greater than [elevation].
const
RawChip
({
const
RawChip
({
Key
key
,
Key
key
,
this
.
avatar
,
this
.
avatar
,
...
@@ -1248,7 +1243,7 @@ class RawChip extends StatefulWidget
...
@@ -1248,7 +1243,7 @@ class RawChip extends StatefulWidget
this
.
deleteButtonTooltipMessage
,
this
.
deleteButtonTooltipMessage
,
this
.
onPressed
,
this
.
onPressed
,
this
.
onSelected
,
this
.
onSelected
,
this
.
pressElevation
=
8.0
,
this
.
pressElevation
,
this
.
tapEnabled
=
true
,
this
.
tapEnabled
=
true
,
this
.
selected
,
this
.
selected
,
this
.
showCheckmark
=
true
,
this
.
showCheckmark
=
true
,
...
@@ -1260,13 +1255,13 @@ class RawChip extends StatefulWidget
...
@@ -1260,13 +1255,13 @@ class RawChip extends StatefulWidget
this
.
clipBehavior
=
Clip
.
none
,
this
.
clipBehavior
=
Clip
.
none
,
this
.
backgroundColor
,
this
.
backgroundColor
,
this
.
materialTapTargetSize
,
this
.
materialTapTargetSize
,
this
.
elevation
=
0.0
,
this
.
elevation
,
this
.
avatarBorder
=
const
CircleBorder
(),
this
.
avatarBorder
=
const
CircleBorder
(),
})
:
assert
(
label
!=
null
),
})
:
assert
(
label
!=
null
),
assert
(
isEnabled
!=
null
),
assert
(
isEnabled
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
clipBehavior
!=
null
),
assert
(
pressElevation
!=
null
&&
pressElevation
>=
0.0
),
assert
(
pressElevation
==
null
||
pressElevation
>=
0.0
),
assert
(
elevation
!=
null
&&
elevation
>=
0.0
),
assert
(
elevation
==
null
||
elevation
>=
0.0
),
deleteIcon
=
deleteIcon
??
_kDefaultDeleteIcon
,
deleteIcon
=
deleteIcon
??
_kDefaultDeleteIcon
,
super
(
key:
key
);
super
(
key:
key
);
...
@@ -1552,6 +1547,9 @@ class _RawChipState extends State<RawChip> with TickerProviderStateMixin<RawChip
...
@@ -1552,6 +1547,9 @@ class _RawChipState extends State<RawChip> with TickerProviderStateMixin<RawChip
);
);
}
}
static
const
double
_defaultElevation
=
0.0
;
static
const
double
_defaultPressElevation
=
8.0
;
@override
@override
Widget
build
(
BuildContext
context
)
{
Widget
build
(
BuildContext
context
)
{
assert
(
debugCheckHasMaterial
(
context
));
assert
(
debugCheckHasMaterial
(
context
));
...
@@ -1563,10 +1561,11 @@ class _RawChipState extends State<RawChip> with TickerProviderStateMixin<RawChip
...
@@ -1563,10 +1561,11 @@ class _RawChipState extends State<RawChip> with TickerProviderStateMixin<RawChip
final
ChipThemeData
chipTheme
=
ChipTheme
.
of
(
context
);
final
ChipThemeData
chipTheme
=
ChipTheme
.
of
(
context
);
final
TextDirection
textDirection
=
Directionality
.
of
(
context
);
final
TextDirection
textDirection
=
Directionality
.
of
(
context
);
final
ShapeBorder
shape
=
widget
.
shape
??
chipTheme
.
shape
;
final
ShapeBorder
shape
=
widget
.
shape
??
chipTheme
.
shape
;
final
double
elevation
=
widget
.
elevation
??
chipTheme
.
elevation
??
_defaultElevation
;
final
double
pressElevation
=
widget
.
pressElevation
??
chipTheme
.
pressElevation
??
_defaultPressElevation
;
Widget
result
=
Material
(
Widget
result
=
Material
(
elevation:
isTapping
?
widget
.
pressElevation
:
widget
.
elevation
,
elevation:
isTapping
?
pressElevation
:
elevation
,
animationDuration:
pressedAnimationDuration
,
animationDuration:
pressedAnimationDuration
,
shape:
shape
,
shape:
shape
,
clipBehavior:
widget
.
clipBehavior
,
clipBehavior:
widget
.
clipBehavior
,
...
...
packages/flutter/lib/src/material/chip_theme.dart
View file @
4ba35a6e
...
@@ -2,6 +2,8 @@
...
@@ -2,6 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// found in the LICENSE file.
import
'dart:ui'
show
lerpDouble
;
import
'package:flutter/foundation.dart'
;
import
'package:flutter/foundation.dart'
;
import
'package:flutter/rendering.dart'
;
import
'package:flutter/rendering.dart'
;
import
'package:flutter/widgets.dart'
;
import
'package:flutter/widgets.dart'
;
...
@@ -162,7 +164,8 @@ class ChipTheme extends InheritedWidget {
...
@@ -162,7 +164,8 @@ class ChipTheme extends InheritedWidget {
/// * [ThemeData], which has a default [ChipThemeData].
/// * [ThemeData], which has a default [ChipThemeData].
class
ChipThemeData
extends
Diagnosticable
{
class
ChipThemeData
extends
Diagnosticable
{
/// Create a [ChipThemeData] given a set of exact values. All the values
/// Create a [ChipThemeData] given a set of exact values. All the values
/// must be specified.
/// must be specified except for [elevation] and [pressElevation], which may
/// be null.
///
///
/// This will rarely be used directly. It is used by [lerp] to
/// This will rarely be used directly. It is used by [lerp] to
/// create intermediate themes based on two themes.
/// create intermediate themes based on two themes.
...
@@ -178,6 +181,8 @@ class ChipThemeData extends Diagnosticable {
...
@@ -178,6 +181,8 @@ class ChipThemeData extends Diagnosticable {
@required
this
.
labelStyle
,
@required
this
.
labelStyle
,
@required
this
.
secondaryLabelStyle
,
@required
this
.
secondaryLabelStyle
,
@required
this
.
brightness
,
@required
this
.
brightness
,
this
.
elevation
,
this
.
pressElevation
,
})
:
assert
(
backgroundColor
!=
null
),
})
:
assert
(
backgroundColor
!=
null
),
assert
(
disabledColor
!=
null
),
assert
(
disabledColor
!=
null
),
assert
(
selectedColor
!=
null
),
assert
(
selectedColor
!=
null
),
...
@@ -328,6 +333,16 @@ class ChipThemeData extends Diagnosticable {
...
@@ -328,6 +333,16 @@ class ChipThemeData extends Diagnosticable {
/// This affects various base material color choices in the chip rendering.
/// This affects various base material color choices in the chip rendering.
final
Brightness
brightness
;
final
Brightness
brightness
;
/// The elevation to be applied to the chip.
///
/// If null, the chip defaults to 0.
final
double
elevation
;
/// The elevation to be applied to the chip during the press motion.
///
/// If null, the chip defaults to 8.
final
double
pressElevation
;
/// Creates a copy of this object but with the given fields replaced with the
/// Creates a copy of this object but with the given fields replaced with the
/// new values.
/// new values.
ChipThemeData
copyWith
({
ChipThemeData
copyWith
({
...
@@ -342,6 +357,8 @@ class ChipThemeData extends Diagnosticable {
...
@@ -342,6 +357,8 @@ class ChipThemeData extends Diagnosticable {
TextStyle
labelStyle
,
TextStyle
labelStyle
,
TextStyle
secondaryLabelStyle
,
TextStyle
secondaryLabelStyle
,
Brightness
brightness
,
Brightness
brightness
,
double
elevation
,
double
pressElevation
,
})
{
})
{
return
ChipThemeData
(
return
ChipThemeData
(
backgroundColor:
backgroundColor
??
this
.
backgroundColor
,
backgroundColor:
backgroundColor
??
this
.
backgroundColor
,
...
@@ -355,6 +372,8 @@ class ChipThemeData extends Diagnosticable {
...
@@ -355,6 +372,8 @@ class ChipThemeData extends Diagnosticable {
labelStyle:
labelStyle
??
this
.
labelStyle
,
labelStyle:
labelStyle
??
this
.
labelStyle
,
secondaryLabelStyle:
secondaryLabelStyle
??
this
.
secondaryLabelStyle
,
secondaryLabelStyle:
secondaryLabelStyle
??
this
.
secondaryLabelStyle
,
brightness:
brightness
??
this
.
brightness
,
brightness:
brightness
??
this
.
brightness
,
elevation:
elevation
??
this
.
elevation
,
pressElevation:
pressElevation
??
this
.
pressElevation
,
);
);
}
}
...
@@ -379,6 +398,8 @@ class ChipThemeData extends Diagnosticable {
...
@@ -379,6 +398,8 @@ class ChipThemeData extends Diagnosticable {
labelStyle:
TextStyle
.
lerp
(
a
?.
labelStyle
,
b
?.
labelStyle
,
t
),
labelStyle:
TextStyle
.
lerp
(
a
?.
labelStyle
,
b
?.
labelStyle
,
t
),
secondaryLabelStyle:
TextStyle
.
lerp
(
a
?.
secondaryLabelStyle
,
b
?.
secondaryLabelStyle
,
t
),
secondaryLabelStyle:
TextStyle
.
lerp
(
a
?.
secondaryLabelStyle
,
b
?.
secondaryLabelStyle
,
t
),
brightness:
t
<
0.5
?
a
?.
brightness
??
Brightness
.
light
:
b
?.
brightness
??
Brightness
.
light
,
brightness:
t
<
0.5
?
a
?.
brightness
??
Brightness
.
light
:
b
?.
brightness
??
Brightness
.
light
,
elevation:
lerpDouble
(
a
?.
elevation
,
b
?.
elevation
,
t
),
pressElevation:
lerpDouble
(
a
?.
pressElevation
,
b
?.
pressElevation
,
t
),
);
);
}
}
...
@@ -396,6 +417,8 @@ class ChipThemeData extends Diagnosticable {
...
@@ -396,6 +417,8 @@ class ChipThemeData extends Diagnosticable {
labelStyle
,
labelStyle
,
secondaryLabelStyle
,
secondaryLabelStyle
,
brightness
,
brightness
,
elevation
,
pressElevation
,
);
);
}
}
...
@@ -418,7 +441,9 @@ class ChipThemeData extends Diagnosticable {
...
@@ -418,7 +441,9 @@ class ChipThemeData extends Diagnosticable {
&&
otherData
.
shape
==
shape
&&
otherData
.
shape
==
shape
&&
otherData
.
labelStyle
==
labelStyle
&&
otherData
.
labelStyle
==
labelStyle
&&
otherData
.
secondaryLabelStyle
==
secondaryLabelStyle
&&
otherData
.
secondaryLabelStyle
==
secondaryLabelStyle
&&
otherData
.
brightness
==
brightness
;
&&
otherData
.
brightness
==
brightness
&&
otherData
.
elevation
==
elevation
&&
otherData
.
pressElevation
==
pressElevation
;
}
}
@override
@override
...
@@ -441,5 +466,7 @@ class ChipThemeData extends Diagnosticable {
...
@@ -441,5 +466,7 @@ class ChipThemeData extends Diagnosticable {
properties
.
add
(
DiagnosticsProperty
<
TextStyle
>(
'labelStyle'
,
labelStyle
,
defaultValue:
defaultData
.
labelStyle
));
properties
.
add
(
DiagnosticsProperty
<
TextStyle
>(
'labelStyle'
,
labelStyle
,
defaultValue:
defaultData
.
labelStyle
));
properties
.
add
(
DiagnosticsProperty
<
TextStyle
>(
'secondaryLabelStyle'
,
secondaryLabelStyle
,
defaultValue:
defaultData
.
secondaryLabelStyle
));
properties
.
add
(
DiagnosticsProperty
<
TextStyle
>(
'secondaryLabelStyle'
,
secondaryLabelStyle
,
defaultValue:
defaultData
.
secondaryLabelStyle
));
properties
.
add
(
EnumProperty
<
Brightness
>(
'brightness'
,
brightness
,
defaultValue:
defaultData
.
brightness
));
properties
.
add
(
EnumProperty
<
Brightness
>(
'brightness'
,
brightness
,
defaultValue:
defaultData
.
brightness
));
properties
.
add
(
DoubleProperty
(
'elevation'
,
elevation
,
defaultValue:
defaultData
.
elevation
));
properties
.
add
(
DoubleProperty
(
'pressElevation'
,
pressElevation
,
defaultValue:
defaultData
.
pressElevation
));
}
}
}
}
packages/flutter/test/material/chip_test.dart
View file @
4ba35a6e
...
@@ -26,6 +26,15 @@ RenderBox getMaterialBox(WidgetTester tester) {
...
@@ -26,6 +26,15 @@ RenderBox getMaterialBox(WidgetTester tester) {
);
);
}
}
Material
getMaterial
(
WidgetTester
tester
)
{
return
tester
.
widget
<
Material
>(
find
.
descendant
(
of:
find
.
byType
(
RawChip
),
matching:
find
.
byType
(
Material
),
),
);
}
IconThemeData
getIconData
(
WidgetTester
tester
)
{
IconThemeData
getIconData
(
WidgetTester
tester
)
{
final
IconTheme
iconTheme
=
tester
.
firstWidget
(
final
IconTheme
iconTheme
=
tester
.
firstWidget
(
find
.
descendant
(
find
.
descendant
(
...
@@ -1497,19 +1506,18 @@ void main() {
...
@@ -1497,19 +1506,18 @@ void main() {
}
}
await
tester
.
pumpWidget
(
buildChip
(
chipTheme
));
await
tester
.
pumpWidget
(
buildChip
(
chipTheme
));
expect
(
inputChip
.
pressElevation
,
8.0
);
Material
material
=
getMaterial
(
tester
);
expect
(
inputChip
.
elevation
,
0.0
);
expect
(
material
.
elevation
,
0.0
);
inputChip
=
const
InputChip
(
inputChip
=
const
InputChip
(
label:
Text
(
'Label'
),
label:
Text
(
'Label'
),
pressElevation:
12.0
,
elevation:
4.0
,
elevation:
4.0
,
);
);
await
tester
.
pumpWidget
(
buildChip
(
chipTheme
));
await
tester
.
pumpWidget
(
buildChip
(
chipTheme
));
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
expect
(
inputChip
.
pressElevation
,
12.0
);
material
=
getMaterial
(
tester
);
expect
(
inputChip
.
elevation
,
4.0
);
expect
(
material
.
elevation
,
4.0
);
});
});
testWidgets
(
'can be tapped outside of chip body'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'can be tapped outside of chip body'
,
(
WidgetTester
tester
)
async
{
...
...
packages/flutter/test/material/chip_theme_test.dart
View file @
4ba35a6e
...
@@ -20,6 +20,15 @@ RenderBox getMaterialBox(WidgetTester tester) {
...
@@ -20,6 +20,15 @@ RenderBox getMaterialBox(WidgetTester tester) {
);
);
}
}
Material
getMaterial
(
WidgetTester
tester
)
{
return
tester
.
widget
<
Material
>(
find
.
descendant
(
of:
find
.
byType
(
RawChip
),
matching:
find
.
byType
(
Material
),
),
);
}
IconThemeData
getIconData
(
WidgetTester
tester
)
{
IconThemeData
getIconData
(
WidgetTester
tester
)
{
final
IconTheme
iconTheme
=
tester
.
firstWidget
(
final
IconTheme
iconTheme
=
tester
.
firstWidget
(
find
.
descendant
(
find
.
descendant
(
...
@@ -110,6 +119,7 @@ void main() {
...
@@ -110,6 +119,7 @@ void main() {
final
ChipThemeData
customTheme
=
chipTheme
.
copyWith
(
final
ChipThemeData
customTheme
=
chipTheme
.
copyWith
(
backgroundColor:
Colors
.
purple
,
backgroundColor:
Colors
.
purple
,
deleteIconColor:
Colors
.
purple
.
withAlpha
(
0x3d
),
deleteIconColor:
Colors
.
purple
.
withAlpha
(
0x3d
),
elevation:
3.0
,
);
);
const
bool
value
=
false
;
const
bool
value
=
false
;
Widget
buildChip
(
ChipThemeData
data
)
{
Widget
buildChip
(
ChipThemeData
data
)
{
...
@@ -148,8 +158,10 @@ void main() {
...
@@ -148,8 +158,10 @@ void main() {
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
final
RenderBox
materialBox
=
getMaterialBox
(
tester
);
final
RenderBox
materialBox
=
getMaterialBox
(
tester
);
final
Material
material
=
getMaterial
(
tester
);
expect
(
materialBox
,
paints
..
path
(
color:
Color
(
customTheme
.
backgroundColor
.
value
)));
expect
(
materialBox
,
paints
..
path
(
color:
Color
(
customTheme
.
backgroundColor
.
value
)));
expect
(
material
.
elevation
,
customTheme
.
elevation
);
});
});
testWidgets
(
'ChipThemeData generates correct opacities for defaults'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'ChipThemeData generates correct opacities for defaults'
,
(
WidgetTester
tester
)
async
{
...
@@ -217,12 +229,21 @@ void main() {
...
@@ -217,12 +229,21 @@ void main() {
secondaryColor:
Colors
.
black
,
secondaryColor:
Colors
.
black
,
brightness:
Brightness
.
dark
,
brightness:
Brightness
.
dark
,
labelStyle:
ThemeData
.
fallback
().
accentTextTheme
.
body2
.
copyWith
(
color:
Colors
.
black
),
labelStyle:
ThemeData
.
fallback
().
accentTextTheme
.
body2
.
copyWith
(
color:
Colors
.
black
),
).
copyWith
(
elevation:
1.0
,
pressElevation:
4.0
,
);
);
final
ChipThemeData
chipThemeWhite
=
ChipThemeData
.
fromDefaults
(
final
ChipThemeData
chipThemeWhite
=
ChipThemeData
.
fromDefaults
(
secondaryColor:
Colors
.
white
,
secondaryColor:
Colors
.
white
,
brightness:
Brightness
.
light
,
brightness:
Brightness
.
light
,
labelStyle:
ThemeData
.
fallback
().
accentTextTheme
.
body2
.
copyWith
(
color:
Colors
.
white
),
labelStyle:
ThemeData
.
fallback
().
accentTextTheme
.
body2
.
copyWith
(
color:
Colors
.
white
),
).
copyWith
(
padding:
const
EdgeInsets
.
all
(
2.0
),
labelPadding:
const
EdgeInsets
.
only
(
top:
8.0
,
bottom:
8.0
));
).
copyWith
(
padding:
const
EdgeInsets
.
all
(
2.0
),
labelPadding:
const
EdgeInsets
.
only
(
top:
8.0
,
bottom:
8.0
),
elevation:
5.0
,
pressElevation:
10.0
,
);
final
ChipThemeData
lerp
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
chipThemeWhite
,
0.5
);
final
ChipThemeData
lerp
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
chipThemeWhite
,
0.5
);
const
Color
middleGrey
=
Color
(
0xff7f7f7f
);
const
Color
middleGrey
=
Color
(
0xff7f7f7f
);
expect
(
lerp
.
backgroundColor
,
equals
(
middleGrey
.
withAlpha
(
0x1f
)));
expect
(
lerp
.
backgroundColor
,
equals
(
middleGrey
.
withAlpha
(
0x1f
)));
...
@@ -236,6 +257,8 @@ void main() {
...
@@ -236,6 +257,8 @@ void main() {
expect
(
lerp
.
labelStyle
.
color
,
equals
(
middleGrey
.
withAlpha
(
0xde
)));
expect
(
lerp
.
labelStyle
.
color
,
equals
(
middleGrey
.
withAlpha
(
0xde
)));
expect
(
lerp
.
secondaryLabelStyle
.
color
,
equals
(
middleGrey
.
withAlpha
(
0xde
)));
expect
(
lerp
.
secondaryLabelStyle
.
color
,
equals
(
middleGrey
.
withAlpha
(
0xde
)));
expect
(
lerp
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerp
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerp
.
elevation
,
3.0
);
expect
(
lerp
.
pressElevation
,
7.0
);
expect
(
ChipThemeData
.
lerp
(
null
,
null
,
0.25
),
isNull
);
expect
(
ChipThemeData
.
lerp
(
null
,
null
,
0.25
),
isNull
);
...
@@ -251,6 +274,8 @@ void main() {
...
@@ -251,6 +274,8 @@ void main() {
expect
(
lerpANull25
.
labelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0x38
)));
expect
(
lerpANull25
.
labelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0x38
)));
expect
(
lerpANull25
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0x38
)));
expect
(
lerpANull25
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0x38
)));
expect
(
lerpANull25
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpANull25
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpANull25
.
elevation
,
1.25
);
expect
(
lerpANull25
.
pressElevation
,
2.5
);
final
ChipThemeData
lerpANull75
=
ChipThemeData
.
lerp
(
null
,
chipThemeWhite
,
0.75
);
final
ChipThemeData
lerpANull75
=
ChipThemeData
.
lerp
(
null
,
chipThemeWhite
,
0.75
);
expect
(
lerpANull75
.
backgroundColor
,
equals
(
Colors
.
black
.
withAlpha
(
0x17
)));
expect
(
lerpANull75
.
backgroundColor
,
equals
(
Colors
.
black
.
withAlpha
(
0x17
)));
...
@@ -264,6 +289,8 @@ void main() {
...
@@ -264,6 +289,8 @@ void main() {
expect
(
lerpANull75
.
labelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0xa7
)));
expect
(
lerpANull75
.
labelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0xa7
)));
expect
(
lerpANull75
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0xa7
)));
expect
(
lerpANull75
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0xa7
)));
expect
(
lerpANull75
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpANull75
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpANull75
.
elevation
,
3.75
);
expect
(
lerpANull75
.
pressElevation
,
7.5
);
final
ChipThemeData
lerpBNull25
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
null
,
0.25
);
final
ChipThemeData
lerpBNull25
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
null
,
0.25
);
expect
(
lerpBNull25
.
backgroundColor
,
equals
(
Colors
.
white
.
withAlpha
(
0x17
)));
expect
(
lerpBNull25
.
backgroundColor
,
equals
(
Colors
.
white
.
withAlpha
(
0x17
)));
...
@@ -277,6 +304,8 @@ void main() {
...
@@ -277,6 +304,8 @@ void main() {
expect
(
lerpBNull25
.
labelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0xa7
)));
expect
(
lerpBNull25
.
labelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0xa7
)));
expect
(
lerpBNull25
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0xa7
)));
expect
(
lerpBNull25
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0xa7
)));
expect
(
lerpBNull25
.
brightness
,
equals
(
Brightness
.
dark
));
expect
(
lerpBNull25
.
brightness
,
equals
(
Brightness
.
dark
));
expect
(
lerpBNull25
.
elevation
,
0.75
);
expect
(
lerpBNull25
.
pressElevation
,
3.0
);
final
ChipThemeData
lerpBNull75
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
null
,
0.75
);
final
ChipThemeData
lerpBNull75
=
ChipThemeData
.
lerp
(
chipThemeBlack
,
null
,
0.75
);
expect
(
lerpBNull75
.
backgroundColor
,
equals
(
Colors
.
white
.
withAlpha
(
0x08
)));
expect
(
lerpBNull75
.
backgroundColor
,
equals
(
Colors
.
white
.
withAlpha
(
0x08
)));
...
@@ -290,5 +319,7 @@ void main() {
...
@@ -290,5 +319,7 @@ void main() {
expect
(
lerpBNull75
.
labelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0x38
)));
expect
(
lerpBNull75
.
labelStyle
.
color
,
equals
(
Colors
.
white
.
withAlpha
(
0x38
)));
expect
(
lerpBNull75
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0x38
)));
expect
(
lerpBNull75
.
secondaryLabelStyle
.
color
,
equals
(
Colors
.
black
.
withAlpha
(
0x38
)));
expect
(
lerpBNull75
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpBNull75
.
brightness
,
equals
(
Brightness
.
light
));
expect
(
lerpBNull75
.
elevation
,
0.25
);
expect
(
lerpBNull75
.
pressElevation
,
1.0
);
});
});
}
}
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