From a6ff5eee45215effb3344cb5d631a27a7c0369aa Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Fri, 22 Sep 2023 19:34:01 +0200 Subject: refactor(components): rewrite form components --- .../flipping-label/flipping-label.stories.tsx | 96 ++++++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 src/components/molecules/forms/flipping-label/flipping-label.stories.tsx (limited to 'src/components/molecules/forms/flipping-label/flipping-label.stories.tsx') diff --git a/src/components/molecules/forms/flipping-label/flipping-label.stories.tsx b/src/components/molecules/forms/flipping-label/flipping-label.stories.tsx new file mode 100644 index 0000000..3ad3529 --- /dev/null +++ b/src/components/molecules/forms/flipping-label/flipping-label.stories.tsx @@ -0,0 +1,96 @@ +import { ComponentMeta, ComponentStory } from '@storybook/react'; +import { useState } from 'react'; +import { MagnifyingGlass } from '../../../atoms'; +import { FlippingLabel } from './flipping-label'; + +export default { + title: 'Molecules/Forms/FlippingLabel', + component: FlippingLabel, + argTypes: { + 'aria-label': { + control: { + type: 'text', + }, + description: 'An accessible name for the label.', + table: { + category: 'Accessibility', + }, + type: { + name: 'string', + required: false, + }, + }, + children: { + control: { + type: null, + }, + description: 'An icon for the label front face.', + type: { + name: 'function', + required: true, + }, + }, + className: { + control: { + type: 'text', + }, + description: 'Set additional classnames to the label.', + table: { + category: 'Styles', + }, + type: { + name: 'string', + required: false, + }, + }, + htmlFor: { + control: { + type: null, + }, + description: 'Bind the label to a field by id.', + table: { + category: 'Options', + }, + type: { + name: 'string', + required: false, + }, + }, + isActive: { + control: { + type: 'boolean', + }, + description: + 'Which side of the label should be displayed? True for the close icon.', + type: { + name: 'boolean', + required: true, + }, + }, + }, +} as ComponentMeta; + +const Template: ComponentStory = ({ + isActive, + ...args +}) => { + const [active, setActive] = useState(isActive); + + return ( +
setActive(!active)}> + +
+ ); +}; + +export const Active = Template.bind({}); +Active.args = { + children: , + isActive: true, +}; + +export const Inactive = Template.bind({}); +Inactive.args = { + children: , + isActive: false, +}; -- cgit v1.2.3