Swap: use correct fee on spending cap screen (#21532)

This commit is contained in:
Volodymyr Kozieiev 2024-11-18 16:15:14 +00:00 committed by GitHub
parent eb3ae3c928
commit 87483b1ef4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
11 changed files with 88 additions and 69 deletions

View File

@ -25,9 +25,8 @@
{:currency currency {:currency currency
:balance balance :balance balance
:token token}) :token token})
fiat-formatted (utils/get-standard-fiat-format crypto-value fiat-formatted (utils/fiat-formatted-for-ui currency-symbol
currency-symbol fiat-value)
fiat-value)
token-available-on-network? (network-utils/token-available-on-network? supported-networks token-available-on-network? (network-utils/token-available-on-network? supported-networks
chain-id)] chain-id)]
[quo/network-list [quo/network-list

View File

@ -18,7 +18,7 @@
:balance total-balance :balance total-balance
:token token}) :token token})
crypto-formatted (utils/get-standard-crypto-format token total-balance) crypto-formatted (utils/get-standard-crypto-format token total-balance)
fiat-formatted (utils/get-standard-fiat-format crypto-formatted currency-symbol fiat-value)] fiat-formatted (utils/fiat-formatted-for-ui currency-symbol fiat-value)]
[quo/token-network [quo/token-network
{:token token-symbol {:token token-symbol
:label token-name :label token-name

View File

@ -251,9 +251,9 @@
(str $ address)) (str $ address))
address)) address))
(defn get-standard-fiat-format (defn fiat-formatted-for-ui
[crypto-value currency-symbol fiat-value] [currency-symbol fiat-value]
(if (string/includes? crypto-value "<") (if (money/less-than fiat-value 0.01)
(str "<" currency-symbol "0.01") (str "<" currency-symbol "0.01")
(prettify-balance currency-symbol fiat-value))) (prettify-balance currency-symbol fiat-value)))
@ -281,9 +281,8 @@
formatted-token-price (prettify-balance currency-symbol price) formatted-token-price (prettify-balance currency-symbol price)
percentage-change (prettify-percentage-change change-pct-24hour) percentage-change (prettify-percentage-change change-pct-24hour)
crypto-value (get-standard-crypto-format token balance) crypto-value (get-standard-crypto-format token balance)
fiat-value (get-standard-fiat-format crypto-value fiat-value (fiat-formatted-for-ui currency-symbol
currency-symbol fiat-unformatted-value)]
fiat-unformatted-value)]
{:token (:symbol token) {:token (:symbol token)
:token-name (:name token) :token-name (:name token)
:state :default :state :default

View File

@ -20,7 +20,7 @@
:balance total-balance :balance total-balance
:token token}) :token token})
crypto-formatted (utils/get-standard-crypto-format token total-balance) crypto-formatted (utils/get-standard-crypto-format token total-balance)
fiat-formatted (utils/get-standard-fiat-format crypto-formatted currency-symbol fiat-value)] fiat-formatted (utils/fiat-formatted-for-ui currency-symbol fiat-value)]
[rn/view {:style {:padding-horizontal 8}} [rn/view {:style {:padding-horizontal 8}}
[quo/token-network [quo/token-network
{:token token-symbol {:token token-symbol

View File

@ -7,7 +7,7 @@
[status-im.common.events-helper :as events-helper] [status-im.common.events-helper :as events-helper]
[status-im.common.floating-button-page.view :as floating-button-page] [status-im.common.floating-button-page.view :as floating-button-page]
[status-im.common.standard-authentication.core :as standard-auth] [status-im.common.standard-authentication.core :as standard-auth]
[status-im.constants :as constants] [status-im.contexts.wallet.common.utils :as utils]
[status-im.contexts.wallet.common.utils.external-links :as external-links] [status-im.contexts.wallet.common.utils.external-links :as external-links]
[status-im.contexts.wallet.swap.set-spending-cap.style :as style] [status-im.contexts.wallet.swap.set-spending-cap.style :as style]
[utils.address :as address-utils] [utils.address :as address-utils]
@ -185,11 +185,14 @@
(defn- transaction-details (defn- transaction-details
[] []
(let [network (rf/sub [:wallet/swap-network]) (let [network (rf/sub [:wallet/swap-network])
max-fees (rf/sub [:wallet/wallet-swap-proposal-fee-fiat-formatted approval-fees (rf/sub [:wallet/approval-gas-fees])
constants/token-for-fees-symbol]) currency-symbol (rf/sub [:profile/currency-symbol])
loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?]) approval-fees-formatted (utils/fiat-formatted-for-ui
estimated-time (rf/sub [:wallet/swap-proposal-estimated-time])] currency-symbol
approval-fees)
loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?])
estimated-time (rf/sub [:wallet/swap-proposal-estimated-time])]
[rn/view {:style style/details-container} [rn/view {:style style/details-container}
[:<> [:<>
[data-item [data-item
@ -198,7 +201,9 @@
:network-image (:source network)}] :network-image (:source network)}]
[data-item [data-item
{:title (i18n/label :t/max-fees) {:title (i18n/label :t/max-fees)
:subtitle (if (and estimated-time max-fees) max-fees (i18n/label :t/unknown)) :subtitle (if (and estimated-time approval-fees-formatted)
approval-fees-formatted
(i18n/label :t/unknown))
:loading? loading-swap-proposal? :loading? loading-swap-proposal?
:size :small}] :size :small}]
[data-item [data-item

View File

@ -65,15 +65,25 @@
(defn- transaction-details (defn- transaction-details
[] []
(let [theme (quo.theme/use-theme) (let [theme (quo.theme/use-theme)
max-fees (rf/sub [:wallet/wallet-swap-proposal-fee-fiat-formatted swap-proposal-fee (rf/sub [:wallet/wallet-swap-proposal-fee-fiat
constants/token-for-fees-symbol]) constants/token-for-fees-symbol])
approval-gas-fee (rf/sub [:wallet/approval-gas-fees])
max-slippage (rf/sub [:wallet/swap-max-slippage]) max-slippage (rf/sub [:wallet/swap-max-slippage])
loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?]) loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?])
currency-symbol (rf/sub [:profile/currency-symbol])
approval-required? (rf/sub [:wallet/swap-proposal-approval-required])
approval-status (rf/sub [:wallet/swap-approval-transaction-status])
max-fee (if (and approval-required? (not= approval-status :confirmed))
(money/add approval-gas-fee swap-proposal-fee)
swap-proposal-fee)
max-fee-formatted (utils/fiat-formatted-for-ui
currency-symbol
max-fee)
error-response (rf/sub [:wallet/swap-error-response])] error-response (rf/sub [:wallet/swap-error-response])]
[rn/view {:style style/details-container} [rn/view {:style style/details-container}
[data-item [data-item
(cond-> {:title (i18n/label :t/max-fees) (cond-> {:title (i18n/label :t/max-fees)
:subtitle max-fees :subtitle max-fee-formatted
:loading? loading-swap-proposal? :loading? loading-swap-proposal?
:size :small} :size :small}
error-response (assoc :subtitle-color error-response (assoc :subtitle-color

View File

@ -7,6 +7,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.common.standard-authentication.core :as standard-auth] [status-im.common.standard-authentication.core :as standard-auth]
[status-im.constants :as constants] [status-im.constants :as constants]
[status-im.contexts.wallet.common.utils :as utils]
[status-im.contexts.wallet.send.utils :as send-utils] [status-im.contexts.wallet.send.utils :as send-utils]
[status-im.contexts.wallet.swap.swap-confirmation.style :as style] [status-im.contexts.wallet.swap.swap-confirmation.style :as style]
[utils.address :as address-utils] [utils.address :as address-utils]
@ -137,8 +138,12 @@
(defn- transaction-details (defn- transaction-details
[] []
(let [max-fees (rf/sub [:wallet/wallet-swap-proposal-fee-fiat-formatted (let [max-fees (rf/sub [:wallet/wallet-swap-proposal-fee-fiat
constants/token-for-fees-symbol]) constants/token-for-fees-symbol])
currency-symbol (rf/sub [:profile/currency-symbol])
max-fees-formatted (utils/fiat-formatted-for-ui
currency-symbol
max-fees)
estimated-time (rf/sub [:wallet/swap-proposal-estimated-time]) estimated-time (rf/sub [:wallet/swap-proposal-estimated-time])
loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?]) loading-swap-proposal? (rf/sub [:wallet/swap-loading-swap-proposal?])
max-slippage (rf/sub [:wallet/swap-max-slippage])] max-slippage (rf/sub [:wallet/swap-max-slippage])]
@ -152,7 +157,7 @@
:loading? loading-swap-proposal?}] :loading? loading-swap-proposal?}]
[data-item [data-item
{:title (i18n/label :t/max-fees) {:title (i18n/label :t/max-fees)
:subtitle (if (and estimated-time max-fees) max-fees (i18n/label :t/unknown)) :subtitle (if (and estimated-time max-fees-formatted) max-fees-formatted (i18n/label :t/unknown))
:loading? loading-swap-proposal?}] :loading? loading-swap-proposal?}]
[data-item [data-item
{:title (i18n/label :t/max-slippage) {:title (i18n/label :t/max-slippage)

View File

@ -58,10 +58,8 @@
max-fees-fiat (wallet-utils/calculate-token-fiat-value {:currency currency max-fees-fiat (wallet-utils/calculate-token-fiat-value {:currency currency
:balance max-fees-ether :balance max-fees-ether
:token eth-token}) :token eth-token})
max-fees-fiat-formatted (-> (wallet-utils/get-standard-crypto-format eth-token max-fees-fiat-formatted (wallet-utils/fiat-formatted-for-ui currency-symbol
max-fees-ether) max-fees-fiat)
(wallet-utils/get-standard-fiat-format currency-symbol
max-fees-fiat))
balance (-> eth-token balance (-> eth-token
(get-in [:balances-per-chain chain-id :raw-balance]) (get-in [:balances-per-chain chain-id :raw-balance])
money/bignumber) money/bignumber)

View File

@ -90,9 +90,8 @@
:balance total-balance :balance total-balance
:token token}) :token token})
crypto-formatted (utils/get-standard-crypto-format token total-balance) crypto-formatted (utils/get-standard-crypto-format token total-balance)
fiat-formatted (utils/get-standard-fiat-format crypto-formatted fiat-formatted (utils/fiat-formatted-for-ui currency-symbol
currency-symbol fiat-value)]
fiat-value)]
{:crypto (str crypto-formatted " " token-symbol) {:crypto (str crypto-formatted " " token-symbol)
:fiat fiat-formatted}))) :fiat fiat-formatted})))
@ -239,30 +238,22 @@
:-> :estimated-time) :-> :estimated-time)
(rf/reg-sub (rf/reg-sub
:wallet/wallet-swap-proposal-fee-fiat-formatted :wallet/wallet-swap-proposal-fee-fiat
:<- [:wallet/current-viewing-account] :<- [:wallet/current-viewing-account]
:<- [:wallet/swap-proposal] :<- [:wallet/swap-proposal]
:<- [:profile/currency] :<- [:profile/currency]
:<- [:profile/currency-symbol] (fn [[account swap-proposal currency] [_ token-symbol-for-fees]]
(fn [[account swap-proposal currency currency-symbol] [_ token-symbol-for-fees]]
(when token-symbol-for-fees (when token-symbol-for-fees
(let [tokens (:tokens account) (let [tokens (:tokens account)
token-for-fees (first (filter #(= (string/lower-case (:symbol %)) token-for-fees (first (filter #(= (string/lower-case (:symbol %))
(string/lower-case token-symbol-for-fees)) (string/lower-case token-symbol-for-fees))
tokens)) tokens))
fee-in-native-token (send-utils/calculate-full-route-gas-fee [swap-proposal]) fee-in-native-token (send-utils/calculate-full-route-gas-fee [swap-proposal])
fee-in-crypto-formatted (utils/get-standard-crypto-format fee-in-fiat (utils/calculate-token-fiat-value
token-for-fees {:currency currency
fee-in-native-token) :balance fee-in-native-token
fee-in-fiat (utils/calculate-token-fiat-value :token token-for-fees})]
{:currency currency fee-in-fiat))))
:balance fee-in-native-token
:token token-for-fees})
fee-formatted (utils/get-standard-fiat-format
fee-in-crypto-formatted
currency-symbol
fee-in-fiat)]
fee-formatted))))
(rf/reg-sub (rf/reg-sub
:wallet/swap-asset-to-pay-balance-for-chain-data :wallet/swap-asset-to-pay-balance-for-chain-data
@ -302,3 +293,20 @@
:currency-symbol currency-symbol :currency-symbol currency-symbol
:balance (or amount 0) :balance (or amount 0)
:token asset-to-pay-with-current-account-balance}))) :token asset-to-pay-with-current-account-balance})))
(rf/reg-sub
:wallet/approval-gas-fees
:<- [:wallet/current-viewing-account]
:<- [:wallet/swap-proposal]
:<- [:profile/currency]
(fn [[account {:keys [approval-gas-fees]} currency]]
(let [tokens (:tokens account)
token-for-fees (first (filter #(= (string/lower-case (:symbol %))
(string/lower-case constants/token-for-fees-symbol))
tokens))
fee-in-fiat (utils/calculate-token-fiat-value
{:currency currency
:balance approval-gas-fees
:token token-for-fees})]
fee-in-fiat)))

