#2159 added navigation safeargs to allow for navigation to reader when selecting book from library

This commit is contained in:
HissPirat 2020-06-22 16:55:18 +02:00
parent 4af75bb276
commit cb13f4440f
9 changed files with 88 additions and 20 deletions

View File

@ -3,6 +3,7 @@ import plugin.KiwixConfigurationPlugin
plugins {
android
id("com.github.triplet.play") version Versions.com_github_triplet_play_gradle_plugin
id("androidx.navigation.safeargs")
}
plugins.apply(KiwixConfigurationPlugin::class)
@ -93,5 +94,4 @@ dependencies {
implementation("androidx.navigation:navigation-ui-ktx:$navVersion")
// Testing Navigation
androidTestImplementation("androidx.navigation:navigation-testing:$navVersion")
}

View File

@ -29,9 +29,9 @@ import org.kiwix.kiwixmobile.local_file_transfer.LocalFileTransferActivity
import org.kiwix.kiwixmobile.main.KiwixMainActivity
import org.kiwix.kiwixmobile.main.KiwixMainFragment
import org.kiwix.kiwixmobile.main.KiwixNewNavigationActivity
import org.kiwix.kiwixmobile.nav_destination_download.OnlineLibraryFragment
import org.kiwix.kiwixmobile.nav_destination_library.LocalLibraryFragment
import org.kiwix.kiwixmobile.nav_destination_reader.ReaderFragment
import org.kiwix.kiwixmobile.nav.destination.library.OnlineLibraryFragment
import org.kiwix.kiwixmobile.nav.destination.library.LocalLibraryFragment
import org.kiwix.kiwixmobile.nav.destination.reader.ReaderFragment
import org.kiwix.kiwixmobile.settings.KiwixSettingsActivity
import org.kiwix.kiwixmobile.splash.KiwixSplashActivity
import org.kiwix.kiwixmobile.webserver.ZimHostActivity

View File

@ -16,7 +16,7 @@
*
*/
package org.kiwix.kiwixmobile.nav_destination_library
package org.kiwix.kiwixmobile.nav.destination.library
import android.Manifest
import android.content.pm.PackageManager
@ -75,7 +75,7 @@ class LocalLibraryFragment : BaseFragment() {
}
private val bookDelegate: BookOnDiskDelegate.BookDelegate by lazy {
BookOnDiskDelegate.BookDelegate(sharedPreferenceUtil,
{ offerAction(ZimManageViewModel.FileSelectActions.RequestOpen(it)) },
{ offerAction(ZimManageViewModel.FileSelectActions.RequestNavigateTo(it)) },
{ offerAction(ZimManageViewModel.FileSelectActions.RequestMultiSelection(it)) },
{ offerAction(ZimManageViewModel.FileSelectActions.RequestSelect(it)) })
}
@ -135,7 +135,8 @@ class LocalLibraryFragment : BaseFragment() {
zim_swiperefresh.isRefreshing = it!!
})
if (savedInstanceState != null && savedInstanceState.getBoolean(WAS_IN_ACTION_MODE)) {
zimManageViewModel.fileSelectActions.offer(ZimManageViewModel.FileSelectActions.RestartActionMode)
zimManageViewModel.fileSelectActions
.offer(ZimManageViewModel.FileSelectActions.RestartActionMode)
}
disposable.add(zimManageViewModel.libraryTabIsVisible.subscribe { finishActionMode() })

View File

@ -16,7 +16,7 @@
*
*/
package org.kiwix.kiwixmobile.nav_destination_download
package org.kiwix.kiwixmobile.nav.destination.library
import android.content.Intent
import android.net.ConnectivityManager

View File

