packages/page-tech-comm/src/Proposals/Close.tsx
// Copyright 2017-2024 @polkadot/app-tech-comm authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { CollectiveType } from '@polkadot/react-hooks/types';
import type { Hash, Proposal, ProposalIndex } from '@polkadot/types/interfaces';
import React, { useState } from 'react';
import { Button, InputAddress, Modal, TxButton } from '@polkadot/react-components';
import { useApi, useCollectiveInstance, useToggle, useWeight } from '@polkadot/react-hooks';
import { ProposedAction } from '@polkadot/react-params';
import { useTranslation } from '../translate.js';
interface Props {
hasFailed: boolean;
hash: Hash;
idNumber: ProposalIndex;
proposal: Proposal | null;
type: CollectiveType;
}
function Close ({ hasFailed, hash, idNumber, proposal, type }: Props): React.ReactElement<Props> | null {
const { t } = useTranslation();
const { api } = useApi();
const [isOpen, toggleOpen] = useToggle();
const [accountId, setAccountId] = useState<string | null>(null);
const { encodedCallLength, weight } = useWeight(proposal);
const modLocation = useCollectiveInstance(type);
if (!modLocation) {
return null;
}
return (
<>
{isOpen && (
<Modal
header={t('Close proposal')}
onClose={toggleOpen}
size='large'
>
<Modal.Content>
<Modal.Columns hint={t('The proposal that will be affected. Once closed for the current voting round, it would need to be re-submitted for a subsequent voting round.')}>
<ProposedAction
idNumber={idNumber}
proposal={proposal}
/>
</Modal.Columns>
<Modal.Columns hint={t('The committee account that will apply the close for the current round.')}>
<InputAddress
label={t('close from account')}
onChange={setAccountId}
type='account'
/>
</Modal.Columns>
</Modal.Content>
<Modal.Actions>
<TxButton
accountId={accountId}
isDisabled={!hasFailed && !encodedCallLength}
onStart={toggleOpen}
params={
api.tx[modLocation].close.meta.args.length === 4
? hasFailed
? [hash, idNumber, 0, 0]
: [hash, idNumber, weight, encodedCallLength]
: [hash, idNumber]
}
tx={api.tx[modLocation].closeOperational || api.tx[modLocation].close}
/>
</Modal.Actions>
</Modal>
)}
<Button
icon='times'
label={t('Close')}
onClick={toggleOpen}
/>
</>
);
}
export default React.memo(Close);