mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-16 03:35:33 +00:00
This commit is contained in:
parent
0d7c2684ee
commit
b907881d59
@ -2,7 +2,6 @@
|
|||||||
(:require
|
(:require
|
||||||
[camel-snake-kebab.extras :as cske]
|
[camel-snake-kebab.extras :as cske]
|
||||||
[clojure.string :as string]
|
[clojure.string :as string]
|
||||||
[react-native.background-timer :as background-timer]
|
|
||||||
[react-native.platform :as platform]
|
[react-native.platform :as platform]
|
||||||
[status-im.constants :as constants]
|
[status-im.constants :as constants]
|
||||||
[status-im.contexts.wallet.common.utils.networks :as network-utils]
|
[status-im.contexts.wallet.common.utils.networks :as network-utils]
|
||||||
@ -329,55 +328,19 @@
|
|||||||
(assoc-in [:wallet :ui :search-address :local-suggestions] suggestion)
|
(assoc-in [:wallet :ui :search-address :local-suggestions] suggestion)
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] (boolean result)))})))
|
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] (boolean result)))})))
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/fetch-address-suggestions
|
|
||||||
(fn [{:keys [db]} [_address]]
|
|
||||||
{:db (-> db
|
|
||||||
(assoc-in [:wallet :ui :search-address :local-suggestions] nil)
|
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] false))}))
|
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/ens-validation-success
|
|
||||||
(fn [{:keys [db]} [_ens]]
|
|
||||||
{:db (-> db
|
|
||||||
(assoc-in [:wallet :ui :search-address :local-suggestions] nil)
|
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] true))}))
|
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/address-validation-success
|
(rf/reg-event-fx :wallet/address-validation-success
|
||||||
(fn [{:keys [db]} [_]]
|
(fn [{:keys [db]}]
|
||||||
{:db (assoc-in db [:wallet :ui :search-address :valid-ens-or-address?] true)}))
|
{:db (assoc-in db [:wallet :ui :search-address :valid-ens-or-address?] true)}))
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/validate-address
|
(rf/reg-event-fx :wallet/address-validation-failed
|
||||||
(fn [{:keys [db]} [address]]
|
(fn [{:keys [db]}]
|
||||||
(let [current-timeout (get-in db [:wallet :ui :search-address :search-timeout])
|
{:db (assoc-in db [:wallet :ui :search-address :valid-ens-or-address?] false)}))
|
||||||
timeout (background-timer/set-timeout
|
|
||||||
#(rf/dispatch [:wallet/address-validation-success address])
|
|
||||||
2000)]
|
|
||||||
(background-timer/clear-timeout current-timeout)
|
|
||||||
{:db (-> db
|
|
||||||
(assoc-in [:wallet :ui :search-address :search-timeout] timeout)
|
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] false))})))
|
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/validate-ens
|
|
||||||
(fn [{:keys [db]} [ens]]
|
|
||||||
(let [current-timeout (get-in db [:wallet :ui :search-address :search-timeout])
|
|
||||||
timeout (background-timer/set-timeout
|
|
||||||
#(rf/dispatch [:wallet/ens-validation-success ens])
|
|
||||||
2000)]
|
|
||||||
(background-timer/clear-timeout current-timeout)
|
|
||||||
{:db (-> db
|
|
||||||
(assoc-in [:wallet :ui :search-address :search-timeout] timeout)
|
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] false))})))
|
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/clean-local-suggestions
|
(rf/reg-event-fx :wallet/clean-local-suggestions
|
||||||
(fn [{:keys [db]}]
|
(fn [{:keys [db]}]
|
||||||
(let [current-timeout (get-in db [:wallet :ui :search-address :search-timeout])]
|
|
||||||
(background-timer/clear-timeout current-timeout)
|
|
||||||
{:db (-> db
|
{:db (-> db
|
||||||
(assoc-in [:wallet :ui :search-address :local-suggestions] [])
|
(assoc-in [:wallet :ui :search-address :local-suggestions] [])
|
||||||
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] false))})))
|
(assoc-in [:wallet :ui :search-address :valid-ens-or-address?] false))}))
|
||||||
|
|
||||||
(rf/reg-event-fx :wallet/clean-ens-or-address-validation
|
|
||||||
(fn [{:keys [db]}]
|
|
||||||
{:db (assoc-in db [:wallet :ui :search-address :valid-ens-or-address?] false)}))
|
|
||||||
|
|
||||||
(rf/reg-event-fx
|
(rf/reg-event-fx
|
||||||
:wallet/navigate-to-chain-explorer-from-bottom-sheet
|
:wallet/navigate-to-chain-explorer-from-bottom-sheet
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
[status-im.common.floating-button-page.view :as floating-button-page]
|
[status-im.common.floating-button-page.view :as floating-button-page]
|
||||||
[status-im.constants :as constants]
|
[status-im.constants :as constants]
|
||||||
[status-im.contexts.wallet.common.account-switcher.view :as account-switcher]
|
[status-im.contexts.wallet.common.account-switcher.view :as account-switcher]
|
||||||
|
[status-im.contexts.wallet.common.validation :as validation]
|
||||||
[status-im.contexts.wallet.item-types :as types]
|
[status-im.contexts.wallet.item-types :as types]
|
||||||
[status-im.contexts.wallet.send.select-address.style :as style]
|
[status-im.contexts.wallet.send.select-address.style :as style]
|
||||||
[status-im.contexts.wallet.send.select-address.tabs.view :as tabs]
|
[status-im.contexts.wallet.send.select-address.tabs.view :as tabs]
|
||||||
@ -23,6 +24,16 @@
|
|||||||
{:id :tab/contacts :label (i18n/label :t/contacts) :accessibility-label :contacts-tab})
|
{:id :tab/contacts :label (i18n/label :t/contacts) :accessibility-label :contacts-tab})
|
||||||
{:id :tab/my-accounts :label (i18n/label :t/my-accounts) :accessibility-label :my-accounts-tab}])
|
{:id :tab/my-accounts :label (i18n/label :t/my-accounts) :accessibility-label :my-accounts-tab}])
|
||||||
|
|
||||||
|
(defn- validate-address
|
||||||
|
[address]
|
||||||
|
(debounce/debounce-and-dispatch
|
||||||
|
(if (and (> (count address) 0)
|
||||||
|
(not (or (validation/ens-name? address)
|
||||||
|
(validation/eth-address? address))))
|
||||||
|
[:wallet/address-validation-failed address]
|
||||||
|
[:wallet/address-validation-success address])
|
||||||
|
300))
|
||||||
|
|
||||||
(defn- address-input
|
(defn- address-input
|
||||||
[input-value input-focused?]
|
[input-value input-focused?]
|
||||||
(fn []
|
(fn []
|
||||||
@ -49,9 +60,7 @@
|
|||||||
; ^ this check is to prevent effect being triggered when screen is
|
; ^ this check is to prevent effect being triggered when screen is
|
||||||
; loaded but not being shown to the user (deep in the navigation
|
; loaded but not being shown to the user (deep in the navigation
|
||||||
; stack) and avoid undesired behaviors
|
; stack) and avoid undesired behaviors
|
||||||
(debounce/debounce-and-dispatch
|
(validate-address %))
|
||||||
[:wallet/validate-address %]
|
|
||||||
300))
|
|
||||||
:on-detect-ens (fn [text cb]
|
:on-detect-ens (fn [text cb]
|
||||||
(when (or (= current-screen-id :screen/wallet.select-address)
|
(when (or (= current-screen-id :screen/wallet.select-address)
|
||||||
(= current-screen-id :screen/wallet.scan-address))
|
(= current-screen-id :screen/wallet.scan-address))
|
||||||
@ -64,6 +73,7 @@
|
|||||||
:on-change-text (fn [text]
|
:on-change-text (fn [text]
|
||||||
(when (empty? text)
|
(when (empty? text)
|
||||||
(rf/dispatch [:wallet/clean-local-suggestions]))
|
(rf/dispatch [:wallet/clean-local-suggestions]))
|
||||||
|
(validate-address text)
|
||||||
(reset! input-value text))
|
(reset! input-value text))
|
||||||
:valid-ens-or-address? valid-ens-or-address?}])))
|
:valid-ens-or-address? valid-ens-or-address?}])))
|
||||||
|
|
||||||
@ -167,6 +177,13 @@
|
|||||||
:title-accessibility-label :title-label}]
|
:title-accessibility-label :title-label}]
|
||||||
[address-input input-value input-focused?]
|
[address-input input-value input-focused?]
|
||||||
[quo/divider-line]
|
[quo/divider-line]
|
||||||
|
(when (and (not valid-ens-or-address?) (> (count @input-value) 0))
|
||||||
|
[rn/view {:style {:padding 20}}
|
||||||
|
[quo/info-message
|
||||||
|
{:type :error
|
||||||
|
:icon :i/info
|
||||||
|
:size :default}
|
||||||
|
(i18n/label :t/invalid-address)]])
|
||||||
(if (or @input-focused? (> (count @input-value) 0))
|
(if (or @input-focused? (> (count @input-value) 0))
|
||||||
[rn/keyboard-avoiding-view
|
[rn/keyboard-avoiding-view
|
||||||
{:style {:flex 1}
|
{:style {:flex 1}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user