mirror of
https://github.com/status-im/status-react.git
synced 2025-01-14 04:55:13 +00:00
[#2884] added name lookup for recipient after qr code scanning, moved address comparision function to utils.ethereum namespace, address= will now expect address to be passed (instead of contact)
Signed-off-by: Goran Jovic <goranjovic@gmail.com>
This commit is contained in:
parent
e09476f5d3
commit
18b4bf590c
@ -1,7 +1,6 @@
|
||||
(ns status-im.contact.subs
|
||||
(:require [re-frame.core :refer [reg-sub subscribe]]
|
||||
[status-im.utils.contacts :as utils.contacts]
|
||||
[status-im.utils.ethereum.core :as ethereum]
|
||||
[status-im.utils.identicon :as identicon]))
|
||||
|
||||
(reg-sub :get-current-contact-identity :contacts/identity)
|
||||
@ -149,19 +148,10 @@
|
||||
:else
|
||||
(identicon/identicon chat-id)))))
|
||||
|
||||
(defn- address= [{:keys [address] :as contact} s]
|
||||
(when (and address (= (ethereum/normalized-address s)
|
||||
(ethereum/normalized-address address)))
|
||||
contact))
|
||||
|
||||
(defn- contact-by-address [[_ contact] s]
|
||||
(when (address= contact s)
|
||||
contact))
|
||||
|
||||
(reg-sub :get-contact-by-address
|
||||
:<- [:get-contacts]
|
||||
(fn [contacts [_ address]]
|
||||
(some #(contact-by-address % address) contacts)))
|
||||
(utils.contacts/find-contact-by-address contacts address)))
|
||||
|
||||
(reg-sub :get-contacts-by-address
|
||||
:<- [:get-contacts]
|
||||
|
@ -6,7 +6,8 @@
|
||||
[status-im.utils.handlers :as handlers]
|
||||
[status-im.utils.money :as money]
|
||||
[status-im.utils.ethereum.ens :as ens]
|
||||
[re-frame.core :as re-frame]))
|
||||
[re-frame.core :as re-frame]
|
||||
[status-im.utils.contacts :as utils.contacts]))
|
||||
|
||||
(handlers/register-handler-fx
|
||||
:wallet/toggle-flashlight
|
||||
@ -15,21 +16,25 @@
|
||||
toggled-state (if (= :on flashlight-state) :off :on)]
|
||||
{:db (assoc-in db [:wallet :send-transaction :camera-flashlight] toggled-state)})))
|
||||
|
||||
(defn- find-address-name [db address]
|
||||
(:name (utils.contacts/find-contact-by-address (:contacts/contacts db) address)))
|
||||
|
||||
(defn- fill-request-details [db {:keys [address name value symbol gas gasPrice whisper-identity from-chat?]}]
|
||||
{:pre [(not (nil? address))]}
|
||||
(update-in
|
||||
db [:wallet :send-transaction]
|
||||
(fn [{old-symbol :symbol :as old-transaction}]
|
||||
(let [symbol-changed? (not= old-symbol symbol)]
|
||||
(cond-> (assoc old-transaction :to address :to-name name :whisper-identity whisper-identity)
|
||||
value (assoc :amount value)
|
||||
symbol (assoc :symbol symbol)
|
||||
(and gas symbol-changed?) (assoc :gas (money/bignumber gas))
|
||||
from-chat? (assoc :from-chat? from-chat?)
|
||||
(and gasPrice symbol-changed?)
|
||||
(assoc :gas-price (money/bignumber gasPrice))
|
||||
(and symbol (not gasPrice) symbol-changed?)
|
||||
(assoc :gas-price (ethereum/estimate-gas symbol)))))))
|
||||
(let [name (or name (find-address-name db address))]
|
||||
(update-in
|
||||
db [:wallet :send-transaction]
|
||||
(fn [{old-symbol :symbol :as old-transaction}]
|
||||
(let [symbol-changed? (not= old-symbol symbol)]
|
||||
(cond-> (assoc old-transaction :to address :to-name name :whisper-identity whisper-identity)
|
||||
value (assoc :amount value)
|
||||
symbol (assoc :symbol symbol)
|
||||
(and gas symbol-changed?) (assoc :gas (money/bignumber gas))
|
||||
from-chat? (assoc :from-chat? from-chat?)
|
||||
(and gasPrice symbol-changed?)
|
||||
(assoc :gas-price (money/bignumber gasPrice))
|
||||
(and symbol (not gasPrice) symbol-changed?)
|
||||
(assoc :gas-price (ethereum/estimate-gas symbol))))))))
|
||||
|
||||
(defn- extract-details
|
||||
"First try to parse as EIP681 URI, if not assume this is an address directly.
|
||||
|
@ -1,7 +1,8 @@
|
||||
(ns status-im.utils.contacts
|
||||
(:require [status-im.js-dependencies :as js-dependencies]
|
||||
[status-im.utils.identicon :as identicon]
|
||||
[status-im.utils.gfycat.core :as gfycat]))
|
||||
[status-im.utils.gfycat.core :as gfycat]
|
||||
[status-im.utils.ethereum.core :as ethereum]))
|
||||
|
||||
(defn whisper-id->new-contact [whisper-id]
|
||||
{:name (gfycat/generate-gfy whisper-id)
|
||||
@ -17,3 +18,10 @@
|
||||
nil)]
|
||||
(when normalized-key
|
||||
(subs (.sha3 js-dependencies/Web3.prototype normalized-key #js {:encoding "hex"}) 26))))
|
||||
|
||||
(defn- contact-by-address [[_ contact] address]
|
||||
(when (ethereum/address= (:address contact) address)
|
||||
contact))
|
||||
|
||||
(defn find-contact-by-address [contacts address]
|
||||
(some #(contact-by-address % address) contacts))
|
||||
|
@ -171,3 +171,8 @@
|
||||
(if-not error
|
||||
(cb (js->clj result :keywordize-keys true))
|
||||
(handle-error error)))))
|
||||
|
||||
(defn address= [address1 address2]
|
||||
(and address1 address2
|
||||
(= (normalized-address address1)
|
||||
(normalized-address address2))))
|
||||
|
Loading…
x
Reference in New Issue
Block a user