- Adds an ability to add a custom codec for serializing/deserializing extra.
- Fixes crashes when dynamically updates routing tables with named routes.
- Fixes the problem that pathParameters is null in redirect when the Router is recreated.
- Fixes deep-link with no path on cold start.
- Adds ability to dynamically update routing table.
- BREAKING CHANGE:
- The function signature of constructor of
RouteConfiguration
is updated. - Adds a required
matchedPath
named parameter toRouteMatch.match
.
- The function signature of constructor of
- Fixes missing parameters in the type-safe routes topic documentation.
- Fixes missing state.extra in onException().
- Fixes a bug where the known routes and initial route were logged even when
debugLogDiagnostics
was set tofalse
.
- Fixes a missing
{@end-tool}
doc directive tag forGoRoute.name
.
- Adds optional parameter
overridePlatformDefaultLocation
to override initial route set by platform.
- Fixes the Android back button ignores top level route's onExit.
- Fixes the GoRouter.goBranch so that it doesn't reset extra to null if extra is not serializable.
- BREAKING CHANGE:
- Updates the function signature of
GoRouteInformationProvider.restore
. - Adds
NavigationType.restore
toNavigationType
enum.
- Updates the function signature of
- Adds
onExit
to GoRoute.
- Fixes RouteInformationParser that does not restore full RouteMatchList if the optionURLReflectsImperativeAPIs is set.
- Fixes an issue in the documentation that was using
state.queryParameters
instead ofstate.uri.queryParameters
.
- Adds pub topics to package metadata.
- Fixes mapping from
Page
toRouteMatch
s. - Updates minimum supported SDK version to Flutter 3.7/Dart 2.19.
- Supports setting
requestFocus
.
- BREAKING CHANGE:
- Replaces location, queryParameters, and queryParametersAll in GoRouterState with Uri.
- See Migrating to 10.0.0 or
run
dart fix --apply
to fix the breakages.
- Fixes a link in error handling documentation.
- Adds the parentNavigatorKey parameter to ShellRouteData and StatefulShellRouteData.
- Fixes a typo in docs for
StatefulShellRoute.indexedStack(...)
. - Cleans some typos in the documentation and asserts.
- Adds helpers for go_router_builder for StatefulShellRoute support
- Exposes package-level privates.
- Allows redirect only GoRoute to be part of RouteMatchList.
- BREAKING CHANGE:
- Removes GoRouter.location. Use GoRouterState.of().location instead.
- GoRouter does not
extends
ChangeNotifier. - Migration guide
- Reduces excessive rebuilds due to inherited look up.
- Adds onException to GoRouter constructor.
- Adds parent navigator key to ShellRoute and StatefulShellRoute.
- Fixes a bug that GoRouterState in top level redirect doesn't contain complete data.
- Updates documentations around
GoRouter.of
,GoRouter.maybeOf
, andBuildContext
extension.
- Makes namedLocation and route name related APIs case sensitive.
- Fixes a bug in
debugLogDiagnostics
to support StatefulShellRoute.
- Fixes a link for an example in
path
documentation. documentation.
- BREAKING CHANGE:
- Imperatively pushed GoRoute no longer change URL.
- Browser backward and forward button respects imperative route operations.
- Refactors the route parsing pipeline.
- Removes obsolete null checks on non-nullable values.
- Introduces
StatefulShellRoute
to support using separate navigators for child routes as well as preserving state in each navigation tree (flutter/flutter#99124). - Updates documentation for
pageBuilder
andbuilder
fields ofShellRoute
, to more correctly describe the meaning of the child argument in the builder functions. - Adds support for restorationId to ShellRoute (and StatefulShellRoute).
- Fixes
BuildContext
extension methodreplaceNamed
to correctly passpathParameters
andqueryParameters
.
- Adds a workaround for the
dart fix --apply
issue, dart-lang/sdk#52233.
- BREAKING CHANGE:
- For the below changes, run
dart fix --apply
to automatically migrate your code.GoRouteState.subloc
has been renamed toGoRouteState.matchedLocation
.GoRouteState.params
has been renamed toGoRouteState.pathParameters
.GoRouteState.fullpath
has been renamed toGoRouteState.fullPath
.GoRouteState.queryParams
has been renamed toGoRouteState.queryParameters
.params
andqueryParams
inGoRouteState.namedLocation
have been renamed topathParameters
andqueryParameters
.params
andqueryParams
inGoRouter
'snamedLocation
,pushNamed
,pushReplacementNamed
replaceNamed
have been renamed topathParameters
andqueryParameters
.
- For the below changes, please follow the migration guide.
params
andqueryParams
inBuildContext
'snamedLocation
,pushNamed
,pushReplacementNamed
replaceNamed
have been renamed topathParameters
andqueryParameters
.
- For the below changes, run
- Cleans up API and makes RouteMatchList immutable.
- Removes navigator keys from
GoRouteData
andShellRouteData
.
- Adds name parameter to
TypedGoRoute
- Fixes a bug that go_router would crash if
GoRoute.pageBuilder
depends onInheritedWidget
s.
- Fixes an issue where ShellRoute routes were not logged when debugLogDiagnostic was enabled.
- Fixes an issue when popping pageless route would accidentally complete imperative page.
- Removes navigator keys from
TypedGoRoute
andTypedShellRoute
.
- Fixes redirect being called with an empty location for unknown routes.
- NoTransitionPage now has an instant reverse transition.
- Fixes an issue where the params are removed after popping.
- Supports returning values on pop.
- Adds
initialExtra
to GoRouter to pass extra data alongsideinitialRoute
.
- 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).
- 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.
- Exports supertypes in route_data.dart library.
- Adds
GoRouter.maybeOf
to get the closestGoRouter
from the context, if there is any.
- Adds helpers for go_router_builder for ShellRoute support
- Fixes deprecation message for
GoRouterState.namedLocation
- Adds support for Iterables, Lists and Sets in query params for TypedGoRoute. #108437.
- 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.
- Adds
reverseTransitionDuration
toCustomTransitionPage
- Fixes unnecessary_null_comparison lint warnings.
- Fixes redirection info log.
- Makes
CustomTransitionPage.barrierDismissible
work
- Fixes missing result on pop in go_router extension.
- Fixes crashes when popping navigators manually.
- Fixes trailing slashes after pops.
- 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
- Fixes crashes when using async redirect.
- Fixes link for router configuration and sub-routes
- Fixes
pop
andpush
to update urls correctly.
- Refactors
GoRouter.pop
to be able to pop individual pageless route with result.
- Fixes
GoRouterState.location
andGoRouterState.param
to return correct value. - Cleans up
RouteMatch
andRouteMatchList
API.
- Fixes link of ShellRoute in README.
- Fixes broken links in documentation.
- Fixes a bug with
replace
where it was not generated a newpageKey
.
- Adds documentation using dartdoc topics.
- Fixes crashes when multiple
GoRoute
s use the sameparentNavigatorKey
in a route subtree.
- Adds migration guide for 5.1.2 to readme.
- Fixes the documentation by removing the
ShellRoute
's non-existingpath
parameter from it.
- Allows redirection to return same location.
- Adds GoRouterState to context.
- Fixes GoRouter notification.
- Updates README.
- Removes dynamic calls in examples.
- BREAKING CHANGE
- Remove NavigatorObserver mixin from GoRouter
- Removes DebugGoRouteInformation.
- Removes urlPathStrategy completely, which should have been done in v5.0.0 but some code remained mistakenly.
- Fixes issue where asserts in popRoute were preventing the app from exiting on Android.
- Fixes a bug in ShellRoute example where NavigationBar might lose current index in a nested routes.
- Changes examples to use the routerConfig API
- Fixes missing code example in ShellRoute documentation.
- Allows ShellRoute to have child ShellRoutes (flutter/flutter#111981)
- 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
- Fixes an issue where GoRoutes with only a redirect were disallowed (flutter/flutter#111763)
- Adds ShellRoute for nested navigation support (flutter/flutter#99126)
- Adds
parentNavigatorKey
to GoRoute, which specifies the Navigator to place that route's Page onto.
- Fix an issue where disabling logging clears the root logger's listeners
- Adds
buildPageWithState
toGoRouteData
. GoRouteData.buildPage
is now deprecated in favor ofGoRouteData.buildPageWithState
.
- Allows
Map<String, dynamic>
maps asqueryParams
ofgoNamed
,replacedName
,pushNamed
andnamedLocation
.
- Updates text theme parameters to avoid deprecation issues.
- Fixes lint warnings.
- Fixes namedLocation to return URIs without trailing question marks if there are no query parameters.
- Cleans up examples.
- Updates README.
- Fixes rendering issues in the README.
- Fixes a bug where calling extra parameter is always null in route level redirect callback
- Rewrites Readme and examples.
- Fixes a bug where the ValueKey to be the same when a page was pushed multiple times.
- Fixes a bug where go_router_builder wasn't detecting annotations.
- Refactors internal classes and methods
- Adds
void replace()
andreplaceNamed
toGoRouterDelegate
,GoRouter
andGoRouterHelper
.
- Fixes a bug where calling namedLocation does not support case-insensitive way.
- Adds
bool canPop()
toGoRouterDelegate
,GoRouter
andGoRouterHelper
.
- Adds missed popping log.
- Fixes a bug where initialLocation took precedence over deep-links
- Fixes a bug where calling setLogging(false) does not clear listeners.
- Refactors go_router and introduces
GoRouteInformationProvider
. Migration Doc - Fixes a bug where top-level routes are skipped if another contains child routes.
- Uses first match if there are more than one route to match. [ #99833
- Adds
GoRouteData
andTypedGoRoute
to supportpackage:go_router_builder
.
- Refactors runtime checks to assertions.
- Exports inherited_go_router.dart file.
- 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.
- Updates code for stricter analysis options.
- Fixes a bug where params disappear when pushing a nested route.
- Moves source to flutter/packages.
- Removes all_lint_rules_community and path_to_regexp dependencies.
- pass along the error to the
navigatorBuilder
to allow for different implementations based on the presence of an error
- 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
- 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
- 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
- updated implementation to use logging package for debug diagnostics; thanks to johnpryan
- fixed up the
GoRouterRefreshStream
implementation with an export, an example and some docs
- 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
- pass additional information to the
NavigatorObserver
via default args toMaterialPage
, etc.
- fix 205: hack around a
failed assertion in Flutter when using
Duration.zero
in theNoTransitionPage
- 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
- fix 191: handle several
kinds of trailing / in the location, e.g.
/foo/
should be the same as/foo
- fix a misleading error message when using redirect functions with sub-routes
- fix 182: fixes a regression in the nested navigation caused by the fix for #163; thanks to lulupointu for the fix!
- 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
- 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
- fix 127: updated the docs to add a video overview of the project for people that prefer that media style over long-form text when approaching a new topic
- fix 108: updated the
description of the
state
parameter to clarfy that not all properties will be set at every usage
- fix 120 again: found the bug in my tests that was masking the real bug; changed two characters to implement the actual fix (sigh)
- fix 116: work-around for
auto-import of the
context.go
family of extension methods
- fix 132: route names are stored as case insensitive and are now matched in a case insensitive manner
- fix 120: encoding and decoding of params and query params
- 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!
- 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
- 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
- fix 86: add
name
toGoRouterState
to complete support for URI-free navigation knowledge in your code - fix 83: fix for
null
extra
object
- fix 80: adding a redirect limit to catch too many redirects error
- fix 81: allow an
extra
object to pass through for navigation
- add badges to the README and codecov to the GitHub commit action; thanks to rydmike for both
- 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
- 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
- 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...
- now showing routing exceptions in the debug log
- updated the docs to make it clear that it will be called until it returns
null
- added support
NavigatorObserver
objects to receive change notifications
- docs updates based on user feedback for clarity
- fix for setting URL path strategy in
main()
- fix for
push()
disablesAppBar
Back button
- 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
- 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
- added support for custom transitions between routes
- updated API docs
- updated docs for
GoRouterState
- updated API docs
- updated named route lookup to O(1)
- updated diagnostics output to show known named routes
- updated diagnostics output to show named route lookup
- docs updates
- added support for named routes
- fix to make
GoRouter
notify on pop
- made
GoRouter
aChangeNotifier
so you can listen forlocation
changes
- books sample bug fix
- added Cupertino sample
- added example of async data lookup
- added state restoration sample
- changed
debugOutputFullPaths
todebugLogDiagnostics
and added add'l debugging logging - parameterized redirect
- updated docs for
Link
widget support
- added Books sample; fixed some issues it revealed
- 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
- update to pageKey to take sub-routes into account
- BREAK: rename
pattern
topath
for consistency w/ other routers in the world - added the
GoRouterLoginGuard
for the common redirect-to-login-page pattern
- fixed issue showing home page for a second before redirecting (if needed)
- added
GoRouterState.pageKey
- removed
cupertino_icons
from mainpubspec.yaml
- 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
- add
urlPathStrategy
argument toGoRouter
ctor
- docs and description updates
- moved redirect to top-level instead of per route for simplicity
- fixed CHANGELOG formatting
- 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
- formatting update to appease the pub.dev gods...
- updated the CHANGELOG
- moved redirection into a
GoRoute
ctor arg - forgot to update the CHANGELOG
- move outstanding issues to issue tracker
- added explanation of Deep Linking to docs
- reformatting to meet pub.dev scoring guidelines
- docs updates
- messing with the CHANGELOG formatting
- 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
- squatting on the package name (I'm not too proud to admit it)