mirror of
https://github.com/status-im/status-web.git
synced 2025-01-26 20:40:43 +00:00
6558e437f5
* remove old icons * add script for syncing icons * regenerate icons * update @status-im/icons exports * allow scroll in storybook * migrate to new icons import * add iconography story * update root package.json * fix typo * add @status-im/colors * generate colors * add colors story * fix ci
43 lines
1.0 KiB
TypeScript
43 lines
1.0 KiB
TypeScript
import { createElement, forwardRef } from 'react'
|
|
|
|
import { useTheme } from '@tamagui/core'
|
|
|
|
import type { ColorTokens } from '@tamagui/core'
|
|
import type { ComponentType, SVGProps } from 'react'
|
|
|
|
// import 'react-native-svg'
|
|
// declare module 'react-native-svg' {
|
|
// export interface SvgProps {
|
|
// xmlns?: string
|
|
// xmlnsXlink?: string
|
|
// xlinkHref?: string
|
|
// }
|
|
// }
|
|
|
|
export interface IconProps extends SVGProps<SVGSVGElement> {
|
|
size: 12 | 16 | 20
|
|
color?: ColorTokens
|
|
}
|
|
|
|
export function createIcon<P extends SVGProps<SVGSVGElement>>(
|
|
Component: ComponentType<P>
|
|
): ComponentType<IconProps> {
|
|
const Icon = forwardRef<SVGElement, IconProps>((props, ref) => {
|
|
const { size, color = '$neutral-100', ...rest } = props
|
|
const theme = useTheme()
|
|
const token = theme[color]?.val
|
|
|
|
return createElement(Component, {
|
|
ref,
|
|
...(rest as P),
|
|
color: token,
|
|
width: size,
|
|
height: size,
|
|
})
|
|
})
|
|
|
|
Icon.displayName = Component.name + 'Icon'
|
|
|
|
return Icon as ComponentType<IconProps>
|
|
}
|