Files
pwap/pezkuwi-sdk-ui/packages/react-params/src/Param/KeyValue.tsx
T
pezkuwichain 971df8edba Rebrand: Remove 3rd party chains, update domains to PezkuwiChain
- Remove all 3rd party parachain configurations from endpoints:
  - productionRelayPolkadot.ts: Keep only system parachains
  - productionRelayDicle.ts: Keep only system parachains
  - testingRelayZagros.ts: Keep only system parachains
  - testingRelayTeyrChain.ts: Keep only system parachains

- Update domain references:
  - polkadot.js.org → pezkuwichain.app
  - wiki.polkadot.network → wiki.pezkuwichain.io
  - dotapps.io → pezkuwichain.app
  - statement.polkadot.network → docs.pezkuwichain.io/statement
  - support.polkadot.network → docs.pezkuwichain.io

- Update repository references:
  - github.com/pezkuwi-js/apps → github.com/pezkuwichain/pwap

- Rename system parachains to Pezkuwi ecosystem:
  - PolkadotAssetHub → PezkuwiAssetHub
  - polkadotBridgeHub → pezkuwiBridgeHub
  - polkadotCollectives → pezkuwiCollectives
  - polkadotCoretime → pezkuwiCoretime
  - polkadotPeople → pezkuwiPeople

- Update network name in claims utility:
  - Polkadot → Pezkuwi
2026-01-09 03:08:11 +03:00

91 lines
2.2 KiB
TypeScript

// Copyright 2017-2026 @pezkuwi/react-params authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { Props } from '../types.js';
import React, { useCallback, useEffect, useState } from 'react';
import { Input } from '@pezkuwi/react-components';
import { compactAddLength, hexToU8a, u8aConcat } from '@pezkuwi/util';
import Bare from './Bare.js';
interface StateParam {
isValid: boolean;
u8a: Uint8Array;
}
// eslint-disable-next-line @typescript-eslint/ban-types
export function createParam (hex: string | String, ignoreLength = false): StateParam {
let u8a;
let isValid = false;
try {
u8a = hexToU8a(hex.toString());
isValid = ignoreLength || u8a.length !== 0;
} catch {
u8a = new Uint8Array([]);
}
return {
isValid,
u8a: compactAddLength(u8a)
};
}
function KeyValue ({ className = '', isDisabled, label, onChange, onEnter, withLabel }: Props): React.ReactElement<Props> {
const [, setIsValid] = useState(false);
const [key, setKey] = useState<StateParam>(() => ({ isValid: false, u8a: new Uint8Array([]) }));
const [value, setValue] = useState<StateParam>(() => ({ isValid: false, u8a: new Uint8Array([]) }));
useEffect((): void => {
const isValid = key.isValid && value.isValid;
onChange && onChange({
isValid,
value: u8aConcat(
key.u8a,
value.u8a
)
});
setIsValid(isValid);
}, [key, onChange, value]);
const _onChangeKey = useCallback(
(key: string): void => setKey(createParam(key)),
[]
);
const _onChangeValue = useCallback(
(value: string): void => setValue(createParam(value, true)),
[]
);
return (
<Bare className={className}>
<Input
className='medium'
isDisabled={isDisabled}
isError={!key.isValid}
label={label}
onChange={_onChangeKey}
placeholder='0x...'
type='text'
withLabel={withLabel}
/>
<Input
className='medium'
isDisabled={isDisabled}
isError={!value.isValid}
onChange={_onChangeValue}
onEnter={onEnter}
placeholder='0x...'
type='text'
withLabel={withLabel}
/>
</Bare>
);
}
export default React.memo(KeyValue);