docs: add DatePicker and ImageInput stories (#980)

Closes #979
This commit is contained in:
Thaïs 2023-07-28 18:40:57 +02:00 committed by GitHub
parent 44a9c2687f
commit 2304823dc6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 78 additions and 7 deletions

View File

@ -7,7 +7,6 @@ import { overlayBackground } from '@/ui/themes/effects';
import 'react-datepicker/dist/react-datepicker.css'; import 'react-datepicker/dist/react-datepicker.css';
export type DatePickerProps = { export type DatePickerProps = {
isOpen?: boolean;
date: Date; date: Date;
onChangeHandler: (date: Date) => void; onChangeHandler: (date: Date) => void;
customInput?: ReactElement; customInput?: ReactElement;
@ -129,11 +128,10 @@ const StyledContainer = styled.div`
&:hover { &:hover {
background: ${({ theme }) => theme.background.transparent.light}; background: ${({ theme }) => theme.background.transparent.light};
} }
}
&:first-of-type { & .react-datepicker__year-option {
display: none; &:first-of-type,
}
&:last-of-type { &:last-of-type {
display: none; display: none;
} }

View File

@ -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<typeof DatePicker> = {
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<typeof DatePicker>;
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(),
);
},
};

View File

@ -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<typeof ImageInput> = {
title: 'UI/Input/ImageInput',
component: ImageInput,
decorators: [ComponentDecorator],
};
export default meta;
type Story = StoryObj<typeof ImageInput>;
export const Default: Story = {};
export const WithPicture: Story = { args: { picture: workspaceLogoUrl } };
export const Disabled: Story = { args: { disabled: true } };

View File

@ -4,6 +4,8 @@ type MockedUser = GetCurrentUserQuery['currentUser'];
export const avatarUrl = export const avatarUrl =
''; '';
export const workspaceLogoUrl =
'';
export const mockedUsersData: Array<MockedUser> = [ export const mockedUsersData: Array<MockedUser> = [
{ {
@ -23,7 +25,7 @@ export const mockedUsersData: Array<MockedUser> = [
displayName: 'Twenty', displayName: 'Twenty',
domainName: 'twenty.com', domainName: 'twenty.com',
inviteHash: 'twenty.com-invite-hash', inviteHash: 'twenty.com-invite-hash',
logo: '', logo: workspaceLogoUrl,
}, },
}, },
settings: { settings: {
@ -49,7 +51,7 @@ export const mockedUsersData: Array<MockedUser> = [
displayName: 'Twenty', displayName: 'Twenty',
domainName: 'twenty.com', domainName: 'twenty.com',
inviteHash: 'twenty.com-invite-hash', inviteHash: 'twenty.com-invite-hash',
logo: '', logo: workspaceLogoUrl,
}, },
}, },
settings: { settings: {