From e3d003eca13530cc4a3f16a666604a7009724a7e Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Mon, 4 Nov 2024 13:44:55 +0000 Subject: [PATCH 1/4] feat: Added label prop to progress circle which overrides default percentage label --- .../pages/components/progress_example.dart | 1 + .../pages/components/progress_widgetbook.dart | 1 + .../components/progress/progress_circle.dart | 26 +++++++++++++++---- 3 files changed, 23 insertions(+), 5 deletions(-) diff --git a/example/lib/pages/components/progress_example.dart b/example/lib/pages/components/progress_example.dart index 18309cb3..e20ad6df 100644 --- a/example/lib/pages/components/progress_example.dart +++ b/example/lib/pages/components/progress_example.dart @@ -132,6 +132,7 @@ class _WrapperState extends State { child: ZetaProgressCircle( progress: progress, size: widget.circleSize!, + label: '30%', ), ) : SizedBox( diff --git a/example/widgetbook/pages/components/progress_widgetbook.dart b/example/widgetbook/pages/components/progress_widgetbook.dart index 249b5896..ba643a22 100644 --- a/example/widgetbook/pages/components/progress_widgetbook.dart +++ b/example/widgetbook/pages/components/progress_widgetbook.dart @@ -33,5 +33,6 @@ Widget progressCircleUseCase(BuildContext context) => WidgetbookScaffold( labelBuilder: enumLabelBuilder, ), onCancel: context.knobs.boolean(label: "Can Cancel") ? () {} : null, + label: context.knobs.stringOrNull(label: 'Label'), ), ); diff --git a/lib/src/components/progress/progress_circle.dart b/lib/src/components/progress/progress_circle.dart index 2538aafa..50383142 100644 --- a/lib/src/components/progress/progress_circle.dart +++ b/lib/src/components/progress/progress_circle.dart @@ -37,6 +37,7 @@ class ZetaProgressCircle extends ZetaProgress { this.size = ZetaCircleSizes.xl, super.rounded, this.onCancel, + this.label, }); ///Size of [ZetaProgressCircle] @@ -45,6 +46,9 @@ class ZetaProgressCircle extends ZetaProgress { /// Cancel function => cancel upload. final VoidCallback? onCancel; + /// Label for [ZetaProgressCircle], override default percentage label. + final String? label; + @override State createState() => _ZetaProgressCircleState(); @@ -55,7 +59,8 @@ class ZetaProgressCircle extends ZetaProgress { ..add(EnumProperty('size', size)) ..add(DoubleProperty('progress', progress)) ..add(DiagnosticsProperty('rounded', rounded)) - ..add(ObjectFlagProperty.has('onCancel', onCancel)); + ..add(ObjectFlagProperty.has('onCancel', onCancel)) + ..add(StringProperty('label', label)); } } @@ -85,13 +90,11 @@ class _ZetaProgressCircleState extends ZetaProgressState { @override Widget build(BuildContext context) { - final textVal = '${(widget.progress * 100).round()}%'; + final textVal = widget.label ?? '${(widget.progress * 100).round()}%'; final colors = Zeta.of(context).colors; final textWidget = Text( textVal, - style: widget.size != ZetaCircleSizes.s - ? ZetaTextStyles.labelSmall - : ZetaTextStyles.labelSmall.copyWith(fontSize: Zeta.of(context).spacing.small), + style: _getTextSize(), ); return ConstrainedBox( @@ -168,6 +171,19 @@ class _ZetaProgressCircleState extends ZetaProgressState { } } + TextStyle _getTextSize() { + switch (widget.size) { + case ZetaCircleSizes.xs: + case ZetaCircleSizes.s: + return ZetaTextStyles.labelSmall; + case ZetaCircleSizes.m: + return ZetaTextStyles.labelMedium; + case ZetaCircleSizes.l: + case ZetaCircleSizes.xl: + return ZetaTextStyles.labelLarge; + } + } + @override void debugFillProperties(DiagnosticPropertiesBuilder properties) { super.debugFillProperties(properties); From bc5bcc0a1b0734e9f3bb92d5ca56ddbb45b95365 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Mon, 4 Nov 2024 13:46:29 +0000 Subject: [PATCH 2/4] removed mistake --- example/lib/pages/components/progress_example.dart | 1 - 1 file changed, 1 deletion(-) diff --git a/example/lib/pages/components/progress_example.dart b/example/lib/pages/components/progress_example.dart index e20ad6df..18309cb3 100644 --- a/example/lib/pages/components/progress_example.dart +++ b/example/lib/pages/components/progress_example.dart @@ -132,7 +132,6 @@ class _WrapperState extends State { child: ZetaProgressCircle( progress: progress, size: widget.circleSize!, - label: '30%', ), ) : SizedBox( From f73a0636ce4dd8bb741e0e92c2d81ba6f4139173 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Tue, 5 Nov 2024 15:27:01 +0000 Subject: [PATCH 3/4] feat: added maxValue to progress circle --- lib/src/components/progress/progress.dart | 17 +++++++++++++---- .../components/progress/progress_circle.dart | 15 +++++++++++++-- 2 files changed, 26 insertions(+), 6 deletions(-) diff --git a/lib/src/components/progress/progress.dart b/lib/src/components/progress/progress.dart index 0ffa2f14..42bb92a0 100644 --- a/lib/src/components/progress/progress.dart +++ b/lib/src/components/progress/progress.dart @@ -10,14 +10,21 @@ abstract class ZetaProgress extends ZetaStatefulWidget { super.key, super.rounded, this.progress = 0, + this.maxValue = 1, }); /// ZetaProgress value, decimal value ranging from 0.0 - 1.0, 0.5 = 50% final double progress; + + /// Maximum value for progress, defaults to 1 + final double maxValue; + @override void debugFillProperties(DiagnosticPropertiesBuilder properties) { super.debugFillProperties(properties); - properties.add(DoubleProperty('progress', progress)); + properties + ..add(DoubleProperty('progress', progress)) + ..add(DoubleProperty('maxValue', maxValue)); } } @@ -48,7 +55,7 @@ abstract class ZetaProgressState extends State with T ).animate(controller) ..addListener(() { setState(() { - progress = animation.value; + progress = animation.value / widget.maxValue; }); }); } @@ -65,10 +72,12 @@ abstract class ZetaProgressState extends State with T setState(() { animation = Tween( - begin: progress, + begin: progress * widget.maxValue, end: newProgress, ).animate(controller); - controller.forward(from: progress); + controller + ..reset() + ..forward(from: 0); }); } diff --git a/lib/src/components/progress/progress_circle.dart b/lib/src/components/progress/progress_circle.dart index 50383142..6847e401 100644 --- a/lib/src/components/progress/progress_circle.dart +++ b/lib/src/components/progress/progress_circle.dart @@ -34,6 +34,7 @@ class ZetaProgressCircle extends ZetaProgress { const ZetaProgressCircle({ super.key, super.progress = 0, + super.maxValue = 1, this.size = ZetaCircleSizes.xl, super.rounded, this.onCancel, @@ -60,6 +61,7 @@ class ZetaProgressCircle extends ZetaProgress { ..add(DoubleProperty('progress', progress)) ..add(DiagnosticsProperty('rounded', rounded)) ..add(ObjectFlagProperty.has('onCancel', onCancel)) + ..add(DoubleProperty('maxValue', maxValue)) ..add(StringProperty('label', label)); } } @@ -108,6 +110,7 @@ class _ZetaProgressCircleState extends ZetaProgressState { progress: animation.value, rounded: context.rounded, context: context, + maxValue: widget.maxValue, ), child: Center( child: widget.size == ZetaCircleSizes.xs @@ -201,7 +204,12 @@ typedef CirclePainter = _CirclePainter; /// Class definition for [_CirclePainter] class _CirclePainter extends CustomPainter { ///Constructor for [_CirclePainter] - _CirclePainter({this.progress = 0, this.rounded = true, required this.context}); + _CirclePainter({ + this.progress = 0, + this.rounded = true, + required this.context, + this.maxValue = 1, + }); ///Percentage of progress in decimal value, defaults to 0 final double progress; @@ -211,6 +219,9 @@ class _CirclePainter extends CustomPainter { final BuildContext context; + /// Maximum value for progress, defaults to 1 + final double maxValue; + final _paint = Paint(); @override @@ -226,7 +237,7 @@ class _CirclePainter extends CustomPainter { canvas.drawArc( Rect.fromLTRB(0, 0, size.width, size.height), 3 * math.pi / 2, - progress * fullCircle, + progress / maxValue * fullCircle, false, _paint, ); From ed4d2c414b668e4883645b69303bde61243d4262 Mon Sep 17 00:00:00 2001 From: Daniel Eshkeri Date: Tue, 5 Nov 2024 16:19:59 +0000 Subject: [PATCH 4/4] feat: Added maxValue on progress circle to widgetbook --- example/widgetbook/pages/components/progress_widgetbook.dart | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/example/widgetbook/pages/components/progress_widgetbook.dart b/example/widgetbook/pages/components/progress_widgetbook.dart index ba643a22..357ccfce 100644 --- a/example/widgetbook/pages/components/progress_widgetbook.dart +++ b/example/widgetbook/pages/components/progress_widgetbook.dart @@ -25,7 +25,7 @@ Widget progressBarUseCase(BuildContext context) => WidgetbookScaffold( Widget progressCircleUseCase(BuildContext context) => WidgetbookScaffold( builder: (context, _) => ZetaProgressCircle( - progress: context.knobs.double.slider(label: 'Progress', min: 0, max: 1, initialValue: 0.5).toDouble(), + progress: context.knobs.double.input(label: 'Progress', initialValue: 0.5), size: context.knobs.list( initialOption: ZetaCircleSizes.xl, label: 'Size', @@ -34,5 +34,6 @@ Widget progressCircleUseCase(BuildContext context) => WidgetbookScaffold( ), onCancel: context.knobs.boolean(label: "Can Cancel") ? () {} : null, label: context.knobs.stringOrNull(label: 'Label'), + maxValue: context.knobs.double.input(label: 'Max Value', initialValue: 1), ), );