mirror of
https://github.com/SimpleMobileTools/Simple-Notes.git
synced 2025-06-05 17:00:23 +02:00
Merge pull request #456 from KryptKode/feat/checklist-sort
Feat/checklist sort
This commit is contained in:
@ -0,0 +1,67 @@
|
||||
package com.simplemobiletools.notes.pro.dialogs
|
||||
|
||||
import androidx.appcompat.app.AlertDialog
|
||||
import com.simplemobiletools.commons.extensions.setupDialogStuff
|
||||
import com.simplemobiletools.commons.helpers.SORT_BY_DATE_CREATED
|
||||
import com.simplemobiletools.commons.helpers.SORT_BY_TITLE
|
||||
import com.simplemobiletools.commons.helpers.SORT_DESCENDING
|
||||
import com.simplemobiletools.notes.pro.R
|
||||
import com.simplemobiletools.notes.pro.activities.SimpleActivity
|
||||
import com.simplemobiletools.notes.pro.extensions.config
|
||||
import kotlinx.android.synthetic.main.dialog_sort_checklist.view.*
|
||||
|
||||
class SortChecklistDialog(private val activity: SimpleActivity, private val callback: () -> Unit) {
|
||||
private val view = activity.layoutInflater.inflate(R.layout.dialog_sort_checklist, null)
|
||||
private val config = activity.config
|
||||
private var currSorting = config.sorting
|
||||
|
||||
init {
|
||||
setupSortRadio()
|
||||
setupOrderRadio()
|
||||
AlertDialog.Builder(activity)
|
||||
.setPositiveButton(R.string.ok) { _, _ -> dialogConfirmed() }
|
||||
.setNegativeButton(R.string.cancel, null)
|
||||
.create().apply {
|
||||
activity.setupDialogStuff(view, this, R.string.sort_by)
|
||||
}
|
||||
}
|
||||
|
||||
private fun setupSortRadio() {
|
||||
val fieldRadio = view.sorting_dialog_radio_sorting
|
||||
var fieldBtn = fieldRadio.sorting_dialog_radio_title
|
||||
|
||||
if (currSorting and SORT_BY_DATE_CREATED != 0) {
|
||||
fieldBtn = fieldRadio.sorting_dialog_radio_date_created
|
||||
}
|
||||
|
||||
fieldBtn.isChecked = true
|
||||
}
|
||||
|
||||
private fun setupOrderRadio() {
|
||||
val orderRadio = view.sorting_dialog_radio_order
|
||||
var orderBtn = orderRadio.sorting_dialog_radio_ascending
|
||||
|
||||
if (currSorting and SORT_DESCENDING != 0) {
|
||||
orderBtn = orderRadio.sorting_dialog_radio_descending
|
||||
}
|
||||
|
||||
orderBtn.isChecked = true
|
||||
}
|
||||
|
||||
private fun dialogConfirmed() {
|
||||
val sortingRadio = view.sorting_dialog_radio_sorting
|
||||
var sorting = when (sortingRadio.checkedRadioButtonId) {
|
||||
R.id.sorting_dialog_radio_date_created -> SORT_BY_DATE_CREATED
|
||||
else -> SORT_BY_TITLE
|
||||
}
|
||||
|
||||
if (view.sorting_dialog_radio_order.checkedRadioButtonId == R.id.sorting_dialog_radio_descending) {
|
||||
sorting = sorting or SORT_DESCENDING
|
||||
}
|
||||
|
||||
if (currSorting != sorting) {
|
||||
config.sorting = sorting
|
||||
callback()
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user