diff --git a/src/components/data-entry/DatePicker/DatePicker.stories.tsx b/src/components/data-entry/DatePicker/DatePicker.stories.tsx index 24ee64261..fa0f9313b 100644 --- a/src/components/data-entry/DatePicker/DatePicker.stories.tsx +++ b/src/components/data-entry/DatePicker/DatePicker.stories.tsx @@ -1,9 +1,59 @@ -import { DatePicker } from 'src/components/data-entry/DatePicker/DatePicker' +import { DatePicker, Tooltip } from 'src/components' +import dayjs, { type Dayjs } from 'dayjs' +import React, { useState } from 'react' import { type Meta, type StoryObj } from '@storybook/react' +import { type CellRender as RcPickerCellRender, type CellRenderInfo } from 'rc-picker/lib/interface' + +const DatePickerWithDisabledYears: React.FC = () => { + const [selectedDate, setSelectedDate] = useState(null) + const disabledDate = (current: Dayjs): boolean => current && current.year() < 2023 + const handleChange = (date: Dayjs | null) => { + if (date && disabledDate(date)) { + setSelectedDate(null) + } else { + setSelectedDate(date) + } + } + + const cellRender: RcPickerCellRender = (current, info: CellRenderInfo) => { + if (!dayjs.isDayjs(current)) { + return info.originNode + } + + const isDisabled = disabledDate(current) + + const handleInteraction = (e: React.SyntheticEvent) => { + if (isDisabled) { + e.preventDefault() + e.stopPropagation() + } + } + if (info.type === 'year') { + return isDisabled ? ( + +
+ {current.year()} +
+
+ ) : ( + info.originNode + ) + } + + return info.originNode + } + + return +} + const meta: Meta = { title: 'Aquarium/Data Entry/Date Picker', component: DatePicker, - args: {}, } export default meta @@ -11,3 +61,74 @@ export default meta type Story = StoryObj export const Primary: Story = {} + +export const WithDatePickerWithDisabledYears: Story = { + render: () => , +} + +WithDatePickerWithDisabledYears.parameters = { + docs: { + source: { + code: ` +import React from 'react'; +import { DatePicker } from 'antd'; +import dayjs, { Dayjs } from 'dayjs'; +import { Tooltip } from 'src/components'; + +const DatePickerWithDisabledYears: React.FC = () => { + const [selectedDate, setSelectedDate] = React.useState(null); + + const disabledDate = (current: Dayjs): boolean => current && current.year() < 2023; + + const handleChange = (date: Dayjs | null) => { + if (date && disabledDate(date)) { + setSelectedDate(null); + } else { + setSelectedDate(date); + } + }; + + const cellRender = (current: Dayjs, info: any) => { + const isDisabled = disabledDate(current); + + const handleInteraction = (e: React.SyntheticEvent) => { + if (isDisabled) { + e.preventDefault(); + e.stopPropagation(); + } + }; + + if (info.type === 'year') { + return isDisabled ? ( + +
+ {current.year()} +
+
+ ) : ( + info.originNode + ); + } + + return info.originNode; + }; + + return ( + + ); +}; + `, + }, + }, +}