mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-05-01 10:07:59 +00:00
48 lines
1.2 KiB
TypeScript
48 lines
1.2 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/app-democracy authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { Hash } from '@pezkuwi/types/interfaces';
|
|
import type { HexString } from '@pezkuwi/util/types';
|
|
|
|
import React from 'react';
|
|
|
|
import { Button } from '@pezkuwi/react-components';
|
|
import { useApi, useToggle } from '@pezkuwi/react-hooks';
|
|
|
|
import { useTranslation } from '../translate.js';
|
|
import PreImage from './PreImage.js';
|
|
|
|
interface Props {
|
|
imageHash: Hash | HexString;
|
|
isImminent?: boolean;
|
|
}
|
|
|
|
function PreImageButton ({ imageHash, isImminent }: Props): React.ReactElement<Props> | null {
|
|
const { t } = useTranslation();
|
|
const { api } = useApi();
|
|
const [isPreimageOpen, togglePreimage] = useToggle();
|
|
|
|
return (
|
|
api.tx.democracy.notePreimage
|
|
? (
|
|
<>
|
|
<Button
|
|
icon='plus'
|
|
label={t('Image')}
|
|
onClick={togglePreimage}
|
|
/>
|
|
{isPreimageOpen && (
|
|
<PreImage
|
|
imageHash={imageHash}
|
|
isImminent={isImminent}
|
|
onClose={togglePreimage}
|
|
/>
|
|
)}
|
|
</>
|
|
)
|
|
: null
|
|
);
|
|
}
|
|
|
|
export default React.memo(PreImageButton);
|