Skip to content

Commit

Permalink
Merge pull request #1523 from decentdao/remove-bignumber
Browse files Browse the repository at this point in the history
Replace BigNumber with bigint
  • Loading branch information
adamgall authored Apr 12, 2024
2 parents bcf05d1 + 57cde3e commit c18bfdf
Show file tree
Hide file tree
Showing 116 changed files with 775 additions and 820 deletions.
8 changes: 4 additions & 4 deletions netlify/functions/tokenPrices.mts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// eslint-disable-next-line import/named
import { Store, getStore } from '@netlify/blobs';
import { ethers } from 'ethers';
import { getStore } from '@netlify/blobs';
import type { Store } from '@netlify/blobs';
import { isAddress } from 'viem';

const PUBLIC_DEMO_API_BASE_URL = 'https://api.coingecko.com/api/v3/';
const AUTH_QUERY_PARAM = `?x_cg_demo_api_key=${process.env.COINGECKO_API_KEY}`;
Expand All @@ -27,7 +27,7 @@ type SupportedNetworks = (typeof SUPPORTED_NETWORKS)[number];
function sanitizeUserInput(tokensString: string, network: SupportedNetworks) {
const rawTokenAddresses = tokensString.split(',');
const needNativeAsset = rawTokenAddresses.map(address => address.toLowerCase()).includes(network);
const validTokenAddresses = rawTokenAddresses.filter(address => ethers.utils.isAddress(address));
const validTokenAddresses = rawTokenAddresses.filter(address => isAddress(address));
const lowerCaseTokenAddresses = validTokenAddresses.map(address => address.toLowerCase());
const tokens = [...new Set(lowerCaseTokenAddresses)];
if (needNativeAsset) tokens.push(network);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,8 @@ export default function ProposalTemplateDetails({
</HStack>
<Divider color="chocolate.700" />
{transactions.map((transaction, i) => {
const valueBiggerThanZero = transaction.ethValue.bigNumberValue
? transaction.ethValue.bigNumberValue.gt(0)
const valueBiggerThanZero = transaction.ethValue.bigintValue
? transaction.ethValue.bigintValue > 0n
: false;
return (
<Fragment key={i}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { useTranslation } from 'react-i18next';
import { CreateProposalTemplateTransaction } from '../../types/createProposalTemplate';
import ABISelector, { ABIElement } from '../ui/forms/ABISelector';
import ExampleLabel from '../ui/forms/ExampleLabel';
import { BigNumberComponent, InputComponent } from '../ui/forms/InputComponent';
import { BigIntComponent, InputComponent } from '../ui/forms/InputComponent';
import { DEFAULT_PROPOSAL_TEMPLATE_TRANSACTION } from './constants';

interface ProposalTemplateTransactionProps {
Expand Down Expand Up @@ -268,7 +268,7 @@ export default function ProposalTemplateTransaction({
mt={6}
pl={10}
>
<BigNumberComponent
<BigIntComponent
label={t('labelEthValue')}
helper={t('helperEthValue')}
isRequired={false}
Expand All @@ -286,7 +286,7 @@ export default function ProposalTemplateTransaction({
</VStack>
}
errorMessage={undefined}
value={transaction.ethValue.bigNumberValue}
value={transaction.ethValue.bigintValue}
onChange={e => {
setFieldValue(`transactions.${transactionIndex}.ethValue`, e);
}}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { ArrowDown, ArrowRight, Minus } from '@decent-org/fractal-ui';
import { FormikErrors, FormikProps } from 'formik';
import { Dispatch, SetStateAction } from 'react';
import { useTranslation } from 'react-i18next';
import { BigNumberValuePair } from '../../types';
import { BigIntValuePair } from '../../types';
import {
CreateProposalTemplateForm,
CreateProposalTemplateTransaction,
Expand Down Expand Up @@ -46,7 +46,7 @@ export default function ProposalTemplateTransactions({
>
{transactions.map((_, index) => {
const txErrors = errors?.transactions?.[index] as
| FormikErrors<CreateProposalTemplateTransaction<BigNumberValuePair>>
| FormikErrors<CreateProposalTemplateTransaction<BigIntValuePair>>
| undefined;
const txAddressError = txErrors?.targetAddress;
const txFunctionError = txErrors?.functionName;
Expand Down
2 changes: 1 addition & 1 deletion src/components/CreateProposalTemplate/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { CreateProposalTemplateTransaction } from '../../types/createProposalTem

export const DEFAULT_PROPOSAL_TEMPLATE_TRANSACTION: CreateProposalTemplateTransaction = {
targetAddress: '',
ethValue: { value: '', bigNumberValue: undefined },
ethValue: { value: '', bigintValue: undefined },
functionName: '',
parameters: [
{
Expand Down
23 changes: 12 additions & 11 deletions src/components/DaoCreator/constants.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { BigNumber } from 'ethers';
import {
CreatorFormState,
GovernanceType,
Expand All @@ -8,6 +7,8 @@ import {

export const DEFAULT_TOKEN_DECIMALS = 18;

// @todo make the time lengths dynamic for whatever real-life values we're targeting here

export const initialState: CreatorFormState = {
essentials: {
daoName: '',
Expand Down Expand Up @@ -45,7 +46,7 @@ export const initialState: CreatorFormState = {
],
quorumThreshold: {
value: '10',
bigNumberValue: BigNumber.from(10),
bigintValue: 10n,
},
},
/**
Expand All @@ -58,42 +59,42 @@ export const initialState: CreatorFormState = {
azorius: {
quorumPercentage: {
value: '4',
bigNumberValue: BigNumber.from(4),
bigintValue: 4n,
},
timelock: {
value: '1440',
bigNumberValue: BigNumber.from(1440),
bigintValue: 1440n,
},
votingPeriod: {
value: '10080',
bigNumberValue: BigNumber.from(10080),
bigintValue: 10080n,
},
executionPeriod: {
value: '2880',
bigNumberValue: BigNumber.from(2880),
bigintValue: 2880n,
},
votingStrategyType: VotingStrategyType.LINEAR_ERC20,
},
freeze: {
executionPeriod: {
value: '2880',
bigNumberValue: BigNumber.from(2880),
bigintValue: 2880n,
},
timelockPeriod: {
value: '1440',
bigNumberValue: BigNumber.from(1440),
bigintValue: 1440n,
},
freezeVotesThreshold: {
value: '1',
bigNumberValue: BigNumber.from(1),
bigintValue: 1n,
},
freezeProposalPeriod: {
value: '10080',
bigNumberValue: BigNumber.from(10080),
bigintValue: 10080n,
},
freezePeriod: {
value: '10080',
bigNumberValue: BigNumber.from(10080),
bigintValue: 10080n,
},
},
multisig: {
Expand Down
22 changes: 11 additions & 11 deletions src/components/DaoCreator/formComponents/AzoriusGovernance.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { Info } from '@decent-org/fractal-ui';
import { useTranslation } from 'react-i18next';
import { ICreationStepProps, CreatorSteps, VotingStrategyType } from '../../../types';
import ContentBoxTitle from '../../ui/containers/ContentBox/ContentBoxTitle';
import { BigNumberInput } from '../../ui/forms/BigNumberInput';
import { BigIntInput } from '../../ui/forms/BigIntInput';
import { LabelComponent } from '../../ui/forms/InputComponent';
import { StepButtons } from '../StepButtons';
import { StepWrapper } from '../StepWrapper';
Expand Down Expand Up @@ -39,8 +39,8 @@ export function AzoriusGovernance(props: ICreationStepProps) {
isRequired
>
<InputGroup>
<BigNumberInput
value={values.azorius.votingPeriod.bigNumberValue}
<BigIntInput
value={values.azorius.votingPeriod.bigintValue}
onChange={valuePair => setFieldValue('azorius.votingPeriod', valuePair)}
decimalPlaces={0}
min="1"
Expand All @@ -63,8 +63,8 @@ export function AzoriusGovernance(props: ICreationStepProps) {
isRequired
>
<InputGroup>
<BigNumberInput
value={values.azorius.quorumPercentage.bigNumberValue}
<BigIntInput
value={values.azorius.quorumPercentage.bigintValue}
onChange={valuePair => setFieldValue('azorius.quorumPercentage', valuePair)}
max="100"
decimalPlaces={0}
Expand All @@ -79,8 +79,8 @@ export function AzoriusGovernance(props: ICreationStepProps) {
helper={t('helperQuorumThreshold')}
isRequired
>
<BigNumberInput
value={values.erc721Token.quorumThreshold.bigNumberValue}
<BigIntInput
value={values.erc721Token.quorumThreshold.bigintValue}
onChange={valuePair => setFieldValue('erc721Token.quorumThreshold', valuePair)}
decimalPlaces={0}
min="1"
Expand All @@ -94,8 +94,8 @@ export function AzoriusGovernance(props: ICreationStepProps) {
isRequired
>
<InputGroup>
<BigNumberInput
value={values.azorius.timelock.bigNumberValue}
<BigIntInput
value={values.azorius.timelock.bigintValue}
onChange={valuePair => setFieldValue('azorius.timelock', valuePair)}
decimalPlaces={0}
data-testid="govConfig-timelock"
Expand All @@ -116,8 +116,8 @@ export function AzoriusGovernance(props: ICreationStepProps) {
isRequired
>
<InputGroup>
<BigNumberInput
value={values.azorius.executionPeriod.bigNumberValue}
<BigIntInput
value={values.azorius.executionPeriod.bigintValue}
onChange={valuePair => setFieldValue('azorius.executionPeriod', valuePair)}
decimalPlaces={0}
min="1"
Expand Down
8 changes: 4 additions & 4 deletions src/components/DaoCreator/formComponents/AzoriusNFTDetail.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@ import { Flex, Box, Text } from '@chakra-ui/react';
import { ethers } from 'ethers';
import { useState, useEffect } from 'react';
import { useTranslation } from 'react-i18next';
import { erc721Abi } from 'viem';
import { erc721Abi, isAddress } from 'viem';
import useDisplayName from '../../../hooks/utils/useDisplayName';
import { useEthersProvider } from '../../../providers/Ethers/hooks/useEthersProvider';
import { BigNumberValuePair, ERC721TokenConfig } from '../../../types';
import { BigIntValuePair, ERC721TokenConfig } from '../../../types';
import { BarLoader } from '../../ui/loaders/BarLoader';

type TokenDetails = {
Expand All @@ -18,7 +18,7 @@ export default function AzoriusNFTDetail({
nft,
hasAddressError,
}: {
nft: ERC721TokenConfig<BigNumberValuePair>;
nft: ERC721TokenConfig<BigIntValuePair>;
hasAddressError: boolean;
}) {
const [loading, setLoading] = useState<boolean>();
Expand All @@ -36,7 +36,7 @@ export default function AzoriusNFTDetail({

setLoading(true);
try {
if (nft.tokenAddress && ethers.utils.isAddress(nft.tokenAddress)) {
if (nft.tokenAddress && isAddress(nft.tokenAddress)) {
const tokenContract = new ethers.Contract(nft.tokenAddress, erc721Abi, provider);
const [name, symbol] = await Promise.all([tokenContract.name(), tokenContract.symbol()]);
setTokenDetails({
Expand Down
12 changes: 6 additions & 6 deletions src/components/DaoCreator/formComponents/AzoriusNFTDetails.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@ import {
ICreationStepProps,
CreatorSteps,
ERC721TokenConfig,
BigNumberValuePair,
BigIntValuePair,
} from '../../../types';
import ContentBoxTitle from '../../ui/containers/ContentBox/ContentBoxTitle';
import { BigNumberInput } from '../../ui/forms/BigNumberInput';
import { BigIntInput } from '../../ui/forms/BigIntInput';
import { LabelComponent } from '../../ui/forms/InputComponent';
import { StepButtons } from '../StepButtons';
import { StepWrapper } from '../StepWrapper';
Expand Down Expand Up @@ -70,7 +70,7 @@ export default function AzoriusNFTDetails(props: ICreationStepProps) {
{values.erc721Token.nfts.map((nft, i) => {
const nftError = (
errors?.erc721Token?.nfts as FormikErrors<
ERC721TokenConfig<BigNumberValuePair>[] | undefined
ERC721TokenConfig<BigIntValuePair>[] | undefined
>
)?.[i];
const addressErrorMessage =
Expand Down Expand Up @@ -135,8 +135,8 @@ export default function AzoriusNFTDetails(props: ICreationStepProps) {
}}
>
<Flex>
<BigNumberInput
value={nft.tokenWeight.bigNumberValue}
<BigIntInput
value={nft.tokenWeight.bigintValue}
onChange={valuePair =>
setFieldValue(`erc721Token.nfts.${i}.tokenWeight`, valuePair)
}
Expand Down Expand Up @@ -198,7 +198,7 @@ export default function AzoriusNFTDetails(props: ICreationStepProps) {
{values.erc721Token.nfts.map((nft, i) => {
const nftError = (
errors?.erc721Token?.nfts as FormikErrors<
ERC721TokenConfig<BigNumberValuePair>[] | undefined
ERC721TokenConfig<BigIntValuePair>[] | undefined
>
)?.[i];
const addressErrorMessage =
Expand Down
Original file line number Diff line number Diff line change
@@ -1,17 +1,16 @@
import { IconButton, Box } from '@chakra-ui/react';
import { LabelWrapper, Minus } from '@decent-org/fractal-ui';
import { BigNumber } from 'ethers';
import { Field, FieldAttributes } from 'formik';
import { useFormHelpers } from '../../../hooks/utils/useFormHelpers';
import { BigNumberInput } from '../../ui/forms/BigNumberInput';
import { BigIntInput } from '../../ui/forms/BigIntInput';
import { AddressInput } from '../../ui/forms/EthAddressInput';
interface ITokenAllocations {
index: number;
remove: <T>(index: number) => T | undefined;
setFieldValue: (field: string, value: any) => void;
addressErrorMessage: string | null;
amountErrorMessage: string | null;
amountInputValue: BigNumber | undefined;
amountInputValue: bigint | undefined;
allocationLength: number;
}

Expand Down Expand Up @@ -39,7 +38,7 @@ export function AzoriusTokenAllocation({
</Field>
</LabelWrapper>
<LabelWrapper errorMessage={amountErrorMessage}>
<BigNumberInput
<BigIntInput
value={amountInputValue}
onChange={valuePair =>
setFieldValue(`erc20Token.tokenAllocations.${index}.amount`, valuePair)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,12 @@ import { BACKGROUND_SEMI_TRANSPARENT } from '../../../constants/common';
import { useFractal } from '../../../providers/App/AppProvider';
import {
AzoriusGovernance,
BigNumberValuePair,
BigIntValuePair,
ICreationStepProps,
TokenAllocation,
} from '../../../types';
import ContentBoxTitle from '../../ui/containers/ContentBox/ContentBoxTitle';
import { BigNumberInput } from '../../ui/forms/BigNumberInput';
import { BigIntInput } from '../../ui/forms/BigIntInput';
import { LabelComponent } from '../../ui/forms/InputComponent';
import { AzoriusTokenAllocation } from './AzoriusTokenAllocation';

Expand Down Expand Up @@ -60,7 +60,7 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
{values.erc20Token.tokenAllocations.map((tokenAllocation, index) => {
const tokenAllocationError = (
errors?.erc20Token?.tokenAllocations as FormikErrors<
TokenAllocation<BigNumberValuePair>[] | undefined
TokenAllocation<BigIntValuePair>[] | undefined
>
)?.[index];

Expand All @@ -72,7 +72,7 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
const amountErrorMessage =
values.erc20Token.tokenSupply.value &&
tokenAllocationError?.amount?.value &&
!tokenAllocation.amount.bigNumberValue?.isZero()
tokenAllocation.amount.bigintValue !== 0n
? tokenAllocationError.amount.value
: null;

Expand All @@ -83,9 +83,7 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
remove={remove}
addressErrorMessage={addressErrorMessage}
amountErrorMessage={amountErrorMessage}
amountInputValue={
values.erc20Token.tokenAllocations[index].amount.bigNumberValue
}
amountInputValue={values.erc20Token.tokenAllocations[index].amount.bigintValue}
allocationLength={values.erc20Token.tokenAllocations.length}
{...props}
/>
Expand Down Expand Up @@ -140,14 +138,14 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
<LabelWrapper
errorMessage={
(
values.erc20Token.parentAllocationAmount?.bigNumberValue &&
values.erc20Token.parentAllocationAmount?.bigintValue &&
(errors.erc20Token?.parentAllocationAmount as any)
)?.value
}
>
<BigNumberInput
<BigIntInput
data-testid="tokenVoting-parentTokenAllocationInput"
value={values.erc20Token.parentAllocationAmount?.bigNumberValue}
value={values.erc20Token.parentAllocationAmount?.bigintValue}
onChange={valuePair =>
setFieldValue('erc20Token.parentAllocationAmount', valuePair)
}
Expand Down
Loading

0 comments on commit c18bfdf

Please sign in to comment.