@ -16,7 +16,7 @@
*
*/
package org.kiwix.kiwixmobile.nav_destination_reader
package org.kiwix.kiwixmobile.nav.destination.reader
import android.content.Intent
import android.os.Bundle
@ -28,6 +28,7 @@ import android.view.ViewGroup
import androidx.appcompat.app.AppCompatActivity
import androidx.core.net.toFile
import androidx.core.net.toUri
import androidx.navigation.fragment.navArgs
import org.json.JSONArray
import org.kiwix.kiwixmobile.R
import org.kiwix.kiwixmobile.core.base.BaseActivity
@ -39,7 +40,6 @@ import org.kiwix.kiwixmobile.core.main.CoreReaderFragment
import org.kiwix.kiwixmobile.core.main.WebViewCallback
import org.kiwix.kiwixmobile.core.reader.ZimFileReader
import org.kiwix.kiwixmobile.core.reader.ZimReaderContainer
import org.kiwix.kiwixmobile.core.utils.EXTRA_ZIM_FILE
import org.kiwix.kiwixmobile.core.utils.SharedPreferenceUtil
import org.kiwix.kiwixmobile.core.utils.TAG_CURRENT_ARTICLES
import org.kiwix.kiwixmobile.core.utils.TAG_CURRENT_FILE
@ -48,6 +48,7 @@ import org.kiwix.kiwixmobile.core.utils.TAG_CURRENT_TAB
import org.kiwix.kiwixmobile.core.utils.TAG_KIWIX
import org.kiwix.kiwixmobile.core.utils.UpdateUtils
import org.kiwix.kiwixmobile.core.utils.files.FileUtils
import org.kiwix.kiwixmobile.destinationreader.ReaderFragmentArgs
import org.kiwix.kiwixmobile.kiwixActivityComponent
import org.kiwix.kiwixmobile.main.KiwixWebViewClient
import org.kiwix.kiwixmobile.webserver.ZimHostActivity
@ -92,7 +93,7 @@ class ReaderFragment : CoreReaderFragment() {
private fun manageExternalLaunchAndRestoringViewState() {
val data = uriFromIntent()
val data = uriFromNavigation()
if (data != null) {
val filePath = FileUtils.getLocalFilePathByUri(requireActivity().applicationContext, data)
@ -145,10 +146,10 @@ class ReaderFragment : CoreReaderFragment() {
override fun isInvalidTitle(zimFileTitle: String?) =
super.isInvalidTitle(zimFileTitle) || HOME_URL == getCurrentWebView().url
private fun uriFromIntent() =
activity?.intent?.data ?: activity?.intent?.getStringExtra(EXTRA_ZIM_FILE)?.let {
File(FileUtils.getFileName(it)).toUri()
}
private val args: ReaderFragmentArgs by navArgs()
private fun uriFromNavigation() =
args.zimFileUri.let { File(FileUtils.getFileName(it)).toUri() }
private fun restoreTabStates() {
val settings = requireActivity().getSharedPreferences(SharedPreferenceUtil.PREF_KIWIX_MOBILE, 0)

View File

@ -54,6 +54,7 @@ import org.kiwix.kiwixmobile.zim_manager.NetworkState.CONNECTED
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.MultiModeFinished
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestDeleteMultiSelection
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestMultiSelection
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestNavigateTo
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestOpen
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestSelect
import org.kiwix.kiwixmobile.zim_manager.ZimManageViewModel.FileSelectActions.RequestShareMultiSelection
@ -62,6 +63,7 @@ import org.kiwix.kiwixmobile.zim_manager.fileselect_view.FileSelectListState
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.DeleteFiles
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.None
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.OpenFile
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.OpenFileWithNavigation
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.ShareFiles
import org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects.StartMultiSelection
import org.kiwix.kiwixmobile.zim_manager.library_view.adapter.LibraryListItem
@ -89,6 +91,7 @@ class ZimManageViewModel @Inject constructor(
) : ViewModel() {
sealed class FileSelectActions {
data class RequestOpen(val bookOnDisk: BookOnDisk) : FileSelectActions()
data class RequestNavigateTo(val bookOnDisk: BookOnDisk) : FileSelectActions()
data class RequestSelect(val bookOnDisk: BookOnDisk) : FileSelectActions()
data class RequestMultiSelection(val bookOnDisk: BookOnDisk) : FileSelectActions()
object RequestDeleteMultiSelection : FileSelectActions()
@ -149,6 +152,7 @@ class ZimManageViewModel @Inject constructor(
private fun fileSelectActions() = fileSelectActions.subscribe({
sideEffects.offer(
when (it) {
is RequestNavigateTo -> OpenFileWithNavigation(it.bookOnDisk)
is RequestOpen -> OpenFile(it.bookOnDisk)
is RequestMultiSelection -> startMultiSelectionAndSelectBook(it.bookOnDisk)
RequestDeleteMultiSelection -> DeleteFiles(selectionsFromState())

View File

@ -0,0 +1,50 @@
/*
* Kiwix Android
* Copyright (c) 2020 Kiwix <android.kiwix.org>
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.kiwix.kiwixmobile.zim_manager.fileselect_view.effects
import androidx.appcompat.app.AppCompatActivity
import androidx.core.net.toUri
import androidx.navigation.findNavController
import org.kiwix.kiwixmobile.core.R
import org.kiwix.kiwixmobile.core.base.SideEffect
import org.kiwix.kiwixmobile.core.extensions.toast
import org.kiwix.kiwixmobile.core.zim_manager.fileselect_view.adapter.BooksOnDiskListItem
import org.kiwix.kiwixmobile.destinationlibrary.LocalLibraryFragmentDirections
data class OpenFileWithNavigation(private val bookOnDisk: BooksOnDiskListItem.BookOnDisk) :
SideEffect<Unit> {
override fun invokeWith(activity: AppCompatActivity) {
val file = bookOnDisk.file
if (!file.canRead()) {
activity.toast(R.string.error_file_not_found)
} else {
val action = LocalLibraryFragmentDirections.actionNavigationLibraryToNavigationReader(
file.toUri().toString()
)
activity.findNavController(org.kiwix.kiwixmobile.R.id.nav_host_fragment).navigate(action)
// activity.finish()
// activity.start<KiwixMainActivity> {
// data = file.toUri()
// flags = Intent.FLAG_ACTIVITY_CLEAR_TOP
// }
}
}
}

View File

@ -23,19 +23,27 @@
app:startDestination="@id/navigation_library">
<fragment
android:id="@+id/navigation_reader"
android:name="org.kiwix.kiwixmobile.nav_destination_reader.ReaderFragment"
android:name="org.kiwix.kiwixmobile.nav.destination.reader.ReaderFragment"
android:label="Reader"
tools:layout="@layout/fragment_destination_reader" />
tools:layout="@layout/fragment_destination_reader">
<argument
android:name="zimFileUri"
app:argType="string" />
</fragment>
<fragment
android:id="@+id/navigation_library"
android:name="org.kiwix.kiwixmobile.nav_destination_library.LocalLibraryFragment"
android:name="org.kiwix.kiwixmobile.nav.destination.library.LocalLibraryFragment"
android:label="Library"
tools:layout="@layout/fragment_destination_library" />
tools:layout="@layout/fragment_destination_library">
<action
android:id="@+id/action_navigation_library_to_navigation_reader"
app:destination="@id/navigation_reader" />
</fragment>
<fragment
android:id="@+id/navigation_downloads"
android:name="org.kiwix.kiwixmobile.nav_destination_download.OnlineLibraryFragment"
android:name="org.kiwix.kiwixmobile.nav.destination.library.OnlineLibraryFragment"
android:label="Downloads"
tools:layout="@layout/fragment_destination_download" />
</navigation>

View File

@ -6,6 +6,10 @@ buildscript {
dependencies {
classpath(Libs.com_android_tools_build_gradle)
classpath(Libs.kotlin_gradle_plugin)
val navVersion = "2.3.0-rc01"
classpath("androidx.navigation:navigation-safe-args-gradle-plugin:$navVersion")
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}