From 9286d7a7371a2e47370374e9572c11b16fdf15d4 Mon Sep 17 00:00:00 2001 From: Lucas Oliveira <62367544+tilucasoli@users.noreply.github.com> Date: Fri, 27 Sep 2024 14:09:05 -0300 Subject: [PATCH] feat: add error state to MixWidgetState (#489) --- examples/todo_list/.gitignore | 2 ++ .../internal/mix_widget_state_builder.dart | 12 ++++++-- .../widget_state/widget_state_controller.dart | 7 +++++ .../context_variant_util/on_util.dart | 1 + .../src/variants/widget_state_variant.dart | 5 ++++ .../widget_state_controller_test.dart | 30 ++++++++++++------- 6 files changed, 44 insertions(+), 13 deletions(-) diff --git a/examples/todo_list/.gitignore b/examples/todo_list/.gitignore index 29a3a5017..79c113f9b 100644 --- a/examples/todo_list/.gitignore +++ b/examples/todo_list/.gitignore @@ -5,9 +5,11 @@ *.swp .DS_Store .atom/ +.build/ .buildlog/ .history .svn/ +.swiftpm/ migrate_working_dir/ # IntelliJ related diff --git a/packages/mix/lib/src/core/widget_state/internal/mix_widget_state_builder.dart b/packages/mix/lib/src/core/widget_state/internal/mix_widget_state_builder.dart index 19578ac10..aead49b4c 100644 --- a/packages/mix/lib/src/core/widget_state/internal/mix_widget_state_builder.dart +++ b/packages/mix/lib/src/core/widget_state/internal/mix_widget_state_builder.dart @@ -25,6 +25,7 @@ class MixWidgetStateBuilder extends StatelessWidget { pressed: controller.pressed, dragged: controller.dragged, selected: controller.selected, + error: controller.error, longPressed: controller.longPressed, child: Builder(builder: builder), ); @@ -42,6 +43,7 @@ class MixWidgetStateModel extends InheritedModel { required this.pressed, required this.dragged, required this.selected, + required this.error, required this.longPressed, required super.child, }); @@ -70,6 +72,7 @@ class MixWidgetStateModel extends InheritedModel { MixWidgetState.dragged => model.dragged, MixWidgetState.selected => model.selected, MixWidgetState.longPressed => model.longPressed, + MixWidgetState.error => model.error, }; } @@ -77,9 +80,10 @@ class MixWidgetStateModel extends InheritedModel { final bool hovered; final bool focused; final bool pressed; + final bool longPressed; final bool dragged; final bool selected; - final bool longPressed; + final bool error; @override bool updateShouldNotify(MixWidgetStateModel oldWidget) { @@ -89,7 +93,8 @@ class MixWidgetStateModel extends InheritedModel { oldWidget.pressed != pressed || oldWidget.dragged != dragged || oldWidget.selected != selected || - oldWidget.longPressed != longPressed; + oldWidget.longPressed != longPressed || + oldWidget.error != error; } @override @@ -110,6 +115,7 @@ class MixWidgetStateModel extends InheritedModel { oldWidget.selected != selected && dependencies.contains(MixWidgetState.selected) || oldWidget.longPressed != longPressed && - dependencies.contains(MixWidgetState.longPressed); + dependencies.contains(MixWidgetState.longPressed) || + oldWidget.error != error && dependencies.contains(MixWidgetState.error); } } diff --git a/packages/mix/lib/src/core/widget_state/widget_state_controller.dart b/packages/mix/lib/src/core/widget_state/widget_state_controller.dart index b7156177f..55decab2f 100644 --- a/packages/mix/lib/src/core/widget_state/widget_state_controller.dart +++ b/packages/mix/lib/src/core/widget_state/widget_state_controller.dart @@ -9,6 +9,7 @@ enum MixWidgetState { dragged, selected, disabled, + error, longPressed; static const of = MixWidgetStateModel.of; @@ -49,6 +50,9 @@ class MixWidgetStateController extends ChangeNotifier { /// Whether the widget is currently in the selected state. bool get selected => value.contains(MixWidgetState.selected); + /// Whether the widget is currently in the error state. + bool get error => value.contains(MixWidgetState.error); + /// Whether the widget is currently being long-pressed. bool get longPressed => value.contains(MixWidgetState.longPressed); @@ -70,6 +74,9 @@ class MixWidgetStateController extends ChangeNotifier { /// Sets whether the widget is in the selected state. set selected(bool value) => update(MixWidgetState.selected, value); + /// Sets whether the widget is in the selected state. + set error(bool value) => update(MixWidgetState.error, value); + /// Sets whether the widget is being long-pressed. set longPressed(bool value) => update(MixWidgetState.longPressed, value); diff --git a/packages/mix/lib/src/variants/context_variant_util/on_util.dart b/packages/mix/lib/src/variants/context_variant_util/on_util.dart index 4fc9c71df..5e958206b 100644 --- a/packages/mix/lib/src/variants/context_variant_util/on_util.dart +++ b/packages/mix/lib/src/variants/context_variant_util/on_util.dart @@ -50,6 +50,7 @@ class OnContextVariantUtility { final selected = const OnSelectedVariant(); final unselected = const OnNotVariant(OnSelectedVariant()); final dragged = const OnDraggedVariant(); + final error = const OnErrorVariant(); /// Creates an [OnNotVariant] with the specified [variant]. /// diff --git a/packages/mix/lib/src/variants/widget_state_variant.dart b/packages/mix/lib/src/variants/widget_state_variant.dart index 5ceca5e04..77c109846 100644 --- a/packages/mix/lib/src/variants/widget_state_variant.dart +++ b/packages/mix/lib/src/variants/widget_state_variant.dart @@ -88,3 +88,8 @@ class OnSelectedVariant extends _ToggleMixStateVariant { class OnDraggedVariant extends _ToggleMixStateVariant { const OnDraggedVariant() : super(MixWidgetState.dragged); } + +/// Applies styles when the widget is error. +class OnErrorVariant extends _ToggleMixStateVariant { + const OnErrorVariant() : super(MixWidgetState.error); +} diff --git a/packages/mix/test/src/widgets/widget_state/widget_state_controller_test.dart b/packages/mix/test/src/widgets/widget_state/widget_state_controller_test.dart index 4b53e693b..a21ea2a5f 100644 --- a/packages/mix/test/src/widgets/widget_state/widget_state_controller_test.dart +++ b/packages/mix/test/src/widgets/widget_state/widget_state_controller_test.dart @@ -126,6 +126,7 @@ void main() { controller.dragged = true; controller.selected = true; controller.longPressed = true; + controller.error = true; await tester.pumpWidget( MaterialApp( @@ -137,6 +138,7 @@ void main() { dragged: controller.dragged, selected: controller.selected, longPressed: controller.longPressed, + error: controller.error, child: Container(), ), ), @@ -151,6 +153,7 @@ void main() { expect(foundModel.dragged, isTrue); expect(foundModel.selected, isTrue); expect(foundModel.longPressed, isTrue); + expect(foundModel.error, isTrue); }); testWidgets('hasStateOf returns if state is set', (tester) async { @@ -164,20 +167,23 @@ void main() { dragged: false, selected: false, longPressed: false, + error: false, child: Builder( builder: (context) { expect( - MixWidgetStateModel.hasStateOf( - context, - MixWidgetState.disabled, - ), - isTrue); + MixWidgetStateModel.hasStateOf( + context, + MixWidgetState.disabled, + ), + isTrue, + ); expect( - MixWidgetStateModel.hasStateOf( - context, - MixWidgetState.hovered, - ), - isFalse); + MixWidgetStateModel.hasStateOf( + context, + MixWidgetState.hovered, + ), + isFalse, + ); return Container(); }, ), @@ -195,6 +201,7 @@ void main() { dragged: false, selected: false, longPressed: false, + error: false, child: Container(), ); final newModel = MixWidgetStateModel( @@ -205,6 +212,7 @@ void main() { dragged: false, selected: false, longPressed: false, + error: false, child: Container(), ); @@ -220,6 +228,7 @@ void main() { dragged: false, selected: false, longPressed: false, + error: false, child: Container(), ); final newModel = MixWidgetStateModel( @@ -230,6 +239,7 @@ void main() { dragged: false, selected: false, longPressed: false, + error: false, child: Container(), );