Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Some cleanup work to close up PRD offshoot issues #2578

Merged
merged 10 commits into from
Dec 4, 2024
45 changes: 4 additions & 41 deletions src/components/DaoCreator/formComponents/AzoriusGovernance.tsx
Original file line number Diff line number Diff line change
@@ -1,27 +1,22 @@
import {
Alert,
Box,
Button,
Flex,
FormControl,
HStack,
InputGroup,
InputRightElement,
NumberDecrementStepper,
NumberIncrementStepper,
NumberInput,
NumberInputField,
Switch,
Text,
} from '@chakra-ui/react';
import { Minus, Plus, WarningCircle } from '@phosphor-icons/react';
import { useCallback, useEffect, useMemo, useState, memo } from 'react';
import { WarningCircle } from '@phosphor-icons/react';
import { useCallback, useEffect, useMemo, useState } from 'react';
import { useTranslation } from 'react-i18next';
import { useDaoInfoStore } from '../../../store/daoInfo/useDaoInfoStore';
import { FractalModuleType, ICreationStepProps, VotingStrategyType } from '../../../types';
import { BigIntInput } from '../../ui/forms/BigIntInput';
import { CustomNonceInput } from '../../ui/forms/CustomNonceInput';
import { LabelComponent } from '../../ui/forms/InputComponent';
import { NumberStepperInput } from '../../ui/forms/NumberStepperInput';
import { StepButtons } from '../StepButtons';
import { StepWrapper } from '../StepWrapper';
import useStepRedirect from '../hooks/useStepRedirect';
Expand All @@ -34,38 +29,6 @@ function DayStepperInput({
inputValue: number;
onInputChange: (val: number) => void;
}) {
const MemoizedNumberStepperInput = memo(
({ value, onChange }: { value?: string | number; onChange: (val: string) => void }) => {
const stepperButton = (direction: 'inc' | 'dec') => (
<Button
variant="secondary"
borderColor="neutral-3"
p="0.5rem"
size="md"
>
{direction === 'inc' ? <Plus size="1.5rem" /> : <Minus size="1.5rem" />}
</Button>
);

return (
<NumberInput
value={value}
onChange={onChange}
min={0}
focusInputOnChange
w="100%"
>
<HStack gap="0.25rem">
<NumberDecrementStepper>{stepperButton('dec')}</NumberDecrementStepper>
<NumberInputField min={0} />
<NumberIncrementStepper>{stepperButton('inc')}</NumberIncrementStepper>
</HStack>
</NumberInput>
);
},
);
MemoizedNumberStepperInput.displayName = 'MemoizedNumberInput';

const { t } = useTranslation('common');

return (
Expand All @@ -76,7 +39,7 @@ function DayStepperInput({
gap="0.5rem"
>
<Text color="neutral-7">{t('days', { ns: 'common' })}</Text>
<MemoizedNumberStepperInput
<NumberStepperInput
value={inputValue}
onChange={val => onInputChange(Number(val))}
/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
<Grid
gridTemplateColumns="1fr 35% 2rem"
columnGap={4}
rowGap={2}
rowGap={8}
data-testid="tokenVoting-tokenAllocations"
>
<Text>{t('titleAddress')}</Text>
Expand Down Expand Up @@ -80,6 +80,7 @@ export function AzoriusTokenAllocations(props: ICreationStepProps) {
);
})}
</Grid>

<Text
color="neutral-7"
textStyle="labels-large"
Expand Down
80 changes: 32 additions & 48 deletions src/components/DaoCreator/formComponents/AzoriusTokenDetails.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
import { Box, Flex, Input, RadioGroup, Text } from '@chakra-ui/react';
import { Info } from '@phosphor-icons/react';
import { Box, Flex, Input, RadioGroup } from '@chakra-ui/react';
import { useFormikContext } from 'formik';
import { useCallback, useEffect, useState } from 'react';
import { useTranslation } from 'react-i18next';
import { erc20Abi, getContract, isAddress, zeroAddress } from 'viem';
import { usePublicClient, useWalletClient } from 'wagmi';
import { createAccountSubstring } from '../../../hooks/utils/useGetAccountName';
import { ICreationStepProps, TokenCreationType } from '../../../types';
import SupportTooltip from '../../ui/badges/SupportTooltip';
import { CreatorFormState, ICreationStepProps, TokenCreationType } from '../../../types';
import ContentBoxTitle from '../../ui/containers/ContentBox/ContentBoxTitle';
import LabelWrapper from '../../ui/forms/LabelWrapper';
import { RadioWithText } from '../../ui/forms/Radio/RadioWithText';
Expand All @@ -30,23 +29,17 @@ function TokenConfigDisplay(props: ICreationStepProps) {
}

export function AzoriusTokenDetails(props: ICreationStepProps) {
const {
transactionPending,
isSubDAO,
setFieldValue,
values,
errors,
handleChange,
isSubmitting,
mode,
} = props;
const { transactionPending, isSubDAO, setFieldValue, errors, handleChange, isSubmitting, mode } =
props;

const { t } = useTranslation('daoCreate');
const { data: walletClient } = useWalletClient();
const publicClient = usePublicClient();

const { values, touched, setTouched } = useFormikContext<CreatorFormState>();

const { checkVotesToken } = usePrepareFormData();
const [isImportedVotesToken, setIsImportedVotesToken] = useState<boolean>();
const [isImportedVotesToken, setIsValidERC20VotesToken] = useState<boolean>();

useStepRedirect({ values });
const updateImportFields = useCallback(async () => {
Expand Down Expand Up @@ -81,17 +74,13 @@ export function AzoriusTokenDetails(props: ICreationStepProps) {
},
true,
);
if (!isVotesToken) {
setFieldValue('erc20Token.tokenName', 'Wrapped ' + name, true);
setFieldValue('erc20Token.tokenSymbol', 'W' + symbol, true);
setIsImportedVotesToken(false);
} else {
setIsImportedVotesToken(true);
if (isVotesToken) {
setIsValidERC20VotesToken(true);
setFieldValue('erc20Token.tokenName', name, true);
setFieldValue('erc20Token.tokenSymbol', symbol, true);
}
} else {
setIsImportedVotesToken(undefined);
setIsValidERC20VotesToken(undefined);
}
}, [
checkVotesToken,
Expand All @@ -106,10 +95,15 @@ export function AzoriusTokenDetails(props: ICreationStepProps) {
updateImportFields();
}, [updateImportFields]);

const tokenImportAddressErrorMessage =
values.erc20Token.tokenImportAddress && errors?.erc20Token?.tokenImportAddress
? errors.erc20Token.tokenImportAddress
: undefined;
let tokenErrorMsg = '';

if (touched.erc20Token?.tokenImportAddress) {
console.log(errors?.erc20Token?.tokenImportAddress);

tokenErrorMsg =
errors?.erc20Token?.tokenImportAddress ||
(!isImportedVotesToken ? t('errorNotVotingToken') : '');
}

Da-Colon marked this conversation as resolved.
Show resolved Hide resolved
return (
<>
Expand Down Expand Up @@ -162,35 +156,25 @@ export function AzoriusTokenDetails(props: ICreationStepProps) {
</RadioGroup>
{values.erc20Token.tokenCreationType === TokenCreationType.IMPORTED && (
<>
<LabelWrapper errorMessage={tokenImportAddressErrorMessage}>
<LabelWrapper errorMessage={tokenErrorMsg}>
<Input
name="erc20Token.tokenImportAddress"
onChange={handleChange}
onChange={e => {
setTouched({
erc20Token: {
tokenImportAddress: true,
},
...touched,
});

handleChange(e);
}}
value={values.erc20Token.tokenImportAddress}
placeholder={createAccountSubstring(zeroAddress)}
isInvalid={!!tokenImportAddressErrorMessage}
isInvalid={!!tokenErrorMsg}
isRequired
/>
</LabelWrapper>
{isImportedVotesToken === false && !errors.erc20Token?.tokenImportAddress && (
<Flex
gap={4}
alignItems="center"
>
<SupportTooltip
IconComponent={Info}
label={t('warningExistingTokenTooltip')}
color="neutral-7"
/>
<Text
color="neutral-7"
textStyle="labels-large"
whiteSpace="pre-wrap"
>
{t('warningExistingToken')}
</Text>
</Flex>
)}
</>
)}
</Flex>
Expand Down
32 changes: 16 additions & 16 deletions src/components/DaoCreator/formComponents/Multisig.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,12 @@
import {
Text,
Flex,
Grid,
IconButton,
NumberInput,
NumberInputField,
Icon,
Button,
} from '@chakra-ui/react';
import { Text, Flex, Grid, IconButton, Icon, Button } from '@chakra-ui/react';
import { MinusCircle, Plus } from '@phosphor-icons/react';
import { Field, FieldAttributes } from 'formik';
import { useTranslation } from 'react-i18next';
import { ICreationStepProps } from '../../../types';
import { AddressInput } from '../../ui/forms/EthAddressInput';
import { LabelComponent } from '../../ui/forms/InputComponent';
import LabelWrapper from '../../ui/forms/LabelWrapper';
import { NumberStepperInput } from '../../ui/forms/NumberStepperInput';
import { StepButtons } from '../StepButtons';
import { StepWrapper } from '../StepWrapper';
import useStepRedirect from '../hooks/useStepRedirect';
Expand Down Expand Up @@ -119,6 +111,17 @@ export function Multisig(props: ICreationStepProps) {
(_, index) => index !== i,
),
});

// If this removal causes the threshold to be higher than the number of signers, adjust the threshold
if (
values.multisig.signatureThreshold! >
values.multisig.numOfSigners! - 1
) {
setFieldValue(
'multisig.signatureThreshold',
values.multisig.numOfSigners! - 1,
);
}
}}
data-testid={'multisig.numOfSigners-' + i}
/>
Expand All @@ -139,13 +142,10 @@ export function Multisig(props: ICreationStepProps) {
isRequired
>
{/* @todo replace with stepper input */}
<NumberInput
value={values.multisig.signatureThreshold}
<NumberStepperInput
onChange={value => validateNumber(value, 'multisig.signatureThreshold')}
isInvalid={!!errors.multisig?.signatureThreshold}
>
<NumberInputField data-testid="safeConfig-thresholdInput" />
</NumberInput>
value={values.multisig.signatureThreshold}
/>
</LabelComponent>
</Flex>
</StepWrapper>
Expand Down
2 changes: 1 addition & 1 deletion src/components/ui/forms/EthAddressInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ export function AddressInput({ value, onChange, ...rest }: InputProps) {
() =>
debounce((event: ChangeEvent<HTMLInputElement>) => {
if (onChange) onChange(event);
}, 300),
}, 500),
[onChange],
);

