To handle lifecycle changes it's better to use Moxy or Android Architecture Components. This library is no longer actively supported.
Library for handling lifecycle events with Observables and Android Loaders in single line!
compile 'ru.arturvasilov:rx-loader:0.1.4'
In your Activity / Presenter make you normally execute server request like this:
@Override
protected void onCreate() {
super.onCreate();
Repository.provideSomeService()
.someMethod()
.compose(RxSchedulers.async())
.subscribe(value -> Log.i("RxLoader", String.valueOf(value)));
}
Now, if you want to handle configuration changes and activity pauses, you can achieve this with LifecycleHandler class like this:
@Override
protected void onCreate() {
super.onCreate();
LifecycleHandler handler = LoaderLifecycleHandler.create(this, getSupportLoaderManager());
Repository.provideSomeService()
.someMethod()
.compose(RxSchedulers.async())
.compose(handler.load(R.id.some_request))
.subscribe(value -> Log.i("RxLoader", String.valueOf(value)));
}
And that's it!
When your device will be rotated you will get the last value from onNext and your Observable will continue it's work. If your Observable hadn't finished its' work, rotation will have no affect.
When you leave the screen or press home button, library automatically unsubscribes from observable. If observable had finished its' work, then each new subscription will give you last result (so, it's like making your observable cold). If observable hasn't finished its' work before activity stopped, you'll get last value if present and observable'll be resubscribed.
Everything above is achieved with interface LifecycleHandler:
public interface LifecycleHandler {
@NonNull
<T> Observable.Transformer<T, T> load(int id);
@NonNull
<T> Observable.Transformer<T, T> reload(int id);
void clear(int id);
}
Load methods executes one observable only once and it doesn't matter how many times you're subscribing to it.
If you want to restart execution, you may use reload method.
If you want to clear everything data from handler, you may use clear method.
You have no need to store LifecycleHandler instance, since it has no state.
It's great to handle configuration changes each with one line of code, but how it works?
In fact, when you call load or reload methods from LifecycleHandler, you will get only a facade for the original observable. Original observable and some of its' input is stored in loaders (which makes them independent for configuration changes). So, original observable is executed in loader and you're get its' results in the observable. So you can call subscribe multiple times.