Dynamic categories can now be updated seperately

This commit is contained in:
Jay 2020-05-23 02:27:35 -04:00
parent 3eb1cc1f17
commit b5702e715a
4 changed files with 57 additions and 10 deletions

View File

@ -132,6 +132,11 @@ class LibraryUpdateService(
*/ */
const val KEY_TARGET = "target" const val KEY_TARGET = "target"
/**
* Key for list of manga to be updated. (For dynamic categories)
*/
const val KEY_MANGAS = "mangas"
/** /**
* Returns the status of the service. * Returns the status of the service.
* *
@ -149,12 +154,21 @@ class LibraryUpdateService(
* @param category a specific category to update, or null for global update. * @param category a specific category to update, or null for global update.
* @param target defines what should be updated. * @param target defines what should be updated.
*/ */
fun start(context: Context, category: Category? = null, target: Target = Target.CHAPTERS) { fun start(
context: Context,
category: Category? = null,
target: Target = Target.CHAPTERS,
mangaToUse: List<LibraryManga>? = null
) {
if (!isRunning()) { if (!isRunning()) {
val intent = Intent(context, LibraryUpdateService::class.java).apply { val intent = Intent(context, LibraryUpdateService::class.java).apply {
putExtra(KEY_TARGET, target) putExtra(KEY_TARGET, target)
category?.id?.let { id -> category?.id?.let { id ->
putExtra(KEY_CATEGORY, id) putExtra(KEY_CATEGORY, id)
if (mangaToUse != null) putExtra(
KEY_MANGAS,
mangaToUse.mapNotNull { it.id }.toLongArray()
)
} }
} }
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.O) { if (Build.VERSION.SDK_INT < Build.VERSION_CODES.O) {
@ -164,7 +178,8 @@ class LibraryUpdateService(
} }
} else { } else {
if (target == Target.CHAPTERS) category?.id?.let { if (target == Target.CHAPTERS) category?.id?.let {
instance?.addCategory(it) if (mangaToUse != null) instance?.addMangaToQueue(it, mangaToUse)
else instance?.addCategory(it)
} }
} }
} }
@ -227,6 +242,13 @@ class LibraryUpdateService(
} }
} }
private fun addMangaToQueue(categoryId: Int, manga: List<LibraryManga>) {
val selectedScheme = preferences.libraryUpdatePrioritization().getOrDefault()
val mangas = manga.sortedWith(rankingScheme[selectedScheme])
categoryIds.add(categoryId)
addManga(mangas)
}
private fun addCategory(categoryId: Int) { private fun addCategory(categoryId: Int) {
val selectedScheme = preferences.libraryUpdatePrioritization().getOrDefault() val selectedScheme = preferences.libraryUpdatePrioritization().getOrDefault()
val mangas = val mangas =
@ -322,7 +344,18 @@ class LibraryUpdateService(
instance = this instance = this
val selectedScheme = preferences.libraryUpdatePrioritization().getOrDefault() val selectedScheme = preferences.libraryUpdatePrioritization().getOrDefault()
val mangaList = getMangaToUpdate(intent, target).sortedWith(rankingScheme[selectedScheme]) val savedMangasList = intent.getLongArrayExtra(KEY_MANGAS)?.asList()
val mangaList = (if (savedMangasList != null) {
val mangas = db.getLibraryMangas().executeAsBlocking().filter {
it.id in savedMangasList
}.distinctBy { it.id }
val categoryId = intent.getIntExtra(KEY_CATEGORY, -1)
if (categoryId > -1) categoryIds.add(categoryId)
mangas
} else {
getMangaToUpdate(intent, target)
}).sortedWith(rankingScheme[selectedScheme])
// Update favorite manga. Destroy service when completed or in case of an error. // Update favorite manga. Destroy service when completed or in case of an error.
launchTarget(target, mangaList, startId) launchTarget(target, mangaList, startId)
return START_REDELIVER_INTENT return START_REDELIVER_INTENT

View File

@ -1140,8 +1140,8 @@ class LibraryController(
override fun openCategoriesBackdrop() = showCategories(true) override fun openCategoriesBackdrop() = showCategories(true)
override fun updateCategory(catId: Int): Boolean { override fun updateCategory(position: Int): Boolean {
val category = (adapter.getItem(catId) as? LibraryHeaderItem)?.category ?: return false val category = (adapter.getItem(position) as? LibraryHeaderItem)?.category ?: return false
val inQueue = LibraryUpdateService.categoryInQueue(category.id) val inQueue = LibraryUpdateService.categoryInQueue(category.id)
snack?.dismiss() snack?.dismiss()
snack = view?.snack( snack = view?.snack(
@ -1157,10 +1157,19 @@ class LibraryController(
view.elevation = 15f.dpToPx view.elevation = 15f.dpToPx
setAction(R.string.cancel) { setAction(R.string.cancel) {
LibraryUpdateService.stop(context) LibraryUpdateService.stop(context)
Handler().post { NotificationReceiver.dismissNotification(context, Notifications.ID_LIBRARY_PROGRESS) } Handler().post {
NotificationReceiver.dismissNotification(
context,
Notifications.ID_LIBRARY_PROGRESS
)
}
} }
} }
if (!inQueue) LibraryUpdateService.start(view!!.context, category) if (!inQueue) LibraryUpdateService.start(
view!!.context, category, mangaToUse = if (category.isDynamic) {
presenter.getMangaInCategories(category.id)
} else null
)
return true return true
} }

View File

@ -116,20 +116,20 @@ class LibraryHeaderHolder(val view: View, private val adapter: LibraryCategoryAd
catProgress.gone() catProgress.gone()
setSelection() setSelection()
} }
category.isDynamic -> { category.id ?: -1 < 0 -> {
expandImage.gone() expandImage.gone()
checkboxImage.gone() checkboxImage.gone()
catProgress.gone() catProgress.gone()
updateButton.gone() updateButton.gone()
} }
LibraryUpdateService.categoryInQueue(category.id) -> { LibraryUpdateService.categoryInQueue(category.id) -> {
expandImage.visibleIf(!adapter.isSingleCategory) expandImage.visibleIf(!adapter.isSingleCategory && !category.isDynamic)
checkboxImage.gone() checkboxImage.gone()
catProgress.visible() catProgress.visible()
updateButton.invisible() updateButton.invisible()
} }
else -> { else -> {
expandImage.visibleIf(!adapter.isSingleCategory) expandImage.visibleIf(!adapter.isSingleCategory && !category.isDynamic)
catProgress.gone() catProgress.gone()
checkboxImage.gone() checkboxImage.gone()
updateButton.visibleIf(!adapter.isSingleCategory) updateButton.visibleIf(!adapter.isSingleCategory)

View File

@ -152,6 +152,11 @@ class LibraryPresenter(
) )
} }
fun getMangaInCategories(catId: Int?): List<LibraryManga>? {
catId ?: return null
return allLibraryItems.filter { it.header.category.id == catId }.map { it.manga }
}
private suspend fun sectionLibrary(items: List<LibraryItem>, freshStart: Boolean = false) { private suspend fun sectionLibrary(items: List<LibraryItem>, freshStart: Boolean = false) {
libraryItems = items libraryItems = items
val showAll = showAllCategories || !libraryIsGrouped || val showAll = showAllCategories || !libraryIsGrouped ||