Merge pull request #1606 from Andries-Smit/chore/number-picker-view-binding

chore: implement view binding adapter number picker
This commit is contained in:
Milos Kozak 2022-04-11 16:06:04 +02:00 committed by GitHub
commit b732b3b492
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
19 changed files with 120 additions and 87 deletions

View file

@ -241,10 +241,10 @@ class ProfileHelperActivity : NoSplashAppCompatActivity() {
} }
ToastUtils.showToastInUiThread(this, R.string.invalidinput) ToastUtils.showToastInUiThread(this, R.string.invalidinput)
} }
binding.age.editText?.id?.let { binding.ageLabel.labelFor = it } binding.ageLabel.labelFor = binding.age.editTextId
binding.tdd.editText?.id?.let { binding.tddLabel.labelFor = it } binding.tddLabel.labelFor = binding.tdd.editTextId
binding.weight.editText?.id?.let { binding.weightLabel.labelFor = it } binding.weightLabel.labelFor = binding.weight.editTextId
binding.basalPctFromTdd.editText?.id?.let { binding.basalPctFromTddLabel.labelFor = it } binding.basalPctFromTddLabel.labelFor = binding.basalPctFromTdd.editTextId
switchTab(0, typeSelected[0], false) switchTab(0, typeSelected[0], false)
} }

View file

