import React, { useEffect, useMemo, useState } from 'react' import { type Meta, type StoryFn, type StoryObj } from '@storybook/react' import { ToggleButton } from '~/src/components/AlphaToggleButton/ToggleButton' import { type ToggleButtonMultipleGroupProps, type ToggleButtonSingleGroupProps, } from '~/src/components/AlphaToggleButtonGroup/ToggleButtonGroup.types' import { Box } from '~/src/components/Box' import { ToggleButtonGroup } from './ToggleButtonGroup' const meta = { component: ToggleButtonGroup, } satisfies Meta const Template: StoryFn< ToggleButtonMultipleGroupProps | ToggleButtonSingleGroupProps > = ({ type, ...props }) => { const initialValue = useMemo( () => (type === 'single' ? 'react' : ['react']), [type] ) const [value, setValue] = useState(initialValue) useEffect( function initializeValue() { setValue(initialValue) }, [initialValue] ) return ( {/* @ts-ignore */} ) } export const Primary = { render: Template, args: { type: 'single', shape: 'rectangle', fullWidth: false, }, parameters: { design: { type: 'link', url: 'https://www.figma.com/design/fPXP9zfjZU9NyARnhTWL6o/Input?node-id=426-1255&t=tGbZuTTPrTF5lobw-0', }, }, } satisfies StoryObj export default meta