Files
pezkuwi-sdk-ui/packages/page-staking2/src/Legend.tsx
pezkuwichain d949863789 Initial commit: Pezkuwi SDK UI
Comprehensive web interface for interacting with Pezkuwi blockchain.

Features:
- Blockchain explorer
- Wallet management
- Staking interface
- Governance participation
- Developer tools

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-19 13:55:36 +03:00

124 lines
2.4 KiB
TypeScript

// Copyright 2017-2026 @pezkuwi/app-staking authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { BN } from '@pezkuwi/util';
import React from 'react';
import { Badge, styled, Tag } from '@pezkuwi/react-components';
import { useTranslation } from './translate.js';
interface Props {
className?: string;
isRelay?: boolean;
minCommission?: BN;
}
function Legend ({ className, isRelay, minCommission }: Props): React.ReactElement<Props> {
const { t } = useTranslation();
return (
<StyledDiv className={className}>
<span>
<Badge
color='blue'
icon='chevron-right'
/>
<span>{t('Next session')}</span>
</span>
{minCommission && (
<span>
<Badge
color='red'
icon='cancel'
/>
<span>{t('Chilled')}</span>
</span>
)}
{isRelay && (
<span>
<Badge
color='purple'
icon='vector-square'
/>
<span>{t('Para validator')}</span>
</span>
)}
<span>
<Badge
color='green'
info='5'
/>
<span>{t('Produced blocks')}</span>
</span>
<span>
<Badge
color='green'
icon='envelope'
/>
<span>{t('Online message')}</span>
</span>
<span>
<Badge
color='green'
icon='hand-paper'
/>
<span>{t('Nominating')}</span>
</span>
<span>
<Badge
color='red'
icon='balance-scale-right'
/>
<span>{t('Oversubscribed')}</span>
</span>
<span>
<Badge
color='red'
icon='skull-crossbones'
/>
<span>{t('Slashed')}</span>
</span>
<span>
<Badge
color='red'
icon='user-slash'
/>
<span>{t('Blocks nominations')}</span>
</span>
<span>
<Tag
color='lightgrey'
label='1,220'
/>
<span>{t('Era points')}</span>
</span>
</StyledDiv>
);
}
const StyledDiv = styled.div`
font-size: var(--font-size-small);
padding: 1rem 0.5rem;
text-align: center;
.ui--Badge, .ui--Tag {
margin-right: 0.5rem;
}
span {
vertical-align: middle;
* {
vertical-align: middle;
}
+ span {
margin-left: 1rem;
}
}
`;
export default React.memo(Legend);