go_router 6.5.2 go_router: ^6.5.2 copied to clipboard
A declarative router for Flutter based on Navigation 2 supporting deep linking, data-driven routes and more
6.5.2 #
- NoTransitionPage now has an instant reverse transition
6.5.1 #
- Fixes an issue where the params are removed after popping.
6.5.0 #
- Supports returning values on pop.
6.4.1 #
- Adds
initialExtra
to GoRouter to pass extra data alongsideinitialRoute
.
6.4.0 #
- Adds
replace
method to that replaces the current route with a new one and keeps the same page key. This is useful for when you want to update the query params without changing the page key ([#115902]https://github.com/flutter/flutter/issues/115902).
6.3.0 #
- Aligns Dart and Flutter SDK constraints.
- Updates compileSdkVersion to 33.
- Updates example app to iOS 11.
- Adds
navigatorKey
toTypedShellRoute
- Adds
parentNavigatorKey
toTypedGoRoute
- Updates documentation in matching methods.
6.2.0 #
- Exports supertypes in route_data.dart library.
6.1.0 #
- Adds
GoRouter.maybeOf
to get the closestGoRouter
from the context, if there is any.
6.0.10 #
- Adds helpers for go_router_builder for ShellRoute support
6.0.9 #
- Fixes deprecation message for
GoRouterState.namedLocation
6.0.7 #
- Add observers parameter to the ShellRoute that will be passed to the nested Navigator.
- Use
HeroControllerScope
for nested Navigator that fixes Hero Widgets not animating in Nested Navigator.
6.0.6 #
- Adds
reverseTransitionDuration
toCustomTransitionPage
6.0.5 #
- Fixes unnecessary_null_comparison lint warnings.
6.0.4 #
- Fixes redirection info log.
6.0.3 #
- Makes
CustomTransitionPage.barrierDismissible
work
6.0.2 #
- Fixes missing result on pop in go_router extension.
6.0.1 #
- Fixes crashes when popping navigators manually.
- Fixes trailing slashes after pops.
6.0.0 #
- BREAKING CHANGE
GoRouteData
'sredirect
now takes 2 parametersBuildContext context, GoRouterState state
.GoRouteData
'sbuild
now takes 2 parametersBuildContext context, GoRouterState state
.GoRouteData
'sbuildPageWithState
has been removed and replaced bybuildPage
with now takes 2 parametersBuildContext context, GoRouterState state
.replace
fromGoRouter
,GoRouterDelegate
andGoRouterHelper
has been renamed intopushReplacement
.replaceNamed
fromGoRouter
,GoRouterDelegate
andGoRouterHelper
has been renamed intopushReplacementNamed
.- go_router v6 migration guide
5.2.4 #
- Fixes crashes when using async redirect.
5.2.3 #
- Fixes link for router configuration and sub-routes
5.2.2 #
- Fixes
pop
andpush
to update urls correctly.
5.2.1 #
- Refactors
GoRouter.pop
to be able to pop individual pageless route with result.
5.2.0 #
- Fixes
GoRouterState.location
andGoRouterState.param
to return correct value. - Cleans up
RouteMatch
andRouteMatchList
API.
5.1.10 #
- Fixes link of ShellRoute in README.
5.1.9 #
- Fixes broken links in documentation.
5.1.8 #
- Fixes a bug with
replace
where it was not generated a newpageKey
.
5.1.7 #
- Adds documentation using dartdoc topics.
5.1.6 #
- Fixes crashes when multiple
GoRoute
s use the sameparentNavigatorKey
in a route subtree.
5.1.5 #
- Adds migration guide for 5.1.2 to readme.
5.1.4 #
- Fixes the documentation by removing the
ShellRoute
's non-existingpath
parameter from it.
5.1.3 #
- Allows redirection to return same location.
5.1.2 #
- Adds GoRouterState to context.
- Fixes GoRouter notification.
- Updates README.
- Removes dynamic calls in examples.
- BREAKING CHANGE
- Remove NavigatorObserver mixin from GoRouter
5.1.1 #
- Removes DebugGoRouteInformation.
5.1.0 #
- Removes urlPathStrategy completely, which should have been done in v5.0.0 but some code remained mistakenly.
5.0.5 #
- Fixes issue where asserts in popRoute were preventing the app from exiting on Android.
5.0.4 #
- Fixes a bug in ShellRoute example where NavigationBar might lose current index in a nested routes.
5.0.3 #
- Changes examples to use the routerConfig API
5.0.2 #
- Fixes missing code example in ShellRoute documentation.
5.0.1 #
- Allows ShellRoute to have child ShellRoutes (flutter/flutter#111981)
5.0.0 #
- Fixes a bug where intermediate route redirect methods are not called.
- GoRouter implements the RouterConfig interface, allowing you to call MaterialApp.router(routerConfig: _myGoRouter) instead of passing the RouterDelegate, RouteInformationParser, and RouteInformationProvider fields.
- BREAKING CHANGE
- Redesigns redirection API, adds asynchronous feature, and adds build context to redirect.
- Removes GoRouterRefreshStream
- Removes navigatorBuilder
- Removes urlPathStrategy
- go_router v5 migration guide
4.5.1 #
- Fixes an issue where GoRoutes with only a redirect were disallowed (flutter/flutter#111763)
4.5.0 #
- Adds ShellRoute for nested navigation support (flutter/flutter#99126)
- Adds
parentNavigatorKey
to GoRoute, which specifies the Navigator to place that route's Page onto.
4.4.1 #
- Fix an issue where disabling logging clears the root logger's listeners
4.4.0 #
- Adds
buildPageWithState
toGoRouteData
. GoRouteData.buildPage
is now deprecated in favor ofGoRouteData.buildPageWithState
.
4.3.0 #
- Allows
Map<String, dynamic>
maps asqueryParams
ofgoNamed
,replacedName
,pushNamed
andnamedLocation
.
4.2.9 #
- Updates text theme parameters to avoid deprecation issues.
- Fixes lint warnings.
4.2.8 #
- Fixes namedLocation to return URIs without trailing question marks if there are no query parameters.
- Cleans up examples.
4.2.7 #
- Updates README.
4.2.6 #
- Fixes rendering issues in the README.
4.2.5 #
- Fixes a bug where calling extra parameter is always null in route level redirect callback
4.2.4 #
- Rewrites Readme and examples.
4.2.3 #
- Fixes a bug where the ValueKey to be the same when a page was pushed multiple times.
4.2.2 #
- Fixes a bug where go_router_builder wasn't detecting annotations.
4.2.1 #
- Refactors internal classes and methods
4.2.0 #
- Adds
void replace()
andreplaceNamed
toGoRouterDelegate
,GoRouter
andGoRouterHelper
.
4.1.1 #
- Fixes a bug where calling namedLocation does not support case-insensitive way.
4.1.0 #
- Adds
bool canPop()
toGoRouterDelegate
,GoRouter
andGoRouterHelper
.
4.0.3 #
- Adds missed popping log.
4.0.2 #
- Fixes a bug where initialLocation took precedence over deep-links
4.0.1 #
- Fixes a bug where calling setLogging(false) does not clear listeners.
4.0.0 #
- Refactors go_router and introduces
GoRouteInformationProvider
. Migration Doc - Fixes a bug where top-level routes are skipped if another contains child routes.
3.1.0 #
- Adds
GoRouteData
andTypedGoRoute
to supportpackage:go_router_builder
.
3.0.7 #
- Refactors runtime checks to assertions.
3.0.6 #
- Exports inherited_go_router.dart file.
3.0.5 #
- Add
dispatchNotification
method toDummyBuildContext
in tests. (This should be revisited when Flutter2.11.0
becomes stable.) - Improves code coverage.
GoRoute
now warns about requiring eitherpageBuilder
,builder
orredirect
at instantiation.
3.0.4 #
- Updates code for stricter analysis options.
3.0.3 #
- Fixes a bug where params disappear when pushing a nested route.
3.0.2 #
- Moves source to flutter/packages.
- Removes all_lint_rules_community and path_to_regexp dependencies.
3.0.1 #
- pass along the error to the
navigatorBuilder
to allow for different implementations based on the presence of an error
3.0.0 #
- breaking change: added
GoRouterState
tonavigatorBuilder
function - breaking change: removed
BuildContext
fromGoRouter.pop()
to remove the need to usecontext
parameter when calling theGoRouter
API; this changes the behavior ofGoRouter.pop()
to only pop what's on theGoRouter
page stack and no longer callsNavigator.pop()
- new Migrating to 3.0 section in the docs to describe the details of the breaking changes and how to update your code
- added a new shared
scaffold
sample to show how to use the
navigatorBuilder
function to build a custom shared scaffold outside of the animations provided by go_router
2.5.7 #
- PR 262: add support for
Router.neglect
; thanks to nullrocket! - PR 265: add Japanese translation of the docs; thanks to toshi-kuji! Unfortunately I don't yet know how to properly display them via docs.page, but I'm working on it
- updated the examples using the
from
query parameter to be completely self-contained in theredirect
function, simplifying usage - updated the async data example to be simpler
- added a new example to show how to implement a loading page
- renamed the navigator_integration example to user_input and added an example
of
WillPopScope
for go_router apps
2.5.6 #
- PR 259: remove a hack for notifying the router of a route change that was no longer needed; thanks to nullrocket!
- improved async example to handle the case that the data has been returned but
the page is no longer there by checking the
mounted
property of the screen
2.5.4 #
- fixed up the
GoRouterRefreshStream
implementation with an export, an example and some docs
2.5.3 #
- added
GoRouterRefreshStream
from jopmiddelkamp to easily map from aStream
to aListenable
for use withrefreshListenable
; very useful when combined with stream-based state management like flutter_bloc - dartdocs fixups from mehade369
- example link fixes from ben-milanko
2.5.2 #
- pass additional information to the
NavigatorObserver
via default args toMaterialPage
, etc.
2.5.1 #
- fix 205: hack around a
failed assertion in Flutter when using
Duration.zero
in theNoTransitionPage
2.5.0 #
- provide default implementation of
GoRoute.pageBuilder
to provide a simpler way to build pages via theGoRouter.build
method - provide default implementation of
GoRouter.errorPageBuilder
to provide a simpler way to build error pages via theGoRouter.errorBuilder
method - provide default implementation of
GoRouter.errorBuilder
to provide an error page without the need to implement a custom error page builder - new Migrating to 2.5 section in
the docs to show how to take advantage of the new
builder
and default error page builder - removed
launch.json
as VSCode-centric and unnecessary for discovery or easy launching - added a new custom error screen sample
- added a new WidgetsApp sample
- added a new
NoTransitionPage
class - updated docs to explain why the browser's Back button doesn't work
with the
extra
param - updated README to point to new docs site: gorouter.dev
2.3.1 #
- fix 191: handle several
kinds of trailing / in the location, e.g.
/foo/
should be the same as/foo
2.3.0 #
- fix a misleading error message when using redirect functions with sub-routes
2.2.9 #
- fix 182: fixes a regression in the nested navigation caused by the fix for #163; thanks to lulupointu for the fix!
2.2.8 #
- reformatted CHANGELOG file; lets see if pub.dev is still ok with it...
- staged an in-progress doc site at https://docs.page/csells/go_router
- tightened up a test that was silently failing
- fixed a bug that dropped parent params in sub-route redirects
2.2.7 #
- fix 163: avoids unnecessary page rebuilds
- fix 139: avoids unnecessary page flashes on deep linking
- fix 158: shows exception info in the debug output even during a top-level redirect coded w/ an anonymous function, i.e. what the samples all use
- fix 151: exposes
Navigator.pop()
viaGoRouter.pop()
to make it easy to find
2.2.6 #
2.2.5 #
- fix 120 again: found the bug in my tests that was masking the real bug; changed two characters to implement the actual fix (sigh)
2.2.3 #
- fix 132: route names are stored as case insensitive and are now matched in a case insensitive manner
2.2.1 #
- fix 114: give a better error
message when the
GoRouter
isn't found in the widget tree viaGoRouter.of(context)
; thanks aoatmon for the excellent bug report!
2.2.0 #
- added a new
navigatorBuilder
argument to theGoRouter
constructor; thanks to andyduke! - also from andyduke is an update to improve state restoration
- refactor from kevmoo for easier maintenance
- added a new Navigator Integration section of the docs
2.1.2 #
- fix 61 again: enable images and file links to work on pub.dev/documentation
- fix 62 re-tested; fixed w/ earlier Android system Back button fix (using navigation key)
- fix 91: fix a regression w/
the
errorPageBuilder
- fix 92: fix an edge case w/ named sub-routes
- fix 89: enable queryParams
and extra object param w/
push
- refactored tests for greater coverage and fewer methods
@visibleForTesting
2.1.1 #
2.1.0 #
2.0.1 #
- add badges to the README and codecov to the GitHub commit action; thanks to rydmike for both
2.0.0 #
- BREAKING CHANGE and fix #50:
split
params
intoparams
andqueryParams
; see the Migrating to 2.0 section of the docs for instructions on how to migrate your code from 1.x to 2.0 - fix 69: exposed named location lookup for redirection
- fix 57: enable the Android
system Back button to behave exactly like the
AppBar
Back button; thanks to SunlightBro for the one-line fix that I had no idea about until he pointed it out - fix 59: add query params to top-level redirect
- fix 44: show how to use the
AutomaticKeepAliveClientMixin
with nested navigation to keep widget state between navigations; thanks to rydmike for this update
1.1.3 #
- enable case-insensitive path matching while still preserving path and query parameter cases
- change a lifetime of habit to sort constructors first as per sort_constructors_first. Thanks for the PR, Abhishek01039!
- set the initial transition example route to
/none
to make pushing the 'fade transition' button on the first run through more fun - fixed an error in the async data example
1.1.2 #
- Thanks, Mikes!
- updated dartdocs from rydmike
- also shoutout to https://github.com/Salakar for the CI action on GitHub
- this is turning into a real community effort...
1.1.1 #
- now showing routing exceptions in the debug log
- updated the docs to make it clear that it will be called until it returns
null
1.1.0 #
- added support
NavigatorObserver
objects to receive change notifications
1.0.1 #
- docs updates based on user feedback for clarity
- fix for setting URL path strategy in
main()
- fix for
push()
disablesAppBar
Back button
1.0.0 #
- updated version for initial release
- some renaming for clarify and consistency with transitions
GoRoute.builder
=>GoRoute.pageBuilder
GoRoute.error
=>GoRoute.errorPageBuilder
- added diagnostic logging for
push
andpushNamed
0.9.6 #
- added support for
push
as well asgo
- added 'none' to transitions example app
- updated animation example to use no transition and added an animated gif to the docs
0.9.5 #
- added support for custom transitions between routes
0.9.4 #
- updated API docs
- updated docs for
GoRouterState
0.9.3 #
- updated API docs
0.9.2 #
- updated named route lookup to O(1)
- updated diagnostics output to show known named routes
0.9.1 #
- updated diagnostics output to show named route lookup
- docs updates
0.9.0 #
- added support for named routes
0.8.8 #
- fix to make
GoRouter
notify on pop
0.8.7 #
- made
GoRouter
aChangeNotifier
so you can listen forlocation
changes
0.8.6 #
- books sample bug fix
0.8.5 #
- added Cupertino sample
- added example of async data lookup
0.8.4 #
- added state restoration sample
0.8.3 #
- changed
debugOutputFullPaths
todebugLogDiagnostics
and added add'l debugging logging - parameterized redirect
0.8.2 #
- updated docs for
Link
widget support
0.8.1 #
- added Books sample; fixed some issues it revealed
0.8.0 #
- breaking build to refactor the API for simplicity and capability
- move to fixed routing from conditional routing; simplies API, allows for redirection at the route level and there scenario was sketchy anyway
- add redirection at the route level
- replace guard objects w/ redirect functions
- add
refresh
method andrefreshListener
- removed
.builder
ctor fromGoRouter
(not reasonable to implement) - add Dynamic linking section to the docs
- replaced Books sample with Nested Navigation sample
- add ability to dump the known full paths to your routes to debug output
0.7.1 #
- update to pageKey to take sub-routes into account
0.7.0 #
- BREAK: rename
pattern
topath
for consistency w/ other routers in the world - added the
GoRouterLoginGuard
for the common redirect-to-login-page pattern
0.6.2 #
- fixed issue showing home page for a second before redirecting (if needed)
0.6.1 #
- added
GoRouterState.pageKey
- removed
cupertino_icons
from mainpubspec.yaml
0.6.0 #
- refactor to support sub-routes to build a stack of pages instead of matching multiple routes
- added unit tests for building the stack of pages
- some renaming of the types, e.g.
Four04Page
andFamiliesPage
toErrorPage
andHomePage
respectively - fix a redirection error shown in the debug output
0.5.2 #
- add
urlPathStrategy
argument toGoRouter
ctor
0.5.1 #
- docs and description updates
0.5.0 #
- moved redirect to top-level instead of per route for simplicity
0.4.1 #
- fixed CHANGELOG formatting
0.4.0 #
- bundled various useful route handling variables into the
GoRouterState
for use when building pages and error pages - updated URL Strategy section of docs to reference
flutter run
0.3.2 #
- formatting update to appease the pub.dev gods...
0.3.1 #
- updated the CHANGELOG
0.3.0 #
- moved redirection into a
GoRoute
ctor arg - forgot to update the CHANGELOG
0.2.3 #
- move outstanding issues to issue tracker
- added explanation of Deep Linking to docs
- reformatting to meet pub.dev scoring guidelines
0.2.2 #
- docs updates
0.2.1 #
- messing with the CHANGELOG formatting
0.2.0 #
- initial useful release
- added support for declarative routes via
GoRoute
instances - added support for imperative routing via
GoRoute.builder
- added support for setting the URL path strategy
- added support for conditional routing
- added support for redirection
- added support for optional query parameters as well as positional parameters in route names
0.1.0 #
- squatting on the package name (I'm not too proud to admit it)