More refactoring + more bug fixes

Such as when a manga picked has 0 chapters
This commit is contained in:
Jay 2020-01-04 22:19:47 -08:00
parent 142dc1c12a
commit 332e8c9487
6 changed files with 51 additions and 33 deletions

View File

@ -21,6 +21,8 @@ class MigratingManga(private val db: DatabaseHelper,
val migrationJob = parentContext + SupervisorJob() + Dispatchers.Default val migrationJob = parentContext + SupervisorJob() + Dispatchers.Default
var migrationStatus:Int = MigrationStatus.RUNNUNG
@Volatile @Volatile
private var manga: Manga? = null private var manga: Manga? = null
suspend fun manga(): Manga? { suspend fun manga(): Manga? {
@ -37,3 +39,11 @@ class MigratingManga(private val db: DatabaseHelper,
return MigrationProcessItem(this) return MigrationProcessItem(this)
} }
} }
class MigrationStatus {
companion object {
val RUNNUNG = 0
val MANGA_FOUND = 1
val MANGA_NOT_FOUND = 2
}
}

View File

@ -9,6 +9,7 @@ import android.view.MenuInflater
import android.view.MenuItem import android.view.MenuItem
import android.view.View import android.view.View
import android.view.ViewGroup import android.view.ViewGroup
import android.widget.Toast
import androidx.core.graphics.ColorUtils import androidx.core.graphics.ColorUtils
import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.LinearLayoutManager
import androidx.vectordrawable.graphics.drawable.VectorDrawableCompat import androidx.vectordrawable.graphics.drawable.VectorDrawableCompat
@ -233,6 +234,9 @@ class MigrationListController(bundle: Bundle? = null) : BaseController(bundle),
} }
} }
manga.migrationStatus = if (result == null) MigrationStatus.MANGA_NOT_FOUND else
MigrationStatus.MANGA_FOUND
adapter?.sourceFinished()
manga.searchResult.initialize(result?.id) manga.searchResult.initialize(result?.id)
} }
} }
@ -281,19 +285,24 @@ class MigrationListController(bundle: Bundle? = null) : BaseController(bundle),
fun useMangaForMigration(manga: Manga, source: Source) { fun useMangaForMigration(manga: Manga, source: Source) {
val firstIndex = selectedPosition ?: return val firstIndex = selectedPosition ?: return
val migratingManga = adapter?.getItem(firstIndex) ?: return val migratingManga = adapter?.getItem(firstIndex) ?: return
migratingManga.showSpinner() migratingManga.manga.migrationStatus = MigrationStatus.RUNNUNG
adapter?.notifyItemChanged(firstIndex)
launchUI { launchUI {
val result = CoroutineScope(migratingManga.manga.migrationJob).async { val result = CoroutineScope(migratingManga.manga.migrationJob).async {
val localManga = smartSearchEngine.networkToLocalManga(manga, source.id) val localManga = smartSearchEngine.networkToLocalManga(manga, source.id)
val chapters = source.fetchChapterList(localManga).toSingle().await( val chapters = source.fetchChapterList(localManga).toSingle().await(
Schedulers.io() Schedulers.io()
) )
withContext(Dispatchers.IO) { try {
syncChaptersWithSource(db, chapters, localManga, source) syncChaptersWithSource(db, chapters, localManga, source)
} }
catch (e: Exception) {
return@async null
}
localManga localManga
}.await() }.await()
if (result != null) {
try { try {
val newManga = val newManga =
sourceManager.getOrStub(result.source).fetchMangaDetails(result).toSingle() sourceManager.getOrStub(result.source).fetchMangaDetails(result).toSingle()
@ -307,9 +316,16 @@ class MigrationListController(bundle: Bundle? = null) : BaseController(bundle),
} catch (e: Exception) { } catch (e: Exception) {
} }
migratingManga.manga.migrationStatus = MigrationStatus.MANGA_FOUND
migratingManga.manga.searchResult.set(result.id) migratingManga.manga.searchResult.set(result.id)
adapter?.notifyDataSetChanged() adapter?.notifyDataSetChanged()
} }
else {
migratingManga.manga.migrationStatus = MigrationStatus.MANGA_NOT_FOUND
activity?.toast(R.string.error_fetching_migration, Toast.LENGTH_LONG)
adapter?.notifyDataSetChanged()
}
}
} }
fun migrateMangas() { fun migrateMangas() {

View File

@ -45,12 +45,10 @@ class MigrationProcessAdapter(
if (allMangasDone()) menuItemListener.enableButtons() if (allMangasDone()) menuItemListener.enableButtons()
} }
fun allMangasDone() = (items.all { it.manga.searchResult.initialized || !it.manga.migrationJob fun allMangasDone() = (items.all { it.manga.migrationStatus != MigrationStatus
.isActive } && items.any { it.manga .RUNNUNG } && items.any { it.manga.migrationStatus == MigrationStatus.MANGA_FOUND })
.searchResult.content != null })
fun mangasSkipped() = (items.count { (!it.manga.searchResult.initialized || it.manga fun mangasSkipped() = (items.count { it.manga.migrationStatus == MigrationStatus.MANGA_NOT_FOUND })
.searchResult.content == null) })
suspend fun performMigrations(copy: Boolean) { suspend fun performMigrations(copy: Boolean) {
withContext(Dispatchers.IO) { withContext(Dispatchers.IO) {

View File

@ -87,7 +87,8 @@ class MigrationProcessHolder(
sourceManager.get(it) sourceManager.get(it)
} }
withContext(Dispatchers.Main) { withContext(Dispatchers.Main) {
if (item.manga.mangaId != this@MigrationProcessHolder.item?.manga?.mangaId) { if (item.manga.mangaId != this@MigrationProcessHolder.item?.manga?.mangaId ||
item.manga.migrationStatus == MigrationStatus.RUNNUNG) {
return@withContext return@withContext
} }
if (searchResult != null && resultSource != null) { if (searchResult != null && resultSource != null) {
@ -101,7 +102,8 @@ class MigrationProcessHolder(
} }
} else { } else {
migration_manga_card_to.loading_group.gone() migration_manga_card_to.loading_group.gone()
migration_manga_card_to.title.text = "No Alternatives Found" migration_manga_card_to.title.text = view.context.applicationContext
.getString(R.string.no_alternatives_found)
} }
migration_menu.visible() migration_menu.visible()
skip_manga.gone() skip_manga.gone()
@ -111,10 +113,6 @@ class MigrationProcessHolder(
} }
} }
fun showSpinner() {
migration_manga_card_to.loading_group.visible()
}
private fun View.resetManga() { private fun View.resetManga() {
loading_group.visible() loading_group.visible()
thumbnail.setImageDrawable(null) thumbnail.setImageDrawable(null)

View File

@ -10,7 +10,6 @@ import eu.kanade.tachiyomi.R
class MigrationProcessItem(val manga: MigratingManga) : class MigrationProcessItem(val manga: MigratingManga) :
AbstractFlexibleItem<MigrationProcessHolder>() { AbstractFlexibleItem<MigrationProcessHolder>() {
var holder:MigrationProcessHolder? = null
override fun getLayoutRes(): Int { override fun getLayoutRes(): Int {
return R.layout.migration_process_item return R.layout.migration_process_item
} }
@ -23,8 +22,6 @@ class MigrationProcessItem(val manga: MigratingManga) :
holder: MigrationProcessHolder, holder: MigrationProcessHolder,
position: Int, position: Int,
payloads: MutableList<Any?>?) { payloads: MutableList<Any?>?) {
this.holder = holder
holder.bind(this) holder.bind(this)
} }
@ -36,10 +33,6 @@ class MigrationProcessItem(val manga: MigratingManga) :
return false return false
} }
fun showSpinner() {
holder?.showSpinner()
}
override fun hashCode(): Int { override fun hashCode(): Int {
return manga.mangaId.toInt() return manga.mangaId.toInt()
} }

View File

@ -426,6 +426,9 @@
<string name="confirm_copy">Copy %1$d%2$s mangas?</string> <string name="confirm_copy">Copy %1$d%2$s mangas?</string>
<string name="skipping_x">(skipping %1$d)</string> <string name="skipping_x">(skipping %1$d)</string>
<string name="no_migrations">No manga migrated</string> <string name="no_migrations">No manga migrated</string>
<string name="error_fetching_migration">No chapters found, this manga cannot be used for
migration</string>
<string name="no_alternatives_found">No Alternatives Found</string>
<!-- Tracking Screen --> <!-- Tracking Screen -->
<string name="manga_tracking_tab">Tracking</string> <string name="manga_tracking_tab">Tracking</string>