mirror of
https://github.com/SimpleMobileTools/Simple-Notes.git
synced 2025-06-05 17:00:23 +02:00
Implement checklist sort
This commit is contained in:
@ -163,6 +163,7 @@ class MainActivity : SimpleActivity() {
|
||||
findItem(R.id.export_all_notes).isVisible = multipleNotesExist && hasPermission(PERMISSION_WRITE_STORAGE)
|
||||
findItem(R.id.open_search).isVisible = !isCurrentItemChecklist()
|
||||
findItem(R.id.remove_done_items).isVisible = isCurrentItemChecklist()
|
||||
findItem(R.id.sort_checklist).isVisible = isCurrentItemChecklist()
|
||||
findItem(R.id.import_folder).isVisible = hasPermission(PERMISSION_READ_STORAGE)
|
||||
findItem(R.id.lock_note).isVisible = mNotes.isNotEmpty() && !mCurrentNote.isLocked()
|
||||
findItem(R.id.unlock_note).isVisible = mNotes.isNotEmpty() && mCurrentNote.isLocked()
|
||||
@ -201,6 +202,7 @@ class MainActivity : SimpleActivity() {
|
||||
R.id.settings -> startActivity(Intent(applicationContext, SettingsActivity::class.java))
|
||||
R.id.about -> launchAbout()
|
||||
R.id.remove_done_items -> fragment?.handleUnlocking { removeDoneItems() }
|
||||
R.id.sort_checklist -> fragment?.handleUnlocking { displaySortChecklistDialog() }
|
||||
else -> return super.onOptionsItemSelected(item)
|
||||
}
|
||||
return true
|
||||
@ -1169,4 +1171,10 @@ class MainActivity : SimpleActivity() {
|
||||
private fun removeDoneItems() {
|
||||
getPagerAdapter().removeDoneCheckListItems(view_pager.currentItem)
|
||||
}
|
||||
|
||||
private fun displaySortChecklistDialog() {
|
||||
SortChecklistDialog(this) {
|
||||
getPagerAdapter().sortChecklistItems(view_pager.currentItem, it)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -149,11 +149,11 @@ class WidgetConfigureActivity : SimpleActivity() {
|
||||
val items = Gson().fromJson<ArrayList<ChecklistItem>>(note.value, checklistItemType) ?: ArrayList(1)
|
||||
items.apply {
|
||||
if (isEmpty()) {
|
||||
add(ChecklistItem(0, "Milk", true))
|
||||
add(ChecklistItem(1, "Butter", true))
|
||||
add(ChecklistItem(2, "Salt", false))
|
||||
add(ChecklistItem(3, "Water", false))
|
||||
add(ChecklistItem(4, "Meat", true))
|
||||
add(ChecklistItem(0, System.currentTimeMillis(),"Milk", true))
|
||||
add(ChecklistItem(1, System.currentTimeMillis(),"Butter", true))
|
||||
add(ChecklistItem(2, System.currentTimeMillis(),"Salt", false))
|
||||
add(ChecklistItem(3, System.currentTimeMillis(),"Water", false))
|
||||
add(ChecklistItem(4, System.currentTimeMillis(),"Meat", true))
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -11,6 +11,7 @@ import com.simplemobiletools.notes.pro.fragments.NoteFragment
|
||||
import com.simplemobiletools.notes.pro.fragments.TextFragment
|
||||
import com.simplemobiletools.notes.pro.helpers.NOTE_ID
|
||||
import com.simplemobiletools.notes.pro.helpers.NoteType
|
||||
import com.simplemobiletools.notes.pro.models.ChecklistSort
|
||||
import com.simplemobiletools.notes.pro.models.Note
|
||||
|
||||
class NotesPagerAdapter(fm: FragmentManager, val notes: List<Note>, val activity: Activity) : FragmentStatePagerAdapter(fm) {
|
||||
@ -95,4 +96,8 @@ class NotesPagerAdapter(fm: FragmentManager, val notes: List<Note>, val activity
|
||||
fun removeDoneCheckListItems(position: Int) {
|
||||
(fragments[position] as? ChecklistFragment)?.removeDoneItems()
|
||||
}
|
||||
|
||||
fun sortChecklistItems(position: Int, sort:ChecklistSort){
|
||||
(fragments[position] as? ChecklistFragment)?.sortChecklist(sort)
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,53 @@
|
||||
package com.simplemobiletools.notes.pro.dialogs
|
||||
|
||||
import android.content.DialogInterface
|
||||
import android.view.View
|
||||
import android.view.ViewGroup
|
||||
import androidx.appcompat.app.AlertDialog
|
||||
import com.simplemobiletools.commons.extensions.setupDialogStuff
|
||||
import com.simplemobiletools.notes.pro.R
|
||||
import com.simplemobiletools.notes.pro.activities.SimpleActivity
|
||||
import com.simplemobiletools.notes.pro.models.ChecklistSort
|
||||
import com.simplemobiletools.notes.pro.models.ChecklistSortDirection
|
||||
import com.simplemobiletools.notes.pro.models.ChecklistSortField
|
||||
import kotlinx.android.synthetic.main.dialog_sort_checklist.view.separate_items_checkbox
|
||||
import kotlinx.android.synthetic.main.dialog_sort_checklist.view.sort_direction_type
|
||||
import kotlinx.android.synthetic.main.dialog_sort_checklist.view.sort_field_type
|
||||
|
||||
class SortChecklistDialog(private val activity: SimpleActivity, val callback: (ChecklistSort) -> Unit) {
|
||||
init {
|
||||
val view = (activity.layoutInflater.inflate(R.layout.dialog_sort_checklist, null) as ViewGroup)
|
||||
|
||||
AlertDialog.Builder(activity)
|
||||
.setPositiveButton(R.string.ok, null)
|
||||
.setNegativeButton(R.string.cancel, null)
|
||||
.create().apply {
|
||||
activity.setupDialogStuff(view, this, R.string.sort_checklist) {
|
||||
getButton(DialogInterface.BUTTON_POSITIVE).setOnClickListener {
|
||||
callback.invoke(
|
||||
ChecklistSort(
|
||||
field = getSortField(view),
|
||||
direction = getSortDirection(view),
|
||||
separateCheckedFromUnchecked = view.separate_items_checkbox.isChecked
|
||||
)
|
||||
)
|
||||
dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private fun getSortField(view: View): ChecklistSortField {
|
||||
return when (view.sort_field_type.checkedRadioButtonId) {
|
||||
R.id.sort_field_title -> ChecklistSortField.TITLE
|
||||
else -> ChecklistSortField.DATE_CREATED
|
||||
}
|
||||
}
|
||||
|
||||
private fun getSortDirection(view: View): ChecklistSortDirection {
|
||||
return when (view.sort_direction_type.checkedRadioButtonId) {
|
||||
R.id.sort_direction_asc -> ChecklistSortDirection.ASCENDING
|
||||
else -> ChecklistSortDirection.DESCENDING
|
||||
}
|
||||
}
|
||||
}
|
@ -1,6 +1,7 @@
|
||||
package com.simplemobiletools.notes.pro.fragments
|
||||
|
||||
import android.os.Bundle
|
||||
import android.util.Log
|
||||
import android.view.LayoutInflater
|
||||
import android.view.View
|
||||
import android.view.ViewGroup
|
||||
@ -18,8 +19,7 @@ import com.simplemobiletools.notes.pro.extensions.updateWidgets
|
||||
import com.simplemobiletools.notes.pro.helpers.NOTE_ID
|
||||
import com.simplemobiletools.notes.pro.helpers.NotesHelper
|
||||
import com.simplemobiletools.notes.pro.interfaces.ChecklistItemsListener
|
||||
import com.simplemobiletools.notes.pro.models.ChecklistItem
|
||||
import com.simplemobiletools.notes.pro.models.Note
|
||||
import com.simplemobiletools.notes.pro.models.*
|
||||
import kotlinx.android.synthetic.main.fragment_checklist.view.*
|
||||
|
||||
class ChecklistFragment : NoteFragment(), ChecklistItemsListener {
|
||||
@ -140,7 +140,7 @@ class ChecklistFragment : NoteFragment(), ChecklistItemsListener {
|
||||
|
||||
titles.forEach { title ->
|
||||
title.split("\n").map { it.trim() }.filter { it.isNotBlank() }.forEach { row ->
|
||||
newItems.add(ChecklistItem(currentMaxId + 1, row, false))
|
||||
newItems.add(ChecklistItem(currentMaxId + 1, System.currentTimeMillis(), row, false))
|
||||
currentMaxId++
|
||||
}
|
||||
}
|
||||
@ -215,4 +215,11 @@ class ChecklistFragment : NoteFragment(), ChecklistItemsListener {
|
||||
override fun refreshItems() {
|
||||
setupAdapter()
|
||||
}
|
||||
|
||||
private val TAG = "ChecklistFragment"
|
||||
fun sortChecklist(sort: ChecklistSort) {
|
||||
Log.d(TAG, "sortChecklist: $sort")
|
||||
items = items.sortedWith(sort.getSortComparator()).toMutableList() as ArrayList<ChecklistItem>
|
||||
setupAdapter()
|
||||
}
|
||||
}
|
||||
|
@ -1,3 +1,3 @@
|
||||
package com.simplemobiletools.notes.pro.models
|
||||
|
||||
data class ChecklistItem(val id: Int, var title: String, var isDone: Boolean)
|
||||
data class ChecklistItem(val id: Int, val dateCreated: Long = 0L, var title: String, var isDone: Boolean)
|
||||
|
@ -0,0 +1,26 @@
|
||||
package com.simplemobiletools.notes.pro.models
|
||||
|
||||
data class ChecklistSort(
|
||||
val field: ChecklistSortField,
|
||||
val direction: ChecklistSortDirection,
|
||||
val separateCheckedFromUnchecked: Boolean,
|
||||
) {
|
||||
|
||||
companion object {
|
||||
val DEFAULT = ChecklistSort(ChecklistSortField.TITLE, ChecklistSortDirection.ASCENDING, false)
|
||||
}
|
||||
|
||||
fun getSortComparator(): Comparator<ChecklistItem> {
|
||||
return when (field) {
|
||||
ChecklistSortField.TITLE -> compareWithSortDirection { it.title }
|
||||
ChecklistSortField.DATE_CREATED -> compareWithSortDirection { it.dateCreated }
|
||||
}
|
||||
}
|
||||
|
||||
private fun compareWithSortDirection(compareFunc: (ChecklistItem) -> Comparable<*>): Comparator<ChecklistItem> {
|
||||
return when (direction) {
|
||||
ChecklistSortDirection.ASCENDING -> if(separateCheckedFromUnchecked) compareBy<ChecklistItem> { it.isDone }.thenBy(compareFunc) else compareBy(compareFunc)
|
||||
ChecklistSortDirection.DESCENDING -> if(separateCheckedFromUnchecked) compareByDescending<ChecklistItem> { it.isDone }.thenByDescending(compareFunc) else compareByDescending(compareFunc)
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,6 @@
|
||||
package com.simplemobiletools.notes.pro.models
|
||||
|
||||
enum class ChecklistSortDirection {
|
||||
ASCENDING,
|
||||
DESCENDING,
|
||||
}
|
@ -0,0 +1,6 @@
|
||||
package com.simplemobiletools.notes.pro.models
|
||||
|
||||
enum class ChecklistSortField {
|
||||
TITLE,
|
||||
DATE_CREATED,
|
||||
}
|
Reference in New Issue
Block a user