mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 19:27:57 +00:00
50 lines
1.3 KiB
TypeScript
50 lines
1.3 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-params authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { Call } from '@pezkuwi/types/interfaces';
|
|
import type { BN } from '@pezkuwi/util';
|
|
|
|
import React from 'react';
|
|
|
|
import { formatNumber, isString, isUndefined } from '@pezkuwi/util';
|
|
|
|
import { useTranslation } from '../translate.js';
|
|
import CallExpander from './CallExpander.js';
|
|
|
|
interface Props {
|
|
className?: string;
|
|
proposal?: Call | null;
|
|
idNumber?: BN | number | string;
|
|
withLinks?: boolean;
|
|
expandNested?: boolean;
|
|
}
|
|
|
|
function ProposedAction ({ className = '', idNumber, proposal }: Props): React.ReactElement<Props> {
|
|
const { t } = useTranslation();
|
|
const stringId = isString(idNumber) || isUndefined(idNumber)
|
|
? idNumber
|
|
: formatNumber(idNumber);
|
|
|
|
if (!proposal) {
|
|
return (
|
|
<div className={`${className} ui--ProposedAction`}>
|
|
<div>{stringId ? `#${stringId}: ` : ''}{t('No execution details available for this proposal')}</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className={`${className} ui--ProposedAction`}>
|
|
<CallExpander
|
|
isHeader
|
|
labelHash={t('preimage')}
|
|
stringId={stringId}
|
|
value={proposal}
|
|
withHash
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default React.memo(ProposedAction);
|