Skip to content

Commit

Permalink
feat(plasma-b2c): migrate to CSF 3 [TextField]
Browse files Browse the repository at this point in the history
  • Loading branch information
Yakutoc committed Nov 8, 2023
1 parent cffef36 commit d93d8a0
Showing 1 changed file with 40 additions and 32 deletions.
72 changes: 40 additions & 32 deletions packages/plasma-b2c/src/components/TextField/TextField.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import React from 'react';
import { Story, Meta } from '@storybook/react';
import React, { useState, useEffect } from 'react';
import type { StoryObj, Meta } from '@storybook/react';
import { action } from '@storybook/addon-actions';
import { IconPlaceholder, InSpacingDecorator, disableProps } from '@salutejs/plasma-sb-utils';

import { TextField, TextFieldView, TextFieldProps } from '.';
import { TextField, TextFieldView } from '.';
import type { TextFieldProps } from '.';

const onChange = action('onChange');
const onFocus = action('onFocus');
Expand All @@ -28,7 +29,7 @@ const propsToDisable = [
'required',
];

export default {
const meta: Meta<TextFieldProps> = {
title: 'Controls/TextField',
component: TextField,
decorators: [InSpacingDecorator],
Expand All @@ -52,15 +53,19 @@ export default {
},
...disableProps(propsToDisable),
},
} as Meta;
};

export default meta;

interface DefaultStoryProps extends TextFieldProps {
type StoryPropsDefault = TextFieldProps & {
enableContentLeft: boolean;
enableContentRight: boolean;
}
};

export const Default: Story<DefaultStoryProps> = ({ enableContentLeft, enableContentRight, status, ...rest }) => {
const [value, setValue] = React.useState('Значение поля');
type StoryPropsDeferredValue = { readOnly: boolean };

const StoryDefault = ({ enableContentLeft, enableContentRight, status, ...rest }: StoryPropsDefault) => {
const [value, setValue] = useState('Значение поля');

return (
<TextField
Expand All @@ -80,24 +85,27 @@ export const Default: Story<DefaultStoryProps> = ({ enableContentLeft, enableCon
);
};

Default.args = {
id: 'example-text-field',
type: 'text',
placeholder: 'Заполните поле имя',
caption: 'Имя',
helperText: 'Допустимы только символы кириллицы',
enableContentLeft: true,
enableContentRight: true,
status: '' as 'success',
disabled: false,
readOnly: false,
size: 'm',
export const Default: StoryObj<StoryPropsDefault> = {
args: {
id: 'example-text-field',
type: 'text',
placeholder: 'Заполните поле имя',
caption: 'Имя',
helperText: 'Допустимы только символы кириллицы',
enableContentLeft: true,
enableContentRight: true,
status: '' as 'success',
disabled: false,
readOnly: false,
size: 'm',
},
render: (args) => <StoryDefault {...args} />,
};

export const DeferredValue: Story<{ readOnly: boolean }> = ({ readOnly }) => {
const [asyncValue, setAsyncValue] = React.useState('');
const StoryDeferredValue = ({ readOnly }: StoryPropsDeferredValue) => {
const [asyncValue, setAsyncValue] = useState('');

React.useEffect(() => {
useEffect(() => {
setTimeout(() => {
setAsyncValue("Sorry i'm late :)");
}, 3000);
Expand All @@ -106,12 +114,12 @@ export const DeferredValue: Story<{ readOnly: boolean }> = ({ readOnly }) => {
return <TextField placeholder="Wait three seconds..." defaultValue={asyncValue} readOnly={readOnly} />;
};

DeferredValue.args = {
readOnly: true,
};

const defValuePropsToDisable = [...propsToDisable, 'status', 'helperText', 'placeholder', 'disabled'];

DeferredValue.argTypes = {
...disableProps(defValuePropsToDisable),
export const DeferredValue: StoryObj<StoryPropsDeferredValue> = {
argTypes: {
...disableProps([...propsToDisable, 'status', 'helperText', 'placeholder', 'disabled']),
},
args: {
readOnly: true,
},
render: (args) => <StoryDeferredValue {...args} />,
};

0 comments on commit d93d8a0

Please sign in to comment.