diff --git a/packages/browser-wallet/src/popup/popupX/constants/routes.ts b/packages/browser-wallet/src/popup/popupX/constants/routes.ts index 3198cc868..7929bc02d 100644 --- a/packages/browser-wallet/src/popup/popupX/constants/routes.ts +++ b/packages/browser-wallet/src/popup/popupX/constants/routes.ts @@ -200,10 +200,6 @@ export const relativeRoutes = { update: { path: 'update', }, - /** Remove existing delegator */ - stop: { - path: 'stop', - }, /** Submit configure delegator transaction */ submit: { path: 'submit', diff --git a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Result/DelegationResult.tsx b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Result/DelegationResult.tsx index 0855278ba..4557a7b88 100644 --- a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Result/DelegationResult.tsx +++ b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Result/DelegationResult.tsx @@ -1,6 +1,7 @@ import React, { useCallback, useMemo } from 'react'; import { AccountAddress, + AccountInfoDelegator, AccountTransactionPayload, AccountTransactionType, CcdAmount, @@ -34,6 +35,7 @@ import { addPendingTransactionAtom } from '@popup/store/transactions'; import { cpStakingCooldown } from '@shared/utils/chain-parameters-helpers'; import { submittedTransactionRoute } from '@popup/popupX/constants/routes'; import Text from '@popup/popupX/shared/Text'; +import { useSelectedAccountInfo } from '@popup/shared/AccountInfoListenerContext/AccountInfoListenerContext'; enum TransactionSubmitErrorType { InsufficientFunds = 'InsufficientFunds', @@ -96,11 +98,11 @@ export default function DelegationResult() { const nav = useNavigate(); const { t } = useTranslation('x', { keyPrefix: 'earn.delegator' }); const getCost = useGetTransactionFee(AccountTransactionType.ConfigureDelegation); - const account = ensureDefined(useAtomValue(selectedAccountAtom), 'No account selected'); + const accountInfo = ensureDefined(useSelectedAccountInfo(), 'No account selected'); const parametersV1 = useBlockChainParametersAboveV0(); const submitTransaction = useTransactionSubmit( - AccountAddress.fromBase58(account), + accountInfo.accountAddress, AccountTransactionType.ConfigureDelegation ); @@ -112,19 +114,26 @@ export default function DelegationResult() { return secondsToDaysRoundedDown(cooldownParam); }, [parametersV1]); - const title = useMemo(() => { + const [title, notice] = useMemo(() => { switch (state?.type) { case 'register': - return t('register.title'); + return [t('register.title'), t('register.notice', { cooldown })]; case 'change': - return t('update.title'); - // case 'remove': - // return t('remove.title'); + if ( + state.payload.stake === undefined || + state.payload.stake.microCcdAmount >= + (accountInfo as AccountInfoDelegator).accountDelegation.stakedAmount.microCcdAmount + ) { + // Staked amount is not lowered + return [t('update.title')]; + } + return [t('update.title'), t('update.lowerStakeNotice', { cooldown })]; + case 'remove': + return [t('remove.title'), t('remove.notice', { cooldown })]; default: - return undefined; + throw new Error("'type' must be defined on route state"); } - }, [state, t]); - const notice = t('register.notice', { cooldown }); // TODO: add more cases when supporting change/remove + }, [state, t, cooldown]); if (state === undefined) { return ; @@ -142,10 +151,10 @@ export default function DelegationResult() { return ( - {notice} + {notice !== undefined && {notice}} - + {state.payload.delegationTarget !== undefined && ( diff --git a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Status.tsx b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Status.tsx index 5180cf31d..436075f5b 100644 --- a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Status.tsx +++ b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/Delegator/Status.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import { AccountInfoType, DelegationTargetType } from '@concordium/web-sdk'; +import { AccountInfoType, CcdAmount, DelegationTargetType } from '@concordium/web-sdk'; import { absoluteRoutes } from '@popup/popupX/constants/routes'; import Button from '@popup/popupX/shared/Button'; import Card from '@popup/popupX/shared/Card'; @@ -9,6 +9,12 @@ import { formatCcdAmount } from '@popup/popupX/shared/utils/helpers'; import { useSelectedAccountInfo } from '@popup/shared/AccountInfoListenerContext/AccountInfoListenerContext'; import { Navigate, useNavigate } from 'react-router-dom'; import AccountCooldowns from '../AccountCooldowns'; +import { DelegationResultLocationState } from './Result/DelegationResult'; + +const REMOVE_STATE: DelegationResultLocationState = { + type: 'remove', + payload: { stake: CcdAmount.zero() }, +}; export default function DelegatorStatus() { const { t } = useTranslation('x', { keyPrefix: 'earn.delegator' }); @@ -63,7 +69,7 @@ export default function DelegatorStatus() { /> nav(absoluteRoutes.settings.earn.delegator.stop.path)} + onClick={() => nav(absoluteRoutes.settings.earn.delegator.submit.path, { state: REMOVE_STATE })} /> diff --git a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/i18n/en.ts b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/i18n/en.ts index c40b23b60..f1d1cc971 100644 --- a/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/i18n/en.ts +++ b/packages/browser-wallet/src/popup/popupX/pages/EarningRewards/i18n/en.ts @@ -76,6 +76,12 @@ const t = { description: 'The proposed transaction contains no changes compared to the current delegation.', buttonBack: 'Go back', }, + lowerStakeNotice: + 'Reducing your stake is subject to a cooldown period of {{cooldown}} days, in which the stake cannot be spent or transferred.', + }, + remove: { + title: 'Remove delegation', + notice: 'The delegated stake is released after {{cooldown}} days', }, target: { description: 'You can delegate to an open pool of your choice, or you can stake using passive delegation.', diff --git a/packages/browser-wallet/src/popup/popupX/shell/Routes.tsx b/packages/browser-wallet/src/popup/popupX/shell/Routes.tsx index 1db811f46..47f799e76 100644 --- a/packages/browser-wallet/src/popup/popupX/shell/Routes.tsx +++ b/packages/browser-wallet/src/popup/popupX/shell/Routes.tsx @@ -133,7 +133,6 @@ export default function Routes({ messagePromptHandlers }: { messagePromptHandler element={} path={`${relativeRoutes.settings.earn.delegator.update.path}/*`} /> - TODO} path={`${relativeRoutes.settings.earn.delegator.stop.path}`} /> } path={relativeRoutes.settings.earn.delegator.submit.path} diff --git a/packages/browser-wallet/src/shared/utils/time-helpers.ts b/packages/browser-wallet/src/shared/utils/time-helpers.ts index 4573a4df2..a62b60b7c 100644 --- a/packages/browser-wallet/src/shared/utils/time-helpers.ts +++ b/packages/browser-wallet/src/shared/utils/time-helpers.ts @@ -1,7 +1,7 @@ import { MILLISECONDS_PER_DAY, MILLISECONDS_PER_HOUR, MILLISECONDS_PER_MINUTE } from '@popup/constants/time'; export function secondsToDaysRoundedDown(seconds: bigint | undefined): bigint { - return seconds ? seconds / (60n * 60n * 24n) : 0n; + return seconds !== undefined ? seconds / (60n * 60n * 24n) : 0n; } type TimeAndUnit = { time: bigint; unit: string };