@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.
Files changed (291) hide show
  1. package/cjs/date/Date.Dialog.d.ts +18 -0
  2. package/cjs/date/Date.Dialog.js +67 -0
  3. package/cjs/date/Date.Dialog.js.map +1 -0
  4. package/cjs/date/Date.Input.d.ts +50 -0
  5. package/cjs/date/Date.Input.js +96 -0
  6. package/cjs/date/Date.Input.js.map +1 -0
  7. package/cjs/date/Date.locale.d.ts +44 -0
  8. package/cjs/date/Date.locale.js +57 -0
  9. package/cjs/date/Date.locale.js.map +1 -0
  10. package/cjs/date/Date.typeutils.d.ts +14 -0
  11. package/cjs/date/Date.typeutils.js +15 -0
  12. package/cjs/date/Date.typeutils.js.map +1 -0
  13. package/cjs/date/date-utils/calendar-range.d.ts +11 -0
  14. package/cjs/date/date-utils/calendar-range.js +30 -0
  15. package/cjs/date/date-utils/calendar-range.js.map +1 -0
  16. package/cjs/date/date-utils/check-dates.d.ts +8 -0
  17. package/cjs/date/date-utils/check-dates.js +20 -0
  18. package/cjs/date/date-utils/check-dates.js.map +1 -0
  19. package/cjs/date/date-utils/clamp-dates.d.ts +19 -0
  20. package/cjs/date/date-utils/clamp-dates.js +41 -0
  21. package/cjs/date/date-utils/clamp-dates.js.map +1 -0
  22. package/cjs/date/date-utils/dates-disabled.d.ts +1 -0
  23. package/cjs/date/date-utils/dates-disabled.js +29 -0
  24. package/cjs/date/date-utils/dates-disabled.js.map +1 -0
  25. package/cjs/date/date-utils/dropdown-options.d.ts +13 -0
  26. package/cjs/date/date-utils/dropdown-options.js +45 -0
  27. package/cjs/date/date-utils/dropdown-options.js.map +1 -0
  28. package/cjs/date/date-utils/format-date.d.ts +2 -0
  29. package/cjs/date/date-utils/format-date.js +13 -0
  30. package/cjs/date/date-utils/format-date.js.map +1 -0
  31. package/cjs/date/date-utils/index.d.ts +8 -0
  32. package/cjs/date/date-utils/index.js +27 -0
  33. package/cjs/date/date-utils/index.js.map +1 -0
  34. package/cjs/date/date-utils/is-match.d.ts +3 -0
  35. package/cjs/date/date-utils/is-match.js +61 -0
  36. package/cjs/date/date-utils/is-match.js.map +1 -0
  37. package/cjs/date/date-utils/parse-date.d.ts +4 -0
  38. package/cjs/date/date-utils/parse-date.js +87 -0
  39. package/cjs/date/date-utils/parse-date.js.map +1 -0
  40. package/cjs/date/datepicker/DatePicker.d.ts +3 -3
  41. package/cjs/date/datepicker/DatePicker.js +47 -63
  42. package/cjs/date/datepicker/DatePicker.js.map +1 -1
  43. package/cjs/date/datepicker/DatePicker.types.d.ts +108 -0
  44. package/cjs/date/datepicker/DatePicker.types.js +3 -0
  45. package/cjs/date/datepicker/DatePicker.types.js.map +1 -0
  46. package/cjs/date/datepicker/hooks/useDatepicker.d.ts +90 -0
  47. package/cjs/date/datepicker/hooks/useDatepicker.js +164 -0
  48. package/cjs/date/datepicker/hooks/useDatepicker.js.map +1 -0
  49. package/cjs/date/datepicker/hooks/useRangeDatepicker.d.ts +76 -0
  50. package/cjs/date/datepicker/hooks/useRangeDatepicker.js +322 -0
  51. package/cjs/date/datepicker/hooks/useRangeDatepicker.js.map +1 -0
  52. package/cjs/date/datepicker/index.d.ts +4 -3
  53. package/cjs/date/datepicker/index.js +8 -7
  54. package/cjs/date/datepicker/index.js.map +1 -1
  55. package/cjs/date/datepicker/parts/DatePicker.DayButton.d.ts +9 -0
  56. package/cjs/date/datepicker/parts/DatePicker.DayButton.js +70 -0
  57. package/cjs/date/datepicker/parts/DatePicker.DayButton.js.map +1 -0
  58. package/cjs/date/datepicker/parts/DatePicker.Months.d.ts +11 -0
  59. package/cjs/date/datepicker/parts/DatePicker.Months.js +84 -0
  60. package/cjs/date/datepicker/parts/DatePicker.Months.js.map +1 -0
  61. package/cjs/date/datepicker/parts/DatePicker.RDP.d.ts +15 -0
  62. package/cjs/date/datepicker/parts/DatePicker.RDP.js +103 -0
  63. package/cjs/date/datepicker/parts/DatePicker.RDP.js.map +1 -0
  64. package/cjs/date/datepicker/parts/DatePicker.Standalone.d.ts +18 -0
  65. package/cjs/date/datepicker/parts/DatePicker.Standalone.js +60 -0
  66. package/cjs/date/datepicker/parts/DatePicker.Standalone.js.map +1 -0
  67. package/cjs/date/datepicker/parts/DatePicker.WeekNumber.d.ts +9 -0
  68. package/cjs/date/datepicker/parts/DatePicker.WeekNumber.js +64 -0
  69. package/cjs/date/datepicker/parts/DatePicker.WeekNumber.js.map +1 -0
  70. package/cjs/date/datepicker/parts/DatePicker.WeekRow.d.ts +8 -0
  71. package/cjs/date/datepicker/parts/DatePicker.WeekRow.js +28 -0
  72. package/cjs/date/datepicker/parts/DatePicker.WeekRow.js.map +1 -0
  73. package/cjs/date/monthpicker/MonthPicker.context.d.ts +21 -0
  74. package/cjs/date/monthpicker/MonthPicker.context.js +48 -0
  75. package/cjs/date/monthpicker/MonthPicker.context.js.map +1 -0
  76. package/cjs/date/monthpicker/MonthPicker.d.ts +3 -3
  77. package/cjs/date/monthpicker/MonthPicker.js +34 -43
  78. package/cjs/date/monthpicker/MonthPicker.js.map +1 -1
  79. package/cjs/date/monthpicker/MonthPicker.types.d.ts +86 -0
  80. package/cjs/date/monthpicker/MonthPicker.types.js +3 -0
  81. package/cjs/date/monthpicker/MonthPicker.types.js.map +1 -0
  82. package/cjs/date/monthpicker/MonthPicker.util.d.ts +2 -0
  83. package/cjs/date/monthpicker/MonthPicker.util.js +156 -0
  84. package/cjs/date/monthpicker/MonthPicker.util.js.map +1 -0
  85. package/cjs/date/monthpicker/hooks/useMonthPicker.d.ts +85 -0
  86. package/cjs/date/monthpicker/hooks/useMonthPicker.js +179 -0
  87. package/cjs/date/monthpicker/hooks/useMonthPicker.js.map +1 -0
  88. package/cjs/date/monthpicker/index.d.ts +4 -4
  89. package/cjs/date/monthpicker/index.js +6 -6
  90. package/cjs/date/monthpicker/index.js.map +1 -1
  91. package/cjs/date/monthpicker/parts/MonthPicker.Button.d.ts +11 -0
  92. package/cjs/date/monthpicker/parts/MonthPicker.Button.js +82 -0
  93. package/cjs/date/monthpicker/parts/MonthPicker.Button.js.map +1 -0
  94. package/cjs/date/monthpicker/parts/MonthPicker.Caption.d.ts +3 -0
  95. package/cjs/date/monthpicker/parts/MonthPicker.Caption.js +52 -0
  96. package/cjs/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -0
  97. package/cjs/date/monthpicker/parts/MonthPicker.Standalone.d.ts +10 -0
  98. package/cjs/date/monthpicker/parts/MonthPicker.Standalone.js +51 -0
  99. package/cjs/date/monthpicker/parts/MonthPicker.Standalone.js.map +1 -0
  100. package/cjs/date/monthpicker/parts/MonthPicker.Table.d.ts +3 -0
  101. package/cjs/date/monthpicker/parts/MonthPicker.Table.js +79 -0
  102. package/cjs/date/monthpicker/parts/MonthPicker.Table.js.map +1 -0
  103. package/cjs/form/combobox/Combobox.d.ts +1 -1
  104. package/cjs/form/combobox/Input/InputController.d.ts +1 -1
  105. package/cjs/modal/Modal.js +2 -2
  106. package/cjs/modal/Modal.js.map +1 -1
  107. package/cjs/popover/Popover.js +3 -3
  108. package/cjs/popover/Popover.js.map +1 -1
  109. package/cjs/tooltip/Tooltip.js +2 -5
  110. package/cjs/tooltip/Tooltip.js.map +1 -1
  111. package/esm/date/Date.Dialog.d.ts +18 -0
  112. package/esm/date/Date.Dialog.js +38 -0
  113. package/esm/date/Date.Dialog.js.map +1 -0
  114. package/esm/date/Date.Input.d.ts +50 -0
  115. package/esm/date/Date.Input.js +66 -0
  116. package/esm/date/Date.Input.js.map +1 -0
  117. package/esm/date/Date.locale.d.ts +44 -0
  118. package/esm/date/Date.locale.js +47 -0
  119. package/esm/date/Date.locale.js.map +1 -0
  120. package/esm/date/Date.typeutils.d.ts +14 -0
  121. package/esm/date/Date.typeutils.js +10 -0
  122. package/esm/date/Date.typeutils.js.map +1 -0
  123. package/esm/date/date-utils/calendar-range.d.ts +11 -0
  124. package/esm/date/date-utils/calendar-range.js +27 -0
  125. package/esm/date/date-utils/calendar-range.js.map +1 -0
  126. package/esm/date/date-utils/check-dates.d.ts +8 -0
  127. package/esm/date/date-utils/check-dates.js +14 -0
  128. package/esm/date/date-utils/check-dates.js.map +1 -0
  129. package/esm/date/date-utils/clamp-dates.d.ts +19 -0
  130. package/esm/date/date-utils/clamp-dates.js +37 -0
  131. package/esm/date/date-utils/clamp-dates.js.map +1 -0
  132. package/esm/date/date-utils/dates-disabled.d.ts +1 -0
  133. package/esm/date/date-utils/dates-disabled.js +25 -0
  134. package/esm/date/date-utils/dates-disabled.js.map +1 -0
  135. package/esm/date/date-utils/dropdown-options.d.ts +13 -0
  136. package/esm/date/date-utils/dropdown-options.js +41 -0
  137. package/esm/date/date-utils/dropdown-options.js.map +1 -0
  138. package/esm/date/date-utils/format-date.d.ts +2 -0
  139. package/esm/date/date-utils/format-date.js +9 -0
  140. package/esm/date/date-utils/format-date.js.map +1 -0
  141. package/esm/date/date-utils/index.d.ts +8 -0
  142. package/esm/date/date-utils/index.js +9 -0
  143. package/esm/date/date-utils/index.js.map +1 -0
  144. package/esm/date/date-utils/is-match.d.ts +3 -0
  145. package/esm/date/date-utils/is-match.js +57 -0
  146. package/esm/date/date-utils/is-match.js.map +1 -0
  147. package/esm/date/date-utils/parse-date.d.ts +4 -0
  148. package/esm/date/date-utils/parse-date.js +83 -0
  149. package/esm/date/date-utils/parse-date.js.map +1 -0
  150. package/esm/date/datepicker/DatePicker.d.ts +3 -3
  151. package/esm/date/datepicker/DatePicker.js +46 -62
  152. package/esm/date/datepicker/DatePicker.js.map +1 -1
  153. package/esm/date/datepicker/DatePicker.types.d.ts +108 -0
  154. package/esm/date/datepicker/DatePicker.types.js +2 -0
  155. package/esm/date/datepicker/DatePicker.types.js.map +1 -0
  156. package/esm/date/datepicker/hooks/useDatepicker.d.ts +90 -0
  157. package/esm/date/datepicker/hooks/useDatepicker.js +160 -0
  158. package/esm/date/datepicker/hooks/useDatepicker.js.map +1 -0
  159. package/esm/date/datepicker/hooks/useRangeDatepicker.d.ts +76 -0
  160. package/esm/date/datepicker/hooks/useRangeDatepicker.js +318 -0
  161. package/esm/date/datepicker/hooks/useRangeDatepicker.js.map +1 -0
  162. package/esm/date/datepicker/index.d.ts +4 -3
  163. package/esm/date/datepicker/index.js +4 -3
  164. package/esm/date/datepicker/index.js.map +1 -1
  165. package/esm/date/datepicker/parts/DatePicker.DayButton.d.ts +9 -0
  166. package/esm/date/datepicker/parts/DatePicker.DayButton.js +41 -0
  167. package/esm/date/datepicker/parts/DatePicker.DayButton.js.map +1 -0
  168. package/esm/date/datepicker/parts/DatePicker.Months.d.ts +11 -0
  169. package/esm/date/datepicker/parts/DatePicker.Months.js +58 -0
  170. package/esm/date/datepicker/parts/DatePicker.Months.js.map +1 -0
  171. package/esm/date/datepicker/parts/DatePicker.RDP.d.ts +15 -0
  172. package/esm/date/datepicker/parts/DatePicker.RDP.js +74 -0
  173. package/esm/date/datepicker/parts/DatePicker.RDP.js.map +1 -0
  174. package/esm/date/datepicker/parts/DatePicker.Standalone.d.ts +18 -0
  175. package/esm/date/datepicker/parts/DatePicker.Standalone.js +31 -0
  176. package/esm/date/datepicker/parts/DatePicker.Standalone.js.map +1 -0
  177. package/esm/date/datepicker/parts/DatePicker.WeekNumber.d.ts +9 -0
  178. package/esm/date/datepicker/parts/DatePicker.WeekNumber.js +35 -0
  179. package/esm/date/datepicker/parts/DatePicker.WeekNumber.js.map +1 -0
  180. package/esm/date/datepicker/parts/DatePicker.WeekRow.d.ts +8 -0
  181. package/esm/date/datepicker/parts/DatePicker.WeekRow.js +22 -0
  182. package/esm/date/datepicker/parts/DatePicker.WeekRow.js.map +1 -0
  183. package/esm/date/monthpicker/MonthPicker.context.d.ts +21 -0
  184. package/esm/date/monthpicker/MonthPicker.context.js +41 -0
  185. package/esm/date/monthpicker/MonthPicker.context.js.map +1 -0
  186. package/esm/date/monthpicker/MonthPicker.d.ts +3 -3
  187. package/esm/date/monthpicker/MonthPicker.js +31 -40
  188. package/esm/date/monthpicker/MonthPicker.js.map +1 -1
  189. package/esm/date/monthpicker/MonthPicker.types.d.ts +86 -0
  190. package/esm/date/monthpicker/MonthPicker.types.js +2 -0
  191. package/esm/date/monthpicker/MonthPicker.types.js.map +1 -0
  192. package/esm/date/monthpicker/MonthPicker.util.d.ts +2 -0
  193. package/esm/date/monthpicker/MonthPicker.util.js +152 -0
  194. package/esm/date/monthpicker/MonthPicker.util.js.map +1 -0
  195. package/esm/date/monthpicker/hooks/useMonthPicker.d.ts +85 -0
  196. package/esm/date/monthpicker/hooks/useMonthPicker.js +175 -0
  197. package/esm/date/monthpicker/hooks/useMonthPicker.js.map +1 -0
  198. package/esm/date/monthpicker/index.d.ts +4 -4
  199. package/esm/date/monthpicker/index.js +3 -3
  200. package/esm/date/monthpicker/index.js.map +1 -1
  201. package/esm/date/monthpicker/parts/MonthPicker.Button.d.ts +11 -0
  202. package/esm/date/monthpicker/parts/MonthPicker.Button.js +52 -0
  203. package/esm/date/monthpicker/parts/MonthPicker.Button.js.map +1 -0
  204. package/esm/date/monthpicker/parts/MonthPicker.Caption.d.ts +3 -0
  205. package/esm/date/monthpicker/parts/MonthPicker.Caption.js +46 -0
  206. package/esm/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -0
  207. package/esm/date/monthpicker/parts/MonthPicker.Standalone.d.ts +10 -0
  208. package/esm/date/monthpicker/parts/MonthPicker.Standalone.js +22 -0
  209. package/esm/date/monthpicker/parts/MonthPicker.Standalone.js.map +1 -0
  210. package/esm/date/monthpicker/parts/MonthPicker.Table.d.ts +3 -0
  211. package/esm/date/monthpicker/parts/MonthPicker.Table.js +50 -0
  212. package/esm/date/monthpicker/parts/MonthPicker.Table.js.map +1 -0
  213. package/esm/form/combobox/Combobox.d.ts +1 -1
  214. package/esm/form/combobox/Input/InputController.d.ts +1 -1
  215. package/esm/modal/Modal.js +3 -3
  216. package/esm/modal/Modal.js.map +1 -1
  217. package/esm/popover/Popover.js +4 -4
  218. package/esm/popover/Popover.js.map +1 -1
  219. package/esm/tooltip/Tooltip.js +2 -5
  220. package/esm/tooltip/Tooltip.js.map +1 -1
  221. package/package.json +6 -7
  222. package/src/date/{parts/DateWrapper.tsx → Date.Dialog.tsx} +12 -9
  223. package/src/date/{parts/DateInput.tsx → Date.Input.tsx} +30 -5
  224. package/src/date/{utils/locale.ts → Date.locale.ts} +11 -2
  225. package/src/date/Date.typeutils.ts +32 -0
  226. package/src/date/date-utils/calendar-range.test.ts +54 -0
  227. package/src/date/date-utils/calendar-range.ts +46 -0
  228. package/src/date/date-utils/check-dates.test.ts +49 -0
  229. package/src/date/date-utils/check-dates.ts +28 -0
  230. package/src/date/date-utils/clamp-dates.test.ts +156 -0
  231. package/src/date/date-utils/clamp-dates.ts +63 -0
  232. package/src/date/{utils/__tests__ → date-utils}/dates-disabled.test.ts +1 -1
  233. package/src/date/{utils → date-utils}/dates-disabled.ts +1 -2
  234. package/src/date/date-utils/dropdown-options.test.ts +143 -0
  235. package/src/date/date-utils/dropdown-options.ts +79 -0
  236. package/src/date/{utils/__tests__ → date-utils}/format-dates.test.ts +2 -2
  237. package/src/date/date-utils/index.ts +16 -0
  238. package/src/date/{utils/__tests__ → date-utils}/is-match.test.ts +1 -1
  239. package/src/date/{utils → date-utils}/is-match.ts +2 -11
  240. package/src/date/{utils/__tests__ → date-utils}/parse-dates.test.ts +2 -1
  241. package/src/date/datepicker/DatePicker.tsx +67 -92
  242. package/src/date/datepicker/{types.ts → DatePicker.types.ts} +10 -4
  243. package/src/date/{hooks → datepicker/hooks}/useDatepicker.tsx +12 -13
  244. package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.test.tsx +1 -1
  245. package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.tsx +19 -19
  246. package/src/date/datepicker/index.ts +4 -5
  247. package/src/date/datepicker/parts/DatePicker.DayButton.tsx +56 -0
  248. package/src/date/datepicker/parts/DatePicker.Months.tsx +149 -0
  249. package/src/date/datepicker/parts/DatePicker.RDP.tsx +170 -0
  250. package/src/date/datepicker/parts/DatePicker.Standalone.tsx +93 -0
  251. package/src/date/datepicker/parts/DatePicker.WeekNumber.tsx +86 -0
  252. package/src/date/datepicker/parts/{WeekRow.tsx → DatePicker.WeekRow.tsx} +20 -21
  253. package/src/date/monthpicker/MonthPicker.context.tsx +103 -0
  254. package/src/date/monthpicker/MonthPicker.tsx +63 -68
  255. package/src/date/monthpicker/{types.ts → MonthPicker.types.ts} +1 -1
  256. package/src/date/{utils/navigation.ts → monthpicker/MonthPicker.util.ts} +2 -1
  257. package/src/date/{hooks → monthpicker/hooks}/useMonthPicker.tsx +14 -13
  258. package/src/date/monthpicker/index.ts +4 -4
  259. package/src/date/monthpicker/{MonthButton.tsx → parts/MonthPicker.Button.tsx} +21 -10
  260. package/src/date/monthpicker/{MonthCaption.tsx → parts/MonthPicker.Caption.tsx} +20 -21
  261. package/src/date/monthpicker/parts/MonthPicker.Standalone.tsx +86 -0
  262. package/src/date/monthpicker/{MonthSelector.tsx → parts/MonthPicker.Table.tsx} +7 -7
  263. package/src/modal/Modal.tsx +3 -3
  264. package/src/popover/Popover.tsx +4 -4
  265. package/src/tooltip/Tooltip.tsx +2 -6
  266. package/src/date/context/index.ts +0 -9
  267. package/src/date/context/useDateInputContext.tsx +0 -34
  268. package/src/date/context/useDateTranslationContext.ts +0 -9
  269. package/src/date/context/useSharedMonthContext.tsx +0 -68
  270. package/src/date/datepicker/DatePickerStandalone.tsx +0 -136
  271. package/src/date/datepicker/datepicker.test.tsx +0 -28
  272. package/src/date/datepicker/parts/Caption.tsx +0 -54
  273. package/src/date/datepicker/parts/DayButton.tsx +0 -32
  274. package/src/date/datepicker/parts/DropdownCaption.tsx +0 -110
  275. package/src/date/datepicker/parts/HeadRow.tsx +0 -56
  276. package/src/date/datepicker/parts/Row.tsx +0 -48
  277. package/src/date/datepicker/parts/TableHead.tsx +0 -17
  278. package/src/date/datepicker/parts/WeekNumber.tsx +0 -75
  279. package/src/date/hooks/index.ts +0 -6
  280. package/src/date/monthpicker/MonthPickerStandalone.tsx +0 -102
  281. package/src/date/utils/__tests__/check-dates.test.ts +0 -22
  282. package/src/date/utils/__tests__/get-dates.test.ts +0 -121
  283. package/src/date/utils/__tests__/get-initial-year.test.ts +0 -83
  284. package/src/date/utils/__tests__/get-month-weeks.test.ts +0 -116
  285. package/src/date/utils/check-dates.ts +0 -13
  286. package/src/date/utils/get-dates.ts +0 -60
  287. package/src/date/utils/get-initial-year.ts +0 -25
  288. package/src/date/utils/get-month-weeks.ts +0 -93
  289. package/src/date/utils/index.ts +0 -18
  290. /package/src/date/{utils → date-utils}/format-date.ts +0 -0
  291. /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,2 @@
