mirror of
https://codeberg.org/tom79/Fedilab.git
synced 2025-10-20 11:20:16 +03:00
export/import settings
This commit is contained in:
parent
7f28d208a3
commit
90263e96b8
6 changed files with 48 additions and 20 deletions
|
@ -41,8 +41,11 @@ class SettingsActivity : BaseActivity() {
|
||||||
setupActionBarWithNavController(navController, appBarConfiguration)
|
setupActionBarWithNavController(navController, appBarConfiguration)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
override fun onSupportNavigateUp(): Boolean {
|
override fun onSupportNavigateUp(): Boolean {
|
||||||
val navController = findNavController(R.id.fragment_container)
|
val navController = findNavController(R.id.fragment_container)
|
||||||
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
|
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1483,7 +1483,7 @@ public class Helper {
|
||||||
message = message.substring(0, 499) + "…";
|
message = message.substring(0, 499) + "…";
|
||||||
}
|
}
|
||||||
}*/
|
}*/
|
||||||
notificationBuilder.setGroup(account.mastodon_account.acct + "@" + account.instance)
|
notificationBuilder.setGroup(account.mastodon_account != null ? account.mastodon_account.acct : "" + "@" + account.instance)
|
||||||
.setContentIntent(pIntent)
|
.setContentIntent(pIntent)
|
||||||
.setContentText(message);
|
.setContentText(message);
|
||||||
int ledColour = Color.BLUE;
|
int ledColour = Color.BLUE;
|
||||||
|
@ -1558,7 +1558,7 @@ public class Helper {
|
||||||
.setLargeIcon(icon)
|
.setLargeIcon(icon)
|
||||||
.setSmallIcon(R.drawable.ic_notification)
|
.setSmallIcon(R.drawable.ic_notification)
|
||||||
.setStyle(new NotificationCompat.BigTextStyle().bigText(message))
|
.setStyle(new NotificationCompat.BigTextStyle().bigText(message))
|
||||||
.setGroup(account.mastodon_account.acct + "@" + account.instance)
|
.setGroup(account.mastodon_account != null ? account.mastodon_account.acct : "" + "@" + account.instance)
|
||||||
.setGroupSummary(true)
|
.setGroupSummary(true)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ import android.os.Environment;
|
||||||
import androidx.preference.PreferenceManager;
|
import androidx.preference.PreferenceManager;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.ObjectInputStream;
|
import java.io.ObjectInputStream;
|
||||||
|
@ -55,7 +54,7 @@ public class SettingsStorage {
|
||||||
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
|
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
|
||||||
output.writeObject(sharedpreferences.getAll());
|
output.writeObject(sharedpreferences.getAll());
|
||||||
res = true;
|
res = true;
|
||||||
String message = context.getString(R.string.data_export_theme_success);
|
String message = context.getString(R.string.data_export_settings_success);
|
||||||
Intent intentOpen = new Intent();
|
Intent intentOpen = new Intent();
|
||||||
intentOpen.setAction(android.content.Intent.ACTION_VIEW);
|
intentOpen.setAction(android.content.Intent.ACTION_VIEW);
|
||||||
Uri uri = Uri.parse("file://" + fullPath);
|
Uri uri = Uri.parse("file://" + fullPath);
|
||||||
|
@ -80,11 +79,11 @@ public class SettingsStorage {
|
||||||
|
|
||||||
@SuppressLint("ApplySharedPref")
|
@SuppressLint("ApplySharedPref")
|
||||||
@SuppressWarnings({"unchecked", "UnnecessaryUnboxing"})
|
@SuppressWarnings({"unchecked", "UnnecessaryUnboxing"})
|
||||||
public static boolean loadSharedPreferencesFromFile(Context context, File src) {
|
public static boolean loadSharedPreferencesFromFile(Context context, Uri srcUri) {
|
||||||
boolean res = false;
|
boolean res = false;
|
||||||
ObjectInputStream input = null;
|
ObjectInputStream input = null;
|
||||||
try {
|
try {
|
||||||
input = new ObjectInputStream(new FileInputStream(src));
|
input = new ObjectInputStream(context.getContentResolver().openInputStream(srcUri));
|
||||||
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
|
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
|
||||||
SharedPreferences.Editor prefEdit = sharedpreferences.edit();
|
SharedPreferences.Editor prefEdit = sharedpreferences.edit();
|
||||||
prefEdit.clear();
|
prefEdit.clear();
|
||||||
|
|
|
@ -15,6 +15,8 @@ package app.fedilab.android.ui.fragment.settings
|
||||||
* see <http://www.gnu.org/licenses>. */
|
* see <http://www.gnu.org/licenses>. */
|
||||||
|
|
||||||
import android.Manifest
|
import android.Manifest
|
||||||
|
import android.app.Activity
|
||||||
|
import android.content.Intent
|
||||||
import android.content.pm.PackageManager
|
import android.content.pm.PackageManager
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
|
@ -25,17 +27,21 @@ import androidx.preference.PreferenceFragmentCompat
|
||||||
import app.fedilab.android.BaseMainActivity.currentAccount
|
import app.fedilab.android.BaseMainActivity.currentAccount
|
||||||
import app.fedilab.android.R
|
import app.fedilab.android.R
|
||||||
import app.fedilab.android.helper.SettingsStorage
|
import app.fedilab.android.helper.SettingsStorage
|
||||||
|
import es.dmoral.toasty.Toasty
|
||||||
|
|
||||||
|
|
||||||
class FragmentSettingsCategories : PreferenceFragmentCompat() {
|
class FragmentSettingsCategories : PreferenceFragmentCompat() {
|
||||||
|
|
||||||
private val REQUEST_CODE = 5412
|
private val REQUEST_CODE = 5412
|
||||||
|
private val PICKUP_FILE = 452
|
||||||
|
|
||||||
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
||||||
setPreferencesFromResource(R.xml.pref_categories, rootKey)
|
setPreferencesFromResource(R.xml.pref_categories, rootKey)
|
||||||
|
|
||||||
findPreference<Preference>(getString(R.string.pref_category_key_account))?.setOnPreferenceClickListener {
|
findPreference<Preference>(getString(R.string.pref_category_key_account))?.setOnPreferenceClickListener {
|
||||||
|
|
||||||
findNavController().navigate(FragmentSettingsCategoriesDirections.categoriesToAccount())
|
findNavController().navigate(FragmentSettingsCategoriesDirections.categoriesToAccount())
|
||||||
|
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,23 +74,31 @@ class FragmentSettingsCategories : PreferenceFragmentCompat() {
|
||||||
findNavController().navigate(FragmentSettingsCategoriesDirections.categoriesToTheming())
|
findNavController().navigate(FragmentSettingsCategoriesDirections.categoriesToTheming())
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
@Suppress("DEPRECATION") val permissionLauncher = registerForActivityResult(
|
||||||
findPreference<Preference>(getString(R.string.pref_export_settings))?.setOnPreferenceClickListener {
|
ActivityResultContracts.RequestPermission()
|
||||||
val permissionLauncher = registerForActivityResult(
|
) { isGranted ->
|
||||||
ActivityResultContracts.RequestPermission()
|
if (isGranted) {
|
||||||
) { isGranted ->
|
SettingsStorage.saveSharedPreferencesToFile(context)
|
||||||
if (isGranted) {
|
} else {
|
||||||
SettingsStorage.saveSharedPreferencesToFile(context)
|
requestPermissions(arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE), REQUEST_CODE)
|
||||||
} else {
|
|
||||||
requestPermissions(arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE), REQUEST_CODE)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
findPreference<Preference>(getString(R.string.pref_export_settings))?.setOnPreferenceClickListener {
|
||||||
permissionLauncher.launch(Manifest.permission.WRITE_EXTERNAL_STORAGE)
|
permissionLauncher.launch(Manifest.permission.WRITE_EXTERNAL_STORAGE)
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
findPreference<Preference>(getString(R.string.pref_import_settings))?.setOnPreferenceClickListener {
|
findPreference<Preference>(getString(R.string.pref_import_settings))?.setOnPreferenceClickListener {
|
||||||
|
val openFileIntent = Intent(Intent.ACTION_OPEN_DOCUMENT)
|
||||||
|
openFileIntent.addCategory(Intent.CATEGORY_OPENABLE)
|
||||||
|
openFileIntent.type = "text/plain"
|
||||||
|
val mimeTypes = arrayOf("text/plain")
|
||||||
|
openFileIntent.putExtra(Intent.EXTRA_MIME_TYPES, mimeTypes)
|
||||||
|
|
||||||
|
startActivityForResult(
|
||||||
|
Intent.createChooser(
|
||||||
|
openFileIntent,
|
||||||
|
getString(R.string.load_settings)), PICKUP_FILE)
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,6 +112,18 @@ class FragmentSettingsCategories : PreferenceFragmentCompat() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Deprecated("Deprecated in Java")
|
||||||
|
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
||||||
|
if (resultCode == Activity.RESULT_OK && requestCode == PICKUP_FILE) {
|
||||||
|
val result = SettingsStorage.loadSharedPreferencesFromFile(context, data?.data)
|
||||||
|
if (result) {
|
||||||
|
activity?.let { Toasty.success(it, getString(R.string.data_import_settings_success), Toasty.LENGTH_LONG).show() }
|
||||||
|
} else {
|
||||||
|
activity?.let { Toasty.error(it, getString(R.string.toast_error), Toasty.LENGTH_LONG).show() }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Deprecated("Deprecated in Java")
|
@Deprecated("Deprecated in Java")
|
||||||
override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<out String>, grantResults: IntArray) {
|
override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<out String>, grantResults: IntArray) {
|
||||||
when (requestCode) {
|
when (requestCode) {
|
||||||
|
|
|
@ -12,10 +12,7 @@
|
||||||
<action
|
<action
|
||||||
android:id="@+id/categories_to_account"
|
android:id="@+id/categories_to_account"
|
||||||
app:destination="@id/EditProfileActivity"
|
app:destination="@id/EditProfileActivity"
|
||||||
app:enterAnim="@anim/enter"
|
/>
|
||||||
app:exitAnim="@anim/exit"
|
|
||||||
app:popEnterAnim="@anim/pop_enter"
|
|
||||||
app:popExitAnim="@anim/pop_exit" />
|
|
||||||
|
|
||||||
<action
|
<action
|
||||||
android:id="@+id/categories_to_timelines"
|
android:id="@+id/categories_to_timelines"
|
||||||
|
|
|
@ -618,6 +618,8 @@
|
||||||
<string name="data_export_theme">The theme was exported</string>
|
<string name="data_export_theme">The theme was exported</string>
|
||||||
<string name="data_export_settings">The settings were exported</string>
|
<string name="data_export_settings">The settings were exported</string>
|
||||||
<string name="data_export_theme_success">The theme has been successfully exported in CSV</string>
|
<string name="data_export_theme_success">The theme has been successfully exported in CSV</string>
|
||||||
|
<string name="data_export_settings_success">Settings have been successfully exported</string>
|
||||||
|
<string name="data_import_settings_success">Settings have been successfully imported</string>
|
||||||
<string name="import_theme">Import a theme</string>
|
<string name="import_theme">Import a theme</string>
|
||||||
<string name="import_theme_title">Tap here to import a theme from a previous export</string>
|
<string name="import_theme_title">Tap here to import a theme from a previous export</string>
|
||||||
<string name="export_theme">Export the theme</string>
|
<string name="export_theme">Export the theme</string>
|
||||||
|
@ -1435,4 +1437,5 @@
|
||||||
<string name="export_settings">Export settings</string>
|
<string name="export_settings">Export settings</string>
|
||||||
<string name="import_settings">Import settings</string>
|
<string name="import_settings">Import settings</string>
|
||||||
<string name="permission_missing">Permission not granted!</string>
|
<string name="permission_missing">Permission not granted!</string>
|
||||||
|
<string name="load_settings">Load exported settings</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Reference in a new issue