From 74a16a3d0c5906b2190528b9619c77c6a7f42c63 Mon Sep 17 00:00:00 2001 From: nick134 <76399455+nick134-bit@users.noreply.github.com> Date: Tue, 30 Jul 2024 15:41:29 +0200 Subject: [PATCH 1/5] feat: aw --- components/Finder.tsx | 2 + components/Layout/RadialGradient.tsx | 5 +- .../Pages/Trade/Swap/defaultTokens.json | 10 ++++ constants/endpoints.json | 10 +++- constants/networks.ts | 8 ++- constants/vaultRouterAddresses.json | 4 +- public/mainnet/archway-1/config.json | 41 ++++++++++++++++ public/mainnet/archway-1/pools_list.json | 31 ++++++++++++ public/mainnet/archway-1/vaults_list.json | 5 ++ public/mainnet/chain_info.json | 49 +++++++++++++++++++ util/getChainLogoUrlByName.ts | 2 + util/getColorByChainName.ts | 4 ++ 12 files changed, 165 insertions(+), 6 deletions(-) create mode 100644 public/mainnet/archway-1/config.json create mode 100644 public/mainnet/archway-1/pools_list.json create mode 100644 public/mainnet/archway-1/vaults_list.json diff --git a/components/Finder.tsx b/components/Finder.tsx index ad83f9ca..bf13964b 100644 --- a/components/Finder.tsx +++ b/components/Finder.tsx @@ -38,6 +38,8 @@ const getUrl = (chainId: string, txHash: string) => { return `https://ping.pub/terra-luna/tx/${txHash}` case ChainId.osmosis: return `https://mintscan.io/osmosis/txs/${txHash}` + case ChainId.archway: + return `https://mintscan.io/archway/txs/${txHash}` default: return null } diff --git a/components/Layout/RadialGradient.tsx b/components/Layout/RadialGradient.tsx index f0222ef0..e967f8da 100644 --- a/components/Layout/RadialGradient.tsx +++ b/components/Layout/RadialGradient.tsx @@ -35,7 +35,10 @@ export const backgrounds = { 'linear-gradient(90deg, rgba(60, 205, 100, 0.25) 2.83%, rgba(255, 255, 0, 0.25) 50%, rgba(0, 117, 255, 0.25) 97.47%)', 'osmosis-1': 'linear-gradient(135deg, rgba(255, 20, 147, 0.8) 0%, rgba(147, 112, 219, 0.8) 50%, rgba(255, 20, 147, 0.8) 100%)', -} +// TODO ARCHWAY + 'archway-1': + 'linear-gradient(135deg, rgba(255, 20, 147, 0.8) 0%, rgba(147, 112, 219, 0.8) 50%, rgba(255, 20, 147, 0.8) 100%)', + } const RadialGradient: FC = () => { const { chainId } = useRecoilValue(chainState) diff --git a/components/Pages/Trade/Swap/defaultTokens.json b/components/Pages/Trade/Swap/defaultTokens.json index 22adb939..7a9d48dd 100644 --- a/components/Pages/Trade/Swap/defaultTokens.json +++ b/components/Pages/Trade/Swap/defaultTokens.json @@ -89,6 +89,16 @@ "tokenSymbol": "WHALE", "amount": 0 } + ], + "archway": [ + { + "tokenSymbol": "ampWHALE", + "amount": 0 + }, + { + "tokenSymbol": "WHALE", + "amount": 0 + } ] }, "testnet": { diff --git a/constants/endpoints.json b/constants/endpoints.json index 77ebd3cf..f98f87a8 100644 --- a/constants/endpoints.json +++ b/constants/endpoints.json @@ -70,5 +70,13 @@ "rest": [ "https://osmosis-rest.publicnode.com" ] + }, + "archway": { + "rpc": [ + "https://archway.rpc.kjnodes.com" + ], + "rest": [ + "https://archway.api.kjnodes.com" + ] } -} \ No newline at end of file +} diff --git a/constants/networks.ts b/constants/networks.ts index 8d4f33d3..b2526f5c 100644 --- a/constants/networks.ts +++ b/constants/networks.ts @@ -9,6 +9,7 @@ export const ACTIVE_NETWORKS = { sei: 'pacific-1', 'terra-classic': 'columbus-5', osmosis: 'osmosis-1', + archway: 'archway-1', }, testnet: { comdex: 'comdex-test2', @@ -32,6 +33,7 @@ export const ACTIVE_NETWORKS_WALLET_NAMES = { 'sei', 'terra', 'osmosis', + 'archway', ], testnet: [ 'injectivetestnet', @@ -59,6 +61,7 @@ export const WALLET_CHAIN_NAMES_BY_CHAIN_ID = { 'atlantic-1': 'seitestnet', 'rebel-2': 'terra', 'osmosis-1': 'osmosis', + 'archway-1': 'archway', } export const ACTIVE_BONDING_NETWORKS = [ @@ -71,6 +74,7 @@ export const ACTIVE_BONDING_NETWORKS = [ 'columbus-5', 'injective-1', 'osmosis-1', + 'archway-1', ] export const ACTIVE_INCENTIVE_NETWORKS = [ 'chihuahua-1', @@ -113,6 +117,6 @@ export const NETWORK_MAP = { } // Chain names by cosmos kit -export enum WalletChainName { terrac = 'terra', terra = 'terra2', migaloo= 'migaloo', juno= 'juno', sei= 'sei', comdex= 'comdex', injective= 'injective', chihuahua= 'chihuahua', osmosis= 'osmosis' } +export enum WalletChainName { terrac = 'terra', terra = 'terra2', migaloo= 'migaloo', juno= 'juno', sei= 'sei', comdex= 'comdex', injective= 'injective', chihuahua= 'chihuahua', osmosis= 'osmosis', archway= 'archway' } export const CHAIN_NAMES = [...ACTIVE_NETWORKS_WALLET_NAMES.mainnet, ...ACTIVE_NETWORKS_WALLET_NAMES.testnet] -export enum ChainId { terrac = 'columbus-5', terra = 'phoenix-1', migaloo = 'migaloo-1', juno = 'juno-1', sei = 'pacific-1', comdex = 'comdex-1', injective = 'injective-1', chihuahua = 'chihuahua-1', narwhal = 'narwhal-1', pisco = 'pisco-1', osmosis = 'osmosis-1' } +export enum ChainId { terrac = 'columbus-5', terra = 'phoenix-1', migaloo = 'migaloo-1', juno = 'juno-1', sei = 'pacific-1', comdex = 'comdex-1', injective = 'injective-1', chihuahua = 'chihuahua-1', narwhal = 'narwhal-1', pisco = 'pisco-1', osmosis = 'osmosis-1', archway = "archway-1" } diff --git a/constants/vaultRouterAddresses.json b/constants/vaultRouterAddresses.json index 6b1b4837..dbda366e 100644 --- a/constants/vaultRouterAddresses.json +++ b/constants/vaultRouterAddresses.json @@ -4,5 +4,5 @@ "chihuahua-1": "chihuahua1qe6jsllyvrlmtz2xqef9k7q67xeyj3zcuc09wzptnvev3wyyd4fs4y4ce9", "injective-1": "inj1hyja4uyjktpeh0fxzuw2fmjudr85rk2qxgqkvu", "migaloo-1": "migaloo19pze0n07guzj6yla2708q2feh38q9n8gxmkk8fjnuprfh6y9ngjqs90hcy", - "osmosis-1": "osmo1ldkya0zakj380tlkd7dry0wj689t0r4x0kyxf6qn4pvvaat0l9tqsly68j" -} \ No newline at end of file + "osmosis-1": "osmo1ldkya0zakj380tlkd7dry0wj689t0r4x0kyxf6qn4pvvaat0l9tqsly68j", +} diff --git a/public/mainnet/archway-1/config.json b/public/mainnet/archway-1/config.json new file mode 100644 index 00000000..cb74324f --- /dev/null +++ b/public/mainnet/archway-1/config.json @@ -0,0 +1,41 @@ +{ + "whale_lair": "archway1a2hawz66n3nuh8964t0kw6yvcvqww2rnucsvacga2g4360nxs2tsyzftg8", + "incentive_factory": "archway1wc6wu89rl42fhyru4gff7jwy5cf3m0qz22yn7szvt8ac3m8al3rsp68vug", + "fee_distributor": "archway19sd5pzm9davt53735nc020ewemtw8dq5znp4sdtynlwmveqy3jfqltvnws", + "frontend_helper": "archway1yuxk5envmnvn8c36gakhzd650jsfjpj5pf5vm3wa0uf4ltj3r6hqzdp8dg", + "whale_base_token": { + "name": "WHALE", + "denom": "ibc/3FED3F9CE7B16BDCB7920FECEC085F8FA58E21C0EAB99703E4B816E5F666E3B9", + "decimals": 6 + }, + "bonding_tokens": [ + { + "id": "eris-amplified-whale", + "chain_id": "archway-1", + "token_address": "ibc/6F78565CB5D0A8E854A4AD895B0881D0067F9147E5A56DC015EAC3476D9E17E4", + "symbol": "ampWHALE", + "name": "ampWHALE", + "decimals": 6, + "logoURI": "/logos/ampWhale.svg", + "tags": [ + "native" + ], + "native": true, + "denom": "ibc/6F78565CB5D0A8E854A4AD895B0881D0067F9147E5A56DC015EAC3476D9E17E4" + }, + { + "id": "backbone-labs-staked-whale", + "chain_id": "archway-1", + "token_address": "ibc/DD9FFDD2E0B4EE93EBFD1C433501A008C8B7593DAB158944AE6C990500788D05", + "symbol": "bWHALE", + "name": "bWHALE", + "decimals": 6, + "logoURI": "https://raw.githubusercontent.com/cosmos/chain-registry/master/migaloo/images/bWHALE.png", + "tags": [ + "native" + ], + "native": true, + "denom": "ibc/DD9FFDD2E0B4EE93EBFD1C433501A008C8B7593DAB158944AE6C990500788D05" + } + ] +} diff --git a/public/mainnet/archway-1/pools_list.json b/public/mainnet/archway-1/pools_list.json new file mode 100644 index 00000000..aa59ccdc --- /dev/null +++ b/public/mainnet/archway-1/pools_list.json @@ -0,0 +1,31 @@ +{ + "name": "Pools list on mainnet", + "logoURI": "/img/logo.svg", + "keywords": [ + "special tokens" + ], + "tags": { + "ProjectName": { + "name": "White Whale", + "description": "Tokens that are listed on Project" + } + }, + "timestamp": "2024-01-23T15:01:19+0000", + "base_token": { + "id": "archway", + "chain_id": "archway-1", + "token_address": "", + "symbol": "ARCH", + "name": "Archway", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/archway.svg", + "tags": [ + "native" + ], + "native": true, + "denom": "aarch" + }, + "routerAddress": "archway1y0eyqu78q8zz93swaplvg90la0qkk0fueht3yxu6huc96yktrmcqntwe67", + "pools": [ + ] +} diff --git a/public/mainnet/archway-1/vaults_list.json b/public/mainnet/archway-1/vaults_list.json new file mode 100644 index 00000000..5a2c59bd --- /dev/null +++ b/public/mainnet/archway-1/vaults_list.json @@ -0,0 +1,5 @@ +{ + "factory": "archway132netq0uv85fqfq9dln93qy3gpukhzytk344u2a6phukmfa02c6qud97lr", + "vaults": [ + ] +} diff --git a/public/mainnet/chain_info.json b/public/mainnet/chain_info.json index 30636002..f66e2ce6 100644 --- a/public/mainnet/chain_info.json +++ b/public/mainnet/chain_info.json @@ -448,5 +448,54 @@ "ibc-go" ], "beta": true + }, + { + "chainId": "archway-1", + "chainName": "Archway Mainnet", + "label": "Archway", + "icon": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/archway.svg", + "rpc": "https://archway.rpc.kjnodes.com", + "rest": "https://archway.api.kjnodes.com", + "stakeCurrency": { + "coinDenom": "ARCH", + "coinMinimalDenom": "aarch", + "coinDecimals": 18 + }, + "bip44": { + "coinType": 118 + }, + "bech32Config": { + "bech32PrefixAccAddr": "arch", + "bech32PrefixAccPub": "archpub", + "bech32PrefixValAddr": "archvaloper", + "bech32PrefixValPub": "archvaloperpub", + "bech32PrefixConsAddr": "archvalcons", + "bech32PrefixConsPub": "archvalconspub" + }, + "currencies": [ + { + "coinDenom": "ARCH", + "coinMinimalDenom": "aarch", + "coinDecimals": 18, + "coinGeckoId": "archway" + } + ], + "feeCurrencies": [ + { + "coinDenom": "ARCH", + "coinMinimalDenom": "aarch", + "coinDecimals": 18, + "coinGeckoId": "archway" + } + ], + "coinType": 118, + "gasPriceStep": { + "low": 140000000000, + "average": 225400000000, + "high": 254800000000 + }, + "features": [ + "cosmwasm" + ] } ] diff --git a/util/getChainLogoUrlByName.ts b/util/getChainLogoUrlByName.ts index 4abae87d..55e03ba4 100644 --- a/util/getChainLogoUrlByName.ts +++ b/util/getChainLogoUrlByName.ts @@ -20,6 +20,8 @@ export const getChainLogoUrlByName = (chainName: string) : string => { return '/logos/terra.png' case WalletChainName.osmosis: return '/logos/osmo.svg' + case WalletChainName.archway: + return 'https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/archway.svg' default: return null } diff --git a/util/getColorByChainName.ts b/util/getColorByChainName.ts index dc962b78..981ea800 100644 --- a/util/getColorByChainName.ts +++ b/util/getColorByChainName.ts @@ -20,6 +20,10 @@ export const getColorByChainName = (chainName: string) : string => { return '#00FF00' case WalletChainName.osmosis: return '#800080' + // TODO: ARCHWAY + case WalletChainName.archway: + return '#000000' + default: return null } From 2b3b763055287340adf304815b492ffb52c85477 Mon Sep 17 00:00:00 2001 From: nick134 <76399455+nick134-bit@users.noreply.github.com> Date: Tue, 30 Jul 2024 15:43:31 +0200 Subject: [PATCH 2/5] chore: comma --- constants/vaultRouterAddresses.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/constants/vaultRouterAddresses.json b/constants/vaultRouterAddresses.json index dbda366e..c2436a12 100644 --- a/constants/vaultRouterAddresses.json +++ b/constants/vaultRouterAddresses.json @@ -4,5 +4,5 @@ "chihuahua-1": "chihuahua1qe6jsllyvrlmtz2xqef9k7q67xeyj3zcuc09wzptnvev3wyyd4fs4y4ce9", "injective-1": "inj1hyja4uyjktpeh0fxzuw2fmjudr85rk2qxgqkvu", "migaloo-1": "migaloo19pze0n07guzj6yla2708q2feh38q9n8gxmkk8fjnuprfh6y9ngjqs90hcy", - "osmosis-1": "osmo1ldkya0zakj380tlkd7dry0wj689t0r4x0kyxf6qn4pvvaat0l9tqsly68j", + "osmosis-1": "osmo1ldkya0zakj380tlkd7dry0wj689t0r4x0kyxf6qn4pvvaat0l9tqsly68j" } From a4313f0fea80f85cc439223ac4784be0415da6fa Mon Sep 17 00:00:00 2001 From: worrex <68468180+worrex@users.noreply.github.com> Date: Tue, 30 Jul 2024 16:14:08 +0200 Subject: [PATCH 3/5] added archway bg gradient --- .husky/_/husky.sh | 36 ------------------- components/Layout/RadialGradient.tsx | 5 ++- .../Incentivize/hooks/useIncentivePoolInfo.ts | 10 +++--- hooks/usePrices.ts | 6 ++-- 4 files changed, 11 insertions(+), 46 deletions(-) diff --git a/.husky/_/husky.sh b/.husky/_/husky.sh index 00bf2b41..e69de29b 100644 --- a/.husky/_/husky.sh +++ b/.husky/_/husky.sh @@ -1,36 +0,0 @@ -#!/usr/bin/env sh -if [ -z "$husky_skip_init" ]; then - debug () { - if [ "$HUSKY_DEBUG" = "1" ]; then - echo "husky (debug) - $1" - fi - } - - readonly hook_name="$(basename -- "$0")" - debug "starting $hook_name..." - - if [ "$HUSKY" = "0" ]; then - debug "HUSKY env variable is set to 0, skipping hook" - exit 0 - fi - - if [ -f ~/.huskyrc ]; then - debug "sourcing ~/.huskyrc" - . ~/.huskyrc - fi - - readonly husky_skip_init=1 - export husky_skip_init - sh -e "$0" "$@" - exitCode="$?" - - if [ $exitCode != 0 ]; then - echo "husky - $hook_name hook exited with code $exitCode (error)" - fi - - if [ $exitCode = 127 ]; then - echo "husky - command not found in PATH=$PATH" - fi - - exit $exitCode -fi diff --git a/components/Layout/RadialGradient.tsx b/components/Layout/RadialGradient.tsx index e967f8da..d0be7552 100644 --- a/components/Layout/RadialGradient.tsx +++ b/components/Layout/RadialGradient.tsx @@ -35,10 +35,9 @@ export const backgrounds = { 'linear-gradient(90deg, rgba(60, 205, 100, 0.25) 2.83%, rgba(255, 255, 0, 0.25) 50%, rgba(0, 117, 255, 0.25) 97.47%)', 'osmosis-1': 'linear-gradient(135deg, rgba(255, 20, 147, 0.8) 0%, rgba(147, 112, 219, 0.8) 50%, rgba(255, 20, 147, 0.8) 100%)', -// TODO ARCHWAY 'archway-1': - 'linear-gradient(135deg, rgba(255, 20, 147, 0.8) 0%, rgba(147, 112, 219, 0.8) 50%, rgba(255, 20, 147, 0.8) 100%)', - } + 'linear-gradient(90deg, rgba(236, 91, 41, 1) 0%, rgba(236, 91, 41, 1) 50%, rgba(255, 91, 41, 1) 100%)', +} const RadialGradient: FC = () => { const { chainId } = useRecoilValue(chainState) diff --git a/components/Pages/Trade/Incentivize/hooks/useIncentivePoolInfo.ts b/components/Pages/Trade/Incentivize/hooks/useIncentivePoolInfo.ts index f356eed1..ed16b415 100644 --- a/components/Pages/Trade/Incentivize/hooks/useIncentivePoolInfo.ts +++ b/components/Pages/Trade/Incentivize/hooks/useIncentivePoolInfo.ts @@ -11,6 +11,7 @@ import { ChainId, } from 'constants/index' import { usePrices } from 'hooks/usePrices' +import { useTokenList } from 'hooks/useTokenList' import { useRecoilValue } from 'recoil' import { PoolData, @@ -22,7 +23,6 @@ import { chainState } from 'state/chainState' import { convertMicroDenomToDenom } from 'util/conversion/index' import { getPoolInfo } from '../../Pools/hooks/queryPoolInfo' -import { useTokenList } from 'hooks/useTokenList' export interface Flow { claimed_amount: string @@ -63,7 +63,7 @@ export const fetchTotalPoolSupply = async (swapAddress: string, if (!client || !swapAddress) { return null } - const queried = await getPoolFromAPI(await client.getChainId(), swapAddress) || await getPoolInfo(swapAddress, client) + const queried = await getPoolFromAPI(await client.getChainId(), swapAddress) || await getPoolInfo(swapAddress, client) return Number(queried.total_share) } export const fetchFlows = async (client, address): Promise => await getFlowsFromAPI(await client.getChainId(), address) || await client.queryContractSmart(address, { flows: {} }) @@ -145,7 +145,7 @@ const getPoolFlowData = async ( (flow.start_epoch + (flow.end_epoch - flow.start_epoch) - Number(currentEpochData.currentEpoch.epoch.id)), - poolAsset?.decimals || 6) + poolAsset?.decimals || 6) const uniqueFlow = uniqueFlowList.find((f) => f.denom === flowDenom) uniqueFlow.dailyEmission += emission } @@ -214,7 +214,9 @@ export const useIncentivePoolInfo = ( }, [currentChainPrefix, pools?.length, client]) const poolAssets = useMemo(() => { - if (!tokenList || loading) return [] + if (!tokenList || loading) { + return [] + } return tokenList?.tokens }, [tokenList, loading, pools, chainId, tokenList?.tokens, config, prices]) diff --git a/hooks/usePrices.ts b/hooks/usePrices.ts index a59a3251..3a28ff6d 100644 --- a/hooks/usePrices.ts +++ b/hooks/usePrices.ts @@ -7,9 +7,9 @@ import { useClients } from 'hooks/useClients' import useCoinGecko from 'hooks/useCoinGecko' import { useTokenList } from 'hooks/useTokenList' import { useRecoilValue } from 'recoil' +import { getPoolFromAPI } from 'services/useAPI' import { chainState } from 'state/chainState' import { convertMicroDenomToDenom } from 'util/conversion/index' -import { getPoolFromAPI } from '../services/useAPI' type Params = { token: TokenInfo @@ -41,7 +41,7 @@ const getTokenPrice = async ({ baseToken, baseTokenPrice, cosmWasmClient, -}: Params) => { +}: Params): Promise => { const poolContainingTokenAndBaseToken = poolList.find((pool) => pool.pool_assets.some((poolAsset) => poolAsset.symbol === token.symbol) && pool.pool_assets.some((poolAsset) => poolAsset.symbol === baseToken.symbol)) if (!poolContainingTokenAndBaseToken) { @@ -139,7 +139,7 @@ export const usePrices = () => { return token.id } }), - [tokenList?.tokens]) + [tokenList?.tokens]) const coingeckoPrices = useCoinGecko(coingeckoIds) const { data: prices } = useQuery({ queryKey: ['newPrices', tokenList?.baseToken, chainId], From da91fbf6131c77feafc4c5497b104154d8e19a0b Mon Sep 17 00:00:00 2001 From: nick134 <76399455+nick134-bit@users.noreply.github.com> Date: Tue, 30 Jul 2024 16:37:03 +0200 Subject: [PATCH 4/5] chore: color --- util/getColorByChainName.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/util/getColorByChainName.ts b/util/getColorByChainName.ts index 981ea800..a2f57da2 100644 --- a/util/getColorByChainName.ts +++ b/util/getColorByChainName.ts @@ -20,9 +20,8 @@ export const getColorByChainName = (chainName: string) : string => { return '#00FF00' case WalletChainName.osmosis: return '#800080' - // TODO: ARCHWAY case WalletChainName.archway: - return '#000000' + return '#ff8a22' default: return null From 466f634cf750d66bc4141e77e8d24ab84c892655 Mon Sep 17 00:00:00 2001 From: nick134 <76399455+nick134-bit@users.noreply.github.com> Date: Sun, 20 Oct 2024 18:02:40 +0400 Subject: [PATCH 5/5] chore: barch-arch pool --- components/Pages/Trade/Pools/Pools.tsx | 20 +++++----- public/mainnet/archway-1/pools_list.json | 48 ++++++++++++++++++++++++ services/useAPI.ts | 3 +- 3 files changed, 61 insertions(+), 10 deletions(-) diff --git a/components/Pages/Trade/Pools/Pools.tsx b/components/Pages/Trade/Pools/Pools.tsx index faf3a70e..a9664efe 100644 --- a/components/Pages/Trade/Pools/Pools.tsx +++ b/components/Pages/Trade/Pools/Pools.tsx @@ -69,7 +69,7 @@ const Pools = () => { const chains: any = useChainInfos() const currentChainPrefix = useMemo(() => chains.find((row: { chainId: string }) => row.chainId === chainId)?.bech32Config?. bech32PrefixAccAddr, - [chains, chainId]) + [chains, chainId]) const { flowPoolData: incentivePoolInfos, @@ -107,8 +107,8 @@ const Pools = () => { const _allPools = await Promise.all(pools.map((pool) => { const isUSDPool = - STABLE_COIN_LIST.includes(pool?.pool_assets[0].symbol) || - STABLE_COIN_LIST.includes(pool?.pool_assets[1].symbol) + STABLE_COIN_LIST.includes(pool?.pool_assets[0].symbol) || + STABLE_COIN_LIST.includes(pool?.pool_assets[1].symbol) if (externalStatsLoading) { setExternalStatsLoading((pool?.liquidity?.reserves?.totalAssetsInDollar || 0) === 0) @@ -150,10 +150,10 @@ const Pools = () => { useEffect(() => { if (pairInfos.length === 0) { - return + return; } let updatedPools = allPools.map((pool) => { - const pairInfo = pairInfos.find((pairInfo) => pairInfo.pool_id === pool.poolId) + const pairInfo = pairInfos?.find((pairInfo) => pairInfo.pool_id === pool.poolId) return { ...pool, volume24hr: pairInfo?.usdVolume24h, @@ -183,7 +183,7 @@ const Pools = () => { const flowLength = useMemo(() => incentivePoolInfos?. map((info) => info.flowData?.length ?? 0). reduce((a, b) => a + b, 0) ?? 0, - [incentivePoolInfos]) + [incentivePoolInfos]) useEffect(() => { const updatedPools = allPools.map((pool) => { @@ -261,7 +261,7 @@ const Pools = () => { {myPools?.length > 0 && ( - Supplied + Supplied { )} - + All Pools diff --git a/public/mainnet/archway-1/pools_list.json b/public/mainnet/archway-1/pools_list.json index aa59ccdc..f40a8a4d 100644 --- a/public/mainnet/archway-1/pools_list.json +++ b/public/mainnet/archway-1/pools_list.json @@ -27,5 +27,53 @@ }, "routerAddress": "archway1y0eyqu78q8zz93swaplvg90la0qkk0fueht3yxu6huc96yktrmcqntwe67", "pools": [ + { + "pool_id": "bARCH-ARCH", + "lpOrder": [ + "bARCH", + "ARCH" + ], + "assetOrder": [ + "bARCH", + "ARCH" + ], + "displayName": "bARCH-ARCH", + "displayLogo1": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/barch.png", + "displayLogo2": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/arch.svg", + "pool_assets": [ + { + "id": "", + "chain_id": "archway-1", + "token_address": "archway17e3z7cr6d29uj54k4ucs6dtqvlxsxhwnwzetqgnp6zeu40cvq7dsd8q60x", + "symbol": "bARCH", + "name": "bARCH", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/barch.png", + "tags": [ + "" + ], + "native": false, + "denom": "archway17e3z7cr6d29uj54k4ucs6dtqvlxsxhwnwzetqgnp6zeu40cvq7dsd8q60x" + }, + { + "id": "archway", + "chain_id": "archway-1", + "token_address": "aarch", + "symbol": "ARCH", + "name": "ARCH", + "decimals": 18, + "logoURI": "https://raw.githubusercontent.com/cosmos/chain-registry/master/archway/images/arch.svg", + "tags": [ + "native" + ], + "native": true, + "denom": "aarch" + } + ], + "lp_token": "archway1a2xz3c9cfjnf6u3ave0q76mkcm50pdcjqt68hasxkw0ys23h9vfq8wsv6x", + "swap_address": "archway19lcq9nsssqplxly8uxnjnlmkz8sy42cpd2d0wnjhcp64r795qdqq0re2x3", + "staking_address": "", + "rewards_tokens": [] + } ] } diff --git a/services/useAPI.ts b/services/useAPI.ts index 4bb03108..f11ab808 100644 --- a/services/useAPI.ts +++ b/services/useAPI.ts @@ -154,7 +154,8 @@ export const getPairAprAndDailyVolumeAPI = async (chain_name: string) => { try { const response = await fetchWithTimeout(`${await getFastestAPI()}/api/pools/${chain_name}`, 50000) const json = await response.json() - return json?.data || null + + return Array.isArray(json?.data) ? json?.data : null } catch (error) { console.error(error) return null