@mantine/dates 3.3.4 → 3.4.2

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 (241) hide show
  1. package/cjs/components/Calendar/Calendar.js +6 -137
  2. package/cjs/components/Calendar/Calendar.js.map +1 -1
  3. package/cjs/components/CalendarBase/CalendarBase.js +242 -0
  4. package/cjs/components/CalendarBase/CalendarBase.js.map +1 -0
  5. package/cjs/components/CalendarBase/CalendarBase.styles.js +22 -0
  6. package/cjs/components/CalendarBase/CalendarBase.styles.js.map +1 -0
  7. package/cjs/components/{Calendar → CalendarBase/CalendarHeader}/ArrowIcon.js +0 -0
  8. package/cjs/components/CalendarBase/CalendarHeader/ArrowIcon.js.map +1 -0
  9. package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.js +119 -0
  10. package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.js.map +1 -0
  11. package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js +58 -0
  12. package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js.map +1 -0
  13. package/cjs/components/CalendarBase/MonthPicker/MonthPicker.js +113 -0
  14. package/cjs/components/CalendarBase/MonthPicker/MonthPicker.js.map +1 -0
  15. package/cjs/components/CalendarBase/MonthPicker/MonthPicker.styles.js +52 -0
  16. package/cjs/components/CalendarBase/MonthPicker/MonthPicker.styles.js.map +1 -0
  17. package/cjs/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js +25 -0
  18. package/cjs/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js.map +1 -0
  19. package/cjs/components/CalendarBase/MonthsList/MonthsList.js +123 -0
  20. package/cjs/components/CalendarBase/MonthsList/MonthsList.js.map +1 -0
  21. package/cjs/components/CalendarBase/MonthsList/format-month-label/format-month-label.js +17 -0
  22. package/cjs/components/CalendarBase/MonthsList/format-month-label/format-month-label.js.map +1 -0
  23. package/cjs/components/CalendarBase/YearPicker/YearPicker.js +102 -0
  24. package/cjs/components/CalendarBase/YearPicker/YearPicker.js.map +1 -0
  25. package/cjs/components/CalendarBase/YearPicker/YearPicker.styles.js +54 -0
  26. package/cjs/components/CalendarBase/YearPicker/YearPicker.styles.js.map +1 -0
  27. package/cjs/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js +16 -0
  28. package/cjs/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js.map +1 -0
  29. package/cjs/components/DatePicker/DatePicker.js +10 -10
  30. package/cjs/components/DatePicker/DatePicker.js.map +1 -1
  31. package/cjs/components/DatePickerBase/DatePickerBase.js +5 -5
  32. package/cjs/components/DatePickerBase/DatePickerBase.js.map +1 -1
  33. package/cjs/components/DateRangePicker/DateRangePicker.js +0 -6
  34. package/cjs/components/DateRangePicker/DateRangePicker.js.map +1 -1
  35. package/cjs/components/Month/Day/Day.js +12 -15
  36. package/cjs/components/Month/Day/Day.js.map +1 -1
  37. package/cjs/components/Month/Day/Day.styles.js +2 -1
  38. package/cjs/components/Month/Day/Day.styles.js.map +1 -1
  39. package/cjs/components/Month/Day/get-day-autofocus/get-day-autofocus.js +13 -0
  40. package/cjs/components/Month/Day/get-day-autofocus/get-day-autofocus.js.map +1 -0
  41. package/cjs/components/Month/Day/get-day-tab-index/get-day-tab-index.js +16 -0
  42. package/cjs/components/Month/Day/get-day-tab-index/get-day-tab-index.js.map +1 -0
  43. package/cjs/components/Month/Month.js +36 -67
  44. package/cjs/components/Month/Month.js.map +1 -1
  45. package/cjs/components/Month/Month.styles.js +1 -1
  46. package/cjs/components/Month/Month.styles.js.map +1 -1
  47. package/cjs/components/Month/get-day-props/get-day-props.js +9 -24
  48. package/cjs/components/Month/get-day-props/get-day-props.js.map +1 -1
  49. package/cjs/components/Month/get-day-props/get-range-props/get-range-props.js +25 -0
  50. package/cjs/components/Month/get-day-props/get-range-props/get-range-props.js.map +1 -0
  51. package/cjs/components/Month/get-day-props/is-disabled/is-disabled.js +27 -0
  52. package/cjs/components/Month/get-day-props/is-disabled/is-disabled.js.map +1 -0
  53. package/cjs/components/Month/get-day-props/is-outside/is-outside.js +13 -0
  54. package/cjs/components/Month/get-day-props/is-outside/is-outside.js.map +1 -0
  55. package/cjs/components/Month/get-day-props/is-weekend/is-weekend.js +11 -0
  56. package/cjs/components/Month/get-day-props/is-weekend/is-weekend.js.map +1 -0
  57. package/cjs/components/RangeCalendar/RangeCalendar.js +19 -122
  58. package/cjs/components/RangeCalendar/RangeCalendar.js.map +1 -1
  59. package/cjs/components/TimeInput/TimeField/TimeField.js +6 -1
  60. package/cjs/components/TimeInput/TimeField/TimeField.js.map +1 -1
  61. package/cjs/components/TimeInput/TimeField/TimeField.styles.js +54 -0
  62. package/cjs/components/TimeInput/TimeField/TimeField.styles.js.map +1 -0
  63. package/cjs/components/TimeInput/TimeInput.styles.js +1 -24
  64. package/cjs/components/TimeInput/TimeInput.styles.js.map +1 -1
  65. package/cjs/components/TimeRangeInput/TimeRangeInput.styles.js +2 -19
  66. package/cjs/components/TimeRangeInput/TimeRangeInput.styles.js.map +1 -1
  67. package/cjs/utils/get-months-names/get-months-names.js +2 -2
  68. package/cjs/utils/get-months-names/get-months-names.js.map +1 -1
  69. package/esm/components/Calendar/Calendar.js +6 -136
  70. package/esm/components/Calendar/Calendar.js.map +1 -1
  71. package/esm/components/CalendarBase/CalendarBase.js +234 -0
  72. package/esm/components/CalendarBase/CalendarBase.js.map +1 -0
  73. package/esm/components/CalendarBase/CalendarBase.styles.js +18 -0
  74. package/esm/components/CalendarBase/CalendarBase.styles.js.map +1 -0
  75. package/esm/components/{Calendar → CalendarBase/CalendarHeader}/ArrowIcon.js +0 -0
  76. package/esm/components/CalendarBase/CalendarHeader/ArrowIcon.js.map +1 -0
  77. package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.js +111 -0
  78. package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.js.map +1 -0
  79. package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js +54 -0
  80. package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js.map +1 -0
  81. package/esm/components/CalendarBase/MonthPicker/MonthPicker.js +105 -0
  82. package/esm/components/CalendarBase/MonthPicker/MonthPicker.js.map +1 -0
  83. package/esm/components/CalendarBase/MonthPicker/MonthPicker.styles.js +48 -0
  84. package/esm/components/CalendarBase/MonthPicker/MonthPicker.styles.js.map +1 -0
  85. package/esm/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js +17 -0
  86. package/esm/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js.map +1 -0
  87. package/esm/components/CalendarBase/MonthsList/MonthsList.js +114 -0
  88. package/esm/components/CalendarBase/MonthsList/MonthsList.js.map +1 -0
  89. package/esm/components/CalendarBase/MonthsList/format-month-label/format-month-label.js +9 -0
  90. package/esm/components/CalendarBase/MonthsList/format-month-label/format-month-label.js.map +1 -0
  91. package/esm/components/CalendarBase/YearPicker/YearPicker.js +94 -0
  92. package/esm/components/CalendarBase/YearPicker/YearPicker.js.map +1 -0
  93. package/esm/components/CalendarBase/YearPicker/YearPicker.styles.js +50 -0
  94. package/esm/components/CalendarBase/YearPicker/YearPicker.styles.js.map +1 -0
  95. package/esm/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js +12 -0
  96. package/esm/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js.map +1 -0
  97. package/esm/components/DatePicker/DatePicker.js +10 -10
  98. package/esm/components/DatePicker/DatePicker.js.map +1 -1
  99. package/esm/components/DatePickerBase/DatePickerBase.js +6 -6
  100. package/esm/components/DatePickerBase/DatePickerBase.js.map +1 -1
  101. package/esm/components/DateRangePicker/DateRangePicker.js +0 -6
  102. package/esm/components/DateRangePicker/DateRangePicker.js.map +1 -1
  103. package/esm/components/Month/Day/Day.js +12 -15
  104. package/esm/components/Month/Day/Day.js.map +1 -1
  105. package/esm/components/Month/Day/Day.styles.js +2 -1
  106. package/esm/components/Month/Day/Day.styles.js.map +1 -1
  107. package/esm/components/Month/Day/get-day-autofocus/get-day-autofocus.js +9 -0
  108. package/esm/components/Month/Day/get-day-autofocus/get-day-autofocus.js.map +1 -0
  109. package/esm/components/Month/Day/get-day-tab-index/get-day-tab-index.js +12 -0
  110. package/esm/components/Month/Day/get-day-tab-index/get-day-tab-index.js.map +1 -0
  111. package/esm/components/Month/Month.js +38 -69
  112. package/esm/components/Month/Month.js.map +1 -1
  113. package/esm/components/Month/Month.styles.js +1 -1
  114. package/esm/components/Month/Month.styles.js.map +1 -1
  115. package/esm/components/Month/get-day-props/get-day-props.js +9 -20
  116. package/esm/components/Month/get-day-props/get-day-props.js.map +1 -1
  117. package/esm/components/Month/get-day-props/get-range-props/get-range-props.js +17 -0
  118. package/esm/components/Month/get-day-props/get-range-props/get-range-props.js.map +1 -0
  119. package/esm/components/Month/get-day-props/is-disabled/is-disabled.js +19 -0
  120. package/esm/components/Month/get-day-props/is-disabled/is-disabled.js.map +1 -0
  121. package/esm/components/Month/get-day-props/is-outside/is-outside.js +9 -0
  122. package/esm/components/Month/get-day-props/is-outside/is-outside.js.map +1 -0
  123. package/esm/components/Month/get-day-props/is-weekend/is-weekend.js +7 -0
  124. package/esm/components/Month/get-day-props/is-weekend/is-weekend.js.map +1 -0
  125. package/esm/components/RangeCalendar/RangeCalendar.js +20 -123
  126. package/esm/components/RangeCalendar/RangeCalendar.js.map +1 -1
  127. package/esm/components/TimeInput/TimeField/TimeField.js +6 -1
  128. package/esm/components/TimeInput/TimeField/TimeField.js.map +1 -1
  129. package/esm/components/TimeInput/TimeField/TimeField.styles.js +50 -0
  130. package/esm/components/TimeInput/TimeField/TimeField.styles.js.map +1 -0
  131. package/esm/components/TimeInput/TimeInput.styles.js +1 -24
  132. package/esm/components/TimeInput/TimeInput.styles.js.map +1 -1
  133. package/esm/components/TimeRangeInput/TimeRangeInput.styles.js +2 -19
  134. package/esm/components/TimeRangeInput/TimeRangeInput.styles.js.map +1 -1
  135. package/esm/utils/get-months-names/get-months-names.js +2 -2
  136. package/esm/utils/get-months-names/get-months-names.js.map +1 -1
  137. package/lib/components/Calendar/Calendar.d.ts +3 -45
  138. package/lib/components/Calendar/Calendar.d.ts.map +1 -1
  139. package/lib/components/Calendar/index.d.ts +1 -1
  140. package/lib/components/Calendar/index.d.ts.map +1 -1
  141. package/lib/components/CalendarBase/CalendarBase.d.ts +56 -0
  142. package/lib/components/CalendarBase/CalendarBase.d.ts.map +1 -0
  143. package/lib/components/CalendarBase/CalendarBase.styles.d.ts +13 -0
  144. package/lib/components/CalendarBase/CalendarBase.styles.d.ts.map +1 -0
  145. package/lib/components/CalendarBase/CalendarHeader/ArrowIcon.d.ts +10 -0
  146. package/lib/components/CalendarBase/CalendarHeader/ArrowIcon.d.ts.map +1 -0
  147. package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.d.ts +24 -0
  148. package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.d.ts.map +1 -0
  149. package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.styles.d.ts +18 -0
  150. package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.styles.d.ts.map +1 -0
  151. package/lib/components/CalendarBase/MonthPicker/MonthPicker.d.ts +27 -0
  152. package/lib/components/CalendarBase/MonthPicker/MonthPicker.d.ts.map +1 -0
  153. package/lib/components/CalendarBase/MonthPicker/MonthPicker.styles.d.ts +11 -0
  154. package/lib/components/CalendarBase/MonthPicker/MonthPicker.styles.d.ts.map +1 -0
  155. package/lib/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.d.ts +8 -0
  156. package/lib/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.d.ts.map +1 -0
  157. package/lib/components/CalendarBase/MonthsList/MonthsList.d.ts +24 -0
  158. package/lib/components/CalendarBase/MonthsList/MonthsList.d.ts.map +1 -0
  159. package/lib/components/CalendarBase/MonthsList/format-month-label/format-month-label.d.ts +8 -0
  160. package/lib/components/CalendarBase/MonthsList/format-month-label/format-month-label.d.ts.map +1 -0
  161. package/lib/components/CalendarBase/YearPicker/YearPicker.d.ts +20 -0
  162. package/lib/components/CalendarBase/YearPicker/YearPicker.d.ts.map +1 -0
  163. package/lib/components/CalendarBase/YearPicker/YearPicker.styles.d.ts +11 -0
  164. package/lib/components/CalendarBase/YearPicker/YearPicker.styles.d.ts.map +1 -0
  165. package/lib/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.d.ts +2 -0
  166. package/lib/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.d.ts.map +1 -0
  167. package/lib/components/DatePicker/DatePicker.d.ts +2 -2
  168. package/lib/components/DatePicker/DatePicker.d.ts.map +1 -1
  169. package/lib/components/DatePickerBase/DatePickerBase.d.ts +2 -2
  170. package/lib/components/DatePickerBase/DatePickerBase.d.ts.map +1 -1
  171. package/lib/components/DateRangePicker/DateRangePicker.d.ts +2 -2
  172. package/lib/components/DateRangePicker/DateRangePicker.d.ts.map +1 -1
  173. package/lib/components/Month/Day/Day.d.ts +3 -3
  174. package/lib/components/Month/Day/Day.d.ts.map +1 -1
  175. package/lib/components/Month/Day/Day.styles.d.ts +3 -2
  176. package/lib/components/Month/Day/Day.styles.d.ts.map +1 -1
  177. package/lib/components/Month/Day/get-day-autofocus/get-day-autofocus.d.ts +8 -0
  178. package/lib/components/Month/Day/get-day-autofocus/get-day-autofocus.d.ts.map +1 -0
  179. package/lib/components/Month/Day/get-day-tab-index/get-day-tab-index.d.ts +9 -0
  180. package/lib/components/Month/Day/get-day-tab-index/get-day-tab-index.d.ts.map +1 -0
  181. package/lib/components/Month/Month.d.ts +12 -11
  182. package/lib/components/Month/Month.d.ts.map +1 -1
  183. package/lib/components/Month/Month.styles.d.ts +2 -2
  184. package/lib/components/Month/get-day-props/get-day-props.d.ts +2 -27
  185. package/lib/components/Month/get-day-props/get-day-props.d.ts.map +1 -1
  186. package/lib/components/Month/get-day-props/get-range-props/get-range-props.d.ts +7 -0
  187. package/lib/components/Month/get-day-props/get-range-props/get-range-props.d.ts.map +1 -0
  188. package/lib/components/Month/get-day-props/is-disabled/is-disabled.d.ts +11 -0
  189. package/lib/components/Month/get-day-props/is-disabled/is-disabled.d.ts.map +1 -0
  190. package/lib/components/Month/get-day-props/is-outside/is-outside.d.ts +2 -0
  191. package/lib/components/Month/get-day-props/is-outside/is-outside.d.ts.map +1 -0
  192. package/lib/components/Month/get-day-props/is-weekend/is-weekend.d.ts +2 -0
  193. package/lib/components/Month/get-day-props/is-weekend/is-weekend.d.ts.map +1 -0
  194. package/lib/components/Month/index.d.ts +1 -0
  195. package/lib/components/Month/index.d.ts.map +1 -1
  196. package/lib/components/Month/types.d.ts +23 -0
  197. package/lib/components/Month/types.d.ts.map +1 -0
  198. package/lib/components/RangeCalendar/RangeCalendar.d.ts +2 -12
  199. package/lib/components/RangeCalendar/RangeCalendar.d.ts.map +1 -1
  200. package/lib/components/TimeInput/TimeField/TimeField.d.ts.map +1 -1
  201. package/lib/components/TimeInput/TimeField/TimeField.styles.d.ts +18 -0
  202. package/lib/components/TimeInput/TimeField/TimeField.styles.d.ts.map +1 -0
  203. package/lib/components/TimeInput/TimeInput.styles.d.ts +0 -7
  204. package/lib/components/TimeInput/TimeInput.styles.d.ts.map +1 -1
  205. package/lib/components/TimeRangeInput/TimeRangeInput.styles.d.ts +2 -2
  206. package/lib/components/TimeRangeInput/TimeRangeInput.styles.d.ts.map +1 -1
  207. package/lib/utils/get-months-names/get-months-names.d.ts +1 -1
  208. package/lib/utils/get-months-names/get-months-names.d.ts.map +1 -1
  209. package/package.json +3 -3
  210. package/cjs/components/Calendar/ArrowIcon.js.map +0 -1
  211. package/cjs/components/Calendar/CalendarHeader/CalendarHeader.js +0 -105
  212. package/cjs/components/Calendar/CalendarHeader/CalendarHeader.js.map +0 -1
  213. package/cjs/components/Calendar/CalendarLabel/CalendarLabel.js +0 -69
  214. package/cjs/components/Calendar/CalendarLabel/CalendarLabel.js.map +0 -1
  215. package/cjs/components/Calendar/CalendarLabel/CalendarLabel.styles.js +0 -14
  216. package/cjs/components/Calendar/CalendarLabel/CalendarLabel.styles.js.map +0 -1
  217. package/cjs/components/Calendar/CalendarWrapper/CalendarWrapper.js +0 -58
  218. package/cjs/components/Calendar/CalendarWrapper/CalendarWrapper.js.map +0 -1
  219. package/cjs/components/Calendar/get-disabled-state/get-disabled-state.js +0 -18
  220. package/cjs/components/Calendar/get-disabled-state/get-disabled-state.js.map +0 -1
  221. package/esm/components/Calendar/ArrowIcon.js.map +0 -1
  222. package/esm/components/Calendar/CalendarHeader/CalendarHeader.js +0 -97
  223. package/esm/components/Calendar/CalendarHeader/CalendarHeader.js.map +0 -1
  224. package/esm/components/Calendar/CalendarLabel/CalendarLabel.js +0 -60
  225. package/esm/components/Calendar/CalendarLabel/CalendarLabel.js.map +0 -1
  226. package/esm/components/Calendar/CalendarLabel/CalendarLabel.styles.js +0 -10
  227. package/esm/components/Calendar/CalendarLabel/CalendarLabel.styles.js.map +0 -1
  228. package/esm/components/Calendar/CalendarWrapper/CalendarWrapper.js +0 -50
  229. package/esm/components/Calendar/CalendarWrapper/CalendarWrapper.js.map +0 -1
  230. package/esm/components/Calendar/get-disabled-state/get-disabled-state.js +0 -10
  231. package/esm/components/Calendar/get-disabled-state/get-disabled-state.js.map +0 -1
  232. package/lib/components/Calendar/CalendarHeader/CalendarHeader.d.ts +0 -33
  233. package/lib/components/Calendar/CalendarHeader/CalendarHeader.d.ts.map +0 -1
  234. package/lib/components/Calendar/CalendarLabel/CalendarLabel.d.ts +0 -26
  235. package/lib/components/Calendar/CalendarLabel/CalendarLabel.d.ts.map +0 -1
  236. package/lib/components/Calendar/CalendarLabel/CalendarLabel.styles.d.ts +0 -7
  237. package/lib/components/Calendar/CalendarLabel/CalendarLabel.styles.d.ts.map +0 -1
  238. package/lib/components/Calendar/CalendarWrapper/CalendarWrapper.d.ts +0 -10
  239. package/lib/components/Calendar/CalendarWrapper/CalendarWrapper.d.ts.map +0 -1
  240. package/lib/components/Calendar/get-disabled-state/get-disabled-state.d.ts +0 -15
  241. package/lib/components/Calendar/get-disabled-state/get-disabled-state.d.ts.map +0 -1
