mirror of
				https://github.com/mihonapp/mihon.git
				synced 2025-10-26 12:00:41 +01:00 
			
		
		
		
	chore: merge upstream.
This commit is contained in:
		| @@ -1,5 +1,6 @@ | ||||
| package tachiyomi.domain.backup.service | ||||
|  | ||||
| import tachiyomi.core.preference.Preference | ||||
| import tachiyomi.core.preference.PreferenceStore | ||||
| import tachiyomi.core.provider.FolderProvider | ||||
|  | ||||
| @@ -13,4 +14,6 @@ class BackupPreferences( | ||||
|     fun numberOfBackups() = preferenceStore.getInt("backup_slots", 2) | ||||
|  | ||||
|     fun backupInterval() = preferenceStore.getInt("backup_interval", 12) | ||||
|  | ||||
|     fun lastAutoBackupTimestamp() = preferenceStore.getLong(Preference.appStateKey("last_auto_backup_timestamp"), 0L) | ||||
| } | ||||
|   | ||||
| @@ -5,13 +5,13 @@ import tachiyomi.core.util.system.logcat | ||||
| import tachiyomi.domain.chapter.model.Chapter | ||||
| import tachiyomi.domain.chapter.repository.ChapterRepository | ||||
| 
 | ||||
| class GetChapterByMangaId( | ||||
| class GetChaptersByMangaId( | ||||
|     private val chapterRepository: ChapterRepository, | ||||
| ) { | ||||
| 
 | ||||
|     suspend fun await(mangaId: Long): List<Chapter> { | ||||
|     suspend fun await(mangaId: Long, applyScanlatorFilter: Boolean = false): List<Chapter> { | ||||
|         return try { | ||||
|             chapterRepository.getChapterByMangaId(mangaId) | ||||
|             chapterRepository.getChapterByMangaId(mangaId, applyScanlatorFilter) | ||||
|         } catch (e: Exception) { | ||||
|             logcat(LogPriority.ERROR, e) | ||||
|             emptyList() | ||||
| @@ -18,6 +18,16 @@ data class Chapter( | ||||
|     val isRecognizedNumber: Boolean | ||||
|         get() = chapterNumber >= 0f | ||||
|  | ||||
|     fun copyFrom(other: Chapter): Chapter { | ||||
|         return copy( | ||||
|             name = other.name, | ||||
|             url = other.url, | ||||
|             dateUpload = other.dateUpload, | ||||
|             chapterNumber = other.chapterNumber, | ||||
|             scanlator = other.scanlator?.ifBlank { null }, | ||||
|         ) | ||||
|     } | ||||
|  | ||||
|     companion object { | ||||
|         fun create() = Chapter( | ||||
|             id = -1, | ||||
|   | ||||
| @@ -16,5 +16,18 @@ data class ChapterUpdate( | ||||
| ) | ||||
|  | ||||
| fun Chapter.toChapterUpdate(): ChapterUpdate { | ||||
|     return ChapterUpdate(id, mangaId, read, bookmark, lastPageRead, dateFetch, sourceOrder, url, name, dateUpload, chapterNumber, scanlator) | ||||
|     return ChapterUpdate( | ||||
|         id, | ||||
|         mangaId, | ||||
|         read, | ||||
|         bookmark, | ||||
|         lastPageRead, | ||||
|         dateFetch, | ||||
|         sourceOrder, | ||||
|         url, | ||||
|         name, | ||||
|         dateUpload, | ||||
|         chapterNumber, | ||||
|         scanlator, | ||||
|     ) | ||||
| } | ||||
|   | ||||
| @@ -14,13 +14,17 @@ interface ChapterRepository { | ||||
|  | ||||
|     suspend fun removeChaptersWithIds(chapterIds: List<Long>) | ||||
|  | ||||
|     suspend fun getChapterByMangaId(mangaId: Long): List<Chapter> | ||||
|     suspend fun getChapterByMangaId(mangaId: Long, applyScanlatorFilter: Boolean = false): List<Chapter> | ||||
|  | ||||
|     suspend fun getScanlatorsByMangaId(mangaId: Long): List<String> | ||||
|  | ||||
|     fun getScanlatorsByMangaIdAsFlow(mangaId: Long): Flow<List<String>> | ||||
|  | ||||
|     suspend fun getBookmarkedChaptersByMangaId(mangaId: Long): List<Chapter> | ||||
|  | ||||
|     suspend fun getChapterById(id: Long): Chapter? | ||||
|  | ||||
|     suspend fun getChapterByMangaIdAsFlow(mangaId: Long): Flow<List<Chapter>> | ||||
|     suspend fun getChapterByMangaIdAsFlow(mangaId: Long, applyScanlatorFilter: Boolean = false): Flow<List<Chapter>> | ||||
|  | ||||
|     suspend fun getChapterByUrlAndMangaId(url: String, mangaId: Long): Chapter? | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package tachiyomi.domain.chapter.service | ||||
|  | ||||
| import tachiyomi.core.util.lang.compareToWithCollator | ||||
| import tachiyomi.domain.chapter.model.Chapter | ||||
| import tachiyomi.domain.manga.model.Manga | ||||
|  | ||||
| @@ -23,6 +24,10 @@ fun getChapterSort( | ||||
|             true -> { c1, c2 -> c2.dateUpload.compareTo(c1.dateUpload) } | ||||
|             false -> { c1, c2 -> c1.dateUpload.compareTo(c2.dateUpload) } | ||||
|         } | ||||
|         Manga.CHAPTER_SORTING_ALPHABET -> when (sortDescending) { | ||||
|             true -> { c1, c2 -> c2.name.compareToWithCollator(c1.name) } | ||||
|             false -> { c1, c2 -> c1.name.compareToWithCollator(c2.name) } | ||||
|         } | ||||
|         else -> throw NotImplementedError("Invalid chapter sorting method: ${manga.sorting}") | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| package tachiyomi.domain.history.interactor | ||||
|  | ||||
| import tachiyomi.domain.chapter.interactor.GetChapterByMangaId | ||||
| import tachiyomi.domain.chapter.interactor.GetChaptersByMangaId | ||||
| import tachiyomi.domain.chapter.model.Chapter | ||||
| import tachiyomi.domain.chapter.service.getChapterSort | ||||
| import tachiyomi.domain.history.repository.HistoryRepository | ||||
| @@ -8,7 +8,7 @@ import tachiyomi.domain.manga.interactor.GetManga | ||||
| import kotlin.math.max | ||||
|  | ||||
| class GetNextChapters( | ||||
|     private val getChapterByMangaId: GetChapterByMangaId, | ||||
|     private val getChaptersByMangaId: GetChaptersByMangaId, | ||||
|     private val getManga: GetManga, | ||||
|     private val historyRepository: HistoryRepository, | ||||
| ) { | ||||
| @@ -20,7 +20,7 @@ class GetNextChapters( | ||||
|  | ||||
|     suspend fun await(mangaId: Long, onlyUnread: Boolean = true): List<Chapter> { | ||||
|         val manga = getManga.await(mangaId) ?: return emptyList() | ||||
|         val chapters = getChapterByMangaId.await(mangaId) | ||||
|         val chapters = getChaptersByMangaId.await(mangaId, applyScanlatorFilter = true) | ||||
|             .sortedWith(getChapterSort(manga, sortDescending = false)) | ||||
|  | ||||
|         return if (onlyUnread) { | ||||
|   | ||||
| @@ -30,6 +30,7 @@ data class LibrarySort( | ||||
|         data object LatestChapter : Type(0b00010100) | ||||
|         data object ChapterFetchDate : Type(0b00011000) | ||||
|         data object DateAdded : Type(0b00011100) | ||||
|         data object TrackerMean : Type(0b000100000) | ||||
|  | ||||
|         companion object { | ||||
|             fun valueOf(flag: Long): Type { | ||||
| @@ -75,6 +76,7 @@ data class LibrarySort( | ||||
|                 Type.LatestChapter, | ||||
|                 Type.ChapterFetchDate, | ||||
|                 Type.DateAdded, | ||||
|                 Type.TrackerMean, | ||||
|             ) | ||||
|         } | ||||
|         val directions by lazy { setOf(Direction.Ascending, Direction.Descending) } | ||||
| @@ -101,6 +103,7 @@ data class LibrarySort( | ||||
|                     "LATEST_CHAPTER" -> Type.LatestChapter | ||||
|                     "CHAPTER_FETCH_DATE" -> Type.ChapterFetchDate | ||||
|                     "DATE_ADDED" -> Type.DateAdded | ||||
|                     "TRACKER_MEAN" -> Type.TrackerMean | ||||
|                     else -> Type.Alphabetical | ||||
|                 } | ||||
|                 val ascending = if (values[1] == "ASCENDING") Direction.Ascending else Direction.Descending | ||||
| @@ -121,6 +124,7 @@ data class LibrarySort( | ||||
|             Type.LatestChapter -> "LATEST_CHAPTER" | ||||
|             Type.ChapterFetchDate -> "CHAPTER_FETCH_DATE" | ||||
|             Type.DateAdded -> "DATE_ADDED" | ||||
|             Type.TrackerMean -> "TRACKER_MEAN" | ||||
|         } | ||||
|         val direction = if (direction == Direction.Ascending) "ASCENDING" else "DESCENDING" | ||||
|         return "$type,$direction" | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package tachiyomi.domain.library.service | ||||
|  | ||||
| import tachiyomi.core.preference.Preference | ||||
| import tachiyomi.core.preference.PreferenceStore | ||||
| import tachiyomi.core.preference.TriState | ||||
| import tachiyomi.core.preference.getEnum | ||||
| @@ -29,7 +30,7 @@ class LibraryPreferences( | ||||
|  | ||||
|     fun landscapeColumns() = preferenceStore.getInt("pref_library_columns_landscape_key", 0) | ||||
|  | ||||
|     fun lastUpdatedTimestamp() = preferenceStore.getLong("library_update_last_timestamp", 0L) | ||||
|     fun lastUpdatedTimestamp() = preferenceStore.getLong(Preference.appStateKey("library_update_last_timestamp"), 0L) | ||||
|     fun autoUpdateInterval() = preferenceStore.getInt("pref_library_update_interval_key", 0) | ||||
|  | ||||
|     fun autoUpdateDeviceRestrictions() = preferenceStore.getStringSet( | ||||
| @@ -120,7 +121,7 @@ class LibraryPreferences( | ||||
|     fun languageBadge() = preferenceStore.getBoolean("display_language_badge", false) | ||||
|  | ||||
|     fun newShowUpdatesCount() = preferenceStore.getBoolean("library_show_updates_count", true) | ||||
|     fun newUpdatesCount() = preferenceStore.getInt("library_unseen_updates_count", 0) | ||||
|     fun newUpdatesCount() = preferenceStore.getInt(Preference.appStateKey("library_unseen_updates_count"), 0) | ||||
|  | ||||
|     // endregion | ||||
|  | ||||
| @@ -128,7 +129,7 @@ class LibraryPreferences( | ||||
|  | ||||
|     fun defaultCategory() = preferenceStore.getInt("default_category", -1) | ||||
|  | ||||
|     fun lastUsedCategory() = preferenceStore.getInt("last_used_category", 0) | ||||
|     fun lastUsedCategory() = preferenceStore.getInt(Preference.appStateKey("last_used_category"), 0) | ||||
|  | ||||
|     fun categoryTabs() = preferenceStore.getBoolean("display_category_tabs", true) | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| package tachiyomi.domain.manga.interactor | ||||
|  | ||||
| import tachiyomi.domain.chapter.interactor.GetChapterByMangaId | ||||
| import tachiyomi.domain.chapter.interactor.GetChaptersByMangaId | ||||
| import tachiyomi.domain.chapter.model.Chapter | ||||
| import tachiyomi.domain.manga.model.Manga | ||||
| import tachiyomi.domain.manga.model.MangaUpdate | ||||
| @@ -11,7 +11,7 @@ import java.time.temporal.ChronoUnit | ||||
| import kotlin.math.absoluteValue | ||||
|  | ||||
| class FetchInterval( | ||||
|     private val getChapterByMangaId: GetChapterByMangaId, | ||||
|     private val getChaptersByMangaId: GetChaptersByMangaId, | ||||
| ) { | ||||
|  | ||||
|     suspend fun toMangaUpdateOrNull( | ||||
| @@ -24,7 +24,7 @@ class FetchInterval( | ||||
|         } else { | ||||
|             window | ||||
|         } | ||||
|         val chapters = getChapterByMangaId.await(manga.id) | ||||
|         val chapters = getChaptersByMangaId.await(manga.id, applyScanlatorFilter = true) | ||||
|         val interval = manga.fetchInterval.takeIf { it < 0 } ?: calculateInterval( | ||||
|             chapters, | ||||
|             dateTime.zone, | ||||
|   | ||||
| @@ -12,10 +12,10 @@ class GetMangaWithChapters( | ||||
|     private val chapterRepository: ChapterRepository, | ||||
| ) { | ||||
|  | ||||
|     suspend fun subscribe(id: Long): Flow<Pair<Manga, List<Chapter>>> { | ||||
|     suspend fun subscribe(id: Long, applyScanlatorFilter: Boolean = false): Flow<Pair<Manga, List<Chapter>>> { | ||||
|         return combine( | ||||
|             mangaRepository.getMangaByIdAsFlow(id), | ||||
|             chapterRepository.getChapterByMangaIdAsFlow(id), | ||||
|             chapterRepository.getChapterByMangaIdAsFlow(id, applyScanlatorFilter), | ||||
|         ) { manga, chapters -> | ||||
|             Pair(manga, chapters) | ||||
|         } | ||||
| @@ -25,7 +25,7 @@ class GetMangaWithChapters( | ||||
|         return mangaRepository.getMangaById(id) | ||||
|     } | ||||
|  | ||||
|     suspend fun awaitChapters(id: Long): List<Chapter> { | ||||
|         return chapterRepository.getChapterByMangaId(id) | ||||
|     suspend fun awaitChapters(id: Long, applyScanlatorFilter: Boolean = false): List<Chapter> { | ||||
|         return chapterRepository.getChapterByMangaId(id, applyScanlatorFilter) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -85,6 +85,7 @@ data class Manga( | ||||
|         const val CHAPTER_SORTING_SOURCE = 0x00000000L | ||||
|         const val CHAPTER_SORTING_NUMBER = 0x00000100L | ||||
|         const val CHAPTER_SORTING_UPLOAD_DATE = 0x00000200L | ||||
|         const val CHAPTER_SORTING_ALPHABET = 0x00000300L | ||||
|         const val CHAPTER_SORTING_MASK = 0x00000300L | ||||
|  | ||||
|         const val CHAPTER_DISPLAY_NAME = 0x00000000L | ||||
|   | ||||
| @@ -87,6 +87,7 @@ class GetApplicationRelease( | ||||
|     sealed interface Result { | ||||
|         data class NewUpdate(val release: Release) : Result | ||||
|         data object NoNewUpdate : Result | ||||
|         data object OsTooOld : Result | ||||
|         data object ThirdPartyInstallation : Result | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,19 +2,14 @@ package tachiyomi.domain.track.interactor | ||||
|  | ||||
| import kotlinx.coroutines.flow.Flow | ||||
| import kotlinx.coroutines.flow.map | ||||
| import tachiyomi.domain.track.model.Track | ||||
| import tachiyomi.domain.track.repository.TrackRepository | ||||
|  | ||||
| class GetTracksPerManga( | ||||
|     private val trackRepository: TrackRepository, | ||||
| ) { | ||||
|  | ||||
|     fun subscribe(): Flow<Map<Long, List<Long>>> { | ||||
|         return trackRepository.getTracksAsFlow().map { tracks -> | ||||
|             tracks | ||||
|                 .groupBy { it.mangaId } | ||||
|                 .mapValues { entry -> | ||||
|                     entry.value.map { it.syncId } | ||||
|                 } | ||||
|         } | ||||
|     fun subscribe(): Flow<Map<Long, List<Track>>> { | ||||
|         return trackRepository.getTracksAsFlow().map { tracks -> tracks.groupBy { it.mangaId } } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -12,7 +12,7 @@ class LibraryFlagsTest { | ||||
|     @Test | ||||
|     fun `Check the amount of flags`() { | ||||
|         LibraryDisplayMode.values.size shouldBe 4 | ||||
|         LibrarySort.types.size shouldBe 8 | ||||
|         LibrarySort.types.size shouldBe 9 | ||||
|         LibrarySort.directions.size shouldBe 2 | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user