-
-
Notifications
You must be signed in to change notification settings - Fork 182
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add useRouteAware hook #166
Labels
enhancement
New feature or request
Comments
You can create a separate class: class Example extends RouteAware {
@override
// Called when the current route has been pushed.
void didPush() {
print('didPush');
}
}
...
final route = ModalRoute.of(context);
useEffect(() {
final example = Example();
routeObserver.subscribe(example, route);
return () => routeObserver.unsubscribe(example);
}, [route, routeObserver]); |
rrousselGit
changed the title
Help: How to implement a RouteObserver/RouteAware Hook?
Add useRouteAware hook
Sep 19, 2020
I would suggest getting acquainted with wouter, maybe its API will inspire you. |
Just in case someone stumbles upon this, here is something I'm using based around the example above. It is using import 'package:dartz/dartz.dart';
import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
class _RouteCallbacks with RouteAware {
const _RouteCallbacks({
this.handleDidPopNext = const None(),
this.handleDidPush = const None(),
this.handleDidPop = const None(),
this.handleDidPushNext = const None(),
});
final Option<VoidCallback> handleDidPopNext;
final Option<VoidCallback> handleDidPush;
final Option<VoidCallback> handleDidPop;
final Option<VoidCallback> handleDidPushNext;
@override
void didPopNext() {
handleDidPopNext.map((f) => f());
}
@override
void didPush() {
handleDidPush.map((f) => f());
}
@override
void didPop() {
handleDidPop.map((f) => f());
}
@override
void didPushNext() {
handleDidPushNext.map((f) => f());
}
}
void useRouteObserver(
RouteObserver<ModalRoute> routeObserver, {
Option<VoidCallback> didPopNext = const None(),
Option<VoidCallback> didPush = const None(),
Option<VoidCallback> didPop = const None(),
Option<VoidCallback> didPushNext = const None(),
List<Object?> keys = const [],
}) {
final context = useContext();
final route = ModalRoute.of(context);
useEffect(() {
if (route == null) return () {};
final callbacks = _RouteCallbacks(
handleDidPop: didPop,
handleDidPopNext: didPopNext,
handleDidPush: didPush,
handleDidPushNext: didPushNext,
);
routeObserver.subscribe(callbacks, route);
return () => routeObserver.unsubscribe(callbacks);
}, [route, routeObserver, ...keys]);
}
|
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
I'm in need of a RouteAware hook for a HookWidget to observer for route changes and make state updates.
This would be a good tutorial/example of what some of use cases would be: https://medium.com/flutter-community/how-to-track-screen-transitions-in-flutter-with-routeobserver-733984a90dea
But I'm stuck trying to figure out how to create a hook for it. Some guidance on how to structure this would be appreciated.
The text was updated successfully, but these errors were encountered: