Files
pezkuwi-apps/packages/page-staking-async/src/Actions/Account/Nominate.tsx
T
pezkuwichain d21bfb1320 feat: initial Pezkuwi Apps rebrand from polkadot-apps
Rebranded terminology:
- Polkadot → Pezkuwi
- Kusama → Dicle
- Westend → Zagros
- Rococo → PezkuwiChain
- Substrate → Bizinikiwi
- parachain → teyrchain

Custom logos with Kurdistan brand colors (#e6007a → #86e62a):
- bizinikiwi-hexagon.svg
- sora-bizinikiwi.svg
- hezscanner.svg
- heztreasury.svg
- pezkuwiscan.svg
- pezkuwistats.svg
- pezkuwiassembly.svg
- pezkuwiholic.svg
2026-01-07 13:05:27 +03:00

72 lines
1.8 KiB
TypeScript

// Copyright 2017-2025 @pezkuwi/app-staking-async authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { SortedTargets } from '@pezkuwi/app-staking/types';
import type { BN } from '@pezkuwi/util';
import type { NominateInfo } from '../partials/types.js';
import React, { useState } from 'react';
import { Modal, styled, TxButton } from '@pezkuwi/react-components';
import { useTranslation } from '../../translate.js';
import NominatePartial from '../partials/Nominate.js';
interface Props {
className?: string;
controllerId: string;
nominating?: string[];
onClose: () => void;
poolId?: BN;
stashId: string;
targets: SortedTargets;
}
function Nominate ({ className = '', controllerId, nominating, onClose, poolId, stashId, targets }: Props): React.ReactElement<Props> | null {
const { t } = useTranslation();
const [{ nominateTx }, setTx] = useState<NominateInfo>({});
return (
<StyledModal
className={className}
header={t('Nominate Validators')}
onClose={onClose}
size='large'
>
<Modal.Content>
<NominatePartial
className='nominatePartial'
controllerId={controllerId}
nominating={nominating}
onChange={setTx}
poolId={poolId}
stashId={stashId}
targets={targets}
withSenders
/>
</Modal.Content>
<Modal.Actions>
<TxButton
accountId={controllerId}
extrinsic={nominateTx}
icon='hand-paper'
isDisabled={!nominateTx}
label={t('Nominate')}
onStart={onClose}
/>
</Modal.Actions>
</StyledModal>
);
}
const StyledModal = styled(Modal)`
.nominatePartial {
.ui--Static .ui--AddressMini .ui--AddressMini-info {
max-width: 10rem;
min-width: 10rem;
}
}
`;
export default React.memo(Nominate);