Presented for review and feedback. API should still be considered unstable, docs incomplete, and functionality buggy. All of the above should be mostly resolved before beta.
1.0 brings major functional improvements and API changes.
- Activity integration has been rewritten and is much simpler. One line to configure and install; one optional line to handle the back button; one optional line to handle new Intent. Flow handles lifecycle internally.
- Resource management (including shared resources) is now natively supported via TreeKeys-- Path has effectively been absorbed and simplified. Contexts are now managed internally and there's much less nesting of wrappers.
- Multiple simultaneous states are now supported via MultiKeys-- Flow now works natively with UIs composed of dialogs, sheets, master-detail views, etc. MultiKeys can be composed of TreeKeys for resource sharing.
- Persistence has been expanded and simplified. You can now save a Bundle along with view state, and Flow takes care of all the lifecycle.
- Nested/queued traversals are much safer and more efficient.
- The
goBack
operation in particular is safer and more predictable. - Save state and view state are managed internally and orthogonally to History; you no longer have to take care to avoid losing state when changing History.
- Fix: History.Builder#pop is nullable again, and adds History.Builder#isEmpty.
- Fix: No longer persists an empty list of states if the filter excludes everything.
- Fix: The Builder returned by
History#buildUpon()
is now safer to use. See javadoc for detail.
A large number of breaking changes have been made in the interest of focusing the library.
- Backstack is now called History and has some new method names.
- The
resetTo
,goTo
,replaceTo
,forward
, andbackward
operations are all gone. In their place are two simple methods:set(Object)
andset(History, Direction)
. HasParent
andgoUp
are gone. "Up" navigation is left as an exercise to app authors who need it, at least for the time being.- The
@Layout
annotation has been removed. You can find it in the sample if you want a copy. - Listener is now called Dispatcher, and can be set on a Flow after construction. Dispatcher gets more information than Listener did.
There are also some new features, and more are coming.
- Added a Context service for easily obtaining the Flow.
- Added
FlowDelegate
for easier integration into an Activity. - Added the flow-path module. Paths generally represent states/screens in an app, and are associated with Contexts which can be created by a user-supplied factory. PathContainer helps with switching views while maintaining view state.
- API break: The Listener now gets a Callback, which it must call when it has completed a transition.
- Flow now supports reentry. While a Listener is executing, calls to Flow which modify the backstack are enqueued.
- Beefed up sample app, including demonstration of providing view persistence via the back stack
- replaceTo and goUp keep original screens for a matching prefix of the stack.
- Fix waitForMeasureLoop in example code.
- API break: replaceTo() now has a new Direction associated with it,
REPLACE
. This is logically more correct because the incumbent backstack is not consulted, and convenient because a replace transition is typically different from a forward or backward transition.
- Keep original screen on stack if found by resetTo.
- API break: @Screen(layout=R.layout.foo) > @Layout(R.layout.foo), and Screens > Layouts. Support for view class literals is gone. They break theming and the fix isn't worth the bother.
- New: Backstack#fromUpChain(Object), allows backstack to be created from a HasParent screen.
Initial release.