diff options
author | Isidro Henoch <imhenoch@protonmail.com> | 2021-12-08 04:28:51 -0600 |
---|---|---|
committer | Isidro Henoch <imhenoch@protonmail.com> | 2021-12-08 04:28:51 -0600 |
commit | 04c2889895483f5925c90ed7a856d38391fcab45 (patch) | |
tree | 896334a1d8a0540b9d54c7390db2d78e61cadb1b /androidApp/src/main/java/mx/trackermap/TrackerMap/android/units | |
parent | d2ee6a21355c390a4aaefc6ea847060c8e47c6ae (diff) | |
download | etbsa-trackermap-mobile-04c2889895483f5925c90ed7a856d38391fcab45.tar.gz etbsa-trackermap-mobile-04c2889895483f5925c90ed7a856d38391fcab45.tar.bz2 etbsa-trackermap-mobile-04c2889895483f5925c90ed7a856d38391fcab45.zip |
WIP: Implements the basic structure for the units list/map
- Updates the Devices and Positions APIs to properly construct the Url's query when there are null values
- Adds a units controller to the shared module
- Adds a devices and map fragment that each print the fetched units on the console
- Adds a units view model to connect previously mentioned fragments with the units controller
Diffstat (limited to 'androidApp/src/main/java/mx/trackermap/TrackerMap/android/units')
-rw-r--r-- | androidApp/src/main/java/mx/trackermap/TrackerMap/android/units/UnitsViewModel.kt | 37 |
1 files changed, 35 insertions, 2 deletions
diff --git a/androidApp/src/main/java/mx/trackermap/TrackerMap/android/units/UnitsViewModel.kt b/androidApp/src/main/java/mx/trackermap/TrackerMap/android/units/UnitsViewModel.kt index 11df89b..7ac6e28 100644 --- a/androidApp/src/main/java/mx/trackermap/TrackerMap/android/units/UnitsViewModel.kt +++ b/androidApp/src/main/java/mx/trackermap/TrackerMap/android/units/UnitsViewModel.kt @@ -2,15 +2,44 @@ package mx.trackermap.TrackerMap.android.units import android.util.Log import androidx.lifecycle.MutableLiveData +import androidx.lifecycle.SavedStateHandle import androidx.lifecycle.ViewModel +import androidx.lifecycle.viewModelScope +import kotlinx.coroutines.DelicateCoroutinesApi +import kotlinx.coroutines.flow.collect +import kotlinx.coroutines.launch +import mx.trackermap.TrackerMap.client.models.UnitInformation +import mx.trackermap.TrackerMap.controllers.UnitsController +import org.koin.core.component.KoinComponent +import org.koin.core.component.inject -class UnitsViewModel : ViewModel() { +@DelicateCoroutinesApi +class UnitsViewModel( + private val savedStateHandle: SavedStateHandle +) : ViewModel(), KoinComponent { enum class UnitsDisplayMode { MAP, LIST } - var unitsDisplayMode = MutableLiveData<UnitsDisplayMode>(UnitsDisplayMode.MAP) + private val unitsController: UnitsController by inject() + + var unitsDisplayMode = MutableLiveData(UnitsDisplayMode.MAP) + var units = MutableLiveData<List<UnitInformation>>() + + init { + Log.d("UnitsViewModel", "Initializing Units View Model") + viewModelScope.launch { + setupObservers() + } + } + + private suspend fun setupObservers() { + Log.d("UnitsViewModel", "Setup observers") + unitsController.displayedUnitsFlow.collect { units -> + this.units.value = units + } + } fun toggleDisplayMode() { Log.d("UnitsViewModel", "Toggling Display mode") @@ -22,4 +51,8 @@ class UnitsViewModel : ViewModel() { } unitsDisplayMode.postValue(newDisplayMode) } + + fun search(query: String) { + unitsController.search(query) + } }
\ No newline at end of file |