[#11218] Hard code fix for SUPR NFT support
Drop collectibles details support
This commit is contained in:
parent
ccd034e7a6
commit
e55cb6b47b
Binary file not shown.
After Width: | Height: | Size: 1.1 KiB |
|
@ -485,6 +485,10 @@
|
||||||
:nft? true
|
:nft? true
|
||||||
:name "SupeRare"
|
:name "SupeRare"
|
||||||
:address "0x41a322b28d0ff354040e2cbc676f0320d8c8850d"}
|
:address "0x41a322b28d0ff354040e2cbc676f0320d8c8850d"}
|
||||||
|
{:symbol :SUPRR
|
||||||
|
:nft? true
|
||||||
|
:name "SuperRare"
|
||||||
|
:address "0xb932a70a57673d89f4acffbe830e8ed7f75fb9e0"}
|
||||||
{:symbol :KDO
|
{:symbol :KDO
|
||||||
:nft? true
|
:nft? true
|
||||||
:name "KudosToken"
|
:name "KudosToken"
|
||||||
|
|
|
@ -48,7 +48,6 @@
|
||||||
[taoensso.timbre :as log]
|
[taoensso.timbre :as log]
|
||||||
status-im.waku.core
|
status-im.waku.core
|
||||||
status-im.wallet.choose-recipient.core
|
status-im.wallet.choose-recipient.core
|
||||||
status-im.wallet.collectibles.core
|
|
||||||
status-im.wallet.accounts.core
|
status-im.wallet.accounts.core
|
||||||
status-im.popover.core
|
status-im.popover.core
|
||||||
[status-im.keycard.core :as keycard]
|
[status-im.keycard.core :as keycard]
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
(ns status-im.ui.screens.routing.wallet-stack
|
(ns status-im.ui.screens.routing.wallet-stack
|
||||||
(:require [status-im.ui.screens.currency-settings.views :as currency-settings]
|
(:require [status-im.ui.screens.currency-settings.views :as currency-settings]
|
||||||
[status-im.ui.screens.wallet.collectibles.views :as collectibles]
|
|
||||||
[status-im.ui.screens.wallet.settings.views :as wallet-settings]
|
[status-im.ui.screens.wallet.settings.views :as wallet-settings]
|
||||||
[status-im.ui.screens.wallet.transactions.views :as wallet-transactions]
|
[status-im.ui.screens.wallet.transactions.views :as wallet-transactions]
|
||||||
[status-im.ui.screens.wallet.custom-tokens.views :as custom-tokens]
|
[status-im.ui.screens.wallet.custom-tokens.views :as custom-tokens]
|
||||||
|
@ -29,8 +28,6 @@
|
||||||
:component add-account/pin}
|
:component add-account/pin}
|
||||||
{:name :account-settings
|
{:name :account-settings
|
||||||
:component account-settings/account-settings}
|
:component account-settings/account-settings}
|
||||||
{:name :collectibles-list
|
|
||||||
:component collectibles/collectibles-list}
|
|
||||||
{:name :wallet-transaction-details
|
{:name :wallet-transaction-details
|
||||||
:component wallet-transactions/transaction-details}
|
:component wallet-transactions/transaction-details}
|
||||||
{:name :wallet-settings-assets
|
{:name :wallet-settings-assets
|
||||||
|
|
|
@ -15,11 +15,6 @@
|
||||||
[status-im.ui.screens.multiaccounts.recover.views :as recover.views]
|
[status-im.ui.screens.multiaccounts.recover.views :as recover.views]
|
||||||
[status-im.ui.screens.wallet.send.views :as wallet]
|
[status-im.ui.screens.wallet.send.views :as wallet]
|
||||||
[status-im.ui.components.status-bar.view :as statusbar]
|
[status-im.ui.components.status-bar.view :as statusbar]
|
||||||
status-im.ui.screens.wallet.collectibles.etheremon.views
|
|
||||||
status-im.ui.screens.wallet.collectibles.cryptostrikers.views
|
|
||||||
status-im.ui.screens.wallet.collectibles.cryptokitties.views
|
|
||||||
status-im.ui.screens.wallet.collectibles.superrare.views
|
|
||||||
status-im.ui.screens.wallet.collectibles.kudos.views
|
|
||||||
[status-im.ui.components.colors :as colors]
|
[status-im.ui.components.colors :as colors]
|
||||||
[status-im.keycard.test-menu :as keycard.test-menu]
|
[status-im.keycard.test-menu :as keycard.test-menu]
|
||||||
[quo.core :as quo]
|
[quo.core :as quo]
|
||||||
|
|
|
@ -80,26 +80,38 @@
|
||||||
colors/white-persist
|
colors/white-persist
|
||||||
#(re-frame/dispatch [:show-popover {:view :share-account :address address}])]]]))
|
#(re-frame/dispatch [:show-popover {:view :share-account :address address}])]]]))
|
||||||
|
|
||||||
(defn render-collectible [address]
|
(defn render-collectible [{:keys [name icon amount] :as collectible}]
|
||||||
(fn [{:keys [name icon amount] :as collectible}]
|
(let [items-number (money/to-fixed amount)]
|
||||||
(let [items-number (money/to-fixed amount)
|
[quo/list-item
|
||||||
details? (pos? items-number)]
|
{:title (wallet.utils/display-symbol collectible)
|
||||||
[quo/list-item
|
:subtitle name
|
||||||
{:title (wallet.utils/display-symbol collectible)
|
:icon [list/item-image icon]
|
||||||
:subtitle name
|
:accessory :text
|
||||||
:icon [list/item-image icon]
|
:accessory-text items-number}]))
|
||||||
:on-press (when details?
|
|
||||||
#(re-frame/dispatch
|
|
||||||
[:show-collectibles-list collectible address]))
|
|
||||||
:chevron :true
|
|
||||||
:accessory :text
|
|
||||||
:accessory-text items-number}])))
|
|
||||||
|
|
||||||
(views/defview transactions [address]
|
(views/defview transactions [address]
|
||||||
(views/letsubs [{:keys [transaction-history-sections]}
|
(views/letsubs [{:keys [transaction-history-sections]}
|
||||||
[:wallet.transactions.history/screen address]]
|
[:wallet.transactions.history/screen address]]
|
||||||
[history/history-list transaction-history-sections address]))
|
[history/history-list transaction-history-sections address]))
|
||||||
|
|
||||||
|
(defn collectibles-link []
|
||||||
|
[react/touchable-highlight
|
||||||
|
{:on-press #(re-frame/dispatch [:browser.ui/open-url "https://opensea.io/account/"])}
|
||||||
|
[react/view
|
||||||
|
{:style {:flex 1
|
||||||
|
:padding-horizontal 14
|
||||||
|
:flex-direction :row
|
||||||
|
:align-items :center
|
||||||
|
:background-color colors/blue-light
|
||||||
|
:height 52}}
|
||||||
|
[icons/tiny-icon
|
||||||
|
:tiny-icons/tiny-external
|
||||||
|
{:color colors/blue
|
||||||
|
:container-style {:margin-right 5}}]
|
||||||
|
[react/text
|
||||||
|
{:style {:color colors/blue}}
|
||||||
|
(i18n/label :t/check-on-opensea)]]])
|
||||||
|
|
||||||
(views/defview assets-and-collections [address]
|
(views/defview assets-and-collections [address]
|
||||||
(views/letsubs [{:keys [tokens nfts]} [:wallet/visible-assets-with-values address]
|
(views/letsubs [{:keys [tokens nfts]} [:wallet/visible-assets-with-values address]
|
||||||
currency [:wallet/currency]]
|
currency [:wallet/currency]]
|
||||||
|
@ -116,14 +128,16 @@
|
||||||
:key-fn :name
|
:key-fn :name
|
||||||
:render-fn (accounts/render-asset (:code currency))}]
|
:render-fn (accounts/render-asset (:code currency))}]
|
||||||
(= tab :nft)
|
(= tab :nft)
|
||||||
(if (seq nfts)
|
[react/view
|
||||||
[list/flat-list {:data nfts
|
[collectibles-link]
|
||||||
:default-separator? false
|
(if (seq nfts)
|
||||||
:key-fn :name
|
[list/flat-list {:data nfts
|
||||||
:render-fn (render-collectible address)}]
|
:default-separator? false
|
||||||
[react/view {:align-items :center :margin-top 32}
|
:key-fn :name
|
||||||
[react/text {:style {:color colors/gray}}
|
:render-fn render-collectible}]
|
||||||
(i18n/label :t/no-collectibles)]])
|
[react/view {:align-items :center :margin-top 32}
|
||||||
|
[react/text {:style {:color colors/gray}}
|
||||||
|
(i18n/label :t/no-collectibles)]])]
|
||||||
(= tab :history)
|
(= tab :history)
|
||||||
[transactions address])])))
|
[transactions address])])))
|
||||||
|
|
||||||
|
|
|
@ -1,27 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.cryptokitties.views
|
|
||||||
(:require [re-frame.core :as re-frame]
|
|
||||||
[status-im.i18n :as i18n]
|
|
||||||
[status-im.ui.components.react :as react]
|
|
||||||
[status-im.ui.screens.wallet.collectibles.styles :as styles]
|
|
||||||
[status-im.ui.screens.wallet.collectibles.views :as collectibles]
|
|
||||||
[status-im.ui.components.svgimage :as svgimage]
|
|
||||||
[quo.core :as quo]))
|
|
||||||
|
|
||||||
(defmethod collectibles/render-collectible :CK [_ {:keys [id name bio image_url]}]
|
|
||||||
[react/view {:style styles/details}
|
|
||||||
[react/view {:style styles/details-text}
|
|
||||||
[svgimage/svgimage {:style styles/details-image
|
|
||||||
:source {:uri image_url}}]
|
|
||||||
[react/view {:flex 1}
|
|
||||||
[react/text {:style styles/details-name}
|
|
||||||
(or name (i18n/label :t/cryptokitty-name {:id id}))]
|
|
||||||
[react/text {:number-of-lines 3
|
|
||||||
:ellipsize-mode :tail}
|
|
||||||
bio]]]
|
|
||||||
[quo/list-item
|
|
||||||
{:theme :accent
|
|
||||||
:title (i18n/label :t/view-cryptokitties)
|
|
||||||
:icon :main-icons/address
|
|
||||||
:accessibility-label :open-collectible-button
|
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
|
||||||
(str "https://www.cryptokitties.co/kitty/" id)])}]])
|
|
|
@ -1,26 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.cryptostrikers.views
|
|
||||||
(:require [re-frame.core :as re-frame]
|
|
||||||
[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.screens.wallet.collectibles.views :as collectibles]
|
|
||||||
[status-im.i18n :as i18n]
|
|
||||||
[quo.core :as quo]))
|
|
||||||
|
|
||||||
(defmethod collectibles/render-collectible :STRK [_ {: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]]]
|
|
||||||
[quo/list-item
|
|
||||||
{:theme :accent
|
|
||||||
:title (i18n/label :t/view-cryptostrikers)
|
|
||||||
:icon :main-icons/address
|
|
||||||
:accessibility-label :open-collectible-button
|
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser external_url])}]])
|
|
|
@ -1,26 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.etheremon.views
|
|
||||||
(:require [re-frame.core :as re-frame]
|
|
||||||
[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.screens.wallet.collectibles.views :as collectibles]
|
|
||||||
[status-im.i18n :as i18n]
|
|
||||||
[quo.core :as quo]))
|
|
||||||
|
|
||||||
(defmethod collectibles/render-collectible :EMONA [_ {:keys [user_defined_name image class_id]}]
|
|
||||||
[react/view {:style styles/details}
|
|
||||||
[react/view {:style styles/details-text}
|
|
||||||
[react/view {:flex 1}
|
|
||||||
[svgimage/svgimage {:style styles/details-image
|
|
||||||
:source {:uri image
|
|
||||||
:k 2}}]]
|
|
||||||
[react/view {:flex 1 :justify-content :center}
|
|
||||||
[react/text {:style styles/details-name}
|
|
||||||
user_defined_name]]]
|
|
||||||
[quo/list-item
|
|
||||||
{:theme :accent
|
|
||||||
:title (i18n/label :t/view-etheremon)
|
|
||||||
:icon :main-icons/address
|
|
||||||
:accessibility-label :open-collectible-button
|
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
|
||||||
(str "https://www.etheremon.com/#/mons/" class_id)])}]])
|
|
|
@ -1,26 +0,0 @@
|
||||||
(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]
|
|
||||||
[re-frame.core :as re-frame]
|
|
||||||
[status-im.i18n :as i18n]
|
|
||||||
[quo.core :as quo]))
|
|
||||||
|
|
||||||
(defmethod collectibles/render-collectible :KDO [_ {: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]]]
|
|
||||||
[quo/list-item
|
|
||||||
{:theme :accent
|
|
||||||
:title (i18n/label :t/view-gitcoin)
|
|
||||||
:icon :main-icons/address
|
|
||||||
:accessibility-label :open-collectible-button
|
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser external_url])}]])
|
|
|
@ -1,27 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.styles)
|
|
||||||
|
|
||||||
(def default-collectible
|
|
||||||
{:padding-left 10
|
|
||||||
:padding-vertical 20})
|
|
||||||
|
|
||||||
(def loading-indicator
|
|
||||||
{:flex 1
|
|
||||||
:align-items :center
|
|
||||||
:justify-content :center})
|
|
||||||
|
|
||||||
(def details
|
|
||||||
{:padding-vertical 10})
|
|
||||||
|
|
||||||
(def details-text
|
|
||||||
{:flex 1
|
|
||||||
:flex-direction :row
|
|
||||||
:align-items :center
|
|
||||||
:padding-horizontal 16})
|
|
||||||
|
|
||||||
(def details-name
|
|
||||||
{:text-align-vertical :center
|
|
||||||
:margin-bottom 10})
|
|
||||||
|
|
||||||
(def details-image
|
|
||||||
{:flex 1
|
|
||||||
:margin 10})
|
|
|
@ -1,26 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.superrare.views
|
|
||||||
(:require [re-frame.core :as re-frame]
|
|
||||||
[status-im.i18n :as i18n]
|
|
||||||
[status-im.ui.components.react :as react]
|
|
||||||
[status-im.ui.screens.wallet.collectibles.styles :as styles]
|
|
||||||
[status-im.ui.screens.wallet.collectibles.views :as collectibles]
|
|
||||||
[quo.core :as quo]))
|
|
||||||
|
|
||||||
(defmethod collectibles/render-collectible :SUPR [_ {tokenId :tokenId {:keys [description name imageUri]} :metadata}]
|
|
||||||
[react/view {:style styles/details}
|
|
||||||
[react/view {:style styles/details-text}
|
|
||||||
[react/image {:style (merge {:resize-mode :contain :width 100 :height 100} styles/details-image)
|
|
||||||
:source {:uri imageUri
|
|
||||||
:k 1.4}}]
|
|
||||||
[react/view {:flex 1 :justify-content :center}
|
|
||||||
[react/text {:style styles/details-name}
|
|
||||||
name]
|
|
||||||
[react/text
|
|
||||||
description]]]
|
|
||||||
[quo/list-item
|
|
||||||
{:theme :accent
|
|
||||||
:title (i18n/label :t/view-superrare)
|
|
||||||
:icon :main-icons/address
|
|
||||||
:accessibility-label :open-collectible-button
|
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
|
||||||
(str "https://superrare.co/artwork/" name "-" tokenId)])}]])
|
|
|
@ -1,34 +0,0 @@
|
||||||
(ns status-im.ui.screens.wallet.collectibles.views
|
|
||||||
(:require-macros [status-im.utils.views :refer [defview letsubs]])
|
|
||||||
(:require [status-im.i18n :as i18n]
|
|
||||||
[status-im.ui.components.colors :as colors]
|
|
||||||
[status-im.ui.components.list.views :as list]
|
|
||||||
[status-im.ui.components.react :as react]
|
|
||||||
[status-im.ui.components.styles :as component.styles]
|
|
||||||
[status-im.ui.screens.wallet.collectibles.styles :as styles]
|
|
||||||
[status-im.ui.components.topbar :as topbar]))
|
|
||||||
|
|
||||||
(defmulti render-collectible (fn [symbol _] symbol))
|
|
||||||
|
|
||||||
(defmethod render-collectible :default [symbol {:keys [id name]}]
|
|
||||||
[react/view {:style styles/default-collectible}
|
|
||||||
[react/text (str (clojure.core/name symbol) " #" (or id name))]])
|
|
||||||
|
|
||||||
(defview collectibles-list []
|
|
||||||
(letsubs [{:keys [name symbol]} [:get-screen-params]
|
|
||||||
collectibles [:screen-collectibles]]
|
|
||||||
[react/view {:style component.styles/flex}
|
|
||||||
[topbar/topbar {:title name}]
|
|
||||||
(cond
|
|
||||||
(nil? collectibles)
|
|
||||||
[react/view {:style styles/loading-indicator}
|
|
||||||
[react/activity-indicator {:animating true :size :large :color colors/blue}]]
|
|
||||||
(seq collectibles)
|
|
||||||
[list/flat-list {:data collectibles
|
|
||||||
:key-fn (comp str :id)
|
|
||||||
:render-fn #(render-collectible symbol %)}]
|
|
||||||
:else
|
|
||||||
;; Should never happen. Less confusing to debug new NFT support.
|
|
||||||
[react/view {:style styles/loading-indicator}
|
|
||||||
[react/text (i18n/label :t/error)]])]))
|
|
||||||
|
|
|
@ -1,197 +0,0 @@
|
||||||
(ns status-im.wallet.collectibles.core
|
|
||||||
(:require [re-frame.core :as re-frame]
|
|
||||||
[status-im.browser.core :as browser]
|
|
||||||
[status-im.ethereum.core :as ethereum]
|
|
||||||
[status-im.ethereum.erc721 :as erc721]
|
|
||||||
[status-im.ethereum.tokens :as tokens]
|
|
||||||
[status-im.utils.handlers :as handlers]
|
|
||||||
[status-im.utils.money :as money]
|
|
||||||
[status-im.utils.http :as http]
|
|
||||||
[clojure.string :as string]
|
|
||||||
[status-im.utils.types :as types]))
|
|
||||||
|
|
||||||
;;TODO: REPLACE ALL HANDLERS BY FX/DEFN
|
|
||||||
|
|
||||||
(defmulti load-collectible-fx (fn [_ symbol _] symbol))
|
|
||||||
|
|
||||||
(defmethod load-collectible-fx :default [_ _ _] nil)
|
|
||||||
|
|
||||||
(defmulti load-collectibles-fx (fn [_ symbol _ _ _] symbol))
|
|
||||||
|
|
||||||
(defmethod load-collectibles-fx :default [all-tokens symbol items-number address]
|
|
||||||
{:load-collectibles-fx [all-tokens symbol items-number address]})
|
|
||||||
|
|
||||||
(defn load-token [i items-number contract address symbol]
|
|
||||||
(when (< i items-number)
|
|
||||||
(erc721/token-of-owner-by-index contract address i
|
|
||||||
(fn [response]
|
|
||||||
(load-token (inc i) items-number contract address symbol)
|
|
||||||
(re-frame/dispatch [:load-collectible symbol response])))))
|
|
||||||
|
|
||||||
(re-frame/reg-fx
|
|
||||||
:load-collectibles-fx
|
|
||||||
(fn [[all-tokens symbol items-number address]]
|
|
||||||
(let [contract (:address (tokens/symbol->token all-tokens symbol))]
|
|
||||||
(load-token 0 items-number contract address symbol))))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:show-collectibles-list
|
|
||||||
(fn [{:keys [db]} [_ {:keys [symbol amount] :as collectible} address]]
|
|
||||||
(let [all-tokens (:wallet/all-tokens db)
|
|
||||||
items-number (money/to-number amount)
|
|
||||||
loaded-items-number (count (get-in db [:collectibles symbol]))]
|
|
||||||
(merge (when (not= items-number loaded-items-number)
|
|
||||||
(load-collectibles-fx all-tokens symbol items-number address))
|
|
||||||
{:dispatch [:navigate-to :collectibles-list collectible]}))))
|
|
||||||
|
|
||||||
;; Crypto Kitties
|
|
||||||
(def ck :CK)
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:load-kitties
|
|
||||||
(fn [{db :db} [_ ids]]
|
|
||||||
{:db (update-in db [:collectibles] merge {ck (sorted-map-by >)})
|
|
||||||
:http-get-n (mapv (fn [id]
|
|
||||||
{:url (str "https://api.cryptokitties.co/kitties/" id)
|
|
||||||
:on-success (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-success ck {id (http/parse-payload o)}]))
|
|
||||||
:on-error (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-failure ck {id (http/parse-payload o)}]))})
|
|
||||||
ids)}))
|
|
||||||
|
|
||||||
(defmethod load-collectibles-fx ck [_ _ items-number address _]
|
|
||||||
{:http-get-n (mapv (fn [offset]
|
|
||||||
{:url (str "https://api.cryptokitties.co/kitties?limit=20&offset="
|
|
||||||
offset
|
|
||||||
"&owner_wallet_address="
|
|
||||||
address
|
|
||||||
"&parents=false")
|
|
||||||
:on-success (fn [o]
|
|
||||||
(re-frame/dispatch [:load-kitties (map :id (:kitties (http/parse-payload o)))]))
|
|
||||||
:on-error (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectibles-failure (http/parse-payload o)]))
|
|
||||||
:timeout-ms 10000})
|
|
||||||
(range 0 items-number 20))}) ;; Cryptokitties API limited to 20 items per request
|
|
||||||
|
|
||||||
;; Crypto Strikers
|
|
||||||
(def strikers :STRK)
|
|
||||||
|
|
||||||
(defmethod load-collectible-fx strikers [_ _ id]
|
|
||||||
{:http-get {:url (str "https://us-central1-cryptostrikers-prod.cloudfunctions.net/cards/" id)
|
|
||||||
:on-success (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-success strikers {id (http/parse-payload o)}]))
|
|
||||||
:on-error (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-failure strikers {id (http/parse-payload o)}]))}})
|
|
||||||
|
|
||||||
;;Etheremona
|
|
||||||
(def emona :EMONA)
|
|
||||||
|
|
||||||
(defmethod load-collectible-fx emona [_ _ id]
|
|
||||||
{:http-get {:url (str "https://www.etheremon.com/api/monster/get_data?monster_ids=" id)
|
|
||||||
:on-success (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-success emona (:data (http/parse-payload o))]))
|
|
||||||
:on-error (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-failure emona {id (http/parse-payload o)}]))}})
|
|
||||||
|
|
||||||
;;Kudos
|
|
||||||
(def kudos :KDO)
|
|
||||||
|
|
||||||
(defmethod load-collectible-fx kudos [{db :db} symbol id]
|
|
||||||
{:erc721-token-uri [(:wallet/all-tokens db) symbol id]})
|
|
||||||
|
|
||||||
(re-frame/reg-fx
|
|
||||||
:erc721-token-uri
|
|
||||||
(fn [[all-tokens symbol tokenId]]
|
|
||||||
(let [contract (:address (tokens/symbol->token all-tokens symbol))]
|
|
||||||
(erc721/token-uri contract
|
|
||||||
tokenId
|
|
||||||
#(re-frame/dispatch [:token-uri-success
|
|
||||||
tokenId
|
|
||||||
(when %
|
|
||||||
(subs % (.indexOf ^js % "http")))]))))) ;; extra chars in rinkeby
|
|
||||||
|
|
||||||
;;Superrare
|
|
||||||
(def superrare :SUPR)
|
|
||||||
|
|
||||||
(defmethod load-collectible-fx superrare [_ _ ids]
|
|
||||||
{:http-get-n (mapv (fn [id]
|
|
||||||
{:url id
|
|
||||||
:on-success (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-success superrare {id (http/parse-payload o)}]))
|
|
||||||
:on-error (fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-failure superrare {id (http/parse-payload o)}]))})
|
|
||||||
ids)})
|
|
||||||
|
|
||||||
(def graphql-url "https://api.pixura.io/graphql")
|
|
||||||
|
|
||||||
(defn graphql-query [address]
|
|
||||||
(str "{
|
|
||||||
collectiblesByOwner: allErc721Tokens(condition: {owner: \"" address "\"}) {
|
|
||||||
collectibles: nodes {
|
|
||||||
tokenId,
|
|
||||||
metadata: erc721MetadatumByTokenId {
|
|
||||||
metadataUri,
|
|
||||||
description,
|
|
||||||
name,
|
|
||||||
imageUri
|
|
||||||
}}}}"))
|
|
||||||
|
|
||||||
(defmethod load-collectibles-fx superrare [_ _ _ address _]
|
|
||||||
{:http-post {:url graphql-url
|
|
||||||
:data (types/clj->json {:query (graphql-query (ethereum/naked-address address))})
|
|
||||||
:opts {:headers {"Content-Type" "application/json"}}
|
|
||||||
:on-success (fn [{:keys [response-body]}]
|
|
||||||
(re-frame/dispatch [:store-collectibles superrare
|
|
||||||
(get-in (http/parse-payload response-body)
|
|
||||||
[:data :collectiblesByOwner :collectibles])]))
|
|
||||||
:on-error (fn [{:keys [response-body]}]
|
|
||||||
(re-frame/dispatch [:load-collectibles-failure (http/parse-payload response-body)]))
|
|
||||||
:timeout-ms 10000}})
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:token-uri-success
|
|
||||||
(fn [_ [_ tokenId token-uri]]
|
|
||||||
{:http-get {:url
|
|
||||||
token-uri
|
|
||||||
:on-success
|
|
||||||
(fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-success kudos
|
|
||||||
{tokenId (update (http/parse-payload o)
|
|
||||||
:image
|
|
||||||
string/replace
|
|
||||||
#"http:"
|
|
||||||
"https:")}])) ;; http in mainnet
|
|
||||||
:on-error
|
|
||||||
(fn [o]
|
|
||||||
(re-frame/dispatch [:load-collectible-failure kudos {tokenId (http/parse-payload o)}]))}}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:load-collectible
|
|
||||||
(fn [cofx [_ symbol token-id]]
|
|
||||||
(load-collectible-fx cofx symbol token-id)))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:store-collectibles
|
|
||||||
(fn [{db :db} [_ symbol collectibles]]
|
|
||||||
{:db (update-in db [:collectibles symbol] merge
|
|
||||||
(reduce #(assoc %1 (:tokenId %2) %2) {} collectibles))}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:load-collectible-success
|
|
||||||
(fn [{db :db} [_ symbol collectibles]]
|
|
||||||
{:db (update-in db [:collectibles symbol] merge collectibles)}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:load-collectibles-failure
|
|
||||||
(fn [{db :db} [_ reason]]
|
|
||||||
{:db (update-in db [:collectibles symbol :errors] merge reason)}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:load-collectible-failure
|
|
||||||
(fn [{db :db} [_]]
|
|
||||||
{:db db}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
|
||||||
:open-collectible-in-browser
|
|
||||||
(fn [cofx [_ url]]
|
|
||||||
(browser/open-url cofx url)))
|
|
|
@ -88,7 +88,7 @@
|
||||||
|
|
||||||
(defn- validate-token-symbol!
|
(defn- validate-token-symbol!
|
||||||
[{:keys [address symbol]}]
|
[{:keys [address symbol]}]
|
||||||
(when-not (= symbol :DCN) ;; ignore this symbol because it has weird symbol
|
(when-not (or (= symbol :DCN) (= symbol :SUPRR)) ;; ignore this symbol because it has weird symbol
|
||||||
(json-rpc/eth-call
|
(json-rpc/eth-call
|
||||||
{:contract address
|
{:contract address
|
||||||
:method "symbol()"
|
:method "symbol()"
|
||||||
|
|
|
@ -1203,6 +1203,7 @@
|
||||||
"cant-report-bug": "Can't report a bug",
|
"cant-report-bug": "Can't report a bug",
|
||||||
"mail-should-be-configured": "Mail client should be configured",
|
"mail-should-be-configured": "Mail client should be configured",
|
||||||
"check-on-etherscan": "Check on etherscan",
|
"check-on-etherscan": "Check on etherscan",
|
||||||
|
"check-on-opensea": "Check on opensea",
|
||||||
"transactions-load-more": "Load more",
|
"transactions-load-more": "Load more",
|
||||||
"private-key": "Private key",
|
"private-key": "Private key",
|
||||||
"generate-an-account": "Generate an account",
|
"generate-an-account": "Generate an account",
|
||||||
|
|
Loading…
Reference in New Issue