diff --git a/.github/workflows/component-ci.yml b/.github/workflows/component-ci.yml new file mode 100644 index 0000000..e2f6ffe --- /dev/null +++ b/.github/workflows/component-ci.yml @@ -0,0 +1,14 @@ +name: Iconica Standard Component CI Workflow +# Workflow Caller version: 2.0.0 + +on: + pull_request: + workflow_dispatch: + +jobs: + call-global-iconica-workflow: + uses: Iconica-Development/.github/.github/workflows/component-ci.yml@master + secrets: inherit + permissions: write-all + with: + subfolder: "." # add optional subfolder to run workflow in \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md index 3446f82..753002c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,3 +7,8 @@ - Add custom wrap alignment - Add custom widget during animation - Can now set duration to 0 for instant transition + +## [0.0.3] 7 February 2024 + +- Add Figma link +- Add CI and Linter diff --git a/README.md b/README.md index 3ec2b37..46e3298 100644 --- a/README.md +++ b/README.md @@ -3,6 +3,9 @@ Grid to List that animates between grid and list when a child in either gets tap https://user-images.githubusercontent.com/57899901/225304113-28cac130-36e8-4c7b-8fed-50032972ad4f.mp4 +Figma Design that defines this component (only accessible for Iconica developers): https://www.figma.com/file/4WkjwynOz5wFeFBRqTHPeP/Iconica-Design-System?type=design&node-id=357%3A3351&mode=design&t=XulkAJNPQ32ARxWh-1 +Figma clickable prototype that demonstrates this component (only accessible for Iconica developers): https://www.figma.com/proto/4WkjwynOz5wFeFBRqTHPeP/Iconica-Design-System?type=design&node-id=340-611&viewport=470%2C-1472%2C0.12&t=XulkAJNPQ32ARxWh-0&scaling=min-zoom&starting-point-node-id=516%3A1855&show-proto-sidebar=1 + ## Usage To use this package, add `flutter_grid_to_list` as a dependency in your pubspec.yaml file. diff --git a/analysis_options.yaml b/analysis_options.yaml index 61b6c4d..e2b30bf 100644 --- a/analysis_options.yaml +++ b/analysis_options.yaml @@ -1,29 +1,9 @@ -# This file configures the analyzer, which statically analyzes Dart code to -# check for errors, warnings, and lints. -# -# The issues identified by the analyzer are surfaced in the UI of Dart-enabled -# IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be -# invoked from the command line by running `flutter analyze`. +include: package:flutter_iconica_analysis/analysis_options.yaml -# The following line activates a set of recommended lints for Flutter apps, -# packages, and plugins designed to encourage good coding practices. -include: package:flutter_lints/flutter.yaml +# Possible to overwrite the rules from the package + +analyzer: + exclude: linter: - # The lint rules applied to this project can be customized in the - # section below to disable rules from the `package:flutter_lints/flutter.yaml` - # included above or to enable additional rules. A list of all available lints - # and their documentation is published at - # https://dart-lang.github.io/linter/lints/index.html. - # - # Instead of disabling a lint rule for the entire project in the - # section below, it can also be suppressed for a single line of code - # or a specific dart file by using the `// ignore: name_of_lint` and - # `// ignore_for_file: name_of_lint` syntax on the line or in the file - # producing the lint. - rules: - # avoid_print: false # Uncomment to disable the `avoid_print` rule - # prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule - -# Additional information about this file can be found at -# https://dart.dev/guides/language/analysis-options + rules: \ No newline at end of file diff --git a/example/.metadata b/example/.metadata index a51f538..640e771 100644 --- a/example/.metadata +++ b/example/.metadata @@ -1,11 +1,11 @@ # This file tracks properties of this Flutter project. # Used by Flutter tool to assess capabilities and perform upgrades etc. # -# This file should be version controlled. +# This file should be version controlled and should not be manually edited. version: - revision: 2ad6cd72c040113b47ee9055e722606a490ef0da - channel: stable + revision: "41456452f29d64e8deb623a3c927524bcf9f111b" + channel: "stable" project_type: app @@ -13,11 +13,11 @@ project_type: app migration: platforms: - platform: root - create_revision: 2ad6cd72c040113b47ee9055e722606a490ef0da - base_revision: 2ad6cd72c040113b47ee9055e722606a490ef0da - - platform: android - create_revision: 2ad6cd72c040113b47ee9055e722606a490ef0da - base_revision: 2ad6cd72c040113b47ee9055e722606a490ef0da + create_revision: 41456452f29d64e8deb623a3c927524bcf9f111b + base_revision: 41456452f29d64e8deb623a3c927524bcf9f111b + - platform: ios + create_revision: 41456452f29d64e8deb623a3c927524bcf9f111b + base_revision: 41456452f29d64e8deb623a3c927524bcf9f111b # User provided section diff --git a/example/pubspec.lock b/example/pubspec.lock index d6c2f51..9ef75ff 100644 --- a/example/pubspec.lock +++ b/example/pubspec.lock @@ -5,10 +5,10 @@ packages: dependency: transitive description: name: async - sha256: bfe67ef28df125b7dddcea62755991f807aa39a2492a23e1550161692950bbe0 + sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c" url: "https://pub.dev" source: hosted - version: "2.10.0" + version: "2.11.0" boolean_selector: dependency: transitive description: @@ -21,10 +21,10 @@ packages: dependency: transitive description: name: characters - sha256: e6a326c8af69605aec75ed6c187d06b349707a27fbff8222ca9cc2cff167975c + sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.3.0" clock: dependency: transitive description: @@ -37,10 +37,10 @@ packages: dependency: transitive description: name: collection - sha256: cfc915e6923fe5ce6e153b0723c753045de46de1b4d63771530504004a45fae0 + sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a url: "https://pub.dev" source: hosted - version: "1.17.0" + version: "1.18.0" cupertino_icons: dependency: "direct main" description: @@ -82,14 +82,6 @@ packages: description: flutter source: sdk version: "0.0.0" - js: - dependency: transitive - description: - name: js - sha256: "5528c2f391ededb7775ec1daa69e65a2d61276f7552de2b5f7b8d34ee9fd4ab7" - url: "https://pub.dev" - source: hosted - version: "0.6.5" lints: dependency: transitive description: @@ -102,34 +94,34 @@ packages: dependency: transitive description: name: matcher - sha256: "16db949ceee371e9b99d22f88fa3a73c4e59fd0afed0bd25fc336eb76c198b72" + sha256: "1803e76e6653768d64ed8ff2e1e67bea3ad4b923eb5c56a295c3e634bad5960e" url: "https://pub.dev" source: hosted - version: "0.12.13" + version: "0.12.16" material_color_utilities: dependency: transitive description: name: material_color_utilities - sha256: d92141dc6fe1dad30722f9aa826c7fbc896d021d792f80678280601aff8cf724 + sha256: "9528f2f296073ff54cb9fee677df673ace1218163c3bc7628093e7eed5203d41" url: "https://pub.dev" source: hosted - version: "0.2.0" + version: "0.5.0" meta: dependency: transitive description: name: meta - sha256: "6c268b42ed578a53088d834796959e4a1814b5e9e164f147f580a386e5decf42" + sha256: a6e590c838b18133bb482a2745ad77c5bb7715fb0451209e1a7567d416678b8e url: "https://pub.dev" source: hosted - version: "1.8.0" + version: "1.10.0" path: dependency: transitive description: name: path - sha256: db9d4f58c908a4ba5953fcee2ae317c94889433e5024c27ce74a37f94267945b + sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917" url: "https://pub.dev" source: hosted - version: "1.8.2" + version: "1.8.3" sky_engine: dependency: transitive description: flutter @@ -139,26 +131,26 @@ packages: dependency: transitive description: name: source_span - sha256: dd904f795d4b4f3b870833847c461801f6750a9fa8e61ea5ac53f9422b31f250 + sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" url: "https://pub.dev" source: hosted - version: "1.9.1" + version: "1.10.0" stack_trace: dependency: transitive description: name: stack_trace - sha256: c3c7d8edb15bee7f0f74debd4b9c5f3c2ea86766fe4178eb2a18eb30a0bdaed5 + sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" url: "https://pub.dev" source: hosted - version: "1.11.0" + version: "1.11.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: "83615bee9045c1d322bbbd1ba209b7a749c2cbcdcb3fdd1df8eb488b3279c1c8" + sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" string_scanner: dependency: transitive description: @@ -179,10 +171,10 @@ packages: dependency: transitive description: name: test_api - sha256: ad540f65f92caa91bf21dfc8ffb8c589d6e4dc0c2267818b4cc2792857706206 + sha256: "5c2f730018264d276c20e4f1503fd1308dfbbae39ec8ee63c5236311ac06954b" url: "https://pub.dev" source: hosted - version: "0.4.16" + version: "0.6.1" vector_math: dependency: transitive description: @@ -191,5 +183,13 @@ packages: url: "https://pub.dev" source: hosted version: "2.1.4" + web: + dependency: transitive + description: + name: web + sha256: afe077240a270dcfd2aafe77602b4113645af95d0ad31128cc02bce5ac5d5152 + url: "https://pub.dev" + source: hosted + version: "0.3.0" sdks: - dart: ">=2.19.3 <3.0.0" + dart: ">=3.2.0-194.0.dev <4.0.0" diff --git a/example/test/widget_test.dart b/example/test/widget_test.dart new file mode 100644 index 0000000..b84fe39 --- /dev/null +++ b/example/test/widget_test.dart @@ -0,0 +1,32 @@ +// This is a basic Flutter widget test. +// +// To perform an interaction with a widget in your test, use the WidgetTester +// utility in the flutter_test package. For example, you can send tap and scroll +// gestures. You can also use WidgetTester to find child widgets in the widget +// tree, read text, and verify that the values of widget properties are correct. + +import 'package:flutter/material.dart'; +import 'package:flutter_test/flutter_test.dart'; + +import 'package:example/main.dart'; + +void main() { + testWidgets('Counter increments smoke test', (WidgetTester tester) async { + // Build our app and trigger a frame. + await tester.pumpWidget(const MaterialApp( + home: GridToList(), + )); + + // Verify that our counter starts at 0. + expect(find.text('0'), findsOneWidget); + expect(find.text('1'), findsNothing); + + // Tap the '+' icon and trigger a frame. + await tester.tap(find.byIcon(Icons.add)); + await tester.pump(); + + // Verify that our counter has incremented. + expect(find.text('0'), findsNothing); + expect(find.text('1'), findsOneWidget); + }); +} diff --git a/lib/flutter_grid_to_list.dart b/lib/flutter_grid_to_list.dart index 392de52..f682dd2 100644 --- a/lib/flutter_grid_to_list.dart +++ b/lib/flutter_grid_to_list.dart @@ -1,7 +1,7 @@ // SPDX-FileCopyrightText: 2022 Iconica // // SPDX-License-Identifier: BSD-3-Clause - +/// library flutter_grid_to_list; export 'src/animated_grid_to_list.dart'; diff --git a/lib/src/animated_grid_to_list.dart b/lib/src/animated_grid_to_list.dart index f267fcc..376eb0a 100644 --- a/lib/src/animated_grid_to_list.dart +++ b/lib/src/animated_grid_to_list.dart @@ -10,12 +10,12 @@ export 'animated_grid_to_list_item_builder.dart'; class AnimatedGridToList extends StatefulWidget { const AnimatedGridToList({ - Key? key, required this.itemBuilder, required this.controller, + super.key, this.startWithGrid = true, this.onTap, - }) : super(key: key); + }); final AnimatedGridToListItemBuilder itemBuilder; final AnimatedGridToListController controller; @@ -91,14 +91,14 @@ class AnimatedGridToListController extends ChangeNotifier { double? _initalHeight; double? _initialWidth; double? _previousScrollOffset; - double? _previousScrollOffsetCopy; + late double? _previousScrollOffsetCopy; double _spacing = 0; bool _isAnimating = false; bool _isExpanded = false; int? _tappedItem; - int? _prevIndex; + late int? _prevIndex; WrapAlignment _wrapAlignment = WrapAlignment.center; @@ -147,7 +147,7 @@ class AnimatedGridToListController extends ChangeNotifier { void _handleScroll(int index) { switch (_type) { case GridToListType.grid: - _scrollController.jumpTo((index * (_boxHeight ?? 0))); + _scrollController.jumpTo(index * (_boxHeight ?? 0)); if ([WrapAlignment.start, WrapAlignment.end].contains(_wrapAlignment) && _controller.value > 0.5) { _wrapAlignment = WrapAlignment.center; @@ -209,8 +209,11 @@ class AnimatedGridToListController extends ChangeNotifier { _finalize(_previousScrollOffsetCopy!); } - WrapAlignment _determineAlignment(int index, BuildContext context, - AnimatedGridToListItemBuilder itemBuilder) { + WrapAlignment _determineAlignment( + int index, + BuildContext context, + AnimatedGridToListItemBuilder itemBuilder, + ) { var amountOfItems = ((context.size?.width ?? 0) / itemBuilder.gridItemSize.width).floor(); @@ -253,10 +256,12 @@ class AnimatedGridToListController extends ChangeNotifier { } } - /// Can be used to retrieve the status of the widget. This is only useful if you use [shrink] and [expand] methods + /// Can be used to retrieve the status of the widget. This is only useful if + /// you use [shrink] and [expand] methods bool get isExpanded => _isExpanded; - /// Can be called to shrink to widget to it's grid state. Only works when the current state is of type [GridToListType.list] + /// Can be called to shrink to widget to it's grid state. Only works when the + /// current state is of type [GridToListType.list] void shrink([Duration? duration]) { _isExpanded = false; if (_type == GridToListType.list) { @@ -264,7 +269,8 @@ class AnimatedGridToListController extends ChangeNotifier { } } - /// Can be called to expand to widget to it's list state. Only works when the current state is of type [GridToListType.grid] + /// Can be called to expand to widget to it's list state. Only works when the + /// current state is of type [GridToListType.grid] /// /// Gets an index to determine which item it needs to transform. void expand(int index, [Duration? duration]) { @@ -275,7 +281,8 @@ class AnimatedGridToListController extends ChangeNotifier { } } - /// Can be called to dynamically change the state of the widget. Works in either [GridToListType.grid] or [GridToListType.list] + /// Can be called to dynamically change the state of the widget. Works in + /// either [GridToListType.grid] or [GridToListType.list] /// /// Gets an index to determine which item it needs to transform. void resize(int index, Duration? duration) { diff --git a/lib/src/animated_grid_to_list_item_builder.dart b/lib/src/animated_grid_to_list_item_builder.dart index 24a56a3..40bc771 100644 --- a/lib/src/animated_grid_to_list_item_builder.dart +++ b/lib/src/animated_grid_to_list_item_builder.dart @@ -5,13 +5,17 @@ import 'package:flutter/material.dart'; /// Class required by [AnimatedGridToList] to build items. -/// Requires [gridItemBuilder] which is an [IndexedWidgetBuilder] to build items in [AnimatedGridToList] grid state. +/// Requires [gridItemBuilder] which is an [IndexedWidgetBuilder] to build items +/// in [AnimatedGridToList] grid state. /// -/// Requires [listItemBuilder] which is an [IndexedWidgetBuilder] to build items in [AnimatedGridToList] list state. +/// Requires [listItemBuilder] which is an [IndexedWidgetBuilder] to build items +/// in [AnimatedGridToList] list state. /// -/// Requires [gridItemSize] which is of type [Size] to build the items and handle the scrolling accordingly. +/// Requires [gridItemSize] which is of type [Size] to build the items and +/// handle the scrolling accordingly. /// -/// Requires [listItemSize] which is of type [Size] to build the items and handle the scrolling accordingly. +/// Requires [listItemSize] which is of type [Size] to build the items and +/// handle the scrolling accordingly. /// /// It also requires an [itemCount], which is of type [int]. class AnimatedGridToListItemBuilder { @@ -34,10 +38,12 @@ class AnimatedGridToListItemBuilder { /// [IndexedWidgetBuilder] which build the items in animated state. final IndexedWidgetBuilder? animatedItemBuilder; - /// A [Size] to build the items in the correct manner and handle scrolling in grid state. + /// A [Size] to build the items in the correct manner and handle scrolling + /// in grid state. final Size gridItemSize; - /// A [Size] to build the items in the correct manner and handle scrolling in list state. + /// A [Size] to build the items in the correct manner and handle scrolling + /// in list state. final Size listItemSize; /// A [WrapAlignment] to align the items in the correct manner. diff --git a/lib/src/animated_grid_to_list_type.dart b/lib/src/animated_grid_to_list_type.dart index 9d75623..fe5d695 100644 --- a/lib/src/animated_grid_to_list_type.dart +++ b/lib/src/animated_grid_to_list_type.dart @@ -5,18 +5,22 @@ import 'package:flutter/material.dart'; import 'package:flutter_grid_to_list/src/animated_grid_to_list_item_builder.dart'; -/// An enum to which offers the possibilties the [AnimatedGridToList] can be rendered in. +/// An enum to which offers the possibilties the [AnimatedGridToList] can be +/// rendered in. enum GridToListType { - /// [grid] type of [GridToListType] which build a grid for [AnimatedGridToList] + /// [grid] type of [GridToListType] which build a grid for + /// [AnimatedGridToList] grid, - /// [list] type of [GridToListType] which build a grid for [AnimatedGridToList] + /// [list] type of [GridToListType] which build a grid for + /// [AnimatedGridToList] list, } extension NextType on GridToListType { - /// Extenstion method on [GridToListType] which can be called to return the next value. - get next => + /// Extenstion method on [GridToListType] which can be called to return + /// the next value. + GridToListType get next => this == GridToListType.grid ? GridToListType.list : GridToListType.grid; } @@ -31,53 +35,53 @@ extension Render on GridToListType { required Function(int)? onTap, required BuildContext context, required bool isAnimating, - }) { - return !isAnimating - ? Wrap( - alignment: itemBuilder.wrapAlignment, - spacing: spacing, - children: [ - for (int i = 0; i < itemBuilder.itemCount; i++) ...[ - Opacity( - opacity: isAnimating && tappedItem == i - ? 1 - : isAnimating && tappedItem != i - ? 0 - : 1, - child: this == GridToListType.grid - ? SizedBox( - width: boxWidth ?? itemBuilder.gridItemSize.width, - height: boxHeight ?? itemBuilder.gridItemSize.height, - child: GestureDetector( - onTap: () => onTap?.call(i), - child: itemBuilder.gridItemBuilder(context, i), + }) => + !isAnimating + ? Wrap( + alignment: itemBuilder.wrapAlignment, + spacing: spacing, + children: [ + for (int i = 0; i < itemBuilder.itemCount; i++) ...[ + Opacity( + opacity: isAnimating && tappedItem == i + ? 1 + : isAnimating && tappedItem != i + ? 0 + : 1, + child: this == GridToListType.grid + ? SizedBox( + width: boxWidth ?? itemBuilder.gridItemSize.width, + height: + boxHeight ?? itemBuilder.gridItemSize.height, + child: GestureDetector( + onTap: () => onTap?.call(i), + child: itemBuilder.gridItemBuilder(context, i), + ), + ) + : SizedBox( + width: boxWidth ?? itemBuilder.listItemSize.width, + height: null, + child: GestureDetector( + onTap: () => onTap?.call(i), + child: itemBuilder.listItemBuilder(context, i), + ), ), - ) - : SizedBox( - width: boxWidth ?? itemBuilder.listItemSize.width, - height: null, - child: GestureDetector( - onTap: () => onTap?.call(i), - child: itemBuilder.listItemBuilder(context, i), - ), - ), - ), + ), + ], ], - ], - ) - : Align( - alignment: tappedItem != itemBuilder.itemCount - 1 - ? Alignment.topCenter - : Alignment.bottomCenter, - child: SizedBox( - width: boxWidth ?? itemBuilder.listItemSize.width, - height: boxHeight ?? itemBuilder.listItemSize.height, - child: GestureDetector( - child: itemBuilder.animatedItemBuilder != null - ? itemBuilder.animatedItemBuilder!(context, tappedItem!) - : itemBuilder.listItemBuilder(context, tappedItem!), + ) + : Align( + alignment: tappedItem != itemBuilder.itemCount - 1 + ? Alignment.topCenter + : Alignment.bottomCenter, + child: SizedBox( + width: boxWidth ?? itemBuilder.listItemSize.width, + height: boxHeight ?? itemBuilder.listItemSize.height, + child: GestureDetector( + child: itemBuilder.animatedItemBuilder != null + ? itemBuilder.animatedItemBuilder!(context, tappedItem!) + : itemBuilder.listItemBuilder(context, tappedItem!), + ), ), - ), - ); - } + ); } diff --git a/pubspec.lock b/pubspec.lock index b18b3f7..d7df4f2 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -5,10 +5,10 @@ packages: dependency: transitive description: name: async - sha256: bfe67ef28df125b7dddcea62755991f807aa39a2492a23e1550161692950bbe0 + sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c" url: "https://pub.dev" source: hosted - version: "2.10.0" + version: "2.11.0" boolean_selector: dependency: transitive description: @@ -21,10 +21,10 @@ packages: dependency: transitive description: name: characters - sha256: e6a326c8af69605aec75ed6c187d06b349707a27fbff8222ca9cc2cff167975c + sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.3.0" clock: dependency: transitive description: @@ -37,10 +37,10 @@ packages: dependency: transitive description: name: collection - sha256: cfc915e6923fe5ce6e153b0723c753045de46de1b4d63771530504004a45fae0 + sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a url: "https://pub.dev" source: hosted - version: "1.17.0" + version: "1.18.0" cupertino_icons: dependency: "direct main" description: @@ -62,8 +62,17 @@ packages: description: flutter source: sdk version: "0.0.0" - flutter_lints: + flutter_iconica_analysis: dependency: "direct dev" + description: + path: "." + ref: "6.0.0" + resolved-ref: "5f0a02791db6785add4e445d383a1ac012fa8f55" + url: "https://github.com/Iconica-Development/flutter_iconica_analysis" + source: git + version: "6.0.0" + flutter_lints: + dependency: transitive description: name: flutter_lints sha256: aeb0b80a8b3709709c9cc496cdc027c5b3216796bc0af0ce1007eaf24464fd4c @@ -75,14 +84,6 @@ packages: description: flutter source: sdk version: "0.0.0" - js: - dependency: transitive - description: - name: js - sha256: "5528c2f391ededb7775ec1daa69e65a2d61276f7552de2b5f7b8d34ee9fd4ab7" - url: "https://pub.dev" - source: hosted - version: "0.6.5" lints: dependency: transitive description: @@ -95,34 +96,34 @@ packages: dependency: transitive description: name: matcher - sha256: "16db949ceee371e9b99d22f88fa3a73c4e59fd0afed0bd25fc336eb76c198b72" + sha256: "1803e76e6653768d64ed8ff2e1e67bea3ad4b923eb5c56a295c3e634bad5960e" url: "https://pub.dev" source: hosted - version: "0.12.13" + version: "0.12.16" material_color_utilities: dependency: transitive description: name: material_color_utilities - sha256: d92141dc6fe1dad30722f9aa826c7fbc896d021d792f80678280601aff8cf724 + sha256: "9528f2f296073ff54cb9fee677df673ace1218163c3bc7628093e7eed5203d41" url: "https://pub.dev" source: hosted - version: "0.2.0" + version: "0.5.0" meta: dependency: transitive description: name: meta - sha256: "6c268b42ed578a53088d834796959e4a1814b5e9e164f147f580a386e5decf42" + sha256: a6e590c838b18133bb482a2745ad77c5bb7715fb0451209e1a7567d416678b8e url: "https://pub.dev" source: hosted - version: "1.8.0" + version: "1.10.0" path: dependency: transitive description: name: path - sha256: db9d4f58c908a4ba5953fcee2ae317c94889433e5024c27ce74a37f94267945b + sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917" url: "https://pub.dev" source: hosted - version: "1.8.2" + version: "1.8.3" sky_engine: dependency: transitive description: flutter @@ -132,26 +133,26 @@ packages: dependency: transitive description: name: source_span - sha256: dd904f795d4b4f3b870833847c461801f6750a9fa8e61ea5ac53f9422b31f250 + sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" url: "https://pub.dev" source: hosted - version: "1.9.1" + version: "1.10.0" stack_trace: dependency: transitive description: name: stack_trace - sha256: c3c7d8edb15bee7f0f74debd4b9c5f3c2ea86766fe4178eb2a18eb30a0bdaed5 + sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" url: "https://pub.dev" source: hosted - version: "1.11.0" + version: "1.11.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: "83615bee9045c1d322bbbd1ba209b7a749c2cbcdcb3fdd1df8eb488b3279c1c8" + sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" string_scanner: dependency: transitive description: @@ -172,10 +173,10 @@ packages: dependency: transitive description: name: test_api - sha256: ad540f65f92caa91bf21dfc8ffb8c589d6e4dc0c2267818b4cc2792857706206 + sha256: "5c2f730018264d276c20e4f1503fd1308dfbbae39ec8ee63c5236311ac06954b" url: "https://pub.dev" source: hosted - version: "0.4.16" + version: "0.6.1" vector_math: dependency: transitive description: @@ -184,5 +185,13 @@ packages: url: "https://pub.dev" source: hosted version: "2.1.4" + web: + dependency: transitive + description: + name: web + sha256: afe077240a270dcfd2aafe77602b4113645af95d0ad31128cc02bce5ac5d5152 + url: "https://pub.dev" + source: hosted + version: "0.3.0" sdks: - dart: ">=2.19.3 <3.0.0" + dart: ">=3.2.0-194.0.dev <4.0.0" diff --git a/pubspec.yaml b/pubspec.yaml index b4e280c..ec21bf1 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -2,7 +2,7 @@ name: flutter_grid_to_list description: A new Flutter project. publish_to: "none" -version: 0.0.2+1 +version: 0.0.3 environment: sdk: ">=2.19.3 <3.0.0" @@ -15,7 +15,10 @@ dependencies: dev_dependencies: flutter_test: sdk: flutter - flutter_lints: ^2.0.0 + flutter_iconica_analysis: + git: + url: https://github.com/Iconica-Development/flutter_iconica_analysis + ref: 6.0.0 flutter: uses-material-design: true