From e28a80d6b671578d18254cdf1c6fe3bd8eddd09a Mon Sep 17 00:00:00 2001 From: Philipp Heckel Date: Wed, 27 Oct 2021 22:32:30 -0400 Subject: [PATCH] Validate input when checkbox is pressed --- .../main/java/io/heckel/ntfy/AddFragment.kt | 30 +++++++++++-------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/app/src/main/java/io/heckel/ntfy/AddFragment.kt b/app/src/main/java/io/heckel/ntfy/AddFragment.kt index 7300771..e1ecdb3 100644 --- a/app/src/main/java/io/heckel/ntfy/AddFragment.kt +++ b/app/src/main/java/io/heckel/ntfy/AddFragment.kt @@ -22,10 +22,6 @@ class AddFragment(private val listener: Listener) : DialogFragment() { val topicNameText = view.findViewById(R.id.add_dialog_topic_text) as TextInputEditText val baseUrlText = view.findViewById(R.id.add_dialog_base_url_text) as TextInputEditText val useAnotherServerCheckbox = view.findViewById(R.id.add_dialog_use_another_server_checkbox) as CheckBox - useAnotherServerCheckbox.setOnCheckedChangeListener { buttonView, isChecked -> - if (isChecked) baseUrlText.visibility = View.VISIBLE - else baseUrlText.visibility = View.GONE - } // Build dialog val alert = AlertDialog.Builder(it) @@ -51,17 +47,20 @@ class AddFragment(private val listener: Listener) : DialogFragment() { val subscribeButton = dialog.getButton(AlertDialog.BUTTON_POSITIVE) subscribeButton.isEnabled = false + val validateInput: () -> Unit = { + if (useAnotherServerCheckbox.isChecked) { + subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank() + && "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString()) + && baseUrlText.text.toString().isNotBlank() + && "^https?://.+".toRegex().matches(baseUrlText.text.toString()) + } else { + subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank() + && "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString()) + } + } val textWatcher = object : TextWatcher { override fun afterTextChanged(s: Editable?) { - if (useAnotherServerCheckbox.isChecked) { - subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank() - && "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString()) - && baseUrlText.text.toString().isNotBlank() - && "^https?://.+".toRegex().matches(baseUrlText.text.toString()) - } else { - subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank() - && "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString()) - } + validateInput() } override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) { // Nothing @@ -72,6 +71,11 @@ class AddFragment(private val listener: Listener) : DialogFragment() { } topicNameText.addTextChangedListener(textWatcher) baseUrlText.addTextChangedListener(textWatcher) + useAnotherServerCheckbox.setOnCheckedChangeListener { buttonView, isChecked -> + if (isChecked) baseUrlText.visibility = View.VISIBLE + else baseUrlText.visibility = View.GONE + validateInput() + } } alert