From bc053580ad21669cf507dea1aa14a8dd5cb59ef6 Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Tue, 10 May 2022 21:02:46 +0800 Subject: [PATCH 01/80] Use theme primary color for slider track (#7102) --- app/src/main/res/color/slider_active_track.xml | 5 +++++ app/src/main/res/color/slider_inactive_track.xml | 5 +++++ app/src/main/res/values/styles.xml | 2 ++ 3 files changed, 12 insertions(+) create mode 100644 app/src/main/res/color/slider_active_track.xml create mode 100644 app/src/main/res/color/slider_inactive_track.xml diff --git a/app/src/main/res/color/slider_active_track.xml b/app/src/main/res/color/slider_active_track.xml new file mode 100644 index 0000000000..764d21bf3d --- /dev/null +++ b/app/src/main/res/color/slider_active_track.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/color/slider_inactive_track.xml b/app/src/main/res/color/slider_inactive_track.xml new file mode 100644 index 0000000000..0f624c1173 --- /dev/null +++ b/app/src/main/res/color/slider_inactive_track.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/values/styles.xml b/app/src/main/res/values/styles.xml index dbf73d1a1e..7130d28c45 100644 --- a/app/src/main/res/values/styles.xml +++ b/app/src/main/res/values/styles.xml @@ -192,6 +192,8 @@ From e421eb61bc7b4bcaf10b7e165358de83d2bfe368 Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 09:19:10 -0400 Subject: [PATCH 02/80] Extract add duplicate manga dialog into a controller --- .../ui/base/controller/DialogController.kt | 2 +- .../ui/manga/AddDuplicateMangaDialog.kt | 49 +++++++++++++++++++ .../tachiyomi/ui/manga/MangaController.kt | 38 ++++---------- 3 files changed, 59 insertions(+), 30 deletions(-) create mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/DialogController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/DialogController.kt index 847f97214b..63f63e1d00 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/DialogController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/DialogController.kt @@ -97,7 +97,7 @@ abstract class DialogController : Controller { /** * Dismiss the dialog and pop this controller */ - private fun dismissDialog() { + fun dismissDialog() { if (dismissed) { return } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt new file mode 100644 index 0000000000..5121f44cc0 --- /dev/null +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt @@ -0,0 +1,49 @@ +package eu.kanade.tachiyomi.ui.manga + +import android.app.Dialog +import android.os.Bundle +import com.bluelinelabs.conductor.Controller +import com.google.android.material.dialog.MaterialAlertDialogBuilder +import eu.kanade.tachiyomi.R +import eu.kanade.tachiyomi.data.database.models.Manga +import eu.kanade.tachiyomi.source.SourceManager +import eu.kanade.tachiyomi.ui.base.controller.DialogController +import eu.kanade.tachiyomi.ui.base.controller.pushController +import uy.kohesive.injekt.injectLazy + +class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bundle) + where T : Controller, T : AddDuplicateMangaDialog.Listener { + + private val sourceManager: SourceManager by injectLazy() + + private lateinit var libraryManga: Manga + private lateinit var newManga: Manga + + constructor(target: T, libraryManga: Manga, newManga: Manga) : this() { + targetController = target + + this.libraryManga = libraryManga + this.newManga = newManga + } + + override fun onCreateDialog(savedViewState: Bundle?): Dialog { + val source = sourceManager.getOrStub(libraryManga.source) + + return MaterialAlertDialogBuilder(activity!!) + .setMessage(activity?.getString(R.string.confirm_manga_add_duplicate, source.name)) + .setPositiveButton(activity?.getString(R.string.action_add)) { _, _ -> + (targetController as? Listener)?.addToLibrary(newManga) + } + .setNegativeButton(android.R.string.cancel, null) + .setNeutralButton(activity?.getString(R.string.action_show_manga)) { _, _ -> + dismissDialog() + router.pushController(MangaController(libraryManga)) + } + .setCancelable(true) + .create() + } + + interface Listener { + fun addToLibrary(newManga: Manga) + } +} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt index 60f0929d8f..e36f5a2031 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt @@ -29,7 +29,6 @@ import coil.request.ImageRequest import com.bluelinelabs.conductor.Controller import com.bluelinelabs.conductor.ControllerChangeHandler import com.bluelinelabs.conductor.ControllerChangeType -import com.google.android.material.dialog.MaterialAlertDialogBuilder import com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton import com.google.android.material.snackbar.Snackbar import dev.chrisbanes.insetter.applyInsetter @@ -114,6 +113,7 @@ class MangaController : FlexibleAdapter.OnItemClickListener, FlexibleAdapter.OnItemLongClickListener, BaseChaptersAdapter.OnChapterClickListener, + AddDuplicateMangaDialog.Listener, ChangeMangaCoverDialog.Listener, ChangeMangaCategoriesDialog.Listener, DownloadCustomChaptersDialog.Listener, @@ -521,38 +521,18 @@ class MangaController : } else { val duplicateManga = presenter.getDuplicateLibraryManga(manga) if (duplicateManga != null) { - showAddDuplicateDialog( - manga, - duplicateManga, - ) + AddDuplicateMangaDialog(this, duplicateManga, manga).showDialog(router) } else { addToLibrary(manga) } } } - private fun showAddDuplicateDialog(newManga: Manga, libraryManga: Manga) { - activity?.let { - val source = sourceManager.getOrStub(libraryManga.source) - MaterialAlertDialogBuilder(it).apply { - setMessage(activity?.getString(R.string.confirm_manga_add_duplicate, source.name)) - setPositiveButton(activity?.getString(R.string.action_add)) { _, _ -> - addToLibrary(newManga) - } - setNegativeButton(activity?.getString(R.string.action_cancel)) { _, _ -> } - setNeutralButton(activity?.getString(R.string.action_show_manga)) { _, _ -> - router.pushController(MangaController(libraryManga)) - } - setCancelable(true) - }.create().show() - } - } - fun onTrackingClick() { trackSheet?.show() } - private fun addToLibrary(manga: Manga) { + override fun addToLibrary(newManga: Manga) { val categories = presenter.getCategories() val defaultCategoryId = preferences.defaultCategory() val defaultCategory = categories.find { it.id == defaultCategoryId } @@ -561,7 +541,7 @@ class MangaController : // Default category set defaultCategory != null -> { toggleFavorite() - presenter.moveMangaToCategory(manga, defaultCategory) + presenter.moveMangaToCategory(newManga, defaultCategory) activity?.toast(activity?.getString(R.string.manga_added_library)) activity?.invalidateOptionsMenu() } @@ -569,14 +549,14 @@ class MangaController : // Automatic 'Default' or no categories defaultCategoryId == 0 || categories.isEmpty() -> { toggleFavorite() - presenter.moveMangaToCategory(manga, null) + presenter.moveMangaToCategory(newManga, null) activity?.toast(activity?.getString(R.string.manga_added_library)) activity?.invalidateOptionsMenu() } // Choose a category else -> { - val ids = presenter.getMangaCategoryIds(manga) + val ids = presenter.getMangaCategoryIds(newManga) val preselected = categories.map { if (it.id in ids) { QuadStateTextView.State.CHECKED.ordinal @@ -585,7 +565,7 @@ class MangaController : } }.toTypedArray() - showChangeCategoryDialog(manga, categories, preselected) + showChangeCategoryDialog(newManga, categories, preselected) } } @@ -597,12 +577,12 @@ class MangaController : .forEach { service -> launchIO { try { - service.match(manga)?.let { track -> + service.match(newManga)?.let { track -> presenter.registerTracking(track, service as TrackService) } } catch (e: Exception) { logcat(LogPriority.WARN, e) { - "Could not match manga: ${manga.title} with service $service" + "Could not match manga: ${newManga.title} with service $service" } } } From e7ed130f2a4fcd7452737476189687fbd130c80d Mon Sep 17 00:00:00 2001 From: nicki <72807749+curche@users.noreply.github.com> Date: Wed, 11 May 2022 02:34:40 +0530 Subject: [PATCH 03/80] Check for app updates by comparing semver (#7100) Instead of just checking whether the current app version *matches* with latest app version in GitHub Releases, compare the semver from the tag names to check whether the latter is greater and the app needs an update Reference: semver spec #11 https://semver.org/#spec-item-11 Co-authored-by: Andreas <6576096+ghostbear@users.noreply.github.com> Co-authored-by: Andreas <6576096+ghostbear@users.noreply.github.com> --- .../kanade/tachiyomi/data/updater/AppUpdateChecker.kt | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt index 9b1b317c96..60460dc982 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt @@ -56,6 +56,7 @@ class AppUpdateChecker { private fun isNewVersion(versionTag: String): Boolean { // Removes prefixes like "r" or "v" val newVersion = versionTag.replace("[^\\d.]".toRegex(), "") + val oldVersion = BuildConfig.VERSION_NAME.replace("[^\\d.]".toRegex(), "") return if (BuildConfig.PREVIEW) { // Preview builds: based on releases in "tachiyomiorg/tachiyomi-preview" repo @@ -64,7 +65,15 @@ class AppUpdateChecker { } else { // Release builds: based on releases in "tachiyomiorg/tachiyomi" repo // tagged as something like "v0.1.2" - newVersion != BuildConfig.VERSION_NAME + val newSemVer = newVersion.split(".").map { it.toInt() } + val oldSemVer = oldVersion.split(".").map { it.toInt() } + + oldSemVer.mapIndexed { index, i -> + if (newSemVer[index] > i) { + return true + } + } + false } } } From 9f655e0d41a690752ac440d9bc8fb56188d4ef0c Mon Sep 17 00:00:00 2001 From: FourTOne5 <59261191+FourTOne5@users.noreply.github.com> Date: Wed, 11 May 2022 03:06:18 +0600 Subject: [PATCH 04/80] Fix download splitter potentially throwing OOM on huge images (#7099) * Fix download splitter potentially throwing OOM on huge images Also move the splitting to ImageUtil * Change variable name and logcat output --- .../tachiyomi/data/download/Downloader.kt | 66 +++----------- .../util/system/ContextExtensions.kt | 3 + .../kanade/tachiyomi/util/system/ImageUtil.kt | 86 ++++++++++++++++--- app/src/main/res/values/strings.xml | 1 + 4 files changed, 90 insertions(+), 66 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt index b4535cfdec..7e62a35a16 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt @@ -1,8 +1,6 @@ package eu.kanade.tachiyomi.data.download import android.content.Context -import android.graphics.Bitmap -import android.graphics.BitmapFactory import android.webkit.MimeTypeMap import com.hippo.unifile.UniFile import com.jakewharton.rxrelay.BehaviorRelay @@ -29,8 +27,6 @@ import eu.kanade.tachiyomi.util.lang.withUIContext import eu.kanade.tachiyomi.util.storage.DiskUtil import eu.kanade.tachiyomi.util.storage.saveTo import eu.kanade.tachiyomi.util.system.ImageUtil -import eu.kanade.tachiyomi.util.system.ImageUtil.isAnimatedAndSupported -import eu.kanade.tachiyomi.util.system.ImageUtil.isTallImage import eu.kanade.tachiyomi.util.system.logcat import kotlinx.coroutines.async import logcat.LogPriority @@ -42,12 +38,9 @@ import rx.subscriptions.CompositeSubscription import uy.kohesive.injekt.injectLazy import java.io.BufferedOutputStream import java.io.File -import java.io.FileOutputStream import java.util.zip.CRC32 import java.util.zip.ZipEntry import java.util.zip.ZipOutputStream -import kotlin.math.ceil -import kotlin.math.min /** * This class is the one in charge of downloading chapters. @@ -353,9 +346,7 @@ class Downloader( .onBackpressureLatest() // Do when page is downloaded. .doOnNext { page -> - if (preferences.splitTallImages().get()) { - splitTallImage(page, tmpDir) - } + splitTallImageIfNeeded(page, tmpDir) notifier.onProgressChange(download) } .toList() @@ -364,6 +355,7 @@ class Downloader( .doOnNext { ensureSuccessfulDownload(download, mangaDir, tmpDir, chapterDirname) } // If the page list threw, it will resume here .onErrorReturn { error -> + logcat(LogPriority.ERROR, error) download.status = Download.State.ERROR notifier.onError(error.message, download.chapter.name, download.manga.title) download @@ -487,6 +479,18 @@ class Downloader( return MimeTypeMap.getSingleton().getExtensionFromMimeType(mime) ?: "jpg" } + private fun splitTallImageIfNeeded(page: Page, tmpDir: UniFile) { + if (!preferences.splitTallImages().get()) return + + val filename = String.format("%03d", page.number) + val imageFile = tmpDir.listFiles()?.find { it.name!!.startsWith("$filename.") } + ?: throw Error(context.getString(R.string.download_notifier_split_page_not_found, page.number)) + val imageFilePath = imageFile.filePath + ?: throw Error(context.getString(R.string.download_notifier_split_page_path_not_found, page.number)) + + ImageUtil.splitTallImage(imageFile, imageFilePath) + } + /** * Checks if the download was successful. * @@ -557,48 +561,6 @@ class Downloader( tmpDir.delete() } - /** - * Splits tall images to improve performance of reader - */ - private fun splitTallImage(page: Page, tmpDir: UniFile) { - val filename = String.format("%03d", page.number) - val imageFile = tmpDir.listFiles()?.find { it.name!!.startsWith("$filename.") } - ?: throw Error(context.getString(R.string.download_notifier_split_page_not_found, page.number)) - - if (isAnimatedAndSupported(imageFile.openInputStream()) || !isTallImage(imageFile.openInputStream())) { - return - } - - val bitmap = BitmapFactory.decodeFile(imageFile.filePath) - val splitsCount = bitmap.height / context.resources.displayMetrics.heightPixels + 1 - val heightPerSplit = ceil(bitmap.height / splitsCount.toDouble()).toInt() - logcat { "Splitting height ${bitmap.height} by $splitsCount * $heightPerSplit" } - - try { - (0 until splitsCount).forEach { split -> - logcat { "Split #$split at y=${split * heightPerSplit}" } - val splitPath = imageFile.filePath!!.substringBeforeLast(".") + "__${"%03d".format(split + 1)}.jpg" - val splitHeight = split * heightPerSplit - FileOutputStream(splitPath).use { stream -> - Bitmap.createBitmap( - bitmap, - 0, - splitHeight, - bitmap.width, - min(heightPerSplit, bitmap.height - splitHeight), - ).compress(Bitmap.CompressFormat.JPEG, 100, stream) - } - } - imageFile.delete() - } catch (e: Exception) { - // Image splits were not successfully saved so delete them and keep the original image - (0 until splitsCount) - .map { imageFile.filePath!!.substringBeforeLast(".") + "__${"%03d".format(it + 1)}.jpg" } - .forEach { File(it).delete() } - throw e - } - } - /** * Completes a download. This method is called in the main thread. */ diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/system/ContextExtensions.kt b/app/src/main/java/eu/kanade/tachiyomi/util/system/ContextExtensions.kt index 134d8470d8..94b69e9d06 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/system/ContextExtensions.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/system/ContextExtensions.kt @@ -162,6 +162,9 @@ fun Context.hasPermission(permission: String) = ContextCompat.checkSelfPermissio } } +val getDisplayHeightInPx: Int + get() = Resources.getSystem().displayMetrics.heightPixels + /** * Converts to dp. */ diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt index a596600aaa..2a4978aeed 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt @@ -4,6 +4,7 @@ import android.content.Context import android.content.res.Configuration import android.graphics.Bitmap import android.graphics.BitmapFactory +import android.graphics.BitmapRegionDecoder import android.graphics.Color import android.graphics.Rect import android.graphics.drawable.ColorDrawable @@ -16,14 +17,18 @@ import androidx.core.graphics.blue import androidx.core.graphics.createBitmap import androidx.core.graphics.green import androidx.core.graphics.red +import com.hippo.unifile.UniFile import tachiyomi.decoder.Format import tachiyomi.decoder.ImageDecoder import java.io.BufferedInputStream import java.io.ByteArrayInputStream import java.io.ByteArrayOutputStream +import java.io.File +import java.io.FileOutputStream import java.io.InputStream import java.net.URLConnection import kotlin.math.abs +import kotlin.math.min object ImageUtil { @@ -67,8 +72,7 @@ object ImageUtil { Format.Webp -> type.isAnimated && Build.VERSION.SDK_INT >= Build.VERSION_CODES.P else -> false } - } catch (e: Exception) { - } + } catch (e: Exception) { /* Do Nothing */ } return false } @@ -106,20 +110,9 @@ object ImageUtil { */ fun isWideImage(imageStream: BufferedInputStream): Boolean { val options = extractImageOptions(imageStream) - imageStream.reset() return options.outWidth > options.outHeight } - /** - * Check whether the image is considered a tall image. - * - * @return true if the height:width ratio is greater than 3. - */ - fun isTallImage(imageStream: InputStream): Boolean { - val options = extractImageOptions(imageStream) - return (options.outHeight / options.outWidth) > 3 - } - /** * Extract the 'side' part from imageStream and return it as InputStream. */ @@ -183,6 +176,70 @@ object ImageUtil { RIGHT, LEFT } + /** + * Check whether the image is considered a tall image. + * + * @return true if the height:width ratio is greater than 3. + */ + fun isTallImage(imageStream: InputStream): Boolean { + val options = extractImageOptions(imageStream, false) + return (options.outHeight / options.outWidth) > 3 + } + + /** + * Splits tall images to improve performance of reader + */ + fun splitTallImage(imageFile: UniFile, imageFilePath: String) { + if (isAnimatedAndSupported(imageFile.openInputStream()) || !isTallImage(imageFile.openInputStream())) { + return + } + + val options = extractImageOptions(imageFile.openInputStream(), false).apply { inJustDecodeBounds = false } + // Values are stored as they get modified during split loop + val imageHeight = options.outHeight + val imageWidth = options.outWidth + + val splitHeight = getDisplayHeightInPx + // -1 so it doesn't try to split when imageHeight = getDisplayHeightInPx + val partCount = (imageHeight - 1) / getDisplayHeightInPx + 1 + + logcat { "Splitting ${imageHeight}px height image into $partCount part with estimated ${splitHeight}px per height" } + + val bitmapRegionDecoder = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) { + BitmapRegionDecoder.newInstance(imageFile.openInputStream()) + } else { + @Suppress("DEPRECATION") + BitmapRegionDecoder.newInstance(imageFile.openInputStream(), false) + } + + try { + (0 until partCount).forEach { splitIndex -> + val splitPath = imageFilePath.substringBeforeLast(".") + "__${"%03d".format(splitIndex + 1)}.jpg" + + val topOffset = splitIndex * splitHeight + val outputImageHeight = min(splitHeight, imageHeight - topOffset) + val bottomOffset = topOffset + outputImageHeight + logcat { "Split #$splitIndex with topOffset=$topOffset height=$outputImageHeight bottomOffset=$bottomOffset" } + + val region = Rect(0, topOffset, imageWidth, bottomOffset) + + FileOutputStream(splitPath).use { outputStream -> + val splitBitmap = bitmapRegionDecoder!!.decodeRegion(region, options) + splitBitmap.compress(Bitmap.CompressFormat.JPEG, 100, outputStream) + } + } + imageFile.delete() + } catch (e: Exception) { + // Image splits were not successfully saved so delete them and keep the original image + (0 until partCount) + .map { imageFile.filePath!!.substringBeforeLast(".") + "__${"%03d".format(it + 1)}.jpg" } + .forEach { File(it).delete() } + throw e + } finally { + bitmapRegionDecoder?.recycle() + } + } + /** * Algorithm for determining what background to accompany a comic/manga page */ @@ -401,12 +458,13 @@ object ImageUtil { /** * Used to check an image's dimensions without loading it in the memory. */ - private fun extractImageOptions(imageStream: InputStream): BitmapFactory.Options { + private fun extractImageOptions(imageStream: InputStream, resetAfterExtraction: Boolean = true): BitmapFactory.Options { imageStream.mark(imageStream.available() + 1) val imageBytes = imageStream.readBytes() val options = BitmapFactory.Options().apply { inJustDecodeBounds = true } BitmapFactory.decodeByteArray(imageBytes, 0, imageBytes.size, options) + if (resetAfterExtraction) imageStream.reset() return options } } diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index c48ae6bbd5..5a1d4b42db 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -815,6 +815,7 @@ Download paused Download completed Page %d not found while splitting + Couldn\'t find file path of page %d Common From d3f9232a3fa50e02af110b5320b4fcf4bcccb3cd Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 17:39:45 -0400 Subject: [PATCH 05/80] Minor cleanup - Add pending intent immutable flags to satisfy lint warnings - Change AddDuplicateMangaDialog arg to a function instead to avoid leaking controller-specific logic into it - Require WebView 99+ --- app/src/main/java/eu/kanade/tachiyomi/App.kt | 2 +- .../data/library/LibraryUpdateNotifier.kt | 2 +- .../data/notification/NotificationReceiver.kt | 32 +++++++++---------- .../data/updater/AppUpdateChecker.kt | 5 ++- .../data/updater/AppUpdateNotifier.kt | 4 ++- .../ui/manga/AddDuplicateMangaDialog.kt | 12 ++++--- .../tachiyomi/ui/manga/MangaController.kt | 3 +- .../tachiyomi/util/system/WebViewUtil.kt | 2 +- 8 files changed, 36 insertions(+), 26 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/App.kt b/app/src/main/java/eu/kanade/tachiyomi/App.kt index 74ced7ff00..acb62da136 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/App.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/App.kt @@ -99,7 +99,7 @@ open class App : Application(), DefaultLifecycleObserver, ImageLoaderFactory { this@App, 0, Intent(ACTION_DISABLE_INCOGNITO_MODE), - PendingIntent.FLAG_ONE_SHOT, + PendingIntent.FLAG_ONE_SHOT or PendingIntent.FLAG_IMMUTABLE, ) setContentIntent(pendingIntent) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateNotifier.kt b/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateNotifier.kt index b855332678..0fe4733c27 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateNotifier.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateNotifier.kt @@ -339,7 +339,7 @@ class LibraryUpdateNotifier(private val context: Context) { flags = Intent.FLAG_ACTIVITY_CLEAR_TOP or Intent.FLAG_ACTIVITY_SINGLE_TOP action = MainActivity.SHORTCUT_RECENTLY_UPDATED } - return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } companion object { diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/notification/NotificationReceiver.kt b/app/src/main/java/eu/kanade/tachiyomi/data/notification/NotificationReceiver.kt index 594325527a..47039a174f 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/notification/NotificationReceiver.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/notification/NotificationReceiver.kt @@ -307,7 +307,7 @@ class NotificationReceiver : BroadcastReceiver() { val intent = Intent(context, NotificationReceiver::class.java).apply { action = ACTION_RESUME_DOWNLOADS } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -320,7 +320,7 @@ class NotificationReceiver : BroadcastReceiver() { val intent = Intent(context, NotificationReceiver::class.java).apply { action = ACTION_PAUSE_DOWNLOADS } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -333,7 +333,7 @@ class NotificationReceiver : BroadcastReceiver() { val intent = Intent(context, NotificationReceiver::class.java).apply { action = ACTION_CLEAR_DOWNLOADS } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -348,7 +348,7 @@ class NotificationReceiver : BroadcastReceiver() { action = ACTION_DISMISS_NOTIFICATION putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -403,7 +403,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_FILE_LOCATION, path) putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -420,7 +420,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_FILE_LOCATION, path) putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -432,7 +432,7 @@ class NotificationReceiver : BroadcastReceiver() { */ internal fun openChapterPendingActivity(context: Context, manga: Manga, chapter: Chapter): PendingIntent { val newIntent = ReaderActivity.newIntent(context, manga, chapter) - return PendingIntent.getActivity(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getActivity(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -448,7 +448,7 @@ class NotificationReceiver : BroadcastReceiver() { .putExtra(MangaController.MANGA_EXTRA, manga.id) .putExtra("notificationId", manga.id.hashCode()) .putExtra("groupId", groupId) - return PendingIntent.getActivity(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getActivity(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -470,7 +470,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_NOTIFICATION_ID, manga.id.hashCode()) putExtra(EXTRA_GROUP_ID, groupId) } - return PendingIntent.getBroadcast(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -492,7 +492,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_NOTIFICATION_ID, manga.id.hashCode()) putExtra(EXTRA_GROUP_ID, groupId) } - return PendingIntent.getBroadcast(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, manga.id.hashCode(), newIntent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -505,7 +505,7 @@ class NotificationReceiver : BroadcastReceiver() { val intent = Intent(context, NotificationReceiver::class.java).apply { action = ACTION_CANCEL_LIBRARY_UPDATE } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -519,7 +519,7 @@ class NotificationReceiver : BroadcastReceiver() { action = MainActivity.SHORTCUT_EXTENSIONS addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP) } - return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -536,7 +536,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_URI, uri) putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -552,7 +552,7 @@ class NotificationReceiver : BroadcastReceiver() { setDataAndType(uri, "text/plain") flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_GRANT_READ_URI_PERMISSION } - return PendingIntent.getActivity(context, 0, intent, 0) + return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_IMMUTABLE) } /** @@ -569,7 +569,7 @@ class NotificationReceiver : BroadcastReceiver() { putExtra(EXTRA_URI, uri) putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } /** @@ -584,7 +584,7 @@ class NotificationReceiver : BroadcastReceiver() { action = ACTION_CANCEL_RESTORE putExtra(EXTRA_NOTIFICATION_ID, notificationId) } - return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt index 60460dc982..3688d302fd 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateChecker.kt @@ -47,6 +47,7 @@ class AppUpdateChecker { when (result) { is AppUpdateResult.NewUpdate -> AppUpdateNotifier(context).promptUpdate(result.release) is AppUpdateResult.NewUpdateFdroidInstallation -> AppUpdateNotifier(context).promptFdroidUpdate() + else -> {} } result @@ -56,7 +57,6 @@ class AppUpdateChecker { private fun isNewVersion(versionTag: String): Boolean { // Removes prefixes like "r" or "v" val newVersion = versionTag.replace("[^\\d.]".toRegex(), "") - val oldVersion = BuildConfig.VERSION_NAME.replace("[^\\d.]".toRegex(), "") return if (BuildConfig.PREVIEW) { // Preview builds: based on releases in "tachiyomiorg/tachiyomi-preview" repo @@ -65,6 +65,8 @@ class AppUpdateChecker { } else { // Release builds: based on releases in "tachiyomiorg/tachiyomi" repo // tagged as something like "v0.1.2" + val oldVersion = BuildConfig.VERSION_NAME.replace("[^\\d.]".toRegex(), "") + val newSemVer = newVersion.split(".").map { it.toInt() } val oldSemVer = oldVersion.split(".").map { it.toInt() } @@ -73,6 +75,7 @@ class AppUpdateChecker { return true } } + false } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateNotifier.kt b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateNotifier.kt index 8d13b89281..25b96cd022 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateNotifier.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/updater/AppUpdateNotifier.kt @@ -1,5 +1,6 @@ package eu.kanade.tachiyomi.data.updater +import android.annotation.SuppressLint import android.app.PendingIntent import android.content.Context import android.content.Intent @@ -26,12 +27,13 @@ internal class AppUpdateNotifier(private val context: Context) { context.notificationManager.notify(id, build()) } + @SuppressLint("LaunchActivityFromNotification") fun promptUpdate(release: GithubRelease) { val intent = Intent(context, AppUpdateService::class.java).apply { putExtra(AppUpdateService.EXTRA_DOWNLOAD_URL, release.getDownloadLink()) putExtra(AppUpdateService.EXTRA_DOWNLOAD_TITLE, release.version) } - val updateIntent = PendingIntent.getService(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT) + val updateIntent = PendingIntent.getService(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) val releaseIntent = Intent(Intent.ACTION_VIEW, release.releaseLink.toUri()).apply { flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TOP diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt index 5121f44cc0..27a06b4fec 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt @@ -17,13 +17,17 @@ class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bund private val sourceManager: SourceManager by injectLazy() private lateinit var libraryManga: Manga - private lateinit var newManga: Manga + private lateinit var onAddToLibrary: () -> Unit - constructor(target: T, libraryManga: Manga, newManga: Manga) : this() { + constructor( + target: T, + libraryManga: Manga, + onAddToLibrary: () -> Unit, + ) : this() { targetController = target this.libraryManga = libraryManga - this.newManga = newManga + this.onAddToLibrary = onAddToLibrary } override fun onCreateDialog(savedViewState: Bundle?): Dialog { @@ -32,7 +36,7 @@ class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bund return MaterialAlertDialogBuilder(activity!!) .setMessage(activity?.getString(R.string.confirm_manga_add_duplicate, source.name)) .setPositiveButton(activity?.getString(R.string.action_add)) { _, _ -> - (targetController as? Listener)?.addToLibrary(newManga) + onAddToLibrary() } .setNegativeButton(android.R.string.cancel, null) .setNeutralButton(activity?.getString(R.string.action_show_manga)) { _, _ -> diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt index e36f5a2031..cd9bb9ec59 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt @@ -521,7 +521,8 @@ class MangaController : } else { val duplicateManga = presenter.getDuplicateLibraryManga(manga) if (duplicateManga != null) { - AddDuplicateMangaDialog(this, duplicateManga, manga).showDialog(router) + AddDuplicateMangaDialog(this, duplicateManga) { addToLibrary(manga) } + .showDialog(router) } else { addToLibrary(manga) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/system/WebViewUtil.kt b/app/src/main/java/eu/kanade/tachiyomi/util/system/WebViewUtil.kt index af0b83041c..7cc8f3fba1 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/system/WebViewUtil.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/system/WebViewUtil.kt @@ -11,7 +11,7 @@ import logcat.LogPriority object WebViewUtil { const val SPOOF_PACKAGE_NAME = "org.chromium.chrome" - const val MINIMUM_WEBVIEW_VERSION = 98 + const val MINIMUM_WEBVIEW_VERSION = 99 fun supportsWebView(context: Context): Boolean { try { From cf024b0e61ab5f85bd1ebad735cfa4a434478df0 Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 17:46:59 -0400 Subject: [PATCH 06/80] Update to Coil 2.0.0 --- gradle/libs.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index bc14b87d9b..7e31dbe10b 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -2,7 +2,7 @@ aboutlib_version = "10.1.0" okhttp_version = "4.9.3" nucleus_version = "3.0.0" -coil_version = "2.0.0-rc03" +coil_version = "2.0.0" conductor_version = "3.1.2" flowbinding_version = "1.2.0" shizuku_version = "12.1.0" From 8bee5accb7f8e22c1589ad78cec8fdb7dca68737 Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 17:53:19 -0400 Subject: [PATCH 07/80] Update build workflow actions --- .github/workflows/build_pull_request.yml | 3 ++- .github/workflows/build_push.yml | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build_pull_request.yml b/.github/workflows/build_pull_request.yml index 06ca19e33f..50c6fc2cfe 100644 --- a/.github/workflows/build_pull_request.yml +++ b/.github/workflows/build_pull_request.yml @@ -24,9 +24,10 @@ jobs: uses: actions/dependency-review-action@v1 - name: Set up JDK 11 - uses: actions/setup-java@v1 + uses: actions/setup-java@v3 with: java-version: 11 + distribution: adopt - name: Copy CI gradle.properties run: | diff --git a/.github/workflows/build_push.yml b/.github/workflows/build_push.yml index ed28a7c0a0..ee2efbd963 100644 --- a/.github/workflows/build_push.yml +++ b/.github/workflows/build_push.yml @@ -25,9 +25,10 @@ jobs: uses: gradle/wrapper-validation-action@v1 - name: Set up JDK 11 - uses: actions/setup-java@v1 + uses: actions/setup-java@v3 with: java-version: 11 + distribution: adopt - name: Copy CI gradle.properties run: | From ae7df4fb7fa4fc996ba26a9f6dbbb6b5277a939b Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 17:54:52 -0400 Subject: [PATCH 08/80] Update linter --- .../eu/kanade/data/AndroidDatabaseHandler.kt | 12 ++++---- .../java/eu/kanade/data/DatabaseHandler.kt | 8 +++--- .../java/eu/kanade/data/TransactionContext.kt | 8 +++--- .../eu/kanade/data/history/HistoryMapper.kt | 4 +-- .../data/history/HistoryRepositoryImpl.kt | 4 +-- .../kanade/data/manga/MangaRepositoryImpl.kt | 2 +- .../eu/kanade/data/source/SourceMapper.kt | 2 +- .../data/source/SourceRepositoryImpl.kt | 2 +- .../eu/kanade/domain/chapter/model/Chapter.kt | 2 +- .../history/interactor/DeleteHistoryTable.kt | 2 +- .../domain/history/interactor/GetHistory.kt | 4 +-- .../interactor/GetNextChapterForManga.kt | 2 +- .../history/interactor/RemoveHistoryById.kt | 2 +- .../interactor/RemoveHistoryByMangaId.kt | 2 +- .../eu/kanade/domain/history/model/History.kt | 2 +- .../history/model/HistoryWithRelations.kt | 2 +- .../interactor/GetFavoritesBySourceId.kt | 2 +- .../eu/kanade/domain/manga/model/Manga.kt | 2 +- .../interactor/GetLanguagesWithSources.kt | 8 +++--- .../interactor/GetSourcesWithFavoriteCount.kt | 6 ++-- .../source/interactor/SetMigrateSorting.kt | 2 +- .../source/interactor/ToggleLanguage.kt | 2 +- .../domain/source/interactor/ToggleSource.kt | 2 +- .../source/interactor/ToggleSourcePin.kt | 2 +- .../eu/kanade/domain/source/model/Source.kt | 2 +- .../presentation/components/EmptyScreen.kt | 2 +- .../presentation/components/MangaCover.kt | 2 +- .../presentation/components/Preferences.kt | 4 +-- .../presentation/history/HistoryScreen.kt | 20 ++++++------- .../manga/components/BaseMangaListItem.kt | 6 ++-- .../eu/kanade/presentation/more/LogoHeader.kt | 2 +- .../presentation/source/MigrateMangaScreen.kt | 10 +++---- .../source/MigrateSourceScreen.kt | 6 ++-- .../presentation/source/SourceFilterScreen.kt | 16 +++++------ .../presentation/source/SourceScreen.kt | 28 +++++++++---------- .../source/components/BaseSourceItem.kt | 10 +++---- .../java/eu/kanade/tachiyomi/AppModule.kt | 8 +++--- .../tachiyomi/data/database/DbOpenCallback.kt | 2 +- .../manga/MigrationMangaController.kt | 2 +- .../manga/MigrationMangaPresenter.kt | 2 +- .../migration/search/SearchController.kt | 2 +- .../sources/MigrationSourcesController.kt | 10 ++++--- .../sources/MigrationSourcesPresenter.kt | 2 +- .../ui/browse/source/SourceFilterPresenter.kt | 4 +-- .../ui/browse/source/SourcePresenter.kt | 2 +- .../util/chapter/ChapterSourceSync.kt | 2 +- .../widget/TachiyomiBottomNavigationView.kt | 2 +- .../preference/ThemesPreferenceAdapter.kt | 2 +- gradle/libs.versions.toml | 2 +- 49 files changed, 119 insertions(+), 117 deletions(-) diff --git a/app/src/main/java/eu/kanade/data/AndroidDatabaseHandler.kt b/app/src/main/java/eu/kanade/data/AndroidDatabaseHandler.kt index bd4d99fde2..fe579888f0 100644 --- a/app/src/main/java/eu/kanade/data/AndroidDatabaseHandler.kt +++ b/app/src/main/java/eu/kanade/data/AndroidDatabaseHandler.kt @@ -19,7 +19,7 @@ class AndroidDatabaseHandler( val db: Database, private val driver: SqlDriver, val queryDispatcher: CoroutineDispatcher = Dispatchers.IO, - val transactionDispatcher: CoroutineDispatcher = queryDispatcher + val transactionDispatcher: CoroutineDispatcher = queryDispatcher, ) : DatabaseHandler { val suspendingTransactionId = ThreadLocal() @@ -30,21 +30,21 @@ class AndroidDatabaseHandler( override suspend fun awaitList( inTransaction: Boolean, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): List { return dispatch(inTransaction) { block(db).executeAsList() } } override suspend fun awaitOne( inTransaction: Boolean, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): T { return dispatch(inTransaction) { block(db).executeAsOne() } } override suspend fun awaitOneOrNull( inTransaction: Boolean, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): T? { return dispatch(inTransaction) { block(db).executeAsOneOrNull() } } @@ -64,7 +64,7 @@ class AndroidDatabaseHandler( override fun subscribeToPagingSource( countQuery: Database.() -> Query, transacter: Database.() -> Transacter, - queryProvider: Database.(Long, Long) -> Query + queryProvider: Database.(Long, Long) -> Query, ): PagingSource { return QueryPagingSource( countQuery = countQuery(db), @@ -72,7 +72,7 @@ class AndroidDatabaseHandler( dispatcher = queryDispatcher, queryProvider = { limit, offset -> queryProvider.invoke(db, limit, offset) - } + }, ) } diff --git a/app/src/main/java/eu/kanade/data/DatabaseHandler.kt b/app/src/main/java/eu/kanade/data/DatabaseHandler.kt index a528b7010e..c0cb676be1 100644 --- a/app/src/main/java/eu/kanade/data/DatabaseHandler.kt +++ b/app/src/main/java/eu/kanade/data/DatabaseHandler.kt @@ -12,17 +12,17 @@ interface DatabaseHandler { suspend fun awaitList( inTransaction: Boolean = false, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): List suspend fun awaitOne( inTransaction: Boolean = false, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): T suspend fun awaitOneOrNull( inTransaction: Boolean = false, - block: suspend Database.() -> Query + block: suspend Database.() -> Query, ): T? fun subscribeToList(block: Database.() -> Query): Flow> @@ -34,6 +34,6 @@ interface DatabaseHandler { fun subscribeToPagingSource( countQuery: Database.() -> Query, transacter: Database.() -> Transacter, - queryProvider: Database.(Long, Long) -> Query + queryProvider: Database.(Long, Long) -> Query, ): PagingSource } diff --git a/app/src/main/java/eu/kanade/data/TransactionContext.kt b/app/src/main/java/eu/kanade/data/TransactionContext.kt index 156b4cdbad..828a5fc178 100644 --- a/app/src/main/java/eu/kanade/data/TransactionContext.kt +++ b/app/src/main/java/eu/kanade/data/TransactionContext.kt @@ -95,7 +95,7 @@ private suspend fun AndroidDatabaseHandler.createTransactionContext(): Coroutine * thread by cancelling the job. */ private suspend fun CoroutineDispatcher.acquireTransactionThread( - controlJob: Job + controlJob: Job, ): ContinuationInterceptor { return suspendCancellableCoroutine { continuation -> continuation.invokeOnCancellation { @@ -116,8 +116,8 @@ private suspend fun CoroutineDispatcher.acquireTransactionThread( // Couldn't acquire a thread, cancel coroutine. continuation.cancel( IllegalStateException( - "Unable to acquire a thread to perform the database transaction.", ex - ) + "Unable to acquire a thread to perform the database transaction.", ex, + ), ) } } @@ -128,7 +128,7 @@ private suspend fun CoroutineDispatcher.acquireTransactionThread( */ private class TransactionElement( private val transactionThreadControlJob: Job, - val transactionDispatcher: ContinuationInterceptor + val transactionDispatcher: ContinuationInterceptor, ) : CoroutineContext.Element { companion object Key : CoroutineContext.Key diff --git a/app/src/main/java/eu/kanade/data/history/HistoryMapper.kt b/app/src/main/java/eu/kanade/data/history/HistoryMapper.kt index e7ebf5cb49..c4b7d4b312 100644 --- a/app/src/main/java/eu/kanade/data/history/HistoryMapper.kt +++ b/app/src/main/java/eu/kanade/data/history/HistoryMapper.kt @@ -13,7 +13,7 @@ val historyMapper: (Long, Long, Date?, Date?) -> History = { id, chapterId, read } val historyWithRelationsMapper: (Long, Long, Long, String, String?, Float, Date?) -> HistoryWithRelations = { - historyId, mangaId, chapterId, title, thumbnailUrl, chapterNumber, readAt -> + historyId, mangaId, chapterId, title, thumbnailUrl, chapterNumber, readAt -> HistoryWithRelations( id = historyId, chapterId = chapterId, @@ -21,6 +21,6 @@ val historyWithRelationsMapper: (Long, Long, Long, String, String?, Float, Date? title = title, thumbnailUrl = thumbnailUrl ?: "", chapterNumber = chapterNumber, - readAt = readAt + readAt = readAt, ) } diff --git a/app/src/main/java/eu/kanade/data/history/HistoryRepositoryImpl.kt b/app/src/main/java/eu/kanade/data/history/HistoryRepositoryImpl.kt index 15d2d26332..19aaa8f29b 100644 --- a/app/src/main/java/eu/kanade/data/history/HistoryRepositoryImpl.kt +++ b/app/src/main/java/eu/kanade/data/history/HistoryRepositoryImpl.kt @@ -11,7 +11,7 @@ import eu.kanade.domain.manga.model.Manga import eu.kanade.tachiyomi.util.system.logcat class HistoryRepositoryImpl( - private val handler: DatabaseHandler + private val handler: DatabaseHandler, ) : HistoryRepository { override fun getHistory(query: String): PagingSource { @@ -20,7 +20,7 @@ class HistoryRepositoryImpl( transacter = { historyViewQueries }, queryProvider = { limit, offset -> historyViewQueries.history(query, limit, offset, historyWithRelationsMapper) - } + }, ) } diff --git a/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt b/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt index 137d2ec0df..11c67db775 100644 --- a/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt +++ b/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt @@ -6,7 +6,7 @@ import eu.kanade.domain.manga.repository.MangaRepository import kotlinx.coroutines.flow.Flow class MangaRepositoryImpl( - private val databaseHandler: DatabaseHandler + private val databaseHandler: DatabaseHandler, ) : MangaRepository { override fun getFavoritesBySourceId(sourceId: Long): Flow> { diff --git a/app/src/main/java/eu/kanade/data/source/SourceMapper.kt b/app/src/main/java/eu/kanade/data/source/SourceMapper.kt index ed4fd7f50a..e03e1c854f 100644 --- a/app/src/main/java/eu/kanade/data/source/SourceMapper.kt +++ b/app/src/main/java/eu/kanade/data/source/SourceMapper.kt @@ -8,7 +8,7 @@ val sourceMapper: (eu.kanade.tachiyomi.source.Source) -> Source = { source -> source.id, source.lang, source.name, - false + false, ) } diff --git a/app/src/main/java/eu/kanade/data/source/SourceRepositoryImpl.kt b/app/src/main/java/eu/kanade/data/source/SourceRepositoryImpl.kt index 1dddc01e16..4db18e633e 100644 --- a/app/src/main/java/eu/kanade/data/source/SourceRepositoryImpl.kt +++ b/app/src/main/java/eu/kanade/data/source/SourceRepositoryImpl.kt @@ -10,7 +10,7 @@ import kotlinx.coroutines.flow.map class SourceRepositoryImpl( private val sourceManager: SourceManager, - private val handler: DatabaseHandler + private val handler: DatabaseHandler, ) : SourceRepository { override fun getSources(): Flow> { diff --git a/app/src/main/java/eu/kanade/domain/chapter/model/Chapter.kt b/app/src/main/java/eu/kanade/domain/chapter/model/Chapter.kt index 6eff7c580b..27ed9a46f9 100644 --- a/app/src/main/java/eu/kanade/domain/chapter/model/Chapter.kt +++ b/app/src/main/java/eu/kanade/domain/chapter/model/Chapter.kt @@ -12,5 +12,5 @@ data class Chapter( val name: String, val dateUpload: Long, val chapterNumber: Float, - val scanlator: String? + val scanlator: String?, ) diff --git a/app/src/main/java/eu/kanade/domain/history/interactor/DeleteHistoryTable.kt b/app/src/main/java/eu/kanade/domain/history/interactor/DeleteHistoryTable.kt index bebf1209d3..a8e10cbf51 100644 --- a/app/src/main/java/eu/kanade/domain/history/interactor/DeleteHistoryTable.kt +++ b/app/src/main/java/eu/kanade/domain/history/interactor/DeleteHistoryTable.kt @@ -3,7 +3,7 @@ package eu.kanade.domain.history.interactor import eu.kanade.domain.history.repository.HistoryRepository class DeleteHistoryTable( - private val repository: HistoryRepository + private val repository: HistoryRepository, ) { suspend fun await(): Boolean { diff --git a/app/src/main/java/eu/kanade/domain/history/interactor/GetHistory.kt b/app/src/main/java/eu/kanade/domain/history/interactor/GetHistory.kt index d2f8302b75..1db219ed37 100644 --- a/app/src/main/java/eu/kanade/domain/history/interactor/GetHistory.kt +++ b/app/src/main/java/eu/kanade/domain/history/interactor/GetHistory.kt @@ -8,12 +8,12 @@ import eu.kanade.domain.history.repository.HistoryRepository import kotlinx.coroutines.flow.Flow class GetHistory( - private val repository: HistoryRepository + private val repository: HistoryRepository, ) { fun subscribe(query: String): Flow> { return Pager( - PagingConfig(pageSize = 25) + PagingConfig(pageSize = 25), ) { repository.getHistory(query) }.flow diff --git a/app/src/main/java/eu/kanade/domain/history/interactor/GetNextChapterForManga.kt b/app/src/main/java/eu/kanade/domain/history/interactor/GetNextChapterForManga.kt index 477408ca3a..4ed35a347f 100644 --- a/app/src/main/java/eu/kanade/domain/history/interactor/GetNextChapterForManga.kt +++ b/app/src/main/java/eu/kanade/domain/history/interactor/GetNextChapterForManga.kt @@ -4,7 +4,7 @@ import eu.kanade.domain.chapter.model.Chapter import eu.kanade.domain.history.repository.HistoryRepository class GetNextChapterForManga( - private val repository: HistoryRepository + private val repository: HistoryRepository, ) { suspend fun await(mangaId: Long, chapterId: Long): Chapter? { diff --git a/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryById.kt b/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryById.kt index 93012c266b..4eb15568c5 100644 --- a/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryById.kt +++ b/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryById.kt @@ -4,7 +4,7 @@ import eu.kanade.domain.history.model.HistoryWithRelations import eu.kanade.domain.history.repository.HistoryRepository class RemoveHistoryById( - private val repository: HistoryRepository + private val repository: HistoryRepository, ) { suspend fun await(history: HistoryWithRelations) { diff --git a/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryByMangaId.kt b/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryByMangaId.kt index f32fa5f7b2..4c35584563 100644 --- a/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryByMangaId.kt +++ b/app/src/main/java/eu/kanade/domain/history/interactor/RemoveHistoryByMangaId.kt @@ -3,7 +3,7 @@ package eu.kanade.domain.history.interactor import eu.kanade.domain.history.repository.HistoryRepository class RemoveHistoryByMangaId( - private val repository: HistoryRepository + private val repository: HistoryRepository, ) { suspend fun await(mangaId: Long) { diff --git a/app/src/main/java/eu/kanade/domain/history/model/History.kt b/app/src/main/java/eu/kanade/domain/history/model/History.kt index 58c1c985e6..5c42c98525 100644 --- a/app/src/main/java/eu/kanade/domain/history/model/History.kt +++ b/app/src/main/java/eu/kanade/domain/history/model/History.kt @@ -5,5 +5,5 @@ import java.util.Date data class History( val id: Long?, val chapterId: Long, - val readAt: Date? + val readAt: Date?, ) diff --git a/app/src/main/java/eu/kanade/domain/history/model/HistoryWithRelations.kt b/app/src/main/java/eu/kanade/domain/history/model/HistoryWithRelations.kt index 6f5a8e1fc0..827cfda540 100644 --- a/app/src/main/java/eu/kanade/domain/history/model/HistoryWithRelations.kt +++ b/app/src/main/java/eu/kanade/domain/history/model/HistoryWithRelations.kt @@ -9,5 +9,5 @@ data class HistoryWithRelations( val title: String, val thumbnailUrl: String, val chapterNumber: Float, - val readAt: Date? + val readAt: Date?, ) diff --git a/app/src/main/java/eu/kanade/domain/manga/interactor/GetFavoritesBySourceId.kt b/app/src/main/java/eu/kanade/domain/manga/interactor/GetFavoritesBySourceId.kt index 9fd42effad..8489d4d57d 100644 --- a/app/src/main/java/eu/kanade/domain/manga/interactor/GetFavoritesBySourceId.kt +++ b/app/src/main/java/eu/kanade/domain/manga/interactor/GetFavoritesBySourceId.kt @@ -5,7 +5,7 @@ import eu.kanade.domain.manga.repository.MangaRepository import kotlinx.coroutines.flow.Flow class GetFavoritesBySourceId( - private val mangaRepository: MangaRepository + private val mangaRepository: MangaRepository, ) { fun subscribe(sourceId: Long): Flow> { diff --git a/app/src/main/java/eu/kanade/domain/manga/model/Manga.kt b/app/src/main/java/eu/kanade/domain/manga/model/Manga.kt index 9226c3f612..bed5f1d61b 100644 --- a/app/src/main/java/eu/kanade/domain/manga/model/Manga.kt +++ b/app/src/main/java/eu/kanade/domain/manga/model/Manga.kt @@ -17,7 +17,7 @@ data class Manga( val genre: List?, val status: Long, val thumbnailUrl: String?, - val initialized: Boolean + val initialized: Boolean, ) { val sorting: Long diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/GetLanguagesWithSources.kt b/app/src/main/java/eu/kanade/domain/source/interactor/GetLanguagesWithSources.kt index 1c157b5c11..3feef0a3a1 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/GetLanguagesWithSources.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/GetLanguagesWithSources.kt @@ -16,19 +16,19 @@ class GetLanguagesWithSources( return combine( preferences.enabledLanguages().asFlow(), preferences.disabledSources().asFlow(), - repository.getOnlineSources() + repository.getOnlineSources(), ) { enabledLanguage, disabledSource, onlineSources -> val sortedSources = onlineSources.sortedWith( compareBy { it.id.toString() in disabledSource } - .thenBy(String.CASE_INSENSITIVE_ORDER) { it.name } + .thenBy(String.CASE_INSENSITIVE_ORDER) { it.name }, ) sortedSources.groupBy { it.lang } .toSortedMap( compareBy( { it !in enabledLanguage }, - { LocaleHelper.getDisplayName(it) } - ) + { LocaleHelper.getDisplayName(it) }, + ), ) } } diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/GetSourcesWithFavoriteCount.kt b/app/src/main/java/eu/kanade/domain/source/interactor/GetSourcesWithFavoriteCount.kt index a290091f64..e88012cada 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/GetSourcesWithFavoriteCount.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/GetSourcesWithFavoriteCount.kt @@ -11,14 +11,14 @@ import java.util.Locale class GetSourcesWithFavoriteCount( private val repository: SourceRepository, - private val preferences: PreferencesHelper + private val preferences: PreferencesHelper, ) { fun subscribe(): Flow>> { return combine( preferences.migrationSortingDirection().asFlow(), preferences.migrationSortingMode().asFlow(), - repository.getSourcesWithFavoriteCount() + repository.getSourcesWithFavoriteCount(), ) { direction, mode, list -> list.sortedWith(sortFn(direction, mode)) } @@ -26,7 +26,7 @@ class GetSourcesWithFavoriteCount( private fun sortFn( direction: SetMigrateSorting.Direction, - sorting: SetMigrateSorting.Mode + sorting: SetMigrateSorting.Mode, ): java.util.Comparator> { val locale = Locale.getDefault() val collator = Collator.getInstance(locale).apply { diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/SetMigrateSorting.kt b/app/src/main/java/eu/kanade/domain/source/interactor/SetMigrateSorting.kt index 8728a9a54c..c93c56ee13 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/SetMigrateSorting.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/SetMigrateSorting.kt @@ -3,7 +3,7 @@ package eu.kanade.domain.source.interactor import eu.kanade.tachiyomi.data.preference.PreferencesHelper class SetMigrateSorting( - private val preferences: PreferencesHelper + private val preferences: PreferencesHelper, ) { fun await(mode: Mode, isAscending: Boolean) { diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleLanguage.kt b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleLanguage.kt index da373e829e..c05559837d 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleLanguage.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleLanguage.kt @@ -5,7 +5,7 @@ import eu.kanade.tachiyomi.util.preference.minusAssign import eu.kanade.tachiyomi.util.preference.plusAssign class ToggleLanguage( - val preferences: PreferencesHelper + val preferences: PreferencesHelper, ) { fun await(language: String) { diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSource.kt b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSource.kt index 8c9296d129..be1ec7a283 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSource.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSource.kt @@ -6,7 +6,7 @@ import eu.kanade.tachiyomi.util.preference.minusAssign import eu.kanade.tachiyomi.util.preference.plusAssign class ToggleSource( - private val preferences: PreferencesHelper + private val preferences: PreferencesHelper, ) { fun await(source: Source) { diff --git a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSourcePin.kt b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSourcePin.kt index 5a5e92df4a..d7229ab468 100644 --- a/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSourcePin.kt +++ b/app/src/main/java/eu/kanade/domain/source/interactor/ToggleSourcePin.kt @@ -6,7 +6,7 @@ import eu.kanade.tachiyomi.util.preference.minusAssign import eu.kanade.tachiyomi.util.preference.plusAssign class ToggleSourcePin( - private val preferences: PreferencesHelper + private val preferences: PreferencesHelper, ) { fun await(source: Source) { diff --git a/app/src/main/java/eu/kanade/domain/source/model/Source.kt b/app/src/main/java/eu/kanade/domain/source/model/Source.kt index 0f9d429ad3..00b494ba48 100644 --- a/app/src/main/java/eu/kanade/domain/source/model/Source.kt +++ b/app/src/main/java/eu/kanade/domain/source/model/Source.kt @@ -13,7 +13,7 @@ data class Source( val name: String, val supportsLatest: Boolean, val pin: Pins = Pins.unpinned, - val isUsedLast: Boolean = false + val isUsedLast: Boolean = false, ) { val nameWithLanguage: String diff --git a/app/src/main/java/eu/kanade/presentation/components/EmptyScreen.kt b/app/src/main/java/eu/kanade/presentation/components/EmptyScreen.kt index e94bef8275..f43d056e90 100644 --- a/app/src/main/java/eu/kanade/presentation/components/EmptyScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/components/EmptyScreen.kt @@ -29,7 +29,7 @@ fun EmptyScreen( ) { Box( modifier = Modifier - .fillMaxSize() + .fillMaxSize(), ) { AndroidView( factory = { context -> diff --git a/app/src/main/java/eu/kanade/presentation/components/MangaCover.kt b/app/src/main/java/eu/kanade/presentation/components/MangaCover.kt index c949dcf8b2..3b2504d99f 100644 --- a/app/src/main/java/eu/kanade/presentation/components/MangaCover.kt +++ b/app/src/main/java/eu/kanade/presentation/components/MangaCover.kt @@ -23,7 +23,7 @@ enum class MangaCover(private val ratio: Float) { modifier: Modifier = Modifier, data: String?, contentDescription: String? = null, - shape: Shape? = null + shape: Shape? = null, ) { AsyncImage( model = data, diff --git a/app/src/main/java/eu/kanade/presentation/components/Preferences.kt b/app/src/main/java/eu/kanade/presentation/components/Preferences.kt index d358f69cbb..a0b6d64271 100644 --- a/app/src/main/java/eu/kanade/presentation/components/Preferences.kt +++ b/app/src/main/java/eu/kanade/presentation/components/Preferences.kt @@ -56,7 +56,7 @@ fun PreferenceRow( onLongClick = onLongClick, onClick = onClick, ), - verticalAlignment = Alignment.CenterVertically + verticalAlignment = Alignment.CenterVertically, ) { if (painter != null) { Icon( @@ -71,7 +71,7 @@ fun PreferenceRow( Column( Modifier .padding(horizontal = horizontalPadding) - .weight(1f) + .weight(1f), ) { Text( text = title, diff --git a/app/src/main/java/eu/kanade/presentation/history/HistoryScreen.kt b/app/src/main/java/eu/kanade/presentation/history/HistoryScreen.kt index 429e4bbfad..6904cafa50 100644 --- a/app/src/main/java/eu/kanade/presentation/history/HistoryScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/history/HistoryScreen.kt @@ -88,7 +88,7 @@ fun HistoryContent( onClickResume: (HistoryWithRelations) -> Unit, onClickDelete: (HistoryWithRelations, Boolean) -> Unit, preferences: PreferencesHelper = Injekt.get(), - nestedScroll: NestedScrollConnection + nestedScroll: NestedScrollConnection, ) { if (history.loadState.refresh is LoadState.Loading) { LoadingScreen() @@ -118,7 +118,7 @@ fun HistoryContent( .animateItemPlacement(), date = item.date, relativeTime = relativeTime, - dateFormat = dateFormat + dateFormat = dateFormat, ) } is HistoryUiModel.Item -> { @@ -142,7 +142,7 @@ fun HistoryContent( onClickDelete(removeState, all) setRemoveState(null) }, - onNegative = { setRemoveState(null) } + onNegative = { setRemoveState(null) }, ) } } @@ -160,12 +160,12 @@ fun HistoryHeader( text = date.toRelativeString( LocalContext.current, relativeTime, - dateFormat + dateFormat, ), style = MaterialTheme.typography.bodyMedium.copy( color = MaterialTheme.colorScheme.onSurfaceVariant, fontWeight = FontWeight.SemiBold, - ) + ), ) } @@ -200,7 +200,7 @@ fun HistoryItem( text = history.title, maxLines = 2, overflow = TextOverflow.Ellipsis, - style = textStyle.copy(fontWeight = FontWeight.SemiBold) + style = textStyle.copy(fontWeight = FontWeight.SemiBold), ) Row { Text( @@ -232,7 +232,7 @@ fun HistoryItem( @Composable fun RemoveHistoryDialog( onPositive: (Boolean) -> Unit, - onNegative: () -> Unit + onNegative: () -> Unit, ) { val (removeEverything, removeEverythingState) = remember { mutableStateOf(false) } @@ -250,9 +250,9 @@ fun RemoveHistoryDialog( interactionSource = remember { MutableInteractionSource() }, indication = null, value = removeEverything, - onValueChange = removeEverythingState + onValueChange = removeEverythingState, ), - verticalAlignment = Alignment.CenterVertically + verticalAlignment = Alignment.CenterVertically, ) { Checkbox( checked = removeEverything, @@ -260,7 +260,7 @@ fun RemoveHistoryDialog( ) Text( modifier = Modifier.padding(start = 4.dp), - text = stringResource(id = R.string.dialog_with_checkbox_reset) + text = stringResource(id = R.string.dialog_with_checkbox_reset), ) } } diff --git a/app/src/main/java/eu/kanade/presentation/manga/components/BaseMangaListItem.kt b/app/src/main/java/eu/kanade/presentation/manga/components/BaseMangaListItem.kt index 1f00c52ba6..49795acaac 100644 --- a/app/src/main/java/eu/kanade/presentation/manga/components/BaseMangaListItem.kt +++ b/app/src/main/java/eu/kanade/presentation/manga/components/BaseMangaListItem.kt @@ -33,7 +33,7 @@ fun BaseMangaListItem( .clickable(onClick = onClickItem) .height(56.dp) .padding(horizontal = horizontalPadding), - verticalAlignment = Alignment.CenterVertically + verticalAlignment = Alignment.CenterVertically, ) { cover() content() @@ -47,7 +47,7 @@ private val defaultCover: @Composable RowScope.(Manga, () -> Unit) -> Unit = { m .padding(vertical = 8.dp) .clickable(onClick = onClick) .fillMaxHeight(), - data = manga.thumbnailUrl + data = manga.thumbnailUrl, ) } @@ -59,7 +59,7 @@ private val defaultContent: @Composable RowScope.(Manga) -> Unit = { .padding(start = horizontalPadding), overflow = TextOverflow.Ellipsis, maxLines = 1, - style = MaterialTheme.typography.bodyMedium + style = MaterialTheme.typography.bodyMedium, ) } } diff --git a/app/src/main/java/eu/kanade/presentation/more/LogoHeader.kt b/app/src/main/java/eu/kanade/presentation/more/LogoHeader.kt index 3506ed505f..b992633a34 100644 --- a/app/src/main/java/eu/kanade/presentation/more/LogoHeader.kt +++ b/app/src/main/java/eu/kanade/presentation/more/LogoHeader.kt @@ -18,7 +18,7 @@ import eu.kanade.tachiyomi.R fun LogoHeader() { Column { Surface( - modifier = Modifier.fillMaxWidth() + modifier = Modifier.fillMaxWidth(), ) { Icon( painter = painterResource(R.drawable.ic_tachi), diff --git a/app/src/main/java/eu/kanade/presentation/source/MigrateMangaScreen.kt b/app/src/main/java/eu/kanade/presentation/source/MigrateMangaScreen.kt index 2bb0526387..4f0bb18728 100644 --- a/app/src/main/java/eu/kanade/presentation/source/MigrateMangaScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/MigrateMangaScreen.kt @@ -25,7 +25,7 @@ fun MigrateMangaScreen( nestedScrollInterop: NestedScrollConnection, presenter: MigrationMangaPresenter, onClickItem: (Manga) -> Unit, - onClickCover: (Manga) -> Unit + onClickCover: (Manga) -> Unit, ) { val state by presenter.state.collectAsState() @@ -48,7 +48,7 @@ fun MigrateMangaContent( nestedScrollInterop: NestedScrollConnection, list: List, onClickItem: (Manga) -> Unit, - onClickCover: (Manga) -> Unit + onClickCover: (Manga) -> Unit, ) { if (list.isEmpty()) { EmptyScreen(textResource = R.string.migrate_empty_screen) @@ -62,7 +62,7 @@ fun MigrateMangaContent( MigrateMangaItem( manga = manga, onClickItem = onClickItem, - onClickCover = onClickCover + onClickCover = onClickCover, ) } } @@ -73,12 +73,12 @@ fun MigrateMangaItem( modifier: Modifier = Modifier, manga: Manga, onClickItem: (Manga) -> Unit, - onClickCover: (Manga) -> Unit + onClickCover: (Manga) -> Unit, ) { BaseMangaListItem( modifier = modifier, manga = manga, onClickItem = { onClickItem(manga) }, - onClickCover = { onClickCover(manga) } + onClickCover = { onClickCover(manga) }, ) } diff --git a/app/src/main/java/eu/kanade/presentation/source/MigrateSourceScreen.kt b/app/src/main/java/eu/kanade/presentation/source/MigrateSourceScreen.kt index 37acf32f06..5394200d32 100644 --- a/app/src/main/java/eu/kanade/presentation/source/MigrateSourceScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/MigrateSourceScreen.kt @@ -70,7 +70,7 @@ fun MigrateSourceList( modifier = Modifier .animateItemPlacement() .padding(horizontal = horizontalPadding, vertical = 8.dp), - style = MaterialTheme.typography.header + style = MaterialTheme.typography.header, ) } @@ -78,14 +78,14 @@ fun MigrateSourceList( items = list, key = { (source, _) -> source.id - } + }, ) { (source, count) -> MigrateSourceItem( modifier = Modifier.animateItemPlacement(), source = source, count = count, onClickItem = { onClickItem(source) }, - onLongClickItem = { onLongClickItem(source) } + onLongClickItem = { onLongClickItem(source) }, ) } } diff --git a/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt b/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt index 8e577af077..4bf8b99755 100644 --- a/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt @@ -31,7 +31,7 @@ fun SourceFilterScreen( nestedScrollInterop: NestedScrollConnection, presenter: SourceFilterPresenter, onClickLang: (String) -> Unit, - onClickSource: (Source) -> Unit + onClickSource: (Source) -> Unit, ) { val state by presenter.state.collectAsState() @@ -53,7 +53,7 @@ fun SourceFilterContent( nestedScrollInterop: NestedScrollConnection, items: List, onClickLang: (String) -> Unit, - onClickSource: (Source) -> Unit + onClickSource: (Source) -> Unit, ) { if (items.isEmpty()) { EmptyScreen(textResource = R.string.source_filter_empty_screen) @@ -76,7 +76,7 @@ fun SourceFilterContent( is FilterUiModel.Header -> it.hashCode() is FilterUiModel.Item -> it.source.key() } - } + }, ) { model -> when (model) { is FilterUiModel.Header -> { @@ -84,14 +84,14 @@ fun SourceFilterContent( modifier = Modifier.animateItemPlacement(), language = model.language, isEnabled = model.isEnabled, - onClickItem = onClickLang + onClickItem = onClickLang, ) } is FilterUiModel.Item -> SourceFilterItem( modifier = Modifier.animateItemPlacement(), source = model.source, isEnabled = model.isEnabled, - onClickItem = onClickSource + onClickItem = onClickSource, ) } } @@ -103,7 +103,7 @@ fun SourceFilterHeader( modifier: Modifier, language: String, isEnabled: Boolean, - onClickItem: (String) -> Unit + onClickItem: (String) -> Unit, ) { PreferenceRow( modifier = modifier, @@ -120,7 +120,7 @@ fun SourceFilterItem( modifier: Modifier, source: Source, isEnabled: Boolean, - onClickItem: (Source) -> Unit + onClickItem: (Source) -> Unit, ) { BaseSourceItem( modifier = modifier, @@ -129,6 +129,6 @@ fun SourceFilterItem( onClickItem = { onClickItem(source) }, action = { Checkbox(checked = isEnabled, onCheckedChange = null) - } + }, ) } diff --git a/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt b/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt index b2487936b9..0e34c9419b 100644 --- a/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt @@ -105,13 +105,13 @@ fun SourceList( is SourceUiModel.Header -> it.hashCode() is SourceUiModel.Item -> it.source.key() } - } + }, ) { model -> when (model) { is SourceUiModel.Header -> { SourceHeader( modifier = Modifier.animateItemPlacement(), - language = model.language + language = model.language, ) } is SourceUiModel.Item -> SourceItem( @@ -139,7 +139,7 @@ fun SourceList( onClickDisable(sourceState) setSourceState(null) }, - onDismiss = { setSourceState(null) } + onDismiss = { setSourceState(null) }, ) } } @@ -147,14 +147,14 @@ fun SourceList( @Composable fun SourceHeader( modifier: Modifier = Modifier, - language: String + language: String, ) { val context = LocalContext.current Text( text = LocaleHelper.getSourceDisplayName(language, context), modifier = modifier .padding(horizontal = horizontalPadding, vertical = 8.dp), - style = MaterialTheme.typography.header + style = MaterialTheme.typography.header, ) } @@ -165,7 +165,7 @@ fun SourceItem( onClickItem: (Source) -> Unit, onLongClickItem: (Source) -> Unit, onClickLatest: (Source) -> Unit, - onClickPin: (Source) -> Unit + onClickPin: (Source) -> Unit, ) { BaseSourceItem( modifier = modifier, @@ -178,14 +178,14 @@ fun SourceItem( Text( text = stringResource(id = R.string.latest), style = LocalTextStyle.current.copy( - color = MaterialTheme.colorScheme.primary - ) + color = MaterialTheme.colorScheme.primary, + ), ) } } SourcePinButton( isPinned = Pin.Pinned in source.pin, - onClick = { onClickPin(source) } + onClick = { onClickPin(source) }, ) }, ) @@ -193,7 +193,7 @@ fun SourceItem( @Composable fun SourceIcon( - source: Source + source: Source, ) { val icon = source.icon val modifier = Modifier @@ -217,7 +217,7 @@ fun SourceIcon( @Composable fun SourcePinButton( isPinned: Boolean, - onClick: () -> Unit + onClick: () -> Unit, ) { val icon = if (isPinned) Icons.Filled.PushPin else Icons.Outlined.PushPin val tint = if (isPinned) MaterialTheme.colorScheme.primary else MaterialTheme.colorScheme.onBackground @@ -225,7 +225,7 @@ fun SourcePinButton( Icon( imageVector = icon, contentDescription = "", - tint = tint + tint = tint, ) } } @@ -249,7 +249,7 @@ fun SourceOptionsDialog( modifier = Modifier .clickable(onClick = onClickPin) .fillMaxWidth() - .padding(vertical = 16.dp) + .padding(vertical = 16.dp), ) if (source.id != LocalSource.ID) { Text( @@ -257,7 +257,7 @@ fun SourceOptionsDialog( modifier = Modifier .clickable(onClick = onClickDisable) .fillMaxWidth() - .padding(vertical = 16.dp) + .padding(vertical = 16.dp), ) } } diff --git a/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt b/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt index 0e49eced84..4f35d7e4df 100644 --- a/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt +++ b/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt @@ -32,10 +32,10 @@ fun BaseSourceItem( modifier = modifier .combinedClickable( onClick = onClickItem, - onLongClick = onLongClickItem + onLongClick = onLongClickItem, ) .padding(horizontal = horizontalPadding, vertical = 8.dp), - verticalAlignment = Alignment.CenterVertically + verticalAlignment = Alignment.CenterVertically, ) { icon.invoke(this, source) content.invoke(this, source, showLanguageInContent) @@ -51,20 +51,20 @@ private val defaultContent: @Composable RowScope.(Source, Boolean) -> Unit = { s Column( modifier = Modifier .padding(horizontal = horizontalPadding) - .weight(1f) + .weight(1f), ) { Text( text = source.name, maxLines = 1, overflow = TextOverflow.Ellipsis, - style = MaterialTheme.typography.bodyMedium + style = MaterialTheme.typography.bodyMedium, ) if (showLanguageInContent) { Text( text = LocaleHelper.getDisplayName(source.lang), maxLines = 1, overflow = TextOverflow.Ellipsis, - style = MaterialTheme.typography.bodySmall + style = MaterialTheme.typography.bodySmall, ) } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/AppModule.kt b/app/src/main/java/eu/kanade/tachiyomi/AppModule.kt index a1291f94ce..e199f01b56 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/AppModule.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/AppModule.kt @@ -43,7 +43,7 @@ class AppModule(val app: Application) : InjektModule { .callback(DbOpenCallback()) .name(DbOpenCallback.DATABASE_NAME) .noBackupDirectory(false) - .build() + .build(), ) } @@ -56,11 +56,11 @@ class AppModule(val app: Application) : InjektModule { driver = get(), historyAdapter = History.Adapter( history_last_readAdapter = dateAdapter, - history_time_readAdapter = dateAdapter + history_time_readAdapter = dateAdapter, ), mangasAdapter = Mangas.Adapter( - genreAdapter = listOfStringsAdapter - ) + genreAdapter = listOfStringsAdapter, + ), ) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/database/DbOpenCallback.kt b/app/src/main/java/eu/kanade/tachiyomi/data/database/DbOpenCallback.kt index a27e4cbad8..d5cf594030 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/database/DbOpenCallback.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/database/DbOpenCallback.kt @@ -26,7 +26,7 @@ class DbOpenCallback : SupportSQLiteOpenHelper.Callback(Database.Schema.version) Database.Schema.migrate( driver = AndroidSqliteDriver(database = db, cacheSize = 1), oldVersion = oldVersion, - newVersion = newVersion + newVersion = newVersion, ) } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaController.kt index 5adece44bf..23509cb78a 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaController.kt @@ -42,7 +42,7 @@ class MigrationMangaController : ComposeController { }, onClickCover = { router.pushController(MangaController(it.id)) - } + }, ) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaPresenter.kt index 156bb5cd5f..9517924727 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/manga/MigrationMangaPresenter.kt @@ -15,7 +15,7 @@ import uy.kohesive.injekt.api.get class MigrationMangaPresenter( private val sourceId: Long, - private val getFavoritesBySourceId: GetFavoritesBySourceId = Injekt.get() + private val getFavoritesBySourceId: GetFavoritesBySourceId = Injekt.get(), ) : BasePresenter() { private val _state: MutableStateFlow = MutableStateFlow(MigrateMangaState.Loading) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/search/SearchController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/search/SearchController.kt index 4c4dfe3bd6..f84c91a5a6 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/search/SearchController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/search/SearchController.kt @@ -28,7 +28,7 @@ class SearchController( constructor(mangaId: Long) : this( Injekt.get() .getManga(mangaId) - .executeAsBlocking() + .executeAsBlocking(), ) private var newManga: Manga? = null diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt index 3b03e966d6..136e418acc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt @@ -30,8 +30,8 @@ class MigrationSourcesController : ComposeController( parentController!!.router.pushController( MigrationMangaController( source.id, - source.name - ) + source.name, + ), ) }, onLongClickItem = { source -> @@ -51,12 +51,14 @@ class MigrationSourcesController : ComposeController( true } R.id.asc_alphabetical, - R.id.desc_alphabetical -> { + R.id.desc_alphabetical, +-> { presenter.setAlphabeticalSorting(itemId == R.id.asc_alphabetical) true } R.id.asc_count, - R.id.desc_count -> { + R.id.desc_count, +-> { presenter.setTotalSorting(itemId == R.id.asc_count) true } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesPresenter.kt index 019d318170..904ade7498 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesPresenter.kt @@ -16,7 +16,7 @@ import uy.kohesive.injekt.api.get class MigrationSourcesPresenter( private val getSourcesWithFavoriteCount: GetSourcesWithFavoriteCount = Injekt.get(), - private val setMigrateSorting: SetMigrateSorting = Injekt.get() + private val setMigrateSorting: SetMigrateSorting = Injekt.get(), ) : BasePresenter() { private val _state: MutableStateFlow = MutableStateFlow(MigrateSourceState.Loading) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt index d57048c6d7..dfe1b26f47 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt @@ -20,7 +20,7 @@ class SourceFilterPresenter( private val getLanguagesWithSources: GetLanguagesWithSources = Injekt.get(), private val toggleSource: ToggleSource = Injekt.get(), private val toggleLanguage: ToggleLanguage = Injekt.get(), - private val preferences: PreferencesHelper = Injekt.get() + private val preferences: PreferencesHelper = Injekt.get(), ) : BasePresenter() { private val _state: MutableStateFlow = MutableStateFlow(SourceFilterState.Loading) @@ -49,7 +49,7 @@ class SourceFilterPresenter( header + it.value.map { source -> FilterUiModel.Item( source, - source.id.toString() !in preferences.disabledSources().get() + source.id.toString() !in preferences.disabledSources().get(), ) } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourcePresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourcePresenter.kt index 3f30be1f9a..9de170ebf5 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourcePresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourcePresenter.kt @@ -25,7 +25,7 @@ import java.util.TreeMap class SourcePresenter( private val getEnabledSources: GetEnabledSources = Injekt.get(), private val toggleSource: ToggleSource = Injekt.get(), - private val toggleSourcePin: ToggleSourcePin = Injekt.get() + private val toggleSourcePin: ToggleSourcePin = Injekt.get(), ) : BasePresenter() { private val _state: MutableStateFlow = MutableStateFlow(SourceState.Loading) diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/chapter/ChapterSourceSync.kt b/app/src/main/java/eu/kanade/tachiyomi/util/chapter/ChapterSourceSync.kt index 162b919e44..4aee9e2467 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/chapter/ChapterSourceSync.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/chapter/ChapterSourceSync.kt @@ -25,7 +25,7 @@ fun syncChaptersWithSource( db: DatabaseHelper, rawSourceChapters: List, manga: Manga, - source: Source + source: Source, ): Pair, List> { if (rawSourceChapters.isEmpty()) { throw NoChaptersException() diff --git a/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt b/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt index dae4a0084c..e3209c3842 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt @@ -91,7 +91,7 @@ class TachiyomiBottomNavigationView @JvmOverloads constructor( currentAnimator = null postInvalidate() } - }) + },) } internal class SavedState : AbsSavedState { diff --git a/app/src/main/java/eu/kanade/tachiyomi/widget/preference/ThemesPreferenceAdapter.kt b/app/src/main/java/eu/kanade/tachiyomi/widget/preference/ThemesPreferenceAdapter.kt index 38e71410f7..4c5bd324d7 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/widget/preference/ThemesPreferenceAdapter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/widget/preference/ThemesPreferenceAdapter.kt @@ -25,7 +25,7 @@ class ThemesPreferenceAdapter(private val clickListener: OnItemClickListener) : override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ThemeViewHolder { val themeResIds = ThemingDelegate.getThemeResIds(themes[viewType], preferences.themeDarkAmoled().get()) val themedContext = themeResIds.fold(parent.context) { - context, themeResId -> + context, themeResId -> ContextThemeWrapper(context, themeResId) } diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 7e31dbe10b..fb2c05b571 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -111,5 +111,5 @@ conductor = ["conductor-core","conductor-viewpager","conductor-support-preferenc shizuku = ["shizuku-api","shizuku-provider"] [plugins] -kotlinter = { id = "org.jmailen.kotlinter", version = "3.6.0"} +kotlinter = { id = "org.jmailen.kotlinter", version = "3.10.0"} versionsx = { id = "com.github.ben-manes.versions", version = "0.42.0"} \ No newline at end of file From cd8392bae20c88daf59759020c588aadecd72ff2 Mon Sep 17 00:00:00 2001 From: arkon Date: Tue, 10 May 2022 17:55:07 -0400 Subject: [PATCH 09/80] Minor dependency updates --- gradle/androidx.versions.toml | 2 +- gradle/compose.versions.toml | 2 +- gradle/libs.versions.toml | 6 +++--- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/gradle/androidx.versions.toml b/gradle/androidx.versions.toml index 6c49236bbe..c741b576cd 100644 --- a/gradle/androidx.versions.toml +++ b/gradle/androidx.versions.toml @@ -8,7 +8,7 @@ appcompat = "androidx.appcompat:appcompat:1.4.1" biometricktx = "androidx.biometric:biometric-ktx:1.2.0-alpha04" constraintlayout = "androidx.constraintlayout:constraintlayout:2.1.3" coordinatorlayout = "androidx.coordinatorlayout:coordinatorlayout:1.2.0" -corektx = "androidx.core:core-ktx:1.8.0-alpha07" +corektx = "androidx.core:core-ktx:1.8.0-beta01" splashscreen = "androidx.core:core-splashscreen:1.0.0-alpha02" recyclerview = "androidx.recyclerview:recyclerview:1.3.0-alpha02" swiperefreshlayout = "androidx.swiperefreshlayout:swiperefreshlayout:1.2.0-alpha01" diff --git a/gradle/compose.versions.toml b/gradle/compose.versions.toml index 90cf39aff4..a12284da5d 100644 --- a/gradle/compose.versions.toml +++ b/gradle/compose.versions.toml @@ -9,7 +9,7 @@ animation = { module = "androidx.compose.animation:animation", version.ref="comp ui-tooling = { module = "androidx.compose.ui:ui-tooling", version.ref="compose" } material3-core = "androidx.compose.material3:material3:1.0.0-alpha10" -material3-adapter = "com.google.android.material:compose-theme-adapter-3:1.0.7" +material3-adapter = "com.google.android.material:compose-theme-adapter-3:1.0.8" material-icons = { module = "androidx.compose.material:material-icons-extended", version.ref="compose" } accompanist-webview = { module = "com.google.accompanist:accompanist-webview", version.ref="accompanist" } \ No newline at end of file diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index fb2c05b571..3ba5133c42 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -23,7 +23,7 @@ flowreactivenetwork = "ru.beryukhov:flowreactivenetwork:1.0.4" okhttp-core = { module = "com.squareup.okhttp3:okhttp", version.ref = "okhttp_version" } okhttp-logging = { module = "com.squareup.okhttp3:logging-interceptor", version.ref = "okhttp_version" } okhttp-dnsoverhttps = { module = "com.squareup.okhttp3:okhttp-dnsoverhttps", version.ref = "okhttp_version" } -okio = "com.squareup.okio:okio:3.0.0" +okio = "com.squareup.okio:okio:3.1.0" conscrypt-android = "org.conscrypt:conscrypt-android:2.5.2" @@ -35,7 +35,7 @@ jsoup = "org.jsoup:jsoup:1.14.3" disklrucache = "com.jakewharton:disklrucache:2.0.2" unifile = "com.github.tachiyomiorg:unifile:17bec43" -junrar = "com.github.junrar:junrar:7.5.0" +junrar = "com.github.junrar:junrar:7.5.1" sqlitektx = "androidx.sqlite:sqlite-ktx:2.3.0-alpha02" sqlite-android = "com.github.requery:sqlite-android:3.36.0" @@ -81,7 +81,7 @@ flowbinding-viewpager = { module = "io.github.reactivecircus.flowbinding:flowbin logcat = "com.squareup.logcat:logcat:0.1" acra-http = "ch.acra:acra-http:5.9.1" -firebase-analytics = "com.google.firebase:firebase-analytics-ktx:20.0.2" +firebase-analytics = "com.google.firebase:firebase-analytics-ktx:21.0.0" aboutLibraries-gradle = { module = "com.mikepenz.aboutlibraries.plugin:aboutlibraries-plugin", version.ref = "aboutlib_version" } aboutLibraries-compose = { module = "com.mikepenz:aboutlibraries-compose", version.ref ="aboutlib_version" } From 598e4516b3b1a3273a8009da527f8c40f52729a2 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 11 May 2022 17:59:47 -0400 Subject: [PATCH 10/80] [skip ci] Configure Renovate (#7105) * Add renovate.json * Update renovate.json * Update renovate.json * Update renovate.json Co-authored-by: Renovate Bot Co-authored-by: arkon --- renovate.json | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 renovate.json diff --git a/renovate.json b/renovate.json new file mode 100644 index 0000000000..8fe4caa0ba --- /dev/null +++ b/renovate.json @@ -0,0 +1,12 @@ +{ + "extends": [ + "config:base" + ], + "schedule": ["every sunday"], + "ignoreDeps": [ + "androidx.core:core-splashscreen", + "androidx.work:work-runtime-ktx", + "info.android15.nucleus:nucleus-support-v7", + "info.android15.nucleus:nucleus" + ] +} From b950370f12680e4113c1f736e656181fdf306579 Mon Sep 17 00:00:00 2001 From: arkon Date: Wed, 11 May 2022 18:08:49 -0400 Subject: [PATCH 11/80] Address some build warnings --- .../java/eu/kanade/presentation/source/SourceFilterScreen.kt | 2 +- .../tachiyomi/extension/util/ExtensionInstallReceiver.kt | 5 +++-- .../browse/migration/sources/MigrationSourcesController.kt | 4 ++-- .../ui/browse/source/browse/BrowseSourceController.kt | 1 + .../eu/kanade/tachiyomi/ui/library/LibrarySettingsSheet.kt | 2 ++ .../tachiyomi/ui/manga/chapter/ChaptersSettingsSheet.kt | 1 + .../kanade/tachiyomi/ui/reader/viewer/ReaderPageImageView.kt | 1 + .../kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt | 3 ++- 8 files changed, 13 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt b/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt index 4bf8b99755..09c196f97f 100644 --- a/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/SourceFilterScreen.kt @@ -37,7 +37,7 @@ fun SourceFilterScreen( when (state) { is SourceFilterState.Loading -> LoadingScreen() - is SourceFilterState.Error -> Text(text = (state as SourceFilterState.Error).error!!.message!!) + is SourceFilterState.Error -> Text(text = (state as SourceFilterState.Error).error.message!!) is SourceFilterState.Success -> SourceFilterContent( nestedScrollInterop = nestedScrollInterop, diff --git a/app/src/main/java/eu/kanade/tachiyomi/extension/util/ExtensionInstallReceiver.kt b/app/src/main/java/eu/kanade/tachiyomi/extension/util/ExtensionInstallReceiver.kt index cdef6e4368..2cbc71cbd6 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/extension/util/ExtensionInstallReceiver.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/extension/util/ExtensionInstallReceiver.kt @@ -52,6 +52,7 @@ internal class ExtensionInstallReceiver(private val listener: Listener) : when (val result = getExtensionFromIntent(context, intent)) { is LoadResult.Success -> listener.onExtensionInstalled(result.extension) is LoadResult.Untrusted -> listener.onExtensionUntrusted(result.extension) + else -> {} } } } @@ -60,8 +61,8 @@ internal class ExtensionInstallReceiver(private val listener: Listener) : when (val result = getExtensionFromIntent(context, intent)) { is LoadResult.Success -> listener.onExtensionUpdated(result.extension) // Not needed as a package can't be upgraded if the signature is different - is LoadResult.Untrusted -> { - } + // is LoadResult.Untrusted -> {} + else -> {} } } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt index 136e418acc..c400c09263 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/migration/sources/MigrationSourcesController.kt @@ -52,13 +52,13 @@ class MigrationSourcesController : ComposeController( } R.id.asc_alphabetical, R.id.desc_alphabetical, --> { + -> { presenter.setAlphabeticalSorting(itemId == R.id.asc_alphabetical) true } R.id.asc_count, R.id.desc_count, --> { + -> { presenter.setTotalSorting(itemId == R.id.asc_count) true } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt index 67d76ac94e..00ac8da409 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt @@ -358,6 +358,7 @@ open class BrowseSourceController(bundle: Bundle) : when (filter) { is Filter.TriState -> filter.state = 1 is Filter.CheckBox -> filter.state = true + else -> {} } filterList = presenter.sourceFilters break@filter diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibrarySettingsSheet.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibrarySettingsSheet.kt index bd9ed749b4..427c9bcc56 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibrarySettingsSheet.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibrarySettingsSheet.kt @@ -394,6 +394,7 @@ class LibrarySettingsSheet( unreadBadge -> preferences.unreadBadge().set((item.checked)) localBadge -> preferences.localBadge().set((item.checked)) languageBadge -> preferences.languageBadge().set((item.checked)) + else -> {} } adapter.notifyItemChanged(item) } @@ -418,6 +419,7 @@ class LibrarySettingsSheet( when (item) { showTabs -> preferences.categoryTabs().set(item.checked) showNumberOfItems -> preferences.categoryNumberOfItems().set(item.checked) + else -> {} } adapter.notifyItemChanged(item) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChaptersSettingsSheet.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChaptersSettingsSheet.kt index b63d0db3cb..9c04ba10d1 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChaptersSettingsSheet.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChaptersSettingsSheet.kt @@ -113,6 +113,7 @@ class ChaptersSettingsSheet( downloaded -> presenter.setDownloadedFilter(newState) unread -> presenter.setUnreadFilter(newState) bookmarked -> presenter.setBookmarkedFilter(newState) + else -> {} } initModels() diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/viewer/ReaderPageImageView.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/viewer/ReaderPageImageView.kt index be427bab36..336cd57ae3 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/viewer/ReaderPageImageView.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/viewer/ReaderPageImageView.kt @@ -249,6 +249,7 @@ open class ReaderPageImageView @JvmOverloads constructor( ZoomStartPosition.LEFT -> setScaleAndCenter(scale, PointF(0F, 0F)) ZoomStartPosition.RIGHT -> setScaleAndCenter(scale, PointF(sWidth.toFloat(), 0F)) ZoomStartPosition.CENTER -> setScaleAndCenter(scale, center.also { it?.y = 0F }) + null -> {} } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt b/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt index e3209c3842..6ed163a2c2 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/widget/TachiyomiBottomNavigationView.kt @@ -91,7 +91,8 @@ class TachiyomiBottomNavigationView @JvmOverloads constructor( currentAnimator = null postInvalidate() } - },) + }, + ) } internal class SavedState : AbsSavedState { From 37199a10bf13ef838bfa839da384969101a32f40 Mon Sep 17 00:00:00 2001 From: arkon Date: Wed, 11 May 2022 18:09:13 -0400 Subject: [PATCH 12/80] Bump dependencies --- .../main/java/eu/kanade/tachiyomi/ui/main/MainActivity.kt | 1 + gradle/androidx.versions.toml | 6 +++--- gradle/libs.versions.toml | 2 +- 3 files changed, 5 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/main/MainActivity.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/main/MainActivity.kt index b1092ff0d6..01287ed958 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/main/MainActivity.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/main/MainActivity.kt @@ -189,6 +189,7 @@ class MainActivity : BaseActivity() { val container: ViewGroup = binding.controllerContainer router = Conductor.attachRouter(this, container, savedInstanceState) + .setPopRootControllerMode(Router.PopRootControllerMode.NEVER) router.addChangeListener( object : ControllerChangeHandler.ControllerChangeListener { override fun onChangeStarted( diff --git a/gradle/androidx.versions.toml b/gradle/androidx.versions.toml index c741b576cd..d88718cfbb 100644 --- a/gradle/androidx.versions.toml +++ b/gradle/androidx.versions.toml @@ -1,6 +1,6 @@ [versions] -agp_version = "7.1.3" -lifecycle_version = "2.5.0-alpha06" +agp_version = "7.2.0" +lifecycle_version = "2.5.0-rc01" [libraries] annotation = "androidx.annotation:annotation:1.4.0-alpha02" @@ -8,7 +8,7 @@ appcompat = "androidx.appcompat:appcompat:1.4.1" biometricktx = "androidx.biometric:biometric-ktx:1.2.0-alpha04" constraintlayout = "androidx.constraintlayout:constraintlayout:2.1.3" coordinatorlayout = "androidx.coordinatorlayout:coordinatorlayout:1.2.0" -corektx = "androidx.core:core-ktx:1.8.0-beta01" +corektx = "androidx.core:core-ktx:1.8.0-rc01" splashscreen = "androidx.core:core-splashscreen:1.0.0-alpha02" recyclerview = "androidx.recyclerview:recyclerview:1.3.0-alpha02" swiperefreshlayout = "androidx.swiperefreshlayout:swiperefreshlayout:1.2.0-alpha01" diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 3ba5133c42..b462a73808 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -3,7 +3,7 @@ aboutlib_version = "10.1.0" okhttp_version = "4.9.3" nucleus_version = "3.0.0" coil_version = "2.0.0" -conductor_version = "3.1.2" +conductor_version = "3.1.4" flowbinding_version = "1.2.0" shizuku_version = "12.1.0" sqldelight = "1.5.3" From c7707dc50edb817652d4e850f4f0806ab05307df Mon Sep 17 00:00:00 2001 From: arkon Date: Wed, 11 May 2022 22:17:12 -0400 Subject: [PATCH 13/80] Minor cleanup --- renovate.json => .github/renovate.json | 3 ++- .../tachiyomi/ui/manga/AddDuplicateMangaDialog.kt | 9 ++------- .../eu/kanade/tachiyomi/ui/manga/MangaController.kt | 3 +-- .../eu/kanade/tachiyomi/util/system/ImageUtil.kt | 12 ++++++++---- gradle/libs.versions.toml | 2 +- 5 files changed, 14 insertions(+), 15 deletions(-) rename renovate.json => .github/renovate.json (76%) diff --git a/renovate.json b/.github/renovate.json similarity index 76% rename from renovate.json rename to .github/renovate.json index 8fe4caa0ba..a1eec22be2 100644 --- a/renovate.json +++ b/.github/renovate.json @@ -7,6 +7,7 @@ "androidx.core:core-splashscreen", "androidx.work:work-runtime-ktx", "info.android15.nucleus:nucleus-support-v7", - "info.android15.nucleus:nucleus" + "info.android15.nucleus:nucleus", + "com.google.guava:guava" ] } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt index 27a06b4fec..58fbe282cc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/AddDuplicateMangaDialog.kt @@ -11,8 +11,7 @@ import eu.kanade.tachiyomi.ui.base.controller.DialogController import eu.kanade.tachiyomi.ui.base.controller.pushController import uy.kohesive.injekt.injectLazy -class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bundle) - where T : Controller, T : AddDuplicateMangaDialog.Listener { +class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bundle) { private val sourceManager: SourceManager by injectLazy() @@ -20,7 +19,7 @@ class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bund private lateinit var onAddToLibrary: () -> Unit constructor( - target: T, + target: Controller, libraryManga: Manga, onAddToLibrary: () -> Unit, ) : this() { @@ -46,8 +45,4 @@ class AddDuplicateMangaDialog(bundle: Bundle? = null) : DialogController(bund .setCancelable(true) .create() } - - interface Listener { - fun addToLibrary(newManga: Manga) - } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt index cd9bb9ec59..961356cabb 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaController.kt @@ -113,7 +113,6 @@ class MangaController : FlexibleAdapter.OnItemClickListener, FlexibleAdapter.OnItemLongClickListener, BaseChaptersAdapter.OnChapterClickListener, - AddDuplicateMangaDialog.Listener, ChangeMangaCoverDialog.Listener, ChangeMangaCategoriesDialog.Listener, DownloadCustomChaptersDialog.Listener, @@ -533,7 +532,7 @@ class MangaController : trackSheet?.show() } - override fun addToLibrary(newManga: Manga) { + private fun addToLibrary(newManga: Manga) { val categories = presenter.getCategories() val defaultCategoryId = preferences.defaultCategory() val defaultCategory = categories.find { it.id == defaultCategoryId } diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt index 2a4978aeed..c3d91e25fc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt @@ -11,6 +11,7 @@ import android.graphics.drawable.ColorDrawable import android.graphics.drawable.Drawable import android.graphics.drawable.GradientDrawable import android.os.Build +import androidx.annotation.ColorInt import androidx.core.graphics.alpha import androidx.core.graphics.applyCanvas import androidx.core.graphics.blue @@ -446,19 +447,22 @@ object ImageUtil { ) } - private fun Int.isDark(): Boolean = + private fun @receiver:ColorInt Int.isDark(): Boolean = red < 40 && blue < 40 && green < 40 && alpha > 200 - private fun Int.isCloseTo(other: Int): Boolean = + private fun @receiver:ColorInt Int.isCloseTo(other: Int): Boolean = abs(red - other.red) < 30 && abs(green - other.green) < 30 && abs(blue - other.blue) < 30 - private fun Int.isWhite(): Boolean = + private fun @receiver:ColorInt Int.isWhite(): Boolean = red + blue + green > 740 /** * Used to check an image's dimensions without loading it in the memory. */ - private fun extractImageOptions(imageStream: InputStream, resetAfterExtraction: Boolean = true): BitmapFactory.Options { + private fun extractImageOptions( + imageStream: InputStream, + resetAfterExtraction: Boolean = true, + ): BitmapFactory.Options { imageStream.mark(imageStream.available() + 1) val imageBytes = imageStream.readBytes() diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index b462a73808..cb3fd794d9 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -80,7 +80,7 @@ flowbinding-viewpager = { module = "io.github.reactivecircus.flowbinding:flowbin logcat = "com.squareup.logcat:logcat:0.1" -acra-http = "ch.acra:acra-http:5.9.1" +acra-http = "ch.acra:acra-http:5.9.3" firebase-analytics = "com.google.firebase:firebase-analytics-ktx:21.0.0" aboutLibraries-gradle = { module = "com.mikepenz.aboutlibraries.plugin:aboutlibraries-plugin", version.ref = "aboutlib_version" } From 393fc146303c3dc6185842e4158c3bd3f006017b Mon Sep 17 00:00:00 2001 From: arkon Date: Wed, 11 May 2022 22:29:28 -0400 Subject: [PATCH 14/80] Update Compose Fixes #7004 --- .../presentation/components/Preferences.kt | 16 ++++++++-------- .../ui/base/controller/ComposeController.kt | 6 +++--- gradle/compose.versions.toml | 8 ++++---- gradle/kotlinx.versions.toml | 5 ++--- 4 files changed, 17 insertions(+), 18 deletions(-) diff --git a/app/src/main/java/eu/kanade/presentation/components/Preferences.kt b/app/src/main/java/eu/kanade/presentation/components/Preferences.kt index a0b6d64271..d50796d2cf 100644 --- a/app/src/main/java/eu/kanade/presentation/components/Preferences.kt +++ b/app/src/main/java/eu/kanade/presentation/components/Preferences.kt @@ -62,7 +62,7 @@ fun PreferenceRow( Icon( painter = painter, modifier = Modifier - .padding(horizontal = horizontalPadding) + .padding(start = horizontalPadding, end = 16.dp) .size(24.dp), tint = MaterialTheme.colorScheme.primary, contentDescription = null, @@ -70,7 +70,7 @@ fun PreferenceRow( } Column( Modifier - .padding(horizontal = horizontalPadding) + .padding(horizontal = 16.dp) .weight(1f), ) { Text( @@ -86,7 +86,11 @@ fun PreferenceRow( } } if (action != null) { - Box(Modifier.widthIn(min = 56.dp)) { + Box( + Modifier + .widthIn(min = 56.dp) + .padding(end = horizontalPadding), + ) { action() } } @@ -106,11 +110,7 @@ fun SwitchPreference( title = title, subtitle = subtitle, painter = painter, - action = { - Switch(checked = preference.value, onCheckedChange = null) - // TODO: remove this once switch checked state is fixed: https://issuetracker.google.com/issues/228336571 - Text(preference.value.toString()) - }, + action = { Switch(checked = preference.value, onCheckedChange = null) }, onClick = { preference.value = !preference.value }, ) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/ComposeController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/ComposeController.kt index 44f32c2446..431b906ae4 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/ComposeController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/base/controller/ComposeController.kt @@ -30,7 +30,7 @@ abstract class ComposeController

>(bundle: Bundle? = null) : consumeWindowInsets = false setViewCompositionStrategy(ViewCompositionStrategy.DisposeOnViewTreeLifecycleDestroyed) setContent { - val nestedScrollInterop = rememberNestedScrollInteropConnection(binding.root) + val nestedScrollInterop = rememberNestedScrollInteropConnection() TachiyomiTheme { ComposeContent(nestedScrollInterop) } @@ -56,7 +56,7 @@ abstract class BasicComposeController : consumeWindowInsets = false setViewCompositionStrategy(ViewCompositionStrategy.DisposeOnViewTreeLifecycleDestroyed) setContent { - val nestedScrollInterop = rememberNestedScrollInteropConnection(binding.root) + val nestedScrollInterop = rememberNestedScrollInteropConnection() TachiyomiTheme { ComposeContent(nestedScrollInterop) } @@ -79,7 +79,7 @@ abstract class SearchableComposeController

>(bundle: Bundle? consumeWindowInsets = false setViewCompositionStrategy(ViewCompositionStrategy.DisposeOnViewTreeLifecycleDestroyed) setContent { - val nestedScrollInterop = rememberNestedScrollInteropConnection(binding.root) + val nestedScrollInterop = rememberNestedScrollInteropConnection() TachiyomiTheme { ComposeContent(nestedScrollInterop) } diff --git a/gradle/compose.versions.toml b/gradle/compose.versions.toml index a12284da5d..e97b9dacbe 100644 --- a/gradle/compose.versions.toml +++ b/gradle/compose.versions.toml @@ -1,6 +1,6 @@ [versions] -compose = "1.2.0-alpha08" -accompanist = "0.24.7-alpha" +compose = "1.2.0-beta01" +accompanist = "0.24.8-beta" [libraries] activity = "androidx.activity:activity-compose:1.6.0-alpha03" @@ -8,8 +8,8 @@ foundation = { module = "androidx.compose.foundation:foundation", version.ref="c animation = { module = "androidx.compose.animation:animation", version.ref="compose" } ui-tooling = { module = "androidx.compose.ui:ui-tooling", version.ref="compose" } -material3-core = "androidx.compose.material3:material3:1.0.0-alpha10" -material3-adapter = "com.google.android.material:compose-theme-adapter-3:1.0.8" +material3-core = "androidx.compose.material3:material3:1.0.0-alpha11" +material3-adapter = "com.google.android.material:compose-theme-adapter-3:1.0.9" material-icons = { module = "androidx.compose.material:material-icons-extended", version.ref="compose" } accompanist-webview = { module = "com.google.accompanist:accompanist-webview", version.ref="accompanist" } \ No newline at end of file diff --git a/gradle/kotlinx.versions.toml b/gradle/kotlinx.versions.toml index 268e66b5f4..52397ac608 100644 --- a/gradle/kotlinx.versions.toml +++ b/gradle/kotlinx.versions.toml @@ -1,5 +1,5 @@ [versions] -kotlin_version = "1.6.20" +kotlin_version = "1.6.21" coroutines_version = "1.6.1" serialization_version = "1.3.2" @@ -16,8 +16,7 @@ serialization-gradle = { module = "org.jetbrains.kotlin:kotlin-serialization", v [bundles] coroutines = ["coroutines-core", "coroutines-android"] -serialization = ["serialization-json","serialization-protobuf"] +serialization = ["serialization-json", "serialization-protobuf"] [plugins] - android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin_version"} \ No newline at end of file From b26daf8824e09922f063db6d6410b78d6281957b Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Thu, 12 May 2022 10:35:30 +0800 Subject: [PATCH 15/80] Fix "Move to top" showing at the most top item in download queue (#7109) --- .../main/java/eu/kanade/tachiyomi/ui/download/DownloadHolder.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/download/DownloadHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/download/DownloadHolder.kt index 8f46231438..514357d658 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/download/DownloadHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/download/DownloadHolder.kt @@ -89,7 +89,7 @@ class DownloadHolder(private val view: View, val adapter: DownloadAdapter) : view.popupMenu( menuRes = R.menu.download_single, initMenu = { - findItem(R.id.move_to_top).isVisible = bindingAdapterPosition != 0 + findItem(R.id.move_to_top).isVisible = bindingAdapterPosition > 1 findItem(R.id.move_to_bottom).isVisible = bindingAdapterPosition != adapter.itemCount - 1 }, From f75d63274089c5a0cfe0e1afde8703017b521870 Mon Sep 17 00:00:00 2001 From: S97 <39028181+saud-97@users.noreply.github.com> Date: Thu, 12 May 2022 05:36:16 +0300 Subject: [PATCH 16/80] Fixed splitting logic and CBZ compression logic (#7098) * Fixes: - spliiting fails when the page was already been split and processed before - Moved CBZ logic a little earlier to avoid marking a download as complete before the CBZ compression was completed * Added a single space for readablity * Added 2 spaces for readability * Moved the splitting logic to happen inside getOrDownloadImage() * Minor cleanup * - Improved error handling when splitting fails due to OOM exception caused by BitmapFactory.decodeFile. - Changed logic from throwing error to only notify to allow the download to complete even if splitting failed. * reverted auto formatting changes * removed an extra loop * Merged to Upstream, cleaned up * Removed unused localized string * Minor cleanup --- .../tachiyomi/data/download/Downloader.kt | 26 +++++++++---------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt index 7e62a35a16..fc18b9f27a 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt @@ -274,7 +274,7 @@ class Downloader( // Start downloader if needed if (autoStart && wasEmpty) { - val queuedDownloads = queue.filter { it.source !is UnmeteredSource }.count() + val queuedDownloads = queue.count { it.source !is UnmeteredSource } val maxDownloadsFromSource = queue .groupBy { it.source } .filterKeys { it !is UnmeteredSource } @@ -345,10 +345,7 @@ class Downloader( .flatMap({ page -> getOrDownloadImage(page, download, tmpDir) }, 5) .onBackpressureLatest() // Do when page is downloaded. - .doOnNext { page -> - splitTallImageIfNeeded(page, tmpDir) - notifier.onProgressChange(download) - } + .doOnNext { notifier.onProgressChange(download) } .toList() .map { download } // Do after download completes @@ -393,8 +390,9 @@ class Downloader( } return pageObservable - // When the image is ready, set image path, progress (just in case) and status + // When the page is ready, set page path, progress (just in case) and status .doOnNext { file -> + splitTallImageIfNeeded(page, tmpDir) page.uri = file.uri page.progress = 100 download.downloadedImages++ @@ -483,11 +481,13 @@ class Downloader( if (!preferences.splitTallImages().get()) return val filename = String.format("%03d", page.number) - val imageFile = tmpDir.listFiles()?.find { it.name!!.startsWith("$filename.") } + val imageFile = tmpDir.listFiles()?.find { it.name!!.startsWith(filename) } ?: throw Error(context.getString(R.string.download_notifier_split_page_not_found, page.number)) val imageFilePath = imageFile.filePath ?: throw Error(context.getString(R.string.download_notifier_split_page_path_not_found, page.number)) + // check if the original page was previously splitted before then skip. + if (imageFile.name!!.contains("__")) return ImageUtil.splitTallImage(imageFile, imageFilePath) } @@ -509,13 +509,7 @@ class Downloader( val downloadedImages = tmpDir.listFiles().orEmpty().filterNot { it.name!!.endsWith(".tmp") || (it.name!!.contains("__") && !it.name!!.contains("__001.jpg")) } download.status = if (downloadedImages.size == download.pages!!.size) { - Download.State.DOWNLOADED - } else { - Download.State.ERROR - } - - // Only rename the directory if it's downloaded. - if (download.status == Download.State.DOWNLOADED) { + // Only rename the directory if it's downloaded. if (preferences.saveChaptersAsCBZ().get()) { archiveChapter(mangaDir, dirname, tmpDir) } else { @@ -524,6 +518,10 @@ class Downloader( cache.addChapter(dirname, mangaDir, download.manga) DiskUtil.createNoMediaFile(tmpDir, context) + + Download.State.DOWNLOADED + } else { + Download.State.ERROR } } From f1afeac0bcd3904c323e24d67dd945c85c666f92 Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Thu, 12 May 2022 20:58:37 +0800 Subject: [PATCH 17/80] Detect identical mangas when long pressing to add to library (#7095) * Detect identical mangas when long pressing to add to library * Use extracted duplicate manga dialog to avoid duplication * Partially revert previous commit * Review changes * Review changes part 2 --- .../source/browse/BrowseSourceController.kt | 78 +++++++++++-------- .../source/browse/BrowseSourcePresenter.kt | 4 + 2 files changed, 49 insertions(+), 33 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt index 00ac8da409..cac78a0a44 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourceController.kt @@ -38,6 +38,7 @@ import eu.kanade.tachiyomi.ui.browse.source.globalsearch.GlobalSearchController import eu.kanade.tachiyomi.ui.library.ChangeMangaCategoriesDialog import eu.kanade.tachiyomi.ui.library.setting.DisplayModeSetting import eu.kanade.tachiyomi.ui.main.MainActivity +import eu.kanade.tachiyomi.ui.manga.AddDuplicateMangaDialog import eu.kanade.tachiyomi.ui.manga.MangaController import eu.kanade.tachiyomi.ui.more.MoreController import eu.kanade.tachiyomi.ui.webview.WebViewActivity @@ -591,6 +592,7 @@ open class BrowseSourceController(bundle: Bundle) : override fun onItemLongClick(position: Int) { val activity = activity ?: return val manga = (adapter?.getItem(position) as? SourceItem?)?.manga ?: return + val duplicateManga = presenter.getDuplicateLibraryManga(manga) if (manga.favorite) { MaterialAlertDialogBuilder(activity) @@ -606,43 +608,53 @@ open class BrowseSourceController(bundle: Bundle) : } .show() } else { - val categories = presenter.getCategories() - val defaultCategoryId = preferences.defaultCategory() - val defaultCategory = categories.find { it.id == defaultCategoryId } - - when { - // Default category set - defaultCategory != null -> { - presenter.moveMangaToCategory(manga, defaultCategory) - - presenter.changeMangaFavorite(manga) - adapter?.notifyItemChanged(position) - activity.toast(activity.getString(R.string.manga_added_library)) - } + if (duplicateManga != null) { + AddDuplicateMangaDialog(this, duplicateManga) { addToLibrary(manga, position) } + .showDialog(router) + } else { + addToLibrary(manga, position) + } + } + } - // Automatic 'Default' or no categories - defaultCategoryId == 0 || categories.isEmpty() -> { - presenter.moveMangaToCategory(manga, null) + private fun addToLibrary(newManga: Manga, position: Int) { + val activity = activity ?: return + val categories = presenter.getCategories() + val defaultCategoryId = preferences.defaultCategory() + val defaultCategory = categories.find { it.id == defaultCategoryId } + + when { + // Default category set + defaultCategory != null -> { + presenter.moveMangaToCategory(newManga, defaultCategory) + + presenter.changeMangaFavorite(newManga) + adapter?.notifyItemChanged(position) + activity.toast(activity.getString(R.string.manga_added_library)) + } - presenter.changeMangaFavorite(manga) - adapter?.notifyItemChanged(position) - activity.toast(activity.getString(R.string.manga_added_library)) - } + // Automatic 'Default' or no categories + defaultCategoryId == 0 || categories.isEmpty() -> { + presenter.moveMangaToCategory(newManga, null) - // Choose a category - else -> { - val ids = presenter.getMangaCategoryIds(manga) - val preselected = categories.map { - if (it.id in ids) { - QuadStateTextView.State.CHECKED.ordinal - } else { - QuadStateTextView.State.UNCHECKED.ordinal - } - }.toTypedArray() + presenter.changeMangaFavorite(newManga) + adapter?.notifyItemChanged(position) + activity.toast(activity.getString(R.string.manga_added_library)) + } - ChangeMangaCategoriesDialog(this, listOf(manga), categories, preselected) - .showDialog(router) - } + // Choose a category + else -> { + val ids = presenter.getMangaCategoryIds(newManga) + val preselected = categories.map { + if (it.id in ids) { + QuadStateTextView.State.CHECKED.ordinal + } else { + QuadStateTextView.State.UNCHECKED.ordinal + } + }.toTypedArray() + + ChangeMangaCategoriesDialog(this, listOf(newManga), categories, preselected) + .showDialog(router) } } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourcePresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourcePresenter.kt index 1bae71a314..afcb0c60ef 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourcePresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/BrowseSourcePresenter.kt @@ -351,6 +351,10 @@ open class BrowseSourcePresenter( return db.getCategories().executeAsBlocking() } + fun getDuplicateLibraryManga(manga: Manga): Manga? { + return db.getDuplicateLibraryManga(manga).executeAsBlocking() + } + /** * Gets the category id's the manga is in, if the manga is not in a category, returns the default id. * From 08fb2fe467a786e1273bf22531361d33ae898a38 Mon Sep 17 00:00:00 2001 From: FourTOne5 <59261191+FourTOne5@users.noreply.github.com> Date: Thu, 12 May 2022 19:00:57 +0600 Subject: [PATCH 18/80] Add option to reset viewer flags (#7062) * Add option to reset viewer flags * Review Changes * Run `resetViewerFlags()` content with `launchIO` --- .../kanade/data/manga/MangaRepositoryImpl.kt | 12 +++++ .../java/eu/kanade/domain/DomainModule.kt | 2 + .../manga/interactor/ResetViewerFlags.kt | 11 +++++ .../manga/repository/MangaRepository.kt | 2 + .../ui/setting/SettingsAdvancedController.kt | 49 ++++++++++++++----- app/src/main/res/values/strings.xml | 4 ++ app/src/main/sqldelight/data/mangas.sq | 6 ++- 7 files changed, 74 insertions(+), 12 deletions(-) create mode 100644 app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt diff --git a/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt b/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt index 11c67db775..70ff72e294 100644 --- a/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt +++ b/app/src/main/java/eu/kanade/data/manga/MangaRepositoryImpl.kt @@ -3,7 +3,9 @@ package eu.kanade.data.manga import eu.kanade.data.DatabaseHandler import eu.kanade.domain.manga.model.Manga import eu.kanade.domain.manga.repository.MangaRepository +import eu.kanade.tachiyomi.util.system.logcat import kotlinx.coroutines.flow.Flow +import logcat.LogPriority class MangaRepositoryImpl( private val databaseHandler: DatabaseHandler, @@ -12,4 +14,14 @@ class MangaRepositoryImpl( override fun getFavoritesBySourceId(sourceId: Long): Flow> { return databaseHandler.subscribeToList { mangasQueries.getFavoriteBySourceId(sourceId, mangaMapper) } } + + override suspend fun resetViewerFlags(): Boolean { + return try { + databaseHandler.await { mangasQueries.resetViewerFlags() } + true + } catch (e: Exception) { + logcat(LogPriority.ERROR, e) + false + } + } } diff --git a/app/src/main/java/eu/kanade/domain/DomainModule.kt b/app/src/main/java/eu/kanade/domain/DomainModule.kt index ee5668767d..7e9cd3de1a 100644 --- a/app/src/main/java/eu/kanade/domain/DomainModule.kt +++ b/app/src/main/java/eu/kanade/domain/DomainModule.kt @@ -10,6 +10,7 @@ import eu.kanade.domain.history.interactor.RemoveHistoryById import eu.kanade.domain.history.interactor.RemoveHistoryByMangaId import eu.kanade.domain.history.repository.HistoryRepository import eu.kanade.domain.manga.interactor.GetFavoritesBySourceId +import eu.kanade.domain.manga.interactor.ResetViewerFlags import eu.kanade.domain.manga.repository.MangaRepository import eu.kanade.domain.source.interactor.GetEnabledSources import eu.kanade.domain.source.interactor.GetLanguagesWithSources @@ -31,6 +32,7 @@ class DomainModule : InjektModule { addSingletonFactory { MangaRepositoryImpl(get()) } addFactory { GetFavoritesBySourceId(get()) } addFactory { GetNextChapterForManga(get()) } + addFactory { ResetViewerFlags(get()) } addSingletonFactory { HistoryRepositoryImpl(get()) } addFactory { DeleteHistoryTable(get()) } diff --git a/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt b/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt new file mode 100644 index 0000000000..cc07264e34 --- /dev/null +++ b/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt @@ -0,0 +1,11 @@ +package eu.kanade.domain.manga.interactor + +import eu.kanade.domain.manga.repository.MangaRepository + +class ResetViewerFlags( + private val mangaRepository: MangaRepository +) { + suspend fun await(): Boolean { + return mangaRepository.resetViewerFlags() + } +} diff --git a/app/src/main/java/eu/kanade/domain/manga/repository/MangaRepository.kt b/app/src/main/java/eu/kanade/domain/manga/repository/MangaRepository.kt index 8fb60a78a1..0dcf680822 100644 --- a/app/src/main/java/eu/kanade/domain/manga/repository/MangaRepository.kt +++ b/app/src/main/java/eu/kanade/domain/manga/repository/MangaRepository.kt @@ -6,4 +6,6 @@ import kotlinx.coroutines.flow.Flow interface MangaRepository { fun getFavoritesBySourceId(sourceId: Long): Flow> + + suspend fun resetViewerFlags(): Boolean } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt index e0557e2d38..3e35c5c413 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt @@ -9,9 +9,9 @@ import android.webkit.WebView import androidx.core.net.toUri import androidx.preference.PreferenceScreen import com.google.android.material.dialog.MaterialAlertDialogBuilder +import eu.kanade.domain.manga.repository.MangaRepository import eu.kanade.tachiyomi.R import eu.kanade.tachiyomi.data.cache.ChapterCache -import eu.kanade.tachiyomi.data.database.DatabaseHelper import eu.kanade.tachiyomi.data.library.LibraryUpdateService import eu.kanade.tachiyomi.data.library.LibraryUpdateService.Target import eu.kanade.tachiyomi.data.preference.PreferenceValues @@ -25,6 +25,7 @@ import eu.kanade.tachiyomi.ui.base.controller.pushController import eu.kanade.tachiyomi.ui.setting.database.ClearDatabaseController import eu.kanade.tachiyomi.util.CrashLogUtil import eu.kanade.tachiyomi.util.lang.launchIO +import eu.kanade.tachiyomi.util.lang.withIOContext import eu.kanade.tachiyomi.util.lang.withUIContext import eu.kanade.tachiyomi.util.preference.bindTo import eu.kanade.tachiyomi.util.preference.defaultValue @@ -45,17 +46,21 @@ import eu.kanade.tachiyomi.util.system.logcat import eu.kanade.tachiyomi.util.system.powerManager import eu.kanade.tachiyomi.util.system.setDefaultSettings import eu.kanade.tachiyomi.util.system.toast +import kotlinx.coroutines.runBlocking import logcat.LogPriority import rikka.sui.Sui +import uy.kohesive.injekt.Injekt +import uy.kohesive.injekt.api.get import uy.kohesive.injekt.injectLazy import java.io.File import eu.kanade.tachiyomi.data.preference.PreferenceKeys as Keys -class SettingsAdvancedController : SettingsController() { +class SettingsAdvancedController( + private val mangaRepository: MangaRepository = Injekt.get() +) : SettingsController() { private val network: NetworkHelper by injectLazy() private val chapterCache: ChapterCache by injectLazy() - private val db: DatabaseHelper by injectLazy() @SuppressLint("BatteryLife") override fun setupPreferenceScreen(screen: PreferenceScreen) = screen.apply { @@ -216,6 +221,13 @@ class SettingsAdvancedController : SettingsController() { onClick { LibraryUpdateService.start(context, target = Target.TRACKING) } } + preference { + key = "pref_reset_viewer_flags" + titleRes = R.string.pref_reset_viewer_flags + summaryRes = R.string.pref_reset_viewer_flags_summary + + onClick { resetViewerFlags() } + } } preferenceCategory { @@ -276,37 +288,52 @@ class SettingsAdvancedController : SettingsController() { } private fun clearChapterCache() { - if (activity == null) return + val activity = activity ?: return launchIO { try { val deletedFiles = chapterCache.clear() withUIContext { - activity?.toast(resources?.getString(R.string.cache_deleted, deletedFiles)) + activity.toast(resources?.getString(R.string.cache_deleted, deletedFiles)) findPreference(CLEAR_CACHE_KEY)?.summary = resources?.getString(R.string.used_cache, chapterCache.readableSize) } } catch (e: Throwable) { logcat(LogPriority.ERROR, e) - withUIContext { activity?.toast(R.string.cache_delete_error) } + withUIContext { activity.toast(R.string.cache_delete_error) } } } } private fun clearWebViewData() { - if (activity == null) return + val activity = activity ?: return try { - val webview = WebView(activity!!) + val webview = WebView(activity) webview.setDefaultSettings() webview.clearCache(true) webview.clearFormData() webview.clearHistory() webview.clearSslPreferences() WebStorage.getInstance().deleteAllData() - activity?.applicationInfo?.dataDir?.let { File("$it/app_webview/").deleteRecursively() } - activity?.toast(R.string.webview_data_deleted) + activity.applicationInfo?.dataDir?.let { File("$it/app_webview/").deleteRecursively() } + activity.toast(R.string.webview_data_deleted) } catch (e: Throwable) { logcat(LogPriority.ERROR, e) - activity?.toast(R.string.cache_delete_error) + activity.toast(R.string.cache_delete_error) + } + } + + private fun resetViewerFlags() { + val activity = activity ?: return + launchIO { + val isSuccesful = mangaRepository.resetViewerFlags() + withUIContext { + val resouurceString = if (isSuccesful) { + R.string.pref_reset_viewer_flags_succesful + } else { + R.string.pref_reset_viewer_flags_unsuccesful + } + activity.toast(resouurceString) + } } } } diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 5a1d4b42db..cb3e79ed55 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -486,6 +486,10 @@ Refresh library manga covers Refresh tracking Updates status, score and last chapter read from the tracking services + Reset Viewer Flags + Resets reading mode and orientation of all series + Viewer flags reset was succesful + Couldn\'t reset viewer flags Dump crash logs Saves error logs to a file for sharing with the developers Crash logs saved diff --git a/app/src/main/sqldelight/data/mangas.sq b/app/src/main/sqldelight/data/mangas.sq index e46bb4c5e0..a1b61f4228 100644 --- a/app/src/main/sqldelight/data/mangas.sq +++ b/app/src/main/sqldelight/data/mangas.sq @@ -42,4 +42,8 @@ getFavoriteBySourceId: SELECT * FROM mangas WHERE favorite = 1 -AND source = :sourceId; \ No newline at end of file +AND source = :sourceId; + +resetViewerFlags: +UPDATE mangas +SET viewer = 0; \ No newline at end of file From 5dc688dc2e581ff0098f9012a3922de2ef85d2f3 Mon Sep 17 00:00:00 2001 From: arkon Date: Thu, 12 May 2022 09:04:02 -0400 Subject: [PATCH 19/80] Update reset viewer flags strings --- .../domain/manga/interactor/ResetViewerFlags.kt | 2 +- .../ui/setting/SettingsAdvancedController.kt | 14 ++++++-------- app/src/main/res/values/strings.xml | 6 +++--- 3 files changed, 10 insertions(+), 12 deletions(-) diff --git a/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt b/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt index cc07264e34..13b766af12 100644 --- a/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt +++ b/app/src/main/java/eu/kanade/domain/manga/interactor/ResetViewerFlags.kt @@ -3,7 +3,7 @@ package eu.kanade.domain.manga.interactor import eu.kanade.domain.manga.repository.MangaRepository class ResetViewerFlags( - private val mangaRepository: MangaRepository + private val mangaRepository: MangaRepository, ) { suspend fun await(): Boolean { return mangaRepository.resetViewerFlags() diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt index 3e35c5c413..f8f9e4424d 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt @@ -25,7 +25,6 @@ import eu.kanade.tachiyomi.ui.base.controller.pushController import eu.kanade.tachiyomi.ui.setting.database.ClearDatabaseController import eu.kanade.tachiyomi.util.CrashLogUtil import eu.kanade.tachiyomi.util.lang.launchIO -import eu.kanade.tachiyomi.util.lang.withIOContext import eu.kanade.tachiyomi.util.lang.withUIContext import eu.kanade.tachiyomi.util.preference.bindTo import eu.kanade.tachiyomi.util.preference.defaultValue @@ -46,7 +45,6 @@ import eu.kanade.tachiyomi.util.system.logcat import eu.kanade.tachiyomi.util.system.powerManager import eu.kanade.tachiyomi.util.system.setDefaultSettings import eu.kanade.tachiyomi.util.system.toast -import kotlinx.coroutines.runBlocking import logcat.LogPriority import rikka.sui.Sui import uy.kohesive.injekt.Injekt @@ -56,7 +54,7 @@ import java.io.File import eu.kanade.tachiyomi.data.preference.PreferenceKeys as Keys class SettingsAdvancedController( - private val mangaRepository: MangaRepository = Injekt.get() + private val mangaRepository: MangaRepository = Injekt.get(), ) : SettingsController() { private val network: NetworkHelper by injectLazy() @@ -325,14 +323,14 @@ class SettingsAdvancedController( private fun resetViewerFlags() { val activity = activity ?: return launchIO { - val isSuccesful = mangaRepository.resetViewerFlags() + val success = mangaRepository.resetViewerFlags() withUIContext { - val resouurceString = if (isSuccesful) { - R.string.pref_reset_viewer_flags_succesful + val message = if (success) { + R.string.pref_reset_viewer_flags_success } else { - R.string.pref_reset_viewer_flags_unsuccesful + R.string.pref_reset_viewer_flags_error } - activity.toast(resouurceString) + activity.toast(message) } } } diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index cb3e79ed55..0c1bbed882 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -486,10 +486,10 @@ Refresh library manga covers Refresh tracking Updates status, score and last chapter read from the tracking services - Reset Viewer Flags + Reset viewer flags Resets reading mode and orientation of all series - Viewer flags reset was succesful - Couldn\'t reset viewer flags + Viewer flags reset + Couldn\'t reset viewer flags Dump crash logs Saves error logs to a file for sharing with the developers Crash logs saved From 63627c81ebd6b3a9b1ee017f385a72b6fc8c8a49 Mon Sep 17 00:00:00 2001 From: nzoba <55888232+nzoba@users.noreply.github.com> Date: Sat, 14 May 2022 03:42:23 +0200 Subject: [PATCH 20/80] Add switch to DownloadPageLoader when chapter is downloaded (#7119) --- .../eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt index 8debf6f3ca..3d79e877dc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt @@ -22,6 +22,7 @@ import eu.kanade.tachiyomi.source.SourceManager import eu.kanade.tachiyomi.source.model.Page import eu.kanade.tachiyomi.ui.base.presenter.BasePresenter import eu.kanade.tachiyomi.ui.reader.loader.ChapterLoader +import eu.kanade.tachiyomi.ui.reader.loader.HttpPageLoader import eu.kanade.tachiyomi.ui.reader.model.InsertPage import eu.kanade.tachiyomi.ui.reader.model.ReaderChapter import eu.kanade.tachiyomi.ui.reader.model.ReaderPage @@ -345,6 +346,14 @@ class ReaderPresenter( * that the user doesn't have to wait too long to continue reading. */ private fun preload(chapter: ReaderChapter) { + if (chapter.pageLoader is HttpPageLoader) { + val manga = manga ?: return + val isDownloaded = downloadManager.isChapterDownloaded(chapter.chapter, manga) + if (isDownloaded) { + chapter.state = ReaderChapter.State.Wait + } + } + if (chapter.state != ReaderChapter.State.Wait && chapter.state !is ReaderChapter.State.Error) { return } From 6d655ff7574c0c51c41cfc6b3abed57fb2115acc Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Sat, 14 May 2022 20:09:15 +0800 Subject: [PATCH 21/80] Fix category tabs incorrect scroll position (#7120) --- .../eu/kanade/tachiyomi/ui/library/LibraryController.kt | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryController.kt index cd70881dce..902f7b5cb4 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryController.kt @@ -8,7 +8,6 @@ import android.view.MenuInflater import android.view.MenuItem import android.view.View import androidx.appcompat.view.ActionMode -import androidx.core.view.doOnAttach import androidx.core.view.isVisible import com.bluelinelabs.conductor.ControllerChangeHandler import com.bluelinelabs.conductor.ControllerChangeType @@ -302,8 +301,10 @@ class LibraryController( onTabsSettingsChanged(firstLaunch = true) // Delay the scroll position to allow the view to be properly measured. - view.doOnAttach { - (activity as? MainActivity)?.binding?.tabs?.setScrollPosition(binding.libraryPager.currentItem, 0f, true) + view.post { + if (isAttached) { + (activity as? MainActivity)?.binding?.tabs?.setScrollPosition(binding.libraryPager.currentItem, 0f, true) + } } // Send the manga map to child fragments after the adapter is updated. From f1ab34e27cbd8f26f87e34238af0863d4650b960 Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Sat, 14 May 2022 20:51:04 +0800 Subject: [PATCH 22/80] Save reader progress when activity is paused (#7121) --- .../java/eu/kanade/tachiyomi/ui/reader/ReaderActivity.kt | 5 +++++ .../java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt | 4 ++++ 2 files changed, 9 insertions(+) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderActivity.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderActivity.kt index 9053864d8c..157ee3c96c 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderActivity.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderActivity.kt @@ -231,6 +231,11 @@ class ReaderActivity : BaseRxActivity() { super.onSaveInstanceState(outState) } + override fun onPause() { + presenter.saveProgress() + super.onPause() + } + /** * Set menu visibility again on activity resume to apply immersive mode again if needed. * Helps with rotations. diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt index 3d79e877dc..2d9c1c67f2 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/ReaderPresenter.kt @@ -465,6 +465,10 @@ class ReaderPresenter( } } + fun saveProgress() { + getCurrentChapter()?.let { onChapterChanged(it) } + } + /** * Called from the activity to preload the given [chapter]. */ From 6d011ebe32561214001089794ff70bb0be9dde66 Mon Sep 17 00:00:00 2001 From: Andreas Date: Sat, 14 May 2022 16:04:43 +0200 Subject: [PATCH 23/80] Update AndroidX SQLite (#7123) --- app/build.gradle.kts | 2 +- gradle/androidx.versions.toml | 2 ++ gradle/libs.versions.toml | 1 - 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/app/build.gradle.kts b/app/build.gradle.kts index f5809ba5f9..6de1454ffb 100644 --- a/app/build.gradle.kts +++ b/app/build.gradle.kts @@ -152,7 +152,7 @@ dependencies { implementation(androidx.paging.runtime) implementation(androidx.paging.compose) - implementation(libs.sqldelight.sqlite) + implementation(androidx.sqlite) implementation(libs.sqldelight.android.driver) implementation(libs.sqldelight.coroutines) implementation(libs.sqldelight.android.paging) diff --git a/gradle/androidx.versions.toml b/gradle/androidx.versions.toml index d88718cfbb..c973777671 100644 --- a/gradle/androidx.versions.toml +++ b/gradle/androidx.versions.toml @@ -24,6 +24,8 @@ guava = "com.google.guava:guava:31.1-android" paging-runtime = "androidx.paging:paging-runtime:3.1.1" paging-compose = "androidx.paging:paging-compose:1.0.0-alpha14" +sqlite = "androidx.sqlite:sqlite-framework:2.2.0" + [bundles] lifecycle = ["lifecycle-common", "lifecycle-process", "lifecycle-runtimektx"] workmanager = ["work-runtime", "guava"] diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index cb3fd794d9..c6b36ae5bc 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -92,7 +92,6 @@ shizuku-provider = { module = "dev.rikka.shizuku:provider", version.ref = "shizu leakcanary-android = { module = "com.squareup.leakcanary:leakcanary-android", version.ref ="leakcanary" } leakcanary-plumber = { module = "com.squareup.leakcanary:plumber-android", version.ref ="leakcanary" } -sqldelight-sqlite = { module = "androidx.sqlite:sqlite-framework", version.ref ="sqldelight" } sqldelight-android-driver = { module = "com.squareup.sqldelight:android-driver", version.ref ="sqldelight" } sqldelight-coroutines = { module = "com.squareup.sqldelight:coroutines-extensions-jvm", version.ref ="sqldelight" } sqldelight-android-paging = { module = "com.squareup.sqldelight:android-paging3-extensions", version.ref ="sqldelight" } From 71bb8ed975bcf790d170310121afbfe94228dbb1 Mon Sep 17 00:00:00 2001 From: FourTOne5 <59261191+FourTOne5@users.noreply.github.com> Date: Sat, 14 May 2022 21:34:15 +0600 Subject: [PATCH 24/80] Minor cleanup in `ImageUtil` and `SourceFilterPresenter` (#7106) * Minor cleanup in `ImageUtil` and `SourceFilterPresenter` * Fix missed stuff --- .../tachiyomi/data/download/Downloader.kt | 14 +++++++----- .../ui/browse/source/SourceFilterPresenter.kt | 10 ++++----- .../kanade/tachiyomi/util/system/ImageUtil.kt | 22 +++++++++++++------ app/src/main/res/values/strings.xml | 1 + 4 files changed, 29 insertions(+), 18 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt index fc18b9f27a..f8ebc535da 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/download/Downloader.kt @@ -392,7 +392,10 @@ class Downloader( return pageObservable // When the page is ready, set page path, progress (just in case) and status .doOnNext { file -> - splitTallImageIfNeeded(page, tmpDir) + val success = splitTallImageIfNeeded(page, tmpDir) + if (success.not()) { + notifier.onError(context.getString(R.string.download_notifier_split_failed), download.chapter.name, download.manga.title) + } page.uri = file.uri page.progress = 100 download.downloadedImages++ @@ -477,8 +480,8 @@ class Downloader( return MimeTypeMap.getSingleton().getExtensionFromMimeType(mime) ?: "jpg" } - private fun splitTallImageIfNeeded(page: Page, tmpDir: UniFile) { - if (!preferences.splitTallImages().get()) return + private fun splitTallImageIfNeeded(page: Page, tmpDir: UniFile): Boolean { + if (!preferences.splitTallImages().get()) return true val filename = String.format("%03d", page.number) val imageFile = tmpDir.listFiles()?.find { it.name!!.startsWith(filename) } @@ -487,8 +490,9 @@ class Downloader( ?: throw Error(context.getString(R.string.download_notifier_split_page_path_not_found, page.number)) // check if the original page was previously splitted before then skip. - if (imageFile.name!!.contains("__")) return - ImageUtil.splitTallImage(imageFile, imageFilePath) + if (imageFile.name!!.contains("__")) return true + + return ImageUtil.splitTallImage(imageFile, imageFilePath) } /** diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt index dfe1b26f47..e4bec09951 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/SourceFilterPresenter.kt @@ -33,15 +33,12 @@ class SourceFilterPresenter( .catch { exception -> _state.value = SourceFilterState.Error(exception) } - .collectLatest { sourceLangMap -> - val uiModels = sourceLangMap.toFilterUiModels() - _state.value = SourceFilterState.Success(uiModels) - } + .collectLatest(::collectLatestSourceLangMap) } } - private fun Map>.toFilterUiModels(): List { - return this.flatMap { + private fun collectLatestSourceLangMap(sourceLangMap: Map>) { + val uiModels = sourceLangMap.flatMap { val isLangEnabled = it.key in preferences.enabledLanguages().get() val header = listOf(FilterUiModel.Header(it.key, isLangEnabled)) @@ -53,6 +50,7 @@ class SourceFilterPresenter( ) } } + _state.value = SourceFilterState.Success(uiModels) } fun toggleSource(source: Source) { diff --git a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt index c3d91e25fc..1844475127 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/util/system/ImageUtil.kt @@ -19,6 +19,7 @@ import androidx.core.graphics.createBitmap import androidx.core.graphics.green import androidx.core.graphics.red import com.hippo.unifile.UniFile +import logcat.LogPriority import tachiyomi.decoder.Format import tachiyomi.decoder.ImageDecoder import java.io.BufferedInputStream @@ -182,7 +183,7 @@ object ImageUtil { * * @return true if the height:width ratio is greater than 3. */ - fun isTallImage(imageStream: InputStream): Boolean { + private fun isTallImage(imageStream: InputStream): Boolean { val options = extractImageOptions(imageStream, false) return (options.outHeight / options.outWidth) > 3 } @@ -190,9 +191,9 @@ object ImageUtil { /** * Splits tall images to improve performance of reader */ - fun splitTallImage(imageFile: UniFile, imageFilePath: String) { + fun splitTallImage(imageFile: UniFile, imageFilePath: String): Boolean { if (isAnimatedAndSupported(imageFile.openInputStream()) || !isTallImage(imageFile.openInputStream())) { - return + return true } val options = extractImageOptions(imageFile.openInputStream(), false).apply { inJustDecodeBounds = false } @@ -213,6 +214,11 @@ object ImageUtil { BitmapRegionDecoder.newInstance(imageFile.openInputStream(), false) } + if (bitmapRegionDecoder == null) { + logcat { "Failed to create new instance of BitmapRegionDecoder" } + return false + } + try { (0 until partCount).forEach { splitIndex -> val splitPath = imageFilePath.substringBeforeLast(".") + "__${"%03d".format(splitIndex + 1)}.jpg" @@ -225,19 +231,21 @@ object ImageUtil { val region = Rect(0, topOffset, imageWidth, bottomOffset) FileOutputStream(splitPath).use { outputStream -> - val splitBitmap = bitmapRegionDecoder!!.decodeRegion(region, options) + val splitBitmap = bitmapRegionDecoder.decodeRegion(region, options) splitBitmap.compress(Bitmap.CompressFormat.JPEG, 100, outputStream) } } imageFile.delete() + return true } catch (e: Exception) { // Image splits were not successfully saved so delete them and keep the original image (0 until partCount) - .map { imageFile.filePath!!.substringBeforeLast(".") + "__${"%03d".format(it + 1)}.jpg" } + .map { imageFilePath.substringBeforeLast(".") + "__${"%03d".format(it + 1)}.jpg" } .forEach { File(it).delete() } - throw e + logcat(LogPriority.ERROR, e) + return false } finally { - bitmapRegionDecoder?.recycle() + bitmapRegionDecoder.recycle() } } diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 0c1bbed882..ef43e434f8 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -820,6 +820,7 @@ Download completed Page %d not found while splitting Couldn\'t find file path of page %d + Couldn\'t split downloaded image Common From 5002692bda658354f1df6285cade002b29747d59 Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Sat, 14 May 2022 23:37:47 +0800 Subject: [PATCH 25/80] Add long click action on chapter download button (#7125) --- .../tachiyomi/ui/manga/chapter/ChapterHolder.kt | 4 ++++ .../ui/manga/chapter/base/BaseChapterHolder.kt | 16 ++++++++++++++++ .../tachiyomi/ui/recent/updates/UpdatesHolder.kt | 4 ++++ 3 files changed, 24 insertions(+) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterHolder.kt index 13edc15743..18d3f76210 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterHolder.kt @@ -25,6 +25,10 @@ class ChapterHolder( binding.download.setOnClickListener { onDownloadClick(it, bindingAdapterPosition) } + binding.download.setOnLongClickListener { + onDownloadLongClick(bindingAdapterPosition) + true + } } fun bind(item: ChapterItem, manga: Manga) { diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/base/BaseChapterHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/base/BaseChapterHolder.kt index a3a38dd437..e2f1dcc9cc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/base/BaseChapterHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/base/BaseChapterHolder.kt @@ -41,4 +41,20 @@ open class BaseChapterHolder( } } } + + fun onDownloadLongClick(position: Int) { + val item = adapter.getItem(position) as? BaseChapterItem<*, *> ?: return + when (item.status) { + Download.State.NOT_DOWNLOADED, Download.State.ERROR -> { + adapter.clickListener.downloadChapter(position) + } + Download.State.DOWNLOADED, Download.State.DOWNLOADING -> { + adapter.clickListener.deleteChapter(position) + } + // Download.State.QUEUE + else -> { + adapter.clickListener.startDownloadNow(position) + } + } + } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesHolder.kt index 25f2c4dd60..e669fafce9 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesHolder.kt @@ -30,6 +30,10 @@ class UpdatesHolder(private val view: View, private val adapter: UpdatesAdapter) binding.download.setOnClickListener { onDownloadClick(it, bindingAdapterPosition) } + binding.download.setOnLongClickListener { + onDownloadLongClick(bindingAdapterPosition) + true + } } fun bind(item: UpdatesItem) { From c77396dbdbc5d43d6cf174b4eb8cbe0393cfbd20 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jozef=20Holl=C3=BD?= <1708197+j2ghz@users.noreply.github.com> Date: Sat, 14 May 2022 23:49:56 +0200 Subject: [PATCH 26/80] Weblate translations (#6994) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Aboo Gh Co-authored-by: Ajeje Brazorf Co-authored-by: Alessandro Jean Co-authored-by: DarKCroX Co-authored-by: DatTran MLL Co-authored-by: David Co-authored-by: Eduard Ereza Martínez Co-authored-by: Eric Co-authored-by: Giorgio Sanna Co-authored-by: Hosted Weblate Co-authored-by: Howard Wu Co-authored-by: Huang Zhiyi Co-authored-by: J. Lavoie Co-authored-by: Jetspectre Co-authored-by: John Philip Sabinet Co-authored-by: Jozef Hollý Co-authored-by: Kim Vognstrup Lind Co-authored-by: Luck In Hell Co-authored-by: Lyfja Co-authored-by: Lzmxya Co-authored-by: Marco Santos Co-authored-by: Matyáš Caras Co-authored-by: Nasy Co-authored-by: Oğuz Ersen Co-authored-by: Paulo Pinho Co-authored-by: Pitpe11 Co-authored-by: RAID ALA EDDINE CHERIFI Co-authored-by: Rikishaaa Co-authored-by: Samuel Leonardo Co-authored-by: Saud Aljaffer Co-authored-by: Scoop Co-authored-by: Shjosan Co-authored-by: Swyter Co-authored-by: THE_LEGEND Co-authored-by: Te quiero Co-authored-by: TheKingTermux Co-authored-by: Thomas Co-authored-by: Vetle Ledaal Co-authored-by: Weblate Co-authored-by: Zakhar Timoshenko Co-authored-by: Zio Co-authored-by: altinat Co-authored-by: jimman2003 Co-authored-by: nzoba Co-authored-by: opb Co-authored-by: pedro henrique garcia pinto Co-authored-by: Роман Co-authored-by: אילון קטן Co-authored-by: عمران حديوي Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ar/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ca/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ceb/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/cs/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/da/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/de/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/el/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/es/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/es_419/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/fa/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/fil/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/fr/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/he/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/hi/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/id/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/it/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ja/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/jv/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ko/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ms/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/nb_NO/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/nn/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/pl/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/pt/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/pt_BR/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/ru/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/sc/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/si/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/sr/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/sv/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/th/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/tr/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/vi/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/zh_Hans/ Translate-URL: https://hosted.weblate.org/projects/tachiyomi/strings/zh_Hant/ Translation: Tachiyomi/Tachiyomi 0.x Co-authored-by: Hosted Weblate Co-authored-by: Aboo Gh Co-authored-by: Ajeje Brazorf Co-authored-by: Alessandro Jean Co-authored-by: DarKCroX Co-authored-by: DatTran MLL Co-authored-by: David Co-authored-by: Eduard Ereza Martínez Co-authored-by: Eric Co-authored-by: Giorgio Sanna Co-authored-by: Howard Wu Co-authored-by: Huang Zhiyi Co-authored-by: J. Lavoie Co-authored-by: Jetspectre Co-authored-by: John Philip Sabinet Co-authored-by: Kim Vognstrup Lind Co-authored-by: Luck In Hell Co-authored-by: Lyfja Co-authored-by: Lzmxya Co-authored-by: Marco Santos Co-authored-by: Matyáš Caras Co-authored-by: Nasy Co-authored-by: Oğuz Ersen Co-authored-by: Paulo Pinho Co-authored-by: Pitpe11 Co-authored-by: RAID ALA EDDINE CHERIFI Co-authored-by: Rikishaaa Co-authored-by: Samuel Leonardo Co-authored-by: Saud Aljaffer Co-authored-by: Scoop Co-authored-by: Shjosan Co-authored-by: Swyter Co-authored-by: THE_LEGEND Co-authored-by: Te quiero Co-authored-by: TheKingTermux Co-authored-by: Thomas Co-authored-by: Vetle Ledaal Co-authored-by: Weblate Co-authored-by: Zakhar Timoshenko Co-authored-by: Zio Co-authored-by: altinat Co-authored-by: jimman2003 Co-authored-by: nzoba Co-authored-by: opb Co-authored-by: pedro henrique garcia pinto Co-authored-by: Роман Co-authored-by: אילון קטן Co-authored-by: عمران حديوي --- app/src/main/res/values-am/strings.xml | 4 - app/src/main/res/values-ar/strings.xml | 64 ++-- app/src/main/res/values-b+es+419/strings.xml | 39 ++- app/src/main/res/values-be/strings.xml | 4 - app/src/main/res/values-bg/strings.xml | 4 - app/src/main/res/values-bn/strings.xml | 4 - app/src/main/res/values-ca/strings.xml | 42 ++- app/src/main/res/values-ceb/strings.xml | 321 ++++++++++++++++++ app/src/main/res/values-cs/strings.xml | 28 +- app/src/main/res/values-cv/strings.xml | 4 - app/src/main/res/values-da/strings.xml | 119 ++++++- app/src/main/res/values-de/strings.xml | 46 ++- app/src/main/res/values-el/strings.xml | 42 ++- app/src/main/res/values-eo/strings.xml | 4 - app/src/main/res/values-es/strings.xml | 58 ++-- app/src/main/res/values-eu/strings.xml | 4 - app/src/main/res/values-fa/strings.xml | 37 ++- app/src/main/res/values-fi/strings.xml | 4 - app/src/main/res/values-fil/strings.xml | 131 ++++---- app/src/main/res/values-fr/strings.xml | 45 ++- app/src/main/res/values-gl/strings.xml | 4 - app/src/main/res/values-he/strings.xml | 110 ++++++- app/src/main/res/values-hi/strings.xml | 49 ++- app/src/main/res/values-hr/strings.xml | 4 - app/src/main/res/values-hu/strings.xml | 4 - app/src/main/res/values-in/strings.xml | 37 ++- app/src/main/res/values-it/strings.xml | 46 ++- app/src/main/res/values-ja/strings.xml | 45 ++- app/src/main/res/values-jv/strings.xml | 106 +++++- app/src/main/res/values-ka-rGE/strings.xml | 3 - app/src/main/res/values-km/strings.xml | 4 - app/src/main/res/values-kn/strings.xml | 4 - app/src/main/res/values-ko/strings.xml | 39 ++- app/src/main/res/values-lt/strings.xml | 4 - app/src/main/res/values-lv/strings.xml | 3 - app/src/main/res/values-mn/strings.xml | 2 + app/src/main/res/values-mr/strings.xml | 2 - app/src/main/res/values-ms/strings.xml | 40 ++- app/src/main/res/values-my/strings.xml | 1 - app/src/main/res/values-nb-rNO/strings.xml | 46 +-- app/src/main/res/values-ne/strings.xml | 4 - app/src/main/res/values-nl/strings.xml | 4 - app/src/main/res/values-nn/strings.xml | 330 +++++++++++++++++++ app/src/main/res/values-pl/strings.xml | 15 +- app/src/main/res/values-pt-rBR/strings.xml | 40 ++- app/src/main/res/values-pt/strings.xml | 71 ++-- app/src/main/res/values-ro/strings.xml | 4 - app/src/main/res/values-ru/strings.xml | 49 ++- app/src/main/res/values-sa/strings.xml | 4 - app/src/main/res/values-sah/strings.xml | 4 - app/src/main/res/values-sc/strings.xml | 28 +- app/src/main/res/values-sdh/strings.xml | 3 - app/src/main/res/values-si/strings.xml | 32 +- app/src/main/res/values-sk/strings.xml | 4 - app/src/main/res/values-sr/strings.xml | 26 +- app/src/main/res/values-sv/strings.xml | 45 ++- app/src/main/res/values-ta/strings.xml | 1 - app/src/main/res/values-te/strings.xml | 3 - app/src/main/res/values-th/strings.xml | 59 ++-- app/src/main/res/values-tr/strings.xml | 40 ++- app/src/main/res/values-uk/strings.xml | 4 - app/src/main/res/values-uz/strings.xml | 1 - app/src/main/res/values-vi/strings.xml | 21 +- app/src/main/res/values-zh-rCN/strings.xml | 41 ++- app/src/main/res/values-zh-rTW/strings.xml | 41 ++- 65 files changed, 1827 insertions(+), 604 deletions(-) create mode 100644 app/src/main/res/values-ceb/strings.xml create mode 100644 app/src/main/res/values-mn/strings.xml create mode 100644 app/src/main/res/values-nn/strings.xml diff --git a/app/src/main/res/values-am/strings.xml b/app/src/main/res/values-am/strings.xml index e3b57528b8..15accce3c9 100644 --- a/app/src/main/res/values-am/strings.xml +++ b/app/src/main/res/values-am/strings.xml @@ -41,7 +41,6 @@ መመሪያ የቤተ-መጽሐፍት ማዘመኛ ድግግሞሽ ዝመናዎች - ክፍት ወደ ምዕራፎች ይዝለሉ የመሬት ገጽታ የቁም ስዕል ዕቃዎች በአንድ ረድፍ @@ -62,7 +61,6 @@ ማሳወቂያዎችን ያቀናብሩ መውጫውን ያረጋግጡ የቀን ቅርጸት - ማያ ገጹን ይጀምሩ በርቷል ጠፍቷል ስርዓት ይከተሉ @@ -145,7 +143,6 @@ ፈልግ ቀን ታክሏል የቅርብ ጊዜ ምዕራፍ - ለመጨረሻ ጊዜ የተፈተሸ ለመጨረሻ ጊዜ የተነበበው ጠቅላላ ምዕራፎች ማጣሪያውን ያስወግዱ @@ -274,7 +271,6 @@ - በማሸብለል ላይ የታች አሞሌን ደብቅ ፋይል እየጎደለ ነው። ልክ ያልሆነ የመጠባበቂያ ፋይል ምትኬ ተፈጥሯል diff --git a/app/src/main/res/values-ar/strings.xml b/app/src/main/res/values-ar/strings.xml index cee6ebb34e..614caa885a 100644 --- a/app/src/main/res/values-ar/strings.xml +++ b/app/src/main/res/values-ar/strings.xml @@ -84,7 +84,6 @@ جاري الشحن سلسلة منتهية تحديث تقدّم الفصول بعد القراءة - شاشة البداية الفئة الافتراضية السؤال دائماً وضع الشاشة الكاملة @@ -239,7 +238,7 @@ لا تتوفر تحديثات جديدة البحث عن التحديثات… جار التنزيل… - اكتمل التنزيل + اضغط للتنزيل حدث خطأ في التنزيل نسخة جديدة متوفرة! غلاف المانجا @@ -334,7 +333,6 @@ إلغاء الكل عرض الفصول أحدث فصل - آخِر تصفح القائمة المصادر نقل إلى الأسفل @@ -446,7 +444,7 @@ تسجيل الخروج من %1$s؟ البريد الإلكتروني - "%1$s عنصر متبقي" + %1$s عنصر متبقي عنصر واحد متبقي عنصران متبقيان %1$s عناصر متبقية @@ -458,7 +456,7 @@ المساحة الجانبية عمودي مستمر رمادي - يقلل النطاقات ولكن يؤثر على الأداء + يزيد من سلاسة تدرج الالوان بالصور، ولكن قد يؤثر على الأداء بعد أقل من دقيقة بعد دقيقة @@ -522,14 +520,13 @@ وضع القراءة قد يحتوى على محتوى للبالغين محتوى غير لائق - الذهاب إلى الفصول المفتوحة هذا لا يمنع الإضافات غير الرسمية أو التي تم وضع علامة عليها بشكل غير صحيح من إظهار محتوى غير لائق داخل التطبيق. تنزيل الفصول غير المقروءة كليهما عمودي أفقي لا شيء - عكس جهة النقر + عكس مناطق اللمس أخطاء مُكتمل التقدّم @@ -548,9 +545,9 @@ لا فصول فصل واحد فصلين - بضعة فصول (%1$s) - عدّة فصول (%1$s) - %1$s فصلاً + %1$s فصول + %1$s فصول + %1$s فصول حالة غير معروفة مؤلّف غير معروف @@ -558,7 +555,7 @@ إبحث عن \"%1$s\" بشكلٍ شامل حُدِّث إلى الإصدار v%1$s - لا توجد فصول مفقودة + جميع الفصول تم تحديثها بنجاح تم تخطي فصل واحد ، إما أن المصدر مفقود أو تمت تصفيته تم تخطي فصلين، إما أن المصدر مفقود أو تمت تصفيته تم تخطي بعض الفصول، إما أن المصدر مفقود أو تمت تصفيته @@ -575,8 +572,7 @@ إعدادات البحث الفصول المنزّلة مانغا من المكتبة - إخفاء الشريط السفلي عند التمرير - هل أنت متأكد؟ سيضيع كل السجل. + هل أنت متأكد؟ سيتم حذف السجل. تم حذف السجل إيقاف سجل القراءة الوضع المخفي @@ -588,7 +584,7 @@ اعرض في قوائم المصادر والامتدادات رجاء سجل دخولك في MAL مجدداً لم يتم العثور على تطبيق منتقي الملفات - تخطيط التنقل + مناطق اللمس على شكل حرف L حافة كيندل العش @@ -616,8 +612,8 @@ يسار التالي السابق - عرض مناطق اللمس للتنقل عند فتح القارئ - إظهار حدود التنقل + عرض مناطق اللمس للتنقل عند فتح القارئ لفترة وجيزة + إظهار مناطق اللمس تاريخ الرفع افقي رأسي @@ -678,7 +674,7 @@ تاكو ديناميك جار تحديث المكتبة…( (%2$d) / (%1$d) ) - هذا المتتبّع متوافق فقط مع المصدر (‌Komga) + هذا المتتبّع متوافق فقط مع المصدر (‌Komga)۔ تقوم بعض الشركات المصنعة بوضع قيود إضافية على التطبيقات التي قد تقضي على الخدمات التي تعمل في الخلفية. يحتوي هذا الموقع على مزيد من المعلومات حول كيفية إصلاحه. النسخ الاحتياطي/الإستعادة ربما لا يعمل بطريقه صحيحة عندما يكون خيار MIUI Optimization غير مفعل. الخدمات التي تقدم ميزات محسنة لأجل مصادر معينه. المانجات سوف يتم تتبعها عندما يتم إضافتها الي المكتبة. @@ -714,7 +710,7 @@ تحذير اللغة يوصى بشدة بالنسخ الاحتياطي التلقائي. يجب عليك الإحتفاظ بنُسخ في أماكن أخرى أيضًا. - التحديثات الكبيرة تضر بالمصادر , تؤدي لتحديثات أبطأ , و أيضا زيادة في استهلاك البطارية + التحديثات الكبيرة تضر بالمصادر، وتؤدي لتحديثات أبطأ، وقد تسبب زيادة في استهلاك البطارية۔ اضغط لمعرفة المزيد۔ التسجيل المطول معلومات التطبيق جارٍ تثبيت الإضافة … @@ -739,7 +735,7 @@ عدد المانغا غير المتواجدة بقاعدة بيانات المكتبة %1$d فشل الحصول على قائمة الملحقات قم بتثبيت \"Shizuku\" لاستخدامه كمثبت ملحق. - تحذير: التحميلات كبيرة الحجم والعدد يمكن أن تؤدي إلى تباطؤ المصادر و/أو تقم بحظر \"Tachiyomi\" + تحذير: التحميلات كبيرة الحجم والعدد يمكن أن تؤدي إلى تباطؤ المصادر و/أو ان تقوم المصادر بحظر Tachiyomi۔ اضغط لمعرفة المزيد۔ خطأ: URI فارغ الاسئله الشائعه والأدلة 5% @@ -748,7 +744,7 @@ شبكة بالاغلفة تم التخطي لعدم وجود فصول مقروءه تم التخطي لوجود فصول غير مقروءه - لديك إدخال في مكتبتك بنفس الإسم و لكن من مصدر مختلف (%1$s). + لديك محتوى في مكتبتك بنفس الإسم و لكن من مصدر مختلف (%1$s). \n \nهل مازلت تريد أن تكمل؟ لم تقرأ أي فصول @@ -758,11 +754,27 @@ متجاوز خطأ أثناء حفظ الصورة معطل - عكس الغلاف - فشل التحديث(ات) - تم تخطي %1$d تحديث(تحديثات) - أنقر للمزيد + رأسي بالعكس + فشل تحديث %1$d عناصر + تم تخطي تحديث %1$d عناصر + اضغط لقراءة المزيد نسخة جديدة متاحة من الإصدارات الرسمية. انقر لمعرفة كيفية الهجرة من إصدارات F-Droid غير الرسمية. - حرك السلسلة للأعلى - المكتبة فارغة ولايمكن عمل نسخة احتياطية منها + نقل سلسلة الفصول للأعلى + لا توجد مدخلات في المكتبة لإجراء نسخة احتياطي‮‮ة + اغلاق + فتح في GitHub + حذف بيانات التصفح المؤقتة + عرض المصادر المثبتة المتكررة + تم حذف بيانات التصفح المؤقتة + البطارية ليست منخفضة + تكرار المصادر المثبتة في مجموعات اللغة الخاصة بها + لا يوجد مصادر مثبته + حسنا،هذا غريب + لا يوجد مصدر + المانغا الغير مقروءة + آخر مانجا محملة + يحسن أداء القارئ عن طريق تقسيم الصور الطويلة التي تم تنزيلها. + تقسيم تلقائي للصور الطويلة + لم يتم العثور على الصفحة %d أثناء التقسيم + لم يتم العثور على مسار الصفخة %d \ No newline at end of file diff --git a/app/src/main/res/values-b+es+419/strings.xml b/app/src/main/res/values-b+es+419/strings.xml index 84e1a25528..1a0a0d0045 100644 --- a/app/src/main/res/values-b+es+419/strings.xml +++ b/app/src/main/res/values-b+es+419/strings.xml @@ -59,7 +59,6 @@ Fuentes Quitar capítulo de favoritos Agregar capítulo a favoritos - Último verificado No leído Marcado Lista de descargas @@ -205,7 +204,7 @@ Categoría por defecto Comprobar nueva portada y los detalles cuando actualizes la biblioteca Actualizar metadatos automáticamente - Series completadas + Que ya están completadas Cargando Restricciones de actualización automática Semanal @@ -216,7 +215,6 @@ Desactivado Actualizaciones automáticas Actualizaciones - Saltar a los capítulos abiertos Horizontal Ambos Vertical @@ -261,7 +259,6 @@ Gestionar notificaciones Confirmar salir Formato de fecha - Pantalla inicial Encendido Apagado Usar el del sistema @@ -339,7 +336,7 @@ ¿Estas seguro\? Los capítulos leídos y el progreso de los mangas que no estén en la biblioteca se perderán Borrar el historial de mangas que no están guardados en la biblioteca Borrar base de datos - Se ha producido un error al borrar el caché + Se ha producido un error mientras se limpiaba No se pudo abrir la configuración del dispositivo Fijadas Última usada @@ -530,7 +527,6 @@ Ajustes del capítulo Capítulos descargardos Manga de la biblioteca - Ocultar la barra inferior al desplazar Opciones de búsqueda Pausar historial de lectura Modo incógnito @@ -651,7 +647,7 @@ Alineación del icono de navegación lateral Navegación Modo oscuro con negro puro - Yotsuba + Tema Yotsuba Yin y Yang Turquesa Tako @@ -660,7 +656,7 @@ Dinámico Tema de la app Apariencia - Fecha obtenida + Fecha de obtención del capítulo Información de la aplicación Instalador Shizuku no se está ejecutando @@ -686,11 +682,11 @@ En hiatus Si necesitas ayuda arreglando errores en la actualización de la biblioteca, ve a %1$s Guardar como archivo CBZ - Hay capítulos no leídos - Saltar actualización + Con capitulo(s) sin leer + Omitir actualización de los títulos Error al obtener la lista de extensiones - Advertencia: las descargas en masa pueden causar lentitud en las fuentes y/o bloquear Tachiyomi - Advertencia: las actualizaciones grandes afectan las fuentes y pueden causar actualizaciones más lentas, además de un mayor uso de batería + Advertencia: las descargas en masa pueden causar lentitud en las fuentes y/o bloquear Tachiyomi. Toca para conocer más. + Advertencia: las actualizaciones grandes afectan las fuentes y podría hacerlas más lentas, además de un mayor uso de batería. Toca para conocer más. Mostrar manga Empezado Portada-única de la cuadrícula @@ -702,16 +698,31 @@ Navegar a la panorámica Ampliar imagen horizontal 5% - No hay capítulos leídos + Que no han sido iniciados Error: URI vacío Omitido porque la serie está completa Omitido porque hay capítulos sin leer Omitido porque no hay capítulos leídos - Más información + Toca para conocer más Omitido %1$d actualización(es) fallida(s) %1$d actualización(es) omitida(s) Retrato inverso Mover la serie al principio Desactivado + Repetir fuentes ancladas en sus grupos de lenguaje respectivos + Mostrar fuentes duplicadas ancladas + No hay entradas para respaldar en la biblioteca + Datos de la vista web eliminados + Limpiar datos de la vista web + Una nueva versión esta disponible desde los lanzamientos oficiales, Toca para aprender a emigrar de lanzamientos F-droid no oficiales. + Error al guardar imagen + Cerrar + La bateria no está baja + Abrir en GitHub + Ninguna fuente encontrada + No se encontró ninguna fuente instalada + Bueno, esto es incomodo + Recuento no leído + Última actualización de manga \ No newline at end of file diff --git a/app/src/main/res/values-be/strings.xml b/app/src/main/res/values-be/strings.xml index 9a67479281..5077e2015e 100644 --- a/app/src/main/res/values-be/strings.xml +++ b/app/src/main/res/values-be/strings.xml @@ -64,7 +64,6 @@ Дата дадання Дата атрымання Апошняя частка - Апошняя праверка Апошняе чытанне Усяго частак У алфавітным парадку @@ -139,7 +138,6 @@ Уручную Частата абнаўлення Глабальнае абнаўленне - Перайсці да частак пры запуску Гарызантальная Партрэтная Элементы ў радку @@ -166,10 +164,8 @@ Пасярэдзіне Паверсе Выраўноўванне значкоў бакавой навігацыі - Схаваць ніжнюю паласу пры прагортцы Пацвярджаць выхад Фармат даты - Пачатковы экран Чысты чорны цёмны рэжым Ёцуба Інь і Ян diff --git a/app/src/main/res/values-bg/strings.xml b/app/src/main/res/values-bg/strings.xml index 2b05d4e41a..318c466ef3 100644 --- a/app/src/main/res/values-bg/strings.xml +++ b/app/src/main/res/values-bg/strings.xml @@ -79,7 +79,6 @@ На зарядно устройство Излизащи серии Обнови прогреса след прочитане - Начален екран Цял екран Анимирани преходи @@ -467,7 +466,6 @@ Преглед на глави Избери обратно Последна глава - Последна проверка Меню Натиснете назад още веднъж, за да излезете Отключете Тачийоми @@ -545,7 +543,6 @@ Режим на четене Може да съдържа неприлично (18+) съдържание 18+ - Отиди до глави при отваряне Тази настройка няма да спре неофициални или потенциално неправилно маркирани разширения да позволяват достъп до съдържание за възрастни (18+) в апликацията. Тема Изтегли непрочетените глави @@ -594,7 +591,6 @@ Къси (Днес, Вчера) Дълги (Къси+, преди х дни) Облик - Скрий долната лента при плъзгане Относителни времеотметки Да L-образно diff --git a/app/src/main/res/values-bn/strings.xml b/app/src/main/res/values-bn/strings.xml index d289f1adfc..edd0577495 100644 --- a/app/src/main/res/values-bn/strings.xml +++ b/app/src/main/res/values-bn/strings.xml @@ -86,7 +86,6 @@ চার্জ হচ্ছে কেবল চলমান মাংগা হালনাগাদ করুন পড়ার পরে অগ্রগতি আপডেট করুন - শুরুর পর্দা সাধারণ বিভাগ সর্বদা জিজ্ঞাসা করুন সম্পূর্ণ পর্দা @@ -335,7 +334,6 @@ উল্টো নির্বাচন করুন তারিখে যোগকৃত সর্বশেষ অধ্যায় - সর্বশেষ পরিক্ষিত তালিকা প্রস্থান করতে আবার ব্যাক চাপুন তাচিওমি খুলুন @@ -380,7 +378,6 @@ অ্যাপ পাল্টানোর সময় অ্যাপের কন্টেন্ট লুকান ও স্ক্রিনসট ব্লক করুন সেটিংসে খুঁজুন কর্মহীন হলে লক করুন - স্ক্রোলের সময় নিচের বার লুকান হালনাগাদকৃত প্রকৃত শ্রেণির সেটিংস প্রকৃত হিসেবে সংরক্ষণ করুন আপনি কি নিশ্চিত সেটিংসগুলো প্রকৃত হিসেবে সংরক্ষণ করবেন\? @@ -424,7 +421,6 @@ অনুমোদনহীন অনিষ্পন্ন হালনাগাদ সংগ্রহশালা হালনাগেদের সময় নতুন মোড়ক এবং বর্ণনা খুঁজুন - খোলার পর অধ্যায়ে যান %1$s অধ্যায়সমূহ এবং ১টি আরও %1$s অধ্যায়সমূহ এবং %2$dটি আরও diff --git a/app/src/main/res/values-ca/strings.xml b/app/src/main/res/values-ca/strings.xml index 85e4b6ac4e..462c3e1c56 100644 --- a/app/src/main/res/values-ca/strings.xml +++ b/app/src/main/res/values-ca/strings.xml @@ -89,7 +89,6 @@ Carregant Amb l\'estat «Completada» Actualitza el progrés després de llegir - Pantalla d\'inici Categoria per defecte Demana-ho sempre Tot @@ -291,7 +290,7 @@ No hi ha cap nova actualització disponible S\'estan cercant actualitzacions… S\'està baixant… - Baixada completada + Premeu per a instal·lar Error de baixada Nova versió disponible! Portada del manga @@ -388,7 +387,6 @@ Els més antics Mou a dalt de tot Mou a sota de tot - Darrera comprovació Comprova si hi ha actualitzacions de les extensions Hi ha una actualització d\'una extensió @@ -447,7 +445,7 @@ Fet en %1$s amb %2$s error Fet en %1$s amb %2$s errors - Redueix les bandes de colors, però afecta el rendiment + Redueix les bandes de colors, però pot afectar el rendiment %d categoria %d categories @@ -479,7 +477,7 @@ En vertical En horitzontal Cap - Inverteix els tocs + Inverteix les zones de toc No s\'han pogut baixar els capítols perquè hi ha poc espai d\'emmagatzematge No s\'ha trobat la font @@ -488,7 +486,7 @@ Estat desconegut Autor desconegut - Cerca \"%1$s\" globalment + Cerca «%1$s» globalment S\'ha actualitzat a la v%1$s Novetats Cal reiniciar l\'aplicació perquè tingui efecte @@ -496,7 +494,6 @@ Mode de lectura Mostra breument el mode actual en obrir el lector Mostra el mode de lectura - Salta als capítols en obrir Tema Desactiva Inicia @@ -531,7 +528,6 @@ Configuració de la cerca Capítols baixats Manga de la biblioteca - Amaga la barra inferior en desplaçar N’esteu segur\? Es perdrà tot l’historial. Pausa l\'historial de lectura Mode d\'incògnit @@ -550,7 +546,7 @@ S\'han desat els registres de fallades Desa els registres d\'errors en un fitxer perquè el pugueu compartir amb els desenvolupadors Bolca els registres de fallades - Disseny de navegació + Zones de toc Vora Semblant al Kindle En forma d\'L @@ -589,14 +585,14 @@ Desa les pàgines en carpetes separades Accions Escala de grisos - Mostra les zones de toc en obrir el lector - Mostra la superposició de la navegació + Mostra breument les zones de toc en obrir el lector + Mostra la superposició de les zones de toc Inclou: %s Exclou: %s Cap Premeu per a veure\'n els detalls Cancel·la-ho tot per a aquesta sèrie - Data d\'obtenció + Data d\'obtenció del capítol Data Ordena per El format del capítol no és vàlid @@ -693,8 +689,8 @@ Actualitzacions de l\'aplicació Segueix Informació de l\'aplicació - Advertència: Les baixades massa grosses poden fer que les fonts es tornin més lentes i/o bloquin el Tachiyomi - Les actualitzacions grosses perjudiquen les fonts i poden implicar actualitzacions més lentes i un augment en l\'ús de bateria + Advertència: Les baixades massa grosses poden fer que les fonts es tornin més lentes i/o bloquin el Tachiyomi. Premeu per a obtenir-ne més informació. + Les actualitzacions grosses perjudiquen les fonts i poden implicar actualitzacions més lentes i un augment en l\'ús de bateria. Premeu per a obtenir-ne més informació. Amplia la imatge en horitzontal Mostra el manga Teniu un element a la vostra biblioteca amb el mateix nom però d\'una font diferent (%1$s). @@ -720,4 +716,22 @@ Hi ha una nova versió disponible als llançaments oficials. Premeu per a obtenir informació de com migrar a partir dels llançaments no oficials d\'F-Droid. Neteja les dades del WebView S\'han netejat les dades del WebView + Tanca + Mostra les fonts fixades duplicades + Repeteix les fonts fixades a llurs grups de llengua + Bateria no baixa + No s\'ha trobat cap font instal·lada + Ostres, que estrany... + No s\'ha trobat cap font + Nombre de no llegits + Darrera actualització de manga + Divideix automàticament les imatges altes + Millora el rendiment del lector dividint les imatges baixades massa altes. + No s\'ha trobat la pàgina %d en dividir + No s\'ha trobat el camí del fitxer de la pàgina %d + Restableix les opcions del lector + Restableix el mode de lectura i l\'orientació de totes les sèries + S\'han restablert les opcions del lector + No s\'han pogut restablir les opcions del lector + No s\'ha pogut dividir la imatge baixada \ No newline at end of file diff --git a/app/src/main/res/values-ceb/strings.xml b/app/src/main/res/values-ceb/strings.xml new file mode 100644 index 0000000000..84fc5d7221 --- /dev/null +++ b/app/src/main/res/values-ceb/strings.xml @@ -0,0 +1,321 @@ + + + Kasaysayan + Mga update + I-unlock ang Tachiyomi + Panghimatuod aron makumpirma ang pagbag-o + Pindota balik pag-usab aron makagawas + Mga setting + Menu + Gi-download + Gi-bookmark + Gisubay + Wala mabasa + Nagsugod + Alpabetiko + Kinatibuk sa manga + Kinatibuk sa mga kapitulo + Katapusan nga pagbasa + Wala mabasa nga ihap + Petsa sa pagkuha sa kapitulo + Gidugang ang petsa + Pangitaa + Mga setting sa pagpangita + Pangkalibutanon nga pagpangita + Pilia ang tanan + Pagpili inverse + Markahi nga gibasa + Markahi nga wala pa mabasa + Markahi ang nauna nga nabasa na + Pag-download + Ngalan + Mga kapitulo + Dugang pa + Mga setting + Tinubdan + Default + Pag-download sa Pila + Manga + Pagsubay + Librarya + Mga Kategoriya + Molalin + Pagpadako + Impormasyon sa Extension + Kasaysayan + Tabang ug sa Pagpasig-uli + Pagsala + Tabang + Pasidaan + I-download ang wala pa mabasa nga mga kapitulo + Pinakabag-o nga kapitulo + Kuhaa ang filter + Katapusan nga update sa manga + + %d Kategoriya + %d Mga kategoriya + + Tanan + Walay bag-o nga mga update + Matag-kategorya nga mga setting alang sa paghan-ay ug pagpakita + Walay downloads + Walay nabasa bag-o lang + Wala kay mga kategorya. i-tap ang plus button aron makahimo og usa para sa pag-organisar sa imong library. + Walay sulod ang imong library + Bookmark nga kapitulo + Unbookmark nga kapitulo + Pagtangtang + Update + I-enable ang tanan + Idugang + Idugang ang kategorya + Usba ang mga kategorya + Usba ang ngalan sa kategorya + Usba ang hapin + Tan-awa ang mga kapitulo + Hunong + Kuhaa + Sa miaging kapitulo + Pagsugod + Sunod nga kapitulo + Sulayi pag-usab + Ipadayon + Ipakita ang manga + Paglalin + Pagpakita + Cover-only grid + Gi-download nga mga kapitulo + Mga kapitulo nga wala pa mabasa + Pinulongan + Ipakita ang mga tab sa kategorya + Ipakita ang gidaghanon sa mga butang + Pag-disable + Unpin + Pagkanselar + I-disable ang tanan + Edit + Pag-update sa librarya + Ibutang ang mga kategorya + Paghunong + Ablihi sa browser + Lokal nga manga + Ablihi sa WebView + Komportable nga grid + Display mode + Listahan + Compact nga grid + Pin + Cancel tanan + Ikansela ang tanan alang niini nga serye + Pagsunud-sunod + Pag-order pag-usab + Pinakabag-o + Lihok sa ubos + Pag-instalar + Tipigi + I-reset + I-undo + Suod nga + Balik + I-refresh + Nagproseso… + Dili magamit ang app + Heneral + Panagway + Library + Magbabasa + Mga pag-download + Pagsubay + Abante + Tema + Dark mode + Sa + Tema sa app + Dinamiko + Berde nga mansanas + Sa tungang gabii sa kilumkilom + Tako + Teal ug Turquoise + Yin ug Yang + Yotsuba + Nabigasyon + Pormat sa petsa + Kinahanglan nga ablihan + I-lock kung walay trabaho + Tagoa ang sulod sa pahibalo + Lig-on nga screen + NSFW (18+) Mga Tinubdan + Bag-o lang + Karon + Pagpakita + Mga butang kada laray + Hulagway + Landscape + Tibuok kalibutan nga update + Off + Kada 6 ka oras + Matag 12 ka oras + Adlaw-adlaw + Kada 2 ka adlaw + Kada semana + Nagpabayad + Dili ubos ang baterya + Mga pagdili: %s + Laktawan ang pag-update sa mga titulo + Uban sa wala pa mabasa nga (mga) kapitulo + Wala pa kana nagsugod + Ipakita ang wala pa mabasa nga ihap sa icon sa Updates + Awtomatikong i-refresh ang metadata + Pangutana kanunay + + Human sa %1$s ka minuto + Human sa %1$s ka minuto + + + Kagahapon + %1$d ka adlaw ang milabay + + Nagpaubos + Pinaagi sa petsa sa pag-upload + Pinaagi sa numero sa kapitulo + Kinatigulangan + Ibalhin sa ibabaw + Ibalhin ang serye sa ibabaw + I-tap aron makita ang mga detalye + Paghimo + FAQ ug mga Giya + Pagsaka + Ipaambit + Bukas nga log + Iuli + Off + Mahitungod sa + Dili gayud + Sa unahan + Sugdi ang pag-download karon + Sunda ang sistema + Strawberry Daiquiri + Dugay (Mubo+, n adlaw ang milabay) + Pagdumala sa mga pahibalo + Seguridad + Ipakita sa mga tinubdan ug mga lista sa mga extension + Purong itom nga dark mode + Ibabaw + Kumpirma ang paggawas + Pag-align sa icon sa nabigasyon sa kilid + Sentro + Mga timestamp + Relatibo nga mga timestamp + Mubo (Karon, Kagahapon) + Dili kini makapugong sa dili opisyal o posibleng sayop nga gi-flag nga mga extension gikan sa pag-surf sa NSFW (18+) nga sulod sulod sa app. + Ubos + Kanunay + Ang luwas nga screen nagtago sa mga sulod sa app sa dihang nagbalhin-balhin og mga app ug nag-block sa mga screenshot + Awtomatikong mga update + Awtomatikong pag-update sa mga pagdili sa device + Sa Wi-Fi lang + Uban sa \"Nakumpleto\" nga kahimtang + Pag-update sa mga tracker kung nag-update sa librarya + Awtomatikong i-refresh ang mga tracker + Default nga kategorya + Kada 3 ka adlaw + Susiha ang bag-ong hapin ug mga detalye kung mag-update sa librarya + Apil ang: %s + Tanan + Naghulat ang mga update + Update + Update tanan + Pag-instalar + Gi-install + Pagsalig + Dili opisyal + Dili kasaligan + I-uninstall + Dili kasaligan nga extension + Kini nga extension dili na magamit. + Kini nga extension dili gikan sa opisyal nga listahan sa mga extension sa Tachiyomi. + Napakyas sa pagkuha sa listahan sa mga extension + Bersyon: %1$s + Pinulongan: %1$s + 18+ + Mahimong adunay sulod nga NSFW (18+) + Nag-instalar og extension… + Installer + Kabilin + Si Shizuku wala modagan + I-install ug sugdi ang Shizuku aron gamiton ang Shizuku isip extension installer. + Fullscreen + Duha ka panid nga bahin + Balita ang duha ka panid nga pagbahin sa pagbutang + Kung ang pagbutang sa doble nga panid sa panid dili motakdo sa direksyon sa pagbasa + Doble nga pag-tap sa katulin sa animation + Ipakita ang numero sa panid + Ipakita ang mode sa pagbasa + Sa daklit ipakita ang kasamtangan nga mode kung giablihan ang magbabasa + 32-bit nga kolor + Mga utlanan sa pananom + Sa + Grayscale + Color filter blend mode + Pagdaghan + Dodge / Pagpagaan + Pagsunog / Pagngitngit + Ipadayon ang screen + Laktawan ang nasala nga mga kapitulo + Nabigasyon + Ibalik ang mga yawe sa volume + Wala + Pahigda + Ang duha + Mga aksyon + I-save ang mga panid sa lainlaing mga folder + Naghimo ug mga folder sumala sa titulo sa manga + Puti + Gray + Itom + Awtomatiko + Default nga mode sa pagbasa + L nga porma + Kindle-ish + Edge + Tuo ug Wala + Nabaldado + Prev + Ipakita ang mga tap zone nga overlay + Sa daklit ipakita kung giablihan ang magbabasa + Pagpakunhod sa banding, apan mahimong makaapekto sa performance + Balika ang mga tap zone + Karaan na + Dili iapil: %s + Pag-instalar + Nag-download + Ang manga sa wala iapil nga mga kategorya dili ma-update bisan kung naa usab sila sa mga gilakip nga kategorya. + Wala + Naghulat + Impormasyon sa app + Kini nga extension gipirmahan gamit ang dili kasaligan nga sertipiko ug wala gi-aktibo. +\n +\nAng usa ka malisyoso nga extension mahimong makabasa sa bisan unsang mga kredensyal sa pag-login nga gitipigan sa Tachiyomi o ipatuman ang arbitraryong code. +\n +\nPinaagi sa pagsalig niini nga sertipiko gidawat nimo kini nga mga risgo. + Ipakita ang sulod sa ginunting nga lugar + I-animate ang mga transisyon sa panid + Custom nga kahayag + Mga yawe sa volume + Off + Pasadya nga kolor nga filter + Pagahal-upan + Laktawan ang mga kapitulo nga gimarkahan nga nabasa + Baliktad + Screen + Ipakita sa taas nga gripo + Bertikal + Kolor sa background + Sunod + Sa wala + Husto + Webtoon + Wala ngadto sa tuo + Tuo ngadto sa wala + Bertikal + \ No newline at end of file diff --git a/app/src/main/res/values-cs/strings.xml b/app/src/main/res/values-cs/strings.xml index 9f70641cb0..2653c21c80 100644 --- a/app/src/main/res/values-cs/strings.xml +++ b/app/src/main/res/values-cs/strings.xml @@ -51,9 +51,8 @@ Denně Každé 2 dny Týdně - Se stavem \"Dokončeno\" + Ve stavu \"Dokončeno\" Aktualizovat počet kapitol po přečtení - Úvodní obrazovka Vše Aktualizovat Instalovat @@ -238,7 +237,7 @@ Vymazat mezipaměť kapitol Využito: %1$s Mezipaměť smazána. %1$d souborů bylo odstraněno - Během vymazávání mezipaměti došlo k chybě + Během vymazávání došlo k chybě Vymazat cookies Cookies vymazány Vyčistit databázi @@ -533,8 +532,6 @@ Datum zahájení čtení Vždy zobrazovat přechod mezi kapitolami Podobné Kindlu - Při otevření přejít na kapitoly - Skrýt spodní lištu při projíždění Přesunout dolů Zrušit vše Pohodlná mřížka @@ -543,7 +540,6 @@ Povolit vše Nastavení vyhledávání Datum přidání - Naposledy zkontrolováno Sledováno Opětovným stisknutím tlačítka aplikaci opustíte Režim čtení @@ -685,18 +681,18 @@ Každé 3 dny Jen na Wi-Fi Podrobné protokolování - Varování: hromadné stahování může vést k tomu, že zdroje zpomalí a/nebo zablokují Tachiyomi + Varování: hromadné stahování může vést k tomu, že zdroje zpomalí a/nebo zablokují Tachiyomi. Klepnutím se dozvíte více. Zobrazit počet nepřečtených kapitol na ikoně Aktualizace Aktualizovat vše Vypisovat podrobné informace do systémového protokolu (sníží výkon aplikace) Aktualizace aplikace - Varování: velké aktualizace poškozují zdroje a můžou vést k pomalejším aktualizacím a zvýšenému využití baterie + Varování: velké aktualizace poškozují zdroje a můžou vést k pomalejším aktualizacím a zvýšenému využití baterie. Klepnutím se dozvíte více. Vymazat cache kapitol při zavření aplikace Chyba v získání seznamu rozšíření Zásady ochrany osobních údajů v databázi je manga %1$d mimo knihovnu Snižuje proužkování, ale ovlivňuje výkon - Přeskočit aktualizaci + Přeskočit aktualizaci titulů S nepřečtenými kapitolami vyčištění databáze Uložit jako CBZ archiv @@ -719,8 +715,20 @@ Zahájeno Přeskočeno Přesunout sérii na začátek - Zjistit více + Klepnutím se dozvíte více Přeskočeno, protože nebyly přečteny žádné kapitoly Přeskočeno, protože série je dokončena Zakázáno + Žádné záznamy v knihovně k zálohování + Žádný zdroj nenalezen + No, tohle je trapné + Nová oficiální verze je dostupná. Pro informace pro přechod z neoficiálních F-Droid verzí klepněte sem. + Zvětšit obrázek na šířku + Žádný nainstalovaný zdroj nenalezen + Otevřít na GitHubu + Chyba při ukládání obrázku + Zavřít + Obrácené na výšku + Vyčistit data WebView + Data z WebView vymazána \ No newline at end of file diff --git a/app/src/main/res/values-cv/strings.xml b/app/src/main/res/values-cv/strings.xml index a7ba1716ec..c3dd51d95a 100644 --- a/app/src/main/res/values-cv/strings.xml +++ b/app/src/main/res/values-cv/strings.xml @@ -53,7 +53,6 @@ Кашни 6 сехет Ҫӗнетни тӑтӑшлӑхӗ Пӗтӗм ҫӗнетӳ - Уҫӑ сыпӑксем патне куҫ Кӑтарт Сыхлав ыкранӗ @@ -64,7 +63,6 @@ Систерӳсене ӗнерле Тухнине ҫирӗплет Вӑхӑт формачӗ - Пуҫламӑш экран Ҫутнӑ Сӳнтернӗ Тата @@ -125,7 +123,6 @@ Пур ҫӗрте шыра Шырав Юлашки сыпӑкпа - Юлашки тӗрӗсленипе Юлашки вуланипе Сыпӑксен шучӗпе Алфавитпа @@ -529,7 +526,6 @@ %1$s: %2$s, %3$d эл Сыпӑк ӗнерлеве Шырав ӗнерлевӗ - Ҫаврӑнтару чух аялти хӑмине пытармалла Тиесе илнӗ сыпӑксем Вулавӑшран манкӑ Вулани кун-ҫула чарса лартать diff --git a/app/src/main/res/values-da/strings.xml b/app/src/main/res/values-da/strings.xml index 135797b90b..7274d5d444 100644 --- a/app/src/main/res/values-da/strings.xml +++ b/app/src/main/res/values-da/strings.xml @@ -32,7 +32,7 @@ Kategorier Manga Kapitler - Tracking + Sporing Kilder Indstillinger Navn @@ -64,7 +64,6 @@ Forsøg igen Sprog Kapitler ialt - Sidst checket Seneste kapitel Global søgning Slet @@ -89,7 +88,121 @@ Stop Ulæste kapitler Lokale manga - Tracked + Sporet Vælg kategorier Vis kategori tabs + Godkend for at bekræfte ænding + Vis antal genstande + Deaktivér + Fastgør + Frigør + Omarranger + Efter upload dato + Efter kapitelnummer + Ældste + Flyt til toppen + Flyt serie til toppen + Flyt til bunden + Installer + Del + Gem + Nulstil + Fortryd + Åben log + Afbryd alle for denne serie + Sorter + Afbryd alle + Afbryd + Stigende + Nyeste + Faldende + Tryk for at se detaljer + Opret + Gendan + Tilbage + Genindlæs + Start download nu + FAQ og guides + Loader… + App ikke tilgængelig + Generelt + Udseende + Downloads + Sporing + Luk + Læser + Frem + Bibliotek + Avanceret + Om + Tema + Mørk tilstand + Følg system + Fra + Til + App tema + Dynamisk + Æble grøn + Skumring + Strawberry Daiquiri + Tako + Blågrøn & Turquoise + Yin-yang + Yotsuba + Kulsort + Navigation + Justering af sidenavigationsikon + Top + Center + Bund + Tidsstempler + Lang (Kort+, n dage siden) + Dato format + Relative tidsstempler + Kort (I dag, I går) + Bekræft afslut + Håndter notifikationer + Sikkerhed + Kræv oplåsning + + I går + %1$d dage siden + + NSFW (18+) kilder + Vis i kilder og udvidelsesliste + Dette forhindrer ikke uofficielle eller potentielt ukorrekt markerede udvidelser fra at vise NSFW (18+) indhold i appen. + For nylig + I dag + + Efter %1$s minut + Efter %1$s minutter + + Lås ved inaktivitet + Altid + Aldrig + Skjul notifikationsindhold + Sikker skærm + Sikker skærm skjuler app indhold, når der skiftes mellem apps, og blokerer for skærmbilleder + Vis + Enhedsbegrænsninger for automatiske opdateringer + Kun på WiFi + Elementer per række + Liggende + Stående + Global opdatering + Automatiske opdateringer + Fra + Hver 6. time + Hver 12. time + Dagligt + Hver anden dag + Hver tredje dag + Ugentligt + Kun under opladning + Når batteriet ikke et lavt + Begrænsninger: %s + Spring over opdatering af titler + Med ulæst kapitler + Med \"Færdig\" status + Der ikke er blevet startet \ No newline at end of file diff --git a/app/src/main/res/values-de/strings.xml b/app/src/main/res/values-de/strings.xml index 9c2b40aaba..204f68cd7c 100644 --- a/app/src/main/res/values-de/strings.xml +++ b/app/src/main/res/values-de/strings.xml @@ -59,7 +59,7 @@ Protokoll öffnen Erstellen Wiederherstellen - Wird geladen… + Wird geladen … App nicht verfügbar Allgemein Lese-Einstellungen @@ -82,7 +82,6 @@ Am Laden Mit dem Status „Abgeschlossen“ Fortschritt nach dem Lesen aktualisieren - Startbildschirm Standardkategorie Immer fragen Vollbild @@ -232,7 +231,7 @@ Keine neue Aktualisierung verfügbar Suche nach Aktualisierungen… Herunterladen… - Download abgeschlossen + Tippe zum Installieren Fehler beim Herunterladen Neue Version verfügbar! Manga-Cover @@ -388,7 +387,6 @@ Älteste Nach oben verschieben Nach unten verschieben - Zuletzt überprüft Nach Erweiterungsaktualisierungen suchen Erweiterungsaktualisierung verfügbar @@ -442,7 +440,7 @@ Grau Lesemodus Für diese Serie - Reduziert Streifenbildung, beeinflusst aber die Performance + Reduziert Streifenbildung, könnte aber die Leistung beeinflussen %d Kategorie %d Kategorien @@ -486,8 +484,7 @@ Erfordert einen Neustart der Anwendung, um wirksam zu werden Netzwerk - Beim Öffnen zu den Kapiteln springen - Tippen invertieren + Tippzonen invertieren Beide Vertikal Horizontal @@ -499,7 +496,7 @@ Was ist neu Herunterladen von Kapiteln aufgrund von zu wenig Speicherplatz nicht möglich Nach „%1$s“ überall suchen - Datum hinzugefügt + Hinzufügedatum Lesemodus Thema @@ -531,7 +528,6 @@ Einstellungen durchsuchen Heruntergeladene Kapitel Manga aus der Bibliothek - Untere Leiste beim Scrollen ausblenden Leseverlauf pausieren Inkognito-Modus Verlauf löschen @@ -545,7 +541,7 @@ Keine Dateiauswahl-App gefunden Bitte logge dich erneut in MAL ein Rand - Navigationslayout + Tippzonen Kindle-Stil L-förmig Absturzprotokolle @@ -567,8 +563,8 @@ Die Daten der Sicherungsdatei werden wiederhergestellt. \n \nDu musst jegliche fehlende Erweiterungen installieren und dich anschließend bei den Tracking-Anbietern einloggen, um sie zu benutzen. - Tipp-Zonen anzeigen, wenn der Leser geöffnet wird - Navigationslayout-Overlay anzeigen + Kurz anzeigen, wenn der Leser geöffnet wird + Tippzonen-Overlay anzeigen Rechts Links Weiter @@ -577,7 +573,7 @@ Ausschließen: %s Einschließen: %s Nichts - Datum abgerufen + Abrufdatum des Kapitels Manga in ausgeschlossenen Kategorien werden nicht heruntergeladen, auch wenn sie in eingeschlossenen Kategorien vorhanden sind. Automatisches Herunterladen Manga in ausgeschlossenen Kategorien werden nicht aktualisiert, auch wenn sie in eingeschlossenen Kategorien vorhanden sind. @@ -672,12 +668,12 @@ Ausführliche Protokolle im Systemprotokoll ausgeben (verringert die Anwendungsleistung) Sprache Warnung - Große Aktualisierungen schaden Quellen und könnten zu langsameren Aktualisierungen sowie höherem Akkuverbrauch führen + Große Aktualisierungen schaden Quellen und könnten zu langsameren Aktualisierungen sowie höherem Akkuverbrauch führen. Tippe, um mehr zu erfahren. Automatische Sicherungen sind sehr zu empfehlen. Du solltest auch Kopien an anderen Orten aufbewahren. Nur über WLAN Alle 3 Tage - Achtung: Große Downloads könnten dazu führen, dass Quellen langsamer werden und/oder Tachiyomi blockieren - Ungelesenenanzahl auf dem Aktualisierungssymbol anzeigen + Achtung: Große Downloads könnten dazu führen, dass Quellen langsamer werden und/oder Tachiyomi blockieren. Tippe, um mehr zu erfahren. + Ungelesenenanzahl auf dem „Neu“-Symbol anzeigen Alle aktualisieren Anwendungsaktualisierungen Kapitel-Zwischenspeicher beim Schließen der App löschen @@ -720,4 +716,22 @@ Auf GitHub öffnen WebView-Daten löschen WebView-Daten gelöscht + Schließen + Akkuladung nicht niedrig + Angeheftete Quellen in ihren jeweiligen Sprachgruppen wiederholen + Doppelte angeheftete Quellen anzeigen + Tja, das ist jetzt etwas peinlich + Keine installierte Quelle gefunden + Keine Quelle gefunden + Ungelesenenanzahl + Zuletzt aktualisierter Manga + Hohe Bilder automatisch teilen + Verbessert die Leseleistung durch Aufteilung hoher heruntergeladener Bilder. + Seite %d während dem Aufteilen nicht gefunden + Dateipfad der Seite %d konnte nicht gefunden werden + Setzt den Lesemodus und die Ausrichtung aller Serien zurück + Lesereinstellungen zurücksetzen + Lesereinstellungen zurückgesetzt + Lesereinstellungen konnten nicht zurückgesetzt werden + Heruntergeladenes Bild konnte nicht aufgeteilt werden \ No newline at end of file diff --git a/app/src/main/res/values-el/strings.xml b/app/src/main/res/values-el/strings.xml index 3f11308719..a0ab2172c9 100644 --- a/app/src/main/res/values-el/strings.xml +++ b/app/src/main/res/values-el/strings.xml @@ -89,7 +89,6 @@ Φορτίζει Με κατάσταση \"Ολοκληρωμένο\" Ενημέρωση προόδου μετά την ανάγνωση - Οθόνη εκκίνησης Προεπιλεγμένη κατηγορία Ερώτηση πάντα Όλα @@ -291,7 +290,7 @@ Δεν υπάρχουν διαθέσιμες νέες ενημερώσεις Αναζήτηση για ενημερώσεις… Γίνεται λήψη… - Η λήψη ολοκληρώθηκε + Πατήστε για εγκατάσταση Σφάλμα λήψης Υπάρχει διαθέσιμη ενημέρωση! Εξώφυλλο manga @@ -421,7 +420,6 @@ Καρφίτσωμα Προβολή κεφαλαίων Νεότερο κεφάλαιο - Ελέγχθηκε τελευταία φορά Μενού Ξεκλειδώστε το Tachiyomi Ληφθέντα μόνο @@ -440,7 +438,7 @@ %1$s που απομένουν Γκρι - Μειώνει το banding, αλλά επηρεάζει την απόδοση + Μειώνει το banding, αλλά μπορεί να επηρεάσει την απόδοση Λειτουργία ανάγνωσης Για αυτήν τη σειρά @@ -486,12 +484,11 @@ Απαιτείται επανεκκίνηση της εφαρμογής για να τεθεί σε ισχύ Δίκτυο - Μετάβαση στα κεφάλαια κατά το άνοιγμα Και τα δυο Κάθετα Οριζόντια Κανένα - Αντιστροφή πατήματος + Αντιστροφή ζωνών πατήματος Άγνωστη κατάσταση Άγνωστος συγγραφέας Ενημερώθηκε σε v%1$s @@ -531,7 +528,6 @@ Αναζήτηση ρυθμίσεων Κεφάλαια που έχουν ληφθεί Manga από τη βιβλιοθήκη - Απόκρυψη της κάτω μπάρας κατά την κύλιση Παύει το ιστορικό ανάγνωσης Λειτουργία ανώνυμης περιήγησης Διαγραφή ιστορικού @@ -544,7 +540,7 @@ Εμφάνιση στις λίστες πηγών και επεκτάσεων Δεν βρέθηκε εφαρμογή επιλογής αρχείων Συνδεθείτε ξανά στο MAL - Διάταξη πλοήγησης + Ζώνες πατήματος Άκρη Σαν Kindle Σχήματος L @@ -558,7 +554,7 @@ Αύξουσα Κατά αριθμό κεφαλαίου Κατά ημερομηνία μεταφόρτωσης - Tracked + Παρακολουθούνται Εμφάνιση αριθμού στοιχείων Δεξιά και Aριστερά Διπλή διαίρεση σελίδας @@ -567,8 +563,8 @@ Τα δεδομένα από το αντίγραφο ασφαλείας θα αποκατασταθούν \n \nΘα χρειαστεί να εγκαταστήσετε τυχόν επεκτάσεις που λείπουν και στη συνέχεια να συνδεθείτε στις υπηρεσίες παρακολούθησης για να τις χρησιμοποιήσετε. - Εμφάνιση ζωνών πατήματος όταν ανοίγει ο αναγνώστης - Εμφάνιση επικάλυψης διάταξης πλοήγησης + Εμφάνιση εν συντομία κατά το άνοιγμα του προγράμματος ανάγνωσης + Εμφάνιση επικάλυψης ζωνών πατήματος Δεξιά Αριστερά Επόμενο @@ -577,7 +573,7 @@ Εξαίρεση: %s Συμπερίληψη: %s Κανένα - Ημερομηνία ανάκτησης + Ημερομηνία ανάκτησης κεφαλαίου Τα Manga σε εξαιρούμενες κατηγορίες δεν θα ληφθούν ακόμα κι αν ανήκουν και σε κατηγορίες που περιλαμβάνονται. Αυτόματη λήψη Τα manga στις αποκλεισμένες κατηγορίες δεν θα ενημερώνονται ακόμη και αν βρίσκονται επίσης στις συμπεριλαμβανόμενες κατηγορίες. @@ -673,10 +669,10 @@ Γλώσσα Προειδοποίηση Συνιστάται ιδιαίτερα η δημιουργία αυτόματων αντιγράφων ασφαλείας. Θα πρέπει να διατηρείτε αντίγραφα και σε άλλα μέρη. - Οι μεγάλες ενημερώσεις βλάπτουν τις πηγές και μπορεί να οδηγήσουν σε πιο αργές ενημερώσεις και σε αυξημένη χρήση της μπαταρίας + Οι μεγάλες ενημερώσεις βλάπτουν τις πηγές και μπορεί να οδηγήσουν σε πιο αργές ενημερώσεις και σε αυξημένη χρήση της μπαταρίας. Πατήστε για να μάθετε περισσότερα. Μόνο σε Wi-Fi Κάθε 3 ημέρες - Προειδοποίηση: οι μαζικές λήψεις ενδέχεται να οδηγήσουν σε επιβράδυνση των πηγών ή/και αποκλεισμό του Tachiyomi + Προειδοποίηση: οι μαζικές λήψεις ενδέχεται να οδηγήσουν σε επιβράδυνση των πηγών ή/και αποκλεισμό του Tachiyomi. Πατήστε για να μάθετε περισσότερα. Εμφάνιση του αριθμού των μη αναγνωσμένων στο εικονίδιο Ενημερώσεις Ενημέρωση όλων Ενημερώσεις εφαρμογής @@ -720,4 +716,22 @@ Άνοιγμα στο GitHub Τα δεδομένα WebView διαγράφηκαν Διαγραφή δεδομένων WebView + Κλείσιμο + Εμφάνιση διπλότυπων καρφιτσωμένων πηγών + Επανάληψη των καρφιτσωμένων πηγών στις αντίστοιχες γλωσσικές ομάδες τους + Η μπαταρία δεν είναι χαμηλή + Λοιπόν, αυτό είναι άβολο + Δε βρέθηκε εγκατεστημένη πηγή + Αριθμός μη αναγνωσμένων + Τελευταία ενημέρωση manga + Δε βρέθηκε πηγή + Αυτόματη διάσπαση ψηλών εικόνων + Βελτιώνει την απόδοση του αναγνώστη με τη διάσπαση ψηλών εικόνων που έχουν ληφθεί. + Η σελίδα %d δε βρέθηκε κατά τη διάσπαση + Δεν ήταν δυνατή η εύρεση της διαδρομής αρχείου της σελίδας %d + Επαναφέρει τη λειτουργία ανάγνωσης και τον προσανατολισμό όλων των σειρών + Επαναφορά σημαιών προβολής + Δεν ήταν δυνατή η επαναφορά των σημαιών προβολής + Έγινε επαναφορά σημαιών προβολής + Δεν ήταν δυνατή η διαίρεση της εικόνας που έχει ληφθεί \ No newline at end of file diff --git a/app/src/main/res/values-eo/strings.xml b/app/src/main/res/values-eo/strings.xml index 4c2f932c6b..28111000a6 100644 --- a/app/src/main/res/values-eo/strings.xml +++ b/app/src/main/res/values-eo/strings.xml @@ -68,7 +68,6 @@ Sekureco Administri sciigojn Data formato - Hejmekrano Ŝalti Malŝalti Laŭ operaciumo @@ -443,7 +442,6 @@ Laŭ nombro da ĉapitroj Laŭ elŝuta dato Elekti inverse - Laste kontrolitaj Defaŭlte Vi havas neniun kategorion. Tuŝeti la butonon kun plus por krei unu por organizi vian bibliotekon. Kromaĵaj ĝisdatigoj @@ -518,7 +516,6 @@ Aŭtomate aktualigi ŝanĝspurilojn Nur ĝisdatigi okazantaj mangaojn Limigoj: %s - Salti al ĉapitroj je malfermo Longa (Mallonga+, antaŭ n tagoj) Mallonga (Hodiaŭ, Hieraŭ) Jotsuba @@ -567,5 +564,4 @@ Montri tuŝetzonojn kiam malfermas legilon Aŭtomate aktualigi metadatumoj Kaŝi aplikaĵan enhavon kiam ŝaltumas aplikaĵojn kaj malebligi ekrankopion - Kaŝi malsupran breton je rulumi \ No newline at end of file diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml index 748a8db6d1..99ee541240 100644 --- a/app/src/main/res/values-es/strings.xml +++ b/app/src/main/res/values-es/strings.xml @@ -1,9 +1,9 @@ - Español + Nombre - Ajustes - Cola de descargas + Herramientas + Descargas en espera Biblioteca Historial Actualizaciones @@ -12,7 +12,7 @@ Ajustes Filtrar Descargados - No leídos + Sin leer Quitar filtro Buscar Seleccionar todo @@ -153,7 +153,7 @@ Siguientes 5 capítulos Siguientes 10 capítulos Todos - No leídos + Sin leer ¿Seguro que quieres eliminar los capítulos seleccionados\? Leyendo @@ -189,7 +189,7 @@ Buscando actualizaciones… Descargando… - Descarga completa + Toca aquí para instalar Error de descarga ¡Nueva versión disponible! @@ -197,7 +197,7 @@ No hay descargas No hay actualizaciones recientes - Nada leído recientemente + No has leído nada últimamente Tu biblioteca está vacía Error @@ -230,7 +230,6 @@ Aplicación no disponible Semanales Todos - Pantalla inicial Categoría predeterminada Preguntar siempre Recortar bordes @@ -255,7 +254,7 @@ Copias de seguridad automáticas Frecuencia de respaldo Copias de seguridad máximas - Se ha creado la copia de respaldo + Copia de seguridad creada Restauración completada Restaurar utiliza fuentes de Internet para obtener los datos, es posible que te cueste dinero dependiendo de tu tarifa de datos móviles. \n @@ -427,7 +426,6 @@ Actualizando biblioteca Abrir sitio en WebView Buscar actualizaciones de extensiones - Por fecha de comprobación Actualizaciones de extensión Saltar capítulos excluidos por filtros Lectura @@ -486,7 +484,7 @@ Completada en %1$s con %2$s errores La sincronización de estos servicios solo funciona en un solo sentido. Cada manga en tu biblioteca tiene un botón de seguimiento y tendrás que configurarlo a mano, uno a uno. - Capítulos no leídos + Capítulos sin leer Esta extensión no es de la lista oficial de extensiones de Tachiyomi. No oficial Datos @@ -517,17 +515,16 @@ Desactivar Es necesario reiniciar la aplicación para que surja efecto Red - Saltar al listado de capítulos al abrir un manga Estado desconocido Ambos Vertical Horizontal No invertir - Invertir toque + Invertir zonas de toque Autor desconocido Actualizado a v%1$s Qué hay de nuevo - Descargar los capítulos no leídos + Descargar capítulos sin leer No se pudo descargar ningún capítulo, queda muy poco espacio Buscar por «%1$s» en todas las fuentes Modo de lectura @@ -562,7 +559,6 @@ Ajustes de búsqueda Capítulos descargados Manga en la biblioteca - Ocultar la barra inferior al desplazarse Pausa el historial de lectura Modo incógnito Borrar historial @@ -582,7 +578,7 @@ Registros de errores guardados Guarda los registros de errores en un archivo para compartirlos con los desarrolladores Volcar registros de fallos - Diseño de navegación + Zonas de toque Borde En forma de L Descendiente @@ -608,15 +604,15 @@ Si la ubicación de la división de página dual no coincide con la dirección de lectura Invertir la ubicación de la división de página dual División de página dual - Ver zonas de toque al abrir el lector - Ver superposición de navegación + Muestra una vista previa de las zonas al abrir el lector + Ver superposición con zonas de toque Excluir: %s Incluir: %s Ninguna El manga de las categorías excluidas no se actualizará, ni siquiera si pertenece a alguna de las categorías que sí estén incluidas. Toca para ver los detalles del error Mostrar el número de elementos - Por fecha de comprobación + Fecha de obtención del capítulo Tipo de rotación Crea carpetas según el título del manga Guardar páginas en carpetas separadas @@ -644,7 +640,7 @@ Actualizando biblioteca… (%1$d/%2$d) No se han encontrado coincidencias Fuente no soportada - No leídos + Sin leer Este servicio de seguimiento sólo es compatible con la fuente Komga. Error al compartir portada Error al guardar portada @@ -702,12 +698,12 @@ Registro detallado Mostrar registros detallados en el registro del sistema (reduce el rendimiento de la aplicación) Advertencia - Las actualizaciones grandes pueden implicar un mayor uso de la batería y que los distintos servicios bloqueen o ralenticen el acceso a tu dispositivo + Las actualizaciones grandes pueden implicar un mayor uso de la batería y que los distintos servicios bloqueen o ralenticen el acceso a tu dispositivo. Toca aquí para más información. Idioma Es una buena idea tener copias de respaldo automáticas, así como respaldarlas fuera de tu dispositivo. Solo con Wi-Fi Cada 3 días - Advertencia: Las descargas grandes pueden llevar a que las fuentes se vuelvan cada vez más lentas y en casos extremos que los servidores limiten o impidan el acceso a Tachiyomi + Advertencia: Las descargas grandes pueden llevar a que las fuentes se vuelvan cada vez más lentas y en casos extremos que los servidores limiten o impidan el acceso a Tachiyomi. Toca aquí para más información. Mostrar el número de capítulos sin leer en el icono de actualizaciones Actualizar todos Actualizaciones de la aplicación @@ -751,4 +747,22 @@ Abrir en GitHub Se han limpiado los datos del WebView Limpiar datos del WebView + Cerrar + Repetir fuentes ancladas en sus respectivos grupos de idiomas + Mostrar fuentes duplicadas ancladas + Batería cargada + Vaya, hemos tenido algún problemilla + No se ha instalado ninguna fuente + No se ha encontrado ninguna fuente + Última actualización de manga + Recuento no leído + Partir imágenes demasiado altas + Mejora el rendimiento del lector dividiendo páginas descargadas mucho más altas que anchas. + No se ha encontrado la página %d al dividir + La ruta al archivo de la página %d no se encuentra + Restablece el modo de lectura y orientación en toda la biblioteca + Se han restablecido los ajustes del visor + Restablecer indicadores del visor + No se pudieron restablecer los ajustes del visor + No se pudo dividir la imagen descargada \ No newline at end of file diff --git a/app/src/main/res/values-eu/strings.xml b/app/src/main/res/values-eu/strings.xml index 371a860cb8..8133c24e21 100644 --- a/app/src/main/res/values-eu/strings.xml +++ b/app/src/main/res/values-eu/strings.xml @@ -471,7 +471,6 @@ Laburra (Gaur, Atzo) Luzea (Laburra+, duela n egun) Dataren formatua - Hasierako pantaila Berretsi irteera Kudeatu jakinarazpenak Segurtasuna @@ -484,7 +483,6 @@ Gaur Bistaratu Errenkada bakoitzeko elementu kopurua - Joan kapituluetara irekitzean Eguneraketa globalak Eguneratze automatikoak Irakurri gabeko kapituluak ditu @@ -547,7 +545,6 @@ Mangak guztira Kapituluak guztira Azken aldiz irakurria - Azken aldiz egiaztatua Azken kapitulua Eskuratze data Mugitu gora @@ -585,7 +582,6 @@ Goian Erdian Behean - Ezkutatu beheko barra mugitzean Denbora-zigiluak Denbora-zigilu erlatiboak Itzali diff --git a/app/src/main/res/values-fa/strings.xml b/app/src/main/res/values-fa/strings.xml index 607ba75cf5..84130dc2c8 100644 --- a/app/src/main/res/values-fa/strings.xml +++ b/app/src/main/res/values-fa/strings.xml @@ -1,16 +1,16 @@ - عکس روی جلد مانگا + کاور مانگا آپدیت برای یک افرونه موجود است آپدیت برای %d افرونه موجود است نسخه جدید موجود است! خطا در دانلود - دانلود تکمیل شد + دانلود کامل شد در حال دانلود… در حال جستجوی آپدیت‌ها … - هیچ آپدیت جدیدی موجود نیست + آپدیت جدیدی موجود نیست دانلود فایل پشتیبان را انتخاب کنید عکس روی جلد را انتخاب کنید @@ -206,17 +206,17 @@ بوک مارک آپدیت افزونه‌ها - آپدیت قسمت‌ها + به روزرسانی قسمت‌ها عمومی دانلود متوقف شد - هیچ اتصال به شبکه در دسترس نیست - اتصال Wi-Fi در دسترس نیست - به دلیل خطای غیرمنتظره قسمت دانلود نشد + اتصال شبکه در دسترس نیست + اتصال وای فای در دسترس نیست + به علت خطای غیرمنتظره بارگیری این چپتر، ممکن نیست خطا - سیستم دانلود - لطفا برنامه WebView را برای سازگاری بهتر آپدیت کنید - WebView برای Tachiyomi مورد نیاز است - عدم موفقیت در دور زدن Cloudflare + سیستم دانلود کننده + لطفا برنامه وب نما را برای سازگاری بهتر آپدیت کنید + وب نما برای تاچیومی مورد نیاز است + عدم موفقیت در دور زدن کولدفیر opacity آبی سبز @@ -323,7 +323,6 @@ مدیریت اعلان‌ها هنگام خروج از برنامه تایید گرفته شود فرمت تاریخ - صفحه اغازین روشن خاموش تم پیش‌فرض سیستم @@ -462,7 +461,6 @@ جست و جوی کامل جست و جو اخرین قسمت - اخیرا دیده شده آخرین خوانده ‌شده کل قسمت‌ها الفبا @@ -501,13 +499,11 @@ شبکه ردیابی هایی که به سیستم وارد نشده اند: حالت خواندن - برنامه در تب \"قسمت ها\" باز شود تم غیرفعال کردن دانلود قسمت‌های خوانده‌نشده تاریخ اضافه شدن به نسخه v%1$s آپدیت شد - نوار پایین هنگام اسکرول کردن پنهان شود جست و جوی تنضیمات قسمت های دانلود شده مانگاهای کتابخانه @@ -532,7 +528,7 @@ افقی هیچ کدام ضربه زدن معکوس - تنظیمات قسمت پیش فرض به روز شد + تنظیمات پیش فرض چپتر به روز شد %1$s: %2$s, صفحه %3$d لطفا دوباره به MAL وارد شوید تنظیمات قسمت ها @@ -563,4 +559,13 @@ احراز هویت جهت تایید تغییرات سرویس های بهینه شده خوانده نشده + این نسخه آندروید دیگر پشتیبانی نمی‌شود + بازکردن در گیت هاب + راهنمای شروع + شما هنوز هیچ دسته‌بندی ندارید. + بروزرسانی برنامه + هدایت به پن + بزرگنمایی تصویر چشم انداز + نسخه جدیدی از نسخه‌های رسمی موجود است. برای یادگیری نحوه انتقال از نسخه‌های غیررسمی اف دروید، ضربه بزنید. + رد شده \ No newline at end of file diff --git a/app/src/main/res/values-fi/strings.xml b/app/src/main/res/values-fi/strings.xml index 5b7e004a41..58734a0233 100644 --- a/app/src/main/res/values-fi/strings.xml +++ b/app/src/main/res/values-fi/strings.xml @@ -136,7 +136,6 @@ Latauksessa Sarja on päättynyt Päivitä luvun edistyminen lukemisen jälkeen - Aloitusnäyttö Oletus kategoria Kysy aina Kaikki @@ -388,7 +387,6 @@ Vanhin Siirrä alkuun Siirrä loppuun - Viimeksi tarkistettu Tarkista laajennuspäivitykset Laajennuspäivitys saatavilla @@ -486,7 +484,6 @@ Edellyttää sovelluksen käynnisstämisen uudelleen Verkko - Siirry lukuihin avatessa Molemmat Pystysuora Vaakasuora @@ -531,7 +528,6 @@ Hakuasetukset Ladatut luvut Manga kirjastosta - Piilota alapalkki selatessa Keskeyttää lukuhistorian Incognito-tila Tyhjennä historia diff --git a/app/src/main/res/values-fil/strings.xml b/app/src/main/res/values-fil/strings.xml index caf2f77b92..b8a9a11bce 100644 --- a/app/src/main/res/values-fil/strings.xml +++ b/app/src/main/res/values-fil/strings.xml @@ -65,26 +65,25 @@ Panlahatang Paghanap Maghanap Pinakabagong kabanata - Huling tiningnan Huling binasa Dami ng kabanata Pa-alpabeto - Wag na\'ng isala + Tanggalin ang filter Babasahin Tinandaan Na-download - Isala + I-filter Pagpipilian Pagsasaayos Pindutin muli para umalis Buksan ang Tachiyomi - Kasaysayan + Nakaraan Tina-track Mga Kabanata Manga - Mga Kategorya + Kategorya Wala ka pang kategorya. Pindutin ang plus button para makagawa ka ng isa para maayos mo ang Aklatan mo. - Walang laman ang Aklatan mo + Bakante ang Aklatan mo Walang binasa kamakailan Walang bago Walang dina-download @@ -94,10 +93,10 @@ Paglipat Pag-backup at Pag-restore Mga Source - Kasaysayan + Nakaraan Bago Aklatan - Mga Dina-download + Dina-download Pagsasaayos Higit pa Pangalan @@ -113,7 +112,6 @@ Seguridad Kumpirmahing aalis Ayos ng petsa - Panimulang screen Nakabukas Nakasara Sundan ang sistema @@ -180,21 +178,21 @@ Baligtarin ang pindutan ng volume Pindutan ng volume Nabigasyon - Laktawan ang mga nakasala + Laktawan ang mga na-filter na kabanata Laktawan ang mga nabasa na Panatilihing nakabukas ang screen Padilimin (Burn/Darken) Paliwanagin (Dodge/Lighten) - Iskrin (Screen) + Screen Paramihin (Multiply) Nakapatong (Overlay) - Paghalo ng kulay - Pagsala sa kulay - Pag-ayos ng liwanag + Blend mode ng filter ng kulay + Pinili kong filter ng kulay + Pinili kong liwanag Gupitin ang gilid Nababawasan ang pagkakaroon ng linya, pero dagdag-pasanin ito sa app Totoong kulay (32-bit) - Mabilisang ipakita ang ginagamit na paraan ng pagbasa kapag ang babasahing-aklat ay nakabukas + Mabilis na ipakita ang kasalukuyang ginagamit kapag nakabukas ang reader Ipakita ang paraan ng pagbasa Ipakita ang bilang ng pahina Bilis ng animasyon sa pagdoble-pindot @@ -230,10 +228,10 @@ %d (na) kategorya Palaging tanungin - Panimulang kategorya + Panimulang lagayan Maghanap ng mga bagong cover at detalye kapag nag-a-update ng Aklatan Kusang sariwain ang metadata - Nasa \"Kumpleto\" na estado + May \"Kumpleto\" na estado Naka-charge Kondisyon sa kusang pag-update Linggo-linggo @@ -251,13 +249,12 @@ Itago ang laman ng abiso Tinatago ng seguridad sa screen ang laman ng app habang nagpapalit ng app at hinaharangan din nito ang mga screenshot Bantayan ang screen - Diretso agad sa kabanata pagbukas - Baligtad na pagpindot + Baligtarin ang mga tap zone Nawawalang (mga) source: Walang manga ang backup. May kulang na data sa file. Invalid na backup - Nai-backup na + Nagawa na ang backup Di naka-login: %1$s Di makita ang source: %1$s Dami ng backup @@ -285,7 +282,7 @@ Patayo Pahiga Mga update sa dugtong - Hindi + Wala Mga update sa kabanata Komon Nakahinto ang pag-download @@ -294,8 +291,8 @@ Di ma-download ang kabanata dahil sa isang di-inaasahang error Nagka-error Taga-download - Mangyaring i-update ang WebView para sa mas maayos na paggana - Kinakailangan ng Tachiyomi ang WebView + Paki-update po ang WebView app para sa mas maayos na paggana + Kailangan ng Tachiyomi ang WebView Bigong ma-bypass ang Cloudflare Cover ng manga @@ -304,7 +301,7 @@ May bagong bersyon! Nagka-error sa pag-download - Na-download na + Pindutin para i-install Dina-download… Naghahanap ng mga update… Walang bagong update @@ -331,7 +328,7 @@ May mga bagong kabanata Naghahanap ng mga bagong kabanata Di ma-download ang mga kabanata dahil sa mababang espasyo - Di ma-download ang mga kabanata. Subukan mo uli ito sa Mga Dina-download + Di ma-download ang mga kabanata. Subukan mo uli ito sa Dina-download Kopyahin Ilipat Pumili ng paglilipatang source @@ -357,7 +354,7 @@ Pahina: %1$d Napalitan na ang cover Gawing cover - Aking pagsala + Pinili kong filter Na-save na ang larawan I-reset ang lahat ng kabanata ng manga na ito Tatanggalin nito ang petsa ng pagbasa sa kabanatang ito. Sigurado ka ba\? @@ -377,18 +374,18 @@ Tinigil Kumpleto Binitawan - Binabasa + Pagbabasa Magdagdag ng tracker Pagta-track Invalid na lugar ng paglalagyan Sigurado ka bang gusto mong burahin ang (mga) piniling kabanata\? Babasahin Lahat - Ako na ang bahala + Pinili ko Susunod na 10 kabanata Susunod na 5 kabanata Susunod - Mag-download ng piniling bilang + Mag-download ng pinili kong bilang I-download Base sa petsa ng pag-upload Base sa bilang @@ -434,8 +431,8 @@ Iba pa Lokal na Source Bisitahin ang site sa WebView - Walang resultang nakita - Wala nang mga resulta + Walang nakitang resulta + Wala na\'ng resulta Mga Tab Mga Panukoy Lokal @@ -447,15 +444,15 @@ Mag-logout sa %1$s\? Naka-login ka na Mag-login - Hudyat (password) + Password Email address - Sagisag (username) + Username Mag-login sa %1$s %1$s na lang %1$s na lang - Isalâ ang Aklatan + I-filter ang lahat ng manga sa Aklatan Mga na-download lang Nakatutulong sa pag-ayos sa mga bug. Walang sensitibong data ang ipapadala Ipadala ang mga ulat ng pag-crash @@ -464,7 +461,7 @@ Mga lisensiyang open-source Anong bago Bersyon - Site + Website Di mabuksan ang pagsasaayos ng iyong device Nakapatay na ang pag-o-optimisa sa baterya Patayin ang pag-o-optimisa sa baterya @@ -473,10 +470,10 @@ Sariwain ang pagta-track Sariwain ang mga cover ng manga sa Aklatan Binura na - Sigurado ka ba\? Mawawala ang datos ng mga manga na wala sa Aklatan mo - Burahin ang kasaysayan ng mga manga na hindi nakalagay sa Aklatan mo + Sigurado ka ba talaga\? Mawawala ang lahat ng mga nabasang kabanata at bahagdang nabasa ng mga manga na wala sa Aklatan + Burahin ang nakaraan ng mga manga na hindi nakalagay sa Aklatan mo Linisin ang database - Nagka-error habang nililinis ang cache + Nagka-error habang nililinis Nalinis na ang cache. Binura ang %1$d (na) file Nagamit: %1$s Linisin ang cache ng kabanata @@ -495,7 +492,7 @@ Na-restore na Ginagamit ng Pag-restore ang mga source para kunin ang data, at posible gumastos ka dahil rito. \n -\nSiguraduhing na-install mo na ang mga lahat ng mga kinakailangang dugtong at naka-login ka na sa lahat ng mga source at tracker bago mo simulan ang pag-restore. +\nSiguraduhing na-install mo na ang mga lahat ng mga kailangang dugtong at naka-login ka na sa lahat ng mga source at tracker bago mo simulan ang pag-restore. Rine-restore ang backup Bigong ma-backup Bina-backup @@ -508,7 +505,7 @@ Wala kang naka-pin na pinagkukunan Tapos na - Mga Error + Mga error Takbo Tapos na sa pag-download Di naka-login sa (mga) tracker: @@ -518,8 +515,8 @@ Maaaring may NSFW (18+) 18+ - Lalaktawan ang %d kabanata, siguro baka wala sa source ito, o baka nasala ito - Lalaktawan ang %d (na) kabanata, siguro baka sa source ang mga ito, o baka nasala sila + Lalaktawan ang %d kabanata, siguro baka wala sa source ito, o baka na-filter ito + Lalaktawan ang %d (na) kabanata, siguro baka sa source ang mga ito, o baka na-filter sila Walang nakitang kabanata Gusto mo bang i-save at ipagpaubaya ang pagsasaayos na ito\? @@ -530,13 +527,12 @@ Pagsasaayos ng Kabanata Mga naka-download na kabanata Manga mula sa Aklatan - Itago ang bottom bar pagka-scroll Maghanap - Hinihinto ang pagtala sa mga binabasa + Hinihinto ang pagtala sa nakaraan Nakatago - Linisin ang kasaysayan - Linis na ang buong kasaysayan - Sigurado ka ba\? Lilinisin nito ang buong kasaysayan ng binuksan mo. + Linisin ang nakaraan + Nalinis na ang nakaraan + Sigurado ka ba talaga\? Mawawala ang buong nakaraan. Gabay sa Paglipat ng Source Abante Balik @@ -550,9 +546,9 @@ Itambak ang mga crash log Nai-save na ang crash log Sine-save ang mga error log sa isang file para maibahagi sa mga developer - Layout ng nabigasyon + Mga tap zone Sulok - mala-Kindle + Mala-Kindle Hugis-L Pababa Pataas @@ -574,8 +570,8 @@ Kaliwa Susunod Nakaraan - Ipakita ang lugar na ita-tap kapag nakabukas ang tagabasa - Ipakita ang overlay ng ayos ng nabigasyon + Mabilis na ipakita ang lugar na ita-tap kapag nakabukas ang reader + Ipakita ang mga overlay ng tap zone Di-kasama: %s Kasama: %s Wala @@ -596,14 +592,14 @@ Ikansela lahat para sa seryeng ito I-update ang tracker tuwing nag-a-update ang Aklatan Kusang sariwain ang tracker - Kaayusan ayon sa + Ayusin ayon sa Restriksyon: %s Walang nahanap na kapares Petsa - Walang bisa ang ayos ng kabanata + Invalid na format ng kabanata Hindi makita ang kabanata Di suportado ang source - Hindi nababasa + Di pa nabasa Gitna Hilera ng nabigasyon sa gilid Di maibahagi ang cover @@ -670,13 +666,13 @@ Bilang ng manga Verbose na pagla-log Mag-print ng mga verbose na log sa log ng sistema (dagdag-pasanin sa app) - Babala: Nakasasama sa source at maaaring humantong sa mabagal na update at pagtaas ng paggamit sa baterya kung maraming ia-update nang sabay + Babala: Nakasasama ang mga malalaking update sa source at maaaring humantong sa mabagal na update at pagtaas ng paggamit sa baterya. Pindutin para matuto pa. Wika Babala Rinerekomenda po namin ang kusang pag-backup. Kailangan mo ring magtabi ng mga kopya sa ibang lugar. Sa Wi-Fi lang Kada 3 araw - Babala: maaaring humantong sa pagbagal ng mga source at/o pagharang sa Tachiyomi kung magda-download nang maramihan + Babala: maaari pong humantong sa pagbagal at/o pagharang ng mga source sa Tachiyomi ang mga malalaking maramihang pag-download. Pakipindot po ito para matuto pa. Ipakita ang bilang ng di pa nabasa sa Bago Mga update sa app I-update lahat @@ -686,13 +682,13 @@ Bigong makuha ang mga dugtong Patakaran sa Pagkapribado Para makahingi ng tulong sa pag-ayos sa mga error sa pag-update ng Aklatan, tingnan ang %1$s - May hindi nababasang kabanata + May di pa nababasang kabanata Laktawan ang pag-update I-save bilang CBZ archive Tapos na\'ng mailathala Naka-hiatus Kinansela - Error: walang URI + Error: bakanteng URI Mga Madalas Itanong at Gabay 5% Ipakita ang manga @@ -700,7 +696,7 @@ Pabalat lang Nilaktawan dahil tapos na ang serye Hindi pa nasisimulan - Nilaktawan dahil may hindi pa nababasang kabanata + Nilaktawan dahil may di pa nababasang kabanata Nilaktawan dahil wala pang nababasang kabanata May entry ka sa Aklatan na may kaparehong pangalan pero galing sa ibang source (%1$s). \n @@ -709,7 +705,7 @@ Gumalaw para mag-pan Matuto pa Nilaktawan - Pumalya ang %1$d (na) update + Nabigo ang %1$d (na) update Baligtad na patayo Nilaktawan ang %1$d (na) update Ilagay sa taas ang serye @@ -718,4 +714,19 @@ Buksan sa Github Error sa pag-save sa larawan May available na bagong bersyon sa mga opisyal na release. Pindutin para matuto pa kung paano lumipat mula sa mga di-opisyal na F-Droid release. + Nalinis na ang WebView data + Linisin ang WebView data + Isara + Di pa lowbat + Ipakita ang mga dinobleng naka-pin na source + Ulitin ang pag-pin sa mga source sa kani-kanilang mga wika + Walang nakitang naka-install na source + Ano, paano ba \'to + Walang nakitang source + Huling update sa manga + Dami ng di pa nabasa + Kusang hatiin ang mga matatangkad na larawan + Pinapahusay ang performance ng reader sa pamamagitan ng paghati sa mga matatangkad na na-download na larawan. + Hindi nakita ang pahina %d habang naghahati + Di makita ang file path ng pahina %d \ No newline at end of file diff --git a/app/src/main/res/values-fr/strings.xml b/app/src/main/res/values-fr/strings.xml index 59df96cc4a..9e661f9c1b 100644 --- a/app/src/main/res/values-fr/strings.xml +++ b/app/src/main/res/values-fr/strings.xml @@ -78,7 +78,6 @@ Appareil en charge Avec le statut « achevé » Synchroniser la progression après lecture - Page d\'accueil Plein écran Activer les transitions @@ -217,7 +216,7 @@ Vérification des mises à jour… Téléchargement en cours… - Téléchargement terminé + Appuyer pour installer Erreur lors du téléchargement Mise à jour disponible ! @@ -429,7 +428,6 @@ Consultez le site Web de WebView Vérifier les mises à jour d’extensions - Dernière vérification Mise à jour de la bibliothèque Sources 25 % @@ -475,7 +473,7 @@ N\'inclure que les sources épinglées Gris Pour cette série - Réduit les bandes de couleur mais affecte les performances + Réduit les bandes de couleur, mais peut impacter les performances %d catégorie %d catégories @@ -524,10 +522,9 @@ Vertical Horizontal Non - Inverser les touches + Inverser les zones tactiles Statut inconnu Auteur inconnu - Aller aux chapitres à l\'ouverture Quoi de neuf Mise à jour de v%1$s Télécharger les chapitres non lus @@ -550,7 +547,7 @@ Supprimer des chapitres Peut contenir du contenu +18 18+ - Cela n\'empêche pas les extensions non officielles ou potentiellement mal signalées de diffuser du contenu +18 dans l\'application. + Ceci n\'empêche pas les extensions non officielles ou potentiellement mal signalées de diffuser du contenu +18 dans l\'application. %d chapitre a été sauté, soit la source ne l\'a pas, soit il a été filtré %d chapitres ont été sautés, soit la source ne l\'a pas, soit il ont été filtrés @@ -558,7 +555,6 @@ Aucun chapitre trouvé Appliquer ce paramétrage par défaut \? Paramètres du chapitre - Cacher la barre inférieure lors du défilement Appliquer à ma librairie Appliquer par défaut %1$s : %2$s, page %3$d @@ -581,11 +577,11 @@ Registres d\'incident Date de fin Date de début - Plutôt provoquant + Style Kindle Registre d\'incident sauvegardé Archivage des registres d\'incident Enregistre les traces d\'incident dans un fichier pour les partager avec les développeurs - Plan de navigation + Zones tactiles Bord En forme de L Décroissant @@ -606,12 +602,12 @@ Droite Gauche Suivant - Afficher les zones tactiles quand le lecteur est ouvert - Afficher la superposition de la disposition de la navigation + Afficher brièvement lorsque le lecteur est ouvert + Afficher les zones tactiles (superposition) Exclure : %s Inclure : %s Aucun - Date récupérée + Date de récupération du chapitre Les mangas dans les catégories exclues ne seront pas mis à jour même s\'ils sont aussi dans les catégories inclues. Les mangas des catégories exclues ne seront pas mis à jour même s\'ils appartiennent aussi à des catégories incluses. Téléchargement automatique @@ -706,11 +702,11 @@ Imprimer les journaux détaillés dans le journal du système (réduit les performances de l\'application) Langue Attention - Les mises à jour importantes nuisent aux sources et peuvent entraîner un ralentissement des mises à jour ainsi qu\'une augmentation de l\'utilisation de la batterie + Les mises à jour importantes nuisent aux sources et peuvent entraîner un ralentissement des mises à jour ainsi qu\'une augmentation de l\'utilisation de la batterie. Appuyez pour en savoir plus. Les sauvegardes automatiques sont fortement conseillées. Nous vous recommandons aussi de conserver des copies ailleurs. Uniquement en Wi-Fi Tous les 3 jours - Avertissement : les téléchargements massifs peuvent entraîner un ralentissement des sources ou le blocage de Tachiyomi + Avertissement : les téléchargements massifs peuvent entraîner un ralentissement des sources ou le blocage de Tachiyomi. Appuyez pour en savoir plus. Afficher le nombre de messages non lus sur l\'icône des mises à jour Tout mettre à jour Mises à jour de l\'application @@ -752,4 +748,23 @@ Une nouvelle version est disponible à partir des versions officielles. Appuyez pour apprendre comment migrer depuis les versions non officielles de F-Droid. Aucune entrée de bibliothèque à sauvegarder Ouvrir sur GitHub + Effacer les données WebView + Données WebView effacées + Fermer + Batterie non faible + Répéter les sources épinglées dans leurs groupes linguistiques respectifs + Afficher les sources épinglées en double + Aucune source installée trouvée + Eh bien, c\'est gênant + Dernière mise à jour du manga + Nombre de non-lus + Aucune source trouvée + Division automatique des grandes images + Améliore les performances du lecteur en fractionnant les grandes images téléchargées. + Page %d introuvable lors du fractionnement + Impossible de trouver le chemin du fichier de la page %d + Réinitialiser les paramètres du lecteur + Réinitialise le mode de lecture et l\'orientation de toutes les séries + Paramètres du lecteur réinitialisés + Impossible de réinitialiser les paramètres du lecteur \ No newline at end of file diff --git a/app/src/main/res/values-gl/strings.xml b/app/src/main/res/values-gl/strings.xml index 0814a0aed8..4fe4003311 100644 --- a/app/src/main/res/values-gl/strings.xml +++ b/app/src/main/res/values-gl/strings.xml @@ -129,7 +129,6 @@ Manual Frecuancia de actualización da biblioteca Actualizacións - Saltar aos capítulos abertos Horizontal Vertical Elementos por fila @@ -153,10 +152,8 @@ Fontes NSFW (+18) Seguridade Xestionar notificacións - Esconder a barra inferior ao desprazar Confirmar saír Formato de data - Pantalla inicial Encendido Apagado Utilizar o do sistema @@ -239,7 +236,6 @@ Procurar Data de engadido Capítulo máis recente - Última comprobación Último leído Capítulos totais Alfabéticamente diff --git a/app/src/main/res/values-he/strings.xml b/app/src/main/res/values-he/strings.xml index b6493332c9..1a63c209ad 100644 --- a/app/src/main/res/values-he/strings.xml +++ b/app/src/main/res/values-he/strings.xml @@ -124,7 +124,7 @@ תיאור מנגה זו הוסרה ממסד הנתונים. המאוחר ביותר - חיפוש כללי… + חיפוש גלובלי… אחר מאנגה מקומית בדוק אתר ב-WebView @@ -190,7 +190,6 @@ אבטחה ניהול התראות תבנית תאריך - מסך פתיחה פעיל כבוי מצב חשוך @@ -219,7 +218,6 @@ מיון בטל הכל תצוגה - נבדק לאחרונה מורד מעקב עוד @@ -246,18 +244,18 @@ גרסה אופטימיזציית סוללה כבר מושבתת עוזר בעדכוני ספריות רקע וגיבויים - השבת אופטימיזציה של סוללה + השבתת האופטימיזציה של הסוללה עדכן סטטוס, ציון ופרק אחרון שנקרא משירותי המעקב הרשומות נמחקו - האם אתה בטוח\? פרקים שנקראו וההתקדמות של מאנגה שאינה מספרייה תאבד - מחק מנגה ופרקים שאינם בספריה שלך - נקה מסד נתונים + האם אתה בטוח\? פרקים שנקראו וההתקדמות של מנגה שאינה בספרייה יאבדו + מחק את היסטוריית המנגה שאינם שמורים בספריה שלך + נקה את מסד הנתונים עוגיות נוקו נקה עוגיות - אירעה שגיאה במהלך ניקוי זכרון המטמון - זכרון מטמון נוקה. %1$d קבצים נמחקו + אירעה שגיאה במהלך הניקוי + זיכרון המטמון נוקה. %1$d קבצים נמחקו בשימוש: %1$s - נקה את זכרון מטמון של הפרקים + נקה את זיכרון המטמון של הפרקים מייצר גיבוי משחזר גיבוי מה אתה רוצה לגבות\? @@ -417,7 +415,6 @@ מצב קריאה מעקב נושא - הסתר את הפס התחתון בזמן גלילה ארוך (קצר+, לפני n ימים) אשר יציאה מקורות NSFW (18+) @@ -425,7 +422,6 @@ זה לא מונע תוספים לא רשמיים או תוספים שעלולים לסמן באופן שגוי מלהציג תוכן NSFW (18+) בתוך האפליקציה. היום תצוגה - קפצו לפרקים בפתיחה עדכן עוקבים בעת עדכון הספרייה אפשר הכל השבת הכל @@ -550,4 +546,94 @@ לא מחובר ל: %1$s שגיאה: URI ריק מעקב + נקה את זיכרון המטמון של הפרקים כשהאפליקציה נסגרת + יש %1$d מנגה שנמצאות במסד הנתונים אבל לא בספרייה + תגים + לשוניות + חפש את \"%1$s\" גלובלית + מצב לא ידוע + מורשה, בעל רישיון + הפרסום הסתיים + + פרק אחד + שני פרקים + %1$s פרקים + %1$s פרקים + + נכשלה ההעתקה ללוח + לפי תאריך העלאה + הכריכה נשמרה + שגיאה בשמירת הכריכה + שגיאה בשיתוף הכריכה + קבע כברירת המחדל + מצב קריאה + מנגה מתוך הספרייה + פרקים שהורדו + כריכה + יותר + פחות + כבר מתרחש גיבוי + מדריך למנגה מקומית + אין מקורות נעוצים + פרק לא נמצא + לסדרה הזאת + מידע מקובץ הגיבוי ישוחזר. +\n +\nלאחר מכן צריך להתקין הרחבות חסרות ולהתחבר לשירותי המעקב כדי להשתמש בהם. + יכול להיות שהגיבוי/השחזור לא יעבדו כמו שצריך אם אופטמיזציית MIUI מנועה. + הגיבוי נכשל + שחזור הגיבוי נכשל + דרוש אתחול לאפליקציה כדי שהשינויים יחולו + מדיניות פרטיות + הוסף לספרייה + הועתק ללוח: +\n%1$s + לא נמצאו פרקים + תאריך התחלה + תאריך סיום + מה חדש + עזור לתרגם + רק מה שהורד + דפדפן + לא נקרא + קריאה + + 1 נשאר + 2 נשארו + %1$s נשארו + %1$s נשארו + + התחברות + נעוץ + %02d דקות, %02d שניות + השחזור בוטל + עדכונים אוטומטיים מאוד מומלצים. רצוי לשמור עותקים נוספים במקומות אחרים. + מסד הנתונים נקי + בדוק עדכונים + סדר ע\"י + תאריך + מחבר לא ידוע + מצב פרטי + סינון כל המנגה בספרייה שלך + אתר + מידע + שגיאה בשמירת התמונה + %1$s: %2$s עמוד %3$d + עוצר את קריאת ההיסטוריה + ביטול מצב פרטי + הורדה + + הושלם ב %1$s עם שגיאה אחת + הושלם ב %1$s עם שתי שגיאות + הושלם ב %1$s עם %2$s שגיאות + הושלם ב %1$s עם %2$s שגיאות + + רשת + בוטל/ה + בתוך הספרייה + הגדרות פרק + האם אתה בטוח שאתה רוצה לשמור את ההגדרות האלה כברירת המחדל\? + כבר מתרחש שחזור + לא נמצאו עמודים + מקור לא נמצא \ No newline at end of file diff --git a/app/src/main/res/values-hi/strings.xml b/app/src/main/res/values-hi/strings.xml index 27cb7b825c..dc32c876e3 100644 --- a/app/src/main/res/values-hi/strings.xml +++ b/app/src/main/res/values-hi/strings.xml @@ -86,7 +86,6 @@ चार्ज होते समय पूरी की गई श्रृंखला पढ़ने के बाद प्रगति अपडेट करें - प्रथम प्रदर्शनी डिफ़ॉल्ट श्रेणी हमेशा पूछे पूर्ण स्क्रीन @@ -158,7 +157,7 @@ अध्याय कैश साफ़ करें उपयोग किया गया: %1$s कैश साफ़ किया गया %1$d फ़ाइलों को हटा दिया गया है - कैश साफ़ करने के दौरान एक त्रुटि हुई + साफ़ करने के दौरान त्रुटि हुई कुकीज़ को साफ़ करें कुकीज़ को साफ़ किया हुआ डेटाबेस साफ़ करें @@ -241,7 +240,7 @@ कोई नया अद्यतन उपलब्ध नहीं है अपडेट के लिए खोज… डाउनलोड… - डाउनलोड सम्पन्न हुआ + इंस्टॉल करने के लिए दबाएं डाउनलोड त्रुटि नया संस्करण उपलब्ध है! मंगा का आवरण @@ -388,7 +387,6 @@ सबसे पुराना शीर्ष पर ले जाएँ नीचे की ओर ले जाएं - अंतिम बार जाँच की गई एक्सटेंशन अपडेट की जांच करें एक्सटेंशन अपडेट उपलब्ध @@ -442,7 +440,7 @@ पढ़न मोड इस श्रृंखला के लिए ग्रे - बैंडिंग को कम करता है, लेकिन प्रदर्शन को प्रभावित करता है + बैंडिंग को कम करता है, लेकिन प्रदर्शन को प्रभावित कर सकता है %d श्रेणी %d श्रेणियाँ @@ -485,12 +483,11 @@ %1$s अध्याय नेटवर्क - खुलने पर अध्यायों पर जाएं दोनों शीर्ष से असंतत क्षैतिज कोई नहीं - उलटा दोहन + टैप ज़ोन उलटें अज्ञात स्थिति अज्ञात लेखक प्रभावी होने के लिए एप्लिकेशन पुनरारंभ की आवश्यकता होती है @@ -530,7 +527,6 @@ %1$s: %2$s, पृष्ठ %3$d डाउनलोड किए गए अध्याय पुस्तकालय से मंगा - स्क्रॉल पर नीचे बार छिपाएं खोज सेंटिंग इतिहास पढ़ने से रोक देता है इंकॉग्निटो मोड @@ -550,7 +546,7 @@ क्रैश लॉग सहेजे गए डेवलपर्स के साथ साझा करने के लिए फ़ाइल में त्रुटि लॉग सहेजता है डंप क्रैश लॉग - नेविगेशन लेआउट + टैप ज़ोन दाएं और बाएं धार किंडल-जैसे @@ -593,7 +589,7 @@ शुरू उच्च टैबलेट यूआई - नेविगेशन लेआउट ओवरले दिखाएं + टैप ज़ोन ओवरले दिखाएं कार्रवाई डिफॉल्ट स्रोत समर्थित नहीं है @@ -647,7 +643,7 @@ पुस्तकालय अपडेट हो रही है… (%1$d/%2$d) आपके पास अभी तक कोई श्रेणी नहीं है। परिवर्तन की पुष्टि करने के लिए प्रमाणित करें - लाई गई तिथि + अध्याय लाई की तिथि मुहर सापेक्ष टाइमस्टैम्प बहिष्कृत श्रेणियों की पुस्तकें अपडेट नहीं की जाएंगी, भले ही वे भी शामिल श्रेणियों में हों। @@ -668,15 +664,15 @@ यह एंड्राइड संस्करण अब समर्थित नहीं है प्रारंभिक मार्गदर्शन यह ट्रैकर केवल Komga स्रोत के साथ संगत है। - रीडर खोले जाने पर टैप ज़ोन दिखाएं + रीडर खोले जाने पर थोड़ी देर दिखाएं सॉर्ट और डिस्प्ले के लिए प्रति-श्रेणी सेटिंग्स अपडेट आइकन पर अपठित संख्या दिखाएं सभी अद्यतन करें चेतावनी भाषा स्वचालित बैकअप की अत्यधिक अनुशंसा की जाती है। आपको अन्य जगहों पर भी प्रतियां रखनी चाहिए। - चेतावनी: बड़े बल्क डाउनलोड के कारण स्रोत धीमे हो सकते हैं और/या टैचियोमी को अवरुद्ध कर सकते हैं - चेतावनी: बड़े अपडेट स्रोतों को नुकसान पहुंचाते हैं और इससे धीमे अपडेट हो सकते हैं और बैटरी का उपयोग भी बढ़ सकता है + चेतावनी: बड़े बल्क डाउनलोड के कारण स्रोत धीमे हो सकते हैं और/या टैचियोमी को अवरुद्ध कर सकते हैं। अधिक जानने के लिए टैप करें + चेतावनी: बड़े अपडेट स्रोतों को नुकसान पहुंचाते हैं और इससे धीमे अपडेट हो सकते हैं और बैटरी का उपयोग भी बढ़ सकता है। अधिक जानने के लिए टैप करें ऐप अपडेट हर 3 दिन केवल वाई-फ़ाई पर @@ -684,7 +680,7 @@ ऐप बंद करते समय चैप्टर कैशे साफ़ करें डेटाबेस साफ़ करें अपठित अध्याय हैं - अद्यतन न करें + किताब अद्यतन न करें CBZ आर्कैव के रूप में सहेजें गोपनीयता नीति लाइब्रेरी अपडेट त्रुटियों को ठीक करने के तरीके पर सहायता के लिए, %1$s देखें @@ -696,11 +692,11 @@ प्रकाशन समाप्त ५% छोड़े गए - अधिक जानकारी + अधिक जानकारी के लिए दबाए छोड़े गए क्योंकि श्रृंखला पूरी हो गई है छोड़ दिया गया क्योंकि वहाँ अपठित अध्याय हैं छोड़ दिया गया क्योंकि कोई अध्याय पढ़ा नहीं गया - कोई अध्याय नहीं पढ़ा + जो शुरू नहीं हुए हैं मंगा दिखाएँ शुरू किया गया केवल कवर ग्रिड @@ -714,4 +710,23 @@ पैन पर नेविगेट करें ज़ूम लैंडस्केप इमेज श्रृंखला को शीर्ष पर ले जाएं + कोई स्रोत नहीं मिला + कोई स्थापित स्रोत नहीं मिला + आखिरी किताब अद्यतन + अपठित + बैटरी कम नहीं + वेब्यु डेटा साफ हो गया + गिटहब में खोलें + खैर, यह अजीब है + चित्र सहेजने में त्रुटि + लंबी डाउनलोड किए गए चित्रों के हिस्से करके पाठमाला के प्रदर्शन में सुधार लाता है + पेज %d हिस्से करते वक्त नहीं मिला + बंद करे + वेबव्यू डाटा साफ करें + एक जैसे पिन किए गए स्रोत दिखाएँ + उनके संबंधित भाषा समूहों में पिन किए गए स्रोतों को फिर से दिखाएं + चित्र %d का फ़ाइल पथ नहीं खोजा जा सका + बैकअप करने के लिए कोई पुस्तकालय प्रविष्टि नहीं + एक नया संस्करण आधिकारिक रिलीज के द्वारा उपलब्ध है। अनौपचारिक F-Droid रिलीज से माइग्रेट करने का तरीका जानने के लिए टैप करें + लंबे चित्रों की ऑटो हिस्से \ No newline at end of file diff --git a/app/src/main/res/values-hr/strings.xml b/app/src/main/res/values-hr/strings.xml index e638a3102f..3fe2952ff9 100644 --- a/app/src/main/res/values-hr/strings.xml +++ b/app/src/main/res/values-hr/strings.xml @@ -61,7 +61,6 @@ Upravljaj obavijestima Potvrdi zatvaranje programa Format datuma - Početni ekran Slijedi sustav Uključeno Isključeno @@ -153,7 +152,6 @@ Globalna pretraga Traži Najnovije poglavlje - Zadnji put provjereno Zadnje čitano Ukupan broj poglavlja Abecednim redom @@ -502,7 +500,6 @@ Preokreni dodirivanje Nepoznato stanje Nepoznat autor - Skoči na poglavlja nakon pokretanja Preuzmi nepročitana poglavlja Aktualizirano na v%1$s Što je novo @@ -542,7 +539,6 @@ Postavke pretrage Manga iz biblioteke Preuzeta poglavlja - Sakrij donju traku pri klizanju Anonimni modus Zaustavlja čitanje povijesti Izbriši povijest diff --git a/app/src/main/res/values-hu/strings.xml b/app/src/main/res/values-hu/strings.xml index e4eae6a5df..cb7c79291b 100644 --- a/app/src/main/res/values-hu/strings.xml +++ b/app/src/main/res/values-hu/strings.xml @@ -41,7 +41,6 @@ Frissítési korlátozások Töltés Csak a jelenleg futó mangákat frissítse - Kezdőképernyő Alapértelmezett kategória Mindig kérdezzen rá Teljes képernyő @@ -154,7 +153,6 @@ Összes kikapcsolása Összes engedélyezése Kiválasztás megfordítása - Utoljára ellenőrizve Menü A befejezéshez nyomd meg újfent a Vissza gombot Tachiyomi feloldása @@ -178,7 +176,6 @@ Letöltés kész E-mail-cím NSFW (18+) források - Az alsó sáv elrejtése görgetéskor Fejezetszám Eredeti méret Utoljára olvasott fejezet @@ -216,7 +213,6 @@ Új borító és részletek keresése a könyvtár frissítésekor Metaadatokat frissítse automatikusan Minden frissítése - Megnyitáskor ugrás a fejezetekhez Megjelenés Ez nem akadályozza meg a nem hivatalos vagy az esetlegesen helytelenül megjelölt bővítményeket a 18+-os tartalmak megjelenítésétől az alkalmazáson belül. Megjelenítés a forrás- és kiterjesztéseklistában diff --git a/app/src/main/res/values-in/strings.xml b/app/src/main/res/values-in/strings.xml index 7255ae5b06..4874c01972 100644 --- a/app/src/main/res/values-in/strings.xml +++ b/app/src/main/res/values-in/strings.xml @@ -6,7 +6,7 @@ Pelacakan Riwayat Pengaturan - Antrean unduhan + Antrian unduhan Pustaka Riwayat Pembaruan @@ -84,7 +84,6 @@ Mengisi daya Dengan status \"Selesai\" Perbarui kemajuan setelah membaca - Layar awal Kategori bawaan Selalu tanya Layar penuh @@ -232,7 +231,7 @@ Pembaruan tidak tersedia Mencari pembaruan… Mengunduh… - Mengunduh selesai + Ketuk untuk menginstal Terjadi kesalahan saat mengunduh Versi baru tersedia! Sampul manga @@ -386,7 +385,6 @@ Pembaruan ekstensi Periksa pembaruan ekstensi Membaca - Terakhir diperiksa WebView dibutuhkan untuk Tachiyomi Terdapat %d perbaruan ekstensi @@ -432,7 +430,7 @@ %02d menit, %02d detik Hanya sertakan sumber yang ditandai Mode membaca - Mengurangi banding, namun mengurangi performa + Mengurangi banding, namun berdampak pada performa %d kategori @@ -474,13 +472,12 @@ Mulai ulang aplikasi untuk menerapkan pengaturan Jaringan - Lompat ke bab saat dibuka Matikan Keduanya Tegak Mendatar Tidak - Ketukan terbalik + Balikkan zona ketuk Status tidak diketahui Penulis tidak diketahui Diperbarui ke v%1$s @@ -523,7 +520,6 @@ Hapus riwayat Apakah anda yakin\? Semua riwayat akan terhapus. Riwayat telah dihapus - Sembunyikan bilah bawah saat scroll halaman Sumber NSFW (18+) Halaman selanjutnya Halaman sebelumnya @@ -544,12 +540,12 @@ Tanggal mulai Log kerusakan disimpan Simpan log kerusakan ke sebuah berkas untuk dibagikan dengan pengembang aplikasi - Tata letak navigasi + Zona ketuk Kanan dan Kiri Tampilkan jumlah item Kosong Ketuk untuk melihat detail - Tanggal diambil + Tanggal pengambilan bab Aksi Kanan Kiri @@ -579,7 +575,7 @@ Manga dalam kategori yang dikecualikan tidak akan diunduh meskipun termasuk dalam kategori yang disertakan. Jenis rotasi Skala abu-abu - Tampilkan tata letak navigasi + Tampilkan zona ketukan Manga dalam kategori yang dikecualikan tidak akan diperbarui meskipun masuk dalam kategori yang disertakan. Tanggal Urutkan menurut @@ -587,7 +583,7 @@ Bab tak ditemukan Jika penempatan dari pemisah halaman ganda tidak cocok dengan arah membaca Balikkan penempatan pemisah halaman ganda - Tampilkan zona ketuk ketika pembaca dibuka + Tunjukkan secara singkat saat pembaca dibuka Perbarui pelacak ketika memperbarui pustaka Segarkan pelacak secara otomatis Batasan: %s @@ -654,8 +650,8 @@ Warisan Pemasang Total manga - Pembaruan berskala besar membahayakan sumber, dapat membuat pembaruan lambat dan meningkatkan penggunaan baterai - Peringatan: mengunduh dalam jumlah besar bisa menyebabkan sumber menjadi lambat dan/atau memblokir Tachiyomi + Pembaruan berskala besar membahayakan sumber, dapat membuat pembaruan lambat dan meningkatkan penggunaan baterai. Ketuk untuk mempelajari lebih lanjut. + Peringatan: mengunduh dalam jumlah besar bisa menyebabkan sumber menjadi lambat dan/atau memblokir Tachiyomi. Ketuk untuk mempelajari lebih lanjut. Peringatan Cetak catatan berlebih ke catatan sistem (mengurangi kinerja aplikasi) Pencadangan otomatis sangat disarankan. Anda juga harus menyimpan duplikat di tempat lain. @@ -708,4 +704,17 @@ Buka di Github Membersihkan data WebView Data WebView telah dibersihkan + Tutup + Baterai tidak lemah + Tampilkan duplikasi sumber yang ditandai + Ulang sumber ditandai pada kelompok bahasa masing-masing + Sumber yang diinstal tidak ditemukan + Hadeh, ini aneh + Tidak ada sumber yang ditemukan + Pembaruan manga terakhir + Jumlah yang belum dibaca + Membagi gambar panjang secara otomatis + Meningkatkan kinerja pembaca dengan memisahkan gambar panjang yang diunduh. + Halaman %d tidak ditemukan saat dipisah + Tidak dapat menemukan jalur file halaman %d \ No newline at end of file diff --git a/app/src/main/res/values-it/strings.xml b/app/src/main/res/values-it/strings.xml index fd56cf9a18..f7462432e5 100644 --- a/app/src/main/res/values-it/strings.xml +++ b/app/src/main/res/values-it/strings.xml @@ -73,9 +73,8 @@ Tutte Restrizioni del dispositivo agli aggiornamenti automatici In carica - Con stato «completa» + Con stato «Completata» Aggiorna il tracking dopo la lettura - Schermata iniziale Schermo Intero Animare le transizioni di pagina @@ -221,8 +220,8 @@ Ricerca aggiornamenti… Download in corso… - Download completato - Errore di download + Tocca per installare + Errore di scaricamento Nuova versione disponibile! Copertina del manga @@ -427,7 +426,6 @@ Sposta in cima Più vecchi Più recenti - Ultimo controllo Menù Fonti Libreria in aggiornamento @@ -481,7 +479,7 @@ %02d min, %02d sec Includi solo le fonti fissate Sincronizzazione a senso unico per aggiornare l\'avanzamento del capitolo sui servizi di tracking. Imposta il tracking per i singoli manga dai loro pulsanti di tracking. - Riduce il banding, ma influisce sulle prestazioni + Riduce il banding, ma potrebbe influire sulle prestazioni Una categoria %d categorie @@ -512,7 +510,7 @@ Verticale Orizzontale Nessuno - Inverti il tocco + Inverti le zone di tocco Fonte non trovata %1$s capitolo @@ -526,7 +524,6 @@ Rete Mostra brevemente la modalità corrente all\'apertura del lettore Mostra modalità di lettura - Vai ai capitoli all\'apertura Disabilita Inizia Scarica capitoli non letti @@ -550,7 +547,7 @@ 18+ %d capitolo saltato, la fonte non ce l\'ha o è stato filtrato - %d capitoli saltati, la fonte non ce li ha o sono stati filtrati + %d capitoli saltati, la fonte non li ha o sono stati filtrati Tracker non collegati: Nessun capitolo trovato @@ -564,7 +561,6 @@ Ricerca impostazioni Capitoli scaricati Manga dalla libreria - Nascondi la barra inferiore allo scorrere Sospendi cronologia di lettura Modalità incognito Svuota cronologia @@ -577,7 +573,7 @@ Mostra nelle liste delle fonti e delle estensioni Per favore accedi di nuovo a MAL Nessuna app per la selezione dei file trovata - Layout della navigazione + Zone di tocco Bordo Stile Kindle A forma di L @@ -603,7 +599,7 @@ Escludi: %s Includi: %s Nessuna - Data di recupero + Data di recupero capitolo Download automatico Successivo Precedente @@ -612,8 +608,8 @@ Sinistra I manga in categorie escluse non saranno aggiornati nonostante si trovino anche in categorie incluse. DNS su HTTPS (DoH) - Mostra schema di navigazione - Mostra zone di tocco quando il lettore viene aperto + Mostra sovrapposizione con zone di tocco + Mostra brevemente quando il lettore viene aperto Tocca per vedere i dettagli Questa versione di Android non è più supportata Impossibile copiare negli appunti @@ -706,10 +702,10 @@ Lingua Attenzione I backup automatici sono altamente consigliati. Dovresti tenere delle copie anche in altri posti. - Grossi aggiornamenti danneggiano le fonti, possono rallentare gli aggiornamenti e aumentare il consumo di batteria + Grossi aggiornamenti danneggiano le fonti, possono rallentare gli aggiornamenti e aumentare il consumo di batteria. Tocca per saperne di più. Solo su Wi-Fi Ogni 3 giorni - Attenzione: grossi download di massa possono rallentare le fonti e/o bloccare tachiyomi + Attenzione: grossi download di massa possono rallentare le fonti e/o bloccare tachiyomi. Tocca per saperne di più. Mostra numero di capitoli non letti nell\'icona degli aggiornamenti Aggiorna tutto Aggiornamenti dell\'applicazione @@ -753,4 +749,22 @@ Apri su GitHub Cancella dati WebView Dati WebView cancellati + Chiudi + Mostra fonti duplicate appuntate + Ripetere le fonti appuntate nei rispettivi gruppi di lingue + Batteria non scarica + Beh, questo è imbarazzante + Nessuna fonte installata trovata + Nessuna fonte trovata + Conteggio non letti + Ultimo aggiornamento dei manga + Migliora le prestazioni del lettore dividendo le immagini scaricate troppo alte. + Dividi automaticamente le immagini troppo alte + Pagina %d non trovata durante la divisione + Impossibile trovare il percorso della pagina %d + Reimposta la modalità di lettura e l\'orientamento per tutte le serie + Reimposta le opzioni del visualizzatore + Opzioni del visualizzatore ripristinate + Impossibile ripristinare le opzioni del visualizzatore + Impossibile separare le immagini scaricate \ No newline at end of file diff --git a/app/src/main/res/values-ja/strings.xml b/app/src/main/res/values-ja/strings.xml index 7064d97e53..7ca5c66adf 100644 --- a/app/src/main/res/values-ja/strings.xml +++ b/app/src/main/res/values-ja/strings.xml @@ -78,7 +78,6 @@ 充電中 ステータスが「完結済み」 読んだ後に読書進捗を更新 - スタート画面 デフォルトカテゴリー 毎回尋ねる すべて @@ -149,7 +148,7 @@ 最大バックアップ数 バックアップが作成されました チャプタキャッシュをクリア - キャッシュの消去中にエラーが発生しました + 消去中にエラーが発生しました データベースをクリア ライブラリにないマンガの履歴を削除 バージョン @@ -245,7 +244,7 @@ 完結済み 放棄済み 保留中 - 読むつもり + 読む予定 評価 タイトル ステータス @@ -280,7 +279,7 @@ 新しいバージョンがありません アップデートを確認中… ダウンロード中… - ダウンロード完了 + タップでインストール ダウンロード中にエラー発生 アップデート利用可能! マンガカバー @@ -296,7 +295,7 @@ ネットワーク接続が利用できません ダウンロード一時停止済み 一般設定 - 読み直している + 読み返し中 未インストールのソース:%1$s 読み終わりました: 読んでいます: @@ -404,7 +403,7 @@ 焼き込み/比較(暗) 覆い焼き/比較(明) 乗算 - バンディングを軽減しますが、パフォーマンスを影響します + バンディングを軽減しますが、パフォーマンスを影響するかもしれません 画面の切り抜きエリアにも内容を表示 この拡張機能はTachiyomiの公式拡張機能リストに含まれていません。 非公式 @@ -432,7 +431,6 @@ 全て無効にする 全て有効にする 選択を反転 - 最近のアクセス順 メニュー もう一度押して終了します 章の更新 @@ -483,7 +481,6 @@ 作者不明 変更を適用するには再起動してください ネットワーク - 起動時にチャプターを表示 タップでのページめくりを反転 v%1$sに更新しました 更新情報 @@ -520,7 +517,6 @@ 検索設定 ダウンロードした章 ライブラリからのマンガ - スクロール時ボトムバーを非表示 閲覧履歴の記録を一時停止します シークレット モード 履歴を全消去 @@ -544,7 +540,7 @@ 登録済み 開発者に渡すよう、エラー ログを保存します クラッシュ ログをダンプ - ナビゲーションレイアウト + タップ可能なゾーン 右と左 Kindleスタイル L形 @@ -560,8 +556,8 @@ 次へ 前へ - ビューアが立ち上がるとタップゾーンを表示します - ナビゲーションレイアウトオーバーレイを表示 + ビューアが立ち上がるとしばらく表示します + タップ可能なゾーンを表示 DNS over HTTPS(DoH) 含まれているカテゴリーに入っていても、除外対象カテゴリーにあるマンガは更新されません。 自動ダウンロード @@ -658,11 +654,11 @@ 特定ソース専用の高度な機能を提供するサービスです。漫画はライブラリに追加される時、自動で追跡され始めます。 バックアップの自動作成は強く推奨されます。ほかの場所にもコピーを保管してください。 システムログにverboseログを出力(アプリのパフォーマンスが低下します) - 大規模のアップデートはソースに有害で、ソースを遅くし、電池の消耗を増加する可能性があります + 大規模のアップデートはソースに有害で、ソースを遅くし、電池の消耗を増加する可能性があります。詳しくはタップでご覧ください。 言語 警告 Verboseログ出力 - 警告:大量の一括ダウンロードにより、ソースは遅くなったり、Tachiyomiを接続禁止したりする恐れがあります + 警告:大量の一括ダウンロードにより、ソースは遅くなったり、Tachiyomiを接続禁止したりする恐れがあります。詳しくはタップでご覧ください。 3日ごと Wi-Fi接続時のみ 更新アイコンで未読カウンターを表示 @@ -675,7 +671,7 @@ プライバシーポリシー タイトル更新のスキップ 未読の章あり - ライブラリ更新エラーの修正については、%1$sをご覧ください。 + ライブラリ更新エラーの修正については、%1$sをご覧ください CBZアーカイブとして保存 完結済み キャンセル済み @@ -706,4 +702,23 @@ GitHubに移動 公式リリースで新しいバージョンが取得可能です。非公式のF-Droidリリースからの移行については、タップで手順をご覧ください。 画像の保存時にエラー発生 + 閉じる + 重複するピン留め中のソース + WebViewデータを消去 + WebViewデータを消去しました + バッテリー残量が低くない + 各言語グループでピン留め済みのソースを繰り返す + ソースが見つかりません + インストール済みのソースが見つかりません + えっと、これはちょっと気まずいですね + 前回の漫画更新 + 未読の章数 + 長い画像を自動で分割 + ダウンロードした長い画像を自動で分割してビューアのパフォーマンスを改善します。 + 分割時にページ%dが見つかりませんでした + ビューアフラグをリセット + 全てのシリーズのビューアモードと画面向きをリセットします + ページ%dのファイルパスが見つかりませんでした + ビューアフラグをリセットしました + ビューアフラグをリセットできませんでした \ No newline at end of file diff --git a/app/src/main/res/values-jv/strings.xml b/app/src/main/res/values-jv/strings.xml index 85265b5420..d7f00fd341 100644 --- a/app/src/main/res/values-jv/strings.xml +++ b/app/src/main/res/values-jv/strings.xml @@ -129,7 +129,6 @@ Tandai dadi diwaca Penggolekan global Tanggal dijupuk - Terakhir dipriksa Terakhir di waca Ngilangno saringan Kelacak @@ -169,10 +168,10 @@ Batalke Copot pin Pin - Tampilke jumlah item - Tampilke tab kategori - Lencana lokal - Lencana durung diwaca + Tampilaken jumlah item + Tampilaken tab kategori + Lokal manga + Bab durung diwaca Unduh lencana Kothak penak Kothak kompak @@ -188,4 +187,101 @@ Nampilno manga Mulai Awas + basa + Tutup + 5% + 25% + 10% + 15% + Batesan: %s + Karo status \"Rampung\" + Kothak sampul + Tumuti sistem + Tema aplikasi + Dinamis + Ijo apel + Takon jawab lan panduan + Ngisor + Stempel wektu + Cendhak (Dina iki, Wingi) + Dawa(Cendhak+, n dina kang rumiyin) + Iki ora nyegah ekstensi kang ora resmi utawa salah dilabeli kanggo nampilake konten NSFW (18+) ing aplikasi. + Nembe mawon + Dinten puniki + + %1$d dinten kala-wingi + + Mati + 20% + Kaamanan + Tansah + Sumber NSFW (18+) + Tampilaken ing sumber lan dhaptar ekstensi + Karo bab durung diwaca + + Sawise %1$s menit + + Konfirmasi metu + Kelola notifikasi + Amanaken layar sembunikan konten aplikasi wektu ngaleh aplikasi lan blokir tangkapan layar + Surup wengi + Kunci wektu meneng + Pindah seri mendhuwur + Stroberi Daiquiri + Tako + Yin lan Yang + Yotsuba + Mode ireng banget + Navigasi + Dhuwur + Tengah + Umpetake konten notifikasi + Amanaken layar + Saben 3 dinten + Namung ing Wi-Fi + + %d kategori + + Ora kapracaya + Iku durung diwiwiti + periksa sampul lan rinci anyar wektu memerbarui pustaka + kategori gawan + Tampilake itungan kang durung diwaca ing ikon nganyari + Kalebu: %s + Kajaba: %s + Nganyari tertunda + Nganyari + Nganyari kabeh + pasang + Ngetrap + Pracaya + Ora resmi + Ekstensi ora kapracaya + Tansah takon + Tampilake nomer halaman + Kuwalik + Tampilake mode maca + Tengen lan Kiwa + Masang + Item saben baris + ora tau + Ucul + Ekstensi iki ora kasedhiya maneh. + Gagal kanggo entuk dhaptar ekstensi + 18+ + Ndean isi konten NSFW (18+) + Masang ekstensi… + Pemasang + Shizuku ora lumaku + Pasang lan wiwit Shizuku kanggo migunakake Shizuku dadi pemasang ekstensi. + Ora + Kaping duane + Werna latar + Kaya Kindle + Tepi + Walik tombol volume + Tampilake konten di wilayah kang terpotong + Lewati bab dithandani kawaca + Tombol volume + Wangun L \ No newline at end of file diff --git a/app/src/main/res/values-ka-rGE/strings.xml b/app/src/main/res/values-ka-rGE/strings.xml index a0f8b6fd02..ba8159ff17 100644 --- a/app/src/main/res/values-ka-rGE/strings.xml +++ b/app/src/main/res/values-ka-rGE/strings.xml @@ -21,7 +21,6 @@ ანბანის მიხედვით თავების რაოდენობა ბოლოს წაკითხული - ბოლოს ნანახი ბოლო თავი ძებნა ყველას მონიშვნა @@ -395,7 +394,6 @@ მიგრაცია მიმაგრება მიმაგრების მოხსნა - საწყისი გვერდი ბიბლიოთეკის განახლებისას მოძებნე ახალი ყდები და დეტალები განახლებები მოლოდინის რეჟიმშია მოძველებული @@ -492,7 +490,6 @@ %d კატეგორია %d კატეგორიები - გახსნილ თავებთან გადასვლა 1 წუთის შემდეგ %1$s წუთის შემდეგ diff --git a/app/src/main/res/values-km/strings.xml b/app/src/main/res/values-km/strings.xml index ff90d9b9b8..7e5a6a38be 100644 --- a/app/src/main/res/values-km/strings.xml +++ b/app/src/main/res/values-km/strings.xml @@ -84,7 +84,6 @@ ថយម្ដងទៀតដើម្បីចេញ ការកំណត់ កន្លែងកំណត់ - បានចូលមើលចុងក្រោយបង្អស់ បញ្ចាក់ភាគមុនថាបានអាន លុប ធ្វើបច្ចុប្បន្នភាព @@ -148,11 +147,9 @@ លើ កណ្ដាល ចុង - លាក់ចុងនៅពេលអូសបា timestamps relative timestamps ទម្រង់ថ្ងៃខែ - អេក្រង់ពេលចូលមកដល់ បញ្ចាក់ការចាកចេញ កំណត់ការជូនដំណឹង សន្តិសុខ @@ -171,7 +168,6 @@ ធាតុក្នុងមួយជួ បញ្ឈរ ផ្ដេក - ចូលទៅtabភាគតែម្ដងនៅពេលបើកកម្មវិធី ការធ្វើប្ចុប្បន្នភាពដោយស្វ័យប្រវត្ត បិទ រាល់៦ម៉ោងម្ដង diff --git a/app/src/main/res/values-kn/strings.xml b/app/src/main/res/values-kn/strings.xml index 09ed314177..b823ce2f45 100644 --- a/app/src/main/res/values-kn/strings.xml +++ b/app/src/main/res/values-kn/strings.xml @@ -19,7 +19,6 @@ ಸೂಚನೆಗಳನ್ನು ನಿರ್ವಹಿಸಿ ನಿರ್ಗಮನವನ್ನು ಖಚಿತಪಡಿಸಿ ದಿನಾಂಕ ಸ್ವರೂಪ - ಮೊದಲ ಪುಟ ಸಿಸ್ಟಮ್ ಅನುಕರಿಸಿ ಆನ್ ಆಫ @@ -91,7 +90,6 @@ ಎಲ್ಲೆಡೆ ಹುಡುಕಿ ಹುಡುಕಿ ಇತ್ತೀಚಿನ ಅಧ್ಯಾಯ - ಕೊನೆಯದಾಗಿ ಪರಿಶೀಲಿಸಲಾಗಿದ ಕೊನೆಯದಾಗಿ ಓದಿದ ಒಟ್ಟು ಅಧ್ಯಾಯಗಳು ವರ್ಣಮಾಲೆಯ ಪ್ರಕಾರ @@ -498,7 +496,6 @@ ಅನ್ವಯಿಸಲು ಅಪ್ಲಿಕೇಶನ್ ಮರುಪ್ರಾರಂಭದ ಅಗತ್ಯವಿದೆ ಅಡ್ವಾನ್ಸ್ಡ್ ಸೆಕ್ಷನ್ ಓದುವ ಮೊಡ್ - ಓಪನ್ ಮಾಡಿದ ಮೇಲೆ ಅಧ್ಯಯಕ್ಕೆ ಹೋಗಿ ಜನರಲ್ ಸೆಲೆಕ್ಷನ್ ಓದದಿರುವ ಅಧ್ಯಾಯಗಳನ್ನು ಡೌನ್‌ಲೋಡ್ ಮಾಡಿ ಹಾಕಿದ್ದ ದಿನಾಂಕ @@ -530,7 +527,6 @@ ಅಧ್ಯಾಯಗಳನ್ನು ಅಳಿಸಿ NSFW (18+) ವಿಷಯವನ್ನು ಹೊಂದಿರಬಹುದು 18+ - ಸ್ಕ್ರಾಲ್‌ ಮಾಡಿದಾಗ ಕೆಳಗಿನ ಪಟ್ಟಿಯನ್ನು ಮರೆಮಾಡಿ ಸಂಯೋಜನೆಗಳಲ್ಲಿ ಹುಡುಕಿ ಮುಂದಿನ ಪುಟ ಹಿಂದಿನ ಪುಟ diff --git a/app/src/main/res/values-ko/strings.xml b/app/src/main/res/values-ko/strings.xml index 613bf48795..52bbe1b673 100644 --- a/app/src/main/res/values-ko/strings.xml +++ b/app/src/main/res/values-ko/strings.xml @@ -44,7 +44,7 @@ 설치 설정 디스플레이 - 기록 + 역사 다운로드 대기열 서재 기록 @@ -86,7 +86,6 @@ 전부 자동 업데이트 조건 충전중 - 시작 화면 기본 카테고리 모든 언어 업데이트 @@ -156,7 +155,7 @@ 회차별 캐시 삭제 %1$s 사용중 캐시 삭제됨. %1$d개의 파일이 삭제됨 - 캐시 삭제중 오류가 발생하였습니다 + 지우는 동안 오류가 발생했습니다 쿠키 삭제 쿠키 삭제됨 데이터베이스 삭제 @@ -237,7 +236,7 @@ 새로운 업데이트 없음 업데이트를 찾는중… 다운로드 중… - 다운로드 완료됨 + 탭하여 설치 다운로드 오류 업데이트 이용 가능! 만화 표지 @@ -394,7 +393,7 @@ 서재에 추가된 시간 순 최신 화 업로드 순 L자 모양 - 터치 반전 + 탭 영역 반전 없음 자동 Kindle식 @@ -412,7 +411,7 @@ 양쪽 가장자리 회차 목록 보기 읽지 않은 회차 - 터치 영역 설정 + 탭 존 경고 번역에 참여하기 회전 설정 @@ -454,7 +453,6 @@ 모양 오늘 네비게이션 - 스크롤 시 하단 바 숨기기 시간 표시 형식 오늘, 어제 전체 업데이트 설정 @@ -484,9 +482,9 @@ 행동 언어 뷰어가 켜질 때 현재 읽기 모드를 표시합니다 - 네비게이션 레이아웃 표시 - 뷰어가 켜질 때 화면 구성을 표시합니다 - 밴딩 효과가 감소하지만 성능이 낮아질 수 있습니다 + 탭 영역 오버레이 표시 + 리더가 열렸을 때 간략히 표시 + 밴딩을 줄이지만 성능에 영향을 줄 수 있음 디스플레이 필터링된 회차 건너뛰기 매우 높음 @@ -504,7 +502,6 @@ 기본 회차 설정을 업데이트 했습니다 건너뜀 회차 업데이트 - 시작 시 회차 표시 포함: %s 백그라운드 활동 안 읽은 회차가 있음 @@ -554,9 +551,9 @@ 내역 삭제 기록이 삭제되었습니다 저장 공간이 부족하여 회차를 다운로드 할 수 없습니다 - 경고: 한꺼번에 많은 양을 다운로드 할 경우 소스가 느려지거나 Tachiyomi를 차단할 수 있습니다 + 경고: 대량 다운로드는 소스가 느려지거나 Tachiyomi를 차단할 수 있습니다. 탭하여 자세히 알아보기 새로운 회차 확인 중 - 대량의 업데이트는 소스에 과도한 부하를 줄 수 있고 배터리 사용량을 증가시킵니다 + 대규모 업데이트는 소스에 피해를 입히고 업데이트가 느려지고 배터리 사용량이 증가할 수 있습니다. 탭하여 자세히 알아보기 %1$s화 %1$d개의 업데이트가 실패했습니다 %1$d개의 업데이트를 건너 뛰었습니다 @@ -615,13 +612,12 @@ 19금 읽는 중 카테고리 탭 보이기 - 정보가 갱신된 시간 순 + 장 가져오기 날짜 만화의 총 개수 뒤로가기 배터리 최적화가 이미 꺼져 있습니다 회차 번호 순 맨 위로 이동 - 마지막으로 확인한 순 업로드 날짜 순 맨 아래로 이동 오름차순 @@ -706,4 +702,17 @@ 새로운 공식 업데이트가 있습니다. F-Droid의 비공식 버젼에서 이전을 원하시면 터치해서 방법을 확인하세요. GitHub에서 열기 이미지 저장 오류 + 출처를 찾을 수 없습니다 + 설치된 소스를 찾을 수 없습니다 + 마지막 만화 업데이트 + 읽지 않은 수 + 중복된 고정 소스 표시 + 해당 언어 그룹에서 고정된 소스 반복 + 글쎄, 이것은 어색하다 + 닫다 + 배터리가 부족하지 않음 + 웹뷰 데이터 지우기 + 웹뷰 데이터 삭제됨 + 긴 이미지 자동 분할 + 긴 다운로드 이미지를 분할하여 리더 성능을 향상시킵니다. \ No newline at end of file diff --git a/app/src/main/res/values-lt/strings.xml b/app/src/main/res/values-lt/strings.xml index 18ff9b63f1..694f8a7ee3 100644 --- a/app/src/main/res/values-lt/strings.xml +++ b/app/src/main/res/values-lt/strings.xml @@ -47,7 +47,6 @@ Išjungti Automatiniai atnaujinimai Globalus naujinimas - Atidarius peršokti į skyrius Horizontalus Portretas Elementai eilutėje @@ -77,13 +76,11 @@ Sauga Tvarkyti pranešimus Patvirtinti išėjimą - Pradžios ekranas Datos formatas Ilgi (Trumpi+, prieš n dienų) Trumpi(Šiandien,Vakar) Reliatyvūs laiko štampai Laiko štampai - Slėpti apatinę juostą slenkant Apačioje Viduryje Viršuje @@ -192,7 +189,6 @@ Pridėtas Tikrinimo datą Naujausiais skyrius - Paskiausiai žiūrėtas Paskutinis skaitytas Skyrių skaičius Abėcėlės tvarka diff --git a/app/src/main/res/values-lv/strings.xml b/app/src/main/res/values-lv/strings.xml index 7c1c8ce5d1..950a7111f5 100644 --- a/app/src/main/res/values-lv/strings.xml +++ b/app/src/main/res/values-lv/strings.xml @@ -123,7 +123,6 @@ Globālā meklēšana Pievienošanas datums Jaunākā nodaļa - Pēdējo reizi pārbaudīts Izvēlne Vēlreiz nospiediet atpakaļ, lai izietu Jums nav nevienas kategorijas. Pieskarieties plus pogu, lai izveidotu vienu savas bibliotēkas organizēšanai. @@ -140,7 +139,6 @@ Notiek jaunu nodaļu meklēšana… Nav pieejamas jaunas nodaļas Lejuplādēt - Pārlēkt uz nodaļām, atverot Ainava Portrets Vienumi rindā @@ -161,7 +159,6 @@ Pārvaldiet paziņojumus Apstipriniet izeju Datuma formāts - Sākuma ekrāns Ieslēgts Izslēgts Sekot sistēmu diff --git a/app/src/main/res/values-mn/strings.xml b/app/src/main/res/values-mn/strings.xml new file mode 100644 index 0000000000..a6b3daec93 --- /dev/null +++ b/app/src/main/res/values-mn/strings.xml @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/app/src/main/res/values-mr/strings.xml b/app/src/main/res/values-mr/strings.xml index 71ca2c1f2f..a7d4a9750c 100644 --- a/app/src/main/res/values-mr/strings.xml +++ b/app/src/main/res/values-mr/strings.xml @@ -93,13 +93,11 @@ मागील वाचलेले म्हणून चिन्हांकित करा व्यस्त निवडा जागतिक शोध - शेवटून चेक केलेले अ‍ॅप्स स्विच करताना अॅप मधील सामग्री लपवा व स्क्रीनशॉट अवरोधित करा %d श्रेणी %d श्रेण्या - प्रारंभाची पृष्ट स्क्रीन सुरक्षित करा 1 मिनीटानंतर diff --git a/app/src/main/res/values-ms/strings.xml b/app/src/main/res/values-ms/strings.xml index 505963204f..4a2dda9162 100644 --- a/app/src/main/res/values-ms/strings.xml +++ b/app/src/main/res/values-ms/strings.xml @@ -85,7 +85,6 @@ Ketika mengecas Dengan status \"Sudah selesai\" Kemas kini selepas dibaca - Skrin permulaan Kategori lalai Sentiasa tanya Skrin penuh @@ -241,7 +240,7 @@ Tiada versi baharu tersedia Mencari versi baharu… Memuat turun… - Muat turun selesai + Ketik untuk memasang Ralat muat turun Versi baharu boleh didapati! Muka hadapan manga @@ -384,7 +383,6 @@ Terlama Naik ke atas Turun ke bawah - Akhir disemak Menyemak kemas kini sambungan %d kemas kini sambungan tersedia @@ -444,7 +442,7 @@ Selesai dalam %1$s dengan %2$s ralat - Bab tidak dibaca + Bab belum dibaca Sinkron satu hala untuk kemas kini bab kemajuan dalam sistem penjejakan. Sediakan penjejakan untuk penyertaan manga persendirian dari butang penjejakan mereka. Segar semula muka hadapan manga pustaka Mengikut tarikh muat naik @@ -477,12 +475,11 @@ Matikan Mula semula diperlukan untuk berkesan Rangkaian - Terus ke bab bila buka Kedua-dua Mod atas bawah Mod kanan kiri Tidak aktif - Songsangkan tekan skrin + Songsangkan zon ketik Status tidak diketahui Pengarang tidak diketahui Muat turun bab belum dibaca @@ -520,7 +517,6 @@ Carian tetapan Bab dimuat turun Manga dari pustaka - Sembunyi bar bawah bila skrol Menjeda sejarah membaca Mod inkognito Padamkan sejarah @@ -533,7 +529,7 @@ Tunjuk dalam senarai sumber dan sambungan Tiada aplikasi memilih fail Sila log masuk ke MAL sekali lagi - Tataletak navigasi + Zon ketik Sisi Serupa Kindle Bentuk L @@ -557,13 +553,13 @@ \n \nAnda perlu memasang sambungan yang hilang dan log masuk ke penjejakan untuk menggunakannya. Sebelumnya - Tunjukkan zon ketik apabila pembaca dibuka + Tunjukkan seketika apabila pembaca dibuka Kanan Kiri - Tunjuk tindanan susun atur navigasi + Tunjuk tindanan zon ketik Seterusnya DNS melalui HTTPS (DoH) - Tarikh diambil + Tarikh bab diambil Kecuali: %s Hanya: %s Tiada @@ -577,7 +573,7 @@ Potret Tindakan Mencipta folder mengikut tajuk manga - Simpan halaman ke folder berasingan + Simpan muka surat ke folder berasingan Jenis putaran skrin Skala kelabu Nyahdaya mod inkognito @@ -661,10 +657,10 @@ Amaran Bahasa Sandaran automatik sangat disyorkan. Anda patut simpan salinan di tempat lain juga. - Kemas kini yang besar membahayakan sumber dan mengakibatkan sumber menjadi perlahan dan juga peningkatan penggunaan bateri + Kemas kini yang besar membahayakan sumber dan mengakibatkan sumber menjadi perlahan dan juga peningkatan penggunaan bateri. Ketik untuk ketahui selebihnya. Hanya menggunakan Wi-Fi Setiap 3 hari - Amaran: muat turun secara pukal besar boleh menyebabkan sumber menjadi lebih perlahan dan/atau menyekat Tachiyomi + Amaran: muat turun secara pukal besar boleh menyebabkan sumber menjadi lebih perlahan dan/atau menyekat Tachiyomi. Ketik untuk ketahui selebihnya. Tunjuk bilangan belum dibaca pada ikon Kemas kini Kemas kini semua Kemas kini aplikasi @@ -708,4 +704,20 @@ Buka di GitHub Hapus data WebView Data WebView dihapuskan + Tutup + Ulang sumber yang disematkan dalam kumpulan bahasa masing-masing + Bateri tidak lemah + Tunjuk pendua sumber yang disematkan + Hmm, ini agak mejanggalkan + Tiada sumber dipasang ditemui + Tiada sumber ditemui + Kiraan belum dibaca + Kemas kini manga terakhir + Auto memisah imej yang tinggi + Meninggkatkan prestasi pembaca dengan memisah imej yang tinggi yang telah dimuat turun. + Muka surat %d tidak dijumpai ketika memisah + Lokasi fail muka surat %d tidak ditemui + Menetapkan semula mod bacaan dan orientasi semua siri + Tetapan pemaparan diset semula + Set semula tetapan pemaparan \ No newline at end of file diff --git a/app/src/main/res/values-my/strings.xml b/app/src/main/res/values-my/strings.xml index 5e22bc1c13..f3a5eeb750 100644 --- a/app/src/main/res/values-my/strings.xml +++ b/app/src/main/res/values-my/strings.xml @@ -70,7 +70,6 @@ ရှာဖွေရန် ထည့်ခဲ့သောရက်စွဲအရ နောက်ဆုံးထွက်အခန်းအရ - နောက်ဆုံးစစ်ဆေးပြီးသော နောက်ဆုံးဖတ်ခဲ့သော အခန်းစုစုပေါင်း အက္ခရာစဉ်အလိုက် diff --git a/app/src/main/res/values-nb-rNO/strings.xml b/app/src/main/res/values-nb-rNO/strings.xml index 7371d37c87..86c78d9d69 100644 --- a/app/src/main/res/values-nb-rNO/strings.xml +++ b/app/src/main/res/values-nb-rNO/strings.xml @@ -78,8 +78,7 @@ Ukentlig Alle Lading - Startskjerm - Forvalgt kategori + Standard kategori Alltid spør Alle Oppdater @@ -107,7 +106,7 @@ Liggende Automatiske oppdateringer Enhetsbegrensninger for automatiske oppdateringer - Fullførte serier + Med \"Fullført\" status Oppdater fremdrift etter lesing 32-biters fargerom Beskjær kanter @@ -120,7 +119,7 @@ Bakgrunnsfarge Hvit Svart - Forvalgt lesemodus + Standard lesemodus Venstre til høyre Høyre til venstre Loddrett @@ -140,7 +139,7 @@ Ingen animasjon Normal Rask - Forvalgt rotasjonstype + Standard rotasjonstype Fri Låst stående Låst liggende @@ -176,9 +175,9 @@ Tøm kapittelhurtiglager Brukt: %1$s Hurtiglager tømt. %1$d filer har blitt slettet - Feil oppstod under tømming av hurtiglager - Tøm kaker - Kaker tømt + Feil oppstod under opprensing + Tøm informasjonskapsler + Informasjonskapsler slettet Tøm database Slett historikk for manga som ikke er lagret i biblioteket ditt Er du sikker\? Leste kapitler og framdrift for manga som ikke er i biblioteket vil gå tapt @@ -368,7 +367,6 @@ Opphev festin Fest Velg motsatt - Sist sjekket Meny Kilder Utvidelsesoppdateringer @@ -459,7 +457,6 @@ Inkluder bare festede kilder Vis lesemodus Denne utvidelsen kommer ikke fra den offisielle Tachiyomi-utvidelseslisten. - Hopp til kapitler på åpning deaktivere Uleste kapitler deaktiver alle @@ -493,7 +490,7 @@ Kap. %1$s - %2$s %1$s: %2$s, side %3$d Kapittelinnstillinger - Sett som forvalg + Sett som standard Fant ingen kapitler %d tracker @@ -504,8 +501,8 @@ Hopper over %d kapitler, enten så mangler kilden de eller så har de blitt filtrert ut Oppdater WebView-programmet for bedre kompabilitet - Oppdaterte forvalgte kapittelinnstillinger - Er du sikker på at du vil lagre disse innstillingene som forvalg\? + Oppdaterte standard kapittelinnstillinger + Er du sikker på at du vil lagre disse innstillingene som standard\? Søkeinnstillinger Utvidelsesoppdatering tilgjengelig @@ -553,7 +550,6 @@ L-formet Vis i kilde- og utvidelseslister Aldersgrense 18+ kilder - Skjul bunnlinjen ved scrolling Synkende Stigende Etter kapittelnummer @@ -641,7 +637,7 @@ Start nedlasting nå Avbryt alle for denne serien Identitetsbekreft for å endre - Forvalg + Standard Noen produsenter har ytterligere appbegrensninger som dreper bakgrunnstjenester. Denne nettsiden har mer info om hvordan det kan fikses. Sikkerhetskopier/gjenoppretting kan krangle hvis MIUI-optimalisering er avskrudd. Tjenester som gir forbedrede funksjoner for spesifikke ressurser. Det holdes automatisk øye med manga når den legges til i biblioteket ditt. @@ -672,7 +668,7 @@ Sirlig loggføring Skriv utfyllende logg til systemloggen (reduserer programytelse) Advarsel - Advarsel: store oppdateringer skader kilder og kan føre til tregere oppdateringer samt økt batteribruk + Store oppdateringer skader kilder og kan føre til tregere oppdateringer samt økt batteribruk Automatiske sikkerhetskopier anbefales sterkt. Du bør oppbevare flere kopier andre steder også. Appoppdateringer Hver 3. dag @@ -682,13 +678,13 @@ Personvernerklæring Ferdig publisert 5% - Har uleste kapitler + Med uleste kapitler Kansellert På pause Lagre som CBZ-arkiv Oppdater alle FAQ og guider - Hopp over oppdateringer + Hopp over oppdateringer av titler Rengjør databasen Hoppet over fordi det er uleste kapitler Vis antall uleste på oppdateringsikonet @@ -700,11 +696,11 @@ For hjelp til å fikse bibliotekoppdateringsfeil, se %1$s Startet Kun omslags-rutenett - Ingen leste kapitler + Som ikke er påbegynt Zoom landskapsbilde Naviger til panorering %1$d ikke-bibliotek manga i databasen - Flytt serier til toppen + Flytt serien til toppen Kunne ikke hente utvidelseslisten Omvendt portrett Tøm kapittelbufferen ved lukking av appen @@ -714,4 +710,14 @@ Hoppet over fordi ingen kapitler er lest Hoppet over Deaktivert + Ingen bibliotekoppføringer å sikkerhetskopiere + En ny versjon er tilgjengelig gjennom offisielle kanaler. Trykk for å lære hvordan du kan migrere fra den uoffisielle F-Droid varianten. + Feil ved lagring av bilde + Åpne på GitHub + Lukk + Vis dupliserte festede kilder + Gjenta festede kilder i sine respektive språkgrupper + Slett WebView data + WebView data slettet + Batteri er ikke lavt \ No newline at end of file diff --git a/app/src/main/res/values-ne/strings.xml b/app/src/main/res/values-ne/strings.xml index 543fa9126e..24fdd32dc3 100644 --- a/app/src/main/res/values-ne/strings.xml +++ b/app/src/main/res/values-ne/strings.xml @@ -1,6 +1,5 @@ - सुरूवात स्क्रिन अन अफ अँध्यारो मोड @@ -81,7 +80,6 @@ ग्लोबल खोजी सेटिङमा खोज्नुहोस् खोज्नुहोस् - अन्तिम जाँच गरियो अन्तिम पढिएको कुल अध्यायहरू वर्णानुक्रम अनुसार @@ -140,7 +138,6 @@ अफ स्वचालित अपडेटहरु ग्लोबल अपडेट - खोलिएको अध्यायहरूमा जानुहोस् ल्याण्डस्केप पङ्क्ति प्रति आइटम को संख्या प्रदर्शन @@ -171,7 +168,6 @@ छोटो (आज, हिजो) सापेक्ष टाइमस्ट्याम्प टाइमस्ट्याम्प - स्क्रोल गर्दा तल पट्टीको बार लुकाउनुहोस् तल्लो मध्य टुप्पो diff --git a/app/src/main/res/values-nl/strings.xml b/app/src/main/res/values-nl/strings.xml index df9b38d612..b49fd9ec82 100644 --- a/app/src/main/res/values-nl/strings.xml +++ b/app/src/main/res/values-nl/strings.xml @@ -73,7 +73,6 @@ Iedere 2 dagen Wekelijks Alles - Beginscherm Standaard categorie Altijd vragen Volledig scherm @@ -363,7 +362,6 @@ Oudste Nieuwste Opnieuw organiseren - Laatst gecontroleerd Menu Vastpinnen Bronnen @@ -486,7 +484,6 @@ Herstart van de app nodig om van kracht te worden Netwerk - Ga naar de hoofdstukken bij openen Beiden Verticaal Horizontaal @@ -536,7 +533,6 @@ Geschiedenis wissen Weet je dit zeker\? Alle geschiedenis zal verloren gaan. Geschiedenis verwijderd - Navigatiebalk verbergen bij het scrollen Volgende pagina Vorige pagina Bronmigratiegids diff --git a/app/src/main/res/values-nn/strings.xml b/app/src/main/res/values-nn/strings.xml new file mode 100644 index 0000000000..8ae26cbfd0 --- /dev/null +++ b/app/src/main/res/values-nn/strings.xml @@ -0,0 +1,330 @@ + + + Namn + Meir + Innstillingar + Oppdateringar + Hjelp + Kategoriar + Manga + Kapittel + Sporing + Historikk + Standard + Åtvaring + Lås opp Tachiyomi + Autentiser for å stadfesta endring + Filter + Bokmerket + Sporet + Ulesen + Starta + Fjern filter + Alfabetisk + Siste kapittel + Dato henta + Søk + Søkeinnstillingar + Vel alt + Vel motsett + Bokmerk kapittel + Fjern bokmerke + Slett + Oppdater + Oppdater bibliotek + Aktiver alle + Deaktiver alle + Rediger + Legg til + Legg til kategori + Rediger kategoriar + Rediger omslag + Vis kapittel + Stopp + Pause + Neste kapittel + Prøv igjen + Fjern + Start + Opne i nettlesar + Vis manga + Opne i WebView + Migrer + Visningsmodus + Vis + Kompakt rutenett + Komfortabelt rutenett + Lokal manga + Språk + Vis kategorifaner + Vis talet på gjenstandar + Avbryt + Avbryt alle + Avbryt alle for denne serien + Sorter + Nyaste + Eldste + Flytt til toppen + Flytt til botnen + Installer + Del + Lagra + Angra + Lukka + Opne logg + Trykk for å sjå detaljar + Oppretta + Tilbake + FAQ og guidar + Lastar… + Generelt + Utsjånad + Bibliotek + Lesar + Avansert + Om + Tema + Av + + Dynamisk + Ingen nedlastingar + Ingen nylege oppdateringar + Bibliotek + Kjelder + Trykk tilbake igjen for å avslutta + Innstillingar + Meny + Sett kategoriar + Gi kategori nytt namn + Førre kapittel + Stigande + Søkkande + Fram + Liste + App tema + Topp + Botn + Tidsstemplar + Relative tidsstemplar + Stutt (i dag, i går) + Lang (Stutt+, n dagar sidan) + Datoformat + Stadfest avslutning + Handter varslingar + Sikkerheit + Alltid + Aldri + + Etter %1$s minutt + Etter %1$s minuttar + + NSFW (18+) kjeder + I dag + + I går + %1$d dagar sidan + + Skjerm + Element per rad + Automatisk oppdateringar + Dagleg + Annankvar dag + Kvar veke + Berre på Wi-Fi + Avgrensingar: %s + Sjå etter nye omslag og detaljar ved oppdatering av bibliotek + Standard kategori + Alltid spør + + %d kategori + %d kategoriar + + Manga i utelatne kategoriar vil ikkje bli oppdatert sjølv om dei òg er i inkluderte kategoriar. + Alle + Ingen + Inkluder: %s + Utelat: %s + Alle + Oppdater + Oppdater alle + Installer + Lastar ned + Installerer + Installert + Tiltru + Kvar tredje dag + Ikkje-tiltrudd + Avinstaller + Ikkje-tiltrudd utvidelse + Denne utvidinga kjem ikkje frå den offisielle Tachiyomi-utvidingslista. + Kunne ikkje henta utvidingslista + Versjon: %1$s + Språk: %1$s + 18+ + Installerer utviding… + Installatør + Shizuku køyrar ikkje + Vis sidetal + 32-bits farge + + Av + Eigendefinert lysstyrke + Gråtonar + Invertert + Eigendefinert fargefilter + Skjerm + Hopp over filtrerte kapittel + Ingen + Vassrett + Loddrett + Begge + Handlingar + Bakgrunnsfarge + Kvit + Grå + Svart + Automatisk + L-forma + Kindle-ish + Kant + Høgre og Venstre + Førre + Neste + Venstre + Høgre + Venstre til høgre + Høgre til venstre + Loddrett + Webtoon + Kontinuerleg loddrett + Strekk + Automatisk + Venstre + Høgre + Liggjande + R + G + B + A + Ingen + 5% + 10% + 15% + 20% + Høgaste + Høg + Låg + Lågaste + Utelatne kategoriar + Lagra som CBZ-arkiv + Tenester + Forbetra tenester + Tenester som tilbyr forbetra tenester for spesifikke kjelder. Manga blir spora automatisk når dei blir lagt til i biblioteket ditt. + Spor + Sjå etter oppdateringar for utvidingar + Lag reservekopi + Gjenopprett reservekopi + Reservekopifil-mappe + Kjelde ikkje funnet: %1$s + Ikkje logga inn: %1$s + Feil: tom URI + Reservekopi oppretta + Ugyldig reservekopifil + Fila manglar data. + Reservekopi inneheld ingen manga. + Gjenopprett bibliotek frå reservekopifil + Gjenoppretting fullført + %02d min, %02d sek + + Gjort på %1$s med %2$s feil + Gjort på %1$s med %2$s feil + + Kva ønskjer du å ta reservekopi av\? + Lagar reservekopi + Gjenoppretter reservekopi + Nettverk + DNS over HTTPS (DoH) + Data + Brukt: %1$s + %1$d ikkje-bibliotek manga i databasen + Versjon + Hjelp med å omsetje + Personvernerklæring + Sjå etter oppdateringar + Oppdatert til v%1$s + Inkognitomodus + Brukarnamn + E-postadresse + Passord + Ukjend feil + Oppdaterer kategori + Lokal + Manga frå biblioteket + Faner + Lokal kjelde + Andre + Sist brukt + Globalt søk… + Søk etter «%1$s» globalt + Utforsk + Denne mangaen har vorte fjerna frå databasen. + Skildring + Ukjend + Ukjend forfattar + Ukjend status + Kansellert + Legg til i bibliotek + Pågåande + Sporing + Kunne ikkje lasta ned kapittel grunna uventa feil + Global oppdatering + Nyleg + Liggjande + Av + Kvar sjette time + Installer og start Shizuku for å bruka Shizuku som utvidingsinstallatør. + Kvar tolvte time + Uoffisiell + Denne utvidinga er ikkje lengre tilgjengeleg. + Kan innehalda NSFW (18+) innhald + Slett kapittel + 25% + Manga i utelatne kategoriar vil ikkje bli nedlasta sjølv om dei òg er i inkluderte kategoriar. + Automatisk reservekopiar + Reservekopifrekvens + Avbroten gjenoppretting + Manglande kjelder: + Sporingstenester ikkje logga inn i: + Nokre produsentar har ytterlegare appavgrensingar som drep bakgrunnstenester. Denne nettstaden har meir info om korleis det kan fiksast. + Sjekk nettstad i WebView + Nettstaden + Sorter etter + Dato + Ferdig publisert + Lagt til i biblioteket + Fjerna frå bibliotek + Kopiert til utklippstavla: +\n%1$s + Kapittel %1$s + Lastar ned (%1$d/%2$d) + Sett som standard + Kva er nytt + Fjern frå bibliotek + Tittel + Meir + Legg manga til i bibliotek\? + Mindre + Kunne ikkje kopiera til utklippstavla + Kjelde ikkje installert: %1$s + I biblioteket + Feil + Etter kjelde + Last ned eigendefinert mengd + Neste kapittel + Neste fem kapittel + Neste ti kapittel + Omslag + Last ned + Eigendefinert + Alle + \ No newline at end of file diff --git a/app/src/main/res/values-pl/strings.xml b/app/src/main/res/values-pl/strings.xml index e1e359b24b..4918de7b90 100644 --- a/app/src/main/res/values-pl/strings.xml +++ b/app/src/main/res/values-pl/strings.xml @@ -134,7 +134,6 @@ Ładowanie Ukończone serie Aktualizuj postęp po przeczytaniu rozdziału - Ekran startowy Domyślna kategoria Zawsze pytaj Pełny ekran @@ -351,9 +350,10 @@ Więcej Ukrywa zawartość ekranu przy przełączaniu między aplikacjami i blokuj zrzuty ekranu - Po 1 minucie + Po %1$s minucie Po %1$s minutach Po %1$s minutach + Po %1$s minutach Nigdy Zawsze @@ -372,7 +372,6 @@ Anuluj wszystko Odwróć zaznaczenie Ostatni rozdział - Ostatnio sprawdzane Menu Odblokuj Tachiyomi Źródła @@ -497,7 +496,6 @@ Start Wymaga ponownego uruchomienia aplikacji Sieć - Przeskocz do rozdziałów przy otwarciu Obydwa Wertykalnie Horyzontalnie @@ -556,7 +554,6 @@ Historia usunięta Serwisy, do których nie zalogowono: Usuwaj rozdziały dodane do zakładek - Ukryj dolny pasek podczas przewijania Usuń rozdziały Może zawierać treści NSFW (18+) 18+ @@ -693,7 +690,7 @@ Ilość mang Język Ostrzeżenie - Ostrzeżenie: duża ilość zakolejkowanych pobrań może doprowadzić do spowolnienia źródeł i/lub zablokowania Tachiyomi + Ostrzeżenie: Duże aktualizacje biblioteki mogą prowadzić do zwiększonego zużycia baterii oraz spowolnienia działania źródeł. Co 3 dni Tylko przez Wi-Fi Usługi dostarczania ulepszonych funkcji dla niektórych źródeł. Mangi po dodaniu do biblioteki są automatycznie śledzone. @@ -713,7 +710,7 @@ Zapisz jako archiwum CBZ Polityka prywatności %1$d mang spoza biblioteki w bazie danych - Pomiń aktualizacje + Pomiń aktualizowanie tytułów Posiada nieprzeczytane rozdziały FAQ i poradniki Błąd: pusty URI @@ -731,4 +728,8 @@ \n \nCzy nadal chcesz kontynuować\? Pominięty + %1$d pominięto aktualizację(-e) + %1$d aktualizacja (aktualizacje) nie powiodła się + Zamknij + Przenieś serię na górę \ No newline at end of file diff --git a/app/src/main/res/values-pt-rBR/strings.xml b/app/src/main/res/values-pt-rBR/strings.xml index 00851cf012..040d0c958f 100644 --- a/app/src/main/res/values-pt-rBR/strings.xml +++ b/app/src/main/res/values-pt-rBR/strings.xml @@ -84,7 +84,6 @@ Carregando Com o estado \"Completo\" Atualizar o progresso após a leitura - Tela inicial Categoria padrão Sempre perguntar Tela cheia @@ -234,7 +233,7 @@ Sem atualizações disponíveis Procurando por atualizações… Fazendo download… - Download concluído + Toque para instalar Erro ao fazer download Nova versão disponível! Capa do mangá @@ -388,7 +387,6 @@ Mais antigos Mover para o topo Mover para o final - Última verificação Procurar por atualizações de extensão Atualização de extensão disponível @@ -442,7 +440,7 @@ Cinza Modo de leitura Para esta série - Reduz as faixas, mas afeta o desempenho + Reduz as faixas, mas pode afetar o desempenho %d categoria %d categorias @@ -486,12 +484,11 @@ Requer o reinício do aplicativo para ter efeito Rede - Pular para os capítulos ao abrir Nenhum Ambos Vertical Horizontal - Inverter o toque + Inverter as zonas de toque Estado desconhecido Autor desconhecido Fazer download de capítulos não lidos @@ -531,7 +528,6 @@ Pesquisar nas configurações Mangás da biblioteca Capítulos disponíveis offline - Ocultar a barra inferior durante a rolagem Pausa o histórico de leitura Modo anônimo Limpar o histórico @@ -547,7 +543,7 @@ Borda Kindle Em forma de L - Layout de navegação + Zonas de toque Registros de travamentos Data de término Data de início @@ -567,8 +563,8 @@ Os dados do arquivo de backup serão restaurados. \n \nVocê precisará instalar quaisquer extensões que estejam faltando e depois realizar o login nos serviços de monitoramento para utilizá-los. - Mostrar as zonas de toque quando o leitor está aberto - Mostrar a sobreposição do layout de navegação + Mostra rapidamente quando o leitor for aberto + Mostrar a sobreposição das zonas de toque Direita Esquerda Próxima @@ -577,7 +573,7 @@ Nenhuma Excluir: %s Incluir: %s - Data de busca + Data de busca do capítulo Os mangás nas categorias excluídas não serão atualizados mesmo que eles também estejam nas categorias incluídas. Os mangás nas categorias excluídas não serão disponibilizados offline mesmo que eles também estejam nas categorias incluídas. Download automático @@ -671,12 +667,12 @@ Imprime registros detalhados no registro de eventos do sistema (reduz o desempenho do aplicativo) Registro de eventos verboso Idioma - Atualizações com muitos itens prejudicam as fontes e podem deixar as atualizações lentas e aumentar o uso da bateria + Atualizações com muitos itens prejudicam as fontes e podem deixar as atualizações lentas e aumentar o uso da bateria. Toque para saber mais. Aviso Backups automáticos são altamente recomendados. Você deve manter cópias em outros locais também. Somente no Wi-Fi A cada 3 dias - Aviso: grandes downloads em massa podem levar as fontes a ficarem lentas e/ou começarem a bloquear o Tachiyomi + Aviso: grandes downloads em massa podem levar as fontes a ficarem lentas e/ou começarem a bloquear o Tachiyomi. Toque para saber mais. Mostrar a contagem de não lidos no ícone de Atualizações Atualizar tudo Atualizações do aplicativo @@ -720,4 +716,22 @@ Abrir no GitHub Limpar os dados da WebView Dados da WebView limpos + Fechar + Mostrar fontes fixadas duplicadas + Repete as fontes fixadas em seus respectivos grupos de idioma + Bateria não fraca + Bem, isso é esquisito + Nenhuma fonte instalada foi encontrada + Nenhuma fonte encontrada + Contagem de não lidos + Ultima atualização do mangá + Dividir automaticamente imagens compridas + Melhora o desempenho do leitor através da divisão de imagens compridas disponíveis offline. + Página %d não encontrada durante a divisão + Não foi possível encontrar o caminho do arquivo da página %d + Redefine o modo de leitura e orientação de todas as séries + Preferências do leitor redefinidas + Não foi possível redefinir as preferências do leitor + Redefinir as preferências do leitor + Não foi possível dividir a imagem transferida \ No newline at end of file diff --git a/app/src/main/res/values-pt/strings.xml b/app/src/main/res/values-pt/strings.xml index c35d6ce000..a427fba217 100644 --- a/app/src/main/res/values-pt/strings.xml +++ b/app/src/main/res/values-pt/strings.xml @@ -63,7 +63,7 @@ Tudo Restrições do aparelho para atualizações automáticas A carregar - Séries em curso + Com estado \'\'Terminado\'\' Atualizar progresso após a leitura Ecrã inteiro @@ -229,7 +229,6 @@ Anular Criar Semanalmente - Ecrã inicial Restaurar App não disponível Categoria padrão @@ -287,7 +286,7 @@ Mostrar com toque longo Abrir em WebView Cores 32-bit - Saltar capítulos marcados como lido + Ignorar capítulos marcados como lido A restauração usa as fontes para obter dados, cobranças adicionais podem ser efetuadas pelo operador. \n \nVerifique se instalou todas as extensões necessárias e tem sessão iniciada nas fontes e serviços de monitorização antes de restaurar. @@ -312,7 +311,7 @@ Transferir quantidade personalizada Monitorização Relendo - Situação + Estado Começado Tipo Autor @@ -378,7 +377,7 @@ Sempre Nunca - Após 1 minuto + Após %1$s minuto Após %1$s minutos Ecrã seguro @@ -388,7 +387,7 @@ Por favor, atualize a app de WebView para melhor compatibilidade Atualizações de capítulos Desbloquear o Tachiyomi - Esconder os conteúdos da app durante a troca de apps e impedir capturas de ecrã + Ecrã seguro esconde os conteúdos da app durante a troca de apps e impedir capturas de ecrã Visualização Capítulo %1$s e %2$d mais Capítulos %1$s @@ -404,7 +403,7 @@ Endereço de e-mail Mostrar sempre transição entre capítulos - Para 1 título + Para %d título Para %d títulos Menu @@ -414,7 +413,7 @@ Mover para o topo Mover para o final - 1 novo capítulo + %1$d novo capítulo %1$d novos capítulos Capítulo %1$s @@ -434,12 +433,11 @@ Preenchimento lateral Lendo Vertical contínuo - Saltar capítulos filtrados + Ignorar capítulos filtrados Verificar atualizações de extensão Desafixar Fixar Seleção inversa - Última verificação Fontes Sítio Web Restauro cancelado @@ -466,7 +464,7 @@ %02d min, %02d seg Apenas incluir fontes fixadas - 1 restante + %1$s restante %1$s restantes Cinzento @@ -508,7 +506,6 @@ Desativar todas Ativar todas Iniciar - Saltar para capítulos ao abrir Desativar Ambos Vertical @@ -517,7 +514,7 @@ Inverter toque Fonte não encontrada - 1 capítulo + %1$s capítulo %1$s capítulos Estado desconhecido @@ -533,7 +530,7 @@ Tema Data de adição - 1 monitorizador + %d monitorizador %d monitorizadores Você não possui fontes fixadas @@ -548,8 +545,8 @@ 18+ Isto não impede extensões não oficiais ou incorretamente marcadas de mostrarem conteúdo NSFW (18+) dentro da app. - A saltar 1 capítulo, ou está em falta na fonte ou foi filtrado - A saltar %d capítulos, ou está em falta na fonte ou foi filtrado + Ignorando %d capítulo, ou está em falta na fonte ou foi filtrado + Ignorando %d capítulos, ou está em falta na fonte ou foi filtrado Nenhum capítulo encontrado Definições padrão de capítulo atualizadas @@ -561,7 +558,6 @@ Definições de pesquisa Capítulos descarregados Mangas da biblioteca - Esconder a barra inferior ao deslocar Pausa histórico de leitura Modo incógnito Eliminar histórico @@ -612,7 +608,7 @@ Excluir: %s Incluir: %s Mangá em categorias excluídas não será atualizada mesmo que também estejam nas categorias incluídas. - Toque para ver os detalhes dos erros + Toque para ver detalhes Data de procura Horizontal Vertical @@ -691,12 +687,12 @@ Guardar como ficheiro CBZ %1$d mangás que não estão na biblioteca na base de dados Base de dados limpa - Aviso: grandes transferências em massa podem levar as fontes a ficarem lentas e/ou começarem a bloquear o Tachiyomi - Aviso: atualizações grandes prejudicam as fontes e podem deixar as atualizações lentas e aumentar o uso da bateria + Aviso: grandes downloads em massa podem levar as fontes a ficarem lentas e/ou começarem a bloquear o Tachiyomi. Toque para saber mais. + Grandes atualizações prejudicam as fontes e podem levar a atualizações lentas e ainda ao aumento do uso da bateria. Toque para saber mais. Para obter ajuda sobre como corrigir erros de atualização da biblioteca, veja %1$s Limpar a cache de capítulos ao fechar a app Este serviço de monitorização só é compatível com a fonte Komga. - Séries lidas completamente + Com capítulo(s) não lidos Sensibilidade para ocultar menu ao deslocar Alta Baixa @@ -704,7 +700,7 @@ Categorias excluídas Atividade em segundo plano Atualizações da app - Restrições de atualização da biblioteca + Ignorar títulos em atualização Invertido Cópias de segurança automáticas são altamente recomendadas. Também deve guardar cópias em outros locais. Interface de tablet @@ -725,4 +721,35 @@ Perguntas frequentes e Guias Mostrar mangá Iniciado + Desativado + Grelha apenas de capas + Fechar + Bateria não fraca + Mover séries para o topo + Ignorado porque a séria está completa + Ignorado porque nenhum capítulo foi lido + Ignorado + Ignorado porque existem capítulos não lidos + Tem uma entrada na sua biblioteca com o mesmo nome mas de uma fonte diferente (%1$s) +\n +\nAinda deseja continuar\? + Sem entradas na biblioteca para fazer cópia de segurança + Que não começaram a ser lidos + Erro: URI vazio + Limpar dados do WebView + Dados do WebView limpos + Vertical invertido + Nenhuma fonte instalada encontrada + Bem, isto é embaraçoso + %1$d atualização(ões) ignorada(s) + %1$d actualização(ões) falhada(s) + Toque para saber mais + Uma nova versão está disponível a partir dos lançamentos oficiais. Toque para saber como migrar de versões não oficiais do F-Droid. + Navegue para mover + Ampliar imagem horizontal + 5% + Abrir no GitHub + Erro ao guardar a imagem + Mostrar fontes fixadas duplicadas + Repita as fontes fixadas nos seus respetivos grupos de idiomas \ No newline at end of file diff --git a/app/src/main/res/values-ro/strings.xml b/app/src/main/res/values-ro/strings.xml index eb3c7789d0..761d537bae 100644 --- a/app/src/main/res/values-ro/strings.xml +++ b/app/src/main/res/values-ro/strings.xml @@ -87,7 +87,6 @@ Se încarcă Actualizați doar manga în desfășurare Actualizați progresul capitolului după citire - Ecran principal Categorie implicită Întreabă mereu Toate @@ -400,7 +399,6 @@ Verificați site-ul în WebView Verificați dacă există actualizări pentru extensii - Ultimul verificat Se actualizează biblioteca Citind Săriți peste capitolele filtrate @@ -502,7 +500,6 @@ Invertiți atingerea Stare necunoscută Autor necunoscut - Sari la capitole deschise Actualizat la v%1$s Ce este nou Descărcați capitolele necitite @@ -541,7 +538,6 @@ Setările capitolului Capitole descărcate Manga din bibliotecă - Ascundeți bara de jos când faceți scroll Setări de căutare Întrerupe citirea istoricului Modul incognito diff --git a/app/src/main/res/values-ru/strings.xml b/app/src/main/res/values-ru/strings.xml index 8b65f7ca9b..d8e0a7f845 100644 --- a/app/src/main/res/values-ru/strings.xml +++ b/app/src/main/res/values-ru/strings.xml @@ -155,7 +155,6 @@ Удалять после прочтения Ориентация по умолчанию Номер страницы - Начальный экран Серия завершена Режим чтения Стартовая позиция увеличения @@ -193,7 +192,7 @@ Загрузить Поиск обновлений… Обновлений не найдено - Загрузка завершена + Нажмите, для установки Ошибка загрузки Загрузка… Доступна новая версия! @@ -402,7 +401,6 @@ В начало В конец Переупорядочить - Проверенная серия Обновления расширений Разблокировать Tachiyomi Меню @@ -453,7 +451,7 @@ Режим чтения Для этой серии Серый - Уменьшает полосатость, но влияет на производительность + Уменьшает полосатость, но может влиять на производительность %d категория %d категории @@ -490,8 +488,8 @@ Страницы не найдены Включить всё Отключить всё - Ненадолго показать режим чтения после открытия читалки - Показать режим чтения + Ненадолго отобразить режим чтения после открытия читалки + Отобразить режим чтения Начать Источник не найден Отключить @@ -503,12 +501,11 @@ Для вступления в силу, требуется перезапуск приложения Сеть - При открытии серии переходить к главам Обе оси Вертикально Горизонтально Нет - Нажатие наоборот + Зоны касания наоборот Неизвестный статус Неизвестный автор Загрузить непрочитанные главы @@ -552,7 +549,6 @@ Поиск настроек Загруженные главы Серия из библиотеки - При прокрутке скрывать панель навигации Приостанавливает историю чтения Режим инкогнито Очистить историю @@ -562,10 +558,10 @@ Предыдущая страница Руководство по миграции источников Источники NSFW (18+) - Показать в списке источников и расширений + Отобразить в списке источников и расширений Приложение для выбора файлов не найдено Пожалуйста, авторизуйтесь в MyAnimeList снова - Схема навигации + Зоны касания По краям Kindle-подобная L-образная @@ -592,17 +588,17 @@ Справа Следующая Предыдущая - Ненадолго показать зоны касания при чтении - Наложение схемы навигации + Ненадолго отобразить при чтении + Наложение зон касания DNS по HTTPS (DoH) Нет Исключать: %s Включать: %s - Дата получения + Дата получения главы Серия не будет загружаться в исключённых категориях, даже если находится во включённых категориях. Серия не будет обновляться в исключённых категориях, даже если находится во включённых категориях. Автозагрузка - Нажмите, чтобы увидеть подробности + Нажать, чтобы увидеть подробности Эта версия Android больше не поддерживается Не удалось скопировать в буфер обмена Альбомная @@ -695,11 +691,11 @@ Записывать подробный журнал в системный журнал (снижает производительность приложения) Язык Предупреждение - Большое количество обновлений серий могут привести к замедлению работы источников и увеличению расхода батареи + Большое количество обновлений серий могут привести к замедлению работы источников и увеличению расхода батареи. Нажать, для подробностей. Настоятельно рекомендуется использовать автоматические резервные копии. Вы также должны хранить копии в разных папках. Только по Wi-Fi Каждые 3 дня - Предупреждение: большие объемы загрузок глав могут привести к замедлению работы источников и/или блокировке Tachiyomi + Предупреждение: большие объемы загрузок глав могут привести к замедлению работы источников и/или блокировке Tachiyomi. Нажмите, для подробностей. Непрочитанные главы на иконке «Обновления» Обновить все Обновления приложения @@ -718,7 +714,7 @@ Руководства и FAQ Ошибка: Пустой URI 5% - Показать серию + Отобразить серию В вашей библиотеке есть серия с таким же названием, но из другого источника (%1$s). \n \nВы по-прежнему хотите продолжить\? @@ -743,4 +739,21 @@ Открыть в GitHub Данные WebView очищены Очистить данные WebView + Закрыть + Повторять прикреплённые источники, в соответствии с их языковыми группами + Отображать дублированные приклеплённые источники + Батарея заряжена + Не найдено установленных источников + Упс, ошибочка вышла + Не найдено источников + Последнее обновление серий + Количество непрочитанных глав + Разделять длинные изображения + Страница %d не найдена, при разделении + Улучшает производительность читалки, разделяя длинные загруженные изображения. + Путь к файлам страницы %d не найден + Сбросить флажки просмотра + Сбрасывает режим чтения и ориентацию для всех серий + Флажки просмотра сброшены + Не удалось сбросить флажки просмотра \ No newline at end of file diff --git a/app/src/main/res/values-sa/strings.xml b/app/src/main/res/values-sa/strings.xml index 175478b377..95c6dbfe4a 100644 --- a/app/src/main/res/values-sa/strings.xml +++ b/app/src/main/res/values-sa/strings.xml @@ -29,7 +29,6 @@ शोधकं निष्करोतु वर्णक्रमानुसारिणि समस्ताः माङ्गाः - अन्तिमपरिशीलितम् नूतनः अध्यायः योजितदिनाङ्कः अन्वेषणम् @@ -151,12 +150,10 @@ उपरि मध्यः अधः - अधस्थां शलाकां सारयति सति वृणोतु समयमुद्राः सम्बन्धकसमयमुद्राः लघु (अद्य श्वः च) दीर्घम् (लघु+, n दिनपूर्वम्) - आरम्भकपटलम् आवेदनानि निर्वहतु संरक्षणम् उद्घाटनम् आवश्यकम् @@ -192,7 +189,6 @@ प्रतिदिनत्रयम् पारणसमये निर्बन्धाः - %s - उद्घाटने अध्यायान् दर्शयतु सार्वत्रिकनवीकरणम् प्रतिद्वादशघण्टा प्रतिसप्ताहिकम् diff --git a/app/src/main/res/values-sah/strings.xml b/app/src/main/res/values-sah/strings.xml index 57e534659e..a77ebbed81 100644 --- a/app/src/main/res/values-sah/strings.xml +++ b/app/src/main/res/values-sah/strings.xml @@ -20,7 +20,6 @@ Көрдөөһүн Киирбит кэмэ Бүтэһик түһүмэх - Бүтэһигинэн көрүллүбүт Бүтэһигинэн ааҕыллыбыт Түһүмэх ахсаанынан Алпаабыт бэрээдэгинэн @@ -74,7 +73,6 @@ Илиинэн Саҥардыы түргэнэ Улахан саҥардыы - Аһаҕас түһүмэххэ көһүү Сытыары Туруору Маллары кэккэ туруор @@ -93,7 +91,6 @@ Биллэриилэри салай Тахсыыны бигэргэт Даататын формаата - Сүрүн экран Холбоммут Араарыллыбыт Системнайы тутуһуҥ @@ -469,7 +466,6 @@ Остуоруйаны сотторуу Эрэллээххин дуо\? Остуоруйа барыта сотторуллуоҕа. Остуоруйа сотторулунна - Эргитэн түһэргэ алларааҥы хонууну сабыы Көрдөөһүн түстэлэ Киллэрэр дааннайдары талыы Аныгыскы сирэй diff --git a/app/src/main/res/values-sc/strings.xml b/app/src/main/res/values-sc/strings.xml index 869aeac762..7121b02689 100644 --- a/app/src/main/res/values-sc/strings.xml +++ b/app/src/main/res/values-sc/strings.xml @@ -89,7 +89,6 @@ Carrighende Cun s\'istadu \"acabbada\" Agiorna su progressu a pustis de sa leghidura - Ischermada de incumintzu Categoria predefinida Pedi semper Totus @@ -185,7 +184,7 @@ Isbòida sa memòria temporànea de sos capìtulos Impreados: %1$s Memòria temporànea isbodiada. %1$d documentos sunt istados iscantzellados - B\'at àpidu un\'errore durante s\'isbodiamentu de sa memòria temporànea + Errore durante s\'isboidamentu Iscantzella sos cookies Cookies iscantzellados Isbòida sa base de datos @@ -292,7 +291,7 @@ Non bi sunt agiornamentos disponìbiles noos Chirchende agiornamentos… Iscarrighende… - Iscarrigamentu acabadu + Toca pro installare Errore de iscarrigamentu Versione noa a disponimentu! Cobertedda de su manga @@ -388,7 +387,6 @@ Prus betzos Manda a pitzus Manda a fundu - Ùrtima chirca Chirca agiornamentos de sas estensiones B\'at un\'agiornamentu disponìbile pro un\'estensione @@ -486,7 +484,6 @@ Tenet bisòngiu chi torres a allùghere s\'aplicatzione pro tènnere efetu Retza - Brinca a sos capìtulos a s\'abertura Ambos Verticale Orizontale @@ -531,7 +528,6 @@ Impostatziones de chirca Capìtulos iscarrigados Manga dae sa biblioteca - Cua sa barra inferiore in s\'iscurridura Ponet in pàusa sa registratzione de sa cronologia de leghidura Modalidade anònima Isbòida sa cronologia @@ -577,7 +573,7 @@ Esclude: %s Include: %s Perunu - Data recuperada + Data de recùperu de su capìtulu Sos manga in sas categorias esclùdidas non s\'ant a iscarrigare nemmancu si sunt fintzas in categorias inclùdidas. Iscarrigamentu automàticu Sos manga in sas categorias esclùdidas non s\'ant a agiornare nemmancu si sunt fintzas in categorias inclùdidas. @@ -673,10 +669,10 @@ Dae cara Limba Sas còpias de seguresa automàticas sunt racumandadas meda. Dias dèpere tènnere còpias fintzas in àteros logos. - Sos agiornamentos mannos diant pòdere fàghere dannu a sas fontes e causare agiornamentos prus lentos e fintzas un\'impreu de sa bateria prus mannu + Sos agiornamentos mannos diant pòdere fàghere dannu a sas fontes e causare agiornamentos prus lentos e fintzas un\'impreu de sa bateria prus mannu. Toca pro nde ischire de prus. Cada 3 dies Petzi cun su Wi-Fi - Dae cara: sos iscarrigamentos de massa mannos diant pòdere rallentare sas fontes e/o blocare Tachiyomi + Dae cara: sos iscarrigamentos de massa mannos diant pòdere rallentare sas fontes e/o blocare Tachiyomi. Toca pro nde ischire de prus. Ammustra su nùmeru de capìtulos non lèghidos in s\'icona de sos agiornamentos Agiorna totu Agiornamentos de s\'aplicatzione @@ -718,4 +714,18 @@ B\'est una versione noa ufitziale a disponimentu. Toca pro imparare comente tramudare dae sas versiones no ufitziales de F-Droid. Aberi in GitHub Perunu elementu in biblioteca de pònnere in sa còpia de seguresa + Isbòida sos datos de WebView + Datos de WebView isboidados + Serra + Bateria non bassa + Ammustra sas fontes apicadas dòpias + Repite sas fontes apicadas in sos grupos de limbas rispetivos + Ùrtimu agiornamentu de sos manga + Contu de non lèghidos + Peruna fonte agatada + Peruna fonte installada agatada + Oja, custu est impitzosu + Partzi in automàticu sas immàgines artas + Megiorat su rendimentu de su leghidore partzende sas immàgines artas iscarrigadas. + Pàgina %d no agatada partzende \ No newline at end of file diff --git a/app/src/main/res/values-sdh/strings.xml b/app/src/main/res/values-sdh/strings.xml index 97b4c565ac..9565957df0 100644 --- a/app/src/main/res/values-sdh/strings.xml +++ b/app/src/main/res/values-sdh/strings.xml @@ -62,7 +62,6 @@ یارمەتی گەڕان بە دوای چاپتەری نوێدا تۆماری ڕابردووەکەت بەتاڵە - کۆتا پشکنین گەڕان لە ناو سازکارییەکان وەک نەخوێندراوێک ئاماژەی پێبکە نیشان نەکردنی چاپتەر @@ -173,13 +172,11 @@ سەرەوە ناوەڕاست خوارەوە - شاردنەوەی دوگمەی شریتەکە لە کاتی جوڵان تۆماری کات تۆماری کاتی ڕێژەیی کورت (ئەمڕۆ، دوێنێ) درێژ (کورت، + چەند ڕۆژ پێش ئێستا) ڕێکخستنی بەروار - شاشەی سەرەتا دڵنیابوون لە دەرچوون بەڕێوەبردنی ئاگانامەکان سازکاری پارێزراوی diff --git a/app/src/main/res/values-si/strings.xml b/app/src/main/res/values-si/strings.xml index f719493415..f990c1fb46 100644 --- a/app/src/main/res/values-si/strings.xml +++ b/app/src/main/res/values-si/strings.xml @@ -44,6 +44,36 @@ පටන් ගත්තා සම්පූර්ණ පරිච්ඡේද ෆිල්ටඑක ඉවත් කරන්න - අවසන් වරට පරීක්ෂා කරන ලදී නවතම පරිච්ඡේදය + ප්රතිලෝම තෝරන්න + කියවූ බවට සලකුණු කරන්න + නොකියවූ ලෙස ලකුණු කරන්න + පෙර කියවූ ලෙස සලකුණු කරන්න + බාගත + පිටු සලකුණු පරිච්ඡේදය ඉවත් කරන්න + මකන්න + යාවත්කාලීන කරන්න(Update) + සියල්ල සබල කරන්න(Enable all) + සංස්කරණය කරන්න + කාණ්ඩ සංස්කරණය කරන්න + ප්‍රවර්ගය නැවත නම් කරන්න(Rename category) + පෙර පරිච්ඡේදය + ආරම්භ කරන්න + ගෝලීය සෙවීම + පුස්තකාලය යාවත්කාලීන කරන්න(Update library) + සියල්ල අක්‍රිය කරන්න + එකතු කරන්න + ප්රවර්ගය එකතු කරන්න(Add category) + කාණ්ඩ සකසන්න + කවරය සංස්කරණය කරන්න + ඉවත් කරන්න + නොකියවූ පරිච්ඡේද බාගන්න + සෙවුම් සැකසුම් + සියල්ල තෝරන්න + පිටු සලකුණු පරිච්ඡේදය + නවත්වන්න + පරිච්ඡේද බලන්න + ඊළඟ පරිච්ඡේදය + දැනට නවත්වන්න + නැවත උත්සාහ කරන්න \ No newline at end of file diff --git a/app/src/main/res/values-sk/strings.xml b/app/src/main/res/values-sk/strings.xml index b3f23b8d10..8052619d11 100644 --- a/app/src/main/res/values-sk/strings.xml +++ b/app/src/main/res/values-sk/strings.xml @@ -91,7 +91,6 @@ Nabíjanie Prebiehajúca séria Synchronizovať kapitoly po prečítaní - Úvodná obrazovka Predvolená kategória Vždy sa opýtať Všetky @@ -354,7 +353,6 @@ Hľadať v nastaveniach Dátum pridaný Dátum načítaný - Naposledy skontrolované Stlačte tlačidlo späť znova pre ukončenie Prihlásiť sa pre potvrdenie zmien Predvolené @@ -425,7 +423,6 @@ Vrchol Stred Dole - Skryť spodnú lištu pri posúvaní Jahodové Daiquiri Modrozelená a tyrkysová Časová značka @@ -461,6 +458,5 @@ Automaticky obnovovať sledovače Aktualizujte sledovače pri aktualizácii knižnice Zobraziť - Pri otvorení prejsť na kapitoly Každé 3 dni \ No newline at end of file diff --git a/app/src/main/res/values-sr/strings.xml b/app/src/main/res/values-sr/strings.xml index d473a3b385..1572654f5c 100644 --- a/app/src/main/res/values-sr/strings.xml +++ b/app/src/main/res/values-sr/strings.xml @@ -87,9 +87,8 @@ Све Ограничења уређаја за аутоматска ажурирања Пуњење - Završeni serijal + Sa završenim \"Statusom\" Ажурирај пратиоца након читања - Почетни екран Podrazumevana kategorija Увек питај Све @@ -184,7 +183,7 @@ Испразни кеш меморију поглавља Искоришћено: %1$s Кеш је испражњен. Уклоњених фајлова: %1$d - Дошло је до грешке током пражњења кеша + Došlo je do greške prilikom brisanja Избриши колачиће Колачићи су избрисани Избриши базу података @@ -304,7 +303,6 @@ Ukolni oznaku Označi Izaberi obrnuto - Zadnje pregledano Meni Притисните поново назад да бисте изашли Samo preuzeto @@ -421,7 +419,6 @@ Изаберите слику за омот Морате прво додати мангу у колекцију Ажурирање омота није успјело - Сакриј доњу траку Tema Onemogući Prikaži naslove umetaka @@ -446,7 +443,6 @@ Провери да ли постоје нови омоти при ажурирању колекције Аутоматски освежи метаподатке - Idi na poglevlje sa otvaranjem Ovo ne sprečava nezvanične ili potencijalno pogrešno označene dodatke da prikažu sadržaj za odrasle (18+) unutar aplikacije. Zapraćeno Dole @@ -688,7 +684,7 @@ Водич за миграцију извора Упозорење: велики број преузимања може довести до успоравања извора и/или блокирања Tachiyomi-ја Ажурирање колекције... (%1$d/%2$d) - Упозорење: велики број ажурирања штети изворе и може довести до споријих ажурирања и повећане потрошње батерије + Velika ažuriranja štete izvorima i mogu dovesti do sporijeg ažuriranja i povećane potrošnje baterije Прикажи број непрочитаних на икони \"Ново\" Ажурирај све Ажурирања апликације @@ -696,12 +692,12 @@ Преузимање листе додатака није успело Испразни кеш меморију при изласку из апликације Čišćenje baze podataka - Preskoči ažuriranja - Ima pročitana poglavlja + Preskočite ažuriranje naslova + Sa neporcitanim poglavljem(ima) Политика приватности Otkazano Na pauzi - Nema pročitanih poglavlja + To nije započeto Prikaži mange 5% Započeto @@ -726,4 +722,14 @@ Preskočeno jer je serijal završen Preskočeno jer ima nepročitanih poglavlja Onesposobljen + Nova verzija je dostupna u zvaničnim izdanjima.Dodirnite da naučite kako da predjete sa nezvaničnih izdanja F-Droid-a. + Nema unosa u biblioteku za pravljenje rezervnih kopija + Otvorite na GitHub-u + Greška pri čuvanju slike + Zatvoriti + Baterija nije prazna + Ponovite zakačene izvore u njihovim jezičkim grupama + Obrišite podatke WebView-a + Podaci WebView-a su obrisani + Prikaži duplirane zakačene izvore \ No newline at end of file diff --git a/app/src/main/res/values-sv/strings.xml b/app/src/main/res/values-sv/strings.xml index 860e3d0b98..f4cfb2f2e5 100644 --- a/app/src/main/res/values-sv/strings.xml +++ b/app/src/main/res/values-sv/strings.xml @@ -89,7 +89,6 @@ Laddning Med status \"Avslutat\" Uppdatera förlopp efter läsning - Startskärm Standardkategori Fråga alltid Alla @@ -184,7 +183,7 @@ Rensa kapitelcache Används: %1$s Cache rensad. %1$d filer har tagits bort - Ett fel uppstod medan cache rensades + Fel inträffade vid rensning Radera cookies Cookies rensade Rensa databas @@ -291,7 +290,7 @@ Inga nya uppdateringar tillgängliga Söker efter uppdateringar… Laddar ner… - Nedladdning färdig + Tryck på för att installera Nedladdningsfel Ny version tillgänglig! Omslag av mangan @@ -396,7 +395,6 @@ Uppdaterar biblioteket Kontrollera webbplatsen i WebView Sök efter tilläggsuppdateringar - Senast kontrollerad Läser Hoppa över filtrerade kapitel Källor @@ -442,7 +440,7 @@ Läsläge För denna serie Grå - Minskar färgbandning men kräver mer prestanda + Minskar bandning, men kan påverka prestandan %d kategori %d kategorier @@ -453,7 +451,7 @@ Det gick inte att öppna enhetsinställningarna Olästa kapitel - Uppdatera bibliotekets manga omslag + Uppdatera bibliotekets mangaomslag Envägssynkronisering för att uppdatera kapitelförloppet i spårningstjänster. Ställ in spårning för enskilda manga från spårningsknappen under manga info. Efter uppladdningsdatum Data @@ -482,7 +480,7 @@ Vertikal Horisontell Ingen - Invertera tryck + Invertera tryckzoner Källan hittades inte %1$s kapitel @@ -492,7 +490,6 @@ Okänd författare Kräver omstart av appen för att börja gälla Nätverk - Hoppa till kapitel vid öppning Inaktivera Det gick inte att ladda ner kapitelt på grund av lågt lagringsutrymme Sök efter \"%1$s\" globalt @@ -535,7 +532,6 @@ Rensa historik Är du säker\? All historik kommer att försvinna. Historiken har tagits bort - Dölj navigationsfältet vid skrollning Sök inställningar Nästa sida Föregående sida @@ -554,7 +550,7 @@ Stigande Slutdatum Start datum - Navigationslayout + Tryckzoner Kant Kindle-ish L-formad @@ -571,13 +567,13 @@ Föregående Om placeringen av dubbelsidesdelningen inte matchar läsriktningen Invertera dubbelsidig delad placering - Visa tryckzoner kort när läsaren öppnas - Visa överlägg för navigeringslayout + Visa kort när läsaren öppnas + Visa överlägg för tryckzoner DNS över HTTPS (DoH) Exkludera: %s Inkludera: %s Ingen - Datum hämtat + Datum för hämtning av kapitel Manga i uteslutna kategorier laddas inte ner även om de också ingår i inkluderade kategorier. Ladda ned automatiskt Manga i uteslutna kategorier uppdateras inte även om de också ingår i inkluderade kategorier. @@ -674,8 +670,8 @@ Varning Språk Bara över Wi-Fi - Stora uppdateringar skadar källor och kan leda till långsammare uppdateringar samt en ökad batterianvändning - Varning: stora massnerladdningar kan leda till att källor blir långsamma och/eller blockerar Tachiyomi + Stora uppdateringar skadar källor och kan leda till långsammare uppdateringar samt en ökad batterianvändning. Tryck för att få veta mer. + Varning: stora massnerladdningar kan leda till att källor blir långsamma och/eller blockerar Tachiyomi. Tryck för att få veta mer. Var 3:e dag Visa antalet olästa på ikonen Uppdateringar Uppdatera alla @@ -718,4 +714,23 @@ En ny version finns tillgänglig i de officiella utgåvorna. Tryck på för att lära dig hur du flyttar från inofficiella F-Droid-versioner. Inga biblioteksposter att säkerhetskopiera Öppna på GitHub + Batteriet är inte lågt + Visa duplicerade källor med pinned-markeringar + Rensa data från WebView + WebView-data rensas + Stäng + Upprepa källor som är upptagna i sina respektive språkgrupper + Ingen installerad källa hittades + Ja, det här var ju pinsamt + Sista manga-uppdateringen + Antal olästa + Automatisk delning av höga bilder + Förbättrar läsarens prestanda genom att dela upp långa nedladdade bilder. + Sida %d hittades inte under delning + Ingen källa hittad + Kunde inte återställa visningsflaggorna + Återställer visningsflaggor + Återställer läsläge och orientering för alla serier + Kunde inte hitta filsökvägen för sida %d + Återställning av visningsflaggor \ No newline at end of file diff --git a/app/src/main/res/values-ta/strings.xml b/app/src/main/res/values-ta/strings.xml index d9b8a0c28c..7fec00768a 100644 --- a/app/src/main/res/values-ta/strings.xml +++ b/app/src/main/res/values-ta/strings.xml @@ -26,7 +26,6 @@ அமைப்புகள் கண்காணிப்பு பட்டியல் - சமீபத்தில் பார்த்தவை சமீப அலகுகள் சேர்க்கப்பட்ட தேதி தேடுதல் diff --git a/app/src/main/res/values-te/strings.xml b/app/src/main/res/values-te/strings.xml index 19262df477..af7474fce0 100644 --- a/app/src/main/res/values-te/strings.xml +++ b/app/src/main/res/values-te/strings.xml @@ -38,7 +38,6 @@ వెతకండి జోడించబడిన తేదీ నూతన అధ్యాయము - చివరిగా తనిఖీ చేయబడినది చివరిగా చదివినది సమస్త అధ్యాయములు అక్షరక్రమములో @@ -141,7 +140,6 @@ మార్గదర్శనము ఆకుపచ్చ సేవఫలము యిన్ మరియు యాంగ్ - ప్రథమ ప్రదర్శనము ఎప్పుడూ వద్దు సందెచీకటి @@ -162,7 +160,6 @@ పైన మధ్య క్రింద - సారణమును చేయునపుడు క్రిందటి కడ్డీని దాయుము సమయ ముద్రణలు సంబంధిత సమయ ముద్రణలు నిష్రమణమును నిర్ధారించుము diff --git a/app/src/main/res/values-th/strings.xml b/app/src/main/res/values-th/strings.xml index fde2569253..1f0b5b5190 100644 --- a/app/src/main/res/values-th/strings.xml +++ b/app/src/main/res/values-th/strings.xml @@ -102,7 +102,6 @@ อัปเดตข้อจำกัดของอุปกรณ์โดยอัตโนมัติ มีเรื่องที่มีสถานะ \"จบแล้ว\" อัปเดตความคืบหน้าหลังอ่าน - หน้าเริ่มต้น หมวดหมู่เริ่มต้น ทั้งหมด เชื่อถือได้ @@ -182,7 +181,7 @@ ล้างแคชตอน ใช้ไปแล้ว: %1$s ล้างแคชแล้ว แฟ้ม %1$d รายการได้ถูกลบ - เกิดข้อผิดพลาดขณะล้างแคช + เกิดข้อผิดพลาดขณะกำลังล้าง ล้างคุกกี้ ล้างคุกกี้แล้ว ล้างฐานข้อมูล @@ -301,7 +300,7 @@ ไม่มีการอัปเดตใหม่ กำลังค้นหาอัปเดต… กำลังดาวน์โหลด… - ดาวน์โหลดเสร็จสิ้น + แตะเพื่อติดตั้ง เกิดข้อผิดพลาดในการดาวน์โหลด มีเวอร์ชั่นใหม่! ปกมังงะ @@ -339,18 +338,18 @@ แนวตั้ง แนวนอน ไม่มี - กลับด้านการแตะ + กลับด้านโซนการแตะ ข้ามตอนที่กรองไว้ โทนสีเทา - ลดปัญหาแถบสี แต่ส่งผลต่อประสิทธิภาพ + ลดปัญหาแถบสี แต่อาจส่งผลต่อประสิทธิภาพ แสดงโหมดปัจจุบันสั้น ๆ เมื่อตัวอ่านเปิดขั้นมา แสดงโหมดการอ่าน แสดงเนื้อหาในพื้นที่ตัดออก หากการจัดวางการแยกหน้าคู่ไม่ตรงกับทิศทางการอ่าน แยกหน้าคู่แบบสลับตำแหน่ง แยกหน้าคู่ - แสดงโซนการแตะเมื่อเปิดตัวอ่าน - แสดงเมนูแถบนําทาง + แสดงครู่หนึ่งเมื่อเปิดตัวอ่าน + แสดงตำแหน่งโซนการแตะ อาจมีเนื้อหา NSFW (18+) 18+ ส่วนขยายนี้ไม่ได้มาจากรายการส่วนขยายทางการของ Tachiyomi @@ -368,7 +367,6 @@ ตรวจสอบหน้าปกและรายละเอียดใหม่เมื่ออัปเดตคลัง โหลดข้อมูลเมตาใหม่โดยอัตโนมัติ อัปเดตทั้งหมด - ไปที่ตอนเมื่อเปิด การแสดงผล นี่ไม่ได้เป็นการป้องกันไม่ให้ส่วนขยายที่ไม่เป็นทางการ หรือที่อาจถูกตั้งค่าสถานะไม่ถูกต้อง ให้แสดงเนื้อหา NSFW (18+) ภายในแอป แสดงในรายการแหล่งข้อมูลและส่วนขยาย @@ -385,7 +383,6 @@ จำเป็นต้องปลดล็อก ความปลอดภัย จัดการการแจ้งเตือน - ซ่อนแถบด้านล่างเมื่อเลื่อน ยืนยันการออก รูปแบบวันที่ เปิด @@ -409,8 +406,8 @@ จัดเรียงใหม่ ยกเลิกทั้งหมดสำหรับเรื่องนี้ ยกเลิกทั้งหมด - ยกเลิกการปักหมุด - ปักหมุด + ยกเลิกการตรึง + ตรึง ปิดการใช้งาน แสดงจำนวน แสดงแท็บหมวดหมู่ @@ -425,9 +422,8 @@ สลับการเลือก ตั้งค่าการค้นหา วันที่เพิ่ม - วันที่ดึงข้อมูล + วันที่ดึงข้อมูลตอน ตอนล่าสุด - ตรวจสอบล่าสุด ติดตามแล้ว เมนู กดกลับอีกครั้งเพื่อออก @@ -443,7 +439,7 @@ การอ่าน โหมดการอ่าน ประเภทการหมุน - เค้าโครงการนําทาง + โซนการแตะ แนวตั้งต่อเนื่อง ขวา ถัดไป @@ -488,10 +484,10 @@ เพิ่มไปยังคลัง ไม่ระบุสถานะ ไม่ทราบผู้แต่ง - ไม่มีแหล่งที่มาที่ปักหมุดไว้ + ไม่มีแหล่งที่มาที่ตรึงไว้ คู่มือแหล่งที่มาภายในเครื่อง ค้นหา \"%1$s\" ในทั้งหมด - หมุดที่ปักไว้ + ที่ตรึงไว้ ใช้ล่าสุด ตรวจสอบเว็บไซต์ใน WebView แท็บ @@ -524,7 +520,7 @@ ดัมพ์บันทึกข้อขัดข้อง โหลดปกมังงะในคลังใหม่ ข้อมูล - ต้องรีสตาร์ทแอพจึงจะมีผล + ต้องรีสตาร์ทแอปจึงจะมีผล DNS ผ่าน HTTPS (DoH) เครือข่าย ยกเลิกการคืนค่า @@ -546,7 +542,7 @@ ข้อมูลสำรองไม่ถูกต้อง ไม่ได้เข้าสู่ระบบ: %1$s ไม่พบแหล่งที่มา: %1$s - เฉพาะแหล่งที่มาที่ปักหมุดไว้เท่านั้น + เฉพาะแหล่งที่มาที่ตรึงไว้เท่านั้น ตรวจสอบการอัปเดตส่วนขยาย ซิงค์ทางเดียวเพื่ออัปเดตความคืบหน้าของตอนกับบริการการติดตาม ตั้งค่าการติดตามรายการมังงะในแต่ละรายการได้จากปุ่มติดตาม มังงะในหมวดหมู่ที่ยกเว้นไว้จะไม่ถูกดาวน์โหลดแม้ว่าจะอยู่ในหมวดหมู่ที่รวมอยู่ด้วยก็ตาม @@ -554,7 +550,7 @@ กำลังตรวจสอบตอนหาใหม่ ไม่สามารถดาวน์โหลดตอนได้เนื่องจากพื้นที่จัดเก็บเหลือน้อย ไม่รองรับ Android เวอร์ชันนี้อีกต่อไป - ไม่พบแอพเลือกแฟ้ม + ไม่พบแอปเลือกแฟ้ม ตอนที่ %1$s และอีก %2$d ตอน @@ -635,7 +631,7 @@ UI แท็บเล็ต มังงะ %1$d เรื่อง ที่ไม่ได้อยู่ในคลังในฐานข้อมูล ล้างฐานข้อมูลแล้ว - ผู้ผลิตบางรายมีข้อจำกัดเพิ่มเติมของแอพที่ปิดบริการพื้นหลัง เว็บไซต์นี้มีข้อมูลเพิ่มเติมเกี่ยวกับวิธีการแก้ไข + ผู้ผลิตบางรายมีข้อจำกัดเพิ่มเติมของแอปที่ปิดบริการพื้นหลัง เว็บไซต์นี้มีข้อมูลเพิ่มเติมเกี่ยวกับวิธีการแก้ไข การบันทึกอย่างละเอียด ข้ามการอัปเดต ลักษณะ @@ -674,9 +670,9 @@ ทุก 3 วัน ข้อจำกัด: %s เฉพาะขณะเชื่อมต่อ Wi-Fi - คำเตือน: การดาวน์โหลดจำนวนมากอาจทำให้แหล่งข้อมูลทำงานช้าลงและ/หรือปิดกั้น Tachiyomi + คำเตือน: การดาวน์โหลดจำนวนมากอาจทำให้แหล่งข้อมูลทำงานช้าลงและ/หรือปิดกั้น Tachiyomi แตะเพื่อเรียนรู้เพิ่มเติม กำลังอัปเดตคลัง… (%1$d/%2$d) - การอัปเดตจำนวนมากเป็นอันตรายต่อแหล่งที่มาและอาจทำให้การอัปเดตช้าลงและใช้งานแบตเตอรี่เพิ่มขึ้น + การอัปเดตจำนวนมากเป็นอันตรายต่อแหล่งที่มาและอาจทำให้การอัปเดตช้าลงและใช้งานแบตเตอรี่เพิ่มขึ้น แตะเพื่อเรียนรู้เพิ่มเติม เผยแพร่จบแล้ว ถูกยกเลิก อยู่ระหว่างพัก @@ -706,4 +702,23 @@ มีเวอร์ชันใหม่พร้อมใช้งานจากรีลีสทางการ แตะเพื่อเรียนรู้วีธีการย้ายข้อมูลจากรีลีสไม่เป็นทางการ F-Droid เปิดใน GithHub ไม่มีรายการคลังถูกสำรองข้อมูลไว้ + แสดงแหล่งที่มาที่ตรึงไว้ที่ซ้ำกัน + ทำซ้ำแหล่งที่มาที่ตรึงไว้เป็นกลุ่มภาษา + ปิด + ล้างข้อมูล WebView + ล้างข้อมูล WebView แล้ว + แบตเตอรี่ยังไม่ต่ำ + ไม่พบแหล่งที่มาที่ติดตั้งแล้ว + เอ่อ แย่ชะมัด + ไม่พบแหล่งที่มาใด ๆ + จำนวนตอนที่ยังไม่ได้อ่าน + มังงะที่อัปเดตล่าสุด + แยกรูปภาพที่สูงยาวออกโดยอัตโนมัติ + ไม่พบหน้า %d ขณะกำลังแยกหน้า + เพิ่มประสิทธิภาพตัวอ่านด้วยการแยกรูปภาพที่สูงยาวที่ดาวน์โหลดไว้ + ไม่พบตำแหน่งไฟล์ของหน้า %d + รีเซ็ต flag ตัวดู + รีเซ็ตโหมดการอ่านและการจัดวางของทุกเรื่อง + รีเซ็ต flag ตัวดูแล้ว + ไม่สามารถรีเซ็ต flag ตัวดู \ No newline at end of file diff --git a/app/src/main/res/values-tr/strings.xml b/app/src/main/res/values-tr/strings.xml index 7f71d2b1d2..63565e19d0 100644 --- a/app/src/main/res/values-tr/strings.xml +++ b/app/src/main/res/values-tr/strings.xml @@ -89,7 +89,6 @@ Şarj oluyor \"Tamamlanan\" durumda olan Okuyunca ilerlemeyi güncelle - Başlangıç ekranı Varsayılan kategori Her zaman sor Tümü @@ -283,7 +282,7 @@ Yeni güncelleme yok Güncellemeler aranıyor… İndiriliyor… - İndirme tamamlandı + Kurmak için dokunun İndirme hatası Yeni sürüm var! Manganın kapağı @@ -388,7 +387,6 @@ En eski En üste taşı En alta taşı - Son denetleme Uzantı güncellemelerini denetle Uzantı güncellemesi var @@ -440,7 +438,7 @@ Yalnızca sabitlenmiş kaynakları içer Gri - Renk şeritlerini azaltır, ancak performansı etkiler + Renk şeritlerini azaltır, ancak performansı etkileyebilir Okuma kipi Bu seri için @@ -486,9 +484,8 @@ Etkili olması için uygulamanın yeniden başlatılmasını gerektirir - Açınca bölümlere git Yok - Dokunmayı ters çevir + Dokunma bölgelerini ters çevir Her ikisi de Dikey Yatay @@ -531,7 +528,6 @@ Arama ayarları İndirilen bölümler Kitaplıktan manga - Kaydırmada alt çubuğu gizle Okuma geçmişini duraklatır Gizli kip Geçmişi temizle @@ -544,7 +540,7 @@ Kaynaklar ve uzantılar listesinde göster Dosya seçme uygulaması bulunamadı Lütfen MAL\'ye tekrar giriş yapın - Gezinme düzeni + Dokunma bölgeleri Kenar Kindle gibi L şeklinde @@ -571,13 +567,13 @@ Sol Sonraki Önceki - Okuyucu açıldığında dokunma bölgelerini göster - Gezinme düzeni kaplamasını göster + Okuyucu açıldığında kısaca göster + Dokunma bölgeleri kaplamasını göster HTTPS üzerinden DNS (DoH) Hariç tut: %s Dahil et: %s Yok - Alındığı tarih + Bölümün alındığı tarih Hariç tutulan kategorilerdeki manga, dahil edilen kategorilerde olsa bile indirilmeyecektir. Otomatik indir Hariç tutulan kategorilerdeki manga, dahil edilen kategorilerde olsa bile güncellenmeyecektir. @@ -671,11 +667,11 @@ Uyarı Dil Otomatik yedeklemeler şiddetle tavsiye edilir. Kopyaları başka yerlerde de tutmalısınız. - Büyük güncellemeler kaynaklara zarar verir ve daha yavaş güncellemelere ve ayrıca pil kullanımının artmasına neden olabilir + Büyük güncellemeler kaynaklara zarar verir ve daha yavaş güncellemelere ve ayrıca pil kullanımının artmasına neden olabilir. Daha fazlasını öğrenmek için dokunun. Ayrıntılı günlük kaydı Ayrıntılı günlükleri sistem günlüğüne yaz (uygulama performansını düşürür) Yalnızca Wi-Fi\'de - Uyarı: büyük toplu indirmeler kaynakların yavaşlamasına ve/veya Tachiyomi\'yi engellemesine neden olabilir + Uyarı: büyük toplu indirmeler kaynakların yavaşlamasına ve/veya Tachiyomi\'yi engellemesine neden olabilir. Daha fazlasını öğrenmek için dokunun. Her 3 günde Güncellemeler simgesinde okunmayan sayısını göster Tümünü güncelle @@ -720,4 +716,22 @@ GitHub\'da aç WebView verileri temizlendi WebView verilerini temizle + Kapat + Yinelenen sabitlenmiş kaynakları göster + Sabitlenen kaynakları ilgili dil gruplarında tekrarla + Pil düşük değil + Bu çok garip + Kurulu kaynak bulunamadı + Kaynak bulunamadı + Son manga güncellemesi + Okunmayan sayısı + Uzun görselleri otomatik böl + İndirilen uzun görselleri bölerek okuyucu performansını artırır. + Bölünürken sayfa %d bulunamadı + Sayfa %d dosya yolu bulunamadı + Görüntüleyici seçeneklerini sıfırla + Tüm serilerin okuma kipini ve yönünü sıfırlar + Görüntüleyici seçenekleri sıfırlandı + Görüntüleyici seçenekleri sıfırlanamadı + İndirilen görsel bölünemedi \ No newline at end of file diff --git a/app/src/main/res/values-uk/strings.xml b/app/src/main/res/values-uk/strings.xml index 9551793bbc..d294f77ad5 100644 --- a/app/src/main/res/values-uk/strings.xml +++ b/app/src/main/res/values-uk/strings.xml @@ -89,7 +89,6 @@ Заряджається Завершена серія Оновлювати прогрес після прочитання - Стартовий екран Категорія за замовчуванням Завжди запитувати Всі @@ -393,7 +392,6 @@ Найстаріші Перемістити догори Перемістити додолу - Востаннє перевірено Перевірити оновлення розширень Наявне оновлення для розширення @@ -507,7 +505,6 @@ Невідомий автор Потрібен перезапуск додатку, щоб зміни вступили в дію Мережа - Перейти до глав при відкритті Оновлено до v%1$s Що новенького Завантажити непрочитані глави @@ -548,7 +545,6 @@ Налаштування глави Завантажені глави Манга з бібліотеки - Приховати нижню панель при прокручуванні Налаштування пошуку Призупиняє історію читання Режим інкогніто diff --git a/app/src/main/res/values-uz/strings.xml b/app/src/main/res/values-uz/strings.xml index f4f9f71d3d..3ea3e41816 100644 --- a/app/src/main/res/values-uz/strings.xml +++ b/app/src/main/res/values-uz/strings.xml @@ -29,7 +29,6 @@ Qidirish Qõshilgan sana Eng oxirgi bõlim - Oxirgi tekshirish Oxirgi õqilgan Umumiy bõlimlar Alifbo kõrinishida diff --git a/app/src/main/res/values-vi/strings.xml b/app/src/main/res/values-vi/strings.xml index 5f3916926c..484062ef0a 100644 --- a/app/src/main/res/values-vi/strings.xml +++ b/app/src/main/res/values-vi/strings.xml @@ -79,7 +79,6 @@ Đang sạc Với trạng thái \"Hoàn Thành\" Cập nhật tiến triển sau khi đọc - Màn hình khởi động Toàn màn hình Hoạt ảnh chuyển trang @@ -135,7 +134,7 @@ Dọn dẹp bộ nhớ đệm Đã sử dụng: %1$s Bộ nhớ đệm đã được dọn dẹp. %1$d tập tin đã bị xóa - Xảy ra lỗi khi xóa bộ nhớ đệm + Lỗi xảy ra trong khi xóa Dọn dẹp thông tin lưu trữ Thông tin lưu trữ đã được xóa Dọn dẹp cơ sở dữ liệu @@ -417,7 +416,6 @@ Xem các chương Đảo ngược lựa chọn Chương mới nhất - Lần kiểm tra gần nhất Mục chính Mở Khoá Tachiyomi Nguồn @@ -461,7 +459,6 @@ Có thể chứa nội dung NSFW 18+ 18+ Tự động làm mới bộ siêu dữ liệu - Chuyển đến các chương khi mở Điều này không ngăn các tiện ích mở rộng không chính thức hoặc có khả năng bị gắn cờ không chính xác hiển thị nội dung NSFW (18+) trong ứng dụng. Chỉ hiện truyện đã tải Hướng dẫn di chuyển nguồn @@ -608,7 +605,6 @@ Hiện số truyện Nguồn NSFW (18+) Hiển thị trong các danh sách nguồn và tiện ích mở rộng - Ẩn thanh dưới cùng khi kéo cuộn Chạm để xem toàn bộ chi tiết Giảm dần Tăng dần @@ -694,11 +690,11 @@ Ngôn ngữ Tự động sao lưu là phương án an toàn nhất. Bạn cũng nên giữ lại các bản sao chép ở những nơi khác nữa. In các ghi chép tường tận đến cả ghi chép hệ thống ( giảm hiệu suất ứng dụng ) - Các bản cập nhật lớn sẽ gây hại cho các nguồn và có thể dẫn đến các bản cập nhật chậm hơn và cũng làm tăng mức sử dụng pin + Các bản cập nhật lớn sẽ gây hại cho các nguồn và có thể dẫn đến các bản cập nhật chậm hơn và cũng làm tăng mức sử dụng pin. Nhấn vào để tìm hiểu thêm. Đang cài đặt tiện ích mở rộng… 3 ngày một lần Chỉ qua Wi-Fi - Cảnh báo: các tải xuống hàng loạt lớn có thể dẫn đến các nguồn trở nên chậm hơn và / hoặc chặn Tachiyomi + Cảnh báo: các tải xuống hàng loạt lớn có thể dẫn đến các nguồn trở nên chậm hơn và / hoặc chặn Tachiyomi. Nhấn vào để tìm hiểu thêm. Hiển thị số lượng chưa đọc ở phần biểu tượng Cập nhật Cập nhật ứng dụng Cập nhật tất cả @@ -738,4 +734,15 @@ Tắt Một phiên bản mới sẵn sàng từ mục phát hành chính thức. Nhấn để học cách kết hợp các mục phát hành không chính thức từ F-Droid. Lỗi khi lưu ảnh + Đóng + Hiện các nguồn bản sao được đính + Pin không quá ít + Các nguồn được đính sẽ lặp lại trong các nhóm ngôn ngữ tương ướng của chúng + Không có nguồn đã cài tìm thấy + Không có nguồn nào được tìm thấy + Ôi, thật là lạ thật đấy + Mở trên GitHub + Không có mục thư viện nào để sao lưu + Dữ liệu WebView đã được xóa + Xóa dữ liệu WebView \ No newline at end of file diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml index 4576108aef..41784ed356 100644 --- a/app/src/main/res/values-zh-rCN/strings.xml +++ b/app/src/main/res/values-zh-rCN/strings.xml @@ -89,7 +89,6 @@ 正在充电 状态为“已完结” 阅读后更新进度 - 起始页面 默认分类 始终询问 全部 @@ -173,7 +172,7 @@ 自动备份 备份频率 最大备份数 - 备份已创建 + 已创建备份 还原完毕 还原备份时需连接网络来抓取图源数据。 \n @@ -291,7 +290,7 @@ 没有可用的更新 正在检查更新… 正在下载… - 下载完毕 + 轻按安装 下载失败 有可用的新版本! 漫画封面 @@ -384,7 +383,6 @@ 最旧 移至顶部 移至底部 - 最近检查 自动检查扩展插件更新 %d 个扩展插件可更新 @@ -443,7 +441,7 @@ 耗时 %1$s,出现 %2$s 个错误 无法打开设备设置 - 减少色带,但会降低性能 + 减少色带,但也许会影响性能 未读章节 刷新书架漫画封面 将章节进度单向同步到追踪服务。点击「追踪」按钮以设置漫画的追踪源。 @@ -477,7 +475,6 @@ 需要重启应用才能生效 网络 - 打开时跳转到阅读章节 水平 + 垂直 垂直 水平 @@ -495,7 +492,7 @@ %d 个追踪源 - 反转轻触方向 + 反转点按区域 你尚未置顶任意图源 完成 进度 @@ -520,7 +517,6 @@ 搜索设置 已下载的章节 书架里的漫画 - 滚动时隐藏底栏 暂停记录阅读历史 无痕模式 清除历史 @@ -533,7 +529,7 @@ 未找到文件选择应用 请重新登录 MyAnimeList 在图源和扩展插件列表中显示 - 导航布局 + 点按区域 边缘样式 Kindle 样式 L 样式 @@ -560,13 +556,13 @@ 下页 上页 - 开始阅读时,显示点按区域 - 显示导航布局覆盖层 + 打开阅读器时短暂显示 + 显示点按区域覆盖 DNS over HTTPS (DoH) 排除:%s 包含:%s - 获取日期 + 章节获取日期 应用不会更新位于排除分类的漫画,即使它们同样位于包含分类。 应用不会下载位于排除分类的漫画,即使它们同样位于包含分类。 自动下载 @@ -661,10 +657,10 @@ 警告 语言 强烈建议启用自动备份,你也应该在其他地方保存副本。 - 大型更新会损害图源,并可能导致更新速度变慢以及电池用量增加 + 大型更新会损害图源,并可能导致更新速度变慢以及电池用量增加。轻按了解更多。 仅连接至 Wi-Fi 时 每 3 天 - 警告:批量下载可能会导致图源变慢和/或图源封锁 Tachiyomi + 警告:批量下载可能会导致图源变慢和/或图源封锁 Tachiyomi。轻按了解更多。 在更新图标上显示未读计数 全部更新 应用更新 @@ -708,4 +704,21 @@ 打开 Github 已清除 Webview 数据 清除 Webview 数据 + 非低电量 + 在各自的语言组中重复固定图源 + 显示重复的固定图源 + 关闭 + 额,好尴尬 + 未找到已安装的图源 + 未找到图源 + 上次漫画更新 + 未读数 + 自动拆分高图像 + 通过拆分下载的高图像来提高阅读器的性能。 + 拆分时未找到页 %d + 找不到页面 %d 的文件路径 + 重置查看器标志 + 重置所有连载的阅读模式和方向 + 已重置查看器标志 + 无法重置阅读器标志 \ No newline at end of file diff --git a/app/src/main/res/values-zh-rTW/strings.xml b/app/src/main/res/values-zh-rTW/strings.xml index a63ccca6ae..6b624e5ab2 100644 --- a/app/src/main/res/values-zh-rTW/strings.xml +++ b/app/src/main/res/values-zh-rTW/strings.xml @@ -85,7 +85,6 @@ 自動更新的裝置限制 充電時 已完結的作品 - 起始畫面 預設分類 總是詢問 更新 @@ -157,7 +156,7 @@ 沒有可用的更新 正在檢查更新… 正在下載更新… - 更新下載完成 + 輕觸即可安裝 更新下載失敗 有可用的更新! 沒有下載 @@ -403,7 +402,7 @@ 使用螢幕凹口區域 電子郵件地址 略過已篩選的章節 - 減緩色調分離,但拖累效能 + 減緩色調分離,但可能拖累效能 開始閱讀時,快顯闡明目前的模式 閱讀模式提示 僅在釘選的來源中搜尋 @@ -424,7 +423,6 @@ 重新排序 上傳日期 最新章節 - 最近檢查 無效的備份檔 備份已在進行 還原已在進行 @@ -450,10 +448,9 @@ 全部 垂直 水平 - 反轉輕觸方向 + 反轉輕觸區域 正在檢查是否有新章節 垂直連貫 - 開啟書籍時直接捲動至章節列表 歷時 %1$s,出現 %2$s 個錯誤 @@ -514,9 +511,8 @@ 沒有章節 保存為預設值 已刪除記錄 - 所有的閱讀記錄將會遺失,你確定嗎? + 你確定嗎?所有的閱讀記錄將會遺失。 清除閱讀記錄 - 捲動時隱藏底部功能表 暫停閱讀記錄 無痕模式 在 WebView 中檢查網站 @@ -541,7 +537,7 @@ 已產生當機記錄 產生錯誤記錄檔以便分享予開發人員 傾印當機記錄 - 輕觸翻頁模式 + 輕觸區域 左右式 依上傳日期 遞減 @@ -560,7 +556,7 @@ 左邊 上一頁 下一頁 - 擷取日期 + 章節獲取日期 右邊 橫向 操作 @@ -576,8 +572,8 @@ 分類同時屬於「排除」及「包含」的漫畫,將不會自動下載。 儲存頁面至個別資料夾 根據漫畫標題建立資料夾 - 開始閱讀時,浮現輕觸翻頁的點擊區域 - 翻頁方式提示 + 開始閱讀時,短暫浮現輕觸區域 + 輕觸區域提示 分類同時屬於「排除」及「包含」的漫畫,將不會自動更新。 取消此叢書 自動 @@ -658,13 +654,13 @@ 漫畫總數 語言 警告 - 大量更新會損害來源,並可能導致更新速度緩慢、電池用量增加 + 大量更新會損害來源,並可能導致更新速度緩慢、電池用量增加。輕觸以瞭解詳情。 錄製詳細記錄 強烈建議啟用自動備份,並在他處保留副本。 傾印詳細記錄至系統日誌 (將降低應用程式效能) 僅透過 Wi-Fi 每 3 日 - 警告:大量批次下載可能壅塞來源並 (或) 使其封鎖 Tachiyomi + 警告:大量批次下載可能壅塞來源並 (或) 使其封鎖 Tachiyomi。輕觸以瞭解詳情。 全部更新 在「新刊」導覽圖示上標記未讀章數 應用程式更新 @@ -708,4 +704,21 @@ 新版本已正式推出。輕觸以瞭解如何從非官方的 F-Droid 版遷移至官方發行版。 清除 WebView 資料 已清除 WebView 資料 + 關閉 + 電量充足時 + 重複顯示釘選來源 + 將來源同時釘選於「已釘選」及其所屬的語言分組 + 找不到來源 + 找不到已安裝的來源 + 呃…尷尬了 + 最後一次漫畫更新 + 未讀章數 + 分割時找不到第 %d 頁 + 自動分割過高圖片 + 將下載的圖片中尺寸較高者分割,以改善閱讀器效能。 + 找不到第 %d 頁的檔案路徑 + 重設閱讀器旗標 + 將所有叢書的閱讀模式和螢幕方向重設為預設值 + 已重設閱讀器旗標 + 無法重設閱讀器旗標 \ No newline at end of file From 628a3bc16c6f059757bc0e1502708f5a2d56732b Mon Sep 17 00:00:00 2001 From: arkon Date: Sat, 14 May 2022 19:18:01 -0400 Subject: [PATCH 27/80] Temporarily downgrade AGP to fix extension loading issue in non-debug builds --- gradle/androidx.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/androidx.versions.toml b/gradle/androidx.versions.toml index c973777671..b46ef77548 100644 --- a/gradle/androidx.versions.toml +++ b/gradle/androidx.versions.toml @@ -1,5 +1,5 @@ [versions] -agp_version = "7.2.0" +agp_version = "7.1.3" lifecycle_version = "2.5.0-rc01" [libraries] From bdb55ef8817557e1d4bb4eda1120949ef42a8b54 Mon Sep 17 00:00:00 2001 From: arkon Date: Sat, 14 May 2022 19:40:08 -0400 Subject: [PATCH 28/80] Update to AGP 7.2.0 again - Disable optimizations on eu.kanade.tachiyomi.source.** classes to avoid access modifications causing mismatches between the app and extensions - Remove Gson and Kotson Proguard rules, since we don't have those dependencies anymore --- app/proguard-rules.pro | 27 +-------------------------- gradle/androidx.versions.toml | 2 +- 2 files changed, 2 insertions(+), 27 deletions(-) diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro index 62c68321a9..ed60b8ed31 100644 --- a/app/proguard-rules.pro +++ b/app/proguard-rules.pro @@ -1,6 +1,7 @@ -dontobfuscate # Keep extension's common dependencies +-keep class eu.kanade.tachiyomi.source.** { public protected *; } # Avoid access modification -keep,allowoptimization class eu.kanade.tachiyomi.** { public protected *; } -keep,allowoptimization class androidx.preference.** { *; } -keep,allowoptimization class kotlin.** { public protected *; } @@ -9,8 +10,6 @@ -keep,allowoptimization class okio.** { public protected *; } -keep,allowoptimization class rx.** { public protected *; } -keep,allowoptimization class org.jsoup.** { public protected *; } --keep,allowoptimization class com.google.gson.** { public protected *; } --keep,allowoptimization class com.github.salomonbrys.kotson.** { public protected *; } -keep,allowoptimization class com.squareup.duktape.** { public protected *; } -keep,allowoptimization class app.cash.quickjs.** { public protected *; } -keep,allowoptimization class uy.kohesive.injekt.** { public protected *; } @@ -34,30 +33,6 @@ -dontnote rx.internal.util.PlatformDependent ##---------------End: proguard configuration for RxJava 1.x ---------- -##---------------Begin: proguard configuration for Gson ---------- -# Gson uses generic type information stored in a class file when working with fields. Proguard -# removes such information by default, so configure it to keep all of it. --keepattributes Signature - -# For using GSON @Expose annotation --keepattributes *Annotation* - -# Gson specific classes --dontwarn sun.misc.** - -# Prevent proguard from stripping interface information from TypeAdapter, TypeAdapterFactory, -# JsonSerializer, JsonDeserializer instances (so they can be used in @JsonAdapter) --keep class * extends com.google.gson.TypeAdapter --keep class * implements com.google.gson.TypeAdapterFactory --keep class * implements com.google.gson.JsonSerializer --keep class * implements com.google.gson.JsonDeserializer - -# Prevent R8 from leaving Data object members always null --keepclassmembers,allowobfuscation class * { - @com.google.gson.annotations.SerializedName ; -} -##---------------End: proguard configuration for Gson ---------- - ##---------------Begin: proguard configuration for kotlinx.serialization ---------- -keepattributes *Annotation*, InnerClasses -dontnote kotlinx.serialization.AnnotationsKt # core serialization annotations diff --git a/gradle/androidx.versions.toml b/gradle/androidx.versions.toml index b46ef77548..c973777671 100644 --- a/gradle/androidx.versions.toml +++ b/gradle/androidx.versions.toml @@ -1,5 +1,5 @@ [versions] -agp_version = "7.1.3" +agp_version = "7.2.0" lifecycle_version = "2.5.0-rc01" [libraries] From 6fb5552d574fbc505752c57259ada0d270d52d3b Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 15 May 2022 09:36:32 -0400 Subject: [PATCH 29/80] Update aboutlib_version to v10.2.0 (#7129) Co-authored-by: Renovate Bot --- gradle/libs.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index c6b36ae5bc..9516b0f224 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -1,5 +1,5 @@ [versions] -aboutlib_version = "10.1.0" +aboutlib_version = "10.2.0" okhttp_version = "4.9.3" nucleus_version = "3.0.0" coil_version = "2.0.0" From 4c9331c4e94d384393708eb6751b918bb31c5d06 Mon Sep 17 00:00:00 2001 From: CVIUS <84634607+CVIUS@users.noreply.github.com> Date: Sun, 15 May 2022 21:37:52 +0800 Subject: [PATCH 30/80] Settings cleanup (#7126) * Settings cleanup * Oops * Also hide "Invert tap zones" if tap zones is set to "Disabled" in ReaderReadingModeSettings --- .../ui/reader/setting/ReaderReadingModeSettings.kt | 7 ++++++- .../ui/setting/SettingsAdvancedController.kt | 14 +++++++++----- .../ui/setting/SettingsReaderController.kt | 2 ++ 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/setting/ReaderReadingModeSettings.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/setting/ReaderReadingModeSettings.kt index 8cf75a54cb..7ce06531c8 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/reader/setting/ReaderReadingModeSettings.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/reader/setting/ReaderReadingModeSettings.kt @@ -72,7 +72,9 @@ class ReaderReadingModeSettings @JvmOverloads constructor(context: Context, attr binding.pagerPrefsGroup.tappingInverted.bindToPreference(preferences.pagerNavInverted()) binding.pagerPrefsGroup.pagerNav.bindToPreference(preferences.navigationModePager()) - + preferences.navigationModePager() + .asImmediateFlow { binding.pagerPrefsGroup.tappingInverted.isVisible = it != 5 } + .launchIn((context as ReaderActivity).lifecycleScope) // Makes so that landscape zoom gets hidden away when image scale type is not fit screen binding.pagerPrefsGroup.scaleType.bindToPreference(preferences.imageScaleType(), 1) preferences.imageScaleType() @@ -102,6 +104,9 @@ class ReaderReadingModeSettings @JvmOverloads constructor(context: Context, attr binding.webtoonPrefsGroup.tappingInverted.bindToPreference(preferences.webtoonNavInverted()) binding.webtoonPrefsGroup.webtoonNav.bindToPreference(preferences.navigationModeWebtoon()) + preferences.navigationModeWebtoon() + .asImmediateFlow { binding.webtoonPrefsGroup.tappingInverted.isVisible = it != 5 } + .launchIn((context as ReaderActivity).lifecycleScope) binding.webtoonPrefsGroup.cropBordersWebtoon.bindToPreference(preferences.cropBordersWebtoon()) binding.webtoonPrefsGroup.webtoonSidePadding.bindToIntPreference(preferences.webtoonSidePadding(), R.array.webtoon_side_padding_values) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt index f8f9e4424d..510252d5d6 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsAdvancedController.kt @@ -15,6 +15,7 @@ import eu.kanade.tachiyomi.data.cache.ChapterCache import eu.kanade.tachiyomi.data.library.LibraryUpdateService import eu.kanade.tachiyomi.data.library.LibraryUpdateService.Target import eu.kanade.tachiyomi.data.preference.PreferenceValues +import eu.kanade.tachiyomi.data.track.TrackManager import eu.kanade.tachiyomi.network.NetworkHelper import eu.kanade.tachiyomi.network.PREF_DOH_ADGUARD import eu.kanade.tachiyomi.network.PREF_DOH_CLOUDFLARE @@ -59,6 +60,7 @@ class SettingsAdvancedController( private val network: NetworkHelper by injectLazy() private val chapterCache: ChapterCache by injectLazy() + private val trackManager: TrackManager by injectLazy() @SuppressLint("BatteryLife") override fun setupPreferenceScreen(screen: PreferenceScreen) = screen.apply { @@ -212,12 +214,14 @@ class SettingsAdvancedController( onClick { LibraryUpdateService.start(context, target = Target.COVERS) } } - preference { - key = "pref_refresh_library_tracking" - titleRes = R.string.pref_refresh_library_tracking - summaryRes = R.string.pref_refresh_library_tracking_summary + if (trackManager.hasLoggedServices()) { + preference { + key = "pref_refresh_library_tracking" + titleRes = R.string.pref_refresh_library_tracking + summaryRes = R.string.pref_refresh_library_tracking_summary - onClick { LibraryUpdateService.start(context, target = Target.TRACKING) } + onClick { LibraryUpdateService.start(context, target = Target.TRACKING) } + } } preference { key = "pref_reset_viewer_flags" diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsReaderController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsReaderController.kt index e8af6c898f..a67f72831c 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsReaderController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/setting/SettingsReaderController.kt @@ -165,6 +165,7 @@ class SettingsReaderController : SettingsController() { TappingInvertMode.BOTH.name, ) summary = "%s" + visibleIf(preferences.navigationModePager()) { it != 5 } } intListPreference { bindTo(preferences.imageScaleType()) @@ -244,6 +245,7 @@ class SettingsReaderController : SettingsController() { TappingInvertMode.BOTH.name, ) summary = "%s" + visibleIf(preferences.navigationModeWebtoon()) { it != 5 } } intListPreference { bindTo(preferences.webtoonSidePadding()) From aef97c5563471fbc33f36e078ea6e51dd657f5ae Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 15 May 2022 09:38:26 -0400 Subject: [PATCH 31/80] Update dependency com.fredporciuncula:flow-preferences to v1.7.0 (#7132) Co-authored-by: Renovate Bot --- gradle/libs.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 9516b0f224..2f27a8cc2b 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -41,7 +41,7 @@ sqlitektx = "androidx.sqlite:sqlite-ktx:2.3.0-alpha02" sqlite-android = "com.github.requery:sqlite-android:3.36.0" preferencektx = "androidx.preference:preference-ktx:1.2.0" -flowpreferences = "com.fredporciuncula:flow-preferences:1.6.0" +flowpreferences = "com.fredporciuncula:flow-preferences:1.7.0" nucleus-core = { module = "info.android15.nucleus:nucleus", version.ref = "nucleus_version" } nucleus-supportv7 = { module = "info.android15.nucleus:nucleus-support-v7", version.ref = "nucleus_version" } From 7a0915964ab85aeabde25a7d87e535ec97478380 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 15 May 2022 09:41:00 -0400 Subject: [PATCH 32/80] Update serialization_version to v1.3.3 (#7128) Co-authored-by: Renovate Bot --- gradle/kotlinx.versions.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle/kotlinx.versions.toml b/gradle/kotlinx.versions.toml index 52397ac608..f0c90be76a 100644 --- a/gradle/kotlinx.versions.toml +++ b/gradle/kotlinx.versions.toml @@ -1,7 +1,7 @@ [versions] kotlin_version = "1.6.21" coroutines_version = "1.6.1" -serialization_version = "1.3.2" +serialization_version = "1.3.3" [libraries] reflect = { module = "org.jetbrains.kotlin:kotlin-reflect", version.ref = "kotlin_version" } From 3e2d7d76b9b0fb1156d4dfaa01f4176d801089ce Mon Sep 17 00:00:00 2001 From: Andreas Date: Sun, 15 May 2022 15:59:53 +0200 Subject: [PATCH 33/80] Convert Extension tab to use Compose (#7107) * Convert Extension tab to use Compose Co-authored-by: jobobby04 <17078382+jobobby04@users.noreply.github.com> * Review changes Co-authored-by: jobobby04 <17078382+jobobby04@users.noreply.github.com> --- app/build.gradle.kts | 1 + .../eu/kanade/core/util/RxJavaExtensions.kt | 25 ++ .../java/eu/kanade/domain/DomainModule.kt | 5 + .../interactor/GetExtensionUpdates.kt | 25 ++ .../extension/interactor/GetExtensions.kt | 48 ++ .../browse/components/BaseBrowseItem.kt | 35 ++ .../browse/components/BrowseIcons.kt | 91 ++++ .../presentation/extension/ExtensionScreen.kt | 417 ++++++++++++++++++ .../presentation/source/SourceScreen.kt | 27 -- .../source/components/BaseSourceItem.kt | 28 +- .../ui/browse/extension/ExtensionAdapter.kt | 27 -- .../browse/extension/ExtensionController.kt | 212 +++------ .../browse/extension/ExtensionGroupHolder.kt | 27 -- .../ui/browse/extension/ExtensionGroupItem.kt | 62 --- .../ui/browse/extension/ExtensionHolder.kt | 84 ---- .../ui/browse/extension/ExtensionItem.kt | 65 --- .../ui/browse/extension/ExtensionPresenter.kt | 265 ++++++----- .../browse/extension/ExtensionTrustDialog.kt | 43 -- .../ui/browse/extension/ExtensionViewUtils.kt | 32 ++ .../main/res/layout/extension_controller.xml | 32 -- app/src/main/res/layout/extension_item.xml | 98 ---- .../res/mipmap-hdpi/ic_untrusted_source.png | Bin 0 -> 2124 bytes .../res/mipmap-mdpi/ic_untrusted_source.png | Bin 0 -> 1102 bytes .../res/mipmap-xhdpi/ic_untrusted_source.png | Bin 0 -> 2599 bytes .../res/mipmap-xxhdpi/ic_untrusted_source.png | Bin 0 -> 5065 bytes .../mipmap-xxxhdpi/ic_untrusted_source.png | Bin 0 -> 7096 bytes gradle/compose.versions.toml | 3 +- 27 files changed, 899 insertions(+), 753 deletions(-) create mode 100644 app/src/main/java/eu/kanade/core/util/RxJavaExtensions.kt create mode 100644 app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensionUpdates.kt create mode 100644 app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensions.kt create mode 100644 app/src/main/java/eu/kanade/presentation/browse/components/BaseBrowseItem.kt create mode 100644 app/src/main/java/eu/kanade/presentation/browse/components/BrowseIcons.kt create mode 100644 app/src/main/java/eu/kanade/presentation/extension/ExtensionScreen.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionAdapter.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupHolder.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupItem.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionHolder.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionItem.kt delete mode 100644 app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionTrustDialog.kt delete mode 100644 app/src/main/res/layout/extension_controller.xml delete mode 100644 app/src/main/res/layout/extension_item.xml create mode 100644 app/src/main/res/mipmap-hdpi/ic_untrusted_source.png create mode 100644 app/src/main/res/mipmap-mdpi/ic_untrusted_source.png create mode 100644 app/src/main/res/mipmap-xhdpi/ic_untrusted_source.png create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_untrusted_source.png create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_untrusted_source.png diff --git a/app/build.gradle.kts b/app/build.gradle.kts index 6de1454ffb..0c0dc94f9a 100644 --- a/app/build.gradle.kts +++ b/app/build.gradle.kts @@ -148,6 +148,7 @@ dependencies { implementation(compose.animation) implementation(compose.ui.tooling) implementation(compose.accompanist.webview) + implementation(compose.accompanist.swiperefresh) implementation(androidx.paging.runtime) implementation(androidx.paging.compose) diff --git a/app/src/main/java/eu/kanade/core/util/RxJavaExtensions.kt b/app/src/main/java/eu/kanade/core/util/RxJavaExtensions.kt new file mode 100644 index 0000000000..4d1ef452d5 --- /dev/null +++ b/app/src/main/java/eu/kanade/core/util/RxJavaExtensions.kt @@ -0,0 +1,25 @@ +package eu.kanade.core.util + +import kotlinx.coroutines.channels.awaitClose +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.callbackFlow +import rx.Observable +import rx.Observer + +fun Observable.asFlow(): Flow = callbackFlow { + val observer = object : Observer { + override fun onNext(t: T) { + trySend(t) + } + + override fun onError(e: Throwable) { + close(e) + } + + override fun onCompleted() { + close() + } + } + val subscription = subscribe(observer) + awaitClose { subscription.unsubscribe() } +} diff --git a/app/src/main/java/eu/kanade/domain/DomainModule.kt b/app/src/main/java/eu/kanade/domain/DomainModule.kt index 7e9cd3de1a..293d3485c1 100644 --- a/app/src/main/java/eu/kanade/domain/DomainModule.kt +++ b/app/src/main/java/eu/kanade/domain/DomainModule.kt @@ -3,6 +3,8 @@ package eu.kanade.domain import eu.kanade.data.history.HistoryRepositoryImpl import eu.kanade.data.manga.MangaRepositoryImpl import eu.kanade.data.source.SourceRepositoryImpl +import eu.kanade.domain.extension.interactor.GetExtensionUpdates +import eu.kanade.domain.extension.interactor.GetExtensions import eu.kanade.domain.history.interactor.DeleteHistoryTable import eu.kanade.domain.history.interactor.GetHistory import eu.kanade.domain.history.interactor.GetNextChapterForManga @@ -40,6 +42,9 @@ class DomainModule : InjektModule { addFactory { RemoveHistoryById(get()) } addFactory { RemoveHistoryByMangaId(get()) } + addFactory { GetExtensions(get(), get()) } + addFactory { GetExtensionUpdates(get(), get()) } + addSingletonFactory { SourceRepositoryImpl(get(), get()) } addFactory { GetLanguagesWithSources(get(), get()) } addFactory { GetEnabledSources(get(), get()) } diff --git a/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensionUpdates.kt b/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensionUpdates.kt new file mode 100644 index 0000000000..96373f9b4b --- /dev/null +++ b/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensionUpdates.kt @@ -0,0 +1,25 @@ +package eu.kanade.domain.extension.interactor + +import eu.kanade.core.util.asFlow +import eu.kanade.tachiyomi.data.preference.PreferencesHelper +import eu.kanade.tachiyomi.extension.ExtensionManager +import eu.kanade.tachiyomi.extension.model.Extension +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.map + +class GetExtensionUpdates( + private val preferences: PreferencesHelper, + private val extensionManager: ExtensionManager, +) { + + fun subscribe(): Flow> { + val showNsfwSources = preferences.showNsfwSource().get() + + return extensionManager.getInstalledExtensionsObservable().asFlow() + .map { installed -> + installed + .filter { it.hasUpdate && (showNsfwSources || it.isNsfw.not()) } + .sortedWith(compareBy(String.CASE_INSENSITIVE_ORDER) { it.name }) + } + } +} diff --git a/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensions.kt b/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensions.kt new file mode 100644 index 0000000000..16056939d1 --- /dev/null +++ b/app/src/main/java/eu/kanade/domain/extension/interactor/GetExtensions.kt @@ -0,0 +1,48 @@ +package eu.kanade.domain.extension.interactor + +import eu.kanade.core.util.asFlow +import eu.kanade.tachiyomi.data.preference.PreferencesHelper +import eu.kanade.tachiyomi.extension.ExtensionManager +import eu.kanade.tachiyomi.extension.model.Extension +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.combine + +typealias ExtensionSegregation = Triple, List, List> + +class GetExtensions( + private val preferences: PreferencesHelper, + private val extensionManager: ExtensionManager, +) { + + fun subscribe(): Flow { + val activeLanguages = preferences.enabledLanguages().get() + val showNsfwSources = preferences.showNsfwSource().get() + + return combine( + extensionManager.getInstalledExtensionsObservable().asFlow(), + extensionManager.getUntrustedExtensionsObservable().asFlow(), + extensionManager.getAvailableExtensionsObservable().asFlow(), + ) { _installed, _untrusted, _available -> + + val installed = _installed + .filter { it.hasUpdate.not() && (showNsfwSources || it.isNsfw.not()) } + .sortedWith( + compareBy { it.isObsolete.not() } + .thenBy(String.CASE_INSENSITIVE_ORDER) { it.name }, + ) + + val untrusted = _untrusted + .sortedWith(compareBy(String.CASE_INSENSITIVE_ORDER) { it.name }) + + val available = _available + .filter { extension -> + _installed.none { it.pkgName == extension.pkgName } && + _untrusted.none { it.pkgName == extension.pkgName } && + extension.lang in activeLanguages && + (showNsfwSources || extension.isNsfw.not()) + } + + Triple(installed, untrusted, available) + } + } +} diff --git a/app/src/main/java/eu/kanade/presentation/browse/components/BaseBrowseItem.kt b/app/src/main/java/eu/kanade/presentation/browse/components/BaseBrowseItem.kt new file mode 100644 index 0000000000..2b3dd022fb --- /dev/null +++ b/app/src/main/java/eu/kanade/presentation/browse/components/BaseBrowseItem.kt @@ -0,0 +1,35 @@ +package eu.kanade.presentation.browse.components + +import androidx.compose.foundation.combinedClickable +import androidx.compose.foundation.layout.Row +import androidx.compose.foundation.layout.RowScope +import androidx.compose.foundation.layout.padding +import androidx.compose.runtime.Composable +import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier +import androidx.compose.ui.unit.dp +import eu.kanade.presentation.util.horizontalPadding + +@Composable +fun BaseBrowseItem( + modifier: Modifier = Modifier, + onClickItem: () -> Unit = {}, + onLongClickItem: () -> Unit = {}, + icon: @Composable RowScope.() -> Unit = {}, + action: @Composable RowScope.() -> Unit = {}, + content: @Composable RowScope.() -> Unit = {}, +) { + Row( + modifier = modifier + .combinedClickable( + onClick = onClickItem, + onLongClick = onLongClickItem, + ) + .padding(horizontal = horizontalPadding, vertical = 8.dp), + verticalAlignment = Alignment.CenterVertically, + ) { + icon() + content() + action() + } +} diff --git a/app/src/main/java/eu/kanade/presentation/browse/components/BrowseIcons.kt b/app/src/main/java/eu/kanade/presentation/browse/components/BrowseIcons.kt new file mode 100644 index 0000000000..1b03232578 --- /dev/null +++ b/app/src/main/java/eu/kanade/presentation/browse/components/BrowseIcons.kt @@ -0,0 +1,91 @@ +package eu.kanade.presentation.browse.components + +import androidx.compose.foundation.Image +import androidx.compose.foundation.layout.Box +import androidx.compose.foundation.layout.aspectRatio +import androidx.compose.foundation.layout.height +import androidx.compose.foundation.shape.RoundedCornerShape +import androidx.compose.runtime.Composable +import androidx.compose.runtime.getValue +import androidx.compose.ui.Modifier +import androidx.compose.ui.draw.clip +import androidx.compose.ui.graphics.Color +import androidx.compose.ui.graphics.ImageBitmap +import androidx.compose.ui.graphics.painter.ColorPainter +import androidx.compose.ui.res.imageResource +import androidx.compose.ui.res.painterResource +import androidx.compose.ui.unit.dp +import coil.compose.AsyncImage +import eu.kanade.domain.source.model.Source +import eu.kanade.presentation.util.bitmapPainterResource +import eu.kanade.tachiyomi.R +import eu.kanade.tachiyomi.extension.model.Extension +import eu.kanade.tachiyomi.ui.browse.extension.Result +import eu.kanade.tachiyomi.ui.browse.extension.getIcon + +private val defaultModifier = Modifier + .height(40.dp) + .aspectRatio(1f) + +@Composable +fun SourceIcon( + source: Source, + modifier: Modifier = Modifier, +) { + val icon = source.icon + + if (icon != null) { + Image( + bitmap = icon, + contentDescription = "", + modifier = modifier.then(defaultModifier), + ) + } else { + Image( + painter = painterResource(id = R.mipmap.ic_local_source), + contentDescription = "", + modifier = modifier.then(defaultModifier), + ) + } +} + +@Composable +fun ExtensionIcon( + extension: Extension, + modifier: Modifier = Modifier, +) { + when (extension) { + is Extension.Available -> { + AsyncImage( + model = extension.iconUrl, + contentDescription = "", + placeholder = ColorPainter(Color(0x1F888888)), + error = bitmapPainterResource(id = R.drawable.cover_error), + modifier = modifier + .clip(RoundedCornerShape(4.dp)) + .then(defaultModifier), + ) + } + is Extension.Installed -> { + val icon by extension.getIcon() + when (icon) { + Result.Error -> Image( + bitmap = ImageBitmap.imageResource(id = R.mipmap.ic_local_source), + contentDescription = "", + modifier = modifier.then(defaultModifier), + ) + Result.Loading -> Box(modifier = modifier.then(defaultModifier)) + is Result.Success -> Image( + bitmap = (icon as Result.Success).value, + contentDescription = "", + modifier = modifier.then(defaultModifier), + ) + } + } + is Extension.Untrusted -> Image( + bitmap = ImageBitmap.imageResource(id = R.mipmap.ic_untrusted_source), + contentDescription = "", + modifier = modifier.then(defaultModifier), + ) + } +} diff --git a/app/src/main/java/eu/kanade/presentation/extension/ExtensionScreen.kt b/app/src/main/java/eu/kanade/presentation/extension/ExtensionScreen.kt new file mode 100644 index 0000000000..7be37a398e --- /dev/null +++ b/app/src/main/java/eu/kanade/presentation/extension/ExtensionScreen.kt @@ -0,0 +1,417 @@ +package eu.kanade.presentation.extension + +import androidx.annotation.StringRes +import androidx.compose.foundation.combinedClickable +import androidx.compose.foundation.layout.Arrangement +import androidx.compose.foundation.layout.Column +import androidx.compose.foundation.layout.Row +import androidx.compose.foundation.layout.RowScope +import androidx.compose.foundation.layout.WindowInsets +import androidx.compose.foundation.layout.asPaddingValues +import androidx.compose.foundation.layout.navigationBars +import androidx.compose.foundation.layout.padding +import androidx.compose.foundation.lazy.LazyColumn +import androidx.compose.foundation.lazy.items +import androidx.compose.material.icons.Icons +import androidx.compose.material.icons.filled.Close +import androidx.compose.material3.AlertDialog +import androidx.compose.material3.Button +import androidx.compose.material3.Icon +import androidx.compose.material3.IconButton +import androidx.compose.material3.LocalTextStyle +import androidx.compose.material3.MaterialTheme +import androidx.compose.material3.Text +import androidx.compose.material3.TextButton +import androidx.compose.runtime.Composable +import androidx.compose.runtime.LaunchedEffect +import androidx.compose.runtime.collectAsState +import androidx.compose.runtime.getValue +import androidx.compose.runtime.mutableStateOf +import androidx.compose.runtime.remember +import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier +import androidx.compose.ui.input.nestedscroll.NestedScrollConnection +import androidx.compose.ui.input.nestedscroll.nestedScroll +import androidx.compose.ui.platform.LocalContext +import androidx.compose.ui.res.stringResource +import androidx.compose.ui.text.style.TextOverflow +import androidx.compose.ui.unit.dp +import com.google.accompanist.swiperefresh.SwipeRefresh +import com.google.accompanist.swiperefresh.rememberSwipeRefreshState +import eu.kanade.presentation.browse.components.BaseBrowseItem +import eu.kanade.presentation.browse.components.ExtensionIcon +import eu.kanade.presentation.theme.header +import eu.kanade.presentation.util.horizontalPadding +import eu.kanade.tachiyomi.R +import eu.kanade.tachiyomi.extension.model.Extension +import eu.kanade.tachiyomi.extension.model.InstallStep +import eu.kanade.tachiyomi.ui.browse.extension.ExtensionPresenter +import eu.kanade.tachiyomi.ui.browse.extension.ExtensionState +import eu.kanade.tachiyomi.ui.browse.extension.ExtensionUiModel +import eu.kanade.tachiyomi.util.system.LocaleHelper + +@Composable +fun ExtensionScreen( + nestedScrollInterop: NestedScrollConnection, + presenter: ExtensionPresenter, + onLongClickItem: (Extension) -> Unit, + onClickItemCancel: (Extension) -> Unit, + onInstallExtension: (Extension.Available) -> Unit, + onUninstallExtension: (Extension) -> Unit, + onUpdateExtension: (Extension.Installed) -> Unit, + onTrustExtension: (Extension.Untrusted) -> Unit, + onOpenExtension: (Extension.Installed) -> Unit, + onClickUpdateAll: () -> Unit, + onRefresh: () -> Unit, + onLaunched: () -> Unit, +) { + val state by presenter.state.collectAsState() + val isRefreshing = presenter.isRefreshing + + SwipeRefresh( + modifier = Modifier.nestedScroll(nestedScrollInterop), + state = rememberSwipeRefreshState(isRefreshing), + onRefresh = onRefresh, + ) { + when (state) { + is ExtensionState.Initialized -> { + ExtensionContent( + nestedScrollInterop = nestedScrollInterop, + items = (state as ExtensionState.Initialized).list, + onLongClickItem = onLongClickItem, + onClickItemCancel = onClickItemCancel, + onInstallExtension = onInstallExtension, + onUninstallExtension = onUninstallExtension, + onUpdateExtension = onUpdateExtension, + onTrustExtension = onTrustExtension, + onOpenExtension = onOpenExtension, + onClickUpdateAll = onClickUpdateAll, + onLaunched = onLaunched, + ) + } + ExtensionState.Uninitialized -> {} + } + } +} + +@Composable +fun ExtensionContent( + nestedScrollInterop: NestedScrollConnection, + items: List, + onLongClickItem: (Extension) -> Unit, + onClickItemCancel: (Extension) -> Unit, + onInstallExtension: (Extension.Available) -> Unit, + onUninstallExtension: (Extension) -> Unit, + onUpdateExtension: (Extension.Installed) -> Unit, + onTrustExtension: (Extension.Untrusted) -> Unit, + onOpenExtension: (Extension.Installed) -> Unit, + onClickUpdateAll: () -> Unit, + onLaunched: () -> Unit, +) { + val (trustState, setTrustState) = remember { mutableStateOf(null) } + LazyColumn( + contentPadding = WindowInsets.navigationBars.asPaddingValues(), + ) { + items( + items = items, + key = { + when (it) { + is ExtensionUiModel.Header.Resource -> it.textRes + is ExtensionUiModel.Header.Text -> it.text + is ExtensionUiModel.Item -> it.key() + } + }, + contentType = { + when (it) { + is ExtensionUiModel.Item -> "item" + else -> "header" + } + }, + ) { item -> + when (item) { + is ExtensionUiModel.Header.Resource -> { + val action: @Composable RowScope.() -> Unit = + if (item.textRes == R.string.ext_updates_pending) { + { + Button(onClick = { onClickUpdateAll() }) { + Text( + text = stringResource(id = R.string.ext_update_all), + style = LocalTextStyle.current.copy( + color = MaterialTheme.colorScheme.onPrimary, + ), + ) + } + } + } else { + {} + } + ExtensionHeader( + textRes = item.textRes, + modifier = Modifier.animateItemPlacement(), + action = action, + ) + } + is ExtensionUiModel.Header.Text -> { + ExtensionHeader( + text = item.text, + modifier = Modifier.animateItemPlacement(), + ) + } + is ExtensionUiModel.Item -> { + ExtensionItem( + modifier = Modifier.animateItemPlacement(), + item = item, + onClickItem = { + when (it) { + is Extension.Available -> onInstallExtension(it) + is Extension.Installed -> { + if (it.hasUpdate) { + onUpdateExtension(it) + } else { + onOpenExtension(it) + } + } + is Extension.Untrusted -> setTrustState(it) + } + }, + onLongClickItem = onLongClickItem, + onClickItemCancel = onClickItemCancel, + onClickItemAction = { + when (it) { + is Extension.Available -> onInstallExtension(it) + is Extension.Installed -> { + if (it.hasUpdate) { + onUpdateExtension(it) + } else { + onOpenExtension(it) + } + } + is Extension.Untrusted -> setTrustState(it) + } + }, + ) + LaunchedEffect(Unit) { + onLaunched() + } + } + } + } + } + if (trustState != null) { + ExtensionTrustDialog( + onClickConfirm = { + onTrustExtension(trustState) + setTrustState(null) + }, + onClickDismiss = { + onUninstallExtension(trustState) + setTrustState(null) + }, + onDismissRequest = { + setTrustState(null) + }, + ) + } +} + +@Composable +fun ExtensionItem( + modifier: Modifier = Modifier, + item: ExtensionUiModel.Item, + onClickItem: (Extension) -> Unit, + onLongClickItem: (Extension) -> Unit, + onClickItemCancel: (Extension) -> Unit, + onClickItemAction: (Extension) -> Unit, +) { + val (extension, installStep) = item + BaseBrowseItem( + modifier = modifier + .combinedClickable( + onClick = { onClickItem(extension) }, + onLongClick = { onLongClickItem(extension) }, + ), + onClickItem = { onClickItem(extension) }, + onLongClickItem = { onLongClickItem(extension) }, + icon = { + ExtensionIcon(extension = extension) + }, + action = { + ExtensionItemActions( + extension = extension, + installStep = installStep, + onClickItemCancel = onClickItemCancel, + onClickItemAction = onClickItemAction, + ) + }, + ) { + ExtensionItemContent( + extension = extension, + modifier = Modifier.weight(1f), + ) + } +} + +@Composable +fun ExtensionItemContent( + extension: Extension, + modifier: Modifier = Modifier, +) { + val context = LocalContext.current + val warning = remember(extension) { + when { + extension is Extension.Untrusted -> R.string.ext_untrusted + extension is Extension.Installed && extension.isUnofficial -> R.string.ext_unofficial + extension is Extension.Installed && extension.isObsolete -> R.string.ext_obsolete + extension.isNsfw -> R.string.ext_nsfw_short + else -> null + } + } + + Column( + modifier = modifier.padding(start = horizontalPadding), + ) { + Text( + text = extension.name, + maxLines = 1, + overflow = TextOverflow.Ellipsis, + style = MaterialTheme.typography.bodyMedium, + ) + Row( + horizontalArrangement = Arrangement.spacedBy(4.dp), + ) { + if (extension.lang.isNullOrEmpty().not()) { + Text( + text = LocaleHelper.getSourceDisplayName(extension.lang, context), + style = MaterialTheme.typography.bodySmall, + ) + } + + if (extension.versionName.isNotEmpty()) { + Text( + text = extension.versionName, + style = MaterialTheme.typography.bodySmall, + ) + } + + if (warning != null) { + Text( + text = stringResource(id = warning).uppercase(), + style = MaterialTheme.typography.bodySmall.copy( + color = MaterialTheme.colorScheme.error, + ), + ) + } + } + } +} + +@Composable +fun ExtensionItemActions( + extension: Extension, + installStep: InstallStep, + modifier: Modifier = Modifier, + onClickItemCancel: (Extension) -> Unit = {}, + onClickItemAction: (Extension) -> Unit = {}, +) { + val isIdle = remember(installStep) { + installStep == InstallStep.Idle || installStep == InstallStep.Error + } + Row(modifier = modifier) { + TextButton( + onClick = { onClickItemAction(extension) }, + enabled = isIdle, + ) { + Text( + text = when (installStep) { + InstallStep.Pending -> stringResource(R.string.ext_pending) + InstallStep.Downloading -> stringResource(R.string.ext_downloading) + InstallStep.Installing -> stringResource(R.string.ext_installing) + InstallStep.Installed -> stringResource(R.string.ext_installed) + InstallStep.Error -> stringResource(R.string.action_retry) + InstallStep.Idle -> { + when (extension) { + is Extension.Installed -> { + if (extension.hasUpdate) { + stringResource(R.string.ext_update) + } else { + stringResource(R.string.action_settings) + } + } + is Extension.Untrusted -> stringResource(R.string.ext_trust) + is Extension.Available -> stringResource(R.string.ext_install) + } + } + }, + style = LocalTextStyle.current.copy( + color = if (isIdle) MaterialTheme.colorScheme.primary else MaterialTheme.colorScheme.surfaceTint, + ), + ) + } + if (isIdle.not()) { + IconButton(onClick = { onClickItemCancel(extension) }) { + Icon(Icons.Default.Close, "") + } + } + } +} + +@Composable +fun ExtensionHeader( + @StringRes textRes: Int, + modifier: Modifier = Modifier, + action: @Composable RowScope.() -> Unit = {}, +) { + ExtensionHeader( + text = stringResource(id = textRes), + modifier = modifier, + action = action, + ) +} + +@Composable +fun ExtensionHeader( + text: String, + modifier: Modifier = Modifier, + action: @Composable RowScope.() -> Unit = {}, +) { + Row( + modifier = modifier.padding(horizontal = horizontalPadding), + verticalAlignment = Alignment.CenterVertically, + ) { + Text( + text = text, + modifier = Modifier + .padding(vertical = 8.dp) + .weight(1f), + style = MaterialTheme.typography.header, + ) + action() + } +} + +@Composable +fun ExtensionTrustDialog( + onClickConfirm: () -> Unit, + onClickDismiss: () -> Unit, + onDismissRequest: () -> Unit, +) { + AlertDialog( + title = { + Text(text = stringResource(id = R.string.untrusted_extension)) + }, + text = { + Text(text = stringResource(id = R.string.untrusted_extension_message)) + }, + confirmButton = { + TextButton(onClick = onClickConfirm) { + Text(text = stringResource(id = R.string.ext_trust)) + } + }, + dismissButton = { + TextButton(onClick = onClickDismiss) { + Text(text = stringResource(id = R.string.ext_uninstall)) + } + }, + onDismissRequest = onDismissRequest, + ) +} diff --git a/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt b/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt index 0e34c9419b..c6da3123a1 100644 --- a/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt +++ b/app/src/main/java/eu/kanade/presentation/source/SourceScreen.kt @@ -1,13 +1,10 @@ package eu.kanade.presentation.source -import androidx.compose.foundation.Image import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.WindowInsets import androidx.compose.foundation.layout.asPaddingValues -import androidx.compose.foundation.layout.aspectRatio import androidx.compose.foundation.layout.fillMaxWidth -import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.navigationBars import androidx.compose.foundation.layout.padding import androidx.compose.foundation.lazy.LazyColumn @@ -31,7 +28,6 @@ import androidx.compose.ui.Modifier import androidx.compose.ui.input.nestedscroll.NestedScrollConnection import androidx.compose.ui.input.nestedscroll.nestedScroll import androidx.compose.ui.platform.LocalContext -import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.unit.dp import eu.kanade.domain.source.model.Pin @@ -191,29 +187,6 @@ fun SourceItem( ) } -@Composable -fun SourceIcon( - source: Source, -) { - val icon = source.icon - val modifier = Modifier - .height(40.dp) - .aspectRatio(1f) - if (icon != null) { - Image( - bitmap = icon, - contentDescription = "", - modifier = modifier, - ) - } else { - Image( - painter = painterResource(id = R.mipmap.ic_local_source), - contentDescription = "", - modifier = modifier, - ) - } -} - @Composable fun SourcePinButton( isPinned: Boolean, diff --git a/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt b/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt index 4f35d7e4df..d5d1b6fc1d 100644 --- a/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt +++ b/app/src/main/java/eu/kanade/presentation/source/components/BaseSourceItem.kt @@ -1,19 +1,16 @@ package eu.kanade.presentation.source.components -import androidx.compose.foundation.combinedClickable import androidx.compose.foundation.layout.Column -import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.RowScope import androidx.compose.foundation.layout.padding import androidx.compose.material3.MaterialTheme import androidx.compose.material3.Text import androidx.compose.runtime.Composable -import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.text.style.TextOverflow -import androidx.compose.ui.unit.dp import eu.kanade.domain.source.model.Source -import eu.kanade.presentation.source.SourceIcon +import eu.kanade.presentation.browse.components.BaseBrowseItem +import eu.kanade.presentation.browse.components.SourceIcon import eu.kanade.presentation.util.horizontalPadding import eu.kanade.tachiyomi.util.system.LocaleHelper @@ -28,19 +25,14 @@ fun BaseSourceItem( action: @Composable RowScope.(Source) -> Unit = {}, content: @Composable RowScope.(Source, Boolean) -> Unit = defaultContent, ) { - Row( - modifier = modifier - .combinedClickable( - onClick = onClickItem, - onLongClick = onLongClickItem, - ) - .padding(horizontal = horizontalPadding, vertical = 8.dp), - verticalAlignment = Alignment.CenterVertically, - ) { - icon.invoke(this, source) - content.invoke(this, source, showLanguageInContent) - action.invoke(this, source) - } + BaseBrowseItem( + modifier = modifier, + onClickItem = onClickItem, + onLongClickItem = onLongClickItem, + icon = { icon.invoke(this, source) }, + action = { action.invoke(this, source) }, + content = { content.invoke(this, source, showLanguageInContent) }, + ) } private val defaultIcon: @Composable RowScope.(Source) -> Unit = { source -> diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionAdapter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionAdapter.kt deleted file mode 100644 index 89f621da27..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionAdapter.kt +++ /dev/null @@ -1,27 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import eu.davidea.flexibleadapter.FlexibleAdapter -import eu.davidea.flexibleadapter.items.IFlexible - -/** - * Adapter that holds the catalogue cards. - * - * @param controller instance of [ExtensionController]. - */ -class ExtensionAdapter(controller: ExtensionController) : - FlexibleAdapter>(null, controller, true) { - - init { - setDisplayHeadersAtStartUp(true) - } - - /** - * Listener for browse item clicks. - */ - val buttonClickListener: OnButtonClickListener = controller - - interface OnButtonClickListener { - fun onButtonClick(position: Int) - fun onCancelButtonClick(position: Int) - } -} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionController.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionController.kt index 7b1aa7b3d1..8112692b70 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionController.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionController.kt @@ -1,48 +1,30 @@ package eu.kanade.tachiyomi.ui.browse.extension -import android.view.LayoutInflater import android.view.Menu import android.view.MenuInflater import android.view.MenuItem -import android.view.View import androidx.appcompat.widget.SearchView -import androidx.recyclerview.widget.LinearLayoutManager +import androidx.compose.runtime.Composable +import androidx.compose.ui.input.nestedscroll.NestedScrollConnection import com.bluelinelabs.conductor.ControllerChangeHandler import com.bluelinelabs.conductor.ControllerChangeType -import dev.chrisbanes.insetter.applyInsetter -import eu.davidea.flexibleadapter.FlexibleAdapter -import eu.davidea.flexibleadapter.items.IFlexible +import eu.kanade.presentation.extension.ExtensionScreen import eu.kanade.tachiyomi.R -import eu.kanade.tachiyomi.databinding.ExtensionControllerBinding import eu.kanade.tachiyomi.extension.model.Extension -import eu.kanade.tachiyomi.source.online.HttpSource -import eu.kanade.tachiyomi.ui.base.controller.NucleusController +import eu.kanade.tachiyomi.ui.base.controller.ComposeController import eu.kanade.tachiyomi.ui.base.controller.pushController import eu.kanade.tachiyomi.ui.browse.BrowseController import eu.kanade.tachiyomi.ui.browse.extension.details.ExtensionDetailsController -import kotlinx.coroutines.flow.drop import kotlinx.coroutines.flow.filter import kotlinx.coroutines.flow.launchIn import kotlinx.coroutines.flow.onEach import reactivecircus.flowbinding.appcompat.queryTextChanges -import reactivecircus.flowbinding.swiperefreshlayout.refreshes /** * Controller to manage the catalogues available in the app. */ open class ExtensionController : - NucleusController(), - ExtensionAdapter.OnButtonClickListener, - FlexibleAdapter.OnItemClickListener, - FlexibleAdapter.OnItemLongClickListener, - ExtensionTrustDialog.Listener { - - /** - * Adapter containing the list of manga from the catalogue. - */ - private var adapter: FlexibleAdapter>? = null - - private var extensions: List = emptyList() + ComposeController() { private var query = "" @@ -50,42 +32,54 @@ open class ExtensionController : setHasOptionsMenu(true) } - override fun getTitle(): String? { - return applicationContext?.getString(R.string.label_extensions) - } - - override fun createPresenter(): ExtensionPresenter { - return ExtensionPresenter() - } - - override fun createBinding(inflater: LayoutInflater) = - ExtensionControllerBinding.inflate(inflater) - - override fun onViewCreated(view: View) { - super.onViewCreated(view) - - binding.recycler.applyInsetter { - type(navigationBars = true) { - padding() - } - } - - binding.swipeRefresh.isRefreshing = true - binding.swipeRefresh.refreshes() - .onEach { presenter.findAvailableExtensions() } - .launchIn(viewScope) + override fun getTitle(): String? = + applicationContext?.getString(R.string.label_extensions) - // Initialize adapter, scroll listener and recycler views - adapter = ExtensionAdapter(this) - // Create recycler and set adapter. - binding.recycler.layoutManager = LinearLayoutManager(view.context) - binding.recycler.adapter = adapter - adapter?.fastScroller = binding.fastScroller - } + override fun createPresenter(): ExtensionPresenter = + ExtensionPresenter() - override fun onDestroyView(view: View) { - adapter = null - super.onDestroyView(view) + @Composable + override fun ComposeContent(nestedScrollInterop: NestedScrollConnection) { + ExtensionScreen( + nestedScrollInterop = nestedScrollInterop, + presenter = presenter, + onLongClickItem = { extension -> + when (extension) { + is Extension.Available -> presenter.installExtension(extension) + else -> presenter.uninstallExtension(extension.pkgName) + } + }, + onClickItemCancel = { extension -> + presenter.cancelInstallUpdateExtension(extension) + }, + onClickUpdateAll = { + presenter.updateAllExtensions() + }, + onLaunched = { + val ctrl = parentController as BrowseController + ctrl.setExtensionUpdateBadge() + ctrl.extensionListUpdateRelay.call(true) + }, + onInstallExtension = { + presenter.installExtension(it) + }, + onOpenExtension = { + val controller = ExtensionDetailsController(it.pkgName) + parentController!!.router.pushController(controller) + }, + onTrustExtension = { + presenter.trustSignature(it.signatureHash) + }, + onUninstallExtension = { + presenter.uninstallExtension(it.pkgName) + }, + onUpdateExtension = { + presenter.updateExtension(it) + }, + onRefresh = { + presenter.findAvailableExtensions() + }, + ) } override fun onOptionsItemSelected(item: MenuItem): Boolean { @@ -105,26 +99,6 @@ open class ExtensionController : } } - override fun onButtonClick(position: Int) { - val extension = (adapter?.getItem(position) as? ExtensionItem)?.extension ?: return - when (extension) { - is Extension.Available -> presenter.installExtension(extension) - is Extension.Untrusted -> openTrustDialog(extension) - is Extension.Installed -> { - if (!extension.hasUpdate) { - openDetails(extension) - } else { - presenter.updateExtension(extension) - } - } - } - } - - override fun onCancelButtonClick(position: Int) { - val extension = (adapter?.getItem(position) as? ExtensionItem)?.extension ?: return - presenter.cancelInstallUpdateExtension(extension) - } - override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) { inflater.inflate(R.menu.browse_extensions, menu) @@ -142,93 +116,11 @@ open class ExtensionController : } searchView.queryTextChanges() - .drop(1) // Drop first event after subscribed .filter { router.backstack.lastOrNull()?.controller == this } .onEach { query = it.toString() - updateExtensionsList() + presenter.search(query) } .launchIn(viewScope) } - - override fun onItemClick(view: View, position: Int): Boolean { - val extension = (adapter?.getItem(position) as? ExtensionItem)?.extension ?: return false - when (extension) { - is Extension.Available -> presenter.installExtension(extension) - is Extension.Untrusted -> openTrustDialog(extension) - is Extension.Installed -> openDetails(extension) - } - return false - } - - override fun onItemLongClick(position: Int) { - val extension = (adapter?.getItem(position) as? ExtensionItem)?.extension ?: return - if (extension is Extension.Installed || extension is Extension.Untrusted) { - uninstallExtension(extension.pkgName) - } - } - - private fun openDetails(extension: Extension.Installed) { - val controller = ExtensionDetailsController(extension.pkgName) - parentController!!.router.pushController(controller) - } - - private fun openTrustDialog(extension: Extension.Untrusted) { - ExtensionTrustDialog(this, extension.signatureHash, extension.pkgName) - .showDialog(router) - } - - fun setExtensions(extensions: List) { - binding.swipeRefresh.isRefreshing = false - this.extensions = extensions - updateExtensionsList() - - // Update badge on parent controller tab - val ctrl = parentController as BrowseController - ctrl.setExtensionUpdateBadge() - ctrl.extensionListUpdateRelay.call(true) - } - - private fun updateExtensionsList() { - if (query.isNotBlank()) { - val queries = query.split(",") - adapter?.updateDataSet( - extensions.filter { - queries.any { query -> - when (it.extension) { - is Extension.Available -> { - it.extension.sources.any { - it.name.contains(query, ignoreCase = true) || - it.baseUrl.contains(query, ignoreCase = true) || - it.id == query.toLongOrNull() - } || it.extension.name.contains(query, ignoreCase = true) - } - is Extension.Installed -> { - it.extension.sources.any { - it.name.contains(query, ignoreCase = true) || - it.id == query.toLongOrNull() || - if (it is HttpSource) { it.baseUrl.contains(query, ignoreCase = true) } else false - } || it.extension.name.contains(query, ignoreCase = true) - } - is Extension.Untrusted -> it.extension.name.contains(query, ignoreCase = true) - } - } - }, - ) - } else { - adapter?.updateDataSet(extensions) - } - } - - fun downloadUpdate(item: ExtensionItem) { - adapter?.updateItem(item, item.installStep) - } - - override fun trustSignature(signatureHash: String) { - presenter.trustSignature(signatureHash) - } - - override fun uninstallExtension(pkgName: String) { - presenter.uninstallExtension(pkgName) - } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupHolder.kt deleted file mode 100644 index 099ad8c88d..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupHolder.kt +++ /dev/null @@ -1,27 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import android.annotation.SuppressLint -import android.view.View -import androidx.core.view.isVisible -import eu.davidea.flexibleadapter.FlexibleAdapter -import eu.davidea.viewholders.FlexibleViewHolder -import eu.kanade.tachiyomi.databinding.SectionHeaderItemBinding - -class ExtensionGroupHolder(view: View, adapter: FlexibleAdapter<*>) : - FlexibleViewHolder(view, adapter) { - - private val binding = SectionHeaderItemBinding.bind(view) - - @SuppressLint("SetTextI18n") - fun bind(item: ExtensionGroupItem) { - var text = item.name - if (item.showSize) { - text += " (${item.size})" - } - binding.title.text = text - - binding.actionButton.isVisible = item.actionLabel != null && item.actionOnClick != null - binding.actionButton.text = item.actionLabel - binding.actionButton.setOnClickListener(if (item.actionLabel != null) item.actionOnClick else null) - } -} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupItem.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupItem.kt deleted file mode 100644 index 53adf7588d..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionGroupItem.kt +++ /dev/null @@ -1,62 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import android.view.View -import androidx.recyclerview.widget.RecyclerView -import eu.davidea.flexibleadapter.FlexibleAdapter -import eu.davidea.flexibleadapter.items.AbstractHeaderItem -import eu.davidea.flexibleadapter.items.IFlexible -import eu.kanade.tachiyomi.R - -/** - * Item that contains the group header. - * - * @param name The header name. - * @param size The number of items in the group. - */ -data class ExtensionGroupItem( - val name: String, - val size: Int, - val showSize: Boolean = false, -) : AbstractHeaderItem() { - - var actionLabel: String? = null - var actionOnClick: (View.OnClickListener)? = null - - /** - * Returns the layout resource of this item. - */ - override fun getLayoutRes(): Int { - return R.layout.section_header_item - } - - /** - * Creates a new view holder for this item. - */ - override fun createViewHolder(view: View, adapter: FlexibleAdapter>): ExtensionGroupHolder { - return ExtensionGroupHolder(view, adapter) - } - - /** - * Binds this item to the given view holder. - */ - override fun bindViewHolder( - adapter: FlexibleAdapter>, - holder: ExtensionGroupHolder, - position: Int, - payloads: List?, - ) { - holder.bind(this) - } - - override fun equals(other: Any?): Boolean { - if (this === other) return true - if (other is ExtensionGroupItem) { - return name == other.name - } - return false - } - - override fun hashCode(): Int { - return name.hashCode() - } -} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionHolder.kt deleted file mode 100644 index 28041c5564..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionHolder.kt +++ /dev/null @@ -1,84 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import android.view.View -import androidx.core.view.isVisible -import coil.dispose -import coil.load -import eu.davidea.viewholders.FlexibleViewHolder -import eu.kanade.tachiyomi.R -import eu.kanade.tachiyomi.databinding.ExtensionItemBinding -import eu.kanade.tachiyomi.extension.model.Extension -import eu.kanade.tachiyomi.extension.model.InstallStep -import eu.kanade.tachiyomi.util.system.LocaleHelper - -class ExtensionHolder(view: View, val adapter: ExtensionAdapter) : - FlexibleViewHolder(view, adapter) { - - private val binding = ExtensionItemBinding.bind(view) - - init { - binding.extButton.setOnClickListener { - adapter.buttonClickListener.onButtonClick(bindingAdapterPosition) - } - binding.cancelButton.setOnClickListener { - adapter.buttonClickListener.onCancelButtonClick(bindingAdapterPosition) - } - } - - fun bind(item: ExtensionItem) { - val extension = item.extension - - binding.name.text = extension.name - binding.version.text = extension.versionName - binding.lang.text = LocaleHelper.getSourceDisplayName(extension.lang, itemView.context) - binding.warning.text = when { - extension is Extension.Untrusted -> itemView.context.getString(R.string.ext_untrusted) - extension is Extension.Installed && extension.isUnofficial -> itemView.context.getString(R.string.ext_unofficial) - extension is Extension.Installed && extension.isObsolete -> itemView.context.getString(R.string.ext_obsolete) - extension.isNsfw -> itemView.context.getString(R.string.ext_nsfw_short) - else -> "" - }.uppercase() - - binding.icon.dispose() - if (extension is Extension.Available) { - binding.icon.load(extension.iconUrl) - } else if (extension is Extension.Installed) { - binding.icon.load(extension.icon) - } - bindButtons(item) - } - - @Suppress("ResourceType") - fun bindButtons(item: ExtensionItem) = with(binding.extButton) { - val extension = item.extension - - val installStep = item.installStep - setText( - when (installStep) { - InstallStep.Pending -> R.string.ext_pending - InstallStep.Downloading -> R.string.ext_downloading - InstallStep.Installing -> R.string.ext_installing - InstallStep.Installed -> R.string.ext_installed - InstallStep.Error -> R.string.action_retry - InstallStep.Idle -> { - when (extension) { - is Extension.Installed -> { - if (extension.hasUpdate) { - R.string.ext_update - } else { - R.string.action_settings - } - } - is Extension.Untrusted -> R.string.ext_trust - is Extension.Available -> R.string.ext_install - } - } - }, - ) - - val isIdle = installStep == InstallStep.Idle || installStep == InstallStep.Error - binding.cancelButton.isVisible = !isIdle - isEnabled = isIdle - isClickable = isIdle - } -} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionItem.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionItem.kt deleted file mode 100644 index 5e895f6b5a..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionItem.kt +++ /dev/null @@ -1,65 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import android.view.View -import androidx.recyclerview.widget.RecyclerView -import eu.davidea.flexibleadapter.FlexibleAdapter -import eu.davidea.flexibleadapter.items.AbstractSectionableItem -import eu.davidea.flexibleadapter.items.IFlexible -import eu.kanade.tachiyomi.R -import eu.kanade.tachiyomi.extension.model.Extension -import eu.kanade.tachiyomi.extension.model.InstallStep -import eu.kanade.tachiyomi.source.CatalogueSource - -/** - * Item that contains source information. - * - * @param source Instance of [CatalogueSource] containing source information. - * @param header The header for this item. - */ -data class ExtensionItem( - val extension: Extension, - val header: ExtensionGroupItem? = null, - val installStep: InstallStep = InstallStep.Idle, -) : - AbstractSectionableItem(header) { - - /** - * Returns the layout resource of this item. - */ - override fun getLayoutRes(): Int { - return R.layout.extension_item - } - - /** - * Creates a new view holder for this item. - */ - override fun createViewHolder(view: View, adapter: FlexibleAdapter>): ExtensionHolder { - return ExtensionHolder(view, adapter as ExtensionAdapter) - } - - /** - * Binds this item to the given view holder. - */ - override fun bindViewHolder( - adapter: FlexibleAdapter>, - holder: ExtensionHolder, - position: Int, - payloads: List?, - ) { - if (payloads == null || payloads.isEmpty()) { - holder.bind(this) - } else { - holder.bindButtons(this) - } - } - - override fun equals(other: Any?): Boolean { - if (this === other) return true - if (javaClass != other?.javaClass) return false - return extension.pkgName == (other as ExtensionItem).extension.pkgName - } - - override fun hashCode(): Int { - return extension.pkgName.hashCode() - } -} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionPresenter.kt index c4fd1f4bb1..76b38aa06a 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionPresenter.kt @@ -2,144 +2,151 @@ package eu.kanade.tachiyomi.ui.browse.extension import android.app.Application import android.os.Bundle -import android.view.View +import androidx.annotation.StringRes +import androidx.compose.runtime.getValue +import androidx.compose.runtime.mutableStateOf +import androidx.compose.runtime.setValue +import eu.kanade.domain.extension.interactor.GetExtensionUpdates +import eu.kanade.domain.extension.interactor.GetExtensions import eu.kanade.tachiyomi.R -import eu.kanade.tachiyomi.data.preference.PreferenceValues -import eu.kanade.tachiyomi.data.preference.PreferencesHelper import eu.kanade.tachiyomi.extension.ExtensionManager import eu.kanade.tachiyomi.extension.model.Extension import eu.kanade.tachiyomi.extension.model.InstallStep +import eu.kanade.tachiyomi.source.online.HttpSource import eu.kanade.tachiyomi.ui.base.presenter.BasePresenter +import eu.kanade.tachiyomi.util.lang.launchIO import eu.kanade.tachiyomi.util.system.LocaleHelper +import kotlinx.coroutines.flow.MutableStateFlow +import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asStateFlow +import kotlinx.coroutines.flow.collectLatest +import kotlinx.coroutines.flow.combine +import kotlinx.coroutines.flow.update import rx.Observable -import rx.Subscription -import rx.android.schedulers.AndroidSchedulers import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.api.get -import java.util.concurrent.TimeUnit - -private typealias ExtensionTuple = - Triple, List, List> /** * Presenter of [ExtensionController]. */ open class ExtensionPresenter( private val extensionManager: ExtensionManager = Injekt.get(), - private val preferences: PreferencesHelper = Injekt.get(), + private val getExtensionUpdates: GetExtensionUpdates = Injekt.get(), + private val getExtensions: GetExtensions = Injekt.get(), ) : BasePresenter() { - private var extensions = emptyList() + private val _query: MutableStateFlow = MutableStateFlow("") + + private var _currentDownloads = MutableStateFlow>(hashMapOf()) + + private val _state: MutableStateFlow = MutableStateFlow(ExtensionState.Uninitialized) + val state: StateFlow = _state.asStateFlow() - private var currentDownloads = hashMapOf() + var isRefreshing: Boolean by mutableStateOf(true) override fun onCreate(savedState: Bundle?) { super.onCreate(savedState) extensionManager.findAvailableExtensions() - bindToExtensionsObservable() - } - - private fun bindToExtensionsObservable(): Subscription { - val installedObservable = extensionManager.getInstalledExtensionsObservable() - val untrustedObservable = extensionManager.getUntrustedExtensionsObservable() - val availableObservable = extensionManager.getAvailableExtensionsObservable() - .startWith(emptyList()) - - return Observable.combineLatest(installedObservable, untrustedObservable, availableObservable) { installed, untrusted, available -> Triple(installed, untrusted, available) } - .debounce(500, TimeUnit.MILLISECONDS) - .map(::toItems) - .observeOn(AndroidSchedulers.mainThread()) - .subscribeLatestCache({ view, _ -> view.setExtensions(extensions) }) - } - @Synchronized - private fun toItems(tuple: ExtensionTuple): List { val context = Injekt.get() - val activeLangs = preferences.enabledLanguages().get() - val showNsfwSources = preferences.showNsfwSource().get() - - val (installed, untrusted, available) = tuple - - val items = mutableListOf() + val extensionMapper: (Map) -> ((Extension) -> ExtensionUiModel) = { map -> + { + ExtensionUiModel.Item(it, map[it.pkgName] ?: InstallStep.Idle) + } + } + val queryFilter: (String) -> ((Extension) -> Boolean) = { query -> + filter@{ extension -> + if (query.isEmpty()) return@filter true + query.split(",").any { _input -> + val input = _input.trim() + if (input.isEmpty()) return@any false + when (extension) { + is Extension.Available -> { + extension.sources.any { + it.name.contains(input, ignoreCase = true) || + it.baseUrl.contains(input, ignoreCase = true) || + it.id == input.toLongOrNull() + } || extension.name.contains(input, ignoreCase = true) + } + is Extension.Installed -> { + extension.sources.any { + it.name.contains(input, ignoreCase = true) || + it.id == input.toLongOrNull() || + if (it is HttpSource) { it.baseUrl.contains(input, ignoreCase = true) } else false + } || extension.name.contains(input, ignoreCase = true) + } + is Extension.Untrusted -> extension.name.contains(input, ignoreCase = true) + } + } + } + } - val updatesSorted = installed.filter { it.hasUpdate && (showNsfwSources || !it.isNsfw) } - .sortedWith(compareBy(String.CASE_INSENSITIVE_ORDER) { it.name }) + launchIO { + combine( + _query, + getExtensions.subscribe(), + getExtensionUpdates.subscribe(), + _currentDownloads, + ) { query, (installed, untrusted, available), updates, downloads -> + isRefreshing = false + + val languagesWithExtensions = available + .filter(queryFilter(query)) + .groupBy { LocaleHelper.getSourceDisplayName(it.lang, context) } + .toSortedMap() + .flatMap { (key, value) -> + listOf( + ExtensionUiModel.Header.Text(key), + *value.map(extensionMapper(downloads)).toTypedArray(), + ) + } - val installedSorted = installed.filter { !it.hasUpdate && (showNsfwSources || !it.isNsfw) } - .sortedWith( - compareBy { !it.isObsolete } - .thenBy(String.CASE_INSENSITIVE_ORDER) { it.name }, - ) + val items = mutableListOf() - val untrustedSorted = untrusted.sortedWith(compareBy(String.CASE_INSENSITIVE_ORDER) { it.name }) + val updates = updates.filter(queryFilter(query)).map(extensionMapper(downloads)) + if (updates.isNotEmpty()) { + items.add(ExtensionUiModel.Header.Resource(R.string.ext_updates_pending)) + items.addAll(updates) + } - val availableSorted = available - // Filter out already installed extensions and disabled languages - .filter { avail -> - installed.none { it.pkgName == avail.pkgName } && - untrusted.none { it.pkgName == avail.pkgName } && - avail.lang in activeLangs && - (showNsfwSources || !avail.isNsfw) - } - .sortedWith(compareBy(String.CASE_INSENSITIVE_ORDER) { it.name }) - - if (updatesSorted.isNotEmpty()) { - val header = ExtensionGroupItem(context.getString(R.string.ext_updates_pending), updatesSorted.size, true) - if (preferences.extensionInstaller().get() != PreferenceValues.ExtensionInstaller.LEGACY) { - header.actionLabel = context.getString(R.string.ext_update_all) - header.actionOnClick = View.OnClickListener { _ -> - extensions - .filter { it.extension is Extension.Installed && it.extension.hasUpdate } - .forEach { updateExtension(it.extension as Extension.Installed) } + val installed = installed.filter(queryFilter(query)).map(extensionMapper(downloads)) + val untrusted = untrusted.filter(queryFilter(query)).map(extensionMapper(downloads)) + if (installed.isNotEmpty() || untrusted.isNotEmpty()) { + items.add(ExtensionUiModel.Header.Resource(R.string.ext_installed)) + items.addAll(installed) + items.addAll(untrusted) } - } - items += updatesSorted.map { extension -> - ExtensionItem(extension, header, currentDownloads[extension.pkgName] ?: InstallStep.Idle) - } - } - if (installedSorted.isNotEmpty() || untrustedSorted.isNotEmpty()) { - val header = ExtensionGroupItem(context.getString(R.string.ext_installed), installedSorted.size + untrustedSorted.size) - items += installedSorted.map { extension -> - ExtensionItem(extension, header, currentDownloads[extension.pkgName] ?: InstallStep.Idle) - } + if (languagesWithExtensions.isNotEmpty()) { + items.addAll(languagesWithExtensions) + } - items += untrustedSorted.map { extension -> - ExtensionItem(extension, header) + items + }.collectLatest { + _state.value = ExtensionState.Initialized(it) } } - if (availableSorted.isNotEmpty()) { - val availableGroupedByLang = availableSorted - .groupBy { LocaleHelper.getSourceDisplayName(it.lang, context) } - .toSortedMap() - - availableGroupedByLang - .forEach { - val header = ExtensionGroupItem(it.key, it.value.size) - items += it.value.map { extension -> - ExtensionItem(extension, header, currentDownloads[extension.pkgName] ?: InstallStep.Idle) - } - } - } - - this.extensions = items - return items } - @Synchronized - private fun updateInstallStep(extension: Extension, state: InstallStep): ExtensionItem? { - val extensions = extensions.toMutableList() - val position = extensions.indexOfFirst { it.extension.pkgName == extension.pkgName } - - return if (position != -1) { - val item = extensions[position].copy(installStep = state) - extensions[position] = item + fun search(query: String) { + launchIO { + _query.emit(query) + } + } - this.extensions = extensions - item - } else { - null + fun updateAllExtensions() { + launchIO { + val state = _state.value + if (state !is ExtensionState.Initialized) return@launchIO + state.list.mapNotNull { + if (it !is ExtensionUiModel.Item) return@mapNotNull null + if (it.extension !is Extension.Installed) return@mapNotNull null + if (it.extension.hasUpdate.not()) return@mapNotNull null + it.extension + }.forEach { + updateExtension(it) + } } } @@ -155,15 +162,29 @@ open class ExtensionPresenter( extensionManager.cancelInstallUpdateExtension(extension) } + private fun removeDownloadState(extension: Extension) { + _currentDownloads.update { map -> + val map = map.toMutableMap() + map.remove(extension.pkgName) + map + } + } + + private fun addDownloadState(extension: Extension, installStep: InstallStep) { + _currentDownloads.update { map -> + val map = map.toMutableMap() + map[extension.pkgName] = installStep + map + } + } + private fun Observable.subscribeToInstallUpdate(extension: Extension) { - this.doOnNext { currentDownloads[extension.pkgName] = it } - .doOnUnsubscribe { currentDownloads.remove(extension.pkgName) } - .map { state -> updateInstallStep(extension, state) } - .subscribeWithView({ view, item -> - if (item != null) { - view.downloadUpdate(item) - } - },) + this + .doOnUnsubscribe { removeDownloadState(extension) } + .subscribe( + { installStep -> addDownloadState(extension, installStep) }, + { removeDownloadState(extension) }, + ) } fun uninstallExtension(pkgName: String) { @@ -171,6 +192,7 @@ open class ExtensionPresenter( } fun findAvailableExtensions() { + isRefreshing = true extensionManager.findAvailableExtensions() } @@ -178,3 +200,28 @@ open class ExtensionPresenter( extensionManager.trustSignature(signatureHash) } } + +sealed interface ExtensionUiModel { + sealed interface Header : ExtensionUiModel { + data class Resource(@StringRes val textRes: Int) : Header + data class Text(val text: String) : Header + } + data class Item( + val extension: Extension, + val installStep: InstallStep, + ) : ExtensionUiModel { + + fun key(): String { + return when (extension) { + is Extension.Installed -> + if (extension.hasUpdate) "update_${extension.pkgName}" else extension.pkgName + else -> extension.pkgName + } + } + } +} + +sealed class ExtensionState { + object Uninitialized : ExtensionState() + data class Initialized(val list: List) : ExtensionState() +} diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionTrustDialog.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionTrustDialog.kt deleted file mode 100644 index 23d23a32ba..0000000000 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionTrustDialog.kt +++ /dev/null @@ -1,43 +0,0 @@ -package eu.kanade.tachiyomi.ui.browse.extension - -import android.app.Dialog -import android.os.Bundle -import androidx.core.os.bundleOf -import com.bluelinelabs.conductor.Controller -import com.google.android.material.dialog.MaterialAlertDialogBuilder -import eu.kanade.tachiyomi.R -import eu.kanade.tachiyomi.ui.base.controller.DialogController - -class ExtensionTrustDialog(bundle: Bundle? = null) : DialogController(bundle) - where T : Controller, T : ExtensionTrustDialog.Listener { - - constructor(target: T, signatureHash: String, pkgName: String) : this( - bundleOf( - SIGNATURE_KEY to signatureHash, - PKGNAME_KEY to pkgName, - ), - ) { - targetController = target - } - - override fun onCreateDialog(savedViewState: Bundle?): Dialog { - return MaterialAlertDialogBuilder(activity!!) - .setTitle(R.string.untrusted_extension) - .setMessage(R.string.untrusted_extension_message) - .setPositiveButton(R.string.ext_trust) { _, _ -> - (targetController as? Listener)?.trustSignature(args.getString(SIGNATURE_KEY)!!) - } - .setNegativeButton(R.string.ext_uninstall) { _, _ -> - (targetController as? Listener)?.uninstallExtension(args.getString(PKGNAME_KEY)!!) - } - .create() - } - - interface Listener { - fun trustSignature(signatureHash: String) - fun uninstallExtension(pkgName: String) - } -} - -private const val SIGNATURE_KEY = "signature_key" -private const val PKGNAME_KEY = "pkgname_key" diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionViewUtils.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionViewUtils.kt index a4bae24846..e9f4b263f6 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionViewUtils.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/extension/ExtensionViewUtils.kt @@ -3,7 +3,15 @@ package eu.kanade.tachiyomi.ui.browse.extension import android.content.Context import android.content.pm.PackageManager import android.graphics.drawable.Drawable +import androidx.compose.runtime.Composable +import androidx.compose.runtime.State +import androidx.compose.runtime.produceState +import androidx.compose.ui.graphics.ImageBitmap +import androidx.compose.ui.graphics.asImageBitmap +import androidx.compose.ui.platform.LocalContext +import androidx.core.graphics.drawable.toBitmap import eu.kanade.tachiyomi.extension.model.Extension +import eu.kanade.tachiyomi.util.lang.withIOContext fun Extension.getApplicationIcon(context: Context): Drawable? { return try { @@ -12,3 +20,27 @@ fun Extension.getApplicationIcon(context: Context): Drawable? { null } } + +@Composable +fun Extension.getIcon(): State> { + val context = LocalContext.current + return produceState>(initialValue = Result.Loading, this) { + withIOContext { + value = try { + Result.Success( + context.packageManager.getApplicationIcon(pkgName) + .toBitmap() + .asImageBitmap(), + ) + } catch (e: Exception) { + Result.Error + } + } + } +} + +sealed class Result { + object Loading : Result() + object Error : Result() + data class Success(val value: T) : Result() +} diff --git a/app/src/main/res/layout/extension_controller.xml b/app/src/main/res/layout/extension_controller.xml deleted file mode 100644 index 0db6a30248..0000000000 --- a/app/src/main/res/layout/extension_controller.xml +++ /dev/null @@ -1,32 +0,0 @@ - - - - - - - - - - - - diff --git a/app/src/main/res/layout/extension_item.xml b/app/src/main/res/layout/extension_item.xml deleted file mode 100644 index b76c9437de..0000000000 --- a/app/src/main/res/layout/extension_item.xml +++ /dev/null @@ -1,98 +0,0 @@ - - - - - - - - - - - - - -