View File

@ -257,7 +257,7 @@
swap-data) swap-data)
(is (match? "0x10000" (rf/sub [sub-name]))))) (is (match? "0x10000" (rf/sub [sub-name])))))
(h/deftest-sub :wallet/wallet-swap-proposal-fee-fiat-formatted (h/deftest-sub :wallet/wallet-swap-proposal-fee-fiat
[sub-name] [sub-name]
(testing "wallet send fee calculated and formatted in fiat" (testing "wallet send fee calculated and formatted in fiat"
(swap! rf-db/app-db (swap! rf-db/app-db
@ -266,9 +266,8 @@
(assoc-in [:wallet :current-viewing-account-address] "0x1") (assoc-in [:wallet :current-viewing-account-address] "0x1")
(assoc-in [:wallet :ui :swap] swap-data) (assoc-in [:wallet :ui :swap] swap-data)
(assoc-in [:currencies] currencies) (assoc-in [:currencies] currencies)
(assoc-in [:profile/profile :currency] :usd) (assoc-in [:profile/profile :currency] :usd)))
(assoc-in [:profile/profile :currency-symbol] "$")))
(let [token-symbol-for-fees "ETH" (let [token-symbol-for-fees "ETH"
result (rf/sub [sub-name token-symbol-for-fees])] result (rf/sub [sub-name token-symbol-for-fees])]
(is (match? result "$1.00"))))) (is (match? result 1)))))

