From 6579b8f4d4079244af7abd90353403e6b6106970 Mon Sep 17 00:00:00 2001 From: Anurag Hazra Date: Wed, 21 Oct 2020 19:28:33 +0530 Subject: [PATCH] chore: datepicker & calendar storybook controls (#106) * chore: datepicker storybook controls * chore: added date range picker controls * chore: added range calendar & calendar controls * chore: added default value in date ranges * chore: removed console log --- .storybook/preview.ts | 1 + src/calendar/stories/Calendar.stories.tsx | 74 ++++--- .../stories/RangeCalendar.stories.tsx | 159 ++++++-------- .../stories/RangeCalendarComponent.tsx | 79 +++++++ src/datepicker/stories/DatePicker.stories.tsx | 119 ++++------- .../stories/DatePickerComponent.tsx | 53 +++++ .../stories/DateRangePicker.stories.tsx | 198 ++++-------------- .../stories/DateRangePickerComponent.tsx | 138 ++++++++++++ 8 files changed, 460 insertions(+), 361 deletions(-) create mode 100644 src/calendar/stories/RangeCalendarComponent.tsx create mode 100644 src/datepicker/stories/DatePickerComponent.tsx create mode 100644 src/datepicker/stories/DateRangePickerComponent.tsx diff --git a/.storybook/preview.ts b/.storybook/preview.ts index 57887cd3b..b83f1ed04 100644 --- a/.storybook/preview.ts +++ b/.storybook/preview.ts @@ -1,3 +1,4 @@ export const parameters = { actions: { argTypesRegex: "^on[A-Z].*" }, + controls: { expanded: true }, }; diff --git a/src/calendar/stories/Calendar.stories.tsx b/src/calendar/stories/Calendar.stories.tsx index 0e2d80ce9..7b462e45d 100644 --- a/src/calendar/stories/Calendar.stories.tsx +++ b/src/calendar/stories/Calendar.stories.tsx @@ -1,18 +1,56 @@ +import "./index.css"; import * as React from "react"; -import { Meta } from "@storybook/react"; +import { Meta, Story } from "@storybook/react"; import { addWeeks, format, subWeeks } from "date-fns"; -import "./index.css"; import { CalendarComponent } from "./CalendarComponent"; export default { title: "Calendar", + component: CalendarComponent, + argTypes: { + value: { control: "date" }, + minValue: { control: "date" }, + maxValue: { control: "date" }, + defaultValue: { control: "date", defaultValue: new Date() }, + }, } as Meta; -export const Default = () => ; -export const DefaultValue = () => ( - -); +const Base: Story = args => { + args.value &&= format(new Date(args.value), "yyyy-MM-dd"); + args.defaultValue &&= format(new Date(args.defaultValue), "yyyy-MM-dd"); + args.minValue &&= format(new Date(args.minValue), "yyyy-MM-dd"); + args.maxValue &&= format(new Date(args.maxValue), "yyyy-MM-dd"); + + return ; +}; + +export const Default = Base.bind({}); + +export const DefaultValue = Base.bind({}); +DefaultValue.args = { defaultValue: "2001-01-01" }; + +export const MinMaxDate = Base.bind({}); +MinMaxDate.args = { + minValue: format(new Date(), "yyyy-MM-dd"), + maxValue: format(addWeeks(new Date(), 1), "yyyy-MM-dd"), +}; + +export const MinMaxDefaultDate = Base.bind({}); +MinMaxDefaultDate.args = { + defaultValue: format(new Date(2020, 10, 7), "yyyy-MM-dd"), + minValue: format(subWeeks(new Date(2020, 10, 7), 1), "yyyy-MM-dd"), + maxValue: format(addWeeks(new Date(2020, 10, 7), 1), "yyyy-MM-dd"), +}; + +export const Options = Base.bind({}); +Options.args = { + value: format(new Date(), "yyyy-MM-dd"), + isDisabled: false, + isReadOnly: false, + autoFocus: false, +}; + export const ControlledValue = () => { const [value, setValue] = React.useState("2020-10-13"); @@ -27,27 +65,3 @@ export const ControlledValue = () => { ); }; - -export const MinMaxDate = () => ( - -); - -export const MinMaxDefaultDate = () => ( - -); - -export const isDisabled = () => ; - -export const isReadOnly = () => ; - -export const autoFocus = () => ( - // eslint-disable-next-line jsx-a11y/no-autofocus - -); diff --git a/src/calendar/stories/RangeCalendar.stories.tsx b/src/calendar/stories/RangeCalendar.stories.tsx index c8e8ba0a1..71b352b89 100644 --- a/src/calendar/stories/RangeCalendar.stories.tsx +++ b/src/calendar/stories/RangeCalendar.stories.tsx @@ -1,94 +1,75 @@ -import * as React from "react"; -import { Meta } from "@storybook/react"; -import { addDays, addWeeks, subDays, format } from "date-fns"; import "./range-style.css"; - -import { - ChevronLeft, - ChevronRight, - DoubleChevronLeft, - DoubleChevronRight, -} from "./svg-icons"; - -import { - Calendar, - CalendarCell, - CalendarGrid, - CalendarHeader, - CalendarButton, - CalendarCellButton, - CalendarWeekTitle, -} from "../index"; import { - useRangeCalendarState, - RangeCalendarInitialState, -} from "../RangeCalendarState"; + addDays, + addWeeks, + subDays, + format, + setDate, + subWeeks, +} from "date-fns"; +import * as React from "react"; +import { Meta, Story } from "@storybook/react"; +import RangeCalendarComponent from "./RangeCalendarComponent"; export default { title: "RangeCalendar", + component: RangeCalendarComponent, + argTypes: { + start: { control: "date", name: "value.start" }, + end: { control: "date", name: "value.end" }, + defaultStart: { + control: "date", + name: "default.start", + }, + defaultEnd: { + control: "date", + name: "default.end", + }, + minValue: { control: "date" }, + maxValue: { control: "date" }, + }, } as Meta; -const RangeCalendarComp: React.FC = props => { - const state = useRangeCalendarState(props); +const Base: Story = args => { + args.value = { + start: args.start && format(new Date(args.start), "yyyy-MM-dd"), + end: args.end && format(new Date(args.end), "yyyy-MM-dd"), + }; + args.defaultValue = { + start: + args.defaultStart && format(new Date(args.defaultStart), "yyyy-MM-dd"), + end: args.defaultEnd && format(new Date(args.defaultEnd), "yyyy-MM-dd"), + }; + args.minValue &&= format(new Date(args.minValue), "yyyy-MM-dd"); + args.maxValue &&= format(new Date(args.maxValue), "yyyy-MM-dd"); - return ( - -
- - - - - - - - - - - - - -
+ return ; +}; - - - - {state.weekDays.map((day, dayIndex) => { - return ( - - {day.abbr} - - ); - })} - - - - {state.daysInMonth.map((week, weekIndex) => ( - - {week.map((day, dayIndex) => ( - - - - ))} - - ))} - - -
- ); +export const Default = Base.bind({}); + +export const DefaultValue = Base.bind({}); +DefaultValue.args = { + defaultStart: setDate(new Date(), 10), + defaultEnd: new Date(), +}; + +export const MinMaxDefaultDate = Base.bind({}); +MinMaxDefaultDate.args = { + minValue: subWeeks(new Date(), 1), + maxValue: addWeeks(new Date(), 1), }; -export const Default = () => ; -export const DefaultValue = () => ( - -); +export const Options = Base.bind({}); +Options.args = { + start: new Date(), + end: addWeeks(new Date(), 1), + minValue: null, + maxValue: null, + isDisabled: false, + isReadOnly: false, + autoFocus: false, +}; export const ControlledValue = () => { const [start, setStart] = React.useState( @@ -106,7 +87,7 @@ export const ControlledValue = () => { value={start} /> setEnd(e.target.value)} value={end} /> - { setStart(start); @@ -116,19 +97,3 @@ export const ControlledValue = () => { ); }; - -export const MinMaxDefaultDate = () => ( - -); - -export const isDisabled = () => ; - -export const isReadOnly = () => ; - -export const autoFocus = () => ( - // eslint-disable-next-line jsx-a11y/no-autofocus - -); diff --git a/src/calendar/stories/RangeCalendarComponent.tsx b/src/calendar/stories/RangeCalendarComponent.tsx new file mode 100644 index 000000000..c364db215 --- /dev/null +++ b/src/calendar/stories/RangeCalendarComponent.tsx @@ -0,0 +1,79 @@ +import React from "react"; + +import { + ChevronLeft, + ChevronRight, + DoubleChevronLeft, + DoubleChevronRight, +} from "./svg-icons"; + +import { + Calendar, + CalendarCell, + CalendarGrid, + CalendarHeader, + CalendarButton, + CalendarCellButton, + CalendarWeekTitle, +} from "../index"; +import { + useRangeCalendarState, + RangeCalendarInitialState, +} from "../RangeCalendarState"; + +const RangeCalendarComponent: React.FC = props => { + const state = useRangeCalendarState(props); + + return ( + +
+ + + + + + + + + + + + + +
+ + + + + {state.weekDays.map((day, dayIndex) => { + return ( + + {day.abbr} + + ); + })} + + + + {state.daysInMonth.map((week, weekIndex) => ( + + {week.map((day, dayIndex) => ( + + + + ))} + + ))} + + +
+ ); +}; + +export default RangeCalendarComponent; diff --git a/src/datepicker/stories/DatePicker.stories.tsx b/src/datepicker/stories/DatePicker.stories.tsx index 5757c127f..c227cae6c 100644 --- a/src/datepicker/stories/DatePicker.stories.tsx +++ b/src/datepicker/stories/DatePicker.stories.tsx @@ -1,66 +1,59 @@ +import "./index.css"; import * as React from "react"; -import { Meta } from "@storybook/react"; +import { Meta, Story } from "@storybook/react"; import { addWeeks, subWeeks, format } from "date-fns"; -import "./index.css"; -import { - DatePicker, - DatePickerSegment, - DatePickerSegmentField, - DatePickerContent, - DatePickerTrigger, - useDatePickerState, - DatePickerInitialState, -} from "../index"; -import { CalendarComp } from "../../calendar/stories/CalendarComponent"; +import DatePickerComponent from "./DatePickerComponent"; export default { + component: DatePickerComponent, title: "DatePicker", + argTypes: { + value: { control: "date" }, + minValue: { control: "date" }, + maxValue: { control: "date" }, + defaultValue: { control: "date" }, + }, } as Meta; -const DatePickerComp: React.FC = props => { - const state = useDatePickerState({ - formatOptions: { month: "2-digit", day: "2-digit", year: "numeric" }, - ...props, - }); - - return ( - <> - -
- - {state.segments.map((segment, i) => ( - - ))} - +const Base: Story = args => { + args.value &&= format(new Date(args.value), "yyyy-MM-dd"); + args.defaultValue &&= format(new Date(args.defaultValue), "yyyy-MM-dd"); + args.minValue &&= format(new Date(args.minValue), "yyyy-MM-dd"); + args.maxValue &&= format(new Date(args.maxValue), "yyyy-MM-dd"); - - - -
-
- - - - - ); + return ; }; -const CalendarIcon = () => ( - -); +export const Default = Base.bind({}); + +export const InitialDate = Base.bind({}); +InitialDate.args = { defaultDate: "2020-02-29" }; -export const Default = () => ; +export const MinMaxDate = Base.bind({}); +MinMaxDate.args = { + minValue: new Date(), + maxValue: addWeeks(new Date(), 2), +}; -export const InitialDate = () => ; +export const InValidDate = Base.bind({}); +InValidDate.args = { + defaultValue: addWeeks(new Date(), 2), + minValue: subWeeks(new Date(), 1), + maxValue: addWeeks(new Date(), 1), +}; + +export const Options = Base.bind({}); +Options.args = { + defaultValue: addWeeks(new Date(), 2), + value: addWeeks(new Date(), 2), + minValue: null, + maxValue: null, + autoFocus: false, + isDisabled: false, + isReadOnly: false, + formatOptions: { month: "2-digit", day: "2-digit", year: "numeric" }, +}; export const ControllableState = () => { const [value, setValue] = React.useState("2020-10-13"); @@ -72,31 +65,7 @@ export const ControllableState = () => { onChange={e => setValue(e.target.value)} value={value} /> - + ); }; - -export const MinMaxDate = () => ( - -); - -export const InValidDate = () => ( - -); - -export const isDisabled = () => ; - -export const isReadOnly = () => ; - -export const autoFocus = () => ( - // eslint-disable-next-line jsx-a11y/no-autofocus - -); diff --git a/src/datepicker/stories/DatePickerComponent.tsx b/src/datepicker/stories/DatePickerComponent.tsx new file mode 100644 index 000000000..e15bf9df5 --- /dev/null +++ b/src/datepicker/stories/DatePickerComponent.tsx @@ -0,0 +1,53 @@ +import * as React from "react"; +import { + DatePicker, + DatePickerSegment, + DatePickerContent, + DatePickerTrigger, + useDatePickerState, + DatePickerInitialState, + DatePickerSegmentField, +} from "../index"; +import { CalendarComp } from "../../calendar/stories/CalendarComponent"; + +const DatePickerComponent: React.FC = props => { + const state = useDatePickerState({ + formatOptions: { month: "2-digit", day: "2-digit", year: "numeric" }, + ...props, + }); + + return ( + <> + +
+ + {state.segments.map((segment, i) => ( + + ))} + + + + + +
+
+ + + + + ); +}; + +export const CalendarIcon = () => ( + +); + +export default DatePickerComponent; diff --git a/src/datepicker/stories/DateRangePicker.stories.tsx b/src/datepicker/stories/DateRangePicker.stories.tsx index da5e8e9d3..15dd05f47 100644 --- a/src/datepicker/stories/DateRangePicker.stories.tsx +++ b/src/datepicker/stories/DateRangePicker.stories.tsx @@ -1,174 +1,54 @@ +import "./index.css"; import * as React from "react"; -import { Meta } from "@storybook/react"; +import { format } from "date-fns"; +import { Meta, Story } from "@storybook/react"; import { addWeeks, setDate, subWeeks } from "date-fns"; -import { - ChevronLeft, - ChevronRight, - DoubleChevronLeft, - DoubleChevronRight, -} from "../../calendar/stories/svg-icons"; -import "./index.css"; - -import { - DatePicker, - DatePickerContent, - DatePickerSegment, - DatePickerTrigger, - DatePickerSegmentField, -} from "../index"; -import { - Calendar, - CalendarCell, - CalendarGrid, - CalendarHeader, - CalendarButton, - CalendarWeekTitle, - CalendarCellButton, - RangeCalendarStateReturn, -} from "../../calendar"; -import { - useDateRangePickerState, - DateRangePickerInitialState, -} from "../DateRangePickerState"; -import { stringifyDate } from "../../utils"; +import DateRangePickerComponent from "./DateRangePickerComponent"; export default { title: "DateRangePicker", + component: DateRangePickerComponent, + argTypes: { + start: { control: "date", name: "value.start" }, + end: { control: "date", name: "value.end" }, + minValue: { control: "date" }, + maxValue: { control: "date" }, + }, } as Meta; -const RangeCalendarComp: React.FC = state => { - return ( - -
- - - - - - - - - - - - - -
+const Base: Story = args => { + args.value = { + start: args.start && format(new Date(args.start), "yyyy-MM-dd"), + end: args.end && format(new Date(args.end), "yyyy-MM-dd"), + }; + args.minValue &&= format(new Date(args.minValue), "yyyy-MM-dd"); + args.maxValue &&= format(new Date(args.maxValue), "yyyy-MM-dd"); - - - - {state.weekDays.map((day, dayIndex) => { - return ( - - {day.abbr} - - ); - })} - - - - {state.daysInMonth.map((week, weekIndex) => ( - - {week.map((day, dayIndex) => ( - - - - ))} - - ))} - - -
- ); + return ; }; -const DateRangePickerComp: React.FC = props => { - const state = useDateRangePickerState({ - formatOptions: { month: "2-digit", day: "2-digit", year: "numeric" }, - ...props, - }); +export const Default = Base.bind({}); - return ( - <> - -
- - {state.startSegmentState.segments.map((segment, i) => ( - - ))} - -  -  - - {state.endSegmentState.segments.map((segment, i) => ( - - ))} - - - - -
-
- - - - - ); +export const DefaultValue = Base.bind({}); +DefaultValue.args = { + start: setDate(new Date(), 10), + end: new Date(), }; -const CalendarIcon = () => ( - -); - -export const Default = () => ; -export const DefaultValue = () => ( - -); +export const DateRangePickerComp = Base.bind({}); +DateRangePickerComp.args = { + minValue: subWeeks(new Date(), 1), + maxValue: addWeeks(new Date(), 1), +}; -export const MinMaxDefaultDate = () => ( - -); -export const isDisabled = () => ; -export const isReadOnly = () => ; -export const autoFocus = () => ( - // eslint-disable-next-line jsx-a11y/no-autofocus - -); +export const Options = Base.bind({}); +Options.args = { + start: new Date(), + end: addWeeks(new Date(), 1), + minValue: null, + maxValue: null, + isDisabled: false, + isReadOnly: false, + autoFocus: false, +}; diff --git a/src/datepicker/stories/DateRangePickerComponent.tsx b/src/datepicker/stories/DateRangePickerComponent.tsx new file mode 100644 index 000000000..b3dc4d1fc --- /dev/null +++ b/src/datepicker/stories/DateRangePickerComponent.tsx @@ -0,0 +1,138 @@ +import React from "react"; +import { + ChevronLeft, + ChevronRight, + DoubleChevronLeft, + DoubleChevronRight, +} from "../../calendar/stories/svg-icons"; + +import { + DatePicker, + DatePickerContent, + DatePickerSegment, + DatePickerTrigger, + DatePickerSegmentField, +} from "../index"; +import { + Calendar, + CalendarCell, + CalendarGrid, + CalendarHeader, + CalendarButton, + CalendarWeekTitle, + CalendarCellButton, + RangeCalendarStateReturn, +} from "../../calendar"; +import { + useDateRangePickerState, + DateRangePickerInitialState, +} from "../DateRangePickerState"; +import { CalendarIcon } from "./DatePickerComponent"; + +const RangeCalendarComp: React.FC = state => { + return ( + +
+ + + + + + + + + + + + + +
+ + + + + {state.weekDays.map((day, dayIndex) => { + return ( + + {day.abbr} + + ); + })} + + + + {state.daysInMonth.map((week, weekIndex) => ( + + {week.map((day, dayIndex) => ( + + + + ))} + + ))} + + +
+ ); +}; + +const DateRangePickerComponent: React.FC = props => { + const state = useDateRangePickerState({ + formatOptions: { month: "2-digit", day: "2-digit", year: "numeric" }, + ...props, + }); + + return ( + <> + +
+ + {state.startSegmentState.segments.map((segment, i) => ( + + ))} + +  -  + + {state.endSegmentState.segments.map((segment, i) => ( + + ))} + + + + +
+
+ + + + + ); +}; + +export default DateRangePickerComponent;