summaryrefslogtreecommitdiff
path: root/app/src/main/java/net/taler/wallet/Amount.kt
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/main/java/net/taler/wallet/Amount.kt')
-rw-r--r--app/src/main/java/net/taler/wallet/Amount.kt16
1 files changed, 16 insertions, 0 deletions
diff --git a/app/src/main/java/net/taler/wallet/Amount.kt b/app/src/main/java/net/taler/wallet/Amount.kt
index 2b41be1..f8b48e3 100644
--- a/app/src/main/java/net/taler/wallet/Amount.kt
+++ b/app/src/main/java/net/taler/wallet/Amount.kt
@@ -18,11 +18,16 @@
package net.taler.wallet
+import com.fasterxml.jackson.core.JsonParser
+import com.fasterxml.jackson.databind.DeserializationContext
+import com.fasterxml.jackson.databind.annotation.JsonDeserialize
+import com.fasterxml.jackson.databind.deser.std.StdDeserializer
import org.json.JSONObject
import kotlin.math.round
private const val FRACTIONAL_BASE = 1e8
+@JsonDeserialize(using = AmountDeserializer::class)
data class Amount(val currency: String, val amount: String) {
fun isZero(): Boolean {
return amount.toDouble() == 0.0
@@ -46,6 +51,17 @@ data class Amount(val currency: String, val amount: String) {
return Amount(components[0], components[1])
}
}
+
+ override fun toString(): String {
+ return String.format("%.2f $currency", amount.toDouble())
+ }
+}
+
+class AmountDeserializer : StdDeserializer<Amount>(Amount::class.java) {
+ override fun deserialize(p: JsonParser, ctxt: DeserializationContext): Amount {
+ val node = p.codec.readValue(p, String::class.java)
+ return Amount.fromString(node)
+ }
}
class ParsedAmount(