diff --git a/AnkiDroid/src/main/AndroidManifest.xml b/AnkiDroid/src/main/AndroidManifest.xml
index e01b8ce48a6a..73307fdb3c3d 100644
--- a/AnkiDroid/src/main/AndroidManifest.xml
+++ b/AnkiDroid/src/main/AndroidManifest.xml
@@ -345,10 +345,6 @@
android:label="@string/preview_title"
android:exported="false"
/>
-
(R.id.toolbar)
+ .menu.findItem(R.id.action_back_side_only)
- override fun onCreate(savedInstanceState: Bundle?) {
- if (showedActivityFailedScreen(savedInstanceState)) {
- return
- }
- super.onCreate(savedInstanceState)
- setContentView(R.layout.previewer)
- setTransparentStatusBar()
-
- enableToolbar().apply {
- setDisplayHomeAsUpEnabled(true)
- setDisplayShowTitleEnabled(false)
- }
+ override fun onCreateView(
+ inflater: LayoutInflater,
+ container: ViewGroup?,
+ savedInstanceState: Bundle?
+ ): View? {
+ return inflater.inflate(R.layout.previewer, container, false)
+ }
- val selectedCardIds = intent.getLongArrayExtra(CARD_IDS_EXTRA)
- ?: throw IllegalArgumentException("'cardIds' extra must be present")
- val currentIndex = intent.getIntExtra(CURRENT_INDEX_EXTRA, 0)
- val mediaDir = File(CollectionHelper.getCurrentAnkiDroidDirectory(this), "collection.media").path
+ override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
+ val selectedCardIds = requireArguments().getLongArray(CARD_IDS_EXTRA)!!
+ val currentIndex = requireArguments().getInt(CURRENT_INDEX_EXTRA, 0)
+ val mediaDir = File(CollectionHelper.getCurrentAnkiDroidDirectory(requireContext()), "collection.media").path
viewModel = ViewModelProvider(
this,
PreviewerViewModel.factory(mediaDir, selectedCardIds, currentIndex)
)[PreviewerViewModel::class.java]
- val webView = findViewById(R.id.webview)
+ val webView = view.findViewById(R.id.webview)
CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true)
with(webView) {
webViewClient = object : WebViewClient() {
@@ -93,22 +94,22 @@ class PreviewerActivity : AnkiActivity() {
}
loadDataWithBaseURL(
viewModel.serverBaseUrl(),
- stdHtml(this@PreviewerActivity, Themes.currentTheme.isNightMode),
+ stdHtml(requireContext(), Themes.currentTheme.isNightMode),
"text/html",
null,
null
)
}
- val slider = findViewById(R.id.slider)
- val nextButton = findViewById(R.id.show_next)
- val previousButton = findViewById(R.id.show_previous)
- val progressIndicator = findViewById(R.id.progress_indicator)
+ val slider = view.findViewById(R.id.slider)
+ val nextButton = view.findViewById(R.id.show_next)
+ val previousButton = view.findViewById(R.id.show_previous)
+ val progressIndicator = view.findViewById(R.id.progress_indicator)
viewModel.onError
.flowWithLifecycle(lifecycle)
.onEach { errorMessage ->
- AlertDialog.Builder(this@PreviewerActivity)
+ AlertDialog.Builder(requireContext())
.setTitle(R.string.vague_error)
.setMessage(errorMessage)
.show()
@@ -169,16 +170,25 @@ class PreviewerActivity : AnkiActivity() {
previousButton.setOnClickListener {
viewModel.launchCatching { showAnswerOrPreviousCard() }
}
+
+ view.findViewById(R.id.toolbar).apply {
+ setOnMenuItemClickListener(this@PreviewerFragment)
+ setNavigationOnClickListener { requireActivity().onBackPressedDispatcher.onBackPressed() }
+ }
+
+ super.onViewCreated(view, savedInstanceState)
}
- override fun onCreateOptionsMenu(menu: Menu?): Boolean {
- menuInflater.inflate(R.menu.previewer2, menu)
- backsideOnlyButton = menu?.findItem(R.id.action_back_side_only)
+ override fun onMenuItemClick(item: MenuItem): Boolean {
+ when (item.itemId) {
+ R.id.action_edit -> editCard()
+ R.id.action_back_side_only -> viewModel.toggleBacksideOnly()
+ }
return true
}
private fun setBacksideOnlyButtonIcon(isBacksideOnly: Boolean) {
- backsideOnlyButton?.apply {
+ backsideOnlyButton.apply {
if (isBacksideOnly) {
setIcon(R.drawable.ic_card_answer)
setTitle(R.string.card_side_answer)
@@ -189,19 +199,6 @@ class PreviewerActivity : AnkiActivity() {
}
}
- override fun onPrepareOptionsMenu(menu: Menu?): Boolean {
- setBacksideOnlyButtonIcon(viewModel.backsideOnly.value)
- return super.onPrepareOptionsMenu(menu)
- }
-
- override fun onOptionsItemSelected(item: MenuItem): Boolean {
- when (item.itemId) {
- R.id.action_edit -> editCard()
- R.id.action_back_side_only -> viewModel.toggleBacksideOnly()
- }
- return super.onOptionsItemSelected(item)
- }
-
private val editCardLauncher = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { result ->
if (result.data?.getBooleanExtra(NoteEditor.RELOAD_REQUIRED_EXTRA_KEY, false) == true ||
result.data?.getBooleanExtra(NoteEditor.NOTE_CHANGED_EXTRA_KEY, false) == true
@@ -211,7 +208,7 @@ class PreviewerActivity : AnkiActivity() {
}
private fun editCard() {
- val intent = Intent(this, NoteEditor::class.java).apply {
+ val intent = Intent(requireContext(), NoteEditor::class.java).apply {
putExtra(NoteEditor.EXTRA_CALLER, NoteEditor.CALLER_PREVIEWER_EDIT)
putExtra(NoteEditor.EXTRA_EDIT_FROM_CARD_ID, viewModel.cardId())
}
@@ -223,10 +220,8 @@ class PreviewerActivity : AnkiActivity() {
const val CARD_IDS_EXTRA = "cardIds"
fun getIntent(context: Context, selectedCardIds: LongArray, currentIndex: Int): Intent {
- return Intent(context, PreviewerActivity::class.java).apply {
- putExtra(CURRENT_INDEX_EXTRA, currentIndex)
- putExtra(CARD_IDS_EXTRA, selectedCardIds)
- }
+ val args = bundleOf(CURRENT_INDEX_EXTRA to currentIndex, CARD_IDS_EXTRA to selectedCardIds)
+ return SingleFragmentActivity.getIntent(context, PreviewerFragment::class, args)
}
}
}
diff --git a/AnkiDroid/src/main/res/layout/previewer.xml b/AnkiDroid/src/main/res/layout/previewer.xml
index 3d661e486195..99e9f9da871b 100644
--- a/AnkiDroid/src/main/res/layout/previewer.xml
+++ b/AnkiDroid/src/main/res/layout/previewer.xml
@@ -4,7 +4,7 @@
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
- tools:context=".previewer.PreviewerActivity">
+ tools:context=".previewer.PreviewerFragment">
diff --git a/AnkiDroid/src/test/java/com/ichi2/anki/ActivityStartupUnderBackupTest.kt b/AnkiDroid/src/test/java/com/ichi2/anki/ActivityStartupUnderBackupTest.kt
index 7dad0521287a..d5eeb74ec9a0 100644
--- a/AnkiDroid/src/test/java/com/ichi2/anki/ActivityStartupUnderBackupTest.kt
+++ b/AnkiDroid/src/test/java/com/ichi2/anki/ActivityStartupUnderBackupTest.kt
@@ -19,7 +19,6 @@ import android.app.Activity
import android.os.Looper.getMainLooper
import com.canhub.cropper.CropImageActivity
import com.ichi2.anki.preferences.Preferences
-import com.ichi2.anki.previewer.PreviewerActivity
import com.ichi2.testutils.ActivityList
import com.ichi2.testutils.ActivityList.ActivityLaunchParam
import com.ichi2.testutils.EmptyApplication
@@ -54,7 +53,6 @@ class ActivityStartupUnderBackupTest : RobolectricTest() {
notYetHandled(IntentHandler::class.java.simpleName, "Not working (or implemented) - inherits from Activity")
notYetHandled(Preferences::class.java.simpleName, "Not working (or implemented) - inherits from AppCompatPreferenceActivity")
notYetHandled(FilteredDeckOptions::class.java.simpleName, "Not working (or implemented) - inherits from AppCompatPreferenceActivity")
- notYetHandled(PreviewerActivity::class.java.simpleName, "Implemented, but the test fails because the activity throws if a specific intent extra isn't set")
notYetHandled(SingleFragmentActivity::class.java.simpleName, "Implemented, but the test fails because the activity throws if a specific intent extra isn't set")
}
diff --git a/AnkiDroid/src/test/java/com/ichi2/testutils/ActivityList.kt b/AnkiDroid/src/test/java/com/ichi2/testutils/ActivityList.kt
index 2968e7c7a9c8..4f651cb55beb 100644
--- a/AnkiDroid/src/test/java/com/ichi2/testutils/ActivityList.kt
+++ b/AnkiDroid/src/test/java/com/ichi2/testutils/ActivityList.kt
@@ -27,7 +27,6 @@ import com.ichi2.anki.multimediacard.activity.MultimediaEditFieldActivity
import com.ichi2.anki.notetype.ManageNotetypes
import com.ichi2.anki.pages.PagesActivity
import com.ichi2.anki.preferences.Preferences
-import com.ichi2.anki.previewer.PreviewerActivity
import com.ichi2.anki.services.ReminderService.Companion.getReviewDeckIntent
import com.ichi2.anki.ui.windows.managespace.ManageSpaceActivity
import com.ichi2.anki.ui.windows.permissions.PermissionsActivity
@@ -76,7 +75,6 @@ object ActivityList {
get(ManageNotetypes::class.java),
get(ManageSpaceActivity::class.java),
get(PermissionsActivity::class.java),
- get(PreviewerActivity::class.java),
get(SingleFragmentActivity::class.java)
)
}