@ -64,7 +64,7 @@ class CalibrationDialog : DialogFragmentWithDate() {
binding.bg.setParams(savedInstanceState?.getDouble("bg") binding.bg.setParams(savedInstanceState?.getDouble("bg")
?: bg, 36.0, 500.0, 1.0, DecimalFormat("0"), false, binding.okcancel.ok) ?: bg, 36.0, 500.0, 1.0, DecimalFormat("0"), false, binding.okcancel.ok)
binding.units.text = if (units == GlucoseUnit.MMOL) rh.gs(R.string.mmol) else rh.gs(R.string.mgdl) binding.units.text = if (units == GlucoseUnit.MMOL) rh.gs(R.string.mmol) else rh.gs(R.string.mgdl)
binding.bg.editText?.id?.let { binding.bgLabel.labelFor = it } binding.bgLabel.labelFor = binding.bg.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -199,9 +199,9 @@ class CarbsDialog : DialogFragmentWithDate() {
binding.hypoTt.isChecked = false binding.hypoTt.isChecked = false
binding.activityTt.isChecked = false binding.activityTt.isChecked = false
} }
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
binding.time.editText?.id?.let { binding.timeLabel.labelFor = it } binding.timeLabel.labelFor = binding.time.editTextId
binding.carbs.editText?.id?.let { binding.carbsLabel.labelFor = it } binding.carbsLabel.labelFor = binding.carbs.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -165,8 +165,8 @@ class CareDialog : DialogFragmentWithDate() {
?: 0.0, 0.0, Constants.MAX_PROFILE_SWITCH_DURATION, 10.0, DecimalFormat("0"), false, binding.okcancel.ok) ?: 0.0, 0.0, Constants.MAX_PROFILE_SWITCH_DURATION, 10.0, DecimalFormat("0"), false, binding.okcancel.ok)
if (options == EventType.NOTE || options == EventType.QUESTION || options == EventType.ANNOUNCEMENT || options == EventType.EXERCISE) if (options == EventType.NOTE || options == EventType.QUESTION || options == EventType.ANNOUNCEMENT || options == EventType.EXERCISE)
binding.notesLayout.root.visibility = View.VISIBLE // independent to preferences binding.notesLayout.root.visibility = View.VISIBLE // independent to preferences
binding.bg.editText?.id?.let { binding.bgLabel.labelFor = it } binding.bgLabel.labelFor = binding.bg.editTextId
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -75,8 +75,8 @@ class ExtendedBolusDialog : DialogFragmentWithDate() {
val extendedMaxDuration = pumpDescription.extendedBolusMaxDuration val extendedMaxDuration = pumpDescription.extendedBolusMaxDuration
binding.duration.setParams(savedInstanceState?.getDouble("duration") binding.duration.setParams(savedInstanceState?.getDouble("duration")
?: extendedDurationStep, extendedDurationStep, extendedMaxDuration, extendedDurationStep, DecimalFormat("0"), false, binding.okcancel.ok) ?: extendedDurationStep, extendedDurationStep, extendedMaxDuration, extendedDurationStep, DecimalFormat("0"), false, binding.okcancel.ok)
binding.insulin.editText?.id?.let { binding.insulinLabel.labelFor = it } binding.insulinLabel.labelFor = binding.insulin.editTextId
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -99,7 +99,7 @@ class FillDialog : DialogFragmentWithDate() {
} else { } else {
binding.fillPresetButton3.visibility = View.GONE binding.fillPresetButton3.visibility = View.GONE
} }
binding.fillInsulinamount.editText?.id?.let { binding.fillLabel.labelFor = it } binding.fillLabel.labelFor = binding.fillInsulinamount.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -150,8 +150,8 @@ class InsulinDialog : DialogFragmentWithDate() {
binding.recordOnly.setOnCheckedChangeListener { _, isChecked: Boolean -> binding.recordOnly.setOnCheckedChangeListener { _, isChecked: Boolean ->
binding.timeLayout.visibility = isChecked.toVisibility() binding.timeLayout.visibility = isChecked.toVisibility()
} }
binding.amount.editText?.id?.let { binding.insulinLabel.labelFor = it } binding.insulinLabel.labelFor = binding.amount.editTextId
binding.time.editText?.id?.let { binding.timeLabel.labelFor = it } binding.timeLabel.labelFor = binding.time.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -152,9 +152,9 @@ class ProfileSwitchDialog : DialogFragmentWithDate() {
} }
} }
binding.ttLayout.visibility = View.GONE binding.ttLayout.visibility = View.GONE
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
binding.percentage.editText?.id?.let { binding.percentageLabel.labelFor = it } binding.percentageLabel.labelFor = binding.percentage.editTextId
binding.timeshift.editText?.id?.let { binding.timeshiftLabel.labelFor = it } binding.timeshiftLabel.labelFor = binding.timeshift.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -89,9 +89,9 @@ class TempBasalDialog : DialogFragmentWithDate() {
binding.percentLayout.visibility = View.GONE binding.percentLayout.visibility = View.GONE
binding.absoluteLayout.visibility = View.VISIBLE binding.absoluteLayout.visibility = View.VISIBLE
} }
binding.basalPercentInput.editText?.id?.let { binding.basalPercentLabel.labelFor = it } binding.basalPercentLabel.labelFor = binding.basalPercentInput.editTextId
binding.basalAbsoluteInput.editText?.id?.let { binding.basalAbsoluteLabel.labelFor = it } binding.basalAbsoluteLabel.labelFor = binding.basalAbsoluteInput.editTextId
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -123,8 +123,8 @@ class TempTargetDialog : DialogFragmentWithDate() {
longClick(it) longClick(it)
return@setOnLongClickListener true return@setOnLongClickListener true
} }
binding.duration.editText?.id?.let { binding.durationLabel.labelFor = it } binding.durationLabel.labelFor = binding.duration.editTextId
binding.temptarget.editText?.id?.let { binding.temptargetLabel.labelFor = it } binding.temptargetLabel.labelFor = binding.temptarget.editTextId
} }
} }

View file