Expand Down
44 changes: 44 additions & 0 deletions src/components/ui/forms/NumberStepperInput.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import {
Button,
HStack,
NumberDecrementStepper,
NumberIncrementStepper,
NumberInput,
NumberInputField,
} from '@chakra-ui/react';
import { Plus, Minus } from '@phosphor-icons/react';

export function NumberStepperInput({
value,
onChange,
}: {
value?: string | number;
onChange: (val: string) => void;
}) {
const stepperButton = (direction: 'inc' | 'dec') => (
<Button
variant="secondary"
borderColor="neutral-3"
p="0.5rem"
size="md"
>
{direction === 'inc' ? <Plus size="1.5rem" /> : <Minus size="1.5rem" />}
</Button>
);

return (
<NumberInput
value={value}
onChange={onChange}
min={0}
focusInputOnChange
w="100%"
>
<HStack gap="0.25rem">
<NumberDecrementStepper>{stepperButton('dec')}</NumberDecrementStepper>
<NumberInputField min={0} />
<NumberIncrementStepper>{stepperButton('inc')}</NumberIncrementStepper>
</HStack>
</NumberInput>
);
}
1 change: 0 additions & 1 deletion src/components/ui/links/ExternalLink.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ export default function ExternalLink({
grey: {
hover: {
bg: 'neutral-2',
borderColor: 'neutral-4',
},
active: {
bg: 'neutral-5',
Expand Down
14 changes: 0 additions & 14 deletions src/components/ui/modals/ModalProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,11 @@ import PaymentWithdrawModal from './PaymentWithdrawModal';
import ProposalTemplateModal from './ProposalTemplateModal';
import StakeModal from './Stake';
import { UnsavedChangesWarningContent } from './UnsavedChangesWarningContent';
import { UnwrapToken } from './UnwrapToken';
import { WrapToken } from './WrapToken';

export enum ModalType {
NONE,
DELEGATE,
STAKE,
WRAP_TOKEN,
UNWRAP_TOKEN,
CONFIRM_URL,
REMOVE_SIGNER,
ADD_SIGNER,
Expand All @@ -50,8 +46,6 @@ export type ModalPropsTypes = {
[ModalType.NONE]: {};
[ModalType.DELEGATE]: {};
[ModalType.STAKE]: {};
[ModalType.WRAP_TOKEN]: {};
[ModalType.UNWRAP_TOKEN]: {};
[ModalType.ADD_PERMISSION]: {};
[ModalType.CONFIRM_DELETE_STRATEGY]: {};
[ModalType.CONFIRM_URL]: { url: string };
Expand Down Expand Up @@ -151,14 +145,6 @@ export function ModalProvider({ children }: { children: ReactNode }) {
modalTitle = t('stakeTitle');
modalContent = <StakeModal close={closeModal} />;
break;
case ModalType.WRAP_TOKEN:
modalTitle = t('wrapTokenTitle');
modalContent = <WrapToken close={closeModal} />;
break;
case ModalType.UNWRAP_TOKEN:
modalTitle = t('unwrapTokenTitle');
modalContent = <UnwrapToken close={closeModal} />;
break;
case ModalType.CONFIRM_URL:
modalTitle = t('confirmUrlTitle');
hasWarning = true;
Expand Down
Loading
Loading