Skip to content
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

docs: How do you navigate backwards with back button or back arrow? #4307

Closed
peoln opened this issue Dec 30, 2024 · 2 comments
Closed

docs: How do you navigate backwards with back button or back arrow? #4307

peoln opened this issue Dec 30, 2024 · 2 comments
Labels
question Further information is requested

Comments

@peoln
Copy link

peoln commented Dec 30, 2024

Description

I have searched on google with this:
"back button" site:bloclibrary.dev

(and have also searched that site/domain for "navigate back" , "back navigation", "backwards navigation", "navigate backwards" and "arrow" as in back arrow)
but could not find anything there in the official pages about how to implement back button navigation.

I have learned the basics about bloc regarding how you navigate forward (so to speak) by letting the bloc implementation call the emit method, which will then trigger a new page that can become rendered with a BlocBuilder.
But I just do not understand how you should implement navigation backwards.

When you use Flutter without bloc you would use Navigator.push to move forward and then Navigator.pop to go back.
As far as I understand, the bloc internal code does not use Navigator.push, so therefore I can not expect to be able to use Navigator.pop to go back?

There should hopefully be a simple way of implementing back navigation?
If so, then please document it.

One way of doing it that I can figure out seems more complicated than it should have to be:
I could use the Command pattern in every bloc and save any new event into a Command object and put in on a stack of command objects.
And then try to capture all back button events (and back arrow clicks) and then find the previous command on the stack, and let the "command.undo" implemetnation method send the previous event to the block again with the method context.read<T>.add(event)

But I guess there should be some much simpler way of support back navgiation?
How?
Is there any example project showing how to navigate backwards in a simple way when using bloc?

@peoln peoln added the documentation Documentation requested label Dec 30, 2024
@donghyeon
Copy link

The Bloc library is excellent for managing the state within individual views. However, if you require state management during navigation, it's better to use dedicated navigation packages like go_router. go_router is designed to manage navigation state more naturally and provide support for the newer routing system known as Navigator 2.0. Alternatively, if you don't need such a complex routing system, you can use the flow_builder package, which follows a design similar to Bloc.

@felangel
Copy link
Owner

You can navigate back using Navigator.of(context).pop() if you've pushed the route using navigator 1.0 APIs. If you're using something like flow_builder then you'd just update the state to go back.

@felangel felangel added question Further information is requested and removed documentation Documentation requested labels Jan 12, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

3 participants