@navikt/ds-react 7.12.2 → 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/form/confirmation-panel/ConfirmationPanel.js +6 -1
- package/cjs/form/confirmation-panel/ConfirmationPanel.js.map +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/theme/Theme.d.ts +7 -1
- package/cjs/theme/Theme.js +24 -2
- package/cjs/theme/Theme.js.map +1 -1
- package/cjs/theme/index.d.ts +1 -1
- package/cjs/theme/index.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/form/confirmation-panel/ConfirmationPanel.js +6 -1
- package/esm/form/confirmation-panel/ConfirmationPanel.js.map +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/theme/Theme.d.ts +7 -1
- package/esm/theme/Theme.js +22 -2
- package/esm/theme/Theme.js.map +1 -1
- package/esm/theme/index.d.ts +1 -1
- package/esm/theme/index.js.map +1 -1
- package/esm/tooltip/Tooltip.js +2 -5
- package/esm/tooltip/Tooltip.js.map +1 -1
- package/package.json +7 -8
- 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/form/confirmation-panel/ConfirmationPanel.tsx +7 -0
- package/src/modal/Modal.tsx +3 -3
- package/src/popover/Popover.tsx +4 -4
- package/src/react-css.d.ts +4 -0
- package/src/theme/RenameCSS.test.ts +80 -0
- package/src/theme/Theme.tsx +45 -8
- package/src/theme/index.ts +1 -1
- 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 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-options.js","sourceRoot":"","sources":["../../../src/date/date-utils/dropdown-options.ts"],"names":[],"mappings":";;AAeA,0CA4BC;AAGD,wCAgCC;AA9ED,uCAYkB;AAElB,iDAAiD;AACjD,SAAgB,eAAe,CAC7B,YAAkB,EAClB,QAA0B,EAC1B,MAAwB,EACxB,MAAc;IAQd,MAAM,MAAM,GAAG,IAAA,8BAAmB,EAAC;QACjC,KAAK,EAAE,IAAA,sBAAW,EAAC,YAAY,CAAC;QAChC,GAAG,EAAE,IAAA,oBAAS,EAAC,YAAY,CAAC;KAC7B,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACnC,MAAM,KAAK,GAAG,IAAA,iBAAM,EAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,IAAA,mBAAQ,EAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,QAAQ,GACZ,CAAC,QAAQ,IAAI,KAAK,GAAG,IAAA,uBAAY,EAAC,QAAQ,CAAC,CAAC;YAC5C,CAAC,MAAM,IAAI,KAAK,GAAG,IAAA,uBAAY,EAAC,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,SAAgB,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,IAAA,sBAAW,EAAC,QAAQ,CAAC,CAAC;IAC3C,MAAM,WAAW,GAAG,IAAA,oBAAS,EAAC,MAAM,CAAC,CAAC;IACtC,MAAM,KAAK,GAAW,EAAE,CAAC;IAEzB,IAAI,IAAI,GAAG,YAAY,CAAC;IACxB,OAAO,IAAA,mBAAQ,EAAC,IAAI,EAAE,WAAW,CAAC,IAAI,IAAA,qBAAU,EAAC,IAAI,EAAE,WAAW,CAAC,EAAE,CAAC;QACpE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,IAAI,GAAG,IAAA,mBAAQ,EAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACzB,MAAM,KAAK,GAAG,IAAA,iBAAM,EAAC,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,OAAO;YACL,KAAK,EAAE,IAAA,kBAAO,EAAC,KAAK,CAAC;YACrB,KAAK;YACL,QAAQ,EAAE,KAAK;SAChB,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatDateForInput = void 0;
|
|
4
|
+
const date_fns_1 = require("date-fns");
|
|
5
|
+
const parse_date_1 = require("./parse-date");
|
|
6
|
+
const formatDateForInput = (date, locale, type, inputFormat) => {
|
|
7
|
+
const INPUT_DATE_STRING_FORMAT = inputFormat !== null && inputFormat !== void 0 ? inputFormat : (type === "date"
|
|
8
|
+
? parse_date_1.INPUT_DATE_STRING_FORMAT_DATE
|
|
9
|
+
: parse_date_1.INPUT_DATE_STRING_FORMAT_MONTH);
|
|
10
|
+
return (0, date_fns_1.format)(date, INPUT_DATE_STRING_FORMAT, { locale });
|
|
11
|
+
};
|
|
12
|
+
exports.formatDateForInput = formatDateForInput;
|
|
13
|
+
//# 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,uCAA0C;AAC1C,6CAGsB;AAEf,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,0CAA6B;QAC/B,CAAC,CAAC,2CAA8B,CAAC,CAAC;IACtC,OAAO,IAAA,iBAAM,EAAC,IAAI,EAAE,wBAAwB,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;AAC5D,CAAC,CAAC;AAZW,QAAA,kBAAkB,sBAY7B"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { formatDateForInput } from "./format-date";
|
|
2
|
+
export { INPUT_DATE_STRING_FORMAT_DATE, INPUT_DATE_STRING_FORMAT_MONTH, parseDate, } from "./parse-date";
|
|
3
|
+
export { disableDate } from "./dates-disabled";
|
|
4
|
+
export { dateIsInCurrentMonth, isValidDate, isDateOutsideRange, } from "./check-dates";
|
|
5
|
+
export { isMatch, isDateInRange } from "./is-match";
|
|
6
|
+
export { clampDisplayMonth, clampDisplayYear } from "./clamp-dates";
|
|
7
|
+
export { getMonthOptions, getYearOptions } from "./dropdown-options";
|
|
8
|
+
export { calendarRange } from "./calendar-range";
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calendarRange = exports.getYearOptions = exports.getMonthOptions = exports.clampDisplayYear = exports.clampDisplayMonth = exports.isDateInRange = exports.isMatch = exports.isDateOutsideRange = exports.isValidDate = exports.dateIsInCurrentMonth = exports.disableDate = exports.parseDate = exports.INPUT_DATE_STRING_FORMAT_MONTH = exports.INPUT_DATE_STRING_FORMAT_DATE = exports.formatDateForInput = void 0;
|
|
4
|
+
var format_date_1 = require("./format-date");
|
|
5
|
+
Object.defineProperty(exports, "formatDateForInput", { enumerable: true, get: function () { return format_date_1.formatDateForInput; } });
|
|
6
|
+
var parse_date_1 = require("./parse-date");
|
|
7
|
+
Object.defineProperty(exports, "INPUT_DATE_STRING_FORMAT_DATE", { enumerable: true, get: function () { return parse_date_1.INPUT_DATE_STRING_FORMAT_DATE; } });
|
|
8
|
+
Object.defineProperty(exports, "INPUT_DATE_STRING_FORMAT_MONTH", { enumerable: true, get: function () { return parse_date_1.INPUT_DATE_STRING_FORMAT_MONTH; } });
|
|
9
|
+
Object.defineProperty(exports, "parseDate", { enumerable: true, get: function () { return parse_date_1.parseDate; } });
|
|
10
|
+
var dates_disabled_1 = require("./dates-disabled");
|
|
11
|
+
Object.defineProperty(exports, "disableDate", { enumerable: true, get: function () { return dates_disabled_1.disableDate; } });
|
|
12
|
+
var check_dates_1 = require("./check-dates");
|
|
13
|
+
Object.defineProperty(exports, "dateIsInCurrentMonth", { enumerable: true, get: function () { return check_dates_1.dateIsInCurrentMonth; } });
|
|
14
|
+
Object.defineProperty(exports, "isValidDate", { enumerable: true, get: function () { return check_dates_1.isValidDate; } });
|
|
15
|
+
Object.defineProperty(exports, "isDateOutsideRange", { enumerable: true, get: function () { return check_dates_1.isDateOutsideRange; } });
|
|
16
|
+
var is_match_1 = require("./is-match");
|
|
17
|
+
Object.defineProperty(exports, "isMatch", { enumerable: true, get: function () { return is_match_1.isMatch; } });
|
|
18
|
+
Object.defineProperty(exports, "isDateInRange", { enumerable: true, get: function () { return is_match_1.isDateInRange; } });
|
|
19
|
+
var clamp_dates_1 = require("./clamp-dates");
|
|
20
|
+
Object.defineProperty(exports, "clampDisplayMonth", { enumerable: true, get: function () { return clamp_dates_1.clampDisplayMonth; } });
|
|
21
|
+
Object.defineProperty(exports, "clampDisplayYear", { enumerable: true, get: function () { return clamp_dates_1.clampDisplayYear; } });
|
|
22
|
+
var dropdown_options_1 = require("./dropdown-options");
|
|
23
|
+
Object.defineProperty(exports, "getMonthOptions", { enumerable: true, get: function () { return dropdown_options_1.getMonthOptions; } });
|
|
24
|
+
Object.defineProperty(exports, "getYearOptions", { enumerable: true, get: function () { return dropdown_options_1.getYearOptions; } });
|
|
25
|
+
var calendar_range_1 = require("./calendar-range");
|
|
26
|
+
Object.defineProperty(exports, "calendarRange", { enumerable: true, get: function () { return calendar_range_1.calendarRange; } });
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date/date-utils/index.ts"],"names":[],"mappings":";;;AAAA,6CAAmD;AAA1C,iHAAA,kBAAkB,OAAA;AAC3B,2CAIsB;AAHpB,2HAAA,6BAA6B,OAAA;AAC7B,4HAAA,8BAA8B,OAAA;AAC9B,uGAAA,SAAS,OAAA;AAEX,mDAA+C;AAAtC,6GAAA,WAAW,OAAA;AACpB,6CAIuB;AAHrB,mHAAA,oBAAoB,OAAA;AACpB,0GAAA,WAAW,OAAA;AACX,iHAAA,kBAAkB,OAAA;AAEpB,uCAAoD;AAA3C,mGAAA,OAAO,OAAA;AAAE,yGAAA,aAAa,OAAA;AAC/B,6CAAoE;AAA3D,gHAAA,iBAAiB,OAAA;AAAE,+GAAA,gBAAgB,OAAA;AAC5C,uDAAqE;AAA5D,mHAAA,eAAe,OAAA;AAAE,kHAAA,cAAc,OAAA;AACxC,mDAAiD;AAAxC,+GAAA,aAAa,OAAA"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isMatch = isMatch;
|
|
4
|
+
exports.isDateInRange = isDateInRange;
|
|
5
|
+
const date_fns_1 = require("date-fns");
|
|
6
|
+
const Date_typeutils_1 = require("../Date.typeutils");
|
|
7
|
+
function isDateType(value) {
|
|
8
|
+
return (0, date_fns_1.isDate)(value);
|
|
9
|
+
}
|
|
10
|
+
function isArrayOfDates(value) {
|
|
11
|
+
return Array.isArray(value) && value.every(date_fns_1.isDate);
|
|
12
|
+
}
|
|
13
|
+
function isMatch(day, matchers) {
|
|
14
|
+
return matchers.some((matcher) => {
|
|
15
|
+
if (isDateType(matcher)) {
|
|
16
|
+
return (0, date_fns_1.isSameMonth)(day, matcher);
|
|
17
|
+
}
|
|
18
|
+
if (isArrayOfDates(matcher)) {
|
|
19
|
+
return matcher.some((matcherDay) => {
|
|
20
|
+
return (0, date_fns_1.isSameMonth)(matcherDay, day);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
if ((0, Date_typeutils_1.isDateRange)(matcher)) {
|
|
24
|
+
return isDateInRange(day, matcher);
|
|
25
|
+
}
|
|
26
|
+
if ((0, Date_typeutils_1.isDateAfterType)(matcher)) {
|
|
27
|
+
return ((0, date_fns_1.isSameMonth)(day, matcher.after) ||
|
|
28
|
+
(0, date_fns_1.differenceInCalendarDays)(day, matcher.after) > 0);
|
|
29
|
+
}
|
|
30
|
+
if ((0, Date_typeutils_1.isDateBeforeType)(matcher)) {
|
|
31
|
+
return ((0, date_fns_1.isSameMonth)(day, matcher.before) ||
|
|
32
|
+
(0, date_fns_1.differenceInCalendarDays)(matcher.before, day) > 0);
|
|
33
|
+
}
|
|
34
|
+
if (typeof matcher === "function") {
|
|
35
|
+
return matcher(day);
|
|
36
|
+
}
|
|
37
|
+
return false;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
function isDateInRange(date, range) {
|
|
41
|
+
let { from, to } = range;
|
|
42
|
+
if (!from) {
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
if (!to && (0, date_fns_1.isSameDay)(from, date)) {
|
|
46
|
+
return true;
|
|
47
|
+
}
|
|
48
|
+
if (!to) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
51
|
+
const isToBeforeFrom = (0, date_fns_1.differenceInCalendarDays)(to, from) < 0;
|
|
52
|
+
if (to && isToBeforeFrom) {
|
|
53
|
+
[from, to] = [to, from];
|
|
54
|
+
}
|
|
55
|
+
if ((0, date_fns_1.isSameMonth)(from, date) || (0, date_fns_1.isSameMonth)(to, date)) {
|
|
56
|
+
return true;
|
|
57
|
+
}
|
|
58
|
+
return ((0, date_fns_1.differenceInCalendarDays)(date, from) >= 0 &&
|
|
59
|
+
(0, date_fns_1.differenceInCalendarDays)(to, date) >= 0);
|
|
60
|
+
}
|
|
61
|
+
//# 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,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.parseDate = exports.INPUT_DATE_STRING_FORMAT_MONTH = exports.INPUT_DATE_STRING_FORMAT_DATE = void 0;
|
|
4
|
+
const date_fns_1 = require("date-fns");
|
|
5
|
+
const check_dates_1 = require("./check-dates");
|
|
6
|
+
exports.INPUT_DATE_STRING_FORMAT_DATE = "dd.MM.yyyy";
|
|
7
|
+
exports.INPUT_DATE_STRING_FORMAT_MONTH = "MMMM yyyy";
|
|
8
|
+
const ALLOWED_INPUT_FORMATS_DATE = [
|
|
9
|
+
exports.INPUT_DATE_STRING_FORMAT_DATE,
|
|
10
|
+
"ddMMyyyy",
|
|
11
|
+
"dd/MM/yyyy",
|
|
12
|
+
"dd-MM-yyyy",
|
|
13
|
+
];
|
|
14
|
+
const ALLOWED_INPUT_FORMATS_MONTH = [
|
|
15
|
+
"M/yyyy",
|
|
16
|
+
"MM/yyyy",
|
|
17
|
+
"M-yyyy",
|
|
18
|
+
"MM-yyyy",
|
|
19
|
+
"MM.yyyy",
|
|
20
|
+
"MMyyyy",
|
|
21
|
+
exports.INPUT_DATE_STRING_FORMAT_MONTH,
|
|
22
|
+
...ALLOWED_INPUT_FORMATS_DATE,
|
|
23
|
+
];
|
|
24
|
+
const parseDate = (date, today, locale, type, allowTwoDigitYear) => {
|
|
25
|
+
let parsed;
|
|
26
|
+
const ALLOWED_FORMATS = type === "date" ? ALLOWED_INPUT_FORMATS_DATE : ALLOWED_INPUT_FORMATS_MONTH;
|
|
27
|
+
if (allowTwoDigitYear) {
|
|
28
|
+
for (const format of ALLOWED_FORMATS) {
|
|
29
|
+
parsed = (0, date_fns_1.parse)(date, format, today, { locale });
|
|
30
|
+
if ((0, check_dates_1.isValidDate)(parsed) &&
|
|
31
|
+
!isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
32
|
+
return parsed;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
for (const format of [
|
|
36
|
+
...ALLOWED_FORMATS.map((x) => x.replace("yyyy", "yy")),
|
|
37
|
+
]) {
|
|
38
|
+
parsed = (0, date_fns_1.parse)(date, format, today, { locale });
|
|
39
|
+
if ((0, check_dates_1.isValidDate)(parsed) &&
|
|
40
|
+
isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
41
|
+
const convertedDate = assignCenturyToDate(date, format, today, locale);
|
|
42
|
+
if ((0, check_dates_1.isValidDate)(new Date(convertedDate))) {
|
|
43
|
+
return new Date(convertedDate);
|
|
44
|
+
}
|
|
45
|
+
return new Date("Invalid date");
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return new Date("Invalid date");
|
|
49
|
+
}
|
|
50
|
+
for (const format of ALLOWED_FORMATS) {
|
|
51
|
+
parsed = (0, date_fns_1.parse)(date, format, today, { locale });
|
|
52
|
+
if ((0, check_dates_1.isValidDate)(parsed) &&
|
|
53
|
+
!isTwoDigitYear(date, today, locale, ALLOWED_FORMATS)) {
|
|
54
|
+
return parsed;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return new Date("Invalid date");
|
|
58
|
+
};
|
|
59
|
+
exports.parseDate = parseDate;
|
|
60
|
+
function isTwoDigitYear(dateString, today, locale, formats) {
|
|
61
|
+
let parsed;
|
|
62
|
+
const newFormat = formats.map((x) => x.replace("yyyy", "yy"));
|
|
63
|
+
for (const format of newFormat) {
|
|
64
|
+
parsed = (0, date_fns_1.parse)(dateString, format, today, { locale });
|
|
65
|
+
if ((0, check_dates_1.isValidDate)(parsed)) {
|
|
66
|
+
return true;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
function assignCenturyToDate(dateStr, format, today, locale) {
|
|
72
|
+
const date20Century = (0, date_fns_1.parse)(appendCenturyToTwoYearDigitDateString(dateStr, "19"), format.replace("yy", "yyyy"), today, { locale });
|
|
73
|
+
const date21Century = (0, date_fns_1.parse)(appendCenturyToTwoYearDigitDateString(dateStr, "20"), format.replace("yy", "yyyy"), today, { locale });
|
|
74
|
+
if ((0, check_dates_1.isValidDate)(date20Century) && (0, check_dates_1.isValidDate)(date21Century)) {
|
|
75
|
+
return (0, date_fns_1.isBefore)(date20Century, (0, date_fns_1.sub)(new Date(), {
|
|
76
|
+
years: 80,
|
|
77
|
+
}))
|
|
78
|
+
? date21Century
|
|
79
|
+
: date20Century;
|
|
80
|
+
}
|
|
81
|
+
return new Date("Invalid date");
|
|
82
|
+
}
|
|
83
|
+
function appendCenturyToTwoYearDigitDateString(dateString, century) {
|
|
84
|
+
const twoDigitYear = dateString.slice(-2);
|
|
85
|
+
return `${dateString.slice(0, dateString.length - 2)}${century}${twoDigitYear}`;
|
|
86
|
+
}
|
|
87
|
+
//# 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";
|
|
3
|
+
import { ConditionalModeProps, DatePickerDefaultProps } from "./DatePicker.types";
|
|
4
|
+
import DatePickerStandalone from "./parts/DatePicker.Standalone";
|
|
5
5
|
export type DatePickerProps = DatePickerDefaultProps & ConditionalModeProps;
|
|
6
6
|
interface DatePickerComponent extends React.ForwardRefExoticComponent<DatePickerProps> {
|
|
7
7
|
/**
|
|
@@ -41,22 +41,15 @@ exports.DatePicker = void 0;
|
|
|
41
41
|
const clsx_1 = __importDefault(require("clsx"));
|
|
42
42
|
const date_fns_1 = require("date-fns");
|
|
43
43
|
const react_1 = __importStar(require("react"));
|
|
44
|
-
const react_day_picker_1 = require("react-day-picker");
|
|
45
|
-
const util_1 = require("../../util");
|
|
46
44
|
const hooks_1 = require("../../util/hooks");
|
|
47
45
|
const useMergeRefs_1 = require("../../util/hooks/useMergeRefs");
|
|
48
46
|
const i18n_hooks_1 = require("../../util/i18n/i18n.hooks");
|
|
49
|
-
const
|
|
50
|
-
const
|
|
51
|
-
const
|
|
52
|
-
const
|
|
53
|
-
const
|
|
54
|
-
const
|
|
55
|
-
const DropdownCaption_1 = __importDefault(require("./parts/DropdownCaption"));
|
|
56
|
-
const HeadRow_1 = require("./parts/HeadRow");
|
|
57
|
-
const Row_1 = __importDefault(require("./parts/Row"));
|
|
58
|
-
const TableHead_1 = __importDefault(require("./parts/TableHead"));
|
|
59
|
-
const WeekNumber_1 = __importDefault(require("./parts/WeekNumber"));
|
|
47
|
+
const Date_Dialog_1 = require("../Date.Dialog");
|
|
48
|
+
const Date_Input_1 = require("../Date.Input");
|
|
49
|
+
const Date_locale_1 = require("../Date.locale");
|
|
50
|
+
const Date_typeutils_1 = require("../Date.typeutils");
|
|
51
|
+
const DatePicker_RDP_1 = require("./parts/DatePicker.RDP");
|
|
52
|
+
const DatePicker_Standalone_1 = __importDefault(require("./parts/DatePicker.Standalone"));
|
|
60
53
|
/**
|
|
61
54
|
* A component that allows users to select a date from a calendar.
|
|
62
55
|
*
|
|
@@ -80,64 +73,55 @@ const WeekNumber_1 = __importDefault(require("./parts/WeekNumber"));
|
|
|
80
73
|
* ```
|
|
81
74
|
*/
|
|
82
75
|
exports.DatePicker = (0, react_1.forwardRef)((_a, ref) => {
|
|
83
|
-
var
|
|
84
|
-
|
|
85
|
-
const translate = (0, i18n_hooks_1.useI18n)("DatePicker", translations, (0, utils_1.getTranslations)(locale));
|
|
86
|
-
const langProviderLocale = (0, i18n_hooks_1.useDateLocale)();
|
|
76
|
+
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"]);
|
|
77
|
+
const translate = (0, i18n_hooks_1.useI18n)("DatePicker", translations, (0, Date_locale_1.getTranslations)(locale));
|
|
87
78
|
const ariaId = (0, hooks_1.useId)(id);
|
|
88
|
-
const [open, setOpen] = (0,
|
|
79
|
+
const [open, setOpen] = (0, hooks_1.useControllableState)({
|
|
80
|
+
defaultValue: false,
|
|
81
|
+
value: _open,
|
|
82
|
+
});
|
|
89
83
|
/* We use state here to insure that anchor is defined if open is true on initial render */
|
|
90
84
|
const [wrapperRef, setWrapperRef] = (0, react_1.useState)(null);
|
|
91
85
|
const mergedRef = (0, useMergeRefs_1.useMergeRefs)(setWrapperRef, ref);
|
|
92
|
-
const [
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
weekend: (day) => disableWeekends && (0, date_fns_1.isWeekend)(day),
|
|
120
|
-
}, modifiersClassNames: {
|
|
121
|
-
weekend: "rdp-day__weekend",
|
|
122
|
-
}, showWeekNumber: showWeekNumber, onWeekNumberClick: mode === "multiple" ? onWeekNumberClick : undefined, fixedWeeks: true, showOutsideDays: true }, (0, util_1.omit)(rest, ["onSelect"]))));
|
|
123
|
-
return (react_1.default.createElement(context_1.DateTranslationContextProvider, { translate: translate },
|
|
124
|
-
react_1.default.createElement(context_1.DateInputContext.Provider, { value: {
|
|
125
|
-
open: _open !== null && _open !== void 0 ? _open : open,
|
|
126
|
-
onOpen: () => {
|
|
127
|
-
setOpen((x) => !x);
|
|
128
|
-
onOpenToggle === null || onOpenToggle === void 0 ? void 0 : onOpenToggle();
|
|
129
|
-
},
|
|
130
|
-
ariaId,
|
|
131
|
-
defined: true,
|
|
132
|
-
} },
|
|
86
|
+
const [value, setValue] = (0, hooks_1.useControllableState)({
|
|
87
|
+
defaultValue: defaultSelected,
|
|
88
|
+
value: selected,
|
|
89
|
+
onChange: (newValue) => {
|
|
90
|
+
var _a;
|
|
91
|
+
let closeDialog = false;
|
|
92
|
+
if (mode === "single" && newValue) {
|
|
93
|
+
closeDialog = true;
|
|
94
|
+
}
|
|
95
|
+
else if ((0, Date_typeutils_1.isDateRange)(newValue) && newValue.from && newValue.to) {
|
|
96
|
+
closeDialog = true;
|
|
97
|
+
if ((0, date_fns_1.isSameDay)(newValue.from, newValue.to)) {
|
|
98
|
+
closeDialog = false;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
if (closeDialog) {
|
|
102
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
103
|
+
setOpen(false);
|
|
104
|
+
}
|
|
105
|
+
(_a = rest === null || rest === void 0 ? void 0 : rest.onSelect) === null || _a === void 0 ? void 0 : _a.call(rest, newValue);
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
return (react_1.default.createElement(Date_locale_1.DateTranslationContextProvider, { translate: translate },
|
|
109
|
+
react_1.default.createElement(Date_Input_1.DateInputContextProvider, { open: open, onOpen: () => {
|
|
110
|
+
setOpen((x) => !x);
|
|
111
|
+
onOpenToggle === null || onOpenToggle === void 0 ? void 0 : onOpenToggle();
|
|
112
|
+
}, ariaId: ariaId, defined: true },
|
|
133
113
|
react_1.default.createElement("div", { ref: mergedRef, className: (0, clsx_1.default)("navds-date__wrapper", wrapperClassName) },
|
|
134
114
|
children,
|
|
135
|
-
react_1.default.createElement(
|
|
115
|
+
react_1.default.createElement(Date_Dialog_1.DateDialog, { open: open, anchor: wrapperRef, onClose: () => {
|
|
116
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
117
|
+
open && setOpen(false);
|
|
118
|
+
}, locale: locale, translate: translate, variant: mode !== null && mode !== void 0 ? mode : "single", popoverProps: {
|
|
136
119
|
id: ariaId,
|
|
137
120
|
strategy,
|
|
138
|
-
} },
|
|
121
|
+
} },
|
|
122
|
+
react_1.default.createElement(DatePicker_RDP_1.ReactDayPicker, Object.assign({}, rest, { locale: locale, handleSelect: setValue, selected: value, mode: mode })))))));
|
|
139
123
|
});
|
|
140
|
-
exports.DatePicker.Standalone =
|
|
141
|
-
exports.DatePicker.Input =
|
|
124
|
+
exports.DatePicker.Standalone = DatePicker_Standalone_1.default;
|
|
125
|
+
exports.DatePicker.Input = Date_Input_1.DatePickerInput;
|
|
142
126
|
exports.default = exports.DatePicker;
|
|
143
127
|
//# sourceMappingURL=DatePicker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DatePicker.js","sourceRoot":"","sources":["../../../src/date/datepicker/DatePicker.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,gDAAsB;AACtB,uCAAqC;AACrC,+CAAoD;
|
|
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";
|
|
3
|
+
import { DateRange } from "../Date.typeutils";
|
|
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";
|
|
3
|
+
import { DatePickerProps } from "../DatePicker";
|
|
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 {};
|