mirror of
https://github.com/status-im/status-web.git
synced 2025-01-12 13:44:39 +00:00
add IconButton component
This commit is contained in:
parent
aee4269406
commit
87957c1611
22
packages/components/src/icon-button/icon-button.stories.tsx
Normal file
22
packages/components/src/icon-button/icon-button.stories.tsx
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import { OptionsIcon } from '@status-im/icons'
|
||||||
|
|
||||||
|
import { IconButton } from './icon-button'
|
||||||
|
|
||||||
|
import type { Meta, StoryObj } from '@storybook/react'
|
||||||
|
|
||||||
|
// More on how to set up stories at: https://storybook.js.org/docs/7.0/react/writing-stories/introduction
|
||||||
|
const meta: Meta<typeof IconButton> = {
|
||||||
|
component: IconButton,
|
||||||
|
argTypes: {},
|
||||||
|
}
|
||||||
|
|
||||||
|
type Story = StoryObj<typeof IconButton>
|
||||||
|
|
||||||
|
// More on writing stories with args: https://storybook.js.org/docs/7.0/react/writing-stories/args
|
||||||
|
export const Default: Story = {
|
||||||
|
args: {
|
||||||
|
icon: <OptionsIcon />,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
export default meta
|
72
packages/components/src/icon-button/icon-button.tsx
Normal file
72
packages/components/src/icon-button/icon-button.tsx
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import { Stack, styled, Text } from '@tamagui/core'
|
||||||
|
|
||||||
|
// import { Pressable } from 'react-native'
|
||||||
|
import type React from 'react'
|
||||||
|
|
||||||
|
const Base = styled(Stack, {
|
||||||
|
name: 'IconButton',
|
||||||
|
accessibilityRole: 'button',
|
||||||
|
|
||||||
|
cursor: 'pointer',
|
||||||
|
userSelect: 'none',
|
||||||
|
borderRadius: 10,
|
||||||
|
display: 'inline-flex',
|
||||||
|
alignItems: 'center',
|
||||||
|
justifyContent: 'center',
|
||||||
|
|
||||||
|
width: 31,
|
||||||
|
height: 31,
|
||||||
|
borderWidth: 1,
|
||||||
|
backgroundColor: '$neutral-10',
|
||||||
|
borderColor: '$neutral-10',
|
||||||
|
|
||||||
|
hoverStyle: {
|
||||||
|
backgroundColor: '$neutral-20',
|
||||||
|
},
|
||||||
|
|
||||||
|
variants: {
|
||||||
|
selected: {
|
||||||
|
true: {
|
||||||
|
backgroundColor: '$neutral-30',
|
||||||
|
borderColor: '$neutral-30',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
} as const,
|
||||||
|
})
|
||||||
|
|
||||||
|
const Icon = styled(Text, {
|
||||||
|
color: '$neutral-50',
|
||||||
|
width: 20,
|
||||||
|
height: 20,
|
||||||
|
|
||||||
|
hoverStyle: {
|
||||||
|
color: '$neutral-100',
|
||||||
|
},
|
||||||
|
|
||||||
|
variants: {
|
||||||
|
selected: {
|
||||||
|
true: {
|
||||||
|
color: '$neutral-100',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
} as const,
|
||||||
|
})
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
icon: React.ReactElement
|
||||||
|
onPress?: () => void
|
||||||
|
selected?: boolean
|
||||||
|
}
|
||||||
|
|
||||||
|
const IconButton = (props: Props) => {
|
||||||
|
const { icon, selected, onPress } = props
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Base selected={selected} onPress={onPress}>
|
||||||
|
<Icon selected={selected}>{icon}</Icon>
|
||||||
|
</Base>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export { IconButton }
|
||||||
|
export type { Props as IconButtonProps }
|
1
packages/components/src/icon-button/index.tsx
Normal file
1
packages/components/src/icon-button/index.tsx
Normal file
@ -0,0 +1 @@
|
|||||||
|
export { type IconButtonProps, IconButton } from './icon-button'
|
Loading…
x
Reference in New Issue
Block a user