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

verse 2.0に伴う改修 #42

Merged
merged 12 commits into from
Apr 19, 2024
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,5 @@ next-env.d.ts

# eslint
.eslintcache

note.md
24 changes: 23 additions & 1 deletion src/components/atoms/input.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,30 @@ type Props = {
disabled?: boolean;
handleClick: (e: ChangeEvent<HTMLInputElement>) => void;
className?: string;
inputType?: InputType;
};

export enum InputType {
Text = "text",
Password = "password",
Email = "email",
Number = "number",
Checkbox = "checkbox",
Radio = "radio",
File = "file",
Submit = "submit",
Button = "button",
Date = "date",
Time = "time",
DateTimeLocal = "datetime-local",
Month = "month",
Week = "week",
Color = "color",
Range = "range",
Tel = "tel",
Url = "url"
}

export const Input = (props: Props) => {
const {
value,
Expand All @@ -29,7 +51,7 @@ export const Input = (props: Props) => {
'border',
'shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 leading-tight focus:outline-4 focus:outline-green-500 focus:shadow-outline',
)}
type="text"
type={props.inputType || InputType.Text}
/>
);
};
80 changes: 60 additions & 20 deletions src/components/organisms/buildVerseModal.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import { ethers } from 'ethers';
import { ChangeEvent, SetStateAction, useState } from 'react';
import { ZERO_ADDRESS } from '@/consts';
import { getL1BuildAgentContract, handleError } from '@/features';
import { ErrorMsg, SuccessMsg, Modal } from '@/components/atoms';
import { ZERO_ADDRESS, L2_GASLIMIT, L2_OO_SUBMISSION_INTERVAL, FINALIZATION_PERIOD_SECONDS } from '@/consts';
import { getL1BuildAgentContract, handleError, getSigner } from '@/features';
import { ErrorMsg, SuccessMsg, Modal, InputType } from '@/components/atoms';
import { Form, LoadingModal } from '@/components/organisms';

type Props = {
Expand All @@ -19,26 +19,45 @@ export const BuildVerseModal = (props: Props) => {
const [buildSuccess, setBuildSuccess] = useState('');
const [isBuilding, setIsBuilding] = useState(false);
const [buildError, setBuildError] = useState('');
const [newChainId, setNewChainId] = useState('');
const [sequencerAddress, setSequencerAddress] = useState('');
const [newChainId, setNewChainId] = useState<number>();
const [finalSystemOwner, setFinalSystemOwner] = useState('');
const [proposerAddress, setProposerAddress] = useState('');
const [batchSenderAddress, setBatchSenderAddress] = useState('');
const [p2pSequencerAddress, setP2PSequencerAddress] = useState('');
const [messageRelayer, setMessageRelayer] = useState('');
const [l2BlockTime, setL2BlockTime] = useState<number>();

const build = async () => {
const L1BuildAgentContract = await getL1BuildAgentContract();
const isLegacy = false;
const L1BuildAgentContract = await getL1BuildAgentContract(isLegacy);

try {
setIsBuilding(true);
const verseChainId = ethers.BigNumber.from(newChainId).toNumber();
const addressManager = await L1BuildAgentContract.getAddressManager(verseChainId);
if (addressManager !== ZERO_ADDRESS) throw new Error(`Chain_id ${verseChainId} is already used`);

const tx: ethers.providers.TransactionResponse = await L1BuildAgentContract.build(verseChainId, sequencerAddress, proposerAddress);
if (l2BlockTime! < 1 || l2BlockTime! > 7) {
throw new Error('L2 Block Time must be between 1 and 7');
}

// At first, set default Values
// Correct values are expected to be set via another button
const l2OOStartingBlockNumber = 0;
const l2OOStartingTimestamp = (await (await getSigner()).provider.getBlock('latest')).timestamp;

const tx: ethers.providers.TransactionResponse = await L1BuildAgentContract.build(
newChainId!,
[finalSystemOwner, proposerAddress, finalSystemOwner, batchSenderAddress, p2pSequencerAddress, messageRelayer, l2BlockTime!, L2_GASLIMIT, L2_OO_SUBMISSION_INTERVAL, FINALIZATION_PERIOD_SECONDS, l2OOStartingBlockNumber, l2OOStartingTimestamp]
);
const receipt = await tx.wait();
if (receipt.status === 1) {
setBuildSuccess(`Verse build is successful. Please memo build_transaction (${tx.hash}) to check VerseInfo at check-verse-page by non_verse_builder`);
setNewChainId('');
setSequencerAddress('');
setBuildSuccess(`Verse build is successful. build transaction (${tx.hash})`);
setNewChainId(undefined);
setFinalSystemOwner('');
setProposerAddress('');
setBatchSenderAddress('');
setP2PSequencerAddress('');
setMessageRelayer('');
setL2BlockTime(undefined);
setBuildError('');
setIsBuilding(false);
}
} catch (err) {
Expand All @@ -50,25 +69,46 @@ export const BuildVerseModal = (props: Props) => {
const buildInputs = [
{
placeholder: 'set verse chain_id',
value: newChainId,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setNewChainId(e.target.value)},
value: newChainId?.toString() || '',
inputType: InputType.Number,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setNewChainId(Number(e.target.value))},
},
{
placeholder: 'set sequencer address',
value: sequencerAddress,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setSequencerAddress(e.target.value)},
placeholder: 'set final system owner',
value: finalSystemOwner,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setFinalSystemOwner(e.target.value)},
},
{
placeholder: 'set proposer address',
value: proposerAddress,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setProposerAddress(e.target.value)},
},
{
placeholder: 'set batch sender address',
value: batchSenderAddress,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setBatchSenderAddress(e.target.value)},
},
{
placeholder: 'set p2p sequencer address',
value: p2pSequencerAddress,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setP2PSequencerAddress(e.target.value)},
},
{
placeholder: 'set message relayer address',
value: messageRelayer,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setMessageRelayer(e.target.value)},
},
{
placeholder: 'set L2 Block Time (range of 1 to 7)',
value: l2BlockTime?.toString() || '',
inputType: InputType.Number,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setL2BlockTime(Number(e.target.value))},
},
];

