diff --git a/src/components/PlaceholderContainer/PlaceholderContainer.tsx b/src/components/PlaceholderContainer/PlaceholderContainer.tsx index bbfbc1aa26..24998b3731 100644 --- a/src/components/PlaceholderContainer/PlaceholderContainer.tsx +++ b/src/components/PlaceholderContainer/PlaceholderContainer.tsx @@ -63,7 +63,7 @@ export const PlaceholderContainer = ({ }; const renderAction = () => { - if (!actions || (!React.isValidElement(actions) && !actions.length)) { + if (!actions || !React.isValidElement(actions) || !Array.isArray(actions)) { return null; } diff --git a/src/components/PlaceholderContainer/__stories__/PlaceholderContainer.stories.tsx b/src/components/PlaceholderContainer/__stories__/PlaceholderContainer.stories.tsx index acf4e5147b..d0f8c0706b 100644 --- a/src/components/PlaceholderContainer/__stories__/PlaceholderContainer.stories.tsx +++ b/src/components/PlaceholderContainer/__stories__/PlaceholderContainer.stories.tsx @@ -1,10 +1,18 @@ import React from 'react'; -import type {Meta, StoryFn} from '@storybook/react'; +import {ChevronDown} from '@gravity-ui/icons'; +import type {Meta, /*StoryFn,*/ StoryObj} from '@storybook/react'; +import {Showcase} from '../../../demo/Showcase'; +import {ShowcaseItem} from '../../../demo/ShowcaseItem'; +import {Button} from '../../Button'; +import {DropdownMenu} from '../../DropdownMenu'; +import {Icon} from '../../Icon'; +import {block} from '../../utils/cn'; import {PlaceholderContainer} from '../PlaceholderContainer'; +import type {PlaceholderContainerActionProps, PlaceholderContainerProps} from '../types'; -import {PlaceholderContainerShowcase} from './PlaceholderContainerShowcase'; +import './PlaceholderContainerShowcase.scss'; export default { title: 'Components/Data Display/PlaceholderContainer', @@ -24,5 +32,235 @@ export default { }, } as Meta; -const ShowcaseTemplate: StoryFn = () => ; -export const Showcase = ShowcaseTemplate.bind({}); +type Story = StoryObj; + +const b = block('placeholder-container-showcase'); + +const ImageComponentTest = () => { + return ( + + + + + 1:1 + + + + ); +}; + +const contentComponentTest = ( + + Custom title + with custom subtitle + and etc + + You can add here any long text with custom content and use custom + content size for displaying very long texts. + + +); + +const actionComponentTest = ( + + {}}, + {text: 'text 2', action: () => {}}, + ]} + onSwitcherClick={(e) => e?.stopPropagation()} + switcher={ + + Text + + + } + /> + +); + +const actionMainProps: PlaceholderContainerActionProps = { + text: 'Main button', + view: 'normal', + onClick: () => alert('Click by main button'), +}; + +const actionAdditionalBtnProps: PlaceholderContainerActionProps = { + text: 'Additional button', + view: 'flat-secondary', + onClick: () => alert('Click by additional button'), +}; + +const baseProps = { + title: 'Container with one button & image component', + image: , + className: 'placeholder-container', +}; + +const placeholderContainerProps: Omit = { + ...baseProps, + actions: [actionMainProps], + align: 'center', +}; + +const actionsProps = { + actions: [actionMainProps, actionAdditionalBtnProps], +}; + +const placeholderContainerCustomRenderedProps: Omit< + PlaceholderContainerProps, + 'size' | 'direction' +> = { + ...placeholderContainerProps, + content: contentComponentTest, +}; + +const placeholderContainerCustomActionProps: Omit = + { + ...placeholderContainerProps, + actions: actionComponentTest, + }; + +const descriptionProps = { + description: + 'Some long descriptionProps text that can contain of long long very long text etc. It can be repeated like this. Some long descriptionProps text that can contain of long long very long text etc.', + promoDescription: + "Comparing to 'L' size promo size has full width of the content block, a larger title size and alignment", +}; + +export const Size: Story = { + render: () => ( + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ), +}; + +export const Actions: Story = { + render: () => ( + + + + + + + + + + + + + + ), +}; + +export const Content: Story = { + render: () => ( + + + + + + ), +}; diff --git a/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.scss b/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.scss index c62c04d4bf..ee3fe3bea1 100644 --- a/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.scss +++ b/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.scss @@ -3,34 +3,6 @@ $block: '.#{$ns}placeholder-container-showcase'; #{$block} { - display: grid; - - &__placeholder-examples { - grid-area: auto; - display: grid; - grid-template: 'title' auto; - gap: 20px; - padding: 20px; - } - - &__section + &__section { - border-block-start: 1px solid var(--g-color-text-hint); - } - - &__examples-row { - display: grid; - grid-template-columns: 1fr 1fr; - - &__sub-title { - grid-area: subtitle; - } - } - - &__title { - grid-area: title; - margin: 0; - } - &__custom-action { margin-block-start: 20px; } diff --git a/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.tsx b/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.tsx deleted file mode 100644 index 98d39be0c2..0000000000 --- a/src/components/PlaceholderContainer/__stories__/PlaceholderContainerShowcase.tsx +++ /dev/null @@ -1,231 +0,0 @@ -import React from 'react'; - -import {ChevronDown} from '@gravity-ui/icons'; - -import {Button} from '../../Button'; -import {DropdownMenu} from '../../DropdownMenu'; -import {Icon} from '../../Icon'; -import {block} from '../../utils/cn'; -import type {PlaceholderContainerActionProps, PlaceholderContainerProps} from '../index'; -import {PlaceholderContainer} from '../index'; - -import './PlaceholderContainerShowcase.scss'; - -const b = block('placeholder-container-showcase'); - -const ImageComponentTest = () => { - return ( - - - - - 1:1 - - - - ); -}; - -const contentComponentTest = ( - - There is any custom title here - - You can add here any long text with custom content and use custom - content size for displaying very long texts. - - -); - -const actionComponentTest = ( - - {}}, - {text: 'text 2', action: () => {}}, - ]} - onSwitcherClick={(e) => e?.stopPropagation()} - switcher={ - - Text - - - } - /> - -); - -const actionMainProps: PlaceholderContainerActionProps = { - text: 'Main button', - view: 'normal', - onClick: () => alert('Click by main button'), -}; - -const actionAdditionalBtnProps: PlaceholderContainerActionProps = { - text: 'Additional button', - view: 'flat-secondary', - onClick: () => alert('Click by additional button'), -}; - -const baseProps = { - title: 'Container with one button & image component', - image: , - className: 'placeholder-container', -}; - -const placeholderContainerProps: PlaceholderContainerProps = { - ...baseProps, - actions: [actionMainProps], - align: 'center', -}; - -const actionsProps = { - actions: [actionMainProps, actionAdditionalBtnProps], -}; - -const placeholderContainerCustomRenderedProps: PlaceholderContainerProps = { - ...placeholderContainerProps, - content: contentComponentTest, -}; - -const placeholderContainerCustomActionProps: PlaceholderContainerProps = { - ...placeholderContainerProps, - actions: actionComponentTest, -}; - -const descriptionProps = { - description: - 'Some long descriptionProps text that can contain of long long very long text etc. It can be repeated like this. Some long descriptionProps text that can contain of long long very long text etc.', -}; - -const imageProps = { - url: '', - alt: 'image alt text', -}; - -export const PlaceholderContainerShowcase = () => { - return ( - - - PlaceholderContainer - - Sizes: - - - - - - - - - - - - - - - - - - - With buttons: - - - - With image props: - - - - Custom content: - - - - Custom action: - - - - - ); -};
+ You can add here any long text with custom content and use custom + content size for displaying very long texts. +
- You can add here any long text with custom content and use custom - content size for displaying very long texts. -