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]()
+
( $ {{ 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,'----')
}