diff --git a/src/components/chain/Market.js b/src/components/chain/Market.js index 51605b5..477e117 100644 --- a/src/components/chain/Market.js +++ b/src/components/chain/Market.js @@ -1,5 +1,7 @@ import { baseConfig } from './wallet/PassportWallet'; import { orderbook } from '@imtbl/sdk'; +import { queryTokenPriceCg } from "@/components/chain/utils" +import {useMarketplaceStore} from "@/store/marketplace"; const makeFeeAddress = import.meta.env.VUE_APP_MAKEFEE_ADDRESS const NATIVE = 'NATIVE' const ERC20 = 'ERC20' @@ -8,6 +10,8 @@ export class ImtblMarket { constructor(_chainInstance) { this.client = new orderbook.Orderbook({ baseConfig }); this.bc = _chainInstance + this.marketStore = useMarketplaceStore(); + this.updateCurrencyPrice(); } updateProvider(provider) { @@ -226,4 +230,17 @@ export class ImtblMarket { const receipt = await this.signer.sendTransaction(unsignedCancelOrderTransaction); return receipt; } + + async updateCurrencyPrice() { + const ids = ['immutable-x', 'ethereum', 'usd-coin'] + let priceList = await queryTokenPriceCg(ids); + priceList = priceList.map((item) => { + return { + id: item.id, + price: item.current_price + } + }) + this.marketStore.currencyPrice = priceList; + return priceList; + } } diff --git a/src/components/chain/utils.js b/src/components/chain/utils.js index 789fbbb..66532f0 100644 --- a/src/components/chain/utils.js +++ b/src/components/chain/utils.js @@ -6,6 +6,10 @@ import { ethers } from 'ethers'; import assert from 'assert' import { AllChains } from "@/configs/allchain"; import { Deferred } from '@/utils/promise.util'; +import { CURRENCYS } from "@/configs/configchain"; +import { useMarketplaceStore } from "@/store/marketplace" +import {priceCalculated} from "@/configs/priceCalculate.js" + export const cfgChainId = parseInt(import.meta.env.VUE_APP_NET_ID); @@ -20,6 +24,9 @@ for (const d of AllChains) { } assert(chainCfg, 'chain config not found'); +export const currencyMap = CURRENCYS[cfgChainId] +assert(currencyMap, 'currencys not configured') + export const currentChainCfg = chainCfg; @@ -57,6 +64,16 @@ export const genRefreshToken = async(refreshToken) => { } return res.data; } +/** + * query token->usd price from coingecko + * @param {*} ids + * @returns + */ +export const queryTokenPriceCg = async(ids) => { + const idstr = ids.join(','); + const url = `https://api.coingecko.com/api/v3/coins/markets?vs_currency=USD&ids=${idstr}` + return fetch(url).then(res => res.json()); +} const utf8ToHex = (str) => { return '0x' + Buffer.from(str).toString('hex'); @@ -185,4 +202,34 @@ export const switchEthereumChain = async (provider, targetChainId) => { } } return deferred.promise +} + +export const formatPrice = (data) => { + const marketplaceList = useMarketplaceStore() + const type = data.item_type + let address; + let icon, price, usd + const tokenAmount = priceCalculated(data.amount, 3) + const amount = parseFloat(ethers.utils.formatUnits(data.amount, 18)) + if (type == 'NATIVE') { + address = 'NATIVE' + } else if (type == 'ERC20') { + address = data.contract_address + if (address) { + address = address.toLowerCase() + } + } + if (!address) { + return {icon, price} + } + if (address) { + const currencyData = currencyMap[address] + if (currencyData) { + const currencyPrice = marketplaceList.priceDatas + icon = currencyData.icon + price = currencyPrice.find(o => o.id == currencyData.id_query) + usd = (amount * price.price).toFixed(2) + } + } + return {icon, price, usd, tokenAmount} } \ No newline at end of file diff --git a/src/components/common/card.vue b/src/components/common/card.vue index 8755c21..78da33f 100644 --- a/src/components/common/card.vue +++ b/src/components/common/card.vue @@ -13,7 +13,7 @@ {{ priceCalculated(nftData.event.data.buy[0].amount) }} - 图片 + 图片
{{ nftData.nft.owner_address.substr(0,4) }}...{{ nftData.nft.owner_address.substr(-4) }}
@@ -47,9 +47,11 @@ import { const localWalletStore = walletStore() const marketplaceList = useMarketplaceStore() import {createModal} from "@/utils/model.util"; +import {formatPrice} from "@/components/chain/utils" const emit = defineEmits(['renewNft']) import { useRouter } from "vue-router"; const router = useRouter(); +const icon = ref('') const { proxy } = getCurrentInstance(); const props = defineProps({ nftData: { @@ -118,6 +120,10 @@ const addCart = async (val) => { onMounted(() => { // console.log(JSON.parse(JSON.stringify(props.nftData)), "-=-=-"); + if (props.nftData?.event?.data?.buy && props.nftData?.event?.data?.buy.length > 0) { + const data = formatPrice(props.nftData?.event?.data?.buy[0]) + icon.value = data.icon + } }); diff --git a/src/configs/configchain.js b/src/configs/configchain.js index fc51fe7..c705218 100644 --- a/src/configs/configchain.js +++ b/src/configs/configchain.js @@ -20,6 +20,70 @@ export const ALL_PROVIDERS = [ }, ]; +export const icon_imx = '' +export const icon_usdc = '' +export const icon_eth = '' + +export const CURRENCYS = { + 13473: { + 'NATIVE': { + name: 'tIMX', + decimals: 18, + icon: icon_imx, + id_query: 'immutable-x' + }, + "0xe9e96d1aad82562b7588f03f49ad34186f996478": { + name: 'ETH', + decimals: 18, + icon: icon_eth, + id_query: 'ethereum' + }, + "0x3b2d8a1931736fc321c24864bceee981b11c3c57": { + name: 'USDC', + decimals: 18, + icon: icon_usdc, + id_query: 'usd-coin' + }, + "0x1ccca691501174b4a623ceda58cc8f1a76dc3439": { + name: 'WIMX', + decimals: 18, + icon: icon_imx, + id_query: 'immutable-x' + }, + "0xfd42bfb03212da7e1a4608a44d7658641d99cf34": { + name: 'cETH', + decimals: 18, + icon: icon_eth, + id_query: 'ethereum' + }, + }, + 13471: { + 'NATIVE': { + name: 'tIMX', + decimals: 18, + icon: icon_imx, + id_query: 'immutable-x' + }, + "0x52a6c53869ce09a731cd772f245b97a4401d3348": { + name: 'ETH', + decimals: 18, + icon: icon_eth, + id_query: 'ethereum' + }, + "0x6de8acc0d406837030ce4dd28e7c08c5a96a30d2": { + name: 'USDC', + decimals: 18, + icon: icon_usdc, + id_query: 'usd-coin' + }, + "0x3a0c2ba54d6cbd3121f01b96dfd20e99d1696c9d": { + name: 'WIMX', + decimals: 18, + icon: icon_imx, + id_query: 'immutable-x' + }, + } +} export default { ALL_PROVIDERS, diff --git a/src/configs/priceCalculate.js b/src/configs/priceCalculate.js index 0159e1e..974275d 100644 --- a/src/configs/priceCalculate.js +++ b/src/configs/priceCalculate.js @@ -2,8 +2,17 @@ import moment from "moment" import { ethers } from "ethers" // 计算价格精度 -export const priceCalculated = (price) => { - return ethers.utils.formatUnits(price, 18) +export const priceCalculated = (price, n) => { + n = n || 3 + console.log('priceCalculated') + let str = ethers.utils.formatUnits(price, 18) + if (str.indexOf('.') > -1) { + str = str.slice(0, str.indexOf('.') + n + 1) + } + if (str === '0.000') { + str = '<0.001' + } + return str } export const timeFormat = (value) => { diff --git a/src/store/marketplace.js b/src/store/marketplace.js index 1a2cabf..94aae0f 100644 --- a/src/store/marketplace.js +++ b/src/store/marketplace.js @@ -1,5 +1,5 @@ import { defineStore } from 'pinia'; -import { ref } from 'vue'; +import { ref, toRaw, computed } from 'vue'; import { apiMarketplaceState, apiGetCartList, apiAddCartList, apiDelCartList } from "@/utils/marketplace" export const useMarketplaceStore = defineStore('marketplace', () => { @@ -12,6 +12,7 @@ export const useMarketplaceStore = defineStore('marketplace', () => { const gold = ref([]) const status = ref([]) const getCartList = ref([]) + const currencyPrice = ref([]) const updateOverviewStatus = (_connected) => { overview.value = _connected; } @@ -37,6 +38,10 @@ export const useMarketplaceStore = defineStore('marketplace', () => { status.value = _connected; } + const priceDatas = computed(() => { + return toRaw(currencyPrice.value) + }) + async function getMarketplaceState(_connected) { return await apiMarketplaceState(_connected) } @@ -66,6 +71,7 @@ export const useMarketplaceStore = defineStore('marketplace', () => { getCartList, getCartListState, addCartListState, delCartListState, + currencyPrice,priceDatas } }, { diff --git a/src/views/DetailView.vue b/src/views/DetailView.vue index 58b34c7..dff7854 100644 --- a/src/views/DetailView.vue +++ b/src/views/DetailView.vue @@ -25,8 +25,8 @@
  • {{ priceCalculated(detailData.event.data.buy[0].amount) }}  - ICON - + ICON + ( $ {{ usd }} )
  • @@ -149,6 +149,7 @@ import {priceCalculated} from "@/configs/priceCalculate.js" import { BlockChain } from "@/components/chain/BlockChain" import {walletStore} from "@/store/wallet"; import LazyLoadImg from "@/components/lazyloadimg" +import {formatPrice} from "@/components/chain/utils" const router = useRouter(); const localWalletStore = walletStore() const props = defineProps({ @@ -159,6 +160,8 @@ import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png' const detailData = ref(null) const myAddress = localWalletStore.address const nftAbilities = ref() +const icon = ref('') +const usd = ref('') // 购买 const buyNow = async () => { @@ -291,6 +294,11 @@ const getDetail = async () => { nftData.event = data.event nftAbilities.value = data.nft.detail detailData.value = data + if (data.event?.data?.buy && data.event?.data?.buy.length > 0) { + const _data = formatPrice(data.event?.data?.buy[0]) + icon.value = _data.icon + usd.value = _data.usd + } console.log(data,'----') }