Files
pezkuwi-apps/packages/react-components/src/Icon.tsx
T
pezkuwichain d21bfb1320 feat: initial Pezkuwi Apps rebrand from polkadot-apps
Rebranded terminology:
- Polkadot → Pezkuwi
- Kusama → Dicle
- Westend → Zagros
- Rococo → PezkuwiChain
- Substrate → Bizinikiwi
- parachain → teyrchain

Custom logos with Kurdistan brand colors (#e6007a → #86e62a):
- bizinikiwi-hexagon.svg
- sora-bizinikiwi.svg
- hezscanner.svg
- heztreasury.svg
- pezkuwiscan.svg
- pezkuwistats.svg
- pezkuwiassembly.svg
- pezkuwiholic.svg
2026-01-07 13:05:27 +03:00

93 lines
1.9 KiB
TypeScript

// Copyright 2017-2025 @pezkuwi/react-components authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { IconName } from '@fortawesome/fontawesome-svg-core';
import { library } from '@fortawesome/fontawesome-svg-core';
import { fas } from '@fortawesome/free-solid-svg-icons';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import React from 'react';
import { styled } from './styled.js';
interface Props {
className?: string;
color?: 'gray' | 'green' | 'normal' | 'orange' | 'red' | 'transparent' | 'white' | 'darkGray';
icon: IconName;
isPadded?: boolean;
isSpinning?: boolean;
onClick?: (e: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;
size?: '1x' | '2x';
tooltip?: string;
}
// one-time init of FA libraries
library.add(fas);
function Icon ({ className = '', color = 'normal', icon, isPadded, isSpinning, onClick, size = '1x', tooltip }: Props): React.ReactElement<Props> {
const extraProps: Record<string, unknown> = {
'data-testid': icon,
...(tooltip
? {
'data-for': tooltip,
'data-tip': true
}
: {}
)
};
return (
<StyledFAI
{...extraProps}
className={`${className} ui--Icon ${color}Color${onClick ? ' isClickable' : ''}${isPadded ? ' isPadded' : ''}`}
icon={icon}
onClick={onClick}
size={size}
spin={isSpinning}
tabIndex={-1}
/>
);
}
const StyledFAI = styled(FontAwesomeIcon)`
outline: none;
&.isClickable {
cursor: pointer;
}
&.isPadded {
margin: 0 0.25rem;
}
&.grayColor {
opacity: 0.25;
}
&.greenColor {
color: green;
}
&.orangeColor {
color: darkorange;
}
&.redColor {
color: darkred;
}
&.transparentColor {
color: transparent;
}
&.whiteColor {
color: white;
}
&.darkGrayColor {
color: #8B8B8B;
}
`;
export default React.memo(Icon);