mirror of
https://github.com/commons-app/apps-android-commons.git
synced 2025-10-26 20:33:53 +01:00
Refactor: Load bookmarked locations using Flow
* `BookmarkLocationsController`: Changed to use `Flow` to load bookmarked locations. * `BookmarkLocationsDao`: Changed to return `Flow` of bookmark location instead of a list. * `BookmarkLocationsFragment`: Used `LifecycleScope` to collect data from flow and display it. * Removed unused `getAllBookmarkLocations()` from `BookmarkLocationsViewModel`. * Used `map` in `BookmarkLocationsDao` to convert from `BookmarksLocations` to `Place` list.
This commit is contained in:
parent
8a41b3db1b
commit
86d0475637
4 changed files with 19 additions and 7 deletions
|
|
@ -1,6 +1,8 @@
|
|||
package fr.free.nrw.commons.bookmarks.locations
|
||||
|
||||
import fr.free.nrw.commons.nearby.Place
|
||||
import kotlinx.coroutines.flow.Flow
|
||||
import kotlinx.coroutines.flow.flow
|
||||
import javax.inject.Inject
|
||||
import javax.inject.Singleton
|
||||
|
||||
|
|
@ -13,5 +15,6 @@ class BookmarkLocationsController @Inject constructor(
|
|||
* Load bookmarked locations from the database.
|
||||
* @return a list of Place objects.
|
||||
*/
|
||||
fun loadFavoritesLocations(): List<Place> = listOf()
|
||||
fun loadFavoritesLocations(): Flow<List<Place>> =
|
||||
bookmarkLocationDao.getAllBookmarksLocationsPlace()
|
||||
}
|
||||
|
|
|
|||
|
|
@ -9,6 +9,7 @@ import fr.free.nrw.commons.nearby.NearbyController
|
|||
import fr.free.nrw.commons.nearby.Place
|
||||
import kotlinx.coroutines.flow.Flow
|
||||
import kotlinx.coroutines.flow.flow
|
||||
import kotlinx.coroutines.flow.map
|
||||
|
||||
@Dao
|
||||
abstract class BookmarkLocationsDao {
|
||||
|
|
@ -17,7 +18,7 @@ abstract class BookmarkLocationsDao {
|
|||
abstract suspend fun addBookmarkLocation(bookmarkLocation: BookmarksLocations)
|
||||
|
||||
@Query("SELECT * FROM bookmarks_locations")
|
||||
abstract suspend fun getAllBookmarksLocations(): List<BookmarksLocations>
|
||||
abstract fun getAllBookmarksLocations(): Flow<List<BookmarksLocations>>
|
||||
|
||||
@Query("SELECT EXISTS (SELECT 1 FROM bookmarks_locations WHERE location_name = :name)")
|
||||
abstract suspend fun findBookmarkLocation(name: String): Boolean
|
||||
|
|
@ -44,6 +45,6 @@ abstract class BookmarkLocationsDao {
|
|||
}
|
||||
|
||||
fun getAllBookmarksLocationsPlace(): Flow<List<Place>> {
|
||||
return flow { getAllBookmarksLocations().map { it.toPlace() } }
|
||||
return flow { getAllBookmarksLocations().map { it.map { it1 -> it1.toPlace() } } }
|
||||
}
|
||||
}
|
||||
|
|
@ -15,8 +15,10 @@ import fr.free.nrw.commons.R
|
|||
import fr.free.nrw.commons.contributions.ContributionController
|
||||
import fr.free.nrw.commons.databinding.FragmentBookmarksLocationsBinding
|
||||
import fr.free.nrw.commons.filepicker.FilePicker
|
||||
import fr.free.nrw.commons.nearby.Place
|
||||
import fr.free.nrw.commons.nearby.fragments.CommonPlaceClickActions
|
||||
import fr.free.nrw.commons.nearby.fragments.PlaceAdapter
|
||||
import kotlinx.coroutines.launch
|
||||
import javax.inject.Inject
|
||||
|
||||
|
||||
|
|
@ -128,7 +130,13 @@ class BookmarkLocationsFragment : DaggerFragment() {
|
|||
}
|
||||
|
||||
private fun initList() {
|
||||
val places = controller.loadFavoritesLocations()
|
||||
var places: List<Place> = listOf()
|
||||
viewLifecycleOwner.lifecycleScope.launch {
|
||||
controller.loadFavoritesLocations().collect {
|
||||
adapter.items = it
|
||||
places = it
|
||||
}
|
||||
}
|
||||
adapter.items = places
|
||||
binding?.loadingImagesProgressBar?.visibility = View.GONE
|
||||
if (places.isEmpty()) {
|
||||
|
|
|
|||
|
|
@ -8,8 +8,8 @@ class BookmarkLocationsViewModel(
|
|||
private val bookmarkLocationsDao: BookmarkLocationsDao
|
||||
): ViewModel() {
|
||||
|
||||
fun getAllBookmarkLocations(): Flow<List<Place>> {
|
||||
return bookmarkLocationsDao.getAllBookmarksLocationsPlace()
|
||||
}
|
||||
// fun getAllBookmarkLocations(): List<Place> {
|
||||
// return bookmarkLocationsDao.getAllBookmarksLocationsPlace()
|
||||
// }
|
||||
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue