mirror of
https://github.com/twentyhq/twenty.git
synced 2024-12-18 17:12:53 +03:00
parent
44a9c2687f
commit
2304823dc6
@ -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 {
|
|
||||||
display: none;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
& .react-datepicker__year-option {
|
||||||
|
&:first-of-type,
|
||||||
&:last-of-type {
|
&:last-of-type {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
@ -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(),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
};
|
@ -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 } };
|
@ -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: {
|
||||||
|
Loading…
Reference in New Issue
Block a user