mirror of
				https://github.com/mihonapp/mihon.git
				synced 2025-11-04 08:08:55 +01:00 
			
		
		
		
	Split UpdatesGridGlanceWidget into smaller bits (#8991)
- Renamed Composables - Moved Constants to core module
This commit is contained in:
		@@ -32,7 +32,7 @@ import eu.kanade.presentation.more.settings.widget.SwitchPreferenceWidget
 | 
			
		||||
import eu.kanade.presentation.more.settings.widget.TextPreferenceWidget
 | 
			
		||||
import eu.kanade.tachiyomi.R
 | 
			
		||||
import eu.kanade.tachiyomi.ui.more.DownloadQueueState
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
 | 
			
		||||
@Composable
 | 
			
		||||
fun MoreScreen(
 | 
			
		||||
 
 | 
			
		||||
@@ -124,8 +124,8 @@ class App : Application(), DefaultLifecycleObserver, ImageLoaderFactory {
 | 
			
		||||
        setAppCompatDelegateThemeMode(Injekt.get<UiPreferences>().themeMode().get())
 | 
			
		||||
 | 
			
		||||
        // Updates widget update
 | 
			
		||||
        with(TachiyomiWidgetManager) {
 | 
			
		||||
            init(ProcessLifecycleOwner.get().lifecycleScope, Injekt.get())
 | 
			
		||||
        with(TachiyomiWidgetManager(Injekt.get())) {
 | 
			
		||||
            init(ProcessLifecycleOwner.get().lifecycleScope)
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (!LogcatLogger.isInstalled && networkPreferences.verboseLogging().get()) {
 | 
			
		||||
 
 | 
			
		||||
@@ -25,6 +25,7 @@ import eu.kanade.tachiyomi.util.lang.launchUI
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.notification
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.notificationBuilder
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.notificationManager
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
import tachiyomi.domain.chapter.model.Chapter
 | 
			
		||||
import tachiyomi.domain.manga.model.Manga
 | 
			
		||||
import uy.kohesive.injekt.injectLazy
 | 
			
		||||
@@ -333,7 +334,7 @@ class LibraryUpdateNotifier(private val context: Context) {
 | 
			
		||||
    private fun getNotificationIntent(): PendingIntent {
 | 
			
		||||
        val intent = Intent(context, MainActivity::class.java).apply {
 | 
			
		||||
            flags = Intent.FLAG_ACTIVITY_CLEAR_TOP or Intent.FLAG_ACTIVITY_SINGLE_TOP
 | 
			
		||||
            action = MainActivity.SHORTCUT_UPDATES
 | 
			
		||||
            action = Constants.SHORTCUT_UPDATES
 | 
			
		||||
        }
 | 
			
		||||
        return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE)
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -7,6 +7,7 @@ import android.net.Uri
 | 
			
		||||
import androidx.core.net.toUri
 | 
			
		||||
import eu.kanade.tachiyomi.extension.util.ExtensionInstaller
 | 
			
		||||
import eu.kanade.tachiyomi.ui.main.MainActivity
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Class that manages [PendingIntent] of activity's
 | 
			
		||||
@@ -20,7 +21,7 @@ object NotificationHandler {
 | 
			
		||||
    internal fun openDownloadManagerPendingActivity(context: Context): PendingIntent {
 | 
			
		||||
        val intent = Intent(context, MainActivity::class.java).apply {
 | 
			
		||||
            flags = Intent.FLAG_ACTIVITY_CLEAR_TOP or Intent.FLAG_ACTIVITY_SINGLE_TOP
 | 
			
		||||
            action = MainActivity.SHORTCUT_DOWNLOADS
 | 
			
		||||
            action = Constants.SHORTCUT_DOWNLOADS
 | 
			
		||||
        }
 | 
			
		||||
        return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE)
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -21,7 +21,6 @@ import eu.kanade.tachiyomi.data.updater.AppUpdateService
 | 
			
		||||
import eu.kanade.tachiyomi.source.SourceManager
 | 
			
		||||
import eu.kanade.tachiyomi.ui.main.MainActivity
 | 
			
		||||
import eu.kanade.tachiyomi.ui.reader.ReaderActivity
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import eu.kanade.tachiyomi.util.lang.launchIO
 | 
			
		||||
import eu.kanade.tachiyomi.util.storage.DiskUtil
 | 
			
		||||
import eu.kanade.tachiyomi.util.storage.getUriCompat
 | 
			
		||||
@@ -30,6 +29,7 @@ import eu.kanade.tachiyomi.util.system.notificationManager
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.toShareIntent
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.toast
 | 
			
		||||
import kotlinx.coroutines.runBlocking
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
import tachiyomi.domain.chapter.model.Chapter
 | 
			
		||||
import tachiyomi.domain.chapter.model.toChapterUpdate
 | 
			
		||||
import tachiyomi.domain.manga.model.Manga
 | 
			
		||||
@@ -455,7 +455,7 @@ class NotificationReceiver : BroadcastReceiver() {
 | 
			
		||||
         */
 | 
			
		||||
        internal fun openChapterPendingActivity(context: Context, manga: Manga, groupId: Int): PendingIntent {
 | 
			
		||||
            val newIntent =
 | 
			
		||||
                Intent(context, MainActivity::class.java).setAction(MainActivity.SHORTCUT_MANGA)
 | 
			
		||||
                Intent(context, MainActivity::class.java).setAction(Constants.SHORTCUT_MANGA)
 | 
			
		||||
                    .addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
 | 
			
		||||
                    .putExtra(Constants.MANGA_EXTRA, manga.id)
 | 
			
		||||
                    .putExtra("notificationId", manga.id.hashCode())
 | 
			
		||||
@@ -538,7 +538,7 @@ class NotificationReceiver : BroadcastReceiver() {
 | 
			
		||||
         */
 | 
			
		||||
        internal fun openExtensionsPendingActivity(context: Context): PendingIntent {
 | 
			
		||||
            val intent = Intent(context, MainActivity::class.java).apply {
 | 
			
		||||
                action = MainActivity.SHORTCUT_EXTENSIONS
 | 
			
		||||
                action = Constants.SHORTCUT_EXTENSIONS
 | 
			
		||||
                addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
 | 
			
		||||
            }
 | 
			
		||||
            return PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE)
 | 
			
		||||
 
 | 
			
		||||
@@ -33,8 +33,8 @@ import eu.kanade.tachiyomi.ui.browse.source.browse.BrowseSourceScreenModel
 | 
			
		||||
import eu.kanade.tachiyomi.ui.home.HomeScreen
 | 
			
		||||
import eu.kanade.tachiyomi.ui.manga.MangaScreen
 | 
			
		||||
import eu.kanade.tachiyomi.ui.webview.WebViewScreen
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import kotlinx.coroutines.launch
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
import tachiyomi.domain.manga.model.Manga
 | 
			
		||||
 | 
			
		||||
data class SourceSearchScreen(
 | 
			
		||||
 
 | 
			
		||||
@@ -54,11 +54,11 @@ import eu.kanade.tachiyomi.ui.browse.source.browse.BrowseSourceScreenModel.Listi
 | 
			
		||||
import eu.kanade.tachiyomi.ui.category.CategoryScreen
 | 
			
		||||
import eu.kanade.tachiyomi.ui.manga.MangaScreen
 | 
			
		||||
import eu.kanade.tachiyomi.ui.webview.WebViewScreen
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import eu.kanade.tachiyomi.util.lang.launchIO
 | 
			
		||||
import kotlinx.coroutines.channels.Channel
 | 
			
		||||
import kotlinx.coroutines.flow.collectLatest
 | 
			
		||||
import kotlinx.coroutines.flow.receiveAsFlow
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
 | 
			
		||||
data class BrowseSourceScreen(
 | 
			
		||||
    private val sourceId: Long,
 | 
			
		||||
 
 | 
			
		||||
@@ -79,7 +79,6 @@ import eu.kanade.tachiyomi.ui.library.LibrarySettingsSheet
 | 
			
		||||
import eu.kanade.tachiyomi.ui.library.LibraryTab
 | 
			
		||||
import eu.kanade.tachiyomi.ui.manga.MangaScreen
 | 
			
		||||
import eu.kanade.tachiyomi.ui.more.NewUpdateScreen
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.dpToPx
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.isNavigationBarNeedsScrim
 | 
			
		||||
import eu.kanade.tachiyomi.util.system.logcat
 | 
			
		||||
@@ -94,6 +93,7 @@ import kotlinx.coroutines.flow.launchIn
 | 
			
		||||
import kotlinx.coroutines.flow.onEach
 | 
			
		||||
import kotlinx.coroutines.launch
 | 
			
		||||
import logcat.LogPriority
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
import tachiyomi.domain.category.model.Category
 | 
			
		||||
import uy.kohesive.injekt.Injekt
 | 
			
		||||
import uy.kohesive.injekt.api.get
 | 
			
		||||
@@ -405,17 +405,17 @@ class MainActivity : BaseActivity() {
 | 
			
		||||
        isHandlingShortcut = true
 | 
			
		||||
 | 
			
		||||
        when (intent.action) {
 | 
			
		||||
            SHORTCUT_LIBRARY -> HomeScreen.openTab(HomeScreen.Tab.Library())
 | 
			
		||||
            SHORTCUT_MANGA -> {
 | 
			
		||||
            Constants.SHORTCUT_LIBRARY -> HomeScreen.openTab(HomeScreen.Tab.Library())
 | 
			
		||||
            Constants.SHORTCUT_MANGA -> {
 | 
			
		||||
                val idToOpen = intent.extras?.getLong(Constants.MANGA_EXTRA) ?: return false
 | 
			
		||||
                navigator.popUntilRoot()
 | 
			
		||||
                HomeScreen.openTab(HomeScreen.Tab.Library(idToOpen))
 | 
			
		||||
            }
 | 
			
		||||
            SHORTCUT_UPDATES -> HomeScreen.openTab(HomeScreen.Tab.Updates)
 | 
			
		||||
            SHORTCUT_HISTORY -> HomeScreen.openTab(HomeScreen.Tab.History)
 | 
			
		||||
            SHORTCUT_SOURCES -> HomeScreen.openTab(HomeScreen.Tab.Browse(false))
 | 
			
		||||
            SHORTCUT_EXTENSIONS -> HomeScreen.openTab(HomeScreen.Tab.Browse(true))
 | 
			
		||||
            SHORTCUT_DOWNLOADS -> {
 | 
			
		||||
            Constants.SHORTCUT_UPDATES -> HomeScreen.openTab(HomeScreen.Tab.Updates)
 | 
			
		||||
            Constants.SHORTCUT_HISTORY -> HomeScreen.openTab(HomeScreen.Tab.History)
 | 
			
		||||
            Constants.SHORTCUT_SOURCES -> HomeScreen.openTab(HomeScreen.Tab.Browse(false))
 | 
			
		||||
            Constants.SHORTCUT_EXTENSIONS -> HomeScreen.openTab(HomeScreen.Tab.Browse(true))
 | 
			
		||||
            Constants.SHORTCUT_DOWNLOADS -> {
 | 
			
		||||
                navigator.popUntilRoot()
 | 
			
		||||
                HomeScreen.openTab(HomeScreen.Tab.More(toDownloads = true))
 | 
			
		||||
            }
 | 
			
		||||
@@ -475,15 +475,6 @@ class MainActivity : BaseActivity() {
 | 
			
		||||
        private const val SPLASH_MAX_DURATION = 5000 // ms
 | 
			
		||||
        private const val SPLASH_EXIT_ANIM_DURATION = 400L // ms
 | 
			
		||||
 | 
			
		||||
        // Shortcut actions
 | 
			
		||||
        const val SHORTCUT_LIBRARY = "eu.kanade.tachiyomi.SHOW_LIBRARY"
 | 
			
		||||
        const val SHORTCUT_MANGA = "eu.kanade.tachiyomi.SHOW_MANGA"
 | 
			
		||||
        const val SHORTCUT_UPDATES = "eu.kanade.tachiyomi.SHOW_RECENTLY_UPDATED"
 | 
			
		||||
        const val SHORTCUT_HISTORY = "eu.kanade.tachiyomi.SHOW_RECENTLY_READ"
 | 
			
		||||
        const val SHORTCUT_SOURCES = "eu.kanade.tachiyomi.SHOW_CATALOGUES"
 | 
			
		||||
        const val SHORTCUT_EXTENSIONS = "eu.kanade.tachiyomi.EXTENSIONS"
 | 
			
		||||
        const val SHORTCUT_DOWNLOADS = "eu.kanade.tachiyomi.SHOW_DOWNLOADS"
 | 
			
		||||
 | 
			
		||||
        const val INTENT_SEARCH = "eu.kanade.tachiyomi.SEARCH"
 | 
			
		||||
        const val INTENT_SEARCH_QUERY = "query"
 | 
			
		||||
        const val INTENT_SEARCH_FILTER = "filter"
 | 
			
		||||
 
 | 
			
		||||
@@ -67,7 +67,6 @@ import eu.kanade.tachiyomi.ui.reader.viewer.BaseViewer
 | 
			
		||||
import eu.kanade.tachiyomi.ui.reader.viewer.ReaderProgressIndicator
 | 
			
		||||
import eu.kanade.tachiyomi.ui.reader.viewer.pager.R2LPagerViewer
 | 
			
		||||
import eu.kanade.tachiyomi.ui.webview.WebViewActivity
 | 
			
		||||
import eu.kanade.tachiyomi.util.Constants
 | 
			
		||||
import eu.kanade.tachiyomi.util.lang.launchIO
 | 
			
		||||
import eu.kanade.tachiyomi.util.lang.launchNonCancellable
 | 
			
		||||
import eu.kanade.tachiyomi.util.lang.withUIContext
 | 
			
		||||
@@ -94,6 +93,7 @@ import kotlinx.coroutines.flow.onEach
 | 
			
		||||
import kotlinx.coroutines.flow.sample
 | 
			
		||||
import kotlinx.coroutines.launch
 | 
			
		||||
import logcat.LogPriority
 | 
			
		||||
import tachiyomi.core.Constants
 | 
			
		||||
import tachiyomi.domain.manga.model.Manga
 | 
			
		||||
import uy.kohesive.injekt.injectLazy
 | 
			
		||||
import kotlin.math.abs
 | 
			
		||||
@@ -403,7 +403,7 @@ class ReaderActivity : BaseActivity() {
 | 
			
		||||
            viewModel.manga?.id?.let { id ->
 | 
			
		||||
                startActivity(
 | 
			
		||||
                    Intent(this, MainActivity::class.java).apply {
 | 
			
		||||
                        action = MainActivity.SHORTCUT_MANGA
 | 
			
		||||
                        action = Constants.SHORTCUT_MANGA
 | 
			
		||||
                        putExtra(Constants.MANGA_EXTRA, id)
 | 
			
		||||
                        addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
 | 
			
		||||
                    },
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +0,0 @@
 | 
			
		||||
package eu.kanade.tachiyomi.util
 | 
			
		||||
 | 
			
		||||
object Constants {
 | 
			
		||||
    const val URL_HELP = "https://tachiyomi.org/help/"
 | 
			
		||||
 | 
			
		||||
    const val MANGA_EXTRA = "manga"
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user