@ -108,8 +108,8 @@ class TreatmentDialog : DialogFragmentWithDate() {
binding.insulin.setParams(savedInstanceState?.getDouble("insulin") binding.insulin.setParams(savedInstanceState?.getDouble("insulin")
?: 0.0, 0.0, maxInsulin, pumpDescription.bolusStep, DecimalFormatter.pumpSupportedBolusFormat(activePlugin.activePump), false, binding.okcancel.ok, textWatcher) ?: 0.0, 0.0, maxInsulin, pumpDescription.bolusStep, DecimalFormatter.pumpSupportedBolusFormat(activePlugin.activePump), false, binding.okcancel.ok, textWatcher)
binding.recordOnlyLayout.visibility = View.GONE binding.recordOnlyLayout.visibility = View.GONE
binding.insulin.editText?.id?.let { binding.insulinLabel.labelFor = it } binding.insulinLabel.labelFor = binding.insulin.editTextId
binding.carbs.editText?.id?.let { binding.carbsLabel.labelFor = it } binding.carbsLabel.labelFor = binding.carbs.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -248,10 +248,10 @@ class WizardDialog : DaggerDialogFragment() {
} }
private fun setA11yLabels() { private fun setA11yLabels() {
binding.bgInput.editText?.id?.let { binding.bgInputLabel.labelFor = it } binding.bgInputLabel.labelFor = binding.bgInput.editTextId
binding.carbsInput.editText?.id?.let { binding.carbsInputLabel.labelFor = it } binding.carbsInputLabel.labelFor = binding.carbsInput.editTextId
binding.correctionInput.editText?.id?.let { binding.correctionInputLabel.labelFor = it } binding.correctionInputLabel.labelFor = binding.correctionInput.editTextId
binding.carbTimeInput.editText?.id?.let { binding.carbTimeInputLabel.labelFor = it } binding.carbTimeInputLabel.labelFor = binding.carbTimeInput.editTextId
} }
override fun onDestroyView() { override fun onDestroyView() {

View file

@ -115,9 +115,7 @@ class LocalProfileFragment : DaggerFragment() {
override fun onTabUnselected(tab: TabLayout.Tab) {} override fun onTabUnselected(tab: TabLayout.Tab) {}
override fun onTabReselected(tab: TabLayout.Tab) {} override fun onTabReselected(tab: TabLayout.Tab) {}
}) })
binding.diaLabel.labelFor = binding.dia.editTextId
binding.dia.editText?.id?.let { binding.diaLabel.labelFor = it }
binding.unlock.setOnClickListener { queryProtection() } binding.unlock.setOnClickListener { queryProtection() }
} }

View file

@ -13,16 +13,16 @@ class MinutesNumberPicker constructor(context: Context, attrs: AttributeSet? = n
} }
override fun updateEditText() { override fun updateEditText() {
if (currentValue == 0.0 && !allowZero) editText?.setText("") if (currentValue == 0.0 && !allowZero) binding.editText.setText("")
else { else {
if (focused) editText?.setText(DecimalFormat("0").format(currentValue)) if (focused) binding.editText.setText(DecimalFormat("0").format(currentValue))
else { else {
val hours = (currentValue / 60).toInt() val hours = (currentValue / 60).toInt()
val minutes = (currentValue - hours * 60).toInt() val minutes = (currentValue - hours * 60).toInt()
val formatted = val formatted =
if (hours != 0) String.format(context.getString(R.string.format_hour_minute), hours, minutes) if (hours != 0) String.format(context.getString(R.string.format_hour_minute), hours, minutes)
else DecimalFormat("0").format(currentValue) else DecimalFormat("0").format(currentValue)
editText?.setText(formatted) binding.editText.setText(formatted)
} }
} }
} }

View file

