@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.
Files changed (310) 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/form/confirmation-panel/ConfirmationPanel.js +6 -1
  106. package/cjs/form/confirmation-panel/ConfirmationPanel.js.map +1 -1
  107. package/cjs/modal/Modal.js +2 -2
  108. package/cjs/modal/Modal.js.map +1 -1
  109. package/cjs/popover/Popover.js +3 -3
  110. package/cjs/popover/Popover.js.map +1 -1
  111. package/cjs/theme/Theme.d.ts +7 -1
  112. package/cjs/theme/Theme.js +24 -2
  113. package/cjs/theme/Theme.js.map +1 -1
  114. package/cjs/theme/index.d.ts +1 -1
  115. package/cjs/theme/index.js.map +1 -1
  116. package/cjs/tooltip/Tooltip.js +2 -5
  117. package/cjs/tooltip/Tooltip.js.map +1 -1
  118. package/esm/date/Date.Dialog.d.ts +18 -0
  119. package/esm/date/Date.Dialog.js +38 -0
  120. package/esm/date/Date.Dialog.js.map +1 -0
  121. package/esm/date/Date.Input.d.ts +50 -0
  122. package/esm/date/Date.Input.js +66 -0
  123. package/esm/date/Date.Input.js.map +1 -0
  124. package/esm/date/Date.locale.d.ts +44 -0
  125. package/esm/date/Date.locale.js +47 -0
  126. package/esm/date/Date.locale.js.map +1 -0
  127. package/esm/date/Date.typeutils.d.ts +14 -0
  128. package/esm/date/Date.typeutils.js +10 -0
  129. package/esm/date/Date.typeutils.js.map +1 -0
  130. package/esm/date/date-utils/calendar-range.d.ts +11 -0
  131. package/esm/date/date-utils/calendar-range.js +27 -0
  132. package/esm/date/date-utils/calendar-range.js.map +1 -0
  133. package/esm/date/date-utils/check-dates.d.ts +8 -0
  134. package/esm/date/date-utils/check-dates.js +14 -0
  135. package/esm/date/date-utils/check-dates.js.map +1 -0
  136. package/esm/date/date-utils/clamp-dates.d.ts +19 -0
  137. package/esm/date/date-utils/clamp-dates.js +37 -0
  138. package/esm/date/date-utils/clamp-dates.js.map +1 -0
  139. package/esm/date/date-utils/dates-disabled.d.ts +1 -0
  140. package/esm/date/date-utils/dates-disabled.js +25 -0
  141. package/esm/date/date-utils/dates-disabled.js.map +1 -0
  142. package/esm/date/date-utils/dropdown-options.d.ts +13 -0
  143. package/esm/date/date-utils/dropdown-options.js +41 -0
  144. package/esm/date/date-utils/dropdown-options.js.map +1 -0
  145. package/esm/date/date-utils/format-date.d.ts +2 -0
  146. package/esm/date/date-utils/format-date.js +9 -0
  147. package/esm/date/date-utils/format-date.js.map +1 -0
  148. package/esm/date/date-utils/index.d.ts +8 -0
  149. package/esm/date/date-utils/index.js +9 -0
  150. package/esm/date/date-utils/index.js.map +1 -0
  151. package/esm/date/date-utils/is-match.d.ts +3 -0
  152. package/esm/date/date-utils/is-match.js +57 -0
  153. package/esm/date/date-utils/is-match.js.map +1 -0
  154. package/esm/date/date-utils/parse-date.d.ts +4 -0
  155. package/esm/date/date-utils/parse-date.js +83 -0
  156. package/esm/date/date-utils/parse-date.js.map +1 -0
  157. package/esm/date/datepicker/DatePicker.d.ts +3 -3
  158. package/esm/date/datepicker/DatePicker.js +46 -62
  159. package/esm/date/datepicker/DatePicker.js.map +1 -1
  160. package/esm/date/datepicker/DatePicker.types.d.ts +108 -0
  161. package/esm/date/datepicker/DatePicker.types.js +2 -0
  162. package/esm/date/datepicker/DatePicker.types.js.map +1 -0
  163. package/esm/date/datepicker/hooks/useDatepicker.d.ts +90 -0
  164. package/esm/date/datepicker/hooks/useDatepicker.js +160 -0
  165. package/esm/date/datepicker/hooks/useDatepicker.js.map +1 -0
  166. package/esm/date/datepicker/hooks/useRangeDatepicker.d.ts +76 -0
  167. package/esm/date/datepicker/hooks/useRangeDatepicker.js +318 -0
  168. package/esm/date/datepicker/hooks/useRangeDatepicker.js.map +1 -0
  169. package/esm/date/datepicker/index.d.ts +4 -3
  170. package/esm/date/datepicker/index.js +4 -3
  171. package/esm/date/datepicker/index.js.map +1 -1
  172. package/esm/date/datepicker/parts/DatePicker.DayButton.d.ts +9 -0
  173. package/esm/date/datepicker/parts/DatePicker.DayButton.js +41 -0
  174. package/esm/date/datepicker/parts/DatePicker.DayButton.js.map +1 -0
  175. package/esm/date/datepicker/parts/DatePicker.Months.d.ts +11 -0
  176. package/esm/date/datepicker/parts/DatePicker.Months.js +58 -0
  177. package/esm/date/datepicker/parts/DatePicker.Months.js.map +1 -0
  178. package/esm/date/datepicker/parts/DatePicker.RDP.d.ts +15 -0
  179. package/esm/date/datepicker/parts/DatePicker.RDP.js +74 -0
  180. package/esm/date/datepicker/parts/DatePicker.RDP.js.map +1 -0
  181. package/esm/date/datepicker/parts/DatePicker.Standalone.d.ts +18 -0
  182. package/esm/date/datepicker/parts/DatePicker.Standalone.js +31 -0
  183. package/esm/date/datepicker/parts/DatePicker.Standalone.js.map +1 -0
  184. package/esm/date/datepicker/parts/DatePicker.WeekNumber.d.ts +9 -0
  185. package/esm/date/datepicker/parts/DatePicker.WeekNumber.js +35 -0
  186. package/esm/date/datepicker/parts/DatePicker.WeekNumber.js.map +1 -0
  187. package/esm/date/datepicker/parts/DatePicker.WeekRow.d.ts +8 -0
  188. package/esm/date/datepicker/parts/DatePicker.WeekRow.js +22 -0
  189. package/esm/date/datepicker/parts/DatePicker.WeekRow.js.map +1 -0
  190. package/esm/date/monthpicker/MonthPicker.context.d.ts +21 -0
  191. package/esm/date/monthpicker/MonthPicker.context.js +41 -0
  192. package/esm/date/monthpicker/MonthPicker.context.js.map +1 -0
  193. package/esm/date/monthpicker/MonthPicker.d.ts +3 -3
  194. package/esm/date/monthpicker/MonthPicker.js +31 -40
  195. package/esm/date/monthpicker/MonthPicker.js.map +1 -1
  196. package/esm/date/monthpicker/MonthPicker.types.d.ts +86 -0
  197. package/esm/date/monthpicker/MonthPicker.types.js +2 -0
  198. package/esm/date/monthpicker/MonthPicker.types.js.map +1 -0
  199. package/esm/date/monthpicker/MonthPicker.util.d.ts +2 -0
  200. package/esm/date/monthpicker/MonthPicker.util.js +152 -0
  201. package/esm/date/monthpicker/MonthPicker.util.js.map +1 -0
  202. package/esm/date/monthpicker/hooks/useMonthPicker.d.ts +85 -0
  203. package/esm/date/monthpicker/hooks/useMonthPicker.js +175 -0
  204. package/esm/date/monthpicker/hooks/useMonthPicker.js.map +1 -0
  205. package/esm/date/monthpicker/index.d.ts +4 -4
  206. package/esm/date/monthpicker/index.js +3 -3
  207. package/esm/date/monthpicker/index.js.map +1 -1
  208. package/esm/date/monthpicker/parts/MonthPicker.Button.d.ts +11 -0
  209. package/esm/date/monthpicker/parts/MonthPicker.Button.js +52 -0
  210. package/esm/date/monthpicker/parts/MonthPicker.Button.js.map +1 -0
  211. package/esm/date/monthpicker/parts/MonthPicker.Caption.d.ts +3 -0
  212. package/esm/date/monthpicker/parts/MonthPicker.Caption.js +46 -0
  213. package/esm/date/monthpicker/parts/MonthPicker.Caption.js.map +1 -0
  214. package/esm/date/monthpicker/parts/MonthPicker.Standalone.d.ts +10 -0
  215. package/esm/date/monthpicker/parts/MonthPicker.Standalone.js +22 -0
  216. package/esm/date/monthpicker/parts/MonthPicker.Standalone.js.map +1 -0
  217. package/esm/date/monthpicker/parts/MonthPicker.Table.d.ts +3 -0
  218. package/esm/date/monthpicker/parts/MonthPicker.Table.js +50 -0
  219. package/esm/date/monthpicker/parts/MonthPicker.Table.js.map +1 -0
  220. package/esm/form/combobox/Combobox.d.ts +1 -1
  221. package/esm/form/combobox/Input/InputController.d.ts +1 -1
  222. package/esm/form/confirmation-panel/ConfirmationPanel.js +6 -1
  223. package/esm/form/confirmation-panel/ConfirmationPanel.js.map +1 -1
  224. package/esm/modal/Modal.js +3 -3
  225. package/esm/modal/Modal.js.map +1 -1
  226. package/esm/popover/Popover.js +4 -4
  227. package/esm/popover/Popover.js.map +1 -1
  228. package/esm/theme/Theme.d.ts +7 -1
  229. package/esm/theme/Theme.js +22 -2
  230. package/esm/theme/Theme.js.map +1 -1
  231. package/esm/theme/index.d.ts +1 -1
  232. package/esm/theme/index.js.map +1 -1
  233. package/esm/tooltip/Tooltip.js +2 -5
  234. package/esm/tooltip/Tooltip.js.map +1 -1
  235. package/package.json +7 -8
  236. package/src/date/{parts/DateWrapper.tsx → Date.Dialog.tsx} +12 -9
  237. package/src/date/{parts/DateInput.tsx → Date.Input.tsx} +30 -5
  238. package/src/date/{utils/locale.ts → Date.locale.ts} +11 -2
  239. package/src/date/Date.typeutils.ts +32 -0
  240. package/src/date/date-utils/calendar-range.test.ts +54 -0
  241. package/src/date/date-utils/calendar-range.ts +46 -0
  242. package/src/date/date-utils/check-dates.test.ts +49 -0
  243. package/src/date/date-utils/check-dates.ts +28 -0
  244. package/src/date/date-utils/clamp-dates.test.ts +156 -0
  245. package/src/date/date-utils/clamp-dates.ts +63 -0
  246. package/src/date/{utils/__tests__ → date-utils}/dates-disabled.test.ts +1 -1
  247. package/src/date/{utils → date-utils}/dates-disabled.ts +1 -2
  248. package/src/date/date-utils/dropdown-options.test.ts +143 -0
  249. package/src/date/date-utils/dropdown-options.ts +79 -0
  250. package/src/date/{utils/__tests__ → date-utils}/format-dates.test.ts +2 -2
  251. package/src/date/date-utils/index.ts +16 -0
  252. package/src/date/{utils/__tests__ → date-utils}/is-match.test.ts +1 -1
  253. package/src/date/{utils → date-utils}/is-match.ts +2 -11
  254. package/src/date/{utils/__tests__ → date-utils}/parse-dates.test.ts +2 -1
  255. package/src/date/datepicker/DatePicker.tsx +67 -92
  256. package/src/date/datepicker/{types.ts → DatePicker.types.ts} +10 -4
  257. package/src/date/{hooks → datepicker/hooks}/useDatepicker.tsx +12 -13
  258. package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.test.tsx +1 -1
  259. package/src/date/{hooks → datepicker/hooks}/useRangeDatepicker.tsx +19 -19
  260. package/src/date/datepicker/index.ts +4 -5
  261. package/src/date/datepicker/parts/DatePicker.DayButton.tsx +56 -0
  262. package/src/date/datepicker/parts/DatePicker.Months.tsx +149 -0
  263. package/src/date/datepicker/parts/DatePicker.RDP.tsx +170 -0
  264. package/src/date/datepicker/parts/DatePicker.Standalone.tsx +93 -0
  265. package/src/date/datepicker/parts/DatePicker.WeekNumber.tsx +86 -0
  266. package/src/date/datepicker/parts/{WeekRow.tsx → DatePicker.WeekRow.tsx} +20 -21
  267. package/src/date/monthpicker/MonthPicker.context.tsx +103 -0
  268. package/src/date/monthpicker/MonthPicker.tsx +63 -68
  269. package/src/date/monthpicker/{types.ts → MonthPicker.types.ts} +1 -1
  270. package/src/date/{utils/navigation.ts → monthpicker/MonthPicker.util.ts} +2 -1
  271. package/src/date/{hooks → monthpicker/hooks}/useMonthPicker.tsx +14 -13
  272. package/src/date/monthpicker/index.ts +4 -4
  273. package/src/date/monthpicker/{MonthButton.tsx → parts/MonthPicker.Button.tsx} +21 -10
  274. package/src/date/monthpicker/{MonthCaption.tsx → parts/MonthPicker.Caption.tsx} +20 -21
  275. package/src/date/monthpicker/parts/MonthPicker.Standalone.tsx +86 -0
  276. package/src/date/monthpicker/{MonthSelector.tsx → parts/MonthPicker.Table.tsx} +7 -7
  277. package/src/form/confirmation-panel/ConfirmationPanel.tsx +7 -0
  278. package/src/modal/Modal.tsx +3 -3
  279. package/src/popover/Popover.tsx +4 -4
  280. package/src/react-css.d.ts +4 -0
  281. package/src/theme/RenameCSS.test.ts +80 -0
  282. package/src/theme/Theme.tsx +45 -8
  283. package/src/theme/index.ts +1 -1
  284. package/src/tooltip/Tooltip.tsx +2 -6
  285. package/src/date/context/index.ts +0 -9
  286. package/src/date/context/useDateInputContext.tsx +0 -34
  287. package/src/date/context/useDateTranslationContext.ts +0 -9
  288. package/src/date/context/useSharedMonthContext.tsx +0 -68
  289. package/src/date/datepicker/DatePickerStandalone.tsx +0 -136
  290. package/src/date/datepicker/datepicker.test.tsx +0 -28
  291. package/src/date/datepicker/parts/Caption.tsx +0 -54
  292. package/src/date/datepicker/parts/DayButton.tsx +0 -32
  293. package/src/date/datepicker/parts/DropdownCaption.tsx +0 -110
  294. package/src/date/datepicker/parts/HeadRow.tsx +0 -56
  295. package/src/date/datepicker/parts/Row.tsx +0 -48
  296. package/src/date/datepicker/parts/TableHead.tsx +0 -17
  297. package/src/date/datepicker/parts/WeekNumber.tsx +0 -75
  298. package/src/date/hooks/index.ts +0 -6
  299. package/src/date/monthpicker/MonthPickerStandalone.tsx +0 -102
  300. package/src/date/utils/__tests__/check-dates.test.ts +0 -22
  301. package/src/date/utils/__tests__/get-dates.test.ts +0 -121
  302. package/src/date/utils/__tests__/get-initial-year.test.ts +0 -83
  303. package/src/date/utils/__tests__/get-month-weeks.test.ts +0 -116
  304. package/src/date/utils/check-dates.ts +0 -13
  305. package/src/date/utils/get-dates.ts +0 -60
  306. package/src/date/utils/get-initial-year.ts +0 -25
  307. package/src/date/utils/get-month-weeks.ts +0 -93
  308. package/src/date/utils/index.ts +0 -18
  309. /package/src/date/{utils → date-utils}/format-date.ts +0 -0
  310. /package/src/date/{utils → date-utils}/parse-date.ts +0 -0
