X-Git-Url: https://gitweb.stoutner.com/?p=PrivacyBrowserAndroid.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fcom%2Fstoutner%2Fprivacybrowser%2Fdialogs%2FSaveDialog.kt;h=77cd1c1acb7b16434b6c7614b58e71842450cb72;hp=35eb2e0db537786fabb4416fdb2d96e9be66f0c1;hb=HEAD;hpb=d4f39c36beb5e6c3568a1e075274ad66defd8e8e diff --git a/app/src/main/java/com/stoutner/privacybrowser/dialogs/SaveDialog.kt b/app/src/main/java/com/stoutner/privacybrowser/dialogs/SaveDialog.kt index 35eb2e0d..dca20947 100644 --- a/app/src/main/java/com/stoutner/privacybrowser/dialogs/SaveDialog.kt +++ b/app/src/main/java/com/stoutner/privacybrowser/dialogs/SaveDialog.kt @@ -1,81 +1,74 @@ /* - * Copyright © 2016-2021 Soren Stoutner . + * Copyright 2019-2024 Soren Stoutner . * - * This file is part of Privacy Browser . + * This file is part of Privacy Browser Android . * - * Privacy Browser is free software: you can redistribute it and/or modify + * Privacy Browser Android 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. * - * Privacy Browser is distributed in the hope that it will be useful, + * Privacy Browser Android 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 Privacy Browser. If not, see . + * along with Privacy Browser Android. If not, see . */ package com.stoutner.privacybrowser.dialogs -import android.annotation.SuppressLint import android.app.Dialog import android.content.Context import android.content.DialogInterface -import android.content.Intent -import android.content.res.Configuration import android.os.Bundle import android.text.Editable +import android.text.InputType import android.text.TextWatcher +import android.view.View import android.view.WindowManager -import android.widget.Button import android.widget.EditText +import android.widget.LinearLayout +import android.widget.TextView + import androidx.appcompat.app.AlertDialog +import androidx.core.view.isVisible import androidx.fragment.app.DialogFragment import androidx.preference.PreferenceManager + import com.stoutner.privacybrowser.R +import com.stoutner.privacybrowser.helpers.UrlHelper -// Declare the class constants. -private const val SAVE_TYPE = "save_type" +import kotlinx.coroutines.CoroutineScope +import kotlinx.coroutines.Dispatchers +import kotlinx.coroutines.launch +import kotlinx.coroutines.withContext -class SaveDialog : DialogFragment() { - // Declare the class variables. - private lateinit var saveListener: SaveListener - private lateinit var fileName: String - - // The public interface is used to send information back to the parent activity. - interface SaveListener { - fun onSave(saveType: Int, dialogFragment: DialogFragment) - } - - override fun onAttach(context: Context) { - // Run the default commands. - super.onAttach(context) - - // Get a handle for the save listener from the launching context. - saveListener = context as SaveListener - } +// Define the private class constants. +private const val URL_STRING = "A" +private const val FILE_SIZE_STRING = "B" +private const val FILE_NAME_STRING = "C" +private const val USER_AGENT_STRING = "D" +private const val COOKIES_ENABLED = "E" +class SaveDialog : DialogFragment() { companion object { - // Declare the companion object constants. These can be moved to class constants once all of the code has transitioned to Kotlin. - const val SAVE_LOGCAT = 0 - const val SAVE_ABOUT_VERSION_TEXT = 1 - const val SAVE_ABOUT_VERSION_IMAGE = 2 - - // `@JvmStatic` will no longer be required once all the code has transitioned to Kotlin. - @JvmStatic - fun save(saveType: Int): SaveDialog { + fun saveUrl(urlString: String, fileNameString: String, fileSizeString: String, userAgentString: String, cookiesEnabled: Boolean): SaveDialog { // Create an arguments bundle. val argumentsBundle = Bundle() // Store the arguments in the bundle. - argumentsBundle.putInt(SAVE_TYPE, saveType) + argumentsBundle.putString(URL_STRING, urlString) + argumentsBundle.putString(FILE_NAME_STRING, fileNameString) + argumentsBundle.putString(FILE_SIZE_STRING, fileSizeString) + argumentsBundle.putString(USER_AGENT_STRING, userAgentString) + argumentsBundle.putBoolean(COOKIES_ENABLED, cookiesEnabled) - // Create a new instance of the save dialog. + // Create a new instance of the save webpage dialog. val saveDialog = SaveDialog() - // Add the arguments bundle to the dialog. + // Add the arguments bundle to the new dialog. saveDialog.arguments = argumentsBundle // Return the new dialog. @@ -83,78 +76,77 @@ class SaveDialog : DialogFragment() { } } - // `@SuppressLint("InflateParams")` removes the warning about using null as the parent view group when inflating the alert dialog. - @SuppressLint("InflateParams") + // Declare the class variables. + private lateinit var saveListener: SaveListener + + // The public interface is used to send information back to the parent activity. + interface SaveListener { + // Save with Android's download manager. + fun saveWithAndroidDownloadManager(dialogFragment: DialogFragment) + + // Save with Privacy Browser. + fun saveWithPrivacyBrowser(originalUrlString: String, fileNameString: String, dialogFragment: DialogFragment) + } + + override fun onAttach(context: Context) { + // Run the default commands. + super.onAttach(context) + + // Get a handle for the save webpage listener from the launching context. + saveListener = context as SaveListener + } + override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { - // Get the arguments from the bundle. - val saveType = requireArguments().getInt(SAVE_TYPE) + // Get the arguments + val arguments = requireArguments() - // Use an alert dialog builder to create the alert dialog. - val dialogBuilder = AlertDialog.Builder(requireContext(), R.style.PrivacyBrowserAlertDialog) + // Get the arguments from the bundle. + val originalUrlString = arguments.getString(URL_STRING)!! + var fileNameString = arguments.getString(FILE_NAME_STRING)!! + val fileSizeString = arguments.getString(FILE_SIZE_STRING)!! + val userAgentString = arguments.getString(USER_AGENT_STRING)!! + val cookiesEnabled = arguments.getBoolean(COOKIES_ENABLED) - // Get the current theme status. - val currentThemeStatus = resources.configuration.uiMode and Configuration.UI_MODE_NIGHT_MASK + // Get the download provider entry values string array. + val downloadProviderEntryValuesStringArray = resources.getStringArray(R.array.download_provider_entry_values) - // Set the title and the icon according to the save type. - when (saveType) { - SAVE_LOGCAT -> { - // Set the title. - dialogBuilder.setTitle(R.string.save_logcat) + // Get a handle for the shared preferences. + val sharedPreferences = PreferenceManager.getDefaultSharedPreferences(requireContext()) - // Set the icon according to the theme. - if (currentThemeStatus == Configuration.UI_MODE_NIGHT_NO) { - dialogBuilder.setIcon(R.drawable.save_dialog_day) - } else { - dialogBuilder.setIcon(R.drawable.save_dialog_night) - } - } + // Get the preference. + val allowScreenshots = sharedPreferences.getBoolean(getString(R.string.allow_screenshots_key), false) + val downloadProvider = sharedPreferences.getString(getString(R.string.download_provider_key), getString(R.string.download_provider_default_value))!! - SAVE_ABOUT_VERSION_TEXT -> { - // Set the title. - dialogBuilder.setTitle(R.string.save_text) + // Determine the download provider. + val privacyBrowserDownloadProvider = downloadProvider == downloadProviderEntryValuesStringArray[0] - // Set the icon according to the theme. - if (currentThemeStatus == Configuration.UI_MODE_NIGHT_NO) { - dialogBuilder.setIcon(R.drawable.save_text_blue_day) - } else { - dialogBuilder.setIcon(R.drawable.save_text_blue_night) - } - } + // Use an alert dialog builder to create the alert dialog. + val dialogBuilder = AlertDialog.Builder(requireContext(), R.style.PrivacyBrowserAlertDialog) - SAVE_ABOUT_VERSION_IMAGE -> { - // Set the title. - dialogBuilder.setTitle(R.string.save_image) + // Set the title. + dialogBuilder.setTitle(R.string.save_url) - // Set the icon according to the theme. - if (currentThemeStatus == Configuration.UI_MODE_NIGHT_NO) { - dialogBuilder.setIcon(R.drawable.images_enabled_day) - } else { - dialogBuilder.setIcon(R.drawable.images_enabled_night) - } - } - } + // Set the icon. + dialogBuilder.setIcon(R.drawable.download) - // Set the view. The parent view is null because it will be assigned by the alert dialog. - dialogBuilder.setView(requireActivity().layoutInflater.inflate(R.layout.save_dialog, null)) + // Set the view. + dialogBuilder.setView(R.layout.save_dialog) // Set the cancel button listener. Using `null` as the listener closes the dialog without doing anything else. dialogBuilder.setNegativeButton(R.string.cancel, null) // Set the save button listener. - dialogBuilder.setPositiveButton(R.string.save) { _: DialogInterface?, _: Int -> - // Return the dialog fragment to the parent activity. - saveListener.onSave(saveType, this) + dialogBuilder.setPositiveButton(R.string.save) { _: DialogInterface, _: Int -> + // Save the URL with the selected download provider. + if (privacyBrowserDownloadProvider) // Download with Privacy Browser. + saveListener.saveWithPrivacyBrowser(originalUrlString, fileNameString, this) + else // Download with Android's download manager. + saveListener.saveWithAndroidDownloadManager(this) } // Create an alert dialog from the builder. val alertDialog = dialogBuilder.create() - // Get a handle for the shared preferences. - val sharedPreferences = PreferenceManager.getDefaultSharedPreferences(context) - - // Get the screenshot preference. - val allowScreenshots = sharedPreferences.getBoolean(getString(R.string.allow_screenshots_key), false) - // Disable screenshots if not allowed. if (!allowScreenshots) { alertDialog.window!!.addFlags(WindowManager.LayoutParams.FLAG_SECURE) @@ -164,58 +156,131 @@ class SaveDialog : DialogFragment() { alertDialog.show() // Get handles for the layout items. - val fileNameEditText = alertDialog.findViewById(R.id.file_name_edittext)!! - val browseButton = alertDialog.findViewById