diff --git a/.storybook/theme.ts b/.storybook/theme.ts index f28b5cf548..f5c4cc5b0c 100644 --- a/.storybook/theme.ts +++ b/.storybook/theme.ts @@ -26,9 +26,9 @@ export const CloudThemeLight = create({ inputTextColor: 'black', inputBorderRadius: 4, - brandUrl: 'https://github.com/gravity-ui/uikit', + brandUrl: 'https://gravity-ui.com/', brandTitle: `
Gravity UI
-
Base Components
`, +
UIKit
`, }); export const CloudThemeDark = create({ diff --git a/src/components/Button/__stories__/Button.stories.tsx b/src/components/Button/__stories__/Button.stories.tsx index df0facb022..3d6a45618e 100644 --- a/src/components/Button/__stories__/Button.stories.tsx +++ b/src/components/Button/__stories__/Button.stories.tsx @@ -10,7 +10,7 @@ import { } from '@gravity-ui/icons'; import type {Meta, StoryObj} from '@storybook/react'; -import {StoryLayout} from '../../../demo/StoryLayout/StoryLayout'; +import {Showcase} from '../../../demo/Showcase'; import {Icon as IconComponent} from '../../Icon/Icon'; import {Button} from '../Button'; @@ -31,7 +31,7 @@ export const View: Story = { export const Size: Story = { render: (args) => ( - + @@ -47,13 +47,13 @@ export const Size: Story = { - + ), }; export const Icon: Story = { render: (args) => ( - + - + ), }; @@ -121,7 +121,7 @@ export const Width: Story = { export const Pin: Story = { render: (args) => { return ( - + - + ); }, }; diff --git a/src/components/Checkbox/__stories__/Checkbox.stories.tsx b/src/components/Checkbox/__stories__/Checkbox.stories.tsx index 1ee45b414f..0841787f33 100644 --- a/src/components/Checkbox/__stories__/Checkbox.stories.tsx +++ b/src/components/Checkbox/__stories__/Checkbox.stories.tsx @@ -1,9 +1,9 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import type {Meta, StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; import {Checkbox} from '../Checkbox'; -import type {CheckboxProps} from '../Checkbox'; import {CheckboxShowcase} from './CheckboxShowcase'; @@ -12,58 +12,58 @@ export default { component: Checkbox, } as Meta; -const DefaultTemplate: StoryFn = (args) => ; -export const Default = DefaultTemplate.bind({}); +type Story = StoryObj; -const SizeTemplate: StoryFn = (args) => ( - - m: - - l: - -); -export const Size = SizeTemplate.bind({}); +export const Default: Story = { + args: { + content: 'Label', + }, +}; -const DisabledTemplate: StoryFn = (args) => ( - - - - - -); -export const Disabled = DisabledTemplate.bind({}); +export const Checked: Story = { + args: { + ...Default.args, + checked: true, + }, +}; -const IndeterminateTemplate: StoryFn = (args) => ( - -); -export const Indeterminate = IndeterminateTemplate.bind({}); +export const Indeterminate: Story = { + args: { + ...Default.args, + indeterminate: true, + }, +}; -const LabelTemplate: StoryFn = (args) => ( - - - - -
- -
- Full - width - content -
+export const Size: Story = { + render: (args) => ( + + + Size m -
-
-); -export const Label = LabelTemplate.bind({}); + + Size l + + + ), +}; -const ControlledTemplate: StoryFn = (args) => ( - - - - - -); -export const Controlled = ControlledTemplate.bind({}); +export const Disabled: Story = { + render: (args) => ( + + + Unchecked + + + Checked + + + Indeterminate + + + ), +}; -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); +export const ShowcaseStory: Story = { + render: () => , + name: 'Showcase', +}; diff --git a/src/components/Checkbox/__stories__/CheckboxShowcase.tsx b/src/components/Checkbox/__stories__/CheckboxShowcase.tsx index 9e8ca83c31..e5588e3326 100644 --- a/src/components/Checkbox/__stories__/CheckboxShowcase.tsx +++ b/src/components/Checkbox/__stories__/CheckboxShowcase.tsx @@ -6,8 +6,8 @@ import {Checkbox} from '../Checkbox'; export function CheckboxShowcase() { return ( - - + +

@@ -23,7 +23,7 @@ export function CheckboxShowcase() {

- +

@@ -34,7 +34,7 @@ export function CheckboxShowcase() {

- +

@@ -42,7 +42,7 @@ export function CheckboxShowcase() {

- +

diff --git a/src/components/Checkbox/__stories__/Docs.mdx b/src/components/Checkbox/__stories__/Docs.mdx new file mode 100644 index 0000000000..ba49e49784 --- /dev/null +++ b/src/components/Checkbox/__stories__/Docs.mdx @@ -0,0 +1,7 @@ +import {Meta, Markdown} from '@storybook/addon-docs'; +import * as Stories from './Checkbox.stories'; +import Readme from '../README.md?raw'; + + + +{Readme} diff --git a/src/components/Radio/__stories__/Docs.mdx b/src/components/Radio/__stories__/Docs.mdx new file mode 100644 index 0000000000..4fb40cd921 --- /dev/null +++ b/src/components/Radio/__stories__/Docs.mdx @@ -0,0 +1,7 @@ +import {Meta, Markdown} from '@storybook/addon-docs'; +import * as Stories from './Radio.stories'; +import Readme from '../README.md?raw'; + + + +{Readme} diff --git a/src/components/Radio/__stories__/Radio.stories.tsx b/src/components/Radio/__stories__/Radio.stories.tsx index 8e8b1c3db4..0615d0e018 100644 --- a/src/components/Radio/__stories__/Radio.stories.tsx +++ b/src/components/Radio/__stories__/Radio.stories.tsx @@ -1,9 +1,9 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import type {Meta, StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; import {Radio} from '../Radio'; -import type {RadioProps} from '../Radio'; import {RadioShowcase} from './RadioShowcase'; @@ -12,8 +12,48 @@ export default { component: Radio, } as Meta; -const DefaultTemplate: StoryFn = (args) => ; -export const Default = DefaultTemplate.bind({}); +type Story = StoryObj; -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); +export const Default: Story = { + args: { + content: 'Label', + }, +}; + +export const Checked: Story = { + args: { + ...Default.args, + checked: true, + }, +}; + +export const Size: Story = { + render: (args) => ( + + + Size m + + + Size l + + + ), +}; + +export const Disabled: Story = { + render: (args) => ( + + + Unchecked + + + Checked + + + ), +}; + +export const ShowcaseStory: Story = { + render: () => , + name: 'Showcase', +}; diff --git a/src/components/Radio/__stories__/RadioShowcase.tsx b/src/components/Radio/__stories__/RadioShowcase.tsx index b9dd3efa51..84d2e4734e 100644 --- a/src/components/Radio/__stories__/RadioShowcase.tsx +++ b/src/components/Radio/__stories__/RadioShowcase.tsx @@ -6,8 +6,8 @@ import {Radio} from '../Radio'; export function RadioShowcase() { return ( - - + +

@@ -19,11 +19,11 @@ export function RadioShowcase() {

- +

- +

@@ -48,7 +48,7 @@ export function RadioShowcase() {

- +

diff --git a/src/components/RadioButton/__stories__/Docs.mdx b/src/components/RadioButton/__stories__/Docs.mdx new file mode 100644 index 0000000000..18ac587a0e --- /dev/null +++ b/src/components/RadioButton/__stories__/Docs.mdx @@ -0,0 +1,7 @@ +import {Meta, Markdown} from '@storybook/addon-docs'; +import * as Stories from './RadioButton.stories'; +import Readme from '../README.md?raw'; + + + +{Readme} diff --git a/src/components/RadioButton/__stories__/RadioButton.stories.tsx b/src/components/RadioButton/__stories__/RadioButton.stories.tsx index de2323c21e..0725000f48 100644 --- a/src/components/RadioButton/__stories__/RadioButton.stories.tsx +++ b/src/components/RadioButton/__stories__/RadioButton.stories.tsx @@ -1,9 +1,10 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import type {Meta, StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; +import {ShowcaseItem} from '../../../demo/ShowcaseItem'; import {RadioButton} from '../RadioButton'; -import type {RadioButtonOption, RadioButtonProps} from '../RadioButton'; import {RadioButtonShowcase} from './RadioButtonShowcase'; @@ -12,20 +13,48 @@ export default { component: RadioButton, } as Meta; -const options: RadioButtonOption[] = [ - {value: 'Value 1', content: 'Value 1'}, - {value: 'Value 2', content: 'Value 2'}, - {value: 'Value 3', content: 'Value 3'}, -]; +type Story = StoryObj; -const DefaultTemplate: StoryFn = (args) => { - const [value, setValue] = React.useState(options[0].value); - return ; +export const Default: Story = { + args: { + options: [ + {value: 'Value 1', content: 'Value 1'}, + {value: 'Value 2', content: 'Value 2'}, + {value: 'Value 3', content: 'Value 3'}, + ], + }, }; -export const Default = DefaultTemplate.bind({}); -Default.args = { - options, + +export const Size: Story = { + render: (args) => ( + + + + + + + + + + + + + + + ), + args: { + ...Default.args, + }, +}; + +export const Disabled: Story = { + args: { + ...Default.args, + disabled: true, + }, }; -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); +export const ShowcaseStory: Story = { + render: () => , + name: 'Showcase', +}; diff --git a/src/components/RadioButton/__stories__/RadioButtonShowcase.scss b/src/components/RadioButton/__stories__/RadioButtonShowcase.scss deleted file mode 100644 index bba81c4f24..0000000000 --- a/src/components/RadioButton/__stories__/RadioButtonShowcase.scss +++ /dev/null @@ -1,8 +0,0 @@ -.radio-button-showcase { - &__grid { - display: inline-grid; - grid-template-columns: repeat(2, auto); - align-items: center; - gap: 10px; - } -} diff --git a/src/components/RadioButton/__stories__/RadioButtonShowcase.tsx b/src/components/RadioButton/__stories__/RadioButtonShowcase.tsx index 186d396903..2dc0bb52c2 100644 --- a/src/components/RadioButton/__stories__/RadioButtonShowcase.tsx +++ b/src/components/RadioButton/__stories__/RadioButtonShowcase.tsx @@ -5,14 +5,9 @@ import {CircleInfoFill, TriangleExclamationFill} from '@gravity-ui/icons'; import {Showcase} from '../../../demo/Showcase'; import {ShowcaseItem} from '../../../demo/ShowcaseItem'; import {Icon} from '../../Icon'; -import {cn} from '../../utils/cn'; import {RadioButton} from '../RadioButton'; import type {RadioButtonOption} from '../RadioButton'; -import './RadioButtonShowcase.scss'; - -const b = cn('radio-button-showcase'); - export function RadioButtonShowcase() { const options: RadioButtonOption[] = [ {value: 'Value 1', content: 'Value 1'}, @@ -26,77 +21,36 @@ export function RadioButtonShowcase() { ]; return ( - - - - - - - - - - - + + + - - + + - + -
-
s
+
+

s

- +
-
m
+

m

- +
-
l
+

l

- +
-
xl
+

xl

- +
diff --git a/src/components/RadioGroup/__stories__/Docs.mdx b/src/components/RadioGroup/__stories__/Docs.mdx new file mode 100644 index 0000000000..2d19ce12ad --- /dev/null +++ b/src/components/RadioGroup/__stories__/Docs.mdx @@ -0,0 +1,7 @@ +import {Meta, Markdown} from '@storybook/addon-docs'; +import * as Stories from './RadioGroup.stories'; +import Readme from '../README.md?raw'; + + + +{Readme} diff --git a/src/components/RadioGroup/__stories__/RadioGroup.stories.tsx b/src/components/RadioGroup/__stories__/RadioGroup.stories.tsx index 3107441c6a..65b9868bc0 100644 --- a/src/components/RadioGroup/__stories__/RadioGroup.stories.tsx +++ b/src/components/RadioGroup/__stories__/RadioGroup.stories.tsx @@ -1,10 +1,10 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import type {Meta, StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; import {ShowcaseItem} from '../../../demo/ShowcaseItem'; import {RadioGroup} from '../RadioGroup'; -import type {RadioGroupOption, RadioGroupProps} from '../RadioGroup'; import {RadioGroupShowcase} from './RadioGroupShowcase'; @@ -13,51 +13,60 @@ export default { component: RadioGroup, } as Meta; -const options: RadioGroupOption[] = [ - {value: 'Value 1', content: 'Value 1'}, - {value: 'Value 2', content: 'Value 2'}, - {value: 'Value 3', content: 'Value 3'}, -]; +type Story = StoryObj; -const DefaultTemplate: StoryFn = (args) => { - const [value, setValue] = React.useState(options[0].value); - return ; -}; -export const Default = DefaultTemplate.bind({}); -Default.args = { - options, +export const Default: Story = { + args: { + options: [ + {value: 'Value 1', content: 'Value 1'}, + {value: 'Value 2', content: 'Value 2'}, + {value: 'Value 3', content: 'Value 3'}, + ], + }, }; -export const Direction: StoryFn = (args) => { - const [value, setValue] = React.useState(args.options?.[0].value); - - return ( - - - +export const Size: Story = { + render: (args) => ( + + + - - + + - - ); + + ), + args: { + ...Default.args, + }, }; -Direction.args = { - options, + +export const Disabled: Story = { + args: { + ...Default.args, + disabled: true, + }, }; -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); +export const Direction: Story = { + args: { + ...Default.args, + }, + render: (args) => { + return ( + + + + + + + + + ); + }, +}; + +export const ShowcaseStory: Story = { + render: () => , + name: 'Showcase', +}; diff --git a/src/components/RadioGroup/__stories__/RadioGroupShowcase.tsx b/src/components/RadioGroup/__stories__/RadioGroupShowcase.tsx index 34dd1376a6..8d2c41ae7f 100644 --- a/src/components/RadioGroup/__stories__/RadioGroupShowcase.tsx +++ b/src/components/RadioGroup/__stories__/RadioGroupShowcase.tsx @@ -12,7 +12,7 @@ export function RadioGroupShowcase() { {value: 'Value 3', content: 'Value 3', disabled: true}, ]; return ( - + diff --git a/src/components/Switch/__stories__/Docs.mdx b/src/components/Switch/__stories__/Docs.mdx new file mode 100644 index 0000000000..285917560e --- /dev/null +++ b/src/components/Switch/__stories__/Docs.mdx @@ -0,0 +1,7 @@ +import {Meta, Markdown} from '@storybook/addon-docs'; +import * as Stories from './Switch.stories'; +import Readme from '../README.md?raw'; + + + +{Readme} diff --git a/src/components/Switch/__stories__/Switch.stories.tsx b/src/components/Switch/__stories__/Switch.stories.tsx index cb5f498f65..d4a941d454 100644 --- a/src/components/Switch/__stories__/Switch.stories.tsx +++ b/src/components/Switch/__stories__/Switch.stories.tsx @@ -1,9 +1,9 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import type {Meta, StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; import {Switch} from '../Switch'; -import type {SwitchProps} from '../Switch'; import {SwitchShowcase} from './SwitchShowcase'; @@ -12,53 +12,48 @@ export default { component: Switch, } as Meta; -const DefaultTemplate: StoryFn = (args) => ; -export const Default = DefaultTemplate.bind({}); - -const SizeTemplate: StoryFn = (args) => ( - - m: - - l: - -); -export const Size = SizeTemplate.bind({}); - -const DisabledTemplate: StoryFn = (args) => ( - - - - - -); -export const Disabled = DisabledTemplate.bind({}); - -const LabelTemplate: StoryFn = (args) => ( - - - - -
- -
- Full - width - content -
+type Story = StoryObj; + +export const Default: Story = { + args: { + content: 'Label', + }, +}; + +export const Checked: Story = { + args: { + ...Default.args, + checked: true, + }, +}; + +export const Size: Story = { + render: (args) => ( + + + Size m -
-
-); -export const Label = LabelTemplate.bind({}); - -const ControlledTemplate: StoryFn = (args) => ( - - - - - -); -export const Controlled = ControlledTemplate.bind({}); - -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); + + Size l + +
+ ), +}; + +export const Disabled: Story = { + render: (args) => ( + + + Unchecked + + + Checked + + + ), +}; + +export const ShowcaseStory: Story = { + render: () => , + name: 'Showcase', +}; diff --git a/src/components/Switch/__stories__/SwitchShowcase.scss b/src/components/Switch/__stories__/SwitchShowcase.scss deleted file mode 100644 index 891ecfb4af..0000000000 --- a/src/components/Switch/__stories__/SwitchShowcase.scss +++ /dev/null @@ -1,7 +0,0 @@ -.switch-showcase { - margin: 36px; - - .row { - margin-bottom: 16px; - } -} diff --git a/src/components/Switch/__stories__/SwitchShowcase.tsx b/src/components/Switch/__stories__/SwitchShowcase.tsx index 4d9d2cba1a..ee294868e9 100644 --- a/src/components/Switch/__stories__/SwitchShowcase.tsx +++ b/src/components/Switch/__stories__/SwitchShowcase.tsx @@ -4,11 +4,9 @@ import {Showcase} from '../../../demo/Showcase'; import {ShowcaseItem} from '../../../demo/ShowcaseItem'; import {Switch} from '../Switch'; -import './SwitchShowcase.scss'; - export const SwitchShowcase = () => { return ( - +

diff --git a/src/demo/Showcase/Showcase.scss b/src/demo/Showcase/Showcase.scss index 5c30e2d753..434d4343ab 100644 --- a/src/demo/Showcase/Showcase.scss +++ b/src/demo/Showcase/Showcase.scss @@ -9,12 +9,19 @@ } &__description { - @include mixins.text-body-3(); - margin-top: 10px; + @include mixins.text-body-2(); + margin-top: var(--g-spacing-2); + color: var(--g-color-text-secondary); } &__content { flex-grow: 1; - margin-top: 20px; + display: flex; + flex-wrap: wrap; + gap: var(--g-spacing-6); + + &:not(:only-child) { + margin-top: var(--g-spacing-5); + } } } diff --git a/src/demo/Showcase/Showcase.tsx b/src/demo/Showcase/Showcase.tsx index d50070224a..486c70ccf0 100644 --- a/src/demo/Showcase/Showcase.tsx +++ b/src/demo/Showcase/Showcase.tsx @@ -5,7 +5,7 @@ import {cn} from '../../components/utils/cn'; import './Showcase.scss'; type Props = React.PropsWithChildren<{ - title: string; + title?: string; description?: React.ReactNode; className?: string; }>; @@ -15,8 +15,8 @@ const b = cn('showcase'); export function Showcase({title, description, className, children}: Props) { return (

-
{title}
-
{description}
+ {title &&
{title}
} + {description &&
{description}
}
{children}
); diff --git a/src/demo/ShowcaseItem/ShowcaseItem.scss b/src/demo/ShowcaseItem/ShowcaseItem.scss index cd84773591..6b4f9e2385 100644 --- a/src/demo/ShowcaseItem/ShowcaseItem.scss +++ b/src/demo/ShowcaseItem/ShowcaseItem.scss @@ -1,12 +1,8 @@ -.showcase-item { - display: inline-block; - margin-right: 60px; - margin-bottom: 20px; - vertical-align: top; +@use '../../../styles/mixins'; +.showcase-item { &__title { - font-size: 16px; - font-weight: bold; - margin-bottom: 15px; + @include mixins.text-subheader-3(); + margin-bottom: var(--g-spacing-3); } } diff --git a/src/demo/StoryLayout/StoryLayout.scss b/src/demo/StoryLayout/StoryLayout.scss deleted file mode 100644 index 3904d117c7..0000000000 --- a/src/demo/StoryLayout/StoryLayout.scss +++ /dev/null @@ -1,5 +0,0 @@ -.story-layout { - display: flex; - flex-wrap: wrap; - gap: 1rem; -} diff --git a/src/demo/StoryLayout/StoryLayout.tsx b/src/demo/StoryLayout/StoryLayout.tsx deleted file mode 100644 index 6f35f98d4b..0000000000 --- a/src/demo/StoryLayout/StoryLayout.tsx +++ /dev/null @@ -1,21 +0,0 @@ -import React from 'react'; - -import {cn} from '../../components/utils/cn'; - -import './StoryLayout.scss'; - -export interface StoryLayoutProps extends React.PropsWithChildren {} - -const b = cn('story-layout'); - -export function StoryLayout({children}: StoryLayoutProps) { - return ( -
- {React.Children.map(children, (elem, i) => ( -
- {elem} -
- ))} -
- ); -}