@@ -0,0 +1,85 @@
1
+ import React from "react";
2
+ import { DateInputProps } from "../../Date.Input.js";
3
+ import { MonthPickerProps } from "../MonthPicker.types.js";
4
+ export interface UseMonthPickerOptions extends Pick<MonthPickerProps, "locale" | "fromDate" | "toDate" | "disabled" | "defaultSelected"> {
5
+ /**
6
+ * Make Date-selection required
7
+ */
8
+ required?: boolean;
9
+ /**
10
+ * Callback for month-change
11
+ */
12
+ onMonthChange?: (date?: Date) => void;
13
+ /**
14
+ * Input-format
15
+ * @default "MMMM yyyy"
16
+ */
17
+ inputFormat?: string;
18
+ /**
19
+ * validation-callback
20
+ */
21
+ onValidate?: (val: MonthValidationT) => void;
22
+ /**
23
+ * Default shown year
24
+ */
25
+ defaultYear?: Date;
26
+ /**
27
+ * Allows input of with `yy` year format.
28
+ *
29
+ * Decision between 20th and 21st century is based on before(todays year - 80) ? 21st : 20th.
30
+ * In 2024 this equals to 1944 - 2043
31
+ * @default true
32
+ */
33
+ allowTwoDigitYear?: boolean;
34
+ }
35
+ interface UseMonthPickerValue {
36
+ /**
37
+ * Use: <MonthPicker {...monthpickerProps} />
38
+ */
39
+ monthpickerProps: MonthPickerProps;
40
+ /**
41
+ * Use: <MonthPicker.Input {...inputProps} />
42
+ */
43
+ inputProps: Pick<DateInputProps, "onChange" | "onFocus" | "value"> & {
44
+ /**
45
+ * @private
46
+ */
47
+ setAnchorRef: React.Dispatch<React.SetStateAction<HTMLButtonElement | null>>;
48
+ };
49
+ /**
50
+ * Currently selected Date
51
+ * Up to user to validate value and extract month
52
+ */
53
+ selectedMonth?: Date;
54
+ /**
55
+ * Manually set selected month if needed
56
+ */
57
+ setSelected: (date?: Date) => void;
58
+ /**
59
+ * Resets all states
60
+ */
61
+ reset: () => void;
62
+ }
63
+ export type MonthValidationT = {
64
+ isDisabled: boolean;
65
+ isEmpty: boolean;
66
+ isInvalid: boolean;
67
+ isValidMonth: boolean;
68
+ isBefore: boolean;
69
+ isAfter: boolean;
70
+ };
71
+ /**
72
+ *
73
+ * @see 🏷️ {@link UseMonthPickerOptions}
74
+ * @see 🏷️ {@link UseMonthPickerValue}
75
+ * @see 🏷️ {@link MonthValidationT}
76
+ * @example
77
+ * const { monthpickerProps, inputProps } = useMonthpicker({
78
+ * fromDate: new Date("Aug 23 2019"),
79
+ * toDate: new Date("Feb 23 2024"),
80
+ * onMonthChange: console.log,
81
+ * onValidate: console.log,
82
+ * });
83
+ */
84
+ export declare const useMonthpicker: (opt?: UseMonthPickerOptions) => UseMonthPickerValue;
85
+ export {};
@@ -0,0 +1,175 @@
1
+ import { useCallback, useMemo, useState } from "react";
2
+ import { dateMatchModifiers } from "react-day-picker";
3
+ import { useDateLocale } from "../../../util/i18n/i18n.hooks.js";
4
+ import { getLocaleFromString } from "../../Date.locale.js";
5
+ import { formatDateForInput, isValidDate, parseDate } from "../../date-utils/index.js";
6
+ const getValidationMessage = (val = {}) => (Object.assign({ isDisabled: false, isEmpty: false, isInvalid: false, isBefore: false, isAfter: false, isValidMonth: true }, val));
7
+ const getIsBefore = (opt) => opt.fromDate &&
8
+ opt.date &&
9
+ (opt.fromDate.getFullYear() > opt.date.getFullYear() ||
10
+ (opt.fromDate.getFullYear() === opt.date.getFullYear() &&
11
+ opt.fromDate.getMonth() > opt.date.getMonth()));
12
+ const getIsAfter = (opt) => opt.toDate &&
13
+ opt.date &&
14
+ (opt.toDate.getFullYear() < opt.date.getFullYear() ||
15
+ (opt.toDate.getFullYear() === opt.date.getFullYear() &&
16
+ opt.toDate.getMonth() < opt.date.getMonth()));
17
+ /**
18
+ *
19
+ * @see 🏷️ {@link UseMonthPickerOptions}
20
+ * @see 🏷️ {@link UseMonthPickerValue}
21
+ * @see 🏷️ {@link MonthValidationT}
22
+ * @example
23
+ * const { monthpickerProps, inputProps } = useMonthpicker({
24
+ * fromDate: new Date("Aug 23 2019"),
25
+ * toDate: new Date("Feb 23 2024"),
26
+ * onMonthChange: console.log,
27
+ * onValidate: console.log,
28
+ * });
29
+ */
30
+ export const useMonthpicker = (opt = {}) => {
31
+ var _a;
32
+ const { locale: _locale, defaultSelected: _defaultSelected, fromDate, toDate, disabled, required, onMonthChange, inputFormat, onValidate, defaultYear, allowTwoDigitYear = true, } = opt;
33
+ const [anchorRef, setAnchorRef] = useState(null);
34
+ const [defaultSelected, setDefaultSelected] = useState(_defaultSelected);
35
+ const today = useMemo(() => new Date(), []);
36
+ const localeFromProvider = useDateLocale();
37
+ const locale = _locale ? getLocaleFromString(_locale) : localeFromProvider;
38
+ // Initialize states
39
+ const [year, setYear] = useState((_a = defaultSelected !== null && defaultSelected !== void 0 ? defaultSelected : defaultYear) !== null && _a !== void 0 ? _a : today);
40
+ const [selectedMonth, setSelectedMonth] = useState(defaultSelected);
41
+ const [open, setOpen] = useState(false);
42
+ const defaultInputValue = defaultSelected
43
+ ? formatDateForInput(defaultSelected, locale, "month", inputFormat)
44
+ : "";
45
+ const [inputValue, setInputValue] = useState(defaultInputValue);
46
+ const handleOpen = useCallback((newOpen) => {
47
+ var _a, _b;
48
+ setOpen(newOpen);
49
+ newOpen &&
50
+ setYear((_b = (_a = selectedMonth !== null && selectedMonth !== void 0 ? selectedMonth : defaultSelected) !== null && _a !== void 0 ? _a : defaultYear) !== null && _b !== void 0 ? _b : today);
51
+ }, [defaultSelected, defaultYear, selectedMonth, today]);
52
+ const updateMonth = (date) => {
53
+ onMonthChange === null || onMonthChange === void 0 ? void 0 : onMonthChange(date);
54
+ setSelectedMonth(date);
55
+ };
56
+ const updateValidation = (val = {}) => onValidate === null || onValidate === void 0 ? void 0 : onValidate(getValidationMessage(val));
57
+ const reset = () => {
58
+ var _a;
59
+ updateMonth(defaultSelected);
60
+ setYear((_a = defaultSelected !== null && defaultSelected !== void 0 ? defaultSelected : defaultYear) !== null && _a !== void 0 ? _a : today);
61
+ setInputValue(defaultInputValue !== null && defaultInputValue !== void 0 ? defaultInputValue : "");
62
+ setDefaultSelected(_defaultSelected);
63
+ };
64
+ const setSelected = (date) => {
65
+ var _a;
66
+ updateMonth(date);
67
+ setYear((_a = date !== null && date !== void 0 ? date : defaultYear) !== null && _a !== void 0 ? _a : today);
68
+ setInputValue(date ? formatDateForInput(date, locale, "month", inputFormat) : "");
69
+ };
70
+ const handleFocus = (e) => {
71
+ var _a;
72
+ if (e.target.readOnly) {
73
+ return;
74
+ }
75
+ const day = parseDate(e.target.value, today, locale, "month", allowTwoDigitYear);
76
+ const isBefore = getIsBefore({ fromDate, date: day });
77
+ const isAfter = getIsAfter({ toDate, date: day });
78
+ if (isValidDate(day)) {
79
+ !isBefore && !isAfter && setYear(day);
80
+ setInputValue(formatDateForInput(day, locale, "month", inputFormat));
81
+ }
82
+ else {
83
+ setYear((_a = defaultSelected !== null && defaultSelected !== void 0 ? defaultSelected : defaultYear) !== null && _a !== void 0 ? _a : today);
84
+ }
85
+ };
86
+ const handleBlur = (e) => {
87
+ const day = parseDate(e.target.value, today, locale, "month", allowTwoDigitYear);
88
+ isValidDate(day) &&
89
+ setInputValue(formatDateForInput(day, locale, "month", inputFormat));
90
+ };
91
+ /* Only allow de-selecting if not required */
92
+ const handleMonthClick = (month) => {
93
+ if (!month && required) {
94
+ return;
95
+ }
96
+ if (month) {
97
+ handleOpen(false);
98
+ setYear(month);
99
+ anchorRef === null || anchorRef === void 0 ? void 0 : anchorRef.focus();
100
+ }
101
+ if (!month) {
102
+ updateMonth(undefined);
103
+ updateValidation({ isValidMonth: false, isEmpty: true });
104
+ setInputValue("");
105
+ setYear(defaultYear !== null && defaultYear !== void 0 ? defaultYear : today);
106
+ return;
107
+ }
108
+ updateMonth(month);
109
+ updateValidation();
110
+ setInputValue(month ? formatDateForInput(month, locale, "month", inputFormat) : "");
111
+ };
112
+ // When changing the input field, save its value in state and check if the
113
+ // string is a valid date. If it is a valid day, set it as selected and update
114
+ // the calendar’s month.
115
+ const handleChange = (e) => {
116
+ setInputValue(e.target.value);
117
+ const month = parseDate(e.target.value, today, locale, "month", allowTwoDigitYear);
118
+ const isBefore = getIsBefore({ fromDate, date: month });
119
+ const isAfter = getIsAfter({ toDate, date: month });
120
+ if (!isValidDate(month) ||
121
+ (disabled && dateMatchModifiers(month, disabled))) {
122
+ updateMonth(undefined);
123
+ updateValidation({
124
+ isInvalid: isValidDate(month),
125
+ isDisabled: disabled && dateMatchModifiers(month, disabled),
126
+ isValidMonth: false,
127
+ isEmpty: !e.target.value,
128
+ isBefore: isBefore !== null && isBefore !== void 0 ? isBefore : false,
129
+ isAfter: isAfter !== null && isAfter !== void 0 ? isAfter : false,
130
+ });
131
+ return;
132
+ }
133
+ if (isAfter ||
134
+ isBefore ||
135
+ (fromDate &&
136
+ toDate &&
137
+ !dateMatchModifiers(month, [{ from: fromDate, to: toDate }]))) {
138
+ updateMonth(undefined);
139
+ updateValidation({
140
+ isValidMonth: false,
141
+ isBefore: isBefore !== null && isBefore !== void 0 ? isBefore : false,
142
+ isAfter: isAfter !== null && isAfter !== void 0 ? isAfter : false,
143
+ });
144
+ return;
145
+ }
146
+ updateMonth(month);
147
+ updateValidation();
148
+ setYear(month);
149
+ };
150
+ const monthpickerProps = {
151
+ year,
152
+ onYearChange: (y) => setYear(y !== null && y !== void 0 ? y : today),
153
+ onMonthSelect: handleMonthClick,
154
+ selected: selectedMonth,
155
+ locale: _locale,
156
+ fromDate,
157
+ toDate,
158
+ open,
159
+ onOpenToggle: () => handleOpen(!open),
160
+ onClose: () => {
161
+ handleOpen(false);
162
+ anchorRef === null || anchorRef === void 0 ? void 0 : anchorRef.focus();
163
+ },
164
+ disabled,
165
+ };
166
+ const inputProps = {
167
+ onChange: handleChange,
168
+ onFocus: handleFocus,
169
+ onBlur: handleBlur,
170
+ value: inputValue,
171
+ setAnchorRef,
172
+ };
173
+ return { monthpickerProps, inputProps, reset, selectedMonth, setSelected };
174
+ };
175
+ //# sourceMappingURL=useMonthPicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMonthPicker.js","sourceRoot":"","sources":["../../../../src/date/monthpicker/hooks/useMonthPicker.tsx"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- export { useMonthpicker, type MonthValidationT } from "../hooks/index.js";
1
+ export { useMonthpicker, type MonthValidationT } from "./hooks/useMonthPicker.js";
2
2
  export { default as MonthPicker } from "./MonthPicker.js";
