// Copyright 2017-2025 @polkadot/app-extrinsics authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { Props, RawParam } from '../types.js'; import React, { useCallback, useState } from 'react'; import { useApi } from '@polkadot/react-hooks'; import { extractInitial } from './Call.js'; import ExtrinsicDisplay from './Extrinsic.js'; function ProposalDisplay ({ className = '', defaultValue, isDisabled, isError, label, onChange, onEnter, onEscape, withLabel }: Props): React.ReactElement { const { api, apiDefaultTxSudo } = useApi(); const [{ initialArgs, initialValue }] = useState( () => extractInitial(api, apiDefaultTxSudo, defaultValue) ); const _onChange = useCallback( ({ isValid, value }: RawParam): void => { let proposal = null; if (isValid && value) { proposal = api.createType('Proposal', value); } onChange && onChange({ isValid, value: proposal }); }, [api, onChange] ); return ( ); } export default React.memo(ProposalDisplay);