mirror of
https://github.com/status-im/status-web.git
synced 2025-01-26 04:20:06 +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