3
- export { type MonthPickerProps } from "./types.js";
4
- export { MonthPickerStandalone, type MonthPickerStandaloneProps, } from "./MonthPickerStandalone.js";
5
- export { MonthPickerInput } from "../parts/DateInput.js";
3
+ export { type MonthPickerProps } from "./MonthPicker.types.js";
4
+ export { MonthPickerStandalone, type MonthPickerStandaloneProps, } from "./parts/MonthPicker.Standalone.js";
5
+ export { MonthPickerInput } from "../Date.Input.js";
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- export { useMonthpicker } from "../hooks/index.js";
2
+ export { useMonthpicker } from "./hooks/useMonthPicker.js";
3
3
  export { default as MonthPicker } from "./MonthPicker.js";
4
- export { MonthPickerStandalone, } from "./MonthPickerStandalone.js";
5
- export { MonthPickerInput } from "../parts/DateInput.js";
4
+ export { MonthPickerStandalone, } from "./parts/MonthPicker.Standalone.js";
5
+ export { MonthPickerInput } from "../Date.Input.js";
6
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date/monthpicker/index.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,cAAc,EAAyB,MAAM,UAAU,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AAEvD,OAAO,EACL,qBAAqB,GAEtB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date/monthpicker/index.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,cAAc,EAAyB,MAAM,wBAAwB,CAAC;AAC/E,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AAEvD,OAAO,EACL,qBAAqB,GAEtB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ interface MonthType {
3
+ month: Date;
4
+ months: Date[];
5
+ focus: Date | undefined;
6
+ setFocus: (date?: Date) => void;
7
+ tabRoot?: Date;
8
+ setTabRoot: (date?: Date) => void;
9
+ }
10
+ export declare const MonthButton: ({ month, months, focus, setFocus, tabRoot, setTabRoot, }: MonthType) => React.JSX.Element;
11
+ export default MonthButton;
@@ -0,0 +1,52 @@
1
+ import cl from "clsx";
2
+ import { compareAsc, compareDesc, format, isSameMonth, setYear, } from "date-fns";
3
+ import React, { useEffect, useRef } from "react";
4
+ import { dateIsInCurrentMonth, isMatch } from "../../date-utils/index.js";
5
+ import { useMonthPickerContext } from "../MonthPicker.context.js";
6
+ import { nextEnabled } from "../MonthPicker.util.js";
7
+ const disableMonth = (month, fromDate, toDate) => {
8
+ if (fromDate && toDate) {
9
+ return ((compareAsc(month, fromDate) === -1 && !isSameMonth(month, fromDate)) ||
10
+ (compareDesc(month, toDate) === -1 && !isSameMonth(month, toDate)));
11
+ }
12
+ if (fromDate) {
13
+ return compareAsc(month, fromDate) === -1 && !isSameMonth(month, fromDate);
14
+ }
15
+ if (toDate) {
16
+ return compareDesc(month, toDate) === -1 && !isSameMonth(month, toDate);
17
+ }
18
+ return false;
19
+ };
20
+ export const MonthButton = ({ month, months, focus, setFocus, tabRoot, setTabRoot, }) => {
21
+ const ref = useRef(null);
22
+ const { fromDate, toDate, locale, selected, disabled, year, onYearChange, onMonthSelect, caption, } = useMonthPickerContext();
23
+ const isSelected = selected && isSameMonth(month, selected);
24
+ useEffect(() => {
25
+ if (focus) {
26
+ isSameMonth(month, focus) && ref.current && ref.current.focus();
27
+ setFocus();
28
+ }
29
+ }, [focus, month, setFocus]);
30
+ const isDisabled = isMatch(setYear(month, year.getFullYear()), disabled) ||
31
+ disableMonth(month, fromDate, toDate);
32
+ const isThisMonth = dateIsInCurrentMonth(month, year);
33
+ return (React.createElement("button", { ref: ref, type: "button", onClick: () => onMonthSelect === null || onMonthSelect === void 0 ? void 0 : onMonthSelect(isSelected ? undefined : month), disabled: isDisabled, "aria-pressed": !!isSelected, "data-current-month": isThisMonth, className: cl("navds-date__month-button", {
34
+ "rdp-day_today": isThisMonth,
35
+ "rdp-day_selected": isSelected,
36
+ "rdp-day_disabled": isDisabled,
37
+ }), tabIndex: tabRoot && isSameMonth(month, setYear(tabRoot, year.getFullYear()))
38
+ ? 0
39
+ : -1, onKeyDown: (e) => {
40
+ const next = nextEnabled(months, e.key, disabled, month, onYearChange, year, caption === "dropdown", fromDate, toDate);
41
+ setFocus(next);
42
+ setTabRoot(next);
43
+ }, onFocus: () => {
44
+ setTabRoot(focus);
45
+ } },
46
+ React.createElement("span", { "aria-hidden": "true" }, format(new Date(month), "LLL", { locale })
47
+ .replace(".", "")
48
+ .substring(0, 3)),
49
+ React.createElement("span", { className: "navds-sr-only" }, format(new Date(month), "LLLL", { locale }))));
50
+ };
51
+ export default MonthButton;
52
+ //# sourceMappingURL=MonthPicker.Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.Button.js","sourceRoot":"","sources":["../../../../src/date/monthpicker/parts/MonthPicker.Button.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ declare const MonthPickerCaption: () => React.JSX.Element;
3
+ export { MonthPickerCaption };
@@ -0,0 +1,46 @@
1
+ import { format, isAfter, isBefore, setYear, startOfMonth, startOfYear, } from "date-fns";
2
+ import React from "react";
3
+ import { ArrowLeftIcon, ArrowRightIcon } from "@navikt/aksel-icons";
4
+ import { Button } from "../../../button/index.js";
5
+ import { Select } from "../../../form/select/index.js";
6
+ import { useDateTranslationContext } from "../../Date.locale.js";
7
+ import { useMonthPickerContext } from "../MonthPicker.context.js";
8
+ const MonthPickerCaption = () => {
9
+ const { fromDate, toDate, locale, year, onYearChange, caption } = useMonthPickerContext();
10
+ const translate = useDateTranslationContext().translate;
11
+ const years = [];
12
+ if (caption === "dropdown" && fromDate && toDate) {
13
+ const fromYear = fromDate.getFullYear();
14
+ const toDateYear = toDate.getFullYear();
15
+ for (let currYear = fromYear; currYear <= toDateYear; currYear++) {
16
+ years.push(setYear(startOfYear(new Date()), currYear));
17
+ }
18
+ if (!years.map((x) => x.getFullYear()).includes(year.getFullYear())) {
19
+ years.push(setYear(startOfYear(new Date()), year.getFullYear()));
20
+ }
21
+ years.sort((a, b) => b.getFullYear() - a.getFullYear());
22
+ }
23
+ const handleYearChange = (event) => {
24
+ onYearChange(setYear(startOfMonth(new Date()), Number(event.target.value)));
25
+ };
26
+ const handleButtonClick = (val) => {
27
+ const newYear = Number(year.getFullYear() + val);
28
+ onYearChange(setYear(year, newYear));
29
+ };
30
+ const disablePreviousYear = () => {
31
+ return fromDate
32
+ ? isBefore((year === null || year === void 0 ? void 0 : year.getFullYear()) - 1, fromDate === null || fromDate === void 0 ? void 0 : fromDate.getFullYear())
33
+ : false;
34
+ };
35
+ const disableNextYear = () => {
36
+ return toDate
37
+ ? isAfter((year === null || year === void 0 ? void 0 : year.getFullYear()) + 1, toDate === null || toDate === void 0 ? void 0 : toDate.getFullYear())
38
+ : false;
39
+ };
40
+ return (React.createElement("div", { className: "navds-date__caption" },
41
+ React.createElement(Button, { className: "navds-date__caption-button", disabled: disablePreviousYear(), onClick: () => handleButtonClick(-1), icon: React.createElement(ArrowLeftIcon, { title: translate("goToPreviousYear") }), variant: "tertiary-neutral", type: "button" }),
42
+ caption === "dropdown" ? (React.createElement(Select, { label: translate("year"), hideLabel: true, value: year.getFullYear(), onChange: handleYearChange, className: "navds-date__caption__year" }, years.map((yearOpt) => (React.createElement("option", { key: yearOpt.getFullYear(), value: yearOpt.getFullYear() }, format(yearOpt, "yyyy", { locale })))))) : (React.createElement("span", { className: "navds-date__year-label", "aria-live": "polite" }, year.getFullYear())),
43
+ React.createElement(Button, { className: "navds-date__caption-button", disabled: disableNextYear(), onClick: () => handleButtonClick(1), icon: React.createElement(ArrowRightIcon, { title: translate("goToNextYear") }), variant: "tertiary-neutral", type: "button" })));
44
+ };
45
+ export { MonthPickerCaption };
46
+ //# sourceMappingURL=MonthPicker.Caption.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.Caption.js","sourceRoot":"","sources":["../../../../src/date/monthpicker/parts/MonthPicker.Caption.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { MonthPickerProps } from "../MonthPicker.types.js";
3
+ export interface MonthPickerStandaloneProps extends Omit<MonthPickerProps, "open" | "onClose" | "onOpenToggle" | "wrapperClassName" | "strategy"> {
4
+ /**
5
+ * Monthpicker classname
6
+ */
7
+ className?: string;
8
+ }
9
+ export type MonthPickerStandaloneType = React.ForwardRefExoticComponent<MonthPickerStandaloneProps & React.RefAttributes<HTMLDivElement>>;
10
+ export declare const MonthPickerStandalone: React.ForwardRefExoticComponent<MonthPickerStandaloneProps & React.RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,22 @@
1
+ import cl from "clsx";
2
+ import React, { forwardRef } from "react";
3
+ import { useDateLocale, useI18n } from "../../../util/i18n/i18n.hooks.js";
4
+ import { DateTranslationContextProvider, getLocaleFromString, getTranslations, } from "../../Date.locale.js";
5
+ import { MonthPickerProvider } from "../MonthPicker.context.js";
6
+ import { MonthPickerCaption } from "./MonthPicker.Caption.js";
7
+ import { MonthPickerTable } from "./MonthPicker.Table.js";
8
+ export const MonthPickerStandalone = forwardRef(({ dropdownCaption = false, fromDate, toDate, disabled = [], selected, className, locale, translations, onMonthSelect, defaultSelected, year, onYearChange, }, ref) => {
9
+ const translate = useI18n("DatePicker", translations, getTranslations(locale));
10
+ const langProviderLocale = useDateLocale();
11
+ if (dropdownCaption && (!fromDate || !toDate)) {
12
+ console.warn("Using dropdownCaption required fromDate and toDate");
13
+ return null;
14
+ }
15
+ return (React.createElement("div", { ref: ref, className: cl("navds-date__wrapper", className) },
16
+ React.createElement(DateTranslationContextProvider, { translate: translate },
17
+ React.createElement(MonthPickerProvider, { dropdownCaption: dropdownCaption, defaultSelected: defaultSelected, selected: selected, disabled: disabled, fromDate: fromDate, toDate: toDate, year: year, onYearChange: onYearChange, onMonthSelect: onMonthSelect, locale: locale ? getLocaleFromString(locale) : langProviderLocale },
18
+ React.createElement("div", { className: "navds-date rdp-month" },
19
+ React.createElement(MonthPickerCaption, null),
20
+ React.createElement(MonthPickerTable, null))))));
21
+ });
22
+ //# sourceMappingURL=MonthPicker.Standalone.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.Standalone.js","sourceRoot":"","sources":["../../../../src/date/monthpicker/parts/MonthPicker.Standalone.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,MAAM,CAAC;AACtB,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,EACL,8BAA8B,EAC9B,mBAAmB,EACnB,eAAe,GAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAiBvD,MAAM,CAAC,MAAM,qBAAqB,GAAG,UAAU,CAI7C,CACE,EACE,eAAe,GAAG,KAAK,EACvB,QAAQ,EACR,MAAM,EACN,QAAQ,GAAG,EAAE,EACb,QAAQ,EACR,SAAS,EACT,MAAM,EACN,YAAY,EACZ,aAAa,EACb,eAAe,EACf,IAAI,EACJ,YAAY,GACb,EACD,GAAG,EACH,EAAE;IACF,MAAM,SAAS,GAAG,OAAO,CACvB,YAAY,EACZ,YAAY,EACZ,eAAe,CAAC,MAAM,CAAC,CACxB,CAAC;IACF,MAAM,kBAAkB,GAAG,aAAa,EAAE,CAAC;IAE3C,IAAI,eAAe,IAAI,CAAC,CAAC,QAAQ,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QAC9C,OAAO,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,6BAAK,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC;QAC5D,oBAAC,8BAA8B,IAAC,SAAS,EAAE,SAAS;YAClD,oBAAC,mBAAmB,IAClB,eAAe,EAAE,eAAe,EAChC,eAAe,EAAE,eAAe,EAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,IAAI,EACV,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,aAAa,EAC5B,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,kBAAkB;gBAEjE,6BAAK,SAAS,EAAC,sBAAsB;oBACnC,oBAAC,kBAAkB,OAAG;oBACtB,oBAAC,gBAAgB,OAAG,CAChB,CACc,CACS,CAC7B,CACP,CAAC;AACJ,CAAC,CACF,CAAC"}
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ declare const MonthPickerTable: () => React.JSX.Element;
3
+ export { MonthPickerTable };
@@ -0,0 +1,50 @@
1
+ import { isSameMonth, setMonth, setYear, startOfMonth } from "date-fns";
2
+ import React, { useState } from "react";
3
+ import { BodyShort } from "../../../typography/index.js";
4
+ import { isMatch } from "../../date-utils/index.js";
5
+ import { useMonthPickerContext } from "../MonthPicker.context.js";
6
+ import MonthButton from "./MonthPicker.Button.js";
7
+ const getAllMonths = () => {
8
+ const months = [];
9
+ const date = startOfMonth(new Date());
10
+ for (let month = 0; month <= 11; month++) {
11
+ months.push(setMonth(date, month));
12
+ }
13
+ return months;
14
+ };
15
+ const MonthPickerTable = () => {
16
+ const [focus, setFocus] = useState();
17
+ const { selected, year, disabled } = useMonthPickerContext();
18
+ const months = getAllMonths();
19
+ const hasSelected = selected &&
20
+ months.some((m) => isSameMonth(setYear(m, year.getFullYear()), selected));
21
+ const getRootFallback = () => {
22
+ const today = startOfMonth(new Date());
23
+ if ((year === null || year === void 0 ? void 0 : year.getFullYear()) === today.getFullYear() &&
24
+ !isMatch(today, disabled)) {
25
+ return today;
26
+ }
27
+ for (let i = 0; i < months.length; i++) {
28
+ const m = months[i];
29
+ if (!isMatch(setYear(m, year.getFullYear()), disabled)) {
30
+ return setYear(m, year.getFullYear());
31
+ }
32
+ }
33
+ };
34
+ const [tabRoot, setTabRoot] = useState(hasSelected ? selected : getRootFallback());
35
+ if ((tabRoot === null || tabRoot === void 0 ? void 0 : tabRoot.getFullYear()) !== year.getFullYear()) {
36
+ setTabRoot(hasSelected ? selected : getRootFallback());
37
+ }
38
+ const tableMonths = [
39
+ months.slice(0, 4),
40
+ months.slice(4, 8),
41
+ months.slice(8, 12),
42
+ ];
43
+ return (React.createElement(BodyShort, { as: "table", className: "rdp-table" },
44
+ React.createElement("tbody", { className: "rdp-tbody" }, tableMonths.map((tableRow, i) => (React.createElement("tr", { className: "rdp-row", key: i }, tableRow.map((month) => {
45
+ return (React.createElement("td", { key: month.toDateString(), className: "rdp-cell" },
46
+ React.createElement(MonthButton, { month: setYear(month, year.getFullYear()), months: months, focus: focus, setFocus: setFocus, tabRoot: tabRoot, setTabRoot: setTabRoot })));
47
+ })))))));
48
+ };
49
+ export { MonthPickerTable };
50
+ //# sourceMappingURL=MonthPicker.Table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.Table.js","sourceRoot":"","sources":["../../../../src/date/monthpicker/parts/MonthPicker.Table.tsx"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  import React from "react";
2
2
  import { ComboboxProps } from "./types.js";
