From 4aea0083e681fded7b839f929a2f566f3845f080 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Thu, 7 Nov 2024 16:08:36 +0000 Subject: [PATCH 1/5] test: Added debugfillproperties test to chip_test feat: Added disabled variant to chip feat: Added onTaps to chips in example app --- .../lib/pages/components/chip_example.dart | 3 + lib/src/components/chips/chip.dart | 92 +++++++++++++------ test/src/components/chips/chip_test.dart | 22 +++-- 3 files changed, 83 insertions(+), 34 deletions(-) diff --git a/example/lib/pages/components/chip_example.dart b/example/lib/pages/components/chip_example.dart index 899a8c38..39bd4cc1 100644 --- a/example/lib/pages/components/chip_example.dart +++ b/example/lib/pages/components/chip_example.dart @@ -25,6 +25,7 @@ class _ChipExampleState extends State { label: 'Label', leading: ZetaIcon(ZetaIcons.user), trailing: IconButton(icon: Icon(ZetaIcons.close), onPressed: () {}), + onTap: () {}, ), ]); @@ -42,6 +43,7 @@ class _ChipExampleState extends State { leading: ZetaIcon(ZetaIcons.star), draggable: true, data: 'Assist chip', + onTap: () {}, ), ), ]); @@ -60,6 +62,7 @@ class _ChipExampleState extends State { selected: true, data: 'Filter chip', draggable: true, + onTap: (bool selected) {}, ), ), ]); diff --git a/lib/src/components/chips/chip.dart b/lib/src/components/chips/chip.dart index 9f3a0fca..e6a09f78 100644 --- a/lib/src/components/chips/chip.dart +++ b/lib/src/components/chips/chip.dart @@ -88,11 +88,16 @@ class ZetaChip extends ZetaStatefulWidget { class _ZetaChipState extends State { bool selected = false; + bool _draggable = false; @override void initState() { super.initState(); selected = widget.selected ?? false; + _draggable = widget.draggable; + WidgetsBinding.instance.addPostFrameCallback((_) { + _updateControllerState(); + }); } @override @@ -101,10 +106,27 @@ class _ZetaChipState extends State { if (oldWidget.selected != widget.selected) { selected = widget.selected ?? false; } + WidgetsBinding.instance.addPostFrameCallback((_) { + _updateControllerState(); + }); + } + + void _updateControllerState() { + if (widget.onTap == null && widget.onToggle == null) { + _controller.update(WidgetState.disabled, true); + setState(() { + _draggable = false; + }); + } else { + _controller.update(WidgetState.disabled, false); + setState(() { + _draggable = widget.draggable; + }); + } } Widget _renderLeading(Color foregroundColor) { - if (widget.leading.runtimeType == Icon) { + if (widget.leading.runtimeType == ZetaIcon || widget.leading.runtimeType == Icon) { return IconTheme( data: IconThemeData(color: foregroundColor, size: Zeta.of(context).spacing.xl), child: widget.leading!, @@ -120,7 +142,6 @@ class _ZetaChipState extends State { @override Widget build(BuildContext context) { final colors = Zeta.of(context).colors; - final foregroundColor = selected ? colors.textInverse : colors.textDefault; return ZetaRoundedScope( rounded: context.rounded, @@ -129,18 +150,18 @@ class _ZetaChipState extends State { button: widget.onTap != null, label: widget.semanticLabel, child: SelectionContainer.disabled( - child: widget.draggable + child: _draggable ? Draggable( feedback: Material( color: Colors.transparent, - child: child(colors, foregroundColor, isDragging: true), + child: child(colors, isDragging: true), ), childWhenDragging: const Nothing(), data: widget.data, onDragCompleted: widget.onDragCompleted, - child: child(colors, foregroundColor), + child: child(colors), ) - : child(colors, foregroundColor), + : child(colors), ), ), ); @@ -171,25 +192,41 @@ class _ZetaChipState extends State { return Zeta.of(context).spacing.large; } + Color _foregroundColor(ZetaColors colors, bool disabled) { + if (!disabled) { + if (selected) { + return colors.textInverse; + } else { + return colors.textDefault; + } + } else { + return colors.textDisabled; + } + } + ValueListenableBuilder> child( - ZetaColors colors, - Color foregroundColor, { + ZetaColors colors, { bool isDragging = false, }) { return ValueListenableBuilder( valueListenable: _controller, builder: (context, states, child) { + final disabled = states.contains(WidgetState.disabled); + final Color foregroundColor = _foregroundColor(colors, disabled); final double iconSize = selected ? Zeta.of(context).spacing.xl_2 : Zeta.of(context).spacing.none; final bool rounded = context.rounded; return InkWell( - statesController: _controller, + statesController: !disabled ? _controller : null, + mouseCursor: !disabled ? SystemMouseCursors.click : SystemMouseCursors.basic, borderRadius: rounded ? Zeta.of(context).radius.full : Zeta.of(context).radius.none, onTap: () { - if (widget.selected != null) { - setState(() => selected = !selected); - widget.onToggle?.call(selected); - } else { - widget.onTap?.call(); + if (!disabled) { + if (widget.selected != null) { + setState(() => selected = !selected); + widget.onToggle?.call(selected); + } else { + widget.onTap?.call(); + } } }, child: AnimatedContainer( @@ -203,22 +240,23 @@ class _ZetaChipState extends State { ), decoration: BoxDecoration( color: () { - if (states.contains(WidgetState.disabled)) { + if (disabled) { return colors.surfaceDisabled; - } - if (selected) { + } else { + if (selected) { + if (states.contains(WidgetState.hovered)) { + return colors.borderHover; + } + return colors.surfaceDefaultInverse; + } + if (states.contains(WidgetState.pressed) || isDragging) { + return colors.surfaceSelected; + } if (states.contains(WidgetState.hovered)) { - return colors.borderHover; + return colors.surfaceHover; } - return colors.surfaceDefaultInverse; - } - if (states.contains(WidgetState.pressed) || isDragging) { - return colors.surfaceSelected; - } - if (states.contains(WidgetState.hovered)) { - return colors.surfaceHover; + return colors.surfacePrimary; } - return colors.surfacePrimary; }(), borderRadius: rounded ? Zeta.of(context).radius.full : Zeta.of(context).radius.none, border: Border.fromBorderSide( @@ -242,7 +280,7 @@ class _ZetaChipState extends State { child: (selected ? ZetaIcon( ZetaIcons.check_mark, - color: widget.selected! ? colors.iconInverse : Colors.transparent, + color: states.contains(WidgetState.disabled) ? colors.iconDisabled : colors.iconInverse, ) : const Nothing()), ) diff --git a/test/src/components/chips/chip_test.dart b/test/src/components/chips/chip_test.dart index 9a9781e2..aa324ae7 100644 --- a/test/src/components/chips/chip_test.dart +++ b/test/src/components/chips/chip_test.dart @@ -16,13 +16,21 @@ void main() { group('Accessibility Tests', () {}); group('Content Tests', () { - // final debugFillProperties = { - // '': '', - // }; - // debugFillPropertiesTest( - // widget, - // debugFillProperties, - // ); + final debugFillProperties = { + 'label': '"Test Chip"', + 'rounded': 'null', + 'selected': 'null', + 'draggable': 'false', + 'data': 'null', + 'onDragCompleted': 'null', + 'semanticLabel': 'null', + 'onTap': 'null', + 'onToggle': 'null', + }; + debugFillPropertiesTest( + const ZetaChip(label: 'Test Chip'), + debugFillProperties, + ); testWidgets('renders label correctly', (WidgetTester tester) async { await tester.pumpWidget( From 8db89f42048cdd2b2eb3801b26faffefc9623735 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Thu, 7 Nov 2024 16:15:33 +0000 Subject: [PATCH 2/5] fix: changed _updateControllerState to _handleDisabledState --- lib/src/components/chips/chip.dart | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/lib/src/components/chips/chip.dart b/lib/src/components/chips/chip.dart index e6a09f78..545edd73 100644 --- a/lib/src/components/chips/chip.dart +++ b/lib/src/components/chips/chip.dart @@ -95,9 +95,7 @@ class _ZetaChipState extends State { super.initState(); selected = widget.selected ?? false; _draggable = widget.draggable; - WidgetsBinding.instance.addPostFrameCallback((_) { - _updateControllerState(); - }); + _handleDisabledState(); } @override @@ -106,12 +104,10 @@ class _ZetaChipState extends State { if (oldWidget.selected != widget.selected) { selected = widget.selected ?? false; } - WidgetsBinding.instance.addPostFrameCallback((_) { - _updateControllerState(); - }); + _handleDisabledState(); } - void _updateControllerState() { + void _handleDisabledState() { if (widget.onTap == null && widget.onToggle == null) { _controller.update(WidgetState.disabled, true); setState(() { From ce6579409083174379a9ec0e0136e688022d5272 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Thu, 7 Nov 2024 16:17:43 +0000 Subject: [PATCH 3/5] fix: used variable --- lib/src/components/chips/chip.dart | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/src/components/chips/chip.dart b/lib/src/components/chips/chip.dart index 545edd73..b6cb8449 100644 --- a/lib/src/components/chips/chip.dart +++ b/lib/src/components/chips/chip.dart @@ -276,7 +276,7 @@ class _ZetaChipState extends State { child: (selected ? ZetaIcon( ZetaIcons.check_mark, - color: states.contains(WidgetState.disabled) ? colors.iconDisabled : colors.iconInverse, + color: disabled ? colors.iconDisabled : colors.iconInverse, ) : const Nothing()), ) From 822bb0cdf9473cdbab81cab55ea3a777611566b7 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Thu, 7 Nov 2024 16:36:54 +0000 Subject: [PATCH 4/5] feat: added onTap to widgetbook --- example/widgetbook/pages/components/chip_widgetbook.dart | 3 +++ 1 file changed, 3 insertions(+) diff --git a/example/widgetbook/pages/components/chip_widgetbook.dart b/example/widgetbook/pages/components/chip_widgetbook.dart index 057d6d6c..30d34c3c 100644 --- a/example/widgetbook/pages/components/chip_widgetbook.dart +++ b/example/widgetbook/pages/components/chip_widgetbook.dart @@ -10,6 +10,7 @@ Widget inputChipUseCase(BuildContext context) { return WidgetbookScaffold( builder: (context, _) => ZetaInputChip( + onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? () {} : null, label: context.knobs.string(label: 'Label', initialValue: 'Label'), leading: context.knobs.boolean(label: 'Avatar', initialValue: true) ? ZetaAvatar( @@ -26,6 +27,7 @@ Widget inputChipUseCase(BuildContext context) { Widget filterChipUseCase(BuildContext context) => WidgetbookScaffold( builder: (context, _) => ZetaFilterChip( + onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? (value) {} : null, label: context.knobs.string(label: 'Label', initialValue: 'Label'), selected: context.knobs.boolean(label: 'Selected', initialValue: true), ), @@ -34,6 +36,7 @@ Widget filterChipUseCase(BuildContext context) => WidgetbookScaffold( Widget assistChipUseCase(BuildContext context) { return WidgetbookScaffold( builder: (context, _) => ZetaAssistChip( + onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? () {} : null, label: context.knobs.string(label: 'Label', initialValue: 'Label'), leading: ZetaIcon(iconKnob(context)), ), From 507f8485d0794f0b9d003868c870bf636f984499 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Thu, 7 Nov 2024 16:41:18 +0000 Subject: [PATCH 5/5] feat: added rounded to widgetbook --- example/widgetbook/pages/components/chip_widgetbook.dart | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/example/widgetbook/pages/components/chip_widgetbook.dart b/example/widgetbook/pages/components/chip_widgetbook.dart index 30d34c3c..ca802db2 100644 --- a/example/widgetbook/pages/components/chip_widgetbook.dart +++ b/example/widgetbook/pages/components/chip_widgetbook.dart @@ -10,7 +10,8 @@ Widget inputChipUseCase(BuildContext context) { return WidgetbookScaffold( builder: (context, _) => ZetaInputChip( - onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? () {} : null, + onTap: context.knobs.boolean(label: 'Disabled', initialValue: false) ? null : () {}, + rounded: context.knobs.boolean(label: 'Rounded', initialValue: true), label: context.knobs.string(label: 'Label', initialValue: 'Label'), leading: context.knobs.boolean(label: 'Avatar', initialValue: true) ? ZetaAvatar( @@ -27,7 +28,8 @@ Widget inputChipUseCase(BuildContext context) { Widget filterChipUseCase(BuildContext context) => WidgetbookScaffold( builder: (context, _) => ZetaFilterChip( - onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? (value) {} : null, + onTap: context.knobs.boolean(label: 'Disabled', initialValue: false) ? null : (i) {}, + rounded: context.knobs.boolean(label: 'Rounded', initialValue: true), label: context.knobs.string(label: 'Label', initialValue: 'Label'), selected: context.knobs.boolean(label: 'Selected', initialValue: true), ), @@ -36,7 +38,8 @@ Widget filterChipUseCase(BuildContext context) => WidgetbookScaffold( Widget assistChipUseCase(BuildContext context) { return WidgetbookScaffold( builder: (context, _) => ZetaAssistChip( - onTap: context.knobs.boolean(label: 'Selectable', initialValue: true) ? () {} : null, + onTap: context.knobs.boolean(label: 'Disabled', initialValue: false) ? null : () {}, + rounded: context.knobs.boolean(label: 'Rounded', initialValue: true), label: context.knobs.string(label: 'Label', initialValue: 'Label'), leading: ZetaIcon(iconKnob(context)), ),