parent
a504c9dd56
commit
c5207cb8a6
2 changed files with 37 additions and 15 deletions
|
@ -297,17 +297,15 @@ data class Boost(
|
|||
if (value != null) {
|
||||
val formatted = formatter.format(value)
|
||||
|
||||
text?.removeTextChangedListener(this)
|
||||
|
||||
s.replace(0, s.length, formatted)
|
||||
if (formatted.endsWith(symbol)) {
|
||||
val result: MatchResult? = symbolPattern.find(formatted)
|
||||
if (result != null && result.range.first < s.length) {
|
||||
text?.setSelection(result.range.first)
|
||||
modifyEditable {
|
||||
s.replace(0, s.length, formatted)
|
||||
if (formatted.endsWith(symbol)) {
|
||||
val result: MatchResult? = symbolPattern.find(formatted)
|
||||
if (result != null && result.range.first < s.length) {
|
||||
text?.setSelection(result.range.first)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
text?.addTextChangedListener(this)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -325,16 +323,24 @@ data class Boost(
|
|||
}
|
||||
|
||||
if (withoutSymbol != withoutLeadingZeroes) {
|
||||
text?.removeTextChangedListener(this)
|
||||
|
||||
val start = s.indexOf(withoutSymbol)
|
||||
s.replace(start, start + withoutSymbol.length, withoutLeadingZeroes)
|
||||
|
||||
text?.addTextChangedListener(this)
|
||||
modifyEditable {
|
||||
val start = s.indexOf(withoutSymbol)
|
||||
s.replace(start, start + withoutSymbol.length, withoutLeadingZeroes)
|
||||
}
|
||||
}
|
||||
|
||||
onCustomAmountChanged(s.removePrefix(symbol).removeSuffix(symbol).trim().toString())
|
||||
}
|
||||
|
||||
private fun modifyEditable(modification: () -> Unit) {
|
||||
text?.removeTextChangedListener(this)
|
||||
text?.keyListener = null
|
||||
|
||||
modification()
|
||||
|
||||
text?.addTextChangedListener(this)
|
||||
text?.keyListener = this
|
||||
}
|
||||
}
|
||||
|
||||
companion object {
|
||||
|
|
|
@ -2,6 +2,9 @@ package org.thoughtcrime.securesms.components.settings.app.subscription.boost
|
|||
|
||||
import android.app.Application
|
||||
import android.text.SpannableStringBuilder
|
||||
import android.widget.TextView
|
||||
import androidx.appcompat.widget.AppCompatEditText
|
||||
import androidx.test.core.app.ApplicationProvider
|
||||
import org.junit.Assert.assertEquals
|
||||
import org.junit.Assert.assertNotNull
|
||||
import org.junit.Assert.assertNull
|
||||
|
@ -96,6 +99,19 @@ class BoostTest__MoneyFilter {
|
|||
assertNull(filterResult)
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Given USD, when I enter 1000, then I expect successful filter`() {
|
||||
val view = AppCompatEditText(ApplicationProvider.getApplicationContext())
|
||||
val testSubject = Boost.MoneyFilter(usd, text = view)
|
||||
|
||||
view.keyListener = testSubject
|
||||
view.addTextChangedListener(testSubject)
|
||||
|
||||
view.setText("1000", TextView.BufferType.EDITABLE)
|
||||
|
||||
assertEquals("$1,000", view.text.toString())
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `Given JPY, when I enter 5, then I expect yen 5`() {
|
||||
val testSubject = Boost.MoneyFilter(yen)
|
||||
|
|
Loading…
Add table
Reference in a new issue