|
|
@ -57,22 +57,24 @@ class MangaRestorer(
|
|
|
|
backupManga: BackupManga,
|
|
|
|
backupManga: BackupManga,
|
|
|
|
backupCategories: List<BackupCategory>,
|
|
|
|
backupCategories: List<BackupCategory>,
|
|
|
|
) {
|
|
|
|
) {
|
|
|
|
val dbManga = findExistingManga(backupManga)
|
|
|
|
handler.await(inTransaction = true) {
|
|
|
|
val manga = backupManga.getMangaImpl()
|
|
|
|
val dbManga = findExistingManga(backupManga)
|
|
|
|
val restoredManga = if (dbManga == null) {
|
|
|
|
val manga = backupManga.getMangaImpl()
|
|
|
|
restoreNewManga(manga)
|
|
|
|
val restoredManga = if (dbManga == null) {
|
|
|
|
} else {
|
|
|
|
restoreNewManga(manga)
|
|
|
|
restoreExistingManga(manga, dbManga)
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
restoreExistingManga(manga, dbManga)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
restoreMangaDetails(
|
|
|
|
restoreMangaDetails(
|
|
|
|
manga = restoredManga,
|
|
|
|
manga = restoredManga,
|
|
|
|
chapters = backupManga.chapters,
|
|
|
|
chapters = backupManga.chapters,
|
|
|
|
categories = backupManga.categories,
|
|
|
|
categories = backupManga.categories,
|
|
|
|
backupCategories = backupCategories,
|
|
|
|
backupCategories = backupCategories,
|
|
|
|
history = backupManga.history + backupManga.brokenHistory.map { it.toBackupHistory() },
|
|
|
|
history = backupManga.history + backupManga.brokenHistory.map { it.toBackupHistory() },
|
|
|
|
tracks = backupManga.tracking,
|
|
|
|
tracks = backupManga.tracking,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private suspend fun findExistingManga(backupManga: BackupManga): Manga? {
|
|
|
|
private suspend fun findExistingManga(backupManga: BackupManga): Manga? {
|
|
|
|