mirror of
https://github.com/status-im/status-react.git
synced 2025-01-10 19:16:59 +00:00
[#6149] Add support for KudosTokens
Signed-off-by: Andrey Shovkoplyas <motor4ik@gmail.com>
This commit is contained in:
parent
09ca7d887c
commit
31fdb39683
BIN
resources/images/tokens/mainnet/KUDOS.png
Normal file
BIN
resources/images/tokens/mainnet/KUDOS.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.6 KiB |
BIN
resources/images/tokens/mainnet/KUDOS@2x.png
Normal file
BIN
resources/images/tokens/mainnet/KUDOS@2x.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.9 KiB |
BIN
resources/images/tokens/mainnet/KUDOS@3x.png
Normal file
BIN
resources/images/tokens/mainnet/KUDOS@3x.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.3 KiB |
BIN
resources/images/tokens/rinkeby/KUDOS.png
Normal file
BIN
resources/images/tokens/rinkeby/KUDOS.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.6 KiB |
BIN
resources/images/tokens/rinkeby/KUDOS@2x.png
Normal file
BIN
resources/images/tokens/rinkeby/KUDOS@2x.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.9 KiB |
BIN
resources/images/tokens/rinkeby/KUDOS@3x.png
Normal file
BIN
resources/images/tokens/rinkeby/KUDOS@3x.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.3 KiB |
@ -88,7 +88,7 @@
|
|||||||
(defn default-account-settings []
|
(defn default-account-settings []
|
||||||
{:wallet {:visible-tokens {:testnet #{:STT :HND}
|
{:wallet {:visible-tokens {:testnet #{:STT :HND}
|
||||||
:mainnet #{:SNT}
|
:mainnet #{:SNT}
|
||||||
:rinkeby #{:MOKSHA}}}})
|
:rinkeby #{:MOKSHA :KUDOS}}}})
|
||||||
|
|
||||||
(def currencies
|
(def currencies
|
||||||
{:aed {:id :aed :code "AED" :display-name (i18n/label :t/currency-display-name-aed) :symbol "د.إ"}
|
{:aed {:id :aed :code "AED" :display-name (i18n/label :t/currency-display-name-aed) :symbol "د.إ"}
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
status-im.ui.screens.wallet.collectibles.cryptostrikers.events
|
status-im.ui.screens.wallet.collectibles.cryptostrikers.events
|
||||||
status-im.ui.screens.wallet.collectibles.etheremon.events
|
status-im.ui.screens.wallet.collectibles.etheremon.events
|
||||||
status-im.ui.screens.wallet.collectibles.superrare.events
|
status-im.ui.screens.wallet.collectibles.superrare.events
|
||||||
|
status-im.ui.screens.wallet.collectibles.kudos.events
|
||||||
status-im.utils.keychain.events
|
status-im.utils.keychain.events
|
||||||
[re-frame.core :as re-frame]
|
[re-frame.core :as re-frame]
|
||||||
[status-im.hardwallet.core :as hardwallet]
|
[status-im.hardwallet.core :as hardwallet]
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
ids)}))
|
ids)}))
|
||||||
|
|
||||||
;; TODO(andrey) Each HTTP call will return up to 100 kitties. Maybe we need to implement some kind of paging later
|
;; TODO(andrey) Each HTTP call will return up to 100 kitties. Maybe we need to implement some kind of paging later
|
||||||
(defmethod collectibles/load-collectibles-fx ck [_ _ items-number address]
|
(defmethod collectibles/load-collectibles-fx ck [_ _ items-number address _]
|
||||||
{:http-get {:url (str "https://api.cryptokitties.co/kitties?offset=0&limit="
|
{:http-get {:url (str "https://api.cryptokitties.co/kitties?offset=0&limit="
|
||||||
items-number
|
items-number
|
||||||
"&owner_wallet_address="
|
"&owner_wallet_address="
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
(def strikers :STRK)
|
(def strikers :STRK)
|
||||||
|
|
||||||
(defmethod collectibles/load-collectible-fx strikers [_ id]
|
(defmethod collectibles/load-collectible-fx strikers [_ _ id]
|
||||||
{:http-get {:url (str "https://us-central1-cryptostrikers-prod.cloudfunctions.net/cards/" id)
|
{:http-get {:url (str "https://us-central1-cryptostrikers-prod.cloudfunctions.net/cards/" id)
|
||||||
:success-event-creator (fn [o]
|
:success-event-creator (fn [o]
|
||||||
[:load-collectible-success strikers {id (http/parse-payload o)}])
|
[:load-collectible-success strikers {id (http/parse-payload o)}])
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
(def emona :EMONA)
|
(def emona :EMONA)
|
||||||
|
|
||||||
(defmethod collectibles/load-collectible-fx emona [_ id]
|
(defmethod collectibles/load-collectible-fx emona [_ _ id]
|
||||||
{:http-get {:url (str "https://www.etheremon.com/api/monster/get_data?monster_ids=" id)
|
{:http-get {:url (str "https://www.etheremon.com/api/monster/get_data?monster_ids=" id)
|
||||||
:success-event-creator (fn [o]
|
:success-event-creator (fn [o]
|
||||||
[:load-collectible-success emona (:data (http/parse-payload o))])
|
[:load-collectible-success emona (:data (http/parse-payload o))])
|
||||||
|
@ -4,43 +4,47 @@
|
|||||||
[status-im.utils.ethereum.erc721 :as erc721]
|
[status-im.utils.ethereum.erc721 :as erc721]
|
||||||
[status-im.utils.ethereum.tokens :as tokens]
|
[status-im.utils.ethereum.tokens :as tokens]
|
||||||
[status-im.utils.money :as money]
|
[status-im.utils.money :as money]
|
||||||
[status-im.browser.core :as browser]))
|
[status-im.browser.core :as browser]
|
||||||
|
[status-im.utils.ethereum.core :as ethereum]
|
||||||
|
[status-im.constants :as constants]))
|
||||||
|
|
||||||
(defmulti load-collectible-fx (fn [symbol _] symbol))
|
(defmulti load-collectible-fx (fn [_ symbol _] symbol))
|
||||||
|
|
||||||
(defmethod load-collectible-fx :default [_ _] nil)
|
(defmethod load-collectible-fx :default [_ _ _] nil)
|
||||||
|
|
||||||
(defmulti load-collectibles-fx (fn [_ symbol _ _] symbol))
|
(defmulti load-collectibles-fx (fn [_ symbol _ _] symbol))
|
||||||
|
|
||||||
(defmethod load-collectibles-fx :default [web3 symbol items-number address]
|
(defmethod load-collectibles-fx :default [web3 symbol items-number address chain-id]
|
||||||
{:load-collectibles-fx [web3 symbol items-number address]})
|
{:load-collectibles-fx [web3 symbol items-number address chain-id]})
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:show-collectibles-list
|
:show-collectibles-list
|
||||||
(fn [{:keys [db]} [_ address {:keys [symbol amount] :as collectible}]]
|
(fn [{:keys [db]} [_ address {:keys [symbol amount] :as collectible}]]
|
||||||
(let [items-number (money/to-number amount)
|
(let [chain-id (get-in constants/default-networks [(:network db) :config :NetworkId])
|
||||||
|
items-number (money/to-number amount)
|
||||||
loaded-items-number (count (get-in db [:collectibles symbol]))]
|
loaded-items-number (count (get-in db [:collectibles symbol]))]
|
||||||
(merge (when (not= items-number loaded-items-number)
|
(merge (when (not= items-number loaded-items-number)
|
||||||
(load-collectibles-fx (:web3 db) symbol items-number address))
|
(load-collectibles-fx (:web3 db) symbol items-number address chain-id))
|
||||||
{:dispatch [:navigate-to :collectibles-list collectible]}))))
|
{:dispatch [:navigate-to :collectibles-list collectible]}))))
|
||||||
|
|
||||||
(defn load-token [web3 i items-number contract address symbol]
|
(defn load-token [web3 i items-number contract address symbol]
|
||||||
(when (< i items-number)
|
(when (< i items-number)
|
||||||
(erc721/token-of-owner-by-index web3 contract address i
|
(erc721/token-of-owner-by-index web3 contract address i
|
||||||
(fn [_ v2]
|
(fn [v1 v2]
|
||||||
(load-token web3 (inc i) items-number contract address symbol)
|
(load-token web3 (inc i) items-number contract address symbol)
|
||||||
(re-frame/dispatch [:load-collectible symbol (.toNumber v2)])))))
|
(re-frame/dispatch [:load-collectible symbol (.toNumber v2)])))))
|
||||||
|
|
||||||
(re-frame/reg-fx
|
(re-frame/reg-fx
|
||||||
:load-collectibles-fx
|
:load-collectibles-fx
|
||||||
(fn [[web3 symbol items-number address]]
|
(fn [[web3 symbol items-number address chain-id]]
|
||||||
(let [contract (:address (tokens/symbol->token :mainnet symbol))]
|
(let [chain (ethereum/chain-id->chain-keyword chain-id)
|
||||||
|
contract (:address (tokens/symbol->token chain symbol))]
|
||||||
(load-token web3 0 items-number contract address symbol))))
|
(load-token web3 0 items-number contract address symbol))))
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:load-collectible
|
:load-collectible
|
||||||
(fn [_ [_ symbol token-id]]
|
(fn [cofx [_ symbol token-id]]
|
||||||
(load-collectible-fx symbol token-id)))
|
(load-collectible-fx cofx symbol token-id)))
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:store-collectibles
|
:store-collectibles
|
||||||
|
@ -0,0 +1,36 @@
|
|||||||
|
(ns status-im.ui.screens.wallet.collectibles.kudos.events
|
||||||
|
(:require [status-im.ui.screens.wallet.collectibles.events :as collectibles]
|
||||||
|
[status-im.utils.http :as http]
|
||||||
|
[status-im.utils.ethereum.erc721 :as erc721]
|
||||||
|
[status-im.utils.ethereum.tokens :as tokens]
|
||||||
|
[re-frame.core :as re-frame]
|
||||||
|
[status-im.utils.handlers :as handlers]
|
||||||
|
[status-im.constants :as constants]
|
||||||
|
[status-im.utils.ethereum.core :as ethereum]))
|
||||||
|
|
||||||
|
(def kudos :KUDOS)
|
||||||
|
|
||||||
|
(defmethod collectibles/load-collectible-fx kudos [{db :db} symbol id]
|
||||||
|
(let [chain-id (get-in constants/default-networks [(:network db) :config :NetworkId])]
|
||||||
|
{:erc721-token-uri [(:web3 db) symbol id chain-id]}))
|
||||||
|
|
||||||
|
(re-frame/reg-fx
|
||||||
|
:erc721-token-uri
|
||||||
|
(fn [[web3 symbol tokenId chain-id]]
|
||||||
|
(let [chain (ethereum/chain-id->chain-keyword chain-id)
|
||||||
|
contract (:address (tokens/symbol->token chain symbol))]
|
||||||
|
(erc721/token-uri web3 contract tokenId
|
||||||
|
#(re-frame/dispatch [:token-uri-success
|
||||||
|
tokenId
|
||||||
|
(when %2
|
||||||
|
;;TODO extra chars in rinkeby
|
||||||
|
(subs %2 (.indexOf %2 "http")))])))))
|
||||||
|
|
||||||
|
(handlers/register-handler-fx
|
||||||
|
:token-uri-success
|
||||||
|
(fn [_ [_ tokenId token-uri]]
|
||||||
|
{:http-get {:url token-uri
|
||||||
|
:success-event-creator (fn [o]
|
||||||
|
[:load-collectible-success kudos {tokenId (http/parse-payload o)}])
|
||||||
|
:failure-event-creator (fn [o]
|
||||||
|
[:load-collectible-failure kudos {tokenId (http/parse-payload o)}])}}))
|
@ -0,0 +1,27 @@
|
|||||||
|
(ns status-im.ui.screens.wallet.collectibles.kudos.views
|
||||||
|
(:require [status-im.ui.screens.wallet.collectibles.views :as collectibles]
|
||||||
|
[status-im.ui.components.react :as react]
|
||||||
|
[status-im.ui.screens.wallet.collectibles.styles :as styles]
|
||||||
|
[status-im.ui.components.svgimage :as svgimage]
|
||||||
|
[status-im.ui.components.action-button.action-button :as action-button]
|
||||||
|
[status-im.ui.components.colors :as colors]
|
||||||
|
[re-frame.core :as re-frame]
|
||||||
|
[status-im.i18n :as i18n]))
|
||||||
|
|
||||||
|
(defmethod collectibles/render-collectible :KUDOS [_ {:keys [external_url description name image]}]
|
||||||
|
[react/view {:style styles/details}
|
||||||
|
[react/view {:style styles/details-text}
|
||||||
|
[svgimage/svgimage {:style styles/details-image
|
||||||
|
:source {:uri image
|
||||||
|
:k 1.4}}]
|
||||||
|
[react/view {:flex 1 :justify-content :center}
|
||||||
|
[react/text {:style styles/details-name}
|
||||||
|
name]
|
||||||
|
[react/text
|
||||||
|
description]]]
|
||||||
|
[action-button/action-button
|
||||||
|
{:label (i18n/label :t/view-gitcoin)
|
||||||
|
:icon :icons/address
|
||||||
|
:icon-opts {:color colors/blue}
|
||||||
|
:accessibility-label :open-collectible-button
|
||||||
|
:on-press #(re-frame/dispatch [:open-collectible-in-browser external_url])}]])
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
(def superrare :SUPR)
|
(def superrare :SUPR)
|
||||||
|
|
||||||
(defmethod collectibles/load-collectible-fx superrare [_ ids]
|
(defmethod collectibles/load-collectible-fx superrare [_ _ ids]
|
||||||
{:http-get-n (mapv (fn [id]
|
{:http-get-n (mapv (fn [id]
|
||||||
{:url id
|
{:url id
|
||||||
:success-event-creator (fn [o]
|
:success-event-creator (fn [o]
|
||||||
@ -29,7 +29,7 @@
|
|||||||
imageUri
|
imageUri
|
||||||
}}}}"))
|
}}}}"))
|
||||||
|
|
||||||
(defmethod collectibles/load-collectibles-fx superrare [_ _ _ address]
|
(defmethod collectibles/load-collectibles-fx superrare [_ _ _ address _]
|
||||||
{:http-post {:url graphql-url
|
{:http-post {:url graphql-url
|
||||||
:data (types/clj->json {:query (graphql-query (ethereum/naked-address address))})
|
:data (types/clj->json {:query (graphql-query (ethereum/naked-address address))})
|
||||||
:opts {:headers {"Content-Type" "application/json"}}
|
:opts {:headers {"Content-Type" "application/json"}}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
status-im.ui.screens.wallet.collectibles.cryptostrikers.views
|
status-im.ui.screens.wallet.collectibles.cryptostrikers.views
|
||||||
status-im.ui.screens.wallet.collectibles.cryptokitties.views
|
status-im.ui.screens.wallet.collectibles.cryptokitties.views
|
||||||
status-im.ui.screens.wallet.collectibles.superrare.views
|
status-im.ui.screens.wallet.collectibles.superrare.views
|
||||||
|
status-im.ui.screens.wallet.collectibles.kudos.views
|
||||||
[status-im.ui.components.status-bar.view :as status-bar.view]
|
[status-im.ui.components.status-bar.view :as status-bar.view]
|
||||||
[status-im.ui.screens.wallet.transactions.views :as transactions.views]
|
[status-im.ui.screens.wallet.transactions.views :as transactions.views]
|
||||||
[status-im.ui.components.colors :as colors]))
|
[status-im.ui.components.colors :as colors]))
|
||||||
|
@ -60,7 +60,15 @@
|
|||||||
|
|
||||||
(defn hex->string [s]
|
(defn hex->string [s]
|
||||||
(when s
|
(when s
|
||||||
(.toAscii dependencies/Web3.prototype s)))
|
(let [hex (.toString s)]
|
||||||
|
(loop [res "" i (if (string/starts-with? hex hex-prefix) 2 0)]
|
||||||
|
(if (and (< i (.-length hex)))
|
||||||
|
(recur
|
||||||
|
(if (= (.substr hex i 2) "00")
|
||||||
|
res
|
||||||
|
(str res (.fromCharCode js/String (js/parseInt (.substr hex i 2) 16))))
|
||||||
|
(+ i 2))
|
||||||
|
res)))))
|
||||||
|
|
||||||
(defn hex->boolean [s]
|
(defn hex->boolean [s]
|
||||||
(= s "0x0"))
|
(= s "0x0"))
|
||||||
|
@ -12,3 +12,12 @@
|
|||||||
(ethereum/normalized-address address)
|
(ethereum/normalized-address address)
|
||||||
(ethereum/int->hex index))
|
(ethereum/int->hex index))
|
||||||
#(cb %1 (ethereum/hex->bignumber %2))))
|
#(cb %1 (ethereum/hex->bignumber %2))))
|
||||||
|
|
||||||
|
(defn token-uri [web3 contract tokenId cb]
|
||||||
|
(ethereum/call web3
|
||||||
|
(ethereum/call-params
|
||||||
|
contract
|
||||||
|
"tokenURI(uint256)"
|
||||||
|
(ethereum/int->hex tokenId))
|
||||||
|
(fn [v1 v2]
|
||||||
|
(cb v1 (ethereum/hex->string v2)))))
|
||||||
|
@ -422,7 +422,11 @@
|
|||||||
{:symbol :SUPR
|
{:symbol :SUPR
|
||||||
:nft? true
|
:nft? true
|
||||||
:name "SuperRare"
|
:name "SuperRare"
|
||||||
:address "0x41a322b28d0ff354040e2cbc676f0320d8c8850d"}])
|
:address "0x41a322b28d0ff354040e2cbc676f0320d8c8850d"}
|
||||||
|
{:symbol :KUDOS
|
||||||
|
:nft? true
|
||||||
|
:name "KudosToken"
|
||||||
|
:address "0x56c72cda0b04fc39a25d0b6a64fa258fad46d664"}])
|
||||||
:testnet
|
:testnet
|
||||||
(resolve-icons :testnet
|
(resolve-icons :testnet
|
||||||
[{:name "Status Test Token"
|
[{:name "Status Test Token"
|
||||||
@ -456,7 +460,11 @@
|
|||||||
[{:name "Moksha Coin"
|
[{:name "Moksha Coin"
|
||||||
:symbol :MOKSHA
|
:symbol :MOKSHA
|
||||||
:decimals 18
|
:decimals 18
|
||||||
:address "0x6ba7dc8dd10880ab83041e60c4ede52bb607864b"}])
|
:address "0x6ba7dc8dd10880ab83041e60c4ede52bb607864b"}
|
||||||
|
{:symbol :KUDOS
|
||||||
|
:nft? true
|
||||||
|
:name "KudosToken"
|
||||||
|
:address "0x93bB0AFbd0627Bbd3a6C72Bc318341D3A22e254a"}])
|
||||||
|
|
||||||
:custom []})
|
:custom []})
|
||||||
|
|
||||||
|
@ -487,6 +487,7 @@
|
|||||||
"currency-display-name-isk": "Iceland Krona",
|
"currency-display-name-isk": "Iceland Krona",
|
||||||
"connect-wnode-content": "Connect to {{name}}?",
|
"connect-wnode-content": "Connect to {{name}}?",
|
||||||
"view-cryptostrikers": "View in CryptoStrikers",
|
"view-cryptostrikers": "View in CryptoStrikers",
|
||||||
|
"view-gitcoin": "View in Gitcoin",
|
||||||
"view-superrare": "View in SuperRare",
|
"view-superrare": "View in SuperRare",
|
||||||
"add-network": "Add network",
|
"add-network": "Add network",
|
||||||
"unknown-status-go-error": "Unknown status-go error",
|
"unknown-status-go-error": "Unknown status-go error",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user