1
+ import { Locale } from "date-fns";
2
+ export declare const formatDateForInput: (date: Date, locale: Locale, type: "date" | "month", inputFormat?: string) => string;
@@ -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,3 @@
1
+ import { DateRange, Matcher } from "../Date.typeutils";
2
+ export declare function isMatch(day: Date, matchers: Matcher[]): boolean;
3
+ export declare function isDateInRange(date: Date, range: DateRange): boolean;
@@ -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 "../parts/DateInput";
3
- import DatePickerStandalone from "./DatePickerStandalone";
4
- import { ConditionalModeProps, DatePickerDefaultProps } from "./types";
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 context_1 = require("../context");
50
- const DateInput_1 = require("../parts/DateInput");
51
- const DateWrapper_1 = require("../parts/DateWrapper");
52
- const utils_1 = require("../utils");
53
- const DatePickerStandalone_1 = __importDefault(require("./DatePickerStandalone"));
54
- const Caption_1 = __importDefault(require("./parts/Caption"));
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 _b;
84
- 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"]);
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, react_1.useState)(_open !== null && _open !== void 0 ? _open : false);
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 [selectedDates, setSelectedDates] = react_1.default.useState(defaultSelected);
93
- const mode = (_b = rest.mode) !== null && _b !== void 0 ? _b : "single";
94
- /**
95
- * @param newSelected Date | Date[] | DateRange | undefined
96
- */
97
- const handleSelect = (newSelected) => {
98
- var _a, _b, _c;
99
- setSelectedDates(newSelected);
100
- if (rest.mode === "single") {
101
- newSelected && ((_a = onClose === null || onClose === void 0 ? void 0 : onClose()) !== null && _a !== void 0 ? _a : setOpen(false));
102
- }
103
- else if (rest.mode === "range") {
104
- (newSelected === null || newSelected === void 0 ? void 0 : newSelected.from) && (newSelected === null || newSelected === void 0 ? void 0 : newSelected.to) && ((_b = onClose === null || onClose === void 0 ? void 0 : onClose()) !== null && _b !== void 0 ? _b : setOpen(false));
105
- }
106
- (_c = rest === null || rest === void 0 ? void 0 : rest.onSelect) === null || _c === void 0 ? void 0 : _c.call(rest, newSelected);
107
- };
108
- const DatePickerComponent = (react_1.default.createElement(react_day_picker_1.DayPicker, Object.assign({ locale: locale ? (0, utils_1.getLocaleFromString)(locale) : langProviderLocale, mode: mode, onSelect: handleSelect, selected: selected !== null && selected !== void 0 ? selected : selectedDates, components: {
109
- Caption: dropdownCaption ? DropdownCaption_1.default : Caption_1.default,
110
- Head: TableHead_1.default,
111
- HeadRow: HeadRow_1.HeadRow,
112
- WeekNumber: WeekNumber_1.default,
113
- Row: Row_1.default,
114
- }, className: (0, clsx_1.default)("navds-date", className), classNames: {
115
- vhidden: "navds-sr-only",
116
- }, disabled: (day) => {
117
- return (disableWeekends && (0, date_fns_1.isWeekend)(day)) || (0, react_day_picker_1.isMatch)(day, disabled);
118
- }, weekStartsOn: 1, initialFocus: false, modifiers: {
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(DateWrapper_1.DateWrapper, { open: _open !== null && _open !== void 0 ? _open : open, anchor: wrapperRef, onClose: () => { var _a; return (_a = onClose === null || onClose === void 0 ? void 0 : onClose()) !== null && _a !== void 0 ? _a : setOpen(false); }, locale: locale, translate: translate, variant: mode, popoverProps: {
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
- } }, DatePickerComponent)))));
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 = DatePickerStandalone_1.default;
141
- exports.DatePicker.Input = DateInput_1.DatePickerInput;
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":"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"}
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,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=DatePicker.types.js.map
@@ -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 {};