cdff4886b2
* chore: remove dead sorting logic * style: lint * style: lint
249 lines
7.0 KiB
TypeScript
249 lines
7.0 KiB
TypeScript
import './i18n';
|
|
|
|
import React, { useEffect } from 'react';
|
|
import * as Sentry from '@sentry/react';
|
|
import { Integrations } from '@sentry/tracing';
|
|
import { BrowserRouter as Router } from 'react-router-dom';
|
|
import { AppLoader } from './app-loader';
|
|
import { NetworkInfo } from '@vegaprotocol/network-info';
|
|
import { BalanceManager } from './components/balance-manager';
|
|
import { EthWallet } from './components/eth-wallet';
|
|
import { TemplateSidebar } from './components/page-templates/template-sidebar';
|
|
import { TransactionModal } from './components/transactions-modal';
|
|
import { VegaWallet } from './components/vega-wallet';
|
|
import { Web3Connector } from './components/web3-connector';
|
|
import { AppStateProvider } from './contexts/app-state/app-state-provider';
|
|
import { ContractsProvider } from './contexts/contracts/contracts-provider';
|
|
import { AppRouter } from './routes';
|
|
import type { EthereumConfig } from '@vegaprotocol/web3';
|
|
import { Web3Provider } from '@vegaprotocol/web3';
|
|
import { VegaWalletDialogs } from './components/vega-wallet-dialogs';
|
|
import { VegaWalletProvider } from '@vegaprotocol/wallet';
|
|
import { AsyncRenderer } from '@vegaprotocol/ui-toolkit';
|
|
import { useEthereumConfig } from '@vegaprotocol/web3';
|
|
import {
|
|
useEnvironment,
|
|
EnvironmentProvider,
|
|
NetworkLoader,
|
|
} from '@vegaprotocol/environment';
|
|
import { createConnectors } from './lib/web3-connectors';
|
|
import { ENV } from './config/env';
|
|
import type {
|
|
FieldFunctionOptions,
|
|
InMemoryCacheConfig,
|
|
Reference,
|
|
} from '@apollo/client';
|
|
|
|
import { addDecimal } from '@vegaprotocol/react-helpers';
|
|
|
|
const formatUintToNumber = (amount: string, decimals = 18) =>
|
|
addDecimal(amount, decimals).toString();
|
|
|
|
const createReadField = (fieldName: string) => ({
|
|
[`${fieldName}Formatted`]: {
|
|
read(_: string, options: FieldFunctionOptions) {
|
|
const amount = options.readField(fieldName) as string;
|
|
return amount ? formatUintToNumber(amount) : '0';
|
|
},
|
|
},
|
|
});
|
|
|
|
const cache: InMemoryCacheConfig = {
|
|
typePolicies: {
|
|
Account: {
|
|
keyFields: false,
|
|
fields: {
|
|
balanceFormatted: {
|
|
read(_: string, options: FieldFunctionOptions) {
|
|
const balance = options.readField('balance');
|
|
const asset = options.readField('asset');
|
|
const decimals = options.readField('decimals', asset as Reference);
|
|
if (typeof balance !== 'string') return '0';
|
|
if (typeof decimals !== 'number') return '0';
|
|
return balance && decimals
|
|
? formatUintToNumber(balance, decimals)
|
|
: '0';
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Delegation: {
|
|
keyFields: false,
|
|
// Only get full updates
|
|
merge(_, incoming) {
|
|
return incoming;
|
|
},
|
|
fields: {
|
|
...createReadField('amount'),
|
|
},
|
|
},
|
|
Reward: {
|
|
keyFields: false,
|
|
fields: {
|
|
...createReadField('amount'),
|
|
},
|
|
},
|
|
RewardPerAssetDetail: {
|
|
keyFields: false,
|
|
fields: {
|
|
...createReadField('totalAmount'),
|
|
},
|
|
},
|
|
Node: {
|
|
keyFields: false,
|
|
fields: {
|
|
...createReadField('pendingStake'),
|
|
...createReadField('stakedByOperator'),
|
|
...createReadField('stakedByDelegates'),
|
|
...createReadField('stakedTotal'),
|
|
},
|
|
},
|
|
NodeData: {
|
|
merge: (existing = {}, incoming) => {
|
|
return { ...existing, ...incoming };
|
|
},
|
|
fields: {
|
|
...createReadField('stakedTotal'),
|
|
},
|
|
},
|
|
Party: {
|
|
fields: {
|
|
stake: {
|
|
merge(existing, incoming) {
|
|
return {
|
|
...existing,
|
|
...incoming,
|
|
};
|
|
},
|
|
read(stake) {
|
|
if (stake) {
|
|
return {
|
|
...stake,
|
|
currentStakeAvailableFormatted: formatUintToNumber(
|
|
stake.currentStakeAvailable
|
|
),
|
|
};
|
|
}
|
|
return stake;
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Withdrawal: {
|
|
fields: {
|
|
pendingOnForeignChain: {
|
|
read: (isPending = false) => isPending,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
};
|
|
|
|
const Web3Container = ({
|
|
chainId,
|
|
providerUrl,
|
|
}: {
|
|
chainId: number;
|
|
providerUrl: string;
|
|
}) => {
|
|
const sideBar = React.useMemo(() => {
|
|
return [<EthWallet />, <VegaWallet />];
|
|
}, []);
|
|
const Connectors = React.useMemo(() => {
|
|
return createConnectors(providerUrl, Number(chainId));
|
|
}, [chainId, providerUrl]);
|
|
return (
|
|
<Web3Provider connectors={Connectors}>
|
|
<Web3Connector connectors={Connectors} chainId={Number(chainId)}>
|
|
<VegaWalletProvider>
|
|
<ContractsProvider>
|
|
<AppLoader>
|
|
<BalanceManager>
|
|
<>
|
|
<div className="app w-full max-w-[1300px] mx-auto grid grid-rows-[1fr_min-content] min-h-full border-neutral-700 lg:border-l lg:border-r lg:text-body-large">
|
|
<TemplateSidebar sidebar={sideBar}>
|
|
<AppRouter />
|
|
</TemplateSidebar>
|
|
<footer className="p-4 border-t border-neutral-700">
|
|
<NetworkInfo />
|
|
</footer>
|
|
</div>
|
|
<VegaWalletDialogs />
|
|
<TransactionModal />
|
|
</>
|
|
</BalanceManager>
|
|
</AppLoader>
|
|
</ContractsProvider>
|
|
</VegaWalletProvider>
|
|
</Web3Connector>
|
|
</Web3Provider>
|
|
);
|
|
};
|
|
|
|
const AppContainer = () => {
|
|
const { config, loading, error } = useEthereumConfig();
|
|
const { VEGA_ENV, GIT_COMMIT_HASH, GIT_BRANCH, ETHEREUM_PROVIDER_URL } =
|
|
useEnvironment();
|
|
|
|
useEffect(() => {
|
|
if (ENV.dsn) {
|
|
Sentry.init({
|
|
dsn: ENV.dsn,
|
|
integrations: [new Integrations.BrowserTracing()],
|
|
tracesSampleRate: 0.1,
|
|
enabled: true,
|
|
environment: VEGA_ENV,
|
|
release: GIT_COMMIT_HASH,
|
|
beforeSend(event) {
|
|
if (event.request?.url?.includes('/claim?')) {
|
|
return {
|
|
...event,
|
|
request: {
|
|
...event.request,
|
|
url: event.request?.url.split('?')[0],
|
|
},
|
|
};
|
|
}
|
|
return event;
|
|
},
|
|
});
|
|
Sentry.setTag('branch', GIT_BRANCH);
|
|
Sentry.setTag('commit', GIT_COMMIT_HASH);
|
|
}
|
|
}, [GIT_COMMIT_HASH, GIT_BRANCH, VEGA_ENV]);
|
|
|
|
return (
|
|
<Router>
|
|
<AppStateProvider>
|
|
<div className="grid min-h-full text-white">
|
|
<AsyncRenderer<EthereumConfig | null>
|
|
loading={loading}
|
|
data={config}
|
|
error={error}
|
|
render={(cnf) =>
|
|
cnf && (
|
|
<Web3Container
|
|
chainId={Number(cnf.chain_id)}
|
|
providerUrl={ETHEREUM_PROVIDER_URL}
|
|
/>
|
|
)
|
|
}
|
|
/>
|
|
</div>
|
|
</AppStateProvider>
|
|
</Router>
|
|
);
|
|
};
|
|
|
|
function App() {
|
|
return (
|
|
<EnvironmentProvider>
|
|
<NetworkLoader cache={cache}>
|
|
<AppContainer />
|
|
</NetworkLoader>
|
|
</EnvironmentProvider>
|
|
);
|
|
}
|
|
|
|
export default App;
|