- 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]flutter/flutter#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.
- Export 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)