const buildButtons = [
{
handleClick: build,
disabled: !sequencerAddress || !proposerAddress || isBuilding,
disabled: !finalSystemOwner || !batchSenderAddress || !p2pSequencerAddress || !proposerAddress || !messageRelayer || !l2BlockTime || isBuilding,
value: 'Build',
}
];
Expand Down
40 changes: 24 additions & 16 deletions src/components/organisms/changeDepositModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,14 @@ import { LoadingModal } from '.';
type Props = {
className?: string;
setModalState: (value: SetStateAction<boolean>) => void;
isLegacy: boolean;
};

export const ChangeDepositModal = (props: Props) => {
const {
className,
setModalState,
isLegacy,
} = props;

const [depositSuccess, setDepositSuccess] = useState('');
Expand All @@ -26,12 +28,12 @@ export const ChangeDepositModal = (props: Props) => {
const [SOASVerseBuilder, setSOASVerseBuilder] = useState('');
const [OASAmount, setOASAmount] = useState('');
const [SOASAmount, setSOASAmount] = useState('');

const refreshL1BuildDeposit = useRefreshL1BuildDeposit();

const depositOAS = async () => {
try {
const L1BuildDepositContract = await getL1BuildDepositContract();
const L1BuildDepositContract = await getL1BuildDepositContract(isLegacy);
const value = ethers.utils.parseEther(OASAmount);
const options = { value: value };
setIsDepositLoading(true);
Expand All @@ -43,6 +45,7 @@ export const ChangeDepositModal = (props: Props) => {
setDepositSuccess(`${oasAmount}${OASTokenUnit} deposit is successful`);
setOASAmount('');
setOASVerseBuilder('');
setDepositError('');
setIsDepositLoading(false);
refreshL1BuildDeposit();
});
Expand All @@ -54,7 +57,7 @@ export const ChangeDepositModal = (props: Props) => {

const withdrawOAS = async () => {
try {
const L1BuildDepositContract = await getL1BuildDepositContract();
const L1BuildDepositContract = await getL1BuildDepositContract(isLegacy);
const value = ethers.utils.parseEther(OASAmount);
setIsDepositLoading(true);
await L1BuildDepositContract.withdraw(OASVerseBuilder, value);
Expand All @@ -65,6 +68,7 @@ export const ChangeDepositModal = (props: Props) => {
setDepositSuccess(`${oasAmount}${OASTokenUnit} withdraw is successful`);
setOASAmount('');
setOASVerseBuilder('');
setDepositError('');
setIsDepositLoading(false);
refreshL1BuildDeposit();
});
Expand All @@ -76,7 +80,7 @@ export const ChangeDepositModal = (props: Props) => {

const depositSOAS = async () => {
try {
const L1BuildDepositContract = await getL1BuildDepositContract();
const L1BuildDepositContract = await getL1BuildDepositContract(isLegacy);
const sOASContract = await getSOASContract();
const value = ethers.utils.parseEther(SOASAmount);
setIsDepositLoading(true);
Expand All @@ -101,7 +105,7 @@ export const ChangeDepositModal = (props: Props) => {

const withdrawSOAS = async () => {
try {
const L1BuildDepositContract = await getL1BuildDepositContract();
const L1BuildDepositContract = await getL1BuildDepositContract(isLegacy);
const value = ethers.utils.parseEther(SOASAmount);
setIsDepositLoading(true);
await L1BuildDepositContract.withdrawERC20(SOASVerseBuilder, sOASAddress, value);
Expand Down Expand Up @@ -147,18 +151,22 @@ export const ChangeDepositModal = (props: Props) => {
withdraw={withdrawOAS}
idDepositLoading={idDepositLoading}
tokenUnit={OASTokenUnit}
isLegacy={isLegacy}
/>
<Deposit
className='space-y-0.5'
amount={SOASAmount}
builder={SOASVerseBuilder}
setAmount={setSOASAmount}
setBuilder={setSOASVerseBuilder}
deposit={depositSOAS}
withdraw={withdrawSOAS}
idDepositLoading={idDepositLoading}
tokenUnit={sOASTokenUnit}
/>
{isLegacy && (
<Deposit
className='space-y-0.5'
amount={SOASAmount}
builder={SOASVerseBuilder}
setAmount={setSOASAmount}
setBuilder={setSOASVerseBuilder}
deposit={depositSOAS}
withdraw={withdrawSOAS}
idDepositLoading={idDepositLoading}
tokenUnit={sOASTokenUnit}
isLegacy={isLegacy}
/>
)}
</div>
</Modal>
}
Expand Down
77 changes: 37 additions & 40 deletions src/components/organisms/checkDepositModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,11 @@ type Props = {
className?: string;
ownerAddress: string;
setModalState: (value: SetStateAction<boolean>) => void;
isLegacy: boolean;
};

export const CheckDepositModal = (props: Props) => {
const {
className,
ownerAddress,
setModalState,
} = props;
const { className, ownerAddress, setModalState, isLegacy } = props;

const [checkSuccess, setCheckSuccess] = useState('');
const [isChecking, setIsChecking] = useState(false);
Expand All @@ -27,13 +24,20 @@ export const CheckDepositModal = (props: Props) => {
const [depositSOAS, setDepositSOAS] = useState<ethers.BigNumber>();

const check = async () => {
const L1BuildDepositContract = await getL1BuildDepositContract();
const L1BuildDepositContract = await getL1BuildDepositContract(isLegacy);

try {
setIsChecking(true);
const depositTotal: ethers.BigNumber = await L1BuildDepositContract.getDepositTotal(builder);
const depositOAS: ethers.BigNumber = await L1BuildDepositContract.getDepositAmount(builder, ownerAddress);
const depositSOAS: ethers.BigNumber = await L1BuildDepositContract.getDepositERC20Amount(builder, ownerAddress, sOASAddress);
const depositTotal: ethers.BigNumber =
await L1BuildDepositContract.getDepositTotal(builder);
const depositOAS: ethers.BigNumber =
await L1BuildDepositContract.getDepositAmount(builder, ownerAddress);
const depositSOAS: ethers.BigNumber =
await L1BuildDepositContract.getDepositERC20Amount(
builder,
ownerAddress,
sOASAddress,
);

setDepositTotal(depositTotal);
setDepositOAS(depositOAS);
Expand All @@ -52,7 +56,9 @@ export const CheckDepositModal = (props: Props) => {
{
placeholder: 'set builder address',
value: builder,
handleClick: (e: ChangeEvent<HTMLInputElement>) => {setBuilder(e.target.value)},
handleClick: (e: ChangeEvent<HTMLInputElement>) => {
setBuilder(e.target.value);
},
},
];

Expand All @@ -61,39 +67,30 @@ export const CheckDepositModal = (props: Props) => {
handleClick: check,
disabled: !builder || isChecking,
value: 'Check Deposit',
}
},
];

return (
<>
{isChecking &&
<LoadingModal />
}
{!isChecking &&
<Modal
setModalState={setModalState}
>
<div className='space-y-4'>
{checkSuccess && (
<SuccessMsg className='w-full' text={checkSuccess} />
)}
{checkError && (
<ErrorMsg className='w-full' text={ checkError } />
)}
<Form
inputs={inputs}
buttons={buttons}
/>
{depositTotal && depositOAS && depositSOAS &&
<DepositDetail
depositTotal={depositTotal}
depositOAS={depositOAS}
depositSOAS={depositSOAS}
/>
}
</div>
</Modal>
}
{isChecking && <LoadingModal />}
{!isChecking && (
<Modal setModalState={setModalState}>
<div className='space-y-4'>
{checkSuccess && (
<SuccessMsg className='w-full' text={checkSuccess} />
)}
{checkError && <ErrorMsg className='w-full' text={checkError} />}
<Form inputs={inputs} buttons={buttons} />
{depositTotal && depositOAS && depositSOAS && (
<DepositDetail
depositTotal={depositTotal}
depositOAS={depositOAS}
depositSOAS={depositSOAS}
/>
)}
</div>
</Modal>
)}
</>
)
);
};
Loading
Loading