@navikt/ds-react 7.13.0 → 7.14.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/date/Date.Dialog.d.ts +18 -0
- package/cjs/date/Date.Dialog.js +67 -0
- package/cjs/date/Date.Dialog.js.map +1 -0
- package/cjs/date/Date.Input.d.ts +50 -0
- package/cjs/date/Date.Input.js +96 -0
- package/cjs/date/Date.Input.js.map +1 -0
- package/cjs/date/Date.locale.d.ts +44 -0
- package/cjs/date/Date.locale.js +57 -0
- package/cjs/date/Date.locale.js.map +1 -0
- package/cjs/date/Date.typeutils.d.ts +14 -0
- package/cjs/date/Date.typeutils.js +15 -0
- package/cjs/date/Date.typeutils.js.map +1 -0
- package/cjs/date/date-utils/calendar-range.d.ts +11 -0
- package/cjs/date/date-utils/calendar-range.js +30 -0
- package/cjs/date/date-utils/calendar-range.js.map +1 -0
- package/cjs/date/date-utils/check-dates.d.ts +8 -0
- package/cjs/date/date-utils/check-dates.js +20 -0
- package/cjs/date/date-utils/check-dates.js.map +1 -0
- package/cjs/date/date-utils/clamp-dates.d.ts +19 -0
- package/cjs/date/date-utils/clamp-dates.js +41 -0
- package/cjs/date/date-utils/clamp-dates.js.map +1 -0
- package/cjs/date/date-utils/dates-disabled.d.ts +1 -0
- package/cjs/date/date-utils/dates-disabled.js +29 -0
- package/cjs/date/date-utils/dates-disabled.js.map +1 -0
- package/cjs/date/date-utils/dropdown-options.d.ts +13 -0
- package/cjs/date/date-utils/dropdown-options.js +45 -0
- package/cjs/date/date-utils/dropdown-options.js.map +1 -0
- package/cjs/date/date-utils/format-date.d.ts +2 -0
- package/cjs/date/date-utils/format-date.js +13 -0
- package/cjs/date/date-utils/format-date.js.map +1 -0
- package/cjs/date/date-utils/index.d.ts +8 -0
- package/cjs/date/date-utils/index.js +27 -0
- package/cjs/date/date-utils/index.js.map +1 -0
- package/cjs/date/date-utils/is-match.d.ts +3 -0
- package/cjs/date/date-utils/is-match.js +61 -0
- package/cjs/date/date-utils/is-match.js.map +1 -0
- package/cjs/date/date-utils/parse-date.d.ts +4 -0
- package/cjs/date/date-utils/parse-date.js +87 -0
- package/cjs/date/date-utils/parse-date.js.map +1 -0
- package/cjs/date/datepicker/DatePicker.d.ts +3 -3
- package/cjs/date/datepicker/DatePicker.js +47 -63
- package/cjs/date/datepicker/DatePicker.js.map +1 -1
- package/cjs/date/datepicker/DatePicker.types.d.ts +108 -0
- package/cjs/date/datepicker/DatePicker.types.js +3 -0
- package/cjs/date/datepicker/DatePicker.types.js.map +1 -0
- package/cjs/date/datepicker/hooks/useDatepicker.d.ts +90 -0
- package/cjs/date/datepicker/hooks/useDatepicker.js +164 -0
- package/cjs/date/datepicker/hooks/useDatepicker.js.map +1 -0
- package/cjs/date/datepicker/hooks/useRangeDatepicker.d.ts +76 -0
- package/cjs/date/datepicker/hooks/useRangeDatepicker.js +322 -0
- package/cjs/date/datepicker/hooks/useRangeDatepicker.js.map +1 -0
- package/cjs/date/datepicker/index.d.ts +4 -3
- package/cjs/date/datepicker/index.js +8 -7
- package/cjs/date/datepicker/index.js.map +1 -1
- package/cjs/date/datepicker/parts/DatePicker.DayButton.d.ts +9 -0
- package/cjs/date/datepicker/parts/DatePicker.DayButton.js +70 -0
- package/cjs/date/datepicker/parts/DatePicker.DayButton.js.map +1 -0
- package/cjs/date/datepicker/parts/DatePicker.Months.d.ts +11 -0
- package/cjs/date/datepicker/parts/DatePicker.Months.js +84 -0
- package/cjs/date/datepicker/parts/DatePicker.Months.js.map +1 -0
- package/cjs/date/datepicker/parts/DatePicker.RDP.d.ts +15 -0
- package/cjs/date/datepicker/parts/DatePicker.RDP.js +103 -0
- package/cjs/date/datepicker/parts/DatePicker.RDP.js.map +1 -0
- package/cjs/date/datepicker/parts/DatePicker.Standalone.d.ts +18 -0
- package/cjs/date/datepicker/parts/DatePicker.Standalone.js +60 -0
- package/cjs/date/datepicker/parts/DatePicker.Standalone.js.map +1 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekNumber.d.ts +9 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekNumber.js +64 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekNumber.js.map +1 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekRow.d.ts +8 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekRow.js +28 -0
- package/cjs/date/datepicker/parts/DatePicker.WeekRow.js.map +1 -0
- package/cjs/date/monthpicker/MonthPicker.context.d.ts +21 -0
- package/cjs/date/monthpicker/MonthPicker.context.js +48 -0
- package/cjs/date/monthpicker/MonthPicker.context.js.map +1 -0
- package/cjs/date/monthpicker/MonthPicker.d.ts +3 -3
- package/cjs/date/monthpicker/MonthPicker.js +34 -43
- package/cjs/date/monthpicker/MonthPicker.js.map +1 -1
- package/cjs/date/monthpicker/MonthPicker.types.d.ts +86 -0
- package/cjs/date/monthpicker/MonthPicker.types.js +3 -0
- package/cjs/date/monthpicker/MonthPicker.types.js.map +1 -0
- package/cjs/date/monthpicker/MonthPicker.util.d.ts +2 -0
- package/cjs/date/monthpicker/MonthPicker.util.js +156 -0
- package/cjs/date/monthpicker/MonthPicker.util.js.map +1 -0
- package/cjs/date/monthpicker/hooks/useMonthPicker.d.ts +85 -0
- package/cjs/date/monthpicker/hooks/useMonthPicker.js +179 -0
- package/cjs/date/monthpicker/hooks/useMonthPicker.js.map +1 -0
- package/cjs/date/monthpicker/index.d.ts +4 -4
- package/cjs/date/monthpicker/index.js +6 -6
- package/cjs/date/monthpicker/index.js.map +1 -1
- package/cjs/date/monthpicker/parts/MonthPicker.Button.d.ts +11 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Button.js +82 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Button.js.map +1 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.d.ts +3 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.js +52 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Standalone.d.ts +10 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Standalone.js +51 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Standalone.js.map +1 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Table.d.ts +3 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Table.js +79 -0
- package/cjs/date/monthpicker/parts/MonthPicker.Table.js.map +1 -0
- package/cjs/form/combobox/Combobox.d.ts +1 -1
- package/cjs/form/combobox/Input/InputController.d.ts +1 -1
- package/cjs/modal/Modal.js +2 -2
- package/cjs/modal/Modal.js.map +1 -1
- package/cjs/popover/Popover.js +3 -3
- package/cjs/popover/Popover.js.map +1 -1
- package/cjs/tooltip/Tooltip.js +2 -5
- package/cjs/tooltip/Tooltip.js.map +1 -1
- package/esm/date/Date.Dialog.d.ts +18 -0
- package/esm/date/Date.Dialog.js +38 -0
- package/esm/date/Date.Dialog.js.map +1 -0
- package/esm/date/Date.Input.d.ts +50 -0
- package/esm/date/Date.Input.js +66 -0
- package/esm/date/Date.Input.js.map +1 -0
- package/esm/date/Date.locale.d.ts +44 -0
- package/esm/date/Date.locale.js +47 -0
- package/esm/date/Date.locale.js.map +1 -0
- package/esm/date/Date.typeutils.d.ts +14 -0
- package/esm/date/Date.typeutils.js +10 -0
- package/esm/date/Date.typeutils.js.map +1 -0
- package/esm/date/date-utils/calendar-range.d.ts +11 -0
- package/esm/date/date-utils/calendar-range.js +27 -0
- package/esm/date/date-utils/calendar-range.js.map +1 -0
- package/esm/date/date-utils/check-dates.d.ts +8 -0
- package/esm/date/date-utils/check-dates.js +14 -0
- package/esm/date/date-utils/check-dates.js.map +1 -0
- package/esm/date/date-utils/clamp-dates.d.ts +19 -0
- package/esm/date/date-utils/clamp-dates.js +37 -0
- package/esm/date/date-utils/clamp-dates.js.map +1 -0
- package/esm/date/date-utils/dates-disabled.d.ts +1 -0
- package/esm/date/date-utils/dates-disabled.js +25 -0
- package/esm/date/date-utils/dates-disabled.js.map +1 -0
- package/esm/date/date-utils/dropdown-options.d.ts +13 -0
- package/esm/date/date-utils/dropdown-options.js +41 -0
- package/esm/date/date-utils/dropdown-options.js.map +1 -0
- package/esm/date/date-utils/format-date.d.ts +2 -0
- package/esm/date/date-utils/format-date.js +9 -0
- package/esm/date/date-utils/format-date.js.map +1 -0
- package/esm/date/date-utils/index.d.ts +8 -0
- package/esm/date/date-utils/index.js +9 -0
- package/esm/date/date-utils/index.js.map +1 -0
- package/esm/date/date-utils/is-match.d.ts +3 -0
- package/esm/date/date-utils/is-match.js +57 -0
- package/esm/date/date-utils/is-match.js.map +1 -0
- package/esm/date/date-utils/parse-date.d.ts +4 -0
- package/esm/date/date-utils/parse-date.js +83 -0
- package/esm/date/date-utils/parse-date.js.map +1 -0
- package/esm/date/datepicker/DatePicker.d.ts +3 -3
- package/esm/date/datepicker/DatePicker.js +46 -62
- package/esm/date/datepicker/DatePicker.js.map +1 -1
- package/esm/date/datepicker/DatePicker.types.d.ts +108 -0
- package/esm/date/datepicker/DatePicker.types.js +2 -0
- package/esm/date/datepicker/DatePicker.types.js.map +1 -0
- package/esm/date/datepicker/hooks/useDatepicker.d.ts +90 -0
- package/esm/date/datepicker/hooks/useDatepicker.js +160 -0
- package/esm/date/datepicker/hooks/useDatepicker.js.map +1 -0
- package/esm/date/datepicker/hooks/useRangeDatepicker.d.ts +76 -0
- package/esm/date/datepicker/hooks/useRangeDatepicker.js +318 -0
- package/esm/date/datepicker/hooks/useRangeDatepicker.js.map +1 -0
- package/esm/date/datepicker/index.d.ts +4 -3
- package/esm/date/datepicker/index.js +4 -3
- package/esm/date/datepicker/index.js.map +1 -1
- package/esm/date/datepicker/parts/DatePicker.DayButton.d.ts +9 -0
- package/esm/date/datepicker/parts/DatePicker.DayButton.js +41 -0
- package/esm/date/datepicker/parts/DatePicker.DayButton.js.map +1 -0
- package/esm/date/datepicker/parts/DatePicker.Months.d.ts +11 -0
- package/esm/date/datepicker/parts/DatePicker.Months.js +58 -0
- package/esm/date/datepicker/parts/DatePicker.Months.js.map +1 -0
- package/esm/date/datepicker/parts/DatePicker.RDP.d.ts +15 -0
- package/esm/date/datepicker/parts/DatePicker.RDP.js +74 -0
- package/esm/date/datepicker/parts/DatePicker.RDP.js.map +1 -0
- package/esm/date/datepicker/parts/DatePicker.Standalone.d.ts +18 -0
- package/esm/date/datepicker/parts/DatePicker.Standalone.js +31 -0
- package/esm/date/datepicker/parts/DatePicker.Standalone.js.map +1 -0
- package/esm/date/datepicker/parts/DatePicker.WeekNumber.d.ts +9 -0
- package/esm/date/datepicker/parts/DatePicker.WeekNumber.js +35 -0
- package/esm/date/datepicker/parts/DatePicker.WeekNumber.js.map +1 -0
- package/esm/date/datepicker/parts/DatePicker.WeekRow.d.ts +8 -0
- package/esm/date/datepicker/parts/DatePicker.WeekRow.js +22 -0
- package/esm/date/datepicker/parts/DatePicker.WeekRow.js.map +1 -0
- package/esm/date/monthpicker/MonthPicker.context.d.ts +21 -0
- package/esm/date/monthpicker/MonthPicker.context.js +41 -0
- package/esm/date/monthpicker/MonthPicker.context.js.map +1 -0
- package/esm/date/monthpicker/MonthPicker.d.ts +3 -3
- package/esm/date/monthpicker/MonthPicker.js +31 -40
- package/esm/date/monthpicker/MonthPicker.js.map +1 -1
- package/esm/date/monthpicker/MonthPicker.types.d.ts +86 -0
- package/esm/date/monthpicker/MonthPicker.types.js +2 -0
- package/esm/date/monthpicker/MonthPicker.types.js.map +1 -0
- package/esm/date/monthpicker/MonthPicker.util.d.ts +2 -0
- package/esm/date/monthpicker/MonthPicker.util.js +152 -0
- package/esm/date/monthpicker/MonthPicker.util.js.map +1 -0
- package/esm/date/monthpicker/hooks/useMonthPicker.d.ts +85 -0
- package/esm/date/monthpicker/hooks/useMonthPicker.js +175 -0
- package/esm/date/monthpicker/hooks/useMonthPicker.js.map +1 -0
- package/esm/date/monthpicker/index.d.ts +4 -4
- package/esm/date/monthpicker/index.js +3 -3
- package/esm/date/monthpicker/index.js.map +1 -1
- package/esm/date/monthpicker/parts/MonthPicker.Button.d.ts +11 -0
- package/esm/date/monthpicker/parts/MonthPicker.Button.js +52 -0
- package/esm/date/monthpicker/parts/MonthPicker.Button.js.map +1 -0
- package/esm/date/monthpicker/parts/MonthPicker.Caption.d.ts +3 -0
- package/esm/date/monthpicker/parts/MonthPicker.Caption.js +46 -0
- package/esm/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -0
- package/esm/date/monthpicker/parts/MonthPicker.Standalone.d.ts +10 -0
- package/esm/date/monthpicker/parts/MonthPicker.Standalone.js +22 -0
- package/esm/date/monthpicker/parts/MonthPicker.Standalone.js.map +1 -0
- package/esm/date/monthpicker/parts/MonthPicker.Table.d.ts +3 -0
- package/esm/date/monthpicker/parts/MonthPicker.Table.js +50 -0
- package/esm/date/monthpicker/parts/MonthPicker.Table.js.map +1 -0
- package/esm/form/combobox/Combobox.d.ts +1 -1
- package/esm/form/combobox/Input/InputController.d.ts +1 -1
- package/esm/modal/Modal.js +3 -3
- package/esm/modal/Modal.js.map +1 -1
- package/esm/popover/Popover.js +4 -4
- package/esm/popover/Popover.js.map +1 -1
- package/esm/tooltip/Tooltip.js +2 -5
- package/esm/tooltip/Tooltip.js.map +1 -1
- package/package.json +6 -7
- package/src/date/{parts/DateWrapper.tsx → Date.Dialog.tsx} +12 -9
- package/src/date/{parts/DateInput.tsx → Date.Input.tsx} +30 -5
- package/src/date/{utils/locale.ts → Date.locale.ts} +11 -2
- package/src/date/Date.typeutils.ts +32 -0
- package/src/date/date-utils/calendar-range.test.ts +54 -0
- package/src/date/date-utils/calendar-range.ts +46 -0
- package/src/date/date-utils/check-dates.test.ts +49 -0
- package/src/date/date-utils/check-dates.ts +28 -0
- package/src/date/date-utils/clamp-dates.test.ts +156 -0
- package/src/date/date-utils/clamp-dates.ts +63 -0
- package/src/date/{utils/__tests__ → date-utils}/dates-disabled.test.ts +1 -1
- package/src/date/{utils → date-utils}/dates-disabled.ts +1 -2
- package/src/date/date-utils/dropdown-options.test.ts +143 -0
- package/src/date/date-utils/dropdown-options.ts +79 -0
- package/src/date/{utils/__tests__ → date-utils}/format-dates.test.ts +2 -2
- package/src/date/date-utils/index.ts +16 -0
- package/src/date/{utils/__tests__ → date-utils}/is-match.test.ts +1 -1
- package/src/date/{utils → date-utils}/is-match.ts +2 -11
- package/src/date/{utils/__tests__ → date-utils}/parse-dates.test.ts +2 -1
- package/src/date/datepicker/DatePicker.tsx +67 -92
- package/src/date/datepicker/{types.ts → DatePicker.types.ts} +10 -4
- package/src/date/{hooks → datepicker/hooks}/useDatepicker.tsx +12 -13
- package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.test.tsx +1 -1
- package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.tsx +19 -19
- package/src/date/datepicker/index.ts +4 -5
- package/src/date/datepicker/parts/DatePicker.DayButton.tsx +56 -0
- package/src/date/datepicker/parts/DatePicker.Months.tsx +149 -0
- package/src/date/datepicker/parts/DatePicker.RDP.tsx +170 -0
- package/src/date/datepicker/parts/DatePicker.Standalone.tsx +93 -0
- package/src/date/datepicker/parts/DatePicker.WeekNumber.tsx +86 -0
- package/src/date/datepicker/parts/{WeekRow.tsx → DatePicker.WeekRow.tsx} +20 -21
- package/src/date/monthpicker/MonthPicker.context.tsx +103 -0
- package/src/date/monthpicker/MonthPicker.tsx +63 -68
- package/src/date/monthpicker/{types.ts → MonthPicker.types.ts} +1 -1
- package/src/date/{utils/navigation.ts → monthpicker/MonthPicker.util.ts} +2 -1
- package/src/date/{hooks → monthpicker/hooks}/useMonthPicker.tsx +14 -13
- package/src/date/monthpicker/index.ts +4 -4
- package/src/date/monthpicker/{MonthButton.tsx → parts/MonthPicker.Button.tsx} +21 -10
- package/src/date/monthpicker/{MonthCaption.tsx → parts/MonthPicker.Caption.tsx} +20 -21
- package/src/date/monthpicker/parts/MonthPicker.Standalone.tsx +86 -0
- package/src/date/monthpicker/{MonthSelector.tsx → parts/MonthPicker.Table.tsx} +7 -7
- package/src/modal/Modal.tsx +3 -3
- package/src/popover/Popover.tsx +4 -4
- package/src/tooltip/Tooltip.tsx +2 -6
- package/src/date/context/index.ts +0 -9
- package/src/date/context/useDateInputContext.tsx +0 -34
- package/src/date/context/useDateTranslationContext.ts +0 -9
- package/src/date/context/useSharedMonthContext.tsx +0 -68
- package/src/date/datepicker/DatePickerStandalone.tsx +0 -136
- package/src/date/datepicker/datepicker.test.tsx +0 -28
- package/src/date/datepicker/parts/Caption.tsx +0 -54
- package/src/date/datepicker/parts/DayButton.tsx +0 -32
- package/src/date/datepicker/parts/DropdownCaption.tsx +0 -110
- package/src/date/datepicker/parts/HeadRow.tsx +0 -56
- package/src/date/datepicker/parts/Row.tsx +0 -48
- package/src/date/datepicker/parts/TableHead.tsx +0 -17
- package/src/date/datepicker/parts/WeekNumber.tsx +0 -75
- package/src/date/hooks/index.ts +0 -6
- package/src/date/monthpicker/MonthPickerStandalone.tsx +0 -102
- package/src/date/utils/__tests__/check-dates.test.ts +0 -22
- package/src/date/utils/__tests__/get-dates.test.ts +0 -121
- package/src/date/utils/__tests__/get-initial-year.test.ts +0 -83
- package/src/date/utils/__tests__/get-month-weeks.test.ts +0 -116
- package/src/date/utils/check-dates.ts +0 -13
- package/src/date/utils/get-dates.ts +0 -60
- package/src/date/utils/get-initial-year.ts +0 -25
- package/src/date/utils/get-month-weeks.ts +0 -93
- package/src/date/utils/index.ts +0 -18
- /package/src/date/{utils → date-utils}/format-date.ts +0 -0
- /package/src/date/{utils → date-utils}/parse-date.ts +0 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { addYears, eachMonthOfInterval, endOfYear, format, getMonth, getYear, isBefore, isSameYear, startOfMonth, startOfYear, } from "date-fns";
|
|
2
|
+
/** Return the months to show in the dropdown. */
|
|
3
|
+
export function getMonthOptions(displayMonth, navStart, navEnd, locale) {
|
|
4
|
+
const months = eachMonthOfInterval({
|
|
5
|
+
start: startOfYear(displayMonth),
|
|
6
|
+
end: endOfYear(displayMonth),
|
|
7
|
+
});
|
|
8
|
+
const options = months.map((month) => {
|
|
9
|
+
const label = format(month, "LLLL", { locale });
|
|
10
|
+
const value = getMonth(month);
|
|
11
|
+
const disabled = (navStart && month < startOfMonth(navStart)) ||
|
|
12
|
+
(navEnd && month > startOfMonth(navEnd)) ||
|
|
13
|
+
false;
|
|
14
|
+
return { value, label, disabled };
|
|
15
|
+
});
|
|
16
|
+
return options;
|
|
17
|
+
}
|
|
18
|
+
/** Return the years to show in the dropdown. */
|
|
19
|
+
export function getYearOptions(navStart, navEnd, locale) {
|
|
20
|
+
if (!navStart)
|
|
21
|
+
return undefined;
|
|
22
|
+
if (!navEnd)
|
|
23
|
+
return undefined;
|
|
24
|
+
const firstNavYear = startOfYear(navStart);
|
|
25
|
+
const lastNavYear = endOfYear(navEnd);
|
|
26
|
+
const years = [];
|
|
27
|
+
let year = firstNavYear;
|
|
28
|
+
while (isBefore(year, lastNavYear) || isSameYear(year, lastNavYear)) {
|
|
29
|
+
years.push(year);
|
|
30
|
+
year = addYears(year, 1);
|
|
31
|
+
}
|
|
32
|
+
return years.map((_year) => {
|
|
33
|
+
const label = format(_year, "yyyy", { locale });
|
|
34
|
+
return {
|
|
35
|
+
value: getYear(_year),
|
|
36
|
+
label,
|
|
37
|
+
disabled: false,
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=dropdown-options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-options.js","sourceRoot":"","sources":["../../../src/date/date-utils/dropdown-options.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,QAAQ,EACR,mBAAmB,EACnB,SAAS,EACT,MAAM,EACN,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,UAAU,EACV,YAAY,EACZ,WAAW,GACZ,MAAM,UAAU,CAAC;AAElB,iDAAiD;AACjD,MAAM,UAAU,eAAe,CAC7B,YAAkB,EAClB,QAA0B,EAC1B,MAAwB,EACxB,MAAc;IAQd,MAAM,MAAM,GAAG,mBAAmB,CAAC;QACjC,KAAK,EAAE,WAAW,CAAC,YAAY,CAAC;QAChC,GAAG,EAAE,SAAS,CAAC,YAAY,CAAC;KAC7B,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACnC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,QAAQ,GACZ,CAAC,QAAQ,IAAI,KAAK,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;YAC5C,CAAC,MAAM,IAAI,KAAK,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;YACxC,KAAK,CAAC;QACR,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,gDAAgD;AAChD,MAAM,UAAU,cAAc,CAC5B,QAA0B,EAC1B,MAAwB,EACxB,MAAc;IAQd,IAAI,CAAC,QAAQ;QAAE,OAAO,SAAS,CAAC;IAChC,IAAI,CAAC,MAAM;QAAE,OAAO,SAAS,CAAC;IAE9B,MAAM,YAAY,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC3C,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IACtC,MAAM,KAAK,GAAW,EAAE,CAAC;IAEzB,IAAI,IAAI,GAAG,YAAY,CAAC;IACxB,OAAO,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,EAAE,CAAC;QACpE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,IAAI,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACzB,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC;YACrB,KAAK;YACL,QAAQ,EAAE,KAAK;SAChB,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { format } from "date-fns";
|
|
2
|
+
import { INPUT_DATE_STRING_FORMAT_DATE, INPUT_DATE_STRING_FORMAT_MONTH, } from "./parse-date.js";
|
|
3
|
+
export const formatDateForInput = (date, locale, type, inputFormat) => {
|
|
4
|
+
const INPUT_DATE_STRING_FORMAT = inputFormat !== null && inputFormat !== void 0 ? inputFormat : (type === "date"
|
|
5
|
+
? INPUT_DATE_STRING_FORMAT_DATE
|
|
6
|
+
: INPUT_DATE_STRING_FORMAT_MONTH);
|
|
7
|
+
return format(date, INPUT_DATE_STRING_FORMAT, { locale });
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=format-date.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-date.js","sourceRoot":"","sources":["../../../src/date/date-utils/format-date.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,MAAM,EAAE,MAAM,UAAU,CAAC;AAC1C,OAAO,EACL,6BAA6B,EAC7B,8BAA8B,GAC/B,MAAM,cAAc,CAAC;AAEtB,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,IAAU,EACV,MAAc,EACd,IAAsB,EACtB,WAAoB,EACpB,EAAE;IACF,MAAM,wBAAwB,GAC5B,WAAW,aAAX,WAAW,cAAX,WAAW,GACX,CAAC,IAAI,KAAK,MAAM;QACd,CAAC,CAAC,6BAA6B;QAC/B,CAAC,CAAC,8BAA8B,CAAC,CAAC;IACtC,OAAO,MAAM,CAAC,IAAI,EAAE,wBAAwB,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;AAC5D,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { formatDateForInput } from "./format-date.js";
|
|
2
|
+
export { INPUT_DATE_STRING_FORMAT_DATE, INPUT_DATE_STRING_FORMAT_MONTH, parseDate, } from "./parse-date.js";
|
|
3
|
+
export { disableDate } from "./dates-disabled.js";
|
|
4
|
+
export { dateIsInCurrentMonth, isValidDate, isDateOutsideRange, } from "./check-dates.js";
|
|
5
|
+
export { isMatch, isDateInRange } from "./is-match.js";
|
|
6
|
+
export { clampDisplayMonth, clampDisplayYear } from "./clamp-dates.js";
|
|
7
|
+
export { getMonthOptions, getYearOptions } from "./dropdown-options.js";
|
|
8
|
+
export { calendarRange } from "./calendar-range.js";
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { formatDateForInput } from "./format-date.js";
|
|
2
|
+
export { INPUT_DATE_STRING_FORMAT_DATE, INPUT_DATE_STRING_FORMAT_MONTH, parseDate, } from "./parse-date.js";
|
|
3
|
+
export { disableDate } from "./dates-disabled.js";
|
|
4
|
+
export { dateIsInCurrentMonth, isValidDate, isDateOutsideRange, } from "./check-dates.js";
|
|
5
|
+
export { isMatch, isDateInRange } from "./is-match.js";
|
|
6
|
+
export { clampDisplayMonth, clampDisplayYear } from "./clamp-dates.js";
|
|
7
|
+
export { getMonthOptions, getYearOptions } from "./dropdown-options.js";
|
|
8
|
+
export { calendarRange } from "./calendar-range.js";
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date/date-utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EACL,6BAA6B,EAC7B,8BAA8B,EAC9B,SAAS,GACV,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,oBAAoB,EACpB,WAAW,EACX,kBAAkB,GACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { differenceInCalendarDays, isDate, isSameDay, isSameMonth, } from "date-fns";
|
|
2
|
+
import { isDateAfterType, isDateBeforeType, isDateRange, } from "../Date.typeutils.js";
|
|
3
|
+
function isDateType(value) {
|
|
4
|
+
return isDate(value);
|
|
5
|
+
}
|
|
6
|
+
function isArrayOfDates(value) {
|
|
7
|
+
return Array.isArray(value) && value.every(isDate);
|
|
8
|
+
}
|
|
9
|
+
export function isMatch(day, matchers) {
|
|
10
|
+
return matchers.some((matcher) => {
|
|
11
|
+
if (isDateType(matcher)) {
|
|
12
|
+
return isSameMonth(day, matcher);
|
|
13
|
+
}
|
|
14
|
+
if (isArrayOfDates(matcher)) {
|
|
15
|
+
return matcher.some((matcherDay) => {
|
|
16
|
+
return isSameMonth(matcherDay, day);
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
if (isDateRange(matcher)) {
|
|
20
|
+
return isDateInRange(day, matcher);
|
|
21
|
+
}
|
|
22
|
+
if (isDateAfterType(matcher)) {
|
|
23
|
+
return (isSameMonth(day, matcher.after) ||
|
|
24
|
+
differenceInCalendarDays(day, matcher.after) > 0);
|
|
25
|
+
}
|
|
26
|
+
if (isDateBeforeType(matcher)) {
|
|
27
|
+
return (isSameMonth(day, matcher.before) ||
|
|
28
|
+
differenceInCalendarDays(matcher.before, day) > 0);
|
|
29
|
+
}
|
|
30
|
+
if (typeof matcher === "function") {
|
|
31
|
+
return matcher(day);
|
|
32
|
+
}
|
|
33
|
+
return false;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
export function isDateInRange(date, range) {
|
|
37
|
+
let { from, to } = range;
|
|
38
|
+
if (!from) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
if (!to && isSameDay(from, date)) {
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
if (!to) {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
const isToBeforeFrom = differenceInCalendarDays(to, from) < 0;
|
|
48
|
+
if (to && isToBeforeFrom) {
|
|
49
|
+
[from, to] = [to, from];
|
|
50
|
+
}
|
|
51
|
+
if (isSameMonth(from, date) || isSameMonth(to, date)) {
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
return (differenceInCalendarDays(date, from) >= 0 &&
|
|
55
|
+
differenceInCalendarDays(to, date) >= 0);
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=is-match.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-match.js","sourceRoot":"","sources":["../../../src/date/date-utils/is-match.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Locale } from "date-fns";
|
|
2
|
+
export declare const INPUT_DATE_STRING_FORMAT_DATE = "dd.MM.yyyy";
|
|
3
|
+
export declare const INPUT_DATE_STRING_FORMAT_MONTH = "MMMM yyyy";
|
|
4
|
+
export declare const parseDate: (date: string, today: Date, locale: Locale, type: "date" | "month", allowTwoDigitYear: boolean) => Date;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { isBefore, parse, sub } from "date-fns";
|
|
2
|
+
import { isValidDate } from "./check-dates.js";
|
|
3
|
+
export const INPUT_DATE_STRING_FORMAT_DATE = "dd.MM.yyyy";
|
|
4
|
+
export const INPUT_DATE_STRING_FORMAT_MONTH = "MMMM yyyy";
|
|
5
|
+
const ALLOWED_INPUT_FORMATS_DATE = [
|
|
6
|
+
INPUT_DATE_STRING_FORMAT_DATE,
|
|
7
|
+
"ddMMyyyy",
|
|
8
|
+
"dd/MM/yyyy",
|
|
9
|
+
"dd-MM-yyyy",
|
|
10
|
+
];
|
|
11
|
+
const ALLOWED_INPUT_FORMATS_MONTH = [
|
|
12
|
+
"M/yyyy",
|
|
13
|
+
"MM/yyyy",
|
|
14
|
+
"M-yyyy",
|
|
15
|
+
"MM-yyyy",
|
|
16
|
+
"MM.yyyy",
|
|
17
|
+
"MMyyyy",
|
|
18
|
+
INPUT_DATE_STRING_FORMAT_MONTH,
|
|
19
|
+
...ALLOWED_INPUT_FORMATS_DATE,
|
|
20
|
+
];
|
|
21
|
+
export const parseDate = (date, today, locale, type, allowTwoDigitYear) => {
|
|
22
|
+
let parsed;
|
|
23
|
+
const ALLOWED_FORMATS = type === "date" ? ALLOWED_INPUT_FORMATS_DATE : ALLOWED_INPUT_FORMATS_MONTH;
|
|
24
|
+
if (allowTwoDigitYear) {
|
|
25
|
+
for (const format of ALLOWED_FORMATS) {
|
|
26
|
+
parsed = parse(date, format, today, { locale });
|
|
27
|
+
if (isValidDate(parsed) &&
|
|
28
|
+
!isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
29
|
+
return parsed;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
for (const format of [
|
|
33
|
+
...ALLOWED_FORMATS.map((x) => x.replace("yyyy", "yy")),
|
|
34
|
+
]) {
|
|
35
|
+
parsed = parse(date, format, today, { locale });
|
|
36
|
+
if (isValidDate(parsed) &&
|
|
37
|
+
isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
38
|
+
const convertedDate = assignCenturyToDate(date, format, today, locale);
|
|
39
|
+
if (isValidDate(new Date(convertedDate))) {
|
|
40
|
+
return new Date(convertedDate);
|
|
41
|
+
}
|
|
42
|
+
return new Date("Invalid date");
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return new Date("Invalid date");
|
|
46
|
+
}
|
|
47
|
+
for (const format of ALLOWED_FORMATS) {
|
|
48
|
+
parsed = parse(date, format, today, { locale });
|
|
49
|
+
if (isValidDate(parsed) &&
|
|
50
|
+
!isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
51
|
+
return parsed;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return new Date("Invalid date");
|
|
55
|
+
};
|
|
56
|
+
function isTwoDigitYear(dateString, today, locale, formats) {
|
|
57
|
+
let parsed;
|
|
58
|
+
const newFormat = formats.map((x) => x.replace("yyyy", "yy"));
|
|
59
|
+
for (const format of newFormat) {
|
|
60
|
+
parsed = parse(dateString, format, today, { locale });
|
|
61
|
+
if (isValidDate(parsed)) {
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
function assignCenturyToDate(dateStr, format, today, locale) {
|
|
68
|
+
const date20Century = parse(appendCenturyToTwoYearDigitDateString(dateStr, "19"), format.replace("yy", "yyyy"), today, { locale });
|
|
69
|
+
const date21Century = parse(appendCenturyToTwoYearDigitDateString(dateStr, "20"), format.replace("yy", "yyyy"), today, { locale });
|
|
70
|
+
if (isValidDate(date20Century) && isValidDate(date21Century)) {
|
|
71
|
+
return isBefore(date20Century, sub(new Date(), {
|
|
72
|
+
years: 80,
|
|
73
|
+
}))
|
|
74
|
+
? date21Century
|
|
75
|
+
: date20Century;
|
|
76
|
+
}
|
|
77
|
+
return new Date("Invalid date");
|
|
78
|
+
}
|
|
79
|
+
function appendCenturyToTwoYearDigitDateString(dateString, century) {
|
|
80
|
+
const twoDigitYear = dateString.slice(-2);
|
|
81
|
+
return `${dateString.slice(0, dateString.length - 2)}${century}${twoDigitYear}`;
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=parse-date.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-date.js","sourceRoot":"","sources":["../../../src/date/date-utils/parse-date.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { DatePickerInput } from "../
|
|
3
|
-
import
|
|
4
|
-
import
|
|
2
|
+
import { DatePickerInput } from "../Date.Input.js";
|
|
3
|
+
import { ConditionalModeProps, DatePickerDefaultProps } from "./DatePicker.types.js";
|
|
4
|
+
import DatePickerStandalone from "./parts/DatePicker.Standalone.js";
|
|
5
5
|
export type DatePickerProps = DatePickerDefaultProps & ConditionalModeProps;
|
|
6
6
|
interface DatePickerComponent extends React.ForwardRefExoticComponent<DatePickerProps> {
|
|
7
7
|
/**
|
|
@@ -10,24 +10,17 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
10
10
|
return t;
|
|
11
11
|
};
|
|
12
12
|
import cl from "clsx";
|
|
13
|
-
import {
|
|
13
|
+
import { isSameDay } from "date-fns";
|
|
14
14
|
import React, { forwardRef, useState } from "react";
|
|
15
|
-
import {
|
|
16
|
-
import { omit } from "../../util/index.js";
|
|
17
|
-
import { useId } from "../../util/hooks/index.js";
|
|
15
|
+
import { useControllableState, useId } from "../../util/hooks/index.js";
|
|
18
16
|
import { useMergeRefs } from "../../util/hooks/useMergeRefs.js";
|
|
19
|
-
import {
|
|
20
|
-
import {
|
|
21
|
-
import { DatePickerInput } from "../
|
|
22
|
-
import {
|
|
23
|
-
import {
|
|
24
|
-
import
|
|
25
|
-
import
|
|
26
|
-
import DropdownCaption from "./parts/DropdownCaption.js";
|
|
27
|
-
import { HeadRow } from "./parts/HeadRow.js";
|
|
28
|
-
import Row from "./parts/Row.js";
|
|
29
|
-
import TableHead from "./parts/TableHead.js";
|
|
30
|
-
import WeekNumber from "./parts/WeekNumber.js";
|
|
17
|
+
import { useI18n } from "../../util/i18n/i18n.hooks.js";
|
|
18
|
+
import { DateDialog } from "../Date.Dialog.js";
|
|
19
|
+
import { DateInputContextProvider, DatePickerInput } from "../Date.Input.js";
|
|
20
|
+
import { DateTranslationContextProvider, getTranslations, } from "../Date.locale.js";
|
|
21
|
+
import { isDateRange } from "../Date.typeutils.js";
|
|
22
|
+
import { ReactDayPicker } from "./parts/DatePicker.RDP.js";
|
|
23
|
+
import DatePickerStandalone from "./parts/DatePicker.Standalone.js";
|
|
31
24
|
/**
|
|
32
25
|
* A component that allows users to select a date from a calendar.
|
|
33
26
|
*
|
|
@@ -51,62 +44,53 @@ import WeekNumber from "./parts/WeekNumber.js";
|
|
|
51
44
|
* ```
|
|
52
45
|
*/
|
|
53
46
|
export const DatePicker = forwardRef((_a, ref) => {
|
|
54
|
-
var
|
|
55
|
-
var { children, locale, translations, dropdownCaption, disabled = [], disableWeekends = false, showWeekNumber = false, selected, id, defaultSelected, className, wrapperClassName, open: _open, onClose, onOpenToggle, strategy, onWeekNumberClick } = _a, rest = __rest(_a, ["children", "locale", "translations", "dropdownCaption", "disabled", "disableWeekends", "showWeekNumber", "selected", "id", "defaultSelected", "className", "wrapperClassName", "open", "onClose", "onOpenToggle", "strategy", "onWeekNumberClick"]);
|
|
47
|
+
var { children, locale, translations, selected, id, defaultSelected, wrapperClassName, open: _open, onClose, onOpenToggle, strategy, mode } = _a, rest = __rest(_a, ["children", "locale", "translations", "selected", "id", "defaultSelected", "wrapperClassName", "open", "onClose", "onOpenToggle", "strategy", "mode"]);
|
|
56
48
|
const translate = useI18n("DatePicker", translations, getTranslations(locale));
|
|
57
|
-
const langProviderLocale = useDateLocale();
|
|
58
49
|
const ariaId = useId(id);
|
|
59
|
-
const [open, setOpen] =
|
|
50
|
+
const [open, setOpen] = useControllableState({
|
|
51
|
+
defaultValue: false,
|
|
52
|
+
value: _open,
|
|
53
|
+
});
|
|
60
54
|
/* We use state here to insure that anchor is defined if open is true on initial render */
|
|
61
55
|
const [wrapperRef, setWrapperRef] = useState(null);
|
|
62
56
|
const mergedRef = useMergeRefs(setWrapperRef, ref);
|
|
63
|
-
const [
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
}, className: cl("navds-date", className), classNames: {
|
|
86
|
-
vhidden: "navds-sr-only",
|
|
87
|
-
}, disabled: (day) => {
|
|
88
|
-
return (disableWeekends && isWeekend(day)) || isMatch(day, disabled);
|
|
89
|
-
}, weekStartsOn: 1, initialFocus: false, modifiers: {
|
|
90
|
-
weekend: (day) => disableWeekends && isWeekend(day),
|
|
91
|
-
}, modifiersClassNames: {
|
|
92
|
-
weekend: "rdp-day__weekend",
|
|
93
|
-
}, showWeekNumber: showWeekNumber, onWeekNumberClick: mode === "multiple" ? onWeekNumberClick : undefined, fixedWeeks: true, showOutsideDays: true }, omit(rest, ["onSelect"]))));
|
|
57
|
+
const [value, setValue] = useControllableState({
|
|
58
|
+
defaultValue: defaultSelected,
|
|
59
|
+
value: selected,
|
|
60
|
+
onChange: (newValue) => {
|
|
61
|
+
var _a;
|
|
62
|
+
let closeDialog = false;
|
|
63
|
+
if (mode === "single" && newValue) {
|
|
64
|
+
closeDialog = true;
|
|
65
|
+
}
|
|
66
|
+
else if (isDateRange(newValue) && newValue.from && newValue.to) {
|
|
67
|
+
closeDialog = true;
|
|
68
|
+
if (isSameDay(newValue.from, newValue.to)) {
|
|
69
|
+
closeDialog = false;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (closeDialog) {
|
|
73
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
74
|
+
setOpen(false);
|
|
75
|
+
}
|
|
76
|
+
(_a = rest === null || rest === void 0 ? void 0 : rest.onSelect) === null || _a === void 0 ? void 0 : _a.call(rest, newValue);
|
|
77
|
+
},
|
|
78
|
+
});
|
|
94
79
|
return (React.createElement(DateTranslationContextProvider, { translate: translate },
|
|
95
|
-
React.createElement(
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
onOpenToggle === null || onOpenToggle === void 0 ? void 0 : onOpenToggle();
|
|
100
|
-
},
|
|
101
|
-
ariaId,
|
|
102
|
-
defined: true,
|
|
103
|
-
} },
|
|
80
|
+
React.createElement(DateInputContextProvider, { open: open, onOpen: () => {
|
|
81
|
+
setOpen((x) => !x);
|
|
82
|
+
onOpenToggle === null || onOpenToggle === void 0 ? void 0 : onOpenToggle();
|
|
83
|
+
}, ariaId: ariaId, defined: true },
|
|
104
84
|
React.createElement("div", { ref: mergedRef, className: cl("navds-date__wrapper", wrapperClassName) },
|
|
105
85
|
children,
|
|
106
|
-
React.createElement(
|
|
86
|
+
React.createElement(DateDialog, { open: open, anchor: wrapperRef, onClose: () => {
|
|
87
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
88
|
+
open && setOpen(false);
|
|
89
|
+
}, locale: locale, translate: translate, variant: mode !== null && mode !== void 0 ? mode : "single", popoverProps: {
|
|
107
90
|
id: ariaId,
|
|
108
91
|
strategy,
|
|
109
|
-
} },
|
|
92
|
+
} },
|
|
93
|
+
React.createElement(ReactDayPicker, Object.assign({}, rest, { locale: locale, handleSelect: setValue, selected: value, mode: mode })))))));
|
|
110
94
|
});
|
|
111
95
|
DatePicker.Standalone = DatePickerStandalone;
|
|
112
96
|
DatePicker.Input = DatePickerInput;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DatePicker.js","sourceRoot":"","sources":["../../../src/date/datepicker/DatePicker.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,MAAM,CAAC;AACtB,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"DatePicker.js","sourceRoot":"","sources":["../../../src/date/datepicker/DatePicker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { CalendarWeek, Matcher, PropsBase } from "react-day-picker";
|
|
2
|
+
import { ComponentTranslation } from "../../util/i18n/i18n.types.js";
|
|
3
|
+
import { DateRange } from "../Date.typeutils.js";
|
|
4
|
+
export type SingleMode = {
|
|
5
|
+
mode?: "single";
|
|
6
|
+
onSelect?: (val?: Date) => void;
|
|
7
|
+
selected?: Date;
|
|
8
|
+
defaultSelected?: Date;
|
|
9
|
+
onWeekNumberClick?: never;
|
|
10
|
+
};
|
|
11
|
+
export type MultipleMode = {
|
|
12
|
+
mode: "multiple";
|
|
13
|
+
onSelect?: (val?: Date[]) => void;
|
|
14
|
+
selected?: Date[];
|
|
15
|
+
defaultSelected?: Date[];
|
|
16
|
+
min?: number;
|
|
17
|
+
max?: number;
|
|
18
|
+
/**
|
|
19
|
+
* Allows selecting a week at a time. Only used with `mode` is set to "multiple".
|
|
20
|
+
* @param week Current week number
|
|
21
|
+
* @param days Dates in the week
|
|
22
|
+
*/
|
|
23
|
+
onWeekNumberClick?: (week: CalendarWeek["weekNumber"], days: Date[]) => void;
|
|
24
|
+
};
|
|
25
|
+
export type RangeMode = {
|
|
26
|
+
mode: "range";
|
|
27
|
+
onSelect?: (val?: DateRange) => void;
|
|
28
|
+
selected?: DateRange;
|
|
29
|
+
defaultSelected?: DateRange;
|
|
30
|
+
min?: number;
|
|
31
|
+
max?: number;
|
|
32
|
+
onWeekNumberClick?: never;
|
|
33
|
+
};
|
|
34
|
+
export type ConditionalModeProps = SingleMode | MultipleMode | RangeMode;
|
|
35
|
+
export interface DatePickerDefaultProps extends Omit<React.HTMLAttributes<HTMLDivElement>, "onSelect">, Pick<PropsBase, "month" | "onMonthChange" | "today" | "onDayClick" | "defaultMonth"> {
|
|
36
|
+
/**
|
|
37
|
+
* Element datepicker anchors to. Use <DatePicker.Input /> for built-in toggle, or make your own with the open/onClose props
|
|
38
|
+
*/
|
|
39
|
+
children?: React.ReactNode;
|
|
40
|
+
/**
|
|
41
|
+
* Classname for datepicker in popover
|
|
42
|
+
*/
|
|
43
|
+
className?: string;
|
|
44
|
+
/**
|
|
45
|
+
* Classname for wrapper
|
|
46
|
+
*/
|
|
47
|
+
wrapperClassName?: string;
|
|
48
|
+
/**
|
|
49
|
+
* Changes datepicker locale
|
|
50
|
+
* @default "nb" (norsk bokmål)
|
|
51
|
+
* @deprecated Use `<Provider />`-component
|
|
52
|
+
*/
|
|
53
|
+
locale?: "nb" | "nn" | "en";
|
|
54
|
+
/**
|
|
55
|
+
* i18n-API for customizing texts and labels.
|
|
56
|
+
*
|
|
57
|
+
* **NB: If you need to change the language, use [Provider](https://aksel.nav.no/komponenter/core/provider#84d7ea5ec517) instead.**
|
|
58
|
+
*/
|
|
59
|
+
translations?: ComponentTranslation<"DatePicker">;
|
|
60
|
+
/**
|
|
61
|
+
* The earliest day to start navigation.
|
|
62
|
+
*/
|
|
63
|
+
fromDate?: Date;
|
|
64
|
+
/**
|
|
65
|
+
* The latests day to end navigation.
|
|
66
|
+
*/
|
|
67
|
+
toDate?: Date;
|
|
68
|
+
/**
|
|
69
|
+
* Display dropdown for choosing the month and the year. Needs `fromDate` + `toDate` to work.
|
|
70
|
+
* @default false
|
|
71
|
+
*/
|
|
72
|
+
dropdownCaption?: boolean;
|
|
73
|
+
/**
|
|
74
|
+
* Apply the disabled modifier to the matching days.
|
|
75
|
+
* https://react-day-picker.js.org/api/type-aliases/Matcher
|
|
76
|
+
*/
|
|
77
|
+
disabled?: Matcher[];
|
|
78
|
+
/**
|
|
79
|
+
* Disable saturday and sunday.
|
|
80
|
+
* @default false
|
|
81
|
+
*/
|
|
82
|
+
disableWeekends?: boolean;
|
|
83
|
+
/**
|
|
84
|
+
* Shows week numbers in left-column. Use with caution, takes up valuable screenspace for small screens.
|
|
85
|
+
* @default false
|
|
86
|
+
*/
|
|
87
|
+
showWeekNumber?: boolean;
|
|
88
|
+
/**
|
|
89
|
+
* Open state for user-controlled state. Component controlled by default.
|
|
90
|
+
*/
|
|
91
|
+
open?: boolean;
|
|
92
|
+
/**
|
|
93
|
+
* onClose callback for user-controlled state.
|
|
94
|
+
*/
|
|
95
|
+
onClose?: () => void;
|
|
96
|
+
/**
|
|
97
|
+
* onOpenToggle callback for user-controlled state. Only called if `<DatePicker.Input />` is used.
|
|
98
|
+
*/
|
|
99
|
+
onOpenToggle?: () => void;
|
|
100
|
+
/**
|
|
101
|
+
* **Avoid using if possible!**
|
|
102
|
+
*
|
|
103
|
+
* Changes what CSS position property to use.
|
|
104
|
+
* You want to use "fixed" if parent wrapper has position relative, but you want popover to escape.
|
|
105
|
+
* @default See Popover
|
|
106
|
+
*/
|
|
107
|
+
strategy?: "absolute" | "fixed";
|
|
108
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DatePicker.types.js","sourceRoot":"","sources":["../../../src/date/datepicker/DatePicker.types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { DateInputProps } from "../../Date.Input.js";
|
|
3
|
+
import { DatePickerProps } from "../DatePicker.js";
|
|
4
|
+
export interface UseDatepickerOptions extends Pick<DatePickerProps, "locale" | "fromDate" | "toDate" | "today" | "toDate" | "fromDate" | "toDate" | "disabled" | "disableWeekends"> {
|
|
5
|
+
/**
|
|
6
|
+
* The initially selected Date
|
|
7
|
+
*/
|
|
8
|
+
defaultSelected?: Date;
|
|
9
|
+
/**
|
|
10
|
+
* Default shown month
|
|
11
|
+
*/
|
|
12
|
+
defaultMonth?: Date;
|
|
13
|
+
/**
|
|
14
|
+
* Make selection of Date required
|
|
15
|
+
*/
|
|
16
|
+
required?: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Callback for changed state
|
|
19
|
+
*/
|
|
20
|
+
onDateChange?: (val?: Date) => void;
|
|
21
|
+
/**
|
|
22
|
+
* Input-format
|
|
23
|
+
* @default "dd.MM.yyyy"
|
|
24
|
+
*/
|
|
25
|
+
inputFormat?: string;
|
|
26
|
+
/**
|
|
27
|
+
* validation-callback
|
|
28
|
+
*/
|
|
29
|
+
onValidate?: (val: DateValidationT) => void;
|
|
30
|
+
/**
|
|
31
|
+
* Allows input of with `yy` year format.
|
|
32
|
+
*
|
|
33
|
+
* Decision between 20th and 21st century is based on before(todays year - 80) ? 21st : 20th.
|
|
34
|
+
* e.g. In 2024 this equals to 1944 - 2043.
|
|
35
|
+
* @default true
|
|
36
|
+
*/
|
|
37
|
+
allowTwoDigitYear?: boolean;
|
|
38
|
+
}
|
|
39
|
+
interface UseDatepickerValue {
|
|
40
|
+
/**
|
|
41
|
+
* Use: <DatePicker {...datepickerProps}/>
|
|
42
|
+
*/
|
|
43
|
+
datepickerProps: DatePickerProps;
|
|
44
|
+
/**
|
|
45
|
+
* Use: <DatePicker.Input {...inputProps}/>
|
|
46
|
+
*/
|
|
47
|
+
inputProps: Pick<DateInputProps, "onChange" | "onFocus" | "onBlur" | "value"> & {
|
|
48
|
+
/**
|
|
49
|
+
* @private
|
|
50
|
+
*/
|
|
51
|
+
setAnchorRef: React.Dispatch<React.SetStateAction<HTMLButtonElement | null>>;
|
|
52
|
+
};
|
|
53
|
+
/**
|
|
54
|
+
* Resets all states (callback)
|
|
55
|
+
*/
|
|
56
|
+
reset: () => void;
|
|
57
|
+
/**
|
|
58
|
+
* Currently selected date
|
|
59
|
+
* Up to user to validate date
|
|
60
|
+
*/
|
|
61
|
+
selectedDay?: Date;
|
|
62
|
+
/**
|
|
63
|
+
* Manually override currently selected day
|
|
64
|
+
*/
|
|
65
|
+
setSelected: (date?: Date) => void;
|
|
66
|
+
}
|
|
67
|
+
export type DateValidationT = {
|
|
68
|
+
isDisabled: boolean;
|
|
69
|
+
isWeekend: boolean;
|
|
70
|
+
isEmpty: boolean;
|
|
71
|
+
isInvalid: boolean;
|
|
72
|
+
isValidDate: boolean;
|
|
73
|
+
isBefore: boolean;
|
|
74
|
+
isAfter: boolean;
|
|
75
|
+
};
|
|
76
|
+
/**
|
|
77
|
+
*
|
|
78
|
+
* @see 🏷️ {@link UseDatepickerOptions}
|
|
79
|
+
* @see 🏷️ {@link UseDatepickerValue}
|
|
80
|
+
* @see 🏷️ {@link DateValidationT}
|
|
81
|
+
* @example
|
|
82
|
+
* const { datepickerProps, inputProps } = useDatepicker({
|
|
83
|
+
* fromDate: new Date("Aug 23 2019"),
|
|
84
|
+
* toDate: new Date("Feb 23 2024"),
|
|
85
|
+
* onDateChange: console.log,
|
|
86
|
+
* onValidate: console.log,
|
|
87
|
+
* });
|
|
88
|
+
*/
|
|
89
|
+
export declare const useDatepicker: (opt?: UseDatepickerOptions) => UseDatepickerValue;
|
|
90
|
+
export {};
|