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) ) }