mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-06-17 02:01:09 +00:00
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
This commit is contained in:
@@ -0,0 +1,71 @@
|
||||
// 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);
|
||||
Reference in New Issue
Block a user