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 d7bc24640..21d8095e8 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 @@ -66,6 +66,7 @@ import eu.kanade.tachiyomi.ui.reader.setting.ReadingModeType 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.preference.toggle import eu.kanade.tachiyomi.util.system.applySystemAnimatorScale import eu.kanade.tachiyomi.util.system.createReaderThemeContext @@ -275,6 +276,9 @@ class ReaderActivity : BaseRxActivity() { */ override fun onOptionsItemSelected(item: MenuItem): Boolean { when (item.itemId) { + R.id.action_open_in_web_view -> { + openChapterInWebview() + } R.id.action_bookmark -> { presenter.bookmarkCurrentChapter(true) invalidateOptionsMenu() @@ -665,6 +669,15 @@ class ReaderActivity : BaseRxActivity() { startPostponedEnterTransition() } + private fun openChapterInWebview() { + val manga = presenter.manga ?: return + val source = presenter.getSource() ?: return + val url = presenter.getChapterUrl() ?: return + + val intent = WebViewActivity.newIntent(this, url, source.id, manga.title) + startActivity(intent) + } + private fun showReadingModeToast(mode: Int) { try { val strings = resources.getStringArray(R.array.viewers_selector) 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 02589dbc5..1a2c141b1 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 @@ -35,6 +35,7 @@ import eu.kanade.tachiyomi.data.track.job.DelayedTrackingStore import eu.kanade.tachiyomi.data.track.job.DelayedTrackingUpdateJob import eu.kanade.tachiyomi.source.SourceManager import eu.kanade.tachiyomi.source.model.Page +import eu.kanade.tachiyomi.source.online.HttpSource import eu.kanade.tachiyomi.ui.base.presenter.BasePresenter import eu.kanade.tachiyomi.ui.reader.loader.ChapterLoader import eu.kanade.tachiyomi.ui.reader.loader.DownloadPageLoader @@ -606,6 +607,15 @@ class ReaderPresenter( return viewerChaptersRelay.value?.currChapter } + fun getSource() = manga?.source?.let { sourceManager.getOrStub(it) } as? HttpSource + + fun getChapterUrl(): String? { + val sChapter = getCurrentChapter()?.chapter ?: return null + val source = getSource() ?: return null + + return source.getChapterUrl(sChapter) + } + /** * Bookmarks the currently active chapter. */ diff --git a/app/src/main/res/drawable/ic_webview_24dp.xml b/app/src/main/res/drawable/ic_webview_24dp.xml new file mode 100644 index 000000000..cd993e203 --- /dev/null +++ b/app/src/main/res/drawable/ic_webview_24dp.xml @@ -0,0 +1,7 @@ + + + diff --git a/app/src/main/res/menu/reader.xml b/app/src/main/res/menu/reader.xml index 419c9674f..0d29f06d5 100644 --- a/app/src/main/res/menu/reader.xml +++ b/app/src/main/res/menu/reader.xml @@ -16,4 +16,11 @@ app:iconTint="?attr/colorOnSurface" app:showAsAction="ifRoom" /> + +