* feat: unhardcode contract addresses * fix: linting and tests * feat: switch contract usage in token app to use unhardcoded addresses * chore: remove other usage of hard coded contract addresses * feat: convert contracts to classes, update claim contract to fix circular dependency * feat: add hard coded contract addresses to contracts page * fix: misc tidy up * chore: rename ethers big num conversion func * fix: remove pending transactions modal * chore: add single toBigNum function that can accept number string or EthersBignNumber * chore: delete unused tranche helpers and decimals functions from smart contracts lib * feat: add faucetable token class * fix: reset tx state after early exit from approve tx * feat: re add transaction modal using zustand store * fix: loader colors for eth wallet * fix: pass ethereum config to gurantee existence before tx execution * add docker image for building explorer * add arg * env file changes * add docker file to build env file * add requirement for env file in explorer * fix env file syntax * containers functional * default to testnet * make env flag logic consistent in all places * pre populate env file * ensure working for all projects * address PR comment * generalising env for token * invert config dependency from ui toolkit * fix: merge issues * docs: running containers documentation * style: lint * fix: env varibales not being added properly * chore: fix merge issues * chore: fix docker file to support new exectutors * chore: set address on all contracts as a property * feat: pull token from contract rather than relying on env var * chore: fix typing * chore: remove duplicated prop * chore: don't use chainId * style: lint * style: lint * Merge branch 'master' into feat/dockerize-frontends * Merge remote-tracking branch 'origin/master' into feat/dockerize-frontends * test: revert changes to explorer e2e file * fix: creating client without base causing token to error * test: fix tests erroring in before hook due to file not being found * chore: remove node env from configurable flags Co-authored-by: Matthew Russell <mattrussell36@gmail.com>
68 lines
2.4 KiB
TypeScript
68 lines
2.4 KiB
TypeScript
import type { Networks } from '@vegaprotocol/react-helpers';
|
|
import { useFetch } from '@vegaprotocol/react-helpers';
|
|
import type { Tranche } from '@vegaprotocol/smart-contracts';
|
|
import React, { useEffect } from 'react';
|
|
import { useEnvironment } from '@vegaprotocol/network-switcher';
|
|
|
|
import { BigNumber } from '../lib/bignumber';
|
|
|
|
const TRANCHES_URLS: { [N in Networks]: string } = {
|
|
MAINNET: 'https://static.vega.xyz/assets/mainnet-tranches.json',
|
|
TESTNET: 'https://static.vega.xyz/assets/testnet-tranches.json',
|
|
STAGNET: 'https://static.vega.xyz/assets/stagnet1-tranches.json',
|
|
STAGNET2: 'https://static.vega.xyz/assets/stagnet2-tranches.json',
|
|
DEVNET: 'https://static.vega.xyz/assets/devnet-tranches.json',
|
|
};
|
|
|
|
export function useTranches() {
|
|
const { VEGA_ENV } = useEnvironment();
|
|
const [tranches, setTranches] = React.useState<Tranche[] | null>(null);
|
|
const url = React.useMemo(() => TRANCHES_URLS[VEGA_ENV], [VEGA_ENV]);
|
|
const {
|
|
state: { data, loading, error },
|
|
} = useFetch<Tranche[] | null>(url);
|
|
useEffect(() => {
|
|
const processedTrances = data
|
|
?.map((t) => ({
|
|
...t,
|
|
tranche_start: new Date(t.tranche_start),
|
|
tranche_end: new Date(t.tranche_end),
|
|
total_added: new BigNumber(t.total_added),
|
|
total_removed: new BigNumber(t.total_removed),
|
|
locked_amount: new BigNumber(t.locked_amount),
|
|
deposits: t.deposits.map((d) => ({
|
|
...d,
|
|
amount: new BigNumber(d.amount),
|
|
})),
|
|
withdrawals: t.withdrawals.map((w) => ({
|
|
...w,
|
|
amount: new BigNumber(w.amount),
|
|
})),
|
|
users: t.users.map((u) => ({
|
|
...u,
|
|
// @ts-ignore - types are incorrect in the SDK lib
|
|
deposits: u.deposits.map((d) => ({
|
|
...d,
|
|
amount: new BigNumber(d.amount),
|
|
})),
|
|
// @ts-ignore - types are incorrect in the SDK lib
|
|
withdrawals: u.withdrawals.map((w) => ({
|
|
...w,
|
|
amount: new BigNumber(w.amount),
|
|
})),
|
|
total_tokens: new BigNumber(u.total_tokens),
|
|
withdrawn_tokens: new BigNumber(u.withdrawn_tokens),
|
|
remaining_tokens: new BigNumber(u.remaining_tokens),
|
|
})),
|
|
}))
|
|
.sort((a: Tranche, b: Tranche) => a.tranche_id - b.tranche_id);
|
|
setTranches(processedTrances ? processedTrances : null);
|
|
}, [data]);
|
|
|
|
return {
|
|
tranches,
|
|
loading,
|
|
error,
|
|
};
|
|
}
|