-
Notifications
You must be signed in to change notification settings - Fork 22
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
Persistent state with MVI - no easy way to pass the saved State to presenter after activity died #27
Comments
Hi, Unfortunately, I'm a little bit busy right now but I hope to take a look at this in first week of August. |
Hi, I'm also affected by this issue. @agta1991, could you post a snippet of your workaround please? |
agta1991 is AFK, but here is the current solution: abstract class BaseController<V : ViewContract<VS>, VS : ViewState, P : MviPresenter<V, VS>>(bundle: Bundle = Bundle()) :
MviController<V, P>(bundle), ViewContract<VS> {
protected val KEY_VIEW_STATE = "MviController.viewState"
private var lastViewState: VS? = null
abstract fun inflateView(inflater: LayoutInflater, container: ViewGroup): View
abstract fun createPresenter(initialViewState: VS): P
abstract fun getInitialViewState(): VS
@CallSuper
override fun render(viewState: VS) {
this.lastViewState = viewState
}
open fun onPostCreateView(view: View) {}
override fun createPresenter(): P {
if (args.containsKey(KEY_VIEW_STATE)) {
return createPresenter(args.getParcelable<Parcelable>(KEY_VIEW_STATE) as VS)
}
return createPresenter(getInitialViewState())
}
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup): View {
val view = inflateView(inflater, container)
onPostCreateView(view)
return view
}
override fun onSaveInstanceState(outState: Bundle) {
if (lastViewState != null) {
args.putParcelable(KEY_VIEW_STATE, lastViewState as Parcelable)
}
}
} |
You can always workaround such issues with a public Observable<MyState> restorePersitentStateIntent() And then read the retained state from Bundle and emit it through that intent to your business logic. The only thing you have to watch out os that the restore intent should be the first intent of all your intents that emits something |
Thank you guys. @larten, do you have injection in the sub-classes and do you make any use of the restoration callbacks ( p.s. Beware of the |
Currenly I left this solution, because, as you wrote, it's easy to eat the full memory :) |
@larten Lol, and I came back to the |
Hi!
I'm currently trying to implement save and restore instance state with Conductor and MVI architecture, like described in Mosby MVI Part 6 - Persistent State. All went well until I faced what happens if the activity dies (example onLowMemory).
With conductor I'm able to reconstruct the backstack, but I can't prepare the presenter with the initial state, because bindIntents run in postCreate cycle, and the Controller only calls restoreInstanceState after postCreate finished. I dived into the code of the Controller class in Conductor and find a hacky workaround for it, but sadly as I said its a hack....
If you pass the last ViewState in the controller's saveInstanceState function to the Controllers original args, it will be persisted if the activity dies. So after the new Activity is created, when the Conductor lib restores the backstack, the Controller will be created with the last ViewState in its' args. With this implementation I can push the last State down to the presenter when createPresenter is called, because it's present in the Controller's constructor.
Do you have a better solution for this problem?
Thanks,
Agta
The text was updated successfully, but these errors were encountered: