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

refactor(apps-core, wallet-dashboard, wallet): move ValidatorLogo to apps/core and use it in Unstake Details #4475

Merged
merged 36 commits into from
Jan 20, 2025
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
fdc511d
refactor: move ValidatorLogo
panteleymonchuk Dec 12, 2024
756a4b1
refactor: remove renderValidatorLogo
panteleymonchuk Dec 12, 2024
68f6d19
refactor: rename ValidatorLogo component to Validator and update imports
panteleymonchuk Dec 12, 2024
491d745
refactor: compare & join 2 Validators
panteleymonchuk Dec 12, 2024
608b1f7
refactor: rename property, use Validator from iota/core.
panteleymonchuk Dec 12, 2024
ddee854
refactor: rename validatorAddress prop to address in Validator compon…
panteleymonchuk Dec 12, 2024
1242e66
Merge branch 'develop' into tooling/move-validator-logo
brancoder Dec 13, 2024
39d01fe
Merge branch 'develop' into tooling/move-validator-logo
brancoder Dec 13, 2024
3930678
refactor(core): update onClick type and remove unused interface
panteleymonchuk Dec 13, 2024
4533ff6
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Dec 17, 2024
2e38e2d
refactor(dashboard): update Validator after merge conflicts
panteleymonchuk Dec 17, 2024
2fd23fc
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Dec 18, 2024
f7d55b7
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Dec 18, 2024
aab3a17
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Dec 18, 2024
fe9ca29
feat(core): enhance validator's loading state with skeleton components
panteleymonchuk Dec 18, 2024
fabbaa7
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Dec 18, 2024
1b1d1aa
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Dec 19, 2024
300a8a9
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Dec 23, 2024
8e650d6
fix(core): Import CardType from apps-ui-kit in UnstakeTransactionInfo…
panteleymonchuk Dec 23, 2024
9fad775
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Dec 27, 2024
2b003a3
Merge branch 'develop' into tooling/move-validator-logo
VmMad Jan 2, 2025
ad3da08
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 5, 2025
36ec216
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Jan 8, 2025
90b3c8f
feat(core): improve showApy property
panteleymonchuk Jan 8, 2025
505860a
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Jan 10, 2025
a8c38f6
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 13, 2025
35ee1c9
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Jan 13, 2025
fa06a6c
refactor(core): remove unused React import from Validator component
panteleymonchuk Jan 13, 2025
d1299c6
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 14, 2025
f4d2cd9
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 15, 2025
4a35cef
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 16, 2025
df7e039
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
panteleymonchuk Jan 17, 2025
089c9d7
fix(core): change activeEpoch type from string to number
panteleymonchuk Jan 17, 2025
e2f96c1
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 17, 2025
69e4736
Merge branch 'develop' into tooling/move-validator-logo
panteleymonchuk Jan 20, 2025
83a0aec
Merge remote-tracking branch 'origin/develop' into tooling/move-valid…
begonaalvarezd Jan 20, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
begonaalvarezd marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
// Copyright (c) 2024 IOTA Stiftung
// Copyright (c) Mysten Labs, Inc.
// Modifications Copyright (c) 2024 IOTA Stiftung
// SPDX-License-Identifier: Apache-2.0
import { ImageIcon, ImageIconSize, formatPercentageDisplay, useValidatorInfo } from '@iota/core';
import React from 'react';
import { ImageIcon, ImageIconSize, formatPercentageDisplay, useValidatorInfo } from '../';
panteleymonchuk marked this conversation as resolved.
Show resolved Hide resolved
import {
Card,
CardBody,
Expand All @@ -10,21 +12,27 @@ import {
CardType,
Badge,
BadgeType,
ImageShape,
Skeleton,
} from '@iota/apps-ui-kit';
import { formatAddress } from '@iota/iota-sdk/utils';

interface ValidatorProps {
isSelected: boolean;
isSelected?: boolean;
address: string;
type?: CardType;
showApy?: boolean;
showActiveStatus?: boolean;
onClick?: (address: string) => void;
onClick?: () => void;
showAction?: boolean;
activeEpoch?: string;
}

export function Validator({
address,
showActiveStatus,
type,
showApy,
showActiveStatus = false,
onClick,
isSelected,
showAction = true,
Expand All @@ -38,10 +46,27 @@ export function Validator({
isApyApproxZero,
validatorSummary,
system,
isPendingValidators,
} = useValidatorInfo({
validatorAddress: address,
});

if (isPendingValidators) {
return (
<Card>
<CardImage shape={ImageShape.Rounded}>
<Skeleton widthClass="w-10" heightClass="h-10" />
</CardImage>
<div className="flex flex-col gap-y-xs">
<Skeleton widthClass="w-40" heightClass="h-3.5" />
<Skeleton widthClass="w-32" heightClass="h-3" hasSecondaryColors />
</div>
<div className="ml-auto flex flex-col gap-y-xs">
<Skeleton widthClass="w-20" heightClass="h-3.5" />
</div>
</Card>
);
}
// for inactive validators, show the epoch number
const fallBackText = activeEpoch
? `Staked ${Number(system?.epoch) - Number(activeEpoch)} epochs ago`
Expand All @@ -58,11 +83,8 @@ export function Validator({
) : (
formatAddress(address)
);

const handleClick = onClick ? () => onClick(address) : undefined;

return (
<Card type={isSelected ? CardType.Filled : CardType.Default} onClick={handleClick}>
<Card type={type || isSelected ? CardType.Filled : CardType.Default} onClick={onClick}>
<CardImage>
<ImageIcon
src={validatorSummary?.imageUrl ?? null}
Expand All @@ -72,6 +94,12 @@ export function Validator({
/>
</CardImage>
<CardBody title={validatorDisplayName} subtitle={subtitle} isTextTruncated />
{showApy && (
<CardAction
type={CardActionType.SupportingText}
title={formatPercentageDisplay(apy, '-', isApyApproxZero)}
/>
)}
{showAction && (
<CardAction
type={CardActionType.SupportingText}
Expand Down
1 change: 1 addition & 0 deletions apps/core/src/components/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,4 @@ export * from './buttons';
export * from './collapsible';
export * from './providers';
export * from './stake';
export * from './Validator';
Original file line number Diff line number Diff line change
Expand Up @@ -10,22 +10,20 @@ import { STAKING_REQUEST_EVENT, UNSTAKING_REQUEST_EVENT } from '../../constants'
import { StakeTransactionDetails } from './details';
import { UnstakeTransactionInfo } from './info';
import { TransactionSummary } from './summary';
import { RenderExplorerLink, RenderValidatorLogo } from '../../types';
import { RenderExplorerLink } from '../../types';
import { GasFees } from '../gas';

interface TransactionReceiptProps {
txn: IotaTransactionBlockResponse;
activeAddress: string | null;
summary: Exclude<ReturnType<typeof useTransactionSummary>, null>;
renderValidatorLogo: RenderValidatorLogo;
renderExplorerLink: RenderExplorerLink;
}

export function TransactionReceipt({
txn,
activeAddress,
summary,
renderValidatorLogo,
renderExplorerLink,
}: TransactionReceiptProps) {
const { events } = txn;
Expand All @@ -49,7 +47,6 @@ export function TransactionReceipt({
activeAddress={activeAddress}
event={stakeTypeTransaction}
gasSummary={summary?.gas}
renderValidatorLogo={renderValidatorLogo}
renderExplorerLink={renderExplorerLink}
/>
) : null}
Expand All @@ -60,7 +57,6 @@ export function TransactionReceipt({
event={unstakeTypeTransaction}
gasSummary={summary?.gas}
renderExplorerLink={renderExplorerLink}
renderValidatorLogo={renderValidatorLogo}
/>
) : null}
</>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,27 +1,27 @@
// Copyright (c) 2024 IOTA Stiftung
// SPDX-License-Identifier: Apache-2.0

import { CardType } from '@iota/apps-ui-kit';
import { IotaEvent } from '@iota/iota-sdk/client';
import { formatPercentageDisplay } from '../../../utils';
import { useGetValidatorsApy } from '../../../hooks';
import { TransactionAmount } from '../amount';
import { StakeTransactionInfo } from '../info';
import { IOTA_TYPE_ARG } from '@iota/iota-sdk/utils';
import type { GasSummaryType, RenderExplorerLink, RenderValidatorLogo } from '../../../types';
import { Validator } from '../../../';
import type { GasSummaryType, RenderExplorerLink } from '../../../types';

interface StakeTransactionDetailsProps {
event: IotaEvent;
activeAddress: string | null;
renderExplorerLink: RenderExplorerLink;
renderValidatorLogo: RenderValidatorLogo;
gasSummary?: GasSummaryType;
}

export function StakeTransactionDetails({
event,
gasSummary,
activeAddress,
renderValidatorLogo: ValidatorLogo,
renderExplorerLink,
}: StakeTransactionDetailsProps) {
const json = event.parsedJson as {
Expand All @@ -42,11 +42,11 @@ export function StakeTransactionDetails({
return (
<div className="flex flex-col gap-y-md">
{validatorAddress && (
<ValidatorLogo
<Validator
address={validatorAddress}
showActiveStatus
activeEpoch={json.epoch}
isSelected
type={CardType.Filled}
/>
)}
{stakedAmount && (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,18 +3,18 @@
// SPDX-License-Identifier: Apache-2.0

import React from 'react';
import { CardType } from '@iota/apps-ui-kit';
import { TransactionAmount } from '../amount';
import type { IotaEvent } from '@iota/iota-sdk/client';
import { IOTA_TYPE_ARG } from '@iota/iota-sdk/utils';
import type { GasSummaryType, RenderExplorerLink, RenderValidatorLogo } from '../../../types';
import type { GasSummaryType, RenderExplorerLink } from '../../../types';
import { useFormatCoin } from '../../../hooks';
import { Divider, KeyValueInfo, Panel } from '@iota/apps-ui-kit';
panteleymonchuk marked this conversation as resolved.
Show resolved Hide resolved
import { GasSummary } from '../../..';
import { GasSummary, Validator } from '../../..';

interface UnstakeTransactionInfoProps {
activeAddress: string | null;
event: IotaEvent;
renderValidatorLogo: RenderValidatorLogo;
renderExplorerLink: RenderExplorerLink;
gasSummary?: GasSummaryType;
}
Expand All @@ -23,7 +23,6 @@ export function UnstakeTransactionInfo({
activeAddress,
event,
gasSummary,
renderValidatorLogo: ValidatorLogo,
renderExplorerLink,
}: UnstakeTransactionInfoProps) {
const json = event.parsedJson as {
Expand All @@ -40,7 +39,7 @@ export function UnstakeTransactionInfo({

return (
<div className="flex flex-col gap-y-md">
{validatorAddress && <ValidatorLogo address={validatorAddress} isSelected />}
{validatorAddress && <Validator address={validatorAddress} type={CardType.Filled} />}
{totalAmount !== 0n && (
<TransactionAmount amount={totalAmount} coinType={IOTA_TYPE_ARG} subtitle="Total" />
)}
Expand Down
1 change: 0 additions & 1 deletion apps/core/src/interfaces/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
// Copyright (c) 2024 IOTA Stiftung
// SPDX-License-Identifier: Apache-2.0

export * from './validatorLogo.interfaces';
export * from './balanceChange.interfaces';
9 changes: 0 additions & 9 deletions apps/core/src/interfaces/validatorLogo.interfaces.ts

This file was deleted.

2 changes: 0 additions & 2 deletions apps/core/src/types/renderComponent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,6 @@

import type { PropsWithChildren, JSX } from 'react';
import type { ExplorerLinkConfig } from '../utils/getExplorerLink';
import type { ValidatorLogoProps } from '../interfaces';

export type RenderExplorerLinkProps = PropsWithChildren<ExplorerLinkConfig>;
export type RenderExplorerLink = (props: RenderExplorerLinkProps) => JSX.Element;
export type RenderValidatorLogo = (props: ValidatorLogoProps) => JSX.Element;
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
// SPDX-License-Identifier: Apache-2.0

import React from 'react';
import { useFormatCoin, useStakeTxnInfo } from '@iota/core';
import { useFormatCoin, useStakeTxnInfo, Validator } from '@iota/core';
import { IOTA_TYPE_ARG } from '@iota/iota-sdk/utils';
import {
Button,
Expand All @@ -20,8 +20,6 @@ import {
import { Field, type FieldProps, useFormikContext } from 'formik';
import { Exclamation, Loader } from '@iota/ui-icons';
import { useIotaClientQuery } from '@iota/dapp-kit';

import { Validator } from './Validator';
import { StakedInfo } from './StakedInfo';
import { DialogLayout, DialogLayoutBody, DialogLayoutFooter } from '../../layout';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import React from 'react';
import { Button, Header } from '@iota/apps-ui-kit';

import { Validator } from './Validator';
import { Validator } from '@iota/core';
import { DialogLayout, DialogLayoutBody, DialogLayoutFooter } from '../../layout';

interface SelectValidatorViewProps {
Expand Down Expand Up @@ -32,7 +32,7 @@ function SelectValidatorView({
<Validator
key={validator}
address={validator}
onClick={onSelect}
onClick={() => onSelect(validator)}
isSelected={selectedValidator === validator}
/>
))}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import {
ViewTxnOnExplorerButton,
} from '@iota/core';
import { useCurrentAccount } from '@iota/dapp-kit';
import { Validator } from './Staking/views/Validator';

interface SharedProps {
txDigest?: string | null;
Expand Down Expand Up @@ -43,7 +42,6 @@ export function TransactionDialogView({
activeAddress={activeAddress}
summary={summary}
renderExplorerLink={ExplorerLink}
renderValidatorLogo={Validator}
/>
) : (
<div className="flex h-full w-full justify-center">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ import {
} from '@iota/core';
import { useCurrentAccount, useIotaClientContext } from '@iota/dapp-kit';
import { DialogLayoutBody, DialogLayoutFooter } from '../layout';
import { Validator } from '../Staking/views/Validator';
import { Network } from '@iota/iota-sdk/client';

interface TransactionDialogDetailsProps {
Expand Down Expand Up @@ -42,7 +41,6 @@ export function TransactionDetailsLayout({ transaction, onClose }: TransactionDi
activeAddress={address}
summary={summary}
renderExplorerLink={ExplorerLink}
renderValidatorLogo={Validator}
/>
</DialogLayoutBody>
<DialogLayoutFooter>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

import { StakeRewardsPanel, ValidatorStakingData } from '@/components';
import { DialogLayout, DialogLayoutBody, DialogLayoutFooter } from '../../layout';
import { Validator } from '../../Staking/views/Validator';
import { Validator } from '@iota/core';
import { useNewUnstakeTimelockedTransaction, useNotifications } from '@/hooks';
import {
Collapsible,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@ import {
GAS_SYMBOL,
useFormatCoin,
useGetStakingValidatorDetails,
Validator,
} from '@iota/core';
import { IOTA_TYPE_ARG } from '@iota/iota-sdk/utils';
import { useCurrentAccount, useSignAndExecuteTransaction } from '@iota/dapp-kit';
import { Warning } from '@iota/ui-icons';
import { StakeRewardsPanel, ValidatorStakingData } from '@/components';
import { DialogLayout, DialogLayoutFooter, DialogLayoutBody } from '../../layout';
import { Validator } from '../../Staking/views/Validator';
import { useNewUnstakeTransaction, useNotifications } from '@/hooks';
import { IotaSignAndExecuteTransactionOutput } from '@iota/wallet-standard';
import { NotificationType } from '@/stores/notificationStore';
Expand Down
10 changes: 0 additions & 10 deletions apps/wallet/src/ui/app/components/receipt-card/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,6 @@ import {
} from '@iota/core';
import { type IotaTransactionBlockResponse } from '@iota/iota-sdk/client';

import { CardType } from '@iota/apps-ui-kit';
import { ValidatorLogo } from '../../staking/validators/ValidatorLogo';
import { ExplorerLinkHelper } from '../ExplorerLinkHelper';
import ExplorerLink from '../explorer-link';

Expand Down Expand Up @@ -40,14 +38,6 @@ export function ReceiptCard({ txn, activeAddress }: ReceiptCardProps) {
summary={summary}
activeAddress={activeAddress}
renderExplorerLink={ExplorerLinkHelper}
renderValidatorLogo={({ address, showActiveStatus, activeEpoch, isSelected }) => (
<ValidatorLogo
validatorAddress={address}
showActiveStatus={showActiveStatus}
activeEpoch={activeEpoch}
type={isSelected ? CardType.Filled : CardType.Outlined}
/>
)}
/>
<div className="pt-sm">
<ExplorerLink transactionID={digest ?? ''} type={ExplorerLinkType.Transaction}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import {
useFormatCoin,
formatPercentageDisplay,
MIN_NUMBER_IOTA_TO_STAKE,
Validator,
} from '@iota/core';
import { useIotaClientQuery } from '@iota/dapp-kit';
import { Network, type StakeObject } from '@iota/iota-sdk/client';
Expand All @@ -35,7 +36,6 @@ import {
LoadingIndicator,
} from '@iota/apps-ui-kit';
import { useNavigate } from 'react-router-dom';
import { ValidatorLogo } from '../validators/ValidatorLogo';
import { Warning } from '@iota/ui-icons';

interface DelegationDetailCardProps {
Expand Down Expand Up @@ -153,7 +153,7 @@ export function DelegationDetailCard({ validatorAddress, stakedId }: DelegationD
return (
<div className="flex h-full w-full flex-col justify-between">
<div className="flex flex-col gap-y-md">
<ValidatorLogo validatorAddress={validatorAddress} type={CardType.Filled} />
<Validator address={validatorAddress} type={CardType.Filled} />
{hasInactiveValidatorDelegation ? (
<InfoBox
type={InfoBoxType.Error}
Expand Down
Loading
Loading