From 2304823dc6102a93456245a24ba5088546cbcdf8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tha=C3=AFs?= Date: Fri, 28 Jul 2023 18:40:57 +0200 Subject: [PATCH] docs: add DatePicker and ImageInput stories (#980) Closes #979 --- .../ui/input/components/DatePicker.tsx | 8 ++- .../__stories__/DatePicker.stories.tsx | 50 +++++++++++++++++++ .../__stories__/ImageInput.stories.tsx | 21 ++++++++ front/src/testing/mock-data/users.ts | 6 ++- 4 files changed, 78 insertions(+), 7 deletions(-) create mode 100644 front/src/modules/ui/input/components/__stories__/DatePicker.stories.tsx create mode 100644 front/src/modules/ui/input/components/__stories__/ImageInput.stories.tsx diff --git a/front/src/modules/ui/input/components/DatePicker.tsx b/front/src/modules/ui/input/components/DatePicker.tsx index 013be77d4f..5cc9c9b4c7 100644 --- a/front/src/modules/ui/input/components/DatePicker.tsx +++ b/front/src/modules/ui/input/components/DatePicker.tsx @@ -7,7 +7,6 @@ import { overlayBackground } from '@/ui/themes/effects'; import 'react-datepicker/dist/react-datepicker.css'; export type DatePickerProps = { - isOpen?: boolean; date: Date; onChangeHandler: (date: Date) => void; customInput?: ReactElement; @@ -129,11 +128,10 @@ const StyledContainer = styled.div` &:hover { background: ${({ theme }) => theme.background.transparent.light}; } + } - &:first-of-type { - display: none; - } - + & .react-datepicker__year-option { + &:first-of-type, &:last-of-type { display: none; } diff --git a/front/src/modules/ui/input/components/__stories__/DatePicker.stories.tsx b/front/src/modules/ui/input/components/__stories__/DatePicker.stories.tsx new file mode 100644 index 0000000000..83d506dd97 --- /dev/null +++ b/front/src/modules/ui/input/components/__stories__/DatePicker.stories.tsx @@ -0,0 +1,50 @@ +import { expect } from '@storybook/jest'; +import type { Meta, StoryObj } from '@storybook/react'; +import { userEvent, within } from '@storybook/testing-library'; + +import { ComponentDecorator } from '~/testing/decorators/ComponentDecorator'; + +import DatePicker from '../DatePicker'; + +const meta: Meta = { + title: 'UI/Input/DatePicker', + component: DatePicker, + decorators: [ComponentDecorator], + argTypes: { + customInput: { control: false }, + date: { control: 'date' }, + }, + args: { date: new Date('January 1, 2023 00:00:00') }, +}; + +export default meta; +type Story = StoryObj; + +export const Default: Story = {}; + +export const WithOpenMonthSelect: Story = { + play: async ({ canvasElement }) => { + const canvas = within(canvasElement); + + const monthSelect = canvas.getByText('January'); + + await userEvent.click(monthSelect); + + expect(canvas.getAllByText('January')).toHaveLength(2); + [ + 'February', + 'March', + 'April', + 'May', + 'June', + 'July', + 'August', + 'September', + 'October', + 'November', + 'December', + ].forEach((monthLabel) => + expect(canvas.getByText(monthLabel)).toBeInTheDocument(), + ); + }, +}; diff --git a/front/src/modules/ui/input/components/__stories__/ImageInput.stories.tsx b/front/src/modules/ui/input/components/__stories__/ImageInput.stories.tsx new file mode 100644 index 0000000000..e10b56b89c --- /dev/null +++ b/front/src/modules/ui/input/components/__stories__/ImageInput.stories.tsx @@ -0,0 +1,21 @@ +import type { Meta, StoryObj } from '@storybook/react'; + +import { ComponentDecorator } from '~/testing/decorators/ComponentDecorator'; +import { workspaceLogoUrl } from '~/testing/mock-data/users'; + +import { ImageInput } from '../ImageInput'; + +const meta: Meta = { + title: 'UI/Input/ImageInput', + component: ImageInput, + decorators: [ComponentDecorator], +}; + +export default meta; +type Story = StoryObj; + +export const Default: Story = {}; + +export const WithPicture: Story = { args: { picture: workspaceLogoUrl } }; + +export const Disabled: Story = { args: { disabled: true } }; diff --git a/front/src/testing/mock-data/users.ts b/front/src/testing/mock-data/users.ts index 9d07c437c2..3bdc3815e3 100644 --- a/front/src/testing/mock-data/users.ts +++ b/front/src/testing/mock-data/users.ts @@ -4,6 +4,8 @@ type MockedUser = GetCurrentUserQuery['currentUser']; export const avatarUrl = ''; +export const workspaceLogoUrl = + ''; export const mockedUsersData: Array = [ { @@ -23,7 +25,7 @@ export const mockedUsersData: Array = [ displayName: 'Twenty', domainName: 'twenty.com', inviteHash: 'twenty.com-invite-hash', - logo: '', + logo: workspaceLogoUrl, }, }, settings: { @@ -49,7 +51,7 @@ export const mockedUsersData: Array = [ displayName: 'Twenty', domainName: 'twenty.com', inviteHash: 'twenty.com-invite-hash', - logo: '', + logo: workspaceLogoUrl, }, }, settings: {