Files
pwap/pezkuwi-sdk-ui/packages/react-params/src/Extra/Proposal.tsx
T
Claude 60a800b33e Add Pezkuwi SDK UI - Polkadot.js Apps clone
- Clone Polkadot.js Apps repository
- Update package.json with Pezkuwi branding
- Add Pezkuwi endpoint to production chains (wss://pezkuwichain.app:9944)
- Create comprehensive README for SDK UI
- Set up project structure with all packages

Next steps:
- Apply Kurdistan colors (Kesk, Sor, Zer, Spi + Black) to UI theme
- Replace logos with Pezkuwi branding
- Test build and deployment
2025-11-14 00:55:17 +00:00

54 lines
1.4 KiB
TypeScript

// 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<Props> {
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 (
<ExtrinsicDisplay
className={className}
defaultArgs={initialArgs}
defaultValue={initialValue}
isDisabled={isDisabled}
isError={isError}
isPrivate
label={label}
onChange={_onChange}
onEnter={onEnter}
onEscape={onEscape}
withLabel={withLabel}
/>
);
}
export default React.memo(ProposalDisplay);