Commit 1a5e4a5d authored by Michel Feinstein's avatar Michel Feinstein Committed by Justin McCandless

Adds the arrowColor option to UserAccountsDrawerHeader (#38608) (#38636)

Changes a hard-coded value to a controllable parameter.
parent 09f6515b
...@@ -72,12 +72,14 @@ class _AccountDetails extends StatefulWidget { ...@@ -72,12 +72,14 @@ class _AccountDetails extends StatefulWidget {
@required this.accountEmail, @required this.accountEmail,
this.onTap, this.onTap,
this.isOpen, this.isOpen,
this.arrowColor,
}) : super(key: key); }) : super(key: key);
final Widget accountName; final Widget accountName;
final Widget accountEmail; final Widget accountEmail;
final VoidCallback onTap; final VoidCallback onTap;
final bool isOpen; final bool isOpen;
final Color arrowColor;
@override @override
_AccountDetailsState createState() => _AccountDetailsState(); _AccountDetailsState createState() => _AccountDetailsState();
...@@ -179,7 +181,7 @@ class _AccountDetailsState extends State<_AccountDetails> with SingleTickerProvi ...@@ -179,7 +181,7 @@ class _AccountDetailsState extends State<_AccountDetails> with SingleTickerProvi
angle: _animation.value * math.pi, angle: _animation.value * math.pi,
child: Icon( child: Icon(
Icons.arrow_drop_down, Icons.arrow_drop_down,
color: Colors.white, color: widget.arrowColor,
semanticLabel: widget.isOpen semanticLabel: widget.isOpen
? localizations.hideAccountsLabel ? localizations.hideAccountsLabel
: localizations.showAccountsLabel, : localizations.showAccountsLabel,
...@@ -314,6 +316,7 @@ class UserAccountsDrawerHeader extends StatefulWidget { ...@@ -314,6 +316,7 @@ class UserAccountsDrawerHeader extends StatefulWidget {
@required this.accountName, @required this.accountName,
@required this.accountEmail, @required this.accountEmail,
this.onDetailsPressed, this.onDetailsPressed,
this.arrowColor = Colors.white,
}) : super(key: key); }) : super(key: key);
/// The header's background. If decoration is null then a [BoxDecoration] /// The header's background. If decoration is null then a [BoxDecoration]
...@@ -344,6 +347,9 @@ class UserAccountsDrawerHeader extends StatefulWidget { ...@@ -344,6 +347,9 @@ class UserAccountsDrawerHeader extends StatefulWidget {
/// [accountName] and [accountEmail] is tapped. /// [accountName] and [accountEmail] is tapped.
final VoidCallback onDetailsPressed; final VoidCallback onDetailsPressed;
/// The [Color] of the arrow icon.
final Color arrowColor;
@override @override
_UserAccountsDrawerHeaderState createState() => _UserAccountsDrawerHeaderState(); _UserAccountsDrawerHeaderState createState() => _UserAccountsDrawerHeaderState();
} }
...@@ -390,6 +396,7 @@ class _UserAccountsDrawerHeaderState extends State<UserAccountsDrawerHeader> { ...@@ -390,6 +396,7 @@ class _UserAccountsDrawerHeaderState extends State<UserAccountsDrawerHeader> {
accountEmail: widget.accountEmail, accountEmail: widget.accountEmail,
isOpen: _isOpen, isOpen: _isOpen,
onTap: widget.onDetailsPressed == null ? null : _handleDetailsPressed, onTap: widget.onDetailsPressed == null ? null : _handleDetailsPressed,
arrowColor: widget.arrowColor,
), ),
], ],
), ),
......
...@@ -216,6 +216,37 @@ void main() { ...@@ -216,6 +216,37 @@ void main() {
expect(transformWidget.transform.getRotation()[4], 1.0); expect(transformWidget.transform.getRotation()[4], 1.0);
}); });
testWidgets('UserAccountsDrawerHeader icon color changes', (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp(
home: Material(
child: UserAccountsDrawerHeader(
onDetailsPressed: () {},
accountName: const Text('name'),
accountEmail: const Text('email'),
),
),
));
Icon iconWidget = tester.firstWidget(find.byType(Icon));
// Default icon color is white.
expect(iconWidget.color, Colors.white);
const Color arrowColor = Colors.red;
await tester.pumpWidget(MaterialApp(
home: Material(
child: UserAccountsDrawerHeader(
onDetailsPressed: () { },
accountName: const Text('name'),
accountEmail: const Text('email'),
arrowColor: arrowColor,
),
),
));
iconWidget = tester.firstWidget(find.byType(Icon));
expect(iconWidget.color, arrowColor);
});
testWidgets('UserAccountsDrawerHeader null parameters LTR', (WidgetTester tester) async { testWidgets('UserAccountsDrawerHeader null parameters LTR', (WidgetTester tester) async {
Widget buildFrame({ Widget buildFrame({
Widget currentAccountPicture, Widget currentAccountPicture,
......
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