@ -19,11 +19,9 @@ import android.view.accessibility.AccessibilityEvent
import android.view.accessibility.AccessibilityManager import android.view.accessibility.AccessibilityManager
import android.view.inputmethod.InputMethodManager import android.view.inputmethod.InputMethodManager
import android.widget.Button import android.widget.Button
import android.widget.ImageButton
import android.widget.LinearLayout import android.widget.LinearLayout
import com.google.android.material.textfield.TextInputEditText
import com.google.android.material.textfield.TextInputLayout
import info.nightscout.androidaps.core.R import info.nightscout.androidaps.core.R
import info.nightscout.androidaps.core.databinding.NumberPickerLayoutBinding
import info.nightscout.androidaps.extensions.toVisibility import info.nightscout.androidaps.extensions.toVisibility
import info.nightscout.androidaps.utils.ToastUtils import info.nightscout.androidaps.utils.ToastUtils
import info.nightscout.shared.SafeParse import info.nightscout.shared.SafeParse
@ -41,10 +39,6 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
fun onValueChanged(value: Double) fun onValueChanged(value: Double)
} }
var editText: TextInputEditText? = null
private var minusButton: ImageButton? = null
private var plusButton: ImageButton? = null
var textInputLayout: TextInputLayout? = null
var currentValue = 0.0 var currentValue = 0.0
var minValue = 0.0 var minValue = 0.0
var maxValue = 1.0 var maxValue = 1.0
@ -57,6 +51,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
private var mUpdater: ScheduledExecutorService? = null private var mUpdater: ScheduledExecutorService? = null
private var mOnValueChangedListener: OnValueChangedListener? = null private var mOnValueChangedListener: OnValueChangedListener? = null
private var mCustomContentDescription: String? = null private var mCustomContentDescription: String? = null
protected lateinit var binding: NumberPickerViewAdapter
private var mHandler: Handler = Handler(Looper.getMainLooper(), Handler.Callback { msg: Message -> private var mHandler: Handler = Handler(Looper.getMainLooper(), Handler.Callback { msg: Message ->
when (msg.what) { when (msg.what) {
@ -93,6 +88,8 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
} }
} }
val editTextId get() = binding.editText.id
var customContentDescription: String? var customContentDescription: String?
get() = mCustomContentDescription get() = mCustomContentDescription
set(value) { set(value) {
@ -101,39 +98,36 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
} }
protected open fun inflate(context: Context) { protected open fun inflate(context: Context) {
LayoutInflater.from(context).inflate(R.layout.number_picker_layout, this, true) val inflater = LayoutInflater.from(context)
val bindLayout = NumberPickerLayoutBinding.inflate(inflater, this, true)
binding = NumberPickerViewAdapter.getBinding(bindLayout)
} }
protected fun initialize(context: Context) { protected fun initialize(context: Context) {
// set layout view // set layout view
inflate(context) inflate(context)
// init ui components binding.minusButton.id = generateViewId()
minusButton = findViewById(R.id.decrement) binding.plusButton.id = generateViewId()
minusButton?.id = generateViewId() binding.editText.id = generateViewId()
plusButton = findViewById(R.id.increment) binding.minusButton.setOnTouchListener(this)
plusButton?.id = generateViewId() binding.minusButton.setOnKeyListener(this)
textInputLayout = findViewById(R.id.textInputLayout) binding.minusButton.setOnClickListener(this)
editText = findViewById(R.id.display) binding.plusButton.setOnTouchListener(this)
editText?.id = generateViewId() binding.plusButton.setOnKeyListener(this)
minusButton?.setOnTouchListener(this) binding.plusButton.setOnClickListener(this)
minusButton?.setOnKeyListener(this)
minusButton?.setOnClickListener(this)
plusButton?.setOnTouchListener(this)
plusButton?.setOnKeyListener(this)
plusButton?.setOnClickListener(this)
setTextWatcher(object : TextWatcher { setTextWatcher(object : TextWatcher {
override fun beforeTextChanged(s: CharSequence, start: Int, count: Int, after: Int) {} override fun beforeTextChanged(s: CharSequence, start: Int, count: Int, after: Int) {}
override fun onTextChanged(s: CharSequence, start: Int, before: Int, count: Int) {} override fun onTextChanged(s: CharSequence, start: Int, before: Int, count: Int) {}
override fun afterTextChanged(s: Editable) { override fun afterTextChanged(s: Editable) {
if (focused) currentValue = SafeParse.stringToDouble(editText?.text.toString()) if (focused) currentValue = SafeParse.stringToDouble(binding.editText.text.toString())
callValueChangedListener() callValueChangedListener()
val inValid = currentValue > maxValue || currentValue < minValue val inValid = currentValue > maxValue || currentValue < minValue
okButton?.visibility = inValid.not().toVisibility() okButton?.visibility = inValid.not().toVisibility()
textInputLayout?.error = if (inValid) "invalid" else null binding.textInputLayout.error = if (inValid) "invalid" else null
} }
}) })
editText?.setOnFocusChangeListener { _: View?, hasFocus: Boolean -> binding.editText.setOnFocusChangeListener { _: View?, hasFocus: Boolean ->
focused = hasFocus focused = hasFocus
if (!focused) value // check min/max if (!focused) value // check min/max
updateEditText() updateEditText()
@ -143,8 +137,8 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
fun updateA11yDescription() { fun updateA11yDescription() {
val description = if (mCustomContentDescription != null) mCustomContentDescription else "" val description = if (mCustomContentDescription != null) mCustomContentDescription else ""
minusButton?.contentDescription = context.getString(R.string.a11y_min_button_description, description, formatter?.format(this.step)) binding.minusButton.contentDescription = context.getString(R.string.a11y_min_button_description, description, formatter?.format(this.step))
plusButton?.contentDescription = context.getString(R.string.a11y_plus_button_description, description, formatter?.format(this.step)) binding.plusButton.contentDescription = context.getString(R.string.a11y_plus_button_description, description, formatter?.format(this.step))
} }
fun announceValue() { fun announceValue() {
@ -164,7 +158,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
} }
override fun setTag(tag: Any) { override fun setTag(tag: Any) {
editText?.tag = tag binding.editText.tag = tag
} }
fun setOnValueChangedListener(onValueChangedListener: OnValueChangedListener?) { fun setOnValueChangedListener(onValueChangedListener: OnValueChangedListener?) {
@ -173,10 +167,10 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
fun setTextWatcher(textWatcher: TextWatcher) { fun setTextWatcher(textWatcher: TextWatcher) {
watcher = textWatcher watcher = textWatcher
editText?.addTextChangedListener(textWatcher) binding.editText.addTextChangedListener(textWatcher)
editText?.onFocusChangeListener = OnFocusChangeListener { _: View?, hasFocus: Boolean -> binding.editText.onFocusChangeListener = OnFocusChangeListener { _: View?, hasFocus: Boolean ->
if (!hasFocus) { if (!hasFocus) {
currentValue = SafeParse.stringToDouble(editText?.text.toString()) currentValue = SafeParse.stringToDouble(binding.editText.text.toString())
if (currentValue > maxValue) { if (currentValue > maxValue) {
currentValue = maxValue currentValue = maxValue
ToastUtils.showToastInUiThread(context, context.getString(R.string.youareonallowedlimit)) ToastUtils.showToastInUiThread(context, context.getString(R.string.youareonallowedlimit))
@ -195,11 +189,11 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
fun setParams(initValue: Double, minValue: Double, maxValue: Double, step: Double, formatter: NumberFormat?, allowZero: Boolean, okButton: Button?, textWatcher: TextWatcher?) { fun setParams(initValue: Double, minValue: Double, maxValue: Double, step: Double, formatter: NumberFormat?, allowZero: Boolean, okButton: Button?, textWatcher: TextWatcher?) {
if (watcher != null) { if (watcher != null) {
editText?.removeTextChangedListener(watcher) binding.editText.removeTextChangedListener(watcher)
} }
setParams(initValue, minValue, maxValue, step, formatter, allowZero, okButton) setParams(initValue, minValue, maxValue, step, formatter, allowZero, okButton)
watcher = textWatcher watcher = textWatcher
if (textWatcher != null) editText?.addTextChangedListener(textWatcher) if (textWatcher != null) binding.editText.addTextChangedListener(textWatcher)
} }
fun setParams(initValue: Double, minValue: Double, maxValue: Double, step: Double, formatter: NumberFormat?, allowZero: Boolean, okButton: Button?) { fun setParams(initValue: Double, minValue: Double, maxValue: Double, step: Double, formatter: NumberFormat?, allowZero: Boolean, okButton: Button?) {
@ -211,11 +205,11 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
this.allowZero = allowZero this.allowZero = allowZero
callValueChangedListener() callValueChangedListener()
this.okButton = okButton this.okButton = okButton
editText?.keyListener = DigitsKeyListenerWithComma.getInstance(minValue < 0, step != round(step)) binding.editText.keyListener = DigitsKeyListenerWithComma.getInstance(minValue < 0, step != round(step))
if (watcher != null) editText?.removeTextChangedListener(watcher) if (watcher != null) binding.editText.removeTextChangedListener(watcher)
updateA11yDescription() updateA11yDescription()
updateEditText() updateEditText()
if (watcher != null) editText?.addTextChangedListener(watcher) if (watcher != null) binding.editText.addTextChangedListener(watcher)
} }
var value: Double var value: Double
@ -231,7 +225,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
return currentValue return currentValue
} }
set(value) { set(value) {
if (watcher != null) editText?.removeTextChangedListener(watcher) if (watcher != null) binding.editText.removeTextChangedListener(watcher)
currentValue = value currentValue = value
if (currentValue > maxValue) { if (currentValue > maxValue) {
currentValue = maxValue currentValue = maxValue
@ -243,11 +237,11 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
} }
callValueChangedListener() callValueChangedListener()
updateEditText() updateEditText()
if (watcher != null) editText?.addTextChangedListener(watcher) if (watcher != null) binding.editText.addTextChangedListener(watcher)
} }
val text: String val text: String
get() = editText?.text.toString() get() = binding.editText.text.toString()
private fun inc(multiplier: Int) { private fun inc(multiplier: Int) {
currentValue += step * multiplier currentValue += step * multiplier
@ -272,7 +266,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
} }
protected open fun updateEditText() { protected open fun updateEditText() {
if (currentValue == 0.0 && !allowZero) editText?.setText("") else editText?.setText(formatter?.format(currentValue)) if (currentValue == 0.0 && !allowZero) binding.editText.setText("") else binding.editText.setText(formatter?.format(currentValue))
} }
private fun callValueChangedListener() { private fun callValueChangedListener() {
@ -300,9 +294,9 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
override fun onClick(v: View) { override fun onClick(v: View) {
if (mUpdater == null) { if (mUpdater == null) {
val imm = context.getSystemService(Service.INPUT_METHOD_SERVICE) as InputMethodManager val imm = context.getSystemService(Service.INPUT_METHOD_SERVICE) as InputMethodManager
imm.hideSoftInputFromWindow(editText?.windowToken, 0) imm.hideSoftInputFromWindow(binding.editText.windowToken, 0)
editText?.clearFocus() binding.editText.clearFocus()
if (v === plusButton) { if (v === binding.plusButton) {
inc(1) inc(1)
} else { } else {
dec(1) dec(1)
@ -318,7 +312,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
if (isKeyOfInterest && isReleased) { if (isKeyOfInterest && isReleased) {
stopUpdating() stopUpdating()
} else if (isKeyOfInterest && isPressed) { } else if (isKeyOfInterest && isPressed) {
startUpdating(v === plusButton) startUpdating(v === binding.plusButton)
} }
return false return false
} }
@ -329,7 +323,7 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
if (isReleased) { if (isReleased) {
stopUpdating() stopUpdating()
} else if (isPressed) { } else if (isPressed) {
startUpdating(v === plusButton) startUpdating(v === binding.plusButton)
} }
return false return false
} }
@ -345,7 +339,8 @@ open class NumberPicker(context: Context, attrs: AttributeSet? = null) : LinearL
context.theme.obtainStyledAttributes( context.theme.obtainStyledAttributes(
attrs, attrs,
R.styleable.NumberPicker, R.styleable.NumberPicker,
0, 0).apply { 0, 0
).apply {
try { try {
mCustomContentDescription = getString(R.styleable.NumberPicker_customContentDescription) mCustomContentDescription = getString(R.styleable.NumberPicker_customContentDescription)

View file

@ -3,11 +3,13 @@ package info.nightscout.androidaps.utils.ui
import android.content.Context import android.content.Context
import android.util.AttributeSet import android.util.AttributeSet
import android.view.LayoutInflater import android.view.LayoutInflater
import info.nightscout.androidaps.R import info.nightscout.androidaps.core.databinding.NumberPickerLayoutVerticalBinding
class NumberPickerVertical(context: Context, attrs: AttributeSet? = null) : NumberPicker(context, attrs) { class NumberPickerVertical(context: Context, attrs: AttributeSet? = null) : NumberPicker(context, attrs) {
override fun inflate(context: Context) { override fun inflate(context: Context) {
LayoutInflater.from(context).inflate(R.layout.number_picker_layout_vertical, this, true) val inflater = LayoutInflater.from(context)
val bindLayout = NumberPickerLayoutVerticalBinding.inflate(inflater, this, true)
binding = NumberPickerViewAdapter(null, bindLayout)
} }
} }

View file

@ -0,0 +1,36 @@
package info.nightscout.androidaps.utils.ui
import info.nightscout.androidaps.core.databinding.NumberPickerLayoutBinding
import info.nightscout.androidaps.core.databinding.NumberPickerLayoutVerticalBinding
/**
* NumberPickerViewAdapter binds both NumberPickerLayoutBinding and NumberPickerLayoutVerticalBinding shared attributes to one common view adapter.
* Requires at least one of the ViewBinding as a parameter. Recommended to use the factory object to create the binding.
*/
class NumberPickerViewAdapter(
val nH: NumberPickerLayoutBinding?,
val nV: NumberPickerLayoutVerticalBinding?,
) {
init {
if (nH == null && nV == null) {
throw IllegalArgumentException("Require at least on Binding parameter")
}
}
val editText = nH?.display ?: nV?.display ?: throw IllegalArgumentException("Missing require View Binding parameter display")
val minusButton = nH?.decrement ?: nV?.decrement ?: throw IllegalArgumentException("require at least on Binding parameter decrement")
val plusButton = nH?.increment ?: nV?.increment ?: throw IllegalArgumentException("require at least on Binding parameter increment")
var textInputLayout = nH?.textInputLayout ?: nV?.textInputLayout ?: throw IllegalArgumentException("require at least on Binding parameter textInputLayout")
companion object {
fun getBinding(bindLayout: NumberPickerLayoutBinding): NumberPickerViewAdapter {
return NumberPickerViewAdapter(bindLayout, null)
}
fun getBinding(bindLayout: NumberPickerLayoutVerticalBinding): NumberPickerViewAdapter {
return NumberPickerViewAdapter(null, bindLayout)
}
}
}

View file

@ -3,7 +3,8 @@
xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" xmlns:tools="http://schemas.android.com/tools"
android:layout_width="130dp" android:layout_width="130dp"
android:layout_height="40dp"> android:layout_height="40dp"
tools:context="info.nightscout.androidaps.utils.ui.NumberPicker">
<com.google.android.material.textfield.TextInputLayout <com.google.android.material.textfield.TextInputLayout
android:id="@+id/textInputLayout" android:id="@+id/textInputLayout"

View file

@ -3,7 +3,8 @@
xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" xmlns:tools="http://schemas.android.com/tools"
android:layout_width="60dp" android:layout_width="60dp"
android:layout_height="100dp"> android:layout_height="100dp"
tools:context="info.nightscout.androidaps.utils.ui.NumberPickerVertical">
<com.google.android.material.textfield.TextInputLayout <com.google.android.material.textfield.TextInputLayout
android:id="@+id/textInputLayout" android:id="@+id/textInputLayout"