-
Notifications
You must be signed in to change notification settings - Fork 99
Event Source
Marcus Forsell Stahre edited this page Jan 26, 2018
·
1 revision
An Event Source is used to send external signals into a Mobius Loop as Events. The typical use case is to listen for things like:
- Network connectivity changes (online/offline)
- Timers (periodic ticks, eg. once per second)
- Headphones connected/disconnected
- Events received by
BroadcastReceiver
s - etc.
In principle an Event Source could be used to send events from the UI (like clicks) but this is discouraged. Instead prefer using MobiusLoop.dispatchEvent(...)
or a Connectable
if you use MobiusLoop.Controller
.
Structurally an Event Source is very similar to Effect Handlers but an Event Source does not need any Effects to be triggered before starting to send Events.
You can configure it by calling .eventSource(...)
on a MobiusLoop.Builder
:
MobiusLoop.Builder<Model, Event, Effect> loopBuilder = Mobius.loop(update, effectHandler)
.eventSource(myEventSource);
If you are using RxJava you can wrap any Observables that emits your Event type into an EventSource
:
Observable<Event.First> first = ...
Observable<Event.Second> second = ...
Observable<Event.Third> third = ...
EventSource<Event> eventSource = RxEventSources.fromObservables(first, second, third);
Getting Started
- Creating a loop
- Mobius and RxJava
- Mobius and Android
- Configuring a MobiusLoop
- Logging and Error Handling
Reference Guide
Patterns