mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-06-30 05:17:22 +00:00
971df8edba
- 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
78 lines
2.5 KiB
TypeScript
78 lines
2.5 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-components authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { LinkOption } from '@pezkuwi/apps-config/endpoints/types';
|
|
import type { IdentityProps } from '@pezkuwi/react-identicon/types';
|
|
import type { AccountId, AccountIndex, Address } from '@pezkuwi/types/interfaces';
|
|
|
|
import React, { useCallback } from 'react';
|
|
|
|
import { getSystemIcon } from '@pezkuwi/apps-config';
|
|
import { useApi, useQueue } from '@pezkuwi/react-hooks';
|
|
import BaseIdentityIcon from '@pezkuwi/react-identicon';
|
|
import { settings } from '@pezkuwi/ui-settings';
|
|
|
|
import { useTranslation } from '../translate.js';
|
|
import RoboHash from './RoboHash/index.js';
|
|
|
|
interface Props {
|
|
className?: string;
|
|
forceIconType?: 'ethereum' | 'bizinikiwi';
|
|
prefix?: IdentityProps['prefix'];
|
|
size?: number;
|
|
theme?: IdentityProps['theme'] | 'robohash';
|
|
value?: AccountId | AccountIndex | Address | string | Uint8Array | null;
|
|
}
|
|
|
|
export function getIdentityTheme (apiEndpoint: LinkOption | null, systemName: string, specName: string): 'bizinikiwi' {
|
|
return (
|
|
(settings.icon === 'default' && (
|
|
apiEndpoint?.ui?.identityIcon ||
|
|
getSystemIcon(systemName, specName)
|
|
)) ||
|
|
settings.icon
|
|
) as 'bizinikiwi';
|
|
}
|
|
|
|
function isCodec (value?: AccountId | AccountIndex | Address | string | Uint8Array | null): value is AccountId | AccountIndex | Address {
|
|
return !!(value && (value as AccountId).toHuman);
|
|
}
|
|
|
|
function IdentityIcon ({ className = '', forceIconType, prefix, size = 24, theme, value }: Props): React.ReactElement<Props> {
|
|
const { apiEndpoint, isEthereum, specName, systemName } = useApi();
|
|
const { t } = useTranslation();
|
|
const { queueAction } = useQueue();
|
|
const thisTheme = theme || getIdentityTheme(apiEndpoint, systemName, specName);
|
|
|
|
const Custom = thisTheme === 'robohash'
|
|
? RoboHash
|
|
: undefined;
|
|
|
|
const onCopy = useCallback(
|
|
(account: string) => queueAction({
|
|
account,
|
|
action: t('clipboard'),
|
|
message: t('address copied'),
|
|
status: 'queued'
|
|
}),
|
|
[queueAction, t]
|
|
);
|
|
|
|
// NOTE ui--Identicon-React-Base is applied here (defined in styles/components.ts)
|
|
// since it has a theme and the styled wrapper overrides it
|
|
|
|
return (
|
|
<BaseIdentityIcon
|
|
Custom={Custom}
|
|
className={`ui--Identicon-React-Base ${className}`}
|
|
onCopy={onCopy}
|
|
prefix={prefix}
|
|
size={size}
|
|
theme={forceIconType || (isEthereum ? 'ethereum' : thisTheme as 'bizinikiwi')}
|
|
value={isCodec(value) ? value.toString() : value}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export default React.memo(IdentityIcon);
|