mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-12 17:54:32 +00:00
[BUG #2189] Do not clear user set amount when scanning QR code
This commit is contained in:
parent
1c43702c32
commit
eea4eeb549
@ -11,7 +11,10 @@
|
|||||||
(assoc-in db [:wallet :send-transaction :camera-flashlight] toggled-state))))
|
(assoc-in db [:wallet :send-transaction :camera-flashlight] toggled-state))))
|
||||||
|
|
||||||
(defn choose-address-and-name [db address name amount]
|
(defn choose-address-and-name [db address name amount]
|
||||||
(update-in db [:wallet :send-transaction] assoc :to-address address :to-name name :amount amount))
|
(update-in
|
||||||
|
db [:wallet :send-transaction]
|
||||||
|
#(cond-> (assoc % :to-address address :to-name name)
|
||||||
|
amount (assoc :amount amount))))
|
||||||
|
|
||||||
(defn- extract-details
|
(defn- extract-details
|
||||||
"First try to parse as EIP67 URI, if not assume this is an address directly.
|
"First try to parse as EIP67 URI, if not assume this is an address directly.
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
(views/defview qr-code [amount]
|
(views/defview qr-code [amount]
|
||||||
(views/letsubs [account [:get-current-account]]
|
(views/letsubs [account [:get-current-account]]
|
||||||
[components.qr-code/qr-code
|
[components.qr-code/qr-code
|
||||||
{:value (eip67/generate-uri (:address account) {:value amount})
|
{:value (eip67/generate-uri (:address account) (when amount {:value amount}))
|
||||||
:size 256}]))
|
:size 256}]))
|
||||||
|
|
||||||
(views/defview request-transaction []
|
(views/defview request-transaction []
|
||||||
|
@ -32,9 +32,13 @@
|
|||||||
(str (name k) key-value-separator v))))
|
(str (name k) key-value-separator v))))
|
||||||
|
|
||||||
(defn generate-uri
|
(defn generate-uri
|
||||||
"Generate a EIP 67 URI based on `address` and an optional map of extra properties.
|
"Generate a EIP 67 URI based on `address` and an optional map (keyword, string) of extra properties.
|
||||||
No validation of address format is performed."
|
No validation of address format is performed."
|
||||||
([address] (generate-uri address nil))
|
([address] (generate-uri address nil))
|
||||||
([address m]
|
([address m]
|
||||||
(when address
|
(when address
|
||||||
(str scheme scheme-separator address (when m (str parameters-separator (generate-parameter-string m)))))))
|
(let [parameters (into {} (filter second m))] ;; filter nil values
|
||||||
|
(str scheme scheme-separator address
|
||||||
|
(when-not (empty? parameters)
|
||||||
|
(str parameters-separator (generate-parameter-string parameters))))))))
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
[status-im.test.utils.utils]
|
[status-im.test.utils.utils]
|
||||||
[status-im.test.utils.money]
|
[status-im.test.utils.money]
|
||||||
[status-im.test.utils.clocks]
|
[status-im.test.utils.clocks]
|
||||||
|
[status-im.test.utils.eip.eip67]
|
||||||
[status-im.test.utils.erc20]
|
[status-im.test.utils.erc20]
|
||||||
[status-im.test.utils.random]
|
[status-im.test.utils.random]
|
||||||
[status-im.test.utils.gfycat.core]
|
[status-im.test.utils.gfycat.core]
|
||||||
@ -38,6 +39,7 @@
|
|||||||
'status-im.test.utils.utils
|
'status-im.test.utils.utils
|
||||||
'status-im.test.utils.money
|
'status-im.test.utils.money
|
||||||
'status-im.test.utils.clocks
|
'status-im.test.utils.clocks
|
||||||
|
'status-im.test.utils.eip.eip67
|
||||||
'status-im.test.utils.erc20
|
'status-im.test.utils.erc20
|
||||||
'status-im.test.utils.random
|
'status-im.test.utils.random
|
||||||
'status-im.test.utils.gfycat.core
|
'status-im.test.utils.gfycat.core
|
||||||
|
@ -14,5 +14,8 @@
|
|||||||
(deftest generate-uri
|
(deftest generate-uri
|
||||||
(is (= nil (eip67/generate-uri nil)))
|
(is (= nil (eip67/generate-uri nil)))
|
||||||
(is (= "ethereum:0x1234" (eip67/generate-uri "0x1234")))
|
(is (= "ethereum:0x1234" (eip67/generate-uri "0x1234")))
|
||||||
|
(is (= "ethereum:0x1234" (eip67/generate-uri "0x1234" nil)))
|
||||||
|
(is (= "ethereum:0x1234" (eip67/generate-uri "0x1234" {})))
|
||||||
|
(is (= "ethereum:0x1234" (eip67/generate-uri "0x1234" {:to nil})))
|
||||||
(is (= "ethereum:0x1234?to=0x5678" (eip67/generate-uri "0x1234" {:to "0x5678"})))
|
(is (= "ethereum:0x1234?to=0x5678" (eip67/generate-uri "0x1234" {:to "0x5678"})))
|
||||||
(is (= "ethereum:0x1234?to=0x5678&value=1" (eip67/generate-uri "0x1234" {:to "0x5678" :value 1}))))
|
(is (= "ethereum:0x1234?to=0x5678&value=1" (eip67/generate-uri "0x1234" {:to "0x5678" :value 1}))))
|
Loading…
x
Reference in New Issue
Block a user