â ï¸ **Dependabot is rebasing this PR** â ï¸ Rebasing might not happen immediately, so don't worry if this takes some time. Note: if you make any changes to this PR yourself, they will take precedence over the rebase. --- Bumps [go_router](https://github.com/flutter/packages/tree/main/packages) from 11.1.4 to 12.0.0. <details> <summary>Commits</summary> <ul> <li><a href="1a24dadf92"><code>1a24dad</code></a> [go_router] adds ability to dynamically update routing table. (<a href="https://github.com/flutter/packages/tree/main/packages/issues/5079">#5079</a>)</li> <li><a href="47a14fd229"><code>47a14fd</code></a> [flutter_lints] rev flutter_lints to 3.0; increase dep on package:lints (<a href="https://github.com/flutter/packages/tree/main/packages/issues/5177">#5177</a>)</li> <li><a href="d4390624a6"><code>d439062</code></a> [gis_web] Adds FedCM toggle. (<a href="https://github.com/flutter/packages/tree/main/packages/issues/5123">#5123</a>)</li> <li><a href="e8127e76d5"><code>e8127e7</code></a> [quick_actions] Convert android to pigeon (<a href="https://github.com/flutter/packages/tree/main/packages/issues/5099">#5099</a>)</li> <li><a href="b96a6dae0c"><code>b96a6da</code></a> [flutter_image] added example app (<a href="https://github.com/flutter/packages/tree/main/packages/issues/4353">#4353</a>)</li> <li>See full diff in <a href="https://github.com/flutter/packages/commits/go_router-v12.0.0/packages">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details>
provider_shopper
A Flutter sample app that shows a state management approach using the Provider package. This is the app discussed in the Simple app state management section of flutter.dev.
Goals for this sample
- Show simple use of
Providerfor providing an immutable value to a subtree - Illustrate a simple state management approach using the ChangeNotifier class
- Show use of
ProxyProviderfor provided objects that depend on other provided objects
The important bits
lib/main.dart
Here the app sets up objects it needs to track state: a catalog and a shopping cart. It builds
a MultiProvider to provide both objects at once to widgets further down the tree.
The CartModel instance is provided using a ChangeNotifierProxyProvider, which combines
two types of functionality:
- It will automatically subscribe to changes in
CartModel(if you only want this functionality simply useChangeNotifierProvider). - It takes the value of a previously provided object (in this case,
CatalogModel, provided just above), and uses it to build the value ofCartModel(if you only want this functionality, simply useProxyProvider).
lib/models/*
This directory contains the model classes that are provided in main.dart. These classes
represent the app state.
lib/screens/*
This directory contains widgets used to construct the two screens of the app: the catalog and
the cart. These widgets have access to the current state of both the catalog and the cart
via Provider.of.
Questions/issues
If you have a general question about Provider, the best places to go are:
If you run into an issue with the sample itself, please file an issue in the main Flutter repo.