Skip to content

Commit

Permalink
update tx data in the controller
Browse files Browse the repository at this point in the history
  • Loading branch information
pedronfigueiredo committed Sep 6, 2024
1 parent 2fd3612 commit ad23725
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 30 deletions.
10 changes: 0 additions & 10 deletions ui/pages/confirmations/components/confirm/info/approve/approve.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,6 @@ const ApproveInfo = () => {

const [isOpenEditSpendingCapModal, setIsOpenEditSpendingCapModal] =
useState(false);
const [customSpendingCap, setCustomSpendingCap] = useState('');

const setCustomSpendingCapCandidate = (newValue: string) => {
const value = parseInt(newValue, 10);
// coerce negative numbers to zero
setCustomSpendingCap(value < 0 ? '0' : newValue);
};

if (!transactionMeta?.txParams) {
return null;
Expand All @@ -43,16 +36,13 @@ const ApproveInfo = () => {
{!isNFT && (
<SpendingCap
setIsOpenEditSpendingCapModal={setIsOpenEditSpendingCapModal}
customSpendingCap={customSpendingCap}
/>
)}
<GasFeesSection />
{showAdvancedDetails && <AdvancedDetails />}
<EditSpendingCapModal
isOpenEditSpendingCapModal={isOpenEditSpendingCapModal}
setIsOpenEditSpendingCapModal={setIsOpenEditSpendingCapModal}
customSpendingCap={customSpendingCap}
setCustomSpendingCap={setCustomSpendingCapCandidate}
/>
</>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import {
TextField,
TextFieldType,
} from '../../../../../../../components/component-library';
import { updateCurrentConfirmation } from '../../../../../../../ducks/confirm/confirm';
import {
AlignItems,
Display,
Expand All @@ -24,6 +23,7 @@ import {
TextVariant,
} from '../../../../../../../helpers/constants/design-system';
import { useI18nContext } from '../../../../../../../hooks/useI18nContext';
import { updateEditableParams } from '../../../../../../../store/actions';
import { getCustomTxParamsData } from '../../../../../confirm-approve/confirm-approve.util';
import { useConfirmContext } from '../../../../../context/confirm';
import { useAssetDetails } from '../../../../../hooks/useAssetDetails';
Expand All @@ -38,13 +38,9 @@ export const getAccountBalance = (userBalance: string, decimals: string) =>
export const EditSpendingCapModal = ({
isOpenEditSpendingCapModal,
setIsOpenEditSpendingCapModal,
customSpendingCap,
setCustomSpendingCap,
}: {
isOpenEditSpendingCapModal: boolean;
setIsOpenEditSpendingCapModal: (newValue: boolean) => void;
customSpendingCap: string;
setCustomSpendingCap: (newValue: string) => void;
}) => {
const t = useI18nContext();

Expand All @@ -67,13 +63,19 @@ export const EditSpendingCapModal = ({
decimals || '0',
);

const [customSpendingCapCandidate, setCustomSpendingCapCandidate] =
const [customSpendingCapInputValue, setCustomSpendingCapInputValue] =
useState('');
const [customSpendingCap, setCustomSpendingCap] = useState('');
const setPositiveSpendingCap = (newValue: string) => {
const parsedValue = parseInt(newValue, 10);
// coerce negative numbers to zero
setCustomSpendingCap(parsedValue < 0 ? '0' : newValue);
};

const customTxParamsData = useMemo(() => {
return getCustomTxParamsData(transactionMeta?.txParams?.data, {
customPermissionAmount: customSpendingCap || '0',
decimals,
decimals: decimals || '0',
});
}, [customSpendingCap, transactionMeta?.txParams?.data, decimals]);

Expand All @@ -85,10 +87,12 @@ export const EditSpendingCapModal = ({

useEffect(() => {
if (customSpendingCap && estimatedGasLimit) {
transactionMeta.txParams.data = customTxParamsData;
transactionMeta.txParams.gas = hexToDecimal(estimatedGasLimit as string);

dispatch(updateCurrentConfirmation(transactionMeta));
dispatch(
updateEditableParams(transactionMeta.id, {
data: customTxParamsData,
gas: hexToDecimal(estimatedGasLimit as string),
}),
);
}
}, [
customSpendingCap,
Expand All @@ -100,13 +104,13 @@ export const EditSpendingCapModal = ({

const handleCancel = () => {
setIsOpenEditSpendingCapModal(false);
setCustomSpendingCapCandidate('');
setCustomSpendingCapInputValue('');
};

function handleSubmit() {
setIsOpenEditSpendingCapModal(false);
setCustomSpendingCapCandidate('');
setCustomSpendingCap(customSpendingCapCandidate);
setCustomSpendingCapInputValue('');
setPositiveSpendingCap(customSpendingCapInputValue);
}

return (
Expand Down Expand Up @@ -139,9 +143,9 @@ export const EditSpendingCapModal = ({
</Text>
<TextField
type={TextFieldType.Number}
value={customSpendingCapCandidate}
value={customSpendingCapInputValue}
onChange={(event) =>
setCustomSpendingCapCandidate(event.target.value)
setCustomSpendingCapInputValue(event.target.value)
}
placeholder={`${
customSpendingCap === ''
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,10 +77,8 @@ const SpendingCapGroup = ({

export const SpendingCap = ({
setIsOpenEditSpendingCapModal,
customSpendingCap,
}: {
setIsOpenEditSpendingCapModal: (newValue: boolean) => void;
customSpendingCap: string;
}) => {
const t = useI18nContext();

Expand All @@ -96,11 +94,13 @@ export const SpendingCap = ({

const accountBalance = getAccountBalance(userBalance || '0', decimals || '0');

const { pending } = useApproveTokenSimulation(
const { pending, spendingCap } = useApproveTokenSimulation(
transactionMeta,
decimals || '0',
);

console.log({ transactionMeta, decodedSpendingCap: spendingCap });

if (pending) {
return <Container isLoading />;
}
Expand All @@ -115,7 +115,7 @@ export const SpendingCap = ({
tokenSymbol={tokenSymbol || ''}
decimals={decimals || '0'}
setIsOpenEditSpendingCapModal={setIsOpenEditSpendingCapModal}
customSpendingCap={customSpendingCap}
customSpendingCap={spendingCap}
/>
</ConfirmInfoSection>
);
Expand Down

0 comments on commit ad23725

Please sign in to comment.