remember last used vcard export path

This commit is contained in:
tibbi
2020-03-16 22:29:11 +01:00
parent 1b7a860cdf
commit 39b432bf4b
4 changed files with 29 additions and 15 deletions

View File

@@ -520,8 +520,8 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
} }
private fun exportContacts() { private fun exportContacts() {
FilePickerDialog(this, pickFile = false, showFAB = true) { ExportContactsDialog(this, config.lastExportPath) { file, ignoredContactSources ->
ExportContactsDialog(this, it) { file, ignoredContactSources -> config.lastExportPath = file.absolutePath.getParentPath()
ContactsHelper(this).getContacts(true, ignoredContactSources) { contacts -> ContactsHelper(this).getContacts(true, ignoredContactSources) { contacts ->
if (contacts.isEmpty()) { if (contacts.isEmpty()) {
toast(R.string.no_entries_for_exporting) toast(R.string.no_entries_for_exporting)
@@ -537,7 +537,6 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
} }
} }
} }
}
private fun launchAbout() { private fun launchAbout() {
val licenses = LICENSE_JODA or LICENSE_GLIDE or LICENSE_GSON or LICENSE_INDICATOR_FAST_SCROLL val licenses = LICENSE_JODA or LICENSE_GLIDE or LICENSE_GSON or LICENSE_INDICATOR_FAST_SCROLL

View File

@@ -2,6 +2,7 @@ package com.simplemobiletools.contacts.pro.dialogs
import android.view.ViewGroup import android.view.ViewGroup
import androidx.appcompat.app.AlertDialog import androidx.appcompat.app.AlertDialog
import com.simplemobiletools.commons.dialogs.FilePickerDialog
import com.simplemobiletools.commons.extensions.* import com.simplemobiletools.commons.extensions.*
import com.simplemobiletools.commons.helpers.ensureBackgroundThread import com.simplemobiletools.commons.helpers.ensureBackgroundThread
import com.simplemobiletools.contacts.pro.R import com.simplemobiletools.contacts.pro.R
@@ -17,12 +18,21 @@ import java.util.*
class ExportContactsDialog(val activity: SimpleActivity, val path: String, private val callback: (file: File, ignoredContactSources: HashSet<String>) -> Unit) { class ExportContactsDialog(val activity: SimpleActivity, val path: String, private val callback: (file: File, ignoredContactSources: HashSet<String>) -> Unit) {
private var contactSources = ArrayList<ContactSource>() private var contactSources = ArrayList<ContactSource>()
private var ignoreClicks = false private var ignoreClicks = false
private var realPath = if (path.isEmpty()) activity.internalStoragePath else path
init { init {
val view = (activity.layoutInflater.inflate(R.layout.dialog_export_contacts, null) as ViewGroup).apply { val view = (activity.layoutInflater.inflate(R.layout.dialog_export_contacts, null) as ViewGroup).apply {
export_contacts_folder.text = activity.humanizePath(path) export_contacts_folder.text = activity.humanizePath(realPath)
export_contacts_filename.setText("contacts_${activity.getCurrentFormattedDateTime()}") export_contacts_filename.setText("contacts_${activity.getCurrentFormattedDateTime()}")
export_contacts_folder.setOnClickListener {
activity.hideKeyboard(export_contacts_filename)
FilePickerDialog(activity, realPath, false, showFAB = true) {
export_contacts_folder.text = activity.humanizePath(it)
realPath = it
}
}
ContactsHelper(activity).getContactSources { ContactsHelper(activity).getContactSources {
it.mapTo(contactSources) { it.copy() } it.mapTo(contactSources) { it.copy() }
activity.runOnUiThread { activity.runOnUiThread {
@@ -45,7 +55,7 @@ class ExportContactsDialog(val activity: SimpleActivity, val path: String, priva
when { when {
filename.isEmpty() -> activity.toast(R.string.empty_name) filename.isEmpty() -> activity.toast(R.string.empty_name)
filename.isAValidFilename() -> { filename.isAValidFilename() -> {
val file = File(path, "$filename.vcf") val file = File(realPath, "$filename.vcf")
if (file.exists()) { if (file.exists()) {
activity.toast(R.string.name_taken) activity.toast(R.string.name_taken)
return@setOnClickListener return@setOnClickListener

View File

@@ -60,6 +60,10 @@ class Config(context: Context) : BaseConfig(context) {
get() = prefs.getBoolean(SHOW_DIALPAD_LETTERS, true) get() = prefs.getBoolean(SHOW_DIALPAD_LETTERS, true)
set(showDialpadLetters) = prefs.edit().putBoolean(SHOW_DIALPAD_LETTERS, showDialpadLetters).apply() set(showDialpadLetters) = prefs.edit().putBoolean(SHOW_DIALPAD_LETTERS, showDialpadLetters).apply()
var lastExportPath: String
get() = prefs.getString(LAST_EXPORT_PATH, "")!!
set(lastExportPath) = prefs.edit().putString(LAST_EXPORT_PATH, lastExportPath).apply()
var speedDial: String var speedDial: String
get() = prefs.getString(SPEED_DIAL, "")!! get() = prefs.getString(SPEED_DIAL, "")!!
set(speedDial) = prefs.edit().putString(SPEED_DIAL, speedDial).apply() set(speedDial) = prefs.edit().putString(SPEED_DIAL, speedDial).apply()

View File

@@ -22,6 +22,7 @@ const val SHOW_CALL_CONFIRMATION = "show_call_confirmation"
const val SHOW_DIALPAD_BUTTON = "show_dialpad_button" const val SHOW_DIALPAD_BUTTON = "show_dialpad_button"
const val SHOW_DIALPAD_LETTERS = "show_dialpad_letters" const val SHOW_DIALPAD_LETTERS = "show_dialpad_letters"
const val SPEED_DIAL = "speed_dial" const val SPEED_DIAL = "speed_dial"
const val LAST_EXPORT_PATH = "last_export_path"
const val CONTACT_ID = "contact_id" const val CONTACT_ID = "contact_id"
const val SMT_PRIVATE = "smt_private" // used at the contact source of local contacts hidden from other apps const val SMT_PRIVATE = "smt_private" // used at the contact source of local contacts hidden from other apps