From 8c77eae5c3654fa1afe494b91c3149393f598374 Mon Sep 17 00:00:00 2001 From: darthpaul Date: Wed, 29 Sep 2021 17:01:45 +0100 Subject: [PATCH] Dynamically add checklist items --- .../pro/dialogs/NewChecklistItemDialog.kt | 75 ++++++++++++++----- .../res/layout/dialog_new_checklist_item.xml | 50 ++++++------- .../main/res/layout/item_add_checklist.xml | 32 ++++++++ app/src/main/res/values/dimens.xml | 1 + 4 files changed, 111 insertions(+), 47 deletions(-) create mode 100644 app/src/main/res/layout/item_add_checklist.xml diff --git a/app/src/main/kotlin/com/simplemobiletools/notes/pro/dialogs/NewChecklistItemDialog.kt b/app/src/main/kotlin/com/simplemobiletools/notes/pro/dialogs/NewChecklistItemDialog.kt index da1183e0..93e1c739 100644 --- a/app/src/main/kotlin/com/simplemobiletools/notes/pro/dialogs/NewChecklistItemDialog.kt +++ b/app/src/main/kotlin/com/simplemobiletools/notes/pro/dialogs/NewChecklistItemDialog.kt @@ -2,38 +2,73 @@ package com.simplemobiletools.notes.pro.dialogs import android.app.Activity import android.content.DialogInterface.BUTTON_POSITIVE +import android.view.KeyEvent +import android.view.View +import android.view.ViewGroup +import android.view.inputmethod.EditorInfo +import android.widget.EditText import androidx.appcompat.app.AlertDialog import com.simplemobiletools.commons.extensions.setupDialogStuff import com.simplemobiletools.commons.extensions.showKeyboard import com.simplemobiletools.commons.extensions.toast -import com.simplemobiletools.commons.extensions.value import com.simplemobiletools.notes.pro.R -import kotlinx.android.synthetic.main.dialog_new_checklist_item.view.* +import kotlinx.android.synthetic.main.dialog_new_checklist_item.view.add_item +import kotlinx.android.synthetic.main.dialog_new_checklist_item.view.checklist_holder +import kotlinx.android.synthetic.main.dialog_new_checklist_item.view.dialog_holder +import kotlinx.android.synthetic.main.item_add_checklist.view.delete_item +import kotlinx.android.synthetic.main.item_add_checklist.view.title_edit_text class NewChecklistItemDialog(val activity: Activity, callback: (titles: ArrayList) -> Unit) { - init { - val view = activity.layoutInflater.inflate(R.layout.dialog_new_checklist_item, null) + private val titles = mutableListOf() + private val view: ViewGroup = activity.layoutInflater.inflate(R.layout.dialog_new_checklist_item, null) as ViewGroup + init { + addNewEditText() + view.add_item.setOnClickListener { + addNewEditText() + } AlertDialog.Builder(activity) - .setPositiveButton(R.string.ok, null) - .setNegativeButton(R.string.cancel, null) - .create().apply { - activity.setupDialogStuff(view, this, R.string.add_new_checklist_items) { - showKeyboard(view.checklist_item_title_1) - getButton(BUTTON_POSITIVE).setOnClickListener { - val title1 = view.checklist_item_title_1.value - val title2 = view.checklist_item_title_2.value - val title3 = view.checklist_item_title_3.value - when { - title1.isEmpty() && title2.isEmpty() && title3.isEmpty() -> activity.toast(R.string.empty_name) - else -> { - val titles = arrayListOf(title1, title2, title3).filter { it.isNotEmpty() }.toMutableList() as ArrayList - callback(titles) - dismiss() - } + .setPositiveButton(R.string.ok, null) + .setNegativeButton(R.string.cancel, null) + .create().apply { + activity.setupDialogStuff(view, this, R.string.add_new_checklist_items, cancelOnTouchOutside = false) { + activity.showKeyboard(titles.first()) + getButton(BUTTON_POSITIVE).setOnClickListener { + when { + titles.all { it.text.isEmpty() } -> activity.toast(R.string.empty_name) + else -> { + val titles = titles.map { it.text.toString() }.filter { it.isNotEmpty() }.toMutableList() as ArrayList + callback(titles) + dismiss() } } } } + } + } + + private fun addNewEditText() { + activity.layoutInflater.inflate(R.layout.item_add_checklist, null).apply { + title_edit_text.setOnEditorActionListener { _, actionId, _ -> + if (actionId == EditorInfo.IME_ACTION_NEXT || actionId == EditorInfo.IME_ACTION_DONE || actionId == KeyEvent.KEYCODE_ENTER) { + addNewEditText() + true + } else { + false + } + } + + val currentIndex = titles.size + delete_item.setOnClickListener { + view.checklist_holder.removeViewAt(currentIndex) + titles.removeAt(currentIndex) + } + titles.add(title_edit_text) + view.checklist_holder.addView(this) + view.dialog_holder.post { + view.dialog_holder.fullScroll(View.FOCUS_DOWN) + activity.showKeyboard(title_edit_text) + } + } } } diff --git a/app/src/main/res/layout/dialog_new_checklist_item.xml b/app/src/main/res/layout/dialog_new_checklist_item.xml index e8be88db..0eb1723a 100644 --- a/app/src/main/res/layout/dialog_new_checklist_item.xml +++ b/app/src/main/res/layout/dialog_new_checklist_item.xml @@ -1,41 +1,37 @@ - - + android:orientation="vertical"> - + - + - + + + diff --git a/app/src/main/res/layout/item_add_checklist.xml b/app/src/main/res/layout/item_add_checklist.xml new file mode 100644 index 00000000..83d60bdf --- /dev/null +++ b/app/src/main/res/layout/item_add_checklist.xml @@ -0,0 +1,32 @@ + + + + + + + + diff --git a/app/src/main/res/values/dimens.xml b/app/src/main/res/values/dimens.xml index 1a0e9740..b671d69a 100644 --- a/app/src/main/res/values/dimens.xml +++ b/app/src/main/res/values/dimens.xml @@ -1,3 +1,4 @@ 56dp + 36dp