@@ -0,0 +1,54 @@
1
+ import { createStyles } from '@mantine/core';
2
+
3
+ const sizes = {
4
+ xs: 32,
5
+ sm: 40,
6
+ md: 44,
7
+ lg: 50,
8
+ xl: 54
9
+ };
10
+ var useStyles = createStyles((theme, { size }) => ({
11
+ calendarHeader: {
12
+ display: "flex",
13
+ justifyContent: "space-between",
14
+ align: "center",
15
+ marginBottom: theme.fn.size({ size, sizes: theme.spacing })
16
+ },
17
+ calendarHeaderControl: {
18
+ width: theme.fn.size({ size, sizes }),
19
+ height: theme.fn.size({ size, sizes }),
20
+ "&:disabled": {
21
+ opacity: 0,
22
+ cursor: "default"
23
+ }
24
+ },
25
+ calendarHeaderLevel: {
26
+ display: "flex",
27
+ alignItems: "center",
28
+ justifyContent: "center",
29
+ height: theme.fn.size({ size, sizes }),
30
+ fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),
31
+ padding: `0 ${theme.fn.size({ size, sizes: theme.spacing })}px`,
32
+ borderRadius: theme.radius.sm,
33
+ fontWeight: 500,
34
+ flex: 1,
35
+ textAlign: "center",
36
+ color: theme.colorScheme === "dark" ? theme.colors.dark[0] : theme.black,
37
+ "&:hover": {
38
+ backgroundColor: theme.colorScheme === "dark" ? theme.colors.dark[8] : theme.colors.gray[0]
39
+ },
40
+ "&:disabled": {
41
+ "&:hover": {
42
+ backgroundColor: "transparent",
43
+ cursor: "default"
44
+ }
45
+ }
46
+ },
47
+ calendarHeaderLevelIcon: {
48
+ marginLeft: 4
49
+ }
50
+ }));
51
+
52
+ export default useStyles;
53
+ export { sizes };
54
+ //# sourceMappingURL=CalendarHeader.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CalendarHeader.styles.js","sources":["../../../../src/components/CalendarBase/CalendarHeader/CalendarHeader.styles.ts"],"sourcesContent":["import { createStyles, MantineSize } from '@mantine/core';\n\ninterface CalendarHeaderStyles {\n size: MantineSize;\n}\n\nexport const sizes = {\n xs: 32,\n sm: 40,\n md: 44,\n lg: 50,\n xl: 54,\n};\n\nexport default createStyles((theme, { size }: CalendarHeaderStyles) => ({\n calendarHeader: {\n display: 'flex',\n justifyContent: 'space-between',\n align: 'center',\n marginBottom: theme.fn.size({ size, sizes: theme.spacing }),\n },\n\n calendarHeaderControl: {\n width: theme.fn.size({ size, sizes }),\n height: theme.fn.size({ size, sizes }),\n\n '&:disabled': {\n opacity: 0,\n cursor: 'default',\n },\n },\n\n calendarHeaderLevel: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n height: theme.fn.size({ size, sizes }),\n fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),\n padding: `0 ${theme.fn.size({ size, sizes: theme.spacing })}px`,\n borderRadius: theme.radius.sm,\n fontWeight: 500,\n flex: 1,\n textAlign: 'center',\n color: theme.colorScheme === 'dark' ? theme.colors.dark[0] : theme.black,\n\n '&:hover': {\n backgroundColor: theme.colorScheme === 'dark' ? theme.colors.dark[8] : theme.colors.gray[0],\n },\n\n '&:disabled': {\n '&:hover': {\n backgroundColor: 'transparent',\n cursor: 'default',\n },\n },\n },\n\n calendarHeaderLevelIcon: {\n marginLeft: 4,\n },\n}));\n"],"names":[],"mappings":";;AACY,MAAC,KAAK,GAAG;AACrB,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE;AACF,gBAAe,YAAY,CAAC,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM;AAClD,EAAE,cAAc,EAAE;AAClB,IAAI,OAAO,EAAE,MAAM;AACnB,IAAI,cAAc,EAAE,eAAe;AACnC,IAAI,KAAK,EAAE,QAAQ;AACnB,IAAI,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;AAC/D,GAAG;AACH,EAAE,qBAAqB,EAAE;AACzB,IAAI,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzC,IAAI,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC1C,IAAI,YAAY,EAAE;AAClB,MAAM,OAAO,EAAE,CAAC;AAChB,MAAM,MAAM,EAAE,SAAS;AACvB,KAAK;AACL,GAAG;AACH,EAAE,mBAAmB,EAAE;AACvB,IAAI,OAAO,EAAE,MAAM;AACnB,IAAI,UAAU,EAAE,QAAQ;AACxB,IAAI,cAAc,EAAE,QAAQ;AAC5B,IAAI,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC1C,IAAI,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;AAC7D,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC;AACnE,IAAI,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE;AACjC,IAAI,UAAU,EAAE,GAAG;AACnB,IAAI,IAAI,EAAE,CAAC;AACX,IAAI,SAAS,EAAE,QAAQ;AACvB,IAAI,KAAK,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK;AAC5E,IAAI,SAAS,EAAE;AACf,MAAM,eAAe,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;AACjG,KAAK;AACL,IAAI,YAAY,EAAE;AAClB,MAAM,SAAS,EAAE;AACjB,QAAQ,eAAe,EAAE,aAAa;AACtC,QAAQ,MAAM,EAAE,SAAS;AACzB,OAAO;AACP,KAAK;AACL,GAAG;AACH,EAAE,uBAAuB,EAAE;AAC3B,IAAI,UAAU,EAAE,CAAC;AACjB,GAAG;AACH,CAAC,CAAC,CAAC;;;;;"}
@@ -0,0 +1,105 @@
1
+ import React from 'react';
2
+ import { UnstyledButton } from '@mantine/core';
3
+ import { getMonthsNames } from '../../../utils/get-months-names/get-months-names.js';
4
+ import 'dayjs';
5
+ import { CalendarHeader } from '../CalendarHeader/CalendarHeader.js';
6
+ import { isMonthInRange } from './is-month-in-range/is-month-in-range.js';
7
+ import useStyles from './MonthPicker.styles.js';
8
+
9
+ var __defProp = Object.defineProperty;
10
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
11
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
12
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
13
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
14
+ var __spreadValues = (a, b) => {
15
+ for (var prop in b || (b = {}))
16
+ if (__hasOwnProp.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ if (__getOwnPropSymbols)
19
+ for (var prop of __getOwnPropSymbols(b)) {
20
+ if (__propIsEnum.call(b, prop))
21
+ __defNormalProp(a, prop, b[prop]);
22
+ }
23
+ return a;
24
+ };
25
+ var __objRest = (source, exclude) => {
26
+ var target = {};
27
+ for (var prop in source)
28
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
29
+ target[prop] = source[prop];
30
+ if (source != null && __getOwnPropSymbols)
31
+ for (var prop of __getOwnPropSymbols(source)) {
32
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
33
+ target[prop] = source[prop];
34
+ }
35
+ return target;
36
+ };
37
+ function MonthPicker(_a) {
38
+ var _b = _a, {
39
+ className,
40
+ styles,
41
+ classNames,
42
+ value,
43
+ onChange,
44
+ locale,
45
+ year,
46
+ onYearChange,
47
+ onNextLevel,
48
+ size,
49
+ minDate,
50
+ maxDate,
51
+ __staticSelector = "MonthPicker",
52
+ nextYearLabel,
53
+ previousYearLabel
54
+ } = _b, others = __objRest(_b, [
55
+ "className",
56
+ "styles",
57
+ "classNames",
58
+ "value",
59
+ "onChange",
60
+ "locale",
61
+ "year",
62
+ "onYearChange",
63
+ "onNextLevel",
64
+ "size",
65
+ "minDate",
66
+ "maxDate",
67
+ "__staticSelector",
68
+ "nextYearLabel",
69
+ "previousYearLabel"
70
+ ]);
71
+ const { classes, cx } = useStyles({ size }, { classNames, styles, name: __staticSelector });
72
+ const range = getMonthsNames(locale);
73
+ const minYear = minDate instanceof Date ? minDate.getFullYear() : void 0;
74
+ const maxYear = maxDate instanceof Date ? maxDate.getFullYear() : void 0;
75
+ const months = range.map((month, index) => /* @__PURE__ */ React.createElement(UnstyledButton, {
76
+ key: month,
77
+ onClick: () => onChange(index),
78
+ className: cx(classes.monthPickerControl, {
79
+ [classes.monthPickerControlActive]: index === value.month && year === value.year
80
+ }),
81
+ disabled: !isMonthInRange({ date: new Date(year, index), minDate, maxDate })
82
+ }, month));
83
+ return /* @__PURE__ */ React.createElement("div", __spreadValues({
84
+ className: cx(classes.monthPicker, className)
85
+ }, others), /* @__PURE__ */ React.createElement(CalendarHeader, {
86
+ label: year.toString(),
87
+ hasNext: typeof maxYear === "number" ? year < maxYear : true,
88
+ hasPrevious: typeof minYear === "number" ? year > minYear : true,
89
+ onNext: () => onYearChange(year + 1),
90
+ onPrevious: () => onYearChange(year - 1),
91
+ onNextLevel,
92
+ size,
93
+ classNames,
94
+ styles,
95
+ __staticSelector,
96
+ nextLabel: nextYearLabel,
97
+ previousLabel: previousYearLabel
98
+ }), /* @__PURE__ */ React.createElement("div", {
99
+ className: classes.monthPickerControls
100
+ }, months));
101
+ }
102
+ MonthPicker.displayName = "@mantine/dates/MonthPicker";
103
+
104
+ export { MonthPicker };
105
+ //# sourceMappingURL=MonthPicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.js","sources":["../../../../src/components/CalendarBase/MonthPicker/MonthPicker.tsx"],"sourcesContent":["import React from 'react';\nimport { DefaultProps, ClassNames, UnstyledButton, MantineSize } from '@mantine/core';\nimport { getMonthsNames } from '../../../utils';\nimport { CalendarHeader, CalendarHeaderStylesNames } from '../CalendarHeader/CalendarHeader';\nimport { isMonthInRange } from './is-month-in-range/is-month-in-range';\nimport useStyles from './MonthPicker.styles';\n\nexport type MonthPickerStylesNames = ClassNames<typeof useStyles> | CalendarHeaderStylesNames;\n\nexport interface MonthPickerProps\n extends DefaultProps<MonthPickerStylesNames>,\n Omit<React.ComponentPropsWithoutRef<'div'>, 'onChange'> {\n value: { year: number; month: number };\n onChange(value: number): void;\n locale: string;\n year: number;\n onYearChange(year: number): void;\n onNextLevel(): void;\n size?: MantineSize;\n minDate?: Date;\n maxDate?: Date;\n __staticSelector?: string;\n nextYearLabel?: string;\n previousYearLabel?: string;\n}\n\nexport function MonthPicker({\n className,\n styles,\n classNames,\n value,\n onChange,\n locale,\n year,\n onYearChange,\n onNextLevel,\n size,\n minDate,\n maxDate,\n __staticSelector = 'MonthPicker',\n nextYearLabel,\n previousYearLabel,\n ...others\n}: MonthPickerProps) {\n const { classes, cx } = useStyles({ size }, { classNames, styles, name: __staticSelector });\n const range = getMonthsNames(locale);\n const minYear = minDate instanceof Date ? minDate.getFullYear() : undefined;\n const maxYear = maxDate instanceof Date ? maxDate.getFullYear() : undefined;\n\n const months = range.map((month, index) => (\n <UnstyledButton\n key={month}\n onClick={() => onChange(index)}\n className={cx(classes.monthPickerControl, {\n [classes.monthPickerControlActive]: index === value.month && year === value.year,\n })}\n disabled={!isMonthInRange({ date: new Date(year, index), minDate, maxDate })}\n >\n {month}\n </UnstyledButton>\n ));\n\n return (\n <div className={cx(classes.monthPicker, className)} {...others}>\n <CalendarHeader\n label={year.toString()}\n hasNext={typeof maxYear === 'number' ? year < maxYear : true}\n hasPrevious={typeof minYear === 'number' ? year > minYear : true}\n onNext={() => onYearChange(year + 1)}\n onPrevious={() => onYearChange(year - 1)}\n onNextLevel={onNextLevel}\n size={size}\n classNames={classNames}\n styles={styles}\n __staticSelector={__staticSelector}\n nextLabel={nextYearLabel}\n previousLabel={previousYearLabel}\n />\n <div className={classes.monthPickerControls}>{months}</div>\n </div>\n );\n}\n\nMonthPicker.displayName = '@mantine/dates/MonthPicker';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ import { createStyles, getSharedColorScheme } from '@mantine/core';
2
+
3
+ const sizes = {
4
+ xs: 32,
5
+ sm: 40,
6
+ md: 46,
7
+ lg: 52,
8
+ xl: 56
9
+ };
10
+ var useStyles = createStyles((theme, { size }) => {
11
+ const colors = getSharedColorScheme({ color: theme.primaryColor, theme, variant: "filled" });
12
+ return {
13
+ monthPicker: {},
14
+ monthPickerControls: {
15
+ display: "flex",
16
+ flexWrap: "wrap",
17
+ justifyContent: "center"
18
+ },
19
+ monthPickerControl: {
20
+ flex: "0 0 33.3333%",
21
+ color: theme.colorScheme === "dark" ? theme.colors.dark[0] : theme.black,
22
+ height: theme.fn.size({ size, sizes }),
23
+ textAlign: "center",
24
+ borderRadius: theme.radius.sm,
25
+ fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),
26
+ "&:hover": {
27
+ backgroundColor: theme.colorScheme === "dark" ? theme.colors.dark[8] : theme.colors.gray[0]
28
+ },
29
+ "&:disabled": {
30
+ color: theme.colorScheme === "dark" ? theme.colors.dark[3] : theme.colors.gray[4],
31
+ cursor: "not-allowed",
32
+ "&:hover": {
33
+ backgroundColor: "transparent"
34
+ }
35
+ }
36
+ },
37
+ monthPickerControlActive: {
38
+ backgroundColor: colors.background,
39
+ color: colors.color,
40
+ "&:hover": {
41
+ backgroundColor: colors.hover
42
+ }
43
+ }
44
+ };
45
+ });
46
+
47
+ export default useStyles;
48
+ //# sourceMappingURL=MonthPicker.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthPicker.styles.js","sources":["../../../../src/components/CalendarBase/MonthPicker/MonthPicker.styles.ts"],"sourcesContent":["import { createStyles, getSharedColorScheme, MantineSize } from '@mantine/core';\n\ninterface MonthPickerStyles {\n size: MantineSize;\n}\n\nconst sizes = {\n xs: 32,\n sm: 40,\n md: 46,\n lg: 52,\n xl: 56,\n};\n\nexport default createStyles((theme, { size }: MonthPickerStyles) => {\n const colors = getSharedColorScheme({ color: theme.primaryColor, theme, variant: 'filled' });\n return {\n monthPicker: {},\n\n monthPickerControls: {\n display: 'flex',\n flexWrap: 'wrap',\n justifyContent: 'center',\n },\n\n monthPickerControl: {\n flex: '0 0 33.3333%',\n color: theme.colorScheme === 'dark' ? theme.colors.dark[0] : theme.black,\n height: theme.fn.size({ size, sizes }),\n textAlign: 'center',\n borderRadius: theme.radius.sm,\n fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),\n\n '&:hover': {\n backgroundColor: theme.colorScheme === 'dark' ? theme.colors.dark[8] : theme.colors.gray[0],\n },\n\n '&:disabled': {\n color: theme.colorScheme === 'dark' ? theme.colors.dark[3] : theme.colors.gray[4],\n cursor: 'not-allowed',\n\n '&:hover': {\n backgroundColor: 'transparent',\n },\n },\n },\n\n monthPickerControlActive: {\n backgroundColor: colors.background,\n color: colors.color,\n\n '&:hover': {\n backgroundColor: colors.hover,\n },\n },\n };\n});\n"],"names":[],"mappings":";;AACA,MAAM,KAAK,GAAG;AACd,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,CAAC,CAAC;AACF,gBAAe,YAAY,CAAC,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK;AACjD,EAAE,MAAM,MAAM,GAAG,oBAAoB,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC/F,EAAE,OAAO;AACT,IAAI,WAAW,EAAE,EAAE;AACnB,IAAI,mBAAmB,EAAE;AACzB,MAAM,OAAO,EAAE,MAAM;AACrB,MAAM,QAAQ,EAAE,MAAM;AACtB,MAAM,cAAc,EAAE,QAAQ;AAC9B,KAAK;AACL,IAAI,kBAAkB,EAAE;AACxB,MAAM,IAAI,EAAE,cAAc;AAC1B,MAAM,KAAK,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK;AAC9E,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC5C,MAAM,SAAS,EAAE,QAAQ;AACzB,MAAM,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE;AACnC,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;AAC/D,MAAM,SAAS,EAAE;AACjB,QAAQ,eAAe,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;AACnG,OAAO;AACP,MAAM,YAAY,EAAE;AACpB,QAAQ,KAAK,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;AACzF,QAAQ,MAAM,EAAE,aAAa;AAC7B,QAAQ,SAAS,EAAE;AACnB,UAAU,eAAe,EAAE,aAAa;AACxC,SAAS;AACT,OAAO;AACP,KAAK;AACL,IAAI,wBAAwB,EAAE;AAC9B,MAAM,eAAe,EAAE,MAAM,CAAC,UAAU;AACxC,MAAM,KAAK,EAAE,MAAM,CAAC,KAAK;AACzB,MAAM,SAAS,EAAE;AACjB,QAAQ,eAAe,EAAE,MAAM,CAAC,KAAK;AACrC,OAAO;AACP,KAAK;AACL,GAAG,CAAC;AACJ,CAAC,CAAC;;;;"}
@@ -0,0 +1,17 @@
1
+ import dayjs from 'dayjs';
2
+
3
+ function isMonthInRange({ date, minDate, maxDate }) {
4
+ const hasMinDate = minDate instanceof Date;
5
+ const hasMaxDate = maxDate instanceof Date;
6
+ if (!hasMaxDate && !hasMinDate) {
7
+ return true;
8
+ }
9
+ const endOfMonth = dayjs(date).endOf("month");
10
+ const startOfMonth = dayjs(date).startOf("month");
11
+ const maxInRange = hasMaxDate ? startOfMonth.isBefore(maxDate) : true;
12
+ const minInRange = hasMinDate ? endOfMonth.isAfter(minDate) : true;
13
+ return maxInRange && minInRange;
14
+ }
15
+
16
+ export { isMonthInRange };
17
+ //# sourceMappingURL=is-month-in-range.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"is-month-in-range.js","sources":["../../../../../src/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.ts"],"sourcesContent":["import dayjs from 'dayjs';\n\ninterface IsMonthInRange {\n date: Date;\n minDate?: Date;\n maxDate?: Date;\n}\n\nexport function isMonthInRange({ date, minDate, maxDate }: IsMonthInRange) {\n const hasMinDate = minDate instanceof Date;\n const hasMaxDate = maxDate instanceof Date;\n\n if (!hasMaxDate && !hasMinDate) {\n return true;\n }\n\n const endOfMonth = dayjs(date).endOf('month');\n const startOfMonth = dayjs(date).startOf('month');\n const maxInRange = hasMaxDate ? startOfMonth.isBefore(maxDate) : true;\n const minInRange = hasMinDate ? endOfMonth.isAfter(minDate) : true;\n return maxInRange && minInRange;\n}\n"],"names":[],"mappings":";;AACO,SAAS,cAAc,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;AAC3D,EAAE,MAAM,UAAU,GAAG,OAAO,YAAY,IAAI,CAAC;AAC7C,EAAE,MAAM,UAAU,GAAG,OAAO,YAAY,IAAI,CAAC;AAC7C,EAAE,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,EAAE;AAClC,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG;AACH,EAAE,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AAChD,EAAE,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AACpD,EAAE,MAAM,UAAU,GAAG,UAAU,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;AACxE,EAAE,MAAM,UAAU,GAAG,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;AACrE,EAAE,OAAO,UAAU,IAAI,UAAU,CAAC;AAClC;;;;"}
@@ -0,0 +1,114 @@
1
+ import React from 'react';
2
+ import dayjs from 'dayjs';
3
+ import { formatMonthLabel } from './format-month-label/format-month-label.js';
4
+ import { isMonthInRange } from '../MonthPicker/is-month-in-range/is-month-in-range.js';
5
+ import { CalendarHeader } from '../CalendarHeader/CalendarHeader.js';
6
+ import { Month } from '../../Month/Month.js';
7
+
8
+ var __defProp = Object.defineProperty;
9
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
10
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
11
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
+ var __spreadValues = (a, b) => {
14
+ for (var prop in b || (b = {}))
15
+ if (__hasOwnProp.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ if (__getOwnPropSymbols)
18
+ for (var prop of __getOwnPropSymbols(b)) {
19
+ if (__propIsEnum.call(b, prop))
20
+ __defNormalProp(a, prop, b[prop]);
21
+ }
22
+ return a;
23
+ };
24
+ var __objRest = (source, exclude) => {
25
+ var target = {};
26
+ for (var prop in source)
27
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
28
+ target[prop] = source[prop];
29
+ if (source != null && __getOwnPropSymbols)
30
+ for (var prop of __getOwnPropSymbols(source)) {
31
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
32
+ target[prop] = source[prop];
33
+ }
34
+ return target;
35
+ };
36
+ function MonthsList(_a) {
37
+ var _b = _a, {
38
+ amountOfMonths,
39
+ month,
40
+ locale,
41
+ minDate,
42
+ maxDate,
43
+ allowLevelChange,
44
+ size,
45
+ daysRefs,
46
+ onMonthChange,
47
+ onNextLevel,
48
+ onDayKeyDown,
49
+ classNames,
50
+ styles,
51
+ __staticSelector = "MonthsList",
52
+ nextMonthLabel,
53
+ previousMonthLabel,
54
+ labelFormat
55
+ } = _b, others = __objRest(_b, [
56
+ "amountOfMonths",
57
+ "month",
58
+ "locale",
59
+ "minDate",
60
+ "maxDate",
61
+ "allowLevelChange",
62
+ "size",
63
+ "daysRefs",
64
+ "onMonthChange",
65
+ "onNextLevel",
66
+ "onDayKeyDown",
67
+ "classNames",
68
+ "styles",
69
+ "__staticSelector",
70
+ "nextMonthLabel",
71
+ "previousMonthLabel",
72
+ "labelFormat"
73
+ ]);
74
+ const nextMonth = dayjs(month).add(amountOfMonths, "months").toDate();
75
+ const previousMonth = dayjs(month).subtract(1, "months").toDate();
76
+ const months = Array(amountOfMonths).fill(0).map((_, index) => {
77
+ const monthDate = dayjs(month).add(index, "months").toDate();
78
+ return /* @__PURE__ */ React.createElement("div", {
79
+ key: index
80
+ }, /* @__PURE__ */ React.createElement(CalendarHeader, {
81
+ hasNext: index + 1 === amountOfMonths && isMonthInRange({ date: nextMonth, minDate, maxDate }),
82
+ hasPrevious: index === 0 && isMonthInRange({ date: previousMonth, minDate, maxDate }),
83
+ label: formatMonthLabel({ month: monthDate, locale, format: labelFormat }),
84
+ onNext: () => onMonthChange(dayjs(month).add(amountOfMonths, "months").toDate()),
85
+ onPrevious: () => onMonthChange(dayjs(month).subtract(amountOfMonths, "months").toDate()),
86
+ onNextLevel,
87
+ nextLevelDisabled: !allowLevelChange,
88
+ size,
89
+ classNames,
90
+ styles,
91
+ __staticSelector,
92
+ nextLabel: nextMonthLabel,
93
+ previousLabel: previousMonthLabel,
94
+ preventLevelFocus: index > 0
95
+ }), /* @__PURE__ */ React.createElement(Month, __spreadValues({
96
+ month: monthDate,
97
+ daysRefs: daysRefs.current[index],
98
+ onDayKeyDown: (...args) => onDayKeyDown(index, ...args),
99
+ size,
100
+ minDate,
101
+ maxDate,
102
+ classNames,
103
+ styles,
104
+ __staticSelector,
105
+ locale,
106
+ focusable: index === 0
107
+ }, others)));
108
+ });
109
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, months);
110
+ }
111
+ MonthsList.displayName = "@mantine/dates/MonthsList";
112
+
113
+ export { MonthsList };
114
+ //# sourceMappingURL=MonthsList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MonthsList.js","sources":["../../../../src/components/CalendarBase/MonthsList/MonthsList.tsx"],"sourcesContent":["import React from 'react';\nimport dayjs from 'dayjs';\nimport { DefaultProps } from '@mantine/core';\nimport { formatMonthLabel } from './format-month-label/format-month-label';\nimport { isMonthInRange } from '../MonthPicker/is-month-in-range/is-month-in-range';\nimport { CalendarHeader, CalendarHeaderStylesNames } from '../CalendarHeader/CalendarHeader';\nimport { Month, MonthProps, DayKeydownPayload, MonthStylesNames } from '../../Month';\n\nexport type MonthsListStylesNames = CalendarHeaderStylesNames | MonthStylesNames;\n\nexport interface MonthsListProps\n extends DefaultProps<MonthsListStylesNames>,\n Omit<MonthProps, 'styles' | 'classNames' | 'daysRefs' | 'onDayKeyDown'> {\n amountOfMonths: number;\n month: Date;\n locale: string;\n allowLevelChange: boolean;\n daysRefs: React.RefObject<HTMLButtonElement[][][]>;\n onMonthChange(month: Date): void;\n onNextLevel(): void;\n onDayKeyDown(\n monthIndex: number,\n payload: DayKeydownPayload,\n event: React.KeyboardEvent<HTMLButtonElement>\n ): void;\n __staticSelector?: string;\n nextMonthLabel?: string;\n previousMonthLabel?: string;\n labelFormat?: string;\n}\n\nexport function MonthsList({\n amountOfMonths,\n month,\n locale,\n minDate,\n maxDate,\n allowLevelChange,\n size,\n daysRefs,\n onMonthChange,\n onNextLevel,\n onDayKeyDown,\n classNames,\n styles,\n __staticSelector = 'MonthsList',\n nextMonthLabel,\n previousMonthLabel,\n labelFormat,\n ...others\n}: MonthsListProps) {\n const nextMonth = dayjs(month).add(amountOfMonths, 'months').toDate();\n const previousMonth = dayjs(month).subtract(1, 'months').toDate();\n\n const months = Array(amountOfMonths)\n .fill(0)\n .map((_, index) => {\n const monthDate = dayjs(month).add(index, 'months').toDate();\n return (\n <div key={index}>\n <CalendarHeader\n hasNext={\n index + 1 === amountOfMonths && isMonthInRange({ date: nextMonth, minDate, maxDate })\n }\n hasPrevious={index === 0 && isMonthInRange({ date: previousMonth, minDate, maxDate })}\n label={formatMonthLabel({ month: monthDate, locale, format: labelFormat })}\n onNext={() => onMonthChange(dayjs(month).add(amountOfMonths, 'months').toDate())}\n onPrevious={() =>\n onMonthChange(dayjs(month).subtract(amountOfMonths, 'months').toDate())\n }\n onNextLevel={onNextLevel}\n nextLevelDisabled={!allowLevelChange}\n size={size}\n classNames={classNames}\n styles={styles}\n __staticSelector={__staticSelector}\n nextLabel={nextMonthLabel}\n previousLabel={previousMonthLabel}\n preventLevelFocus={index > 0}\n />\n\n <Month\n month={monthDate}\n daysRefs={daysRefs.current[index]}\n onDayKeyDown={(...args) => onDayKeyDown(index, ...args)}\n size={size}\n minDate={minDate}\n maxDate={maxDate}\n classNames={classNames}\n styles={styles}\n __staticSelector={__staticSelector}\n locale={locale}\n focusable={index === 0}\n {...others}\n />\n </div>\n );\n });\n\n return <>{months}</>;\n}\n\nMonthsList.displayName = '@mantine/dates/MonthsList';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import dayjs from 'dayjs';
2
+ import { upperFirst } from '@mantine/hooks';
3
+
4
+ function formatMonthLabel({ month, locale, format }) {
5
+ return upperFirst(dayjs(month).locale(locale).format(format));
6
+ }
7
+
8
+ export { formatMonthLabel };
9
+ //# sourceMappingURL=format-month-label.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"format-month-label.js","sources":["../../../../../src/components/CalendarBase/MonthsList/format-month-label/format-month-label.ts"],"sourcesContent":["import dayjs from 'dayjs';\nimport { upperFirst } from '@mantine/hooks';\n\ninterface FormatMonthLabel {\n month: Date;\n locale: string;\n format: string;\n}\n\nexport function formatMonthLabel({ month, locale, format }: FormatMonthLabel) {\n return upperFirst(dayjs(month).locale(locale).format(format));\n}\n"],"names":[],"mappings":";;;AAEO,SAAS,gBAAgB,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE;AAC5D,EAAE,OAAO,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;AAChE;;;;"}
@@ -0,0 +1,94 @@
1
+ import React, { useState } from 'react';
2
+ import { UnstyledButton } from '@mantine/core';
3
+ import { getDecadeRange } from './get-decade-range/get-decade-range.js';
4
+ import { CalendarHeader } from '../CalendarHeader/CalendarHeader.js';
5
+ import useStyles from './YearPicker.styles.js';
6
+
7
+ var __defProp = Object.defineProperty;
8
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
10
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
+ var __spreadValues = (a, b) => {
13
+ for (var prop in b || (b = {}))
14
+ if (__hasOwnProp.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ if (__getOwnPropSymbols)
17
+ for (var prop of __getOwnPropSymbols(b)) {
18
+ if (__propIsEnum.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ }
21
+ return a;
22
+ };
23
+ var __objRest = (source, exclude) => {
24
+ var target = {};
25
+ for (var prop in source)
26
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
27
+ target[prop] = source[prop];
28
+ if (source != null && __getOwnPropSymbols)
29
+ for (var prop of __getOwnPropSymbols(source)) {
30
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
31
+ target[prop] = source[prop];
32
+ }
33
+ return target;
34
+ };
35
+ function YearPicker(_a) {
36
+ var _b = _a, {
37
+ className,
38
+ styles,
39
+ classNames,
40
+ value,
41
+ onChange,
42
+ size,
43
+ minYear,
44
+ maxYear,
45
+ __staticSelector = "YearPicker",
46
+ nextDecadeLabel,
47
+ previousDecadeLabel
48
+ } = _b, others = __objRest(_b, [
49
+ "className",
50
+ "styles",
51
+ "classNames",
52
+ "value",
53
+ "onChange",
54
+ "size",
55
+ "minYear",
56
+ "maxYear",
57
+ "__staticSelector",
58
+ "nextDecadeLabel",
59
+ "previousDecadeLabel"
60
+ ]);
61
+ const { classes, cx } = useStyles({ size }, { classNames, styles, name: __staticSelector });
62
+ const [decade, setDecade] = useState(value);
63
+ const range = getDecadeRange(decade);
64
+ const years = range.map((year) => /* @__PURE__ */ React.createElement(UnstyledButton, {
65
+ key: year,
66
+ onClick: () => onChange(year),
67
+ disabled: year < minYear || year > maxYear,
68
+ className: cx(classes.yearPickerControl, {
69
+ [classes.yearPickerControlActive]: year === value
70
+ })
71
+ }, year));
72
+ return /* @__PURE__ */ React.createElement("div", __spreadValues({
73
+ className: cx(classes.yearPicker, className)
74
+ }, others), /* @__PURE__ */ React.createElement(CalendarHeader, {
75
+ label: `${range[0]} \u2013 ${range[range.length - 1]}`,
76
+ hasPrevious: typeof minYear === "number" ? minYear < range[0] : true,
77
+ hasNext: typeof maxYear === "number" ? maxYear > range[range.length - 1] : true,
78
+ onNext: () => setDecade((current) => current + 10),
79
+ onPrevious: () => setDecade((current) => current - 10),
80
+ nextLevelDisabled: true,
81
+ size,
82
+ nextLabel: nextDecadeLabel,
83
+ previousLabel: previousDecadeLabel,
84
+ styles,
85
+ classNames,
86
+ __staticSelector
87
+ }), /* @__PURE__ */ React.createElement("div", {
88
+ className: classes.yearPickerControls
89
+ }, years));
90
+ }
91
+ YearPicker.displayName = "@mantine/dates/YearPicker";
92
+
93
+ export { YearPicker };
94
+ //# sourceMappingURL=YearPicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YearPicker.js","sources":["../../../../src/components/CalendarBase/YearPicker/YearPicker.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { DefaultProps, ClassNames, UnstyledButton, MantineSize } from '@mantine/core';\nimport { getDecadeRange } from './get-decade-range/get-decade-range';\nimport { CalendarHeader, CalendarHeaderStylesNames } from '../CalendarHeader/CalendarHeader';\nimport useStyles from './YearPicker.styles';\n\nexport type YearPickerStylesNames = ClassNames<typeof useStyles> | CalendarHeaderStylesNames;\n\nexport interface YearPickerProps\n extends DefaultProps<YearPickerStylesNames>,\n Omit<React.ComponentPropsWithoutRef<'div'>, 'onChange'> {\n value: number;\n onChange(value: number): void;\n minYear?: number;\n maxYear?: number;\n size?: MantineSize;\n __staticSelector?: string;\n nextDecadeLabel?: string;\n previousDecadeLabel?: string;\n}\n\nexport function YearPicker({\n className,\n styles,\n classNames,\n value,\n onChange,\n size,\n minYear,\n maxYear,\n __staticSelector = 'YearPicker',\n nextDecadeLabel,\n previousDecadeLabel,\n ...others\n}: YearPickerProps) {\n const { classes, cx } = useStyles({ size }, { classNames, styles, name: __staticSelector });\n const [decade, setDecade] = useState(value);\n const range = getDecadeRange(decade);\n\n const years = range.map((year) => (\n <UnstyledButton\n key={year}\n onClick={() => onChange(year)}\n disabled={year < minYear || year > maxYear}\n className={cx(classes.yearPickerControl, {\n [classes.yearPickerControlActive]: year === value,\n })}\n >\n {year}\n </UnstyledButton>\n ));\n\n return (\n <div className={cx(classes.yearPicker, className)} {...others}>\n <CalendarHeader\n label={`${range[0]} – ${range[range.length - 1]}`}\n hasPrevious={typeof minYear === 'number' ? minYear < range[0] : true}\n hasNext={typeof maxYear === 'number' ? maxYear > range[range.length - 1] : true}\n onNext={() => setDecade((current) => current + 10)}\n onPrevious={() => setDecade((current) => current - 10)}\n nextLevelDisabled\n size={size}\n nextLabel={nextDecadeLabel}\n previousLabel={previousDecadeLabel}\n styles={styles}\n classNames={classNames}\n __staticSelector={__staticSelector}\n />\n <div className={classes.yearPickerControls}>{years}</div>\n </div>\n );\n}\n\nYearPicker.displayName = '@mantine/dates/YearPicker';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ import { createStyles, getSharedColorScheme } from '@mantine/core';
2
+
3
+ const sizes = {
4
+ xs: 32,
5
+ sm: 40,
6
+ md: 46,
7
+ lg: 52,
8
+ xl: 56
9
+ };
10
+ var useStyles = createStyles((theme, { size }) => {
11
+ const colors = getSharedColorScheme({ color: theme.primaryColor, theme, variant: "filled" });
12
+ return {
13
+ yearPicker: {
14
+ width: "100%"
15
+ },
16
+ yearPickerControls: {
17
+ display: "flex",
18
+ flexWrap: "wrap",
19
+ justifyContent: "center"
20
+ },
21
+ yearPickerControl: {
22
+ flex: "0 0 25%",
23
+ color: theme.colorScheme === "dark" ? theme.colors.dark[0] : theme.black,
24
+ height: theme.fn.size({ size, sizes }),
25
+ textAlign: "center",
26
+ borderRadius: theme.radius.sm,
27
+ fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),
28
+ "&:hover": {
29
+ backgroundColor: theme.colorScheme === "dark" ? theme.colors.dark[8] : theme.colors.gray[0]
30
+ },
31
+ "&:disabled": {
32
+ color: theme.colorScheme === "dark" ? theme.colors.dark[3] : theme.colors.gray[4],
33
+ cursor: "not-allowed",
34
+ "&:hover": {
35
+ backgroundColor: "transparent"
36
+ }
37
+ }
38
+ },
39
+ yearPickerControlActive: {
40
+ backgroundColor: colors.background,
41
+ color: colors.color,
42
+ "&:hover": {
43
+ backgroundColor: colors.hover
44
+ }
45
+ }
46
+ };
47
+ });
48
+
49
+ export default useStyles;
50
+ //# sourceMappingURL=YearPicker.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YearPicker.styles.js","sources":["../../../../src/components/CalendarBase/YearPicker/YearPicker.styles.ts"],"sourcesContent":["import { createStyles, getSharedColorScheme, MantineSize } from '@mantine/core';\n\ninterface YearPickerStyles {\n size: MantineSize;\n}\n\nconst sizes = {\n xs: 32,\n sm: 40,\n md: 46,\n lg: 52,\n xl: 56,\n};\n\nexport default createStyles((theme, { size }: YearPickerStyles) => {\n const colors = getSharedColorScheme({ color: theme.primaryColor, theme, variant: 'filled' });\n\n return {\n yearPicker: {\n width: '100%',\n },\n\n yearPickerControls: {\n display: 'flex',\n flexWrap: 'wrap',\n justifyContent: 'center',\n },\n\n yearPickerControl: {\n flex: '0 0 25%',\n color: theme.colorScheme === 'dark' ? theme.colors.dark[0] : theme.black,\n height: theme.fn.size({ size, sizes }),\n textAlign: 'center',\n borderRadius: theme.radius.sm,\n fontSize: theme.fn.size({ size, sizes: theme.fontSizes }),\n\n '&:hover': {\n backgroundColor: theme.colorScheme === 'dark' ? theme.colors.dark[8] : theme.colors.gray[0],\n },\n\n '&:disabled': {\n color: theme.colorScheme === 'dark' ? theme.colors.dark[3] : theme.colors.gray[4],\n cursor: 'not-allowed',\n\n '&:hover': {\n backgroundColor: 'transparent',\n },\n },\n },\n\n yearPickerControlActive: {\n backgroundColor: colors.background,\n color: colors.color,\n\n '&:hover': {\n backgroundColor: colors.hover,\n },\n },\n };\n});\n"],"names":[],"mappings":";;AACA,MAAM,KAAK,GAAG;AACd,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,EAAE,EAAE,EAAE;AACR,CAAC,CAAC;AACF,gBAAe,YAAY,CAAC,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK;AACjD,EAAE,MAAM,MAAM,GAAG,oBAAoB,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC/F,EAAE,OAAO;AACT,IAAI,UAAU,EAAE;AAChB,MAAM,KAAK,EAAE,MAAM;AACnB,KAAK;AACL,IAAI,kBAAkB,EAAE;AACxB,MAAM,OAAO,EAAE,MAAM;AACrB,MAAM,QAAQ,EAAE,MAAM;AACtB,MAAM,cAAc,EAAE,QAAQ;AAC9B,KAAK;AACL,IAAI,iBAAiB,EAAE;AACvB,MAAM,IAAI,EAAE,SAAS;AACrB,MAAM,KAAK,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK;AAC9E,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC5C,MAAM,SAAS,EAAE,QAAQ;AACzB,MAAM,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE;AACnC,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;AAC/D,MAAM,SAAS,EAAE;AACjB,QAAQ,eAAe,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;AACnG,OAAO;AACP,MAAM,YAAY,EAAE;AACpB,QAAQ,KAAK,EAAE,KAAK,CAAC,WAAW,KAAK,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;AACzF,QAAQ,MAAM,EAAE,aAAa;AAC7B,QAAQ,SAAS,EAAE;AACnB,UAAU,eAAe,EAAE,aAAa;AACxC,SAAS;AACT,OAAO;AACP,KAAK;AACL,IAAI,uBAAuB,EAAE;AAC7B,MAAM,eAAe,EAAE,MAAM,CAAC,UAAU;AACxC,MAAM,KAAK,EAAE,MAAM,CAAC,KAAK;AACzB,MAAM,SAAS,EAAE;AACjB,QAAQ,eAAe,EAAE,MAAM,CAAC,KAAK;AACrC,OAAO;AACP,KAAK;AACL,GAAG,CAAC;AACJ,CAAC,CAAC;;;;"}
@@ -0,0 +1,12 @@
1
+ function getDecadeRange(year) {
2
+ const rounded = year - year % 10 - 1;
3
+ const range = [];
4
+ for (let i = 0; i < 12; i += 1) {
5
+ const rangeYear = rounded + i;
6
+ range.push(rangeYear);
7
+ }
8
+ return range;
9
+ }
10
+
11
+ export { getDecadeRange };
12
+ //# sourceMappingURL=get-decade-range.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-decade-range.js","sources":["../../../../../src/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.ts"],"sourcesContent":["export function getDecadeRange(year: number) {\n const rounded = year - (year % 10) - 1;\n const range: number[] = [];\n for (let i = 0; i < 12; i += 1) {\n const rangeYear = rounded + i;\n range.push(rangeYear);\n }\n\n return range;\n}\n"],"names":[],"mappings":"AAAO,SAAS,cAAc,CAAC,IAAI,EAAE;AACrC,EAAE,MAAM,OAAO,GAAG,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,CAAC,CAAC;AACvC,EAAE,MAAM,KAAK,GAAG,EAAE,CAAC;AACnB,EAAE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE;AAClC,IAAI,MAAM,SAAS,GAAG,OAAO,GAAG,CAAC,CAAC;AAClC,IAAI,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;AAC1B,GAAG;AACH,EAAE,OAAO,KAAK,CAAC;AACf;;;;"}