3
- export declare const Combobox: React.ForwardRefExoticComponent<Omit<ComboboxProps, "onChange" | "value" | "size" | "disabled" | "options" | "onClear"> & React.RefAttributes<HTMLInputElement>>;
3
+ export declare const Combobox: React.ForwardRefExoticComponent<Omit<ComboboxProps, "size" | "disabled" | "value" | "onChange" | "onClear" | "options"> & React.RefAttributes<HTMLInputElement>>;
4
4
  export default Combobox;
@@ -1,3 +1,3 @@
1
1
  import React from "react";
2
2
  import { ComboboxProps } from "../types.js";
3
- export declare const InputController: React.ForwardRefExoticComponent<Omit<ComboboxProps, "onChange" | "value" | "label" | "size" | "disabled" | "options" | "hideLabel" | "description" | "onClear"> & React.RefAttributes<HTMLInputElement>>;
3
+ export declare const InputController: React.ForwardRefExoticComponent<Omit<ComboboxProps, "size" | "disabled" | "description" | "value" | "onChange" | "label" | "hideLabel" | "onClear" | "options"> & React.RefAttributes<HTMLInputElement>>;
@@ -37,11 +37,16 @@ export const ConfirmationPanel = forwardRef((_a, ref) => {
37
37
  var { className, children, label } = _a, props = __rest(_a, ["className", "children", "label"]);
38
38
  const { errorId, showErrorMsg, hasError, size, inputProps } = useFormField(props, "confirmation-panel");
39
39
  const id = useId();
40
+ const currentRole = hasError
41
+ ? "danger"
42
+ : props.checked
43
+ ? "success"
44
+ : "warning";
40
45
  return (React.createElement("div", { className: cl("navds-confirmation-panel", "navds-form-field", className, {
41
46
  "navds-confirmation-panel--small": size === "small",
42
47
  "navds-confirmation-panel--error": hasError,
43
48
  "navds-confirmation-panel--checked": !!props.checked,
44
- }) },
49
+ }), "data-color-role": currentRole },
45
50
  React.createElement("div", { className: "navds-confirmation-panel__inner" },
46
51
  children && (React.createElement(BodyLong, { size: props.size, className: "navds-confirmation-panel__content", id: `confirmation-panel-${id}`, as: "div" }, children)),
47
52
  React.createElement(Checkbox, Object.assign({ ref: ref }, props, inputProps, { "aria-describedby": cl(inputProps["aria-describedby"], children && `confirmation-panel-${id}`), error: hasError, size: size }), label)),
@@ -1 +1 @@
1
- {"version":3,"file":"ConfirmationPanel.js","sourceRoot":"","sources":["../../../src/form/confirmation-panel/ConfirmationPanel.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,MAAM,CAAC;AACtB,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAiB,MAAM,aAAa,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAyB/C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,UAAU,CAGzC,CAAC,EAAwC,EAAE,GAAG,EAAE,EAAE;QAAjD,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,OAAY,EAAP,KAAK,cAAtC,kCAAwC,CAAF;IACvC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,YAAY,CACxE,KAAK,EACL,oBAAoB,CACrB,CAAC;IAEF,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IAEnB,OAAO,CACL,6BACE,SAAS,EAAE,EAAE,CAAC,0BAA0B,EAAE,kBAAkB,EAAE,SAAS,EAAE;YACvE,iCAAiC,EAAE,IAAI,KAAK,OAAO;YACnD,iCAAiC,EAAE,QAAQ;YAC3C,mCAAmC,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO;SACrD,CAAC;QAEF,6BAAK,SAAS,EAAC,iCAAiC;YAC7C,QAAQ,IAAI,CACX,oBAAC,QAAQ,IACP,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,SAAS,EAAC,mCAAmC,EAC7C,EAAE,EAAE,sBAAsB,EAAE,EAAE,EAC9B,EAAE,EAAC,KAAK,IAEP,QAAQ,CACA,CACZ;YACD,oBAAC,QAAQ,kBACP,GAAG,EAAE,GAAG,IACJ,KAAK,EACL,UAAU,wBACI,EAAE,CAClB,UAAU,CAAC,kBAAkB,CAAC,EAC9B,QAAQ,IAAI,sBAAsB,EAAE,EAAE,CACvC,EACD,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE,IAAI,KAET,KAAK,CACG,CACP;QACN,6BAAK,SAAS,EAAC,yBAAyB,EAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,IAC/D,YAAY,IAAI,CACf,oBAAC,YAAY,IAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,UAC/B,KAAK,CAAC,KAAK,CACC,CAChB,CACG,CACF,CACP,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,eAAe,iBAAiB,CAAC"}
1
+ {"version":3,"file":"ConfirmationPanel.js","sourceRoot":"","sources":["../../../src/form/confirmation-panel/ConfirmationPanel.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,MAAM,CAAC;AACtB,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAiB,MAAM,aAAa,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAyB/C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,UAAU,CAGzC,CAAC,EAAwC,EAAE,GAAG,EAAE,EAAE;QAAjD,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,OAAY,EAAP,KAAK,cAAtC,kCAAwC,CAAF;IACvC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,YAAY,CACxE,KAAK,EACL,oBAAoB,CACrB,CAAC;IAEF,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IAEnB,MAAM,WAAW,GAAG,QAAQ;QAC1B,CAAC,CAAC,QAAQ;QACV,CAAC,CAAC,KAAK,CAAC,OAAO;YACb,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,SAAS,CAAC;IAEhB,OAAO,CACL,6BACE,SAAS,EAAE,EAAE,CAAC,0BAA0B,EAAE,kBAAkB,EAAE,SAAS,EAAE;YACvE,iCAAiC,EAAE,IAAI,KAAK,OAAO;YACnD,iCAAiC,EAAE,QAAQ;YAC3C,mCAAmC,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO;SACrD,CAAC,qBACe,WAAW;QAE5B,6BAAK,SAAS,EAAC,iCAAiC;YAC7C,QAAQ,IAAI,CACX,oBAAC,QAAQ,IACP,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,SAAS,EAAC,mCAAmC,EAC7C,EAAE,EAAE,sBAAsB,EAAE,EAAE,EAC9B,EAAE,EAAC,KAAK,IAEP,QAAQ,CACA,CACZ;YACD,oBAAC,QAAQ,kBACP,GAAG,EAAE,GAAG,IACJ,KAAK,EACL,UAAU,wBACI,EAAE,CAClB,UAAU,CAAC,kBAAkB,CAAC,EAC9B,QAAQ,IAAI,sBAAsB,EAAE,EAAE,CACvC,EACD,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE,IAAI,KAET,KAAK,CACG,CACP;QACN,6BAAK,SAAS,EAAC,yBAAyB,EAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,IAC/D,YAAY,IAAI,CACf,oBAAC,YAAY,IAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,UAC/B,KAAK,CAAC,KAAK,CACC,CAChB,CACG,CACF,CACP,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,eAAe,iBAAiB,CAAC"}
@@ -11,9 +11,9 @@ var __rest = (this && this.__rest) || function (s, e) {
11
11
  };
12
12
  import { useFloatingPortalNode } from "@floating-ui/react";
13
13
  import cl from "clsx";
14
- import React, { forwardRef, useContext, useEffect, useRef } from "react";
14
+ import React, { forwardRef, useEffect, useRef } from "react";
15
15
  import { createPortal } from "react-dom";
16
- import { DateInputContext } from "../date/context/index.js";
16
+ import { useDateInputContext } from "../date/Date.Input.js";
17
17
  import { useProvider } from "../provider/Provider.js";
18
18
  import { Detail, Heading } from "../typography/index.js";
19
19
  import { composeEventHandlers } from "../util/composeEventHandlers.js";
@@ -80,7 +80,7 @@ export const Modal = forwardRef((_a, ref) => {
80
80
  const ariaLabelId = useId();
81
81
  const rootElement = (_b = useProvider()) === null || _b === void 0 ? void 0 : _b.rootElement;
82
82
  const portalNode = useFloatingPortalNode({ root: rootElement });
83
- const dateContext = useContext(DateInputContext);
83
+ const dateContext = useDateInputContext(false);
84
84
  const isNested = useModalContext(false) !== undefined;
85
85
  if (isNested && !dateContext) {
86
86
  console.error("Modals should not be nested");