diff options
author | pacien | 2018-02-17 01:43:30 +0100 |
---|---|---|
committer | pacien | 2018-02-17 01:43:30 +0100 |
commit | 000b7459192ea4f801e204eabbf19107a3ac2c60 (patch) | |
tree | 77c1830505a81ccf4a76100a531de5f5586c1c31 /app/src/main/java/org/pacien/tincapp/intent | |
parent | e38fbf4a348201241522a90d09221e609ad58d2d (diff) | |
download | tincapp-000b7459192ea4f801e204eabbf19107a3ac2c60.tar.gz |
Refactor broadcast action mapper
Diffstat (limited to 'app/src/main/java/org/pacien/tincapp/intent')
-rw-r--r-- | app/src/main/java/org/pacien/tincapp/intent/BroadcastMapper.kt (renamed from app/src/main/java/org/pacien/tincapp/intent/SimpleBroadcastReceiver.kt) | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/app/src/main/java/org/pacien/tincapp/intent/SimpleBroadcastReceiver.kt b/app/src/main/java/org/pacien/tincapp/intent/BroadcastMapper.kt index fb77174..1382f0a 100644 --- a/app/src/main/java/org/pacien/tincapp/intent/SimpleBroadcastReceiver.kt +++ b/app/src/main/java/org/pacien/tincapp/intent/BroadcastMapper.kt | |||
@@ -10,10 +10,11 @@ import org.pacien.tincapp.context.App | |||
10 | /** | 10 | /** |
11 | * @author pacien | 11 | * @author pacien |
12 | */ | 12 | */ |
13 | class SimpleBroadcastReceiver(private val intentFilter: IntentFilter, private val eventHandler: () -> Unit) : BroadcastReceiver() { | 13 | class BroadcastMapper(private val actionHandlers: Map<String, () -> Unit>) : BroadcastReceiver() { |
14 | private val broadcastManager = LocalBroadcastManager.getInstance(App.getContext()) | 14 | private val broadcastManager = LocalBroadcastManager.getInstance(App.getContext()) |
15 | private val intentFilter = actionHandlers.keys.fold(IntentFilter(), { filter, action -> filter.apply { addAction(action) } }) | ||
15 | 16 | ||
16 | fun register() = broadcastManager.registerReceiver(this, intentFilter) | 17 | fun register() = broadcastManager.registerReceiver(this, intentFilter) |
17 | fun unregister() = broadcastManager.unregisterReceiver(this) | 18 | fun unregister() = broadcastManager.unregisterReceiver(this) |
18 | override fun onReceive(context: Context?, intent: Intent?) = eventHandler() | 19 | override fun onReceive(context: Context?, intent: Intent?) = actionHandlers[intent?.action]?.invoke() ?: Unit |
19 | } | 20 | } |