Validate input when checkbox is pressed
This commit is contained in:
parent
170bdc2485
commit
e28a80d6b6
1 changed files with 17 additions and 13 deletions
|
@ -22,10 +22,6 @@ class AddFragment(private val listener: Listener) : DialogFragment() {
|
||||||
val topicNameText = view.findViewById(R.id.add_dialog_topic_text) as TextInputEditText
|
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 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
|
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
|
// Build dialog
|
||||||
val alert = AlertDialog.Builder(it)
|
val alert = AlertDialog.Builder(it)
|
||||||
|
@ -51,8 +47,7 @@ class AddFragment(private val listener: Listener) : DialogFragment() {
|
||||||
val subscribeButton = dialog.getButton(AlertDialog.BUTTON_POSITIVE)
|
val subscribeButton = dialog.getButton(AlertDialog.BUTTON_POSITIVE)
|
||||||
subscribeButton.isEnabled = false
|
subscribeButton.isEnabled = false
|
||||||
|
|
||||||
val textWatcher = object : TextWatcher {
|
val validateInput: () -> Unit = {
|
||||||
override fun afterTextChanged(s: Editable?) {
|
|
||||||
if (useAnotherServerCheckbox.isChecked) {
|
if (useAnotherServerCheckbox.isChecked) {
|
||||||
subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank()
|
subscribeButton.isEnabled = topicNameText.text.toString().isNotBlank()
|
||||||
&& "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString())
|
&& "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString())
|
||||||
|
@ -63,6 +58,10 @@ class AddFragment(private val listener: Listener) : DialogFragment() {
|
||||||
&& "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString())
|
&& "[-_A-Za-z0-9]+".toRegex().matches(topicNameText.text.toString())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
val textWatcher = object : TextWatcher {
|
||||||
|
override fun afterTextChanged(s: Editable?) {
|
||||||
|
validateInput()
|
||||||
|
}
|
||||||
override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {
|
override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {
|
||||||
// Nothing
|
// Nothing
|
||||||
}
|
}
|
||||||
|
@ -72,6 +71,11 @@ class AddFragment(private val listener: Listener) : DialogFragment() {
|
||||||
}
|
}
|
||||||
topicNameText.addTextChangedListener(textWatcher)
|
topicNameText.addTextChangedListener(textWatcher)
|
||||||
baseUrlText.addTextChangedListener(textWatcher)
|
baseUrlText.addTextChangedListener(textWatcher)
|
||||||
|
useAnotherServerCheckbox.setOnCheckedChangeListener { buttonView, isChecked ->
|
||||||
|
if (isChecked) baseUrlText.visibility = View.VISIBLE
|
||||||
|
else baseUrlText.visibility = View.GONE
|
||||||
|
validateInput()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
alert
|
alert
|
||||||
|
|
Loading…
Add table
Reference in a new issue