View File

@ -768,22 +768,18 @@
:<- [:profile/currency-symbol] :<- [:profile/currency-symbol]
(fn [[account route currency currency-symbol] [_ token-symbol-for-fees]] (fn [[account route currency currency-symbol] [_ token-symbol-for-fees]]
(when token-symbol-for-fees (when token-symbol-for-fees
(let [tokens (:tokens account) (let [tokens (:tokens account)
token-for-fees (first (filter #(= (string/lower-case (:symbol %)) token-for-fees (first (filter #(= (string/lower-case (:symbol %))
(string/lower-case token-symbol-for-fees)) (string/lower-case token-symbol-for-fees))
tokens)) tokens))
fee-in-native-token (send-utils/calculate-full-route-gas-fee route) fee-in-native-token (send-utils/calculate-full-route-gas-fee route)
fee-in-crypto-formatted (utils/get-standard-crypto-format fee-in-fiat (utils/calculate-token-fiat-value
token-for-fees {:currency currency
fee-in-native-token) :balance fee-in-native-token
fee-in-fiat (utils/calculate-token-fiat-value :token token-for-fees})
{:currency currency fee-formatted (utils/fiat-formatted-for-ui
:balance fee-in-native-token currency-symbol
:token token-for-fees}) fee-in-fiat)]
fee-formatted (utils/get-standard-fiat-format
fee-in-crypto-formatted
currency-symbol
fee-in-fiat)]
fee-formatted)))) fee-formatted))))
(rf/reg-sub (rf/reg-sub