@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.
- package/cjs/components/Calendar/Calendar.js +6 -137
- package/cjs/components/Calendar/Calendar.js.map +1 -1
- package/cjs/components/CalendarBase/CalendarBase.js +242 -0
- package/cjs/components/CalendarBase/CalendarBase.js.map +1 -0
- package/cjs/components/CalendarBase/CalendarBase.styles.js +22 -0
- package/cjs/components/CalendarBase/CalendarBase.styles.js.map +1 -0
- package/cjs/components/{Calendar → CalendarBase/CalendarHeader}/ArrowIcon.js +0 -0
- package/cjs/components/CalendarBase/CalendarHeader/ArrowIcon.js.map +1 -0
- package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.js +119 -0
- package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.js.map +1 -0
- package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js +58 -0
- package/cjs/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js.map +1 -0
- package/cjs/components/CalendarBase/MonthPicker/MonthPicker.js +113 -0
- package/cjs/components/CalendarBase/MonthPicker/MonthPicker.js.map +1 -0
- package/cjs/components/CalendarBase/MonthPicker/MonthPicker.styles.js +52 -0
- package/cjs/components/CalendarBase/MonthPicker/MonthPicker.styles.js.map +1 -0
- package/cjs/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js +25 -0
- package/cjs/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js.map +1 -0
- package/cjs/components/CalendarBase/MonthsList/MonthsList.js +123 -0
- package/cjs/components/CalendarBase/MonthsList/MonthsList.js.map +1 -0
- package/cjs/components/CalendarBase/MonthsList/format-month-label/format-month-label.js +17 -0
- package/cjs/components/CalendarBase/MonthsList/format-month-label/format-month-label.js.map +1 -0
- package/cjs/components/CalendarBase/YearPicker/YearPicker.js +102 -0
- package/cjs/components/CalendarBase/YearPicker/YearPicker.js.map +1 -0
- package/cjs/components/CalendarBase/YearPicker/YearPicker.styles.js +54 -0
- package/cjs/components/CalendarBase/YearPicker/YearPicker.styles.js.map +1 -0
- package/cjs/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js +16 -0
- package/cjs/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js.map +1 -0
- package/cjs/components/DatePicker/DatePicker.js +10 -10
- package/cjs/components/DatePicker/DatePicker.js.map +1 -1
- package/cjs/components/DatePickerBase/DatePickerBase.js +5 -5
- package/cjs/components/DatePickerBase/DatePickerBase.js.map +1 -1
- package/cjs/components/DateRangePicker/DateRangePicker.js +0 -6
- package/cjs/components/DateRangePicker/DateRangePicker.js.map +1 -1
- package/cjs/components/Month/Day/Day.js +12 -15
- package/cjs/components/Month/Day/Day.js.map +1 -1
- package/cjs/components/Month/Day/Day.styles.js +2 -1
- package/cjs/components/Month/Day/Day.styles.js.map +1 -1
- package/cjs/components/Month/Day/get-day-autofocus/get-day-autofocus.js +13 -0
- package/cjs/components/Month/Day/get-day-autofocus/get-day-autofocus.js.map +1 -0
- package/cjs/components/Month/Day/get-day-tab-index/get-day-tab-index.js +16 -0
- package/cjs/components/Month/Day/get-day-tab-index/get-day-tab-index.js.map +1 -0
- package/cjs/components/Month/Month.js +36 -67
- package/cjs/components/Month/Month.js.map +1 -1
- package/cjs/components/Month/Month.styles.js +1 -1
- package/cjs/components/Month/Month.styles.js.map +1 -1
- package/cjs/components/Month/get-day-props/get-day-props.js +9 -24
- package/cjs/components/Month/get-day-props/get-day-props.js.map +1 -1
- package/cjs/components/Month/get-day-props/get-range-props/get-range-props.js +25 -0
- package/cjs/components/Month/get-day-props/get-range-props/get-range-props.js.map +1 -0
- package/cjs/components/Month/get-day-props/is-disabled/is-disabled.js +27 -0
- package/cjs/components/Month/get-day-props/is-disabled/is-disabled.js.map +1 -0
- package/cjs/components/Month/get-day-props/is-outside/is-outside.js +13 -0
- package/cjs/components/Month/get-day-props/is-outside/is-outside.js.map +1 -0
- package/cjs/components/Month/get-day-props/is-weekend/is-weekend.js +11 -0
- package/cjs/components/Month/get-day-props/is-weekend/is-weekend.js.map +1 -0
- package/cjs/components/RangeCalendar/RangeCalendar.js +19 -122
- package/cjs/components/RangeCalendar/RangeCalendar.js.map +1 -1
- package/cjs/components/TimeInput/TimeField/TimeField.js +6 -1
- package/cjs/components/TimeInput/TimeField/TimeField.js.map +1 -1
- package/cjs/components/TimeInput/TimeField/TimeField.styles.js +54 -0
- package/cjs/components/TimeInput/TimeField/TimeField.styles.js.map +1 -0
- package/cjs/components/TimeInput/TimeInput.styles.js +1 -24
- package/cjs/components/TimeInput/TimeInput.styles.js.map +1 -1
- package/cjs/components/TimeRangeInput/TimeRangeInput.styles.js +2 -19
- package/cjs/components/TimeRangeInput/TimeRangeInput.styles.js.map +1 -1
- package/cjs/utils/get-months-names/get-months-names.js +2 -2
- package/cjs/utils/get-months-names/get-months-names.js.map +1 -1
- package/esm/components/Calendar/Calendar.js +6 -136
- package/esm/components/Calendar/Calendar.js.map +1 -1
- package/esm/components/CalendarBase/CalendarBase.js +234 -0
- package/esm/components/CalendarBase/CalendarBase.js.map +1 -0
- package/esm/components/CalendarBase/CalendarBase.styles.js +18 -0
- package/esm/components/CalendarBase/CalendarBase.styles.js.map +1 -0
- package/esm/components/{Calendar → CalendarBase/CalendarHeader}/ArrowIcon.js +0 -0
- package/esm/components/CalendarBase/CalendarHeader/ArrowIcon.js.map +1 -0
- package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.js +111 -0
- package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.js.map +1 -0
- package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js +54 -0
- package/esm/components/CalendarBase/CalendarHeader/CalendarHeader.styles.js.map +1 -0
- package/esm/components/CalendarBase/MonthPicker/MonthPicker.js +105 -0
- package/esm/components/CalendarBase/MonthPicker/MonthPicker.js.map +1 -0
- package/esm/components/CalendarBase/MonthPicker/MonthPicker.styles.js +48 -0
- package/esm/components/CalendarBase/MonthPicker/MonthPicker.styles.js.map +1 -0
- package/esm/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js +17 -0
- package/esm/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.js.map +1 -0
- package/esm/components/CalendarBase/MonthsList/MonthsList.js +114 -0
- package/esm/components/CalendarBase/MonthsList/MonthsList.js.map +1 -0
- package/esm/components/CalendarBase/MonthsList/format-month-label/format-month-label.js +9 -0
- package/esm/components/CalendarBase/MonthsList/format-month-label/format-month-label.js.map +1 -0
- package/esm/components/CalendarBase/YearPicker/YearPicker.js +94 -0
- package/esm/components/CalendarBase/YearPicker/YearPicker.js.map +1 -0
- package/esm/components/CalendarBase/YearPicker/YearPicker.styles.js +50 -0
- package/esm/components/CalendarBase/YearPicker/YearPicker.styles.js.map +1 -0
- package/esm/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js +12 -0
- package/esm/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.js.map +1 -0
- package/esm/components/DatePicker/DatePicker.js +10 -10
- package/esm/components/DatePicker/DatePicker.js.map +1 -1
- package/esm/components/DatePickerBase/DatePickerBase.js +6 -6
- package/esm/components/DatePickerBase/DatePickerBase.js.map +1 -1
- package/esm/components/DateRangePicker/DateRangePicker.js +0 -6
- package/esm/components/DateRangePicker/DateRangePicker.js.map +1 -1
- package/esm/components/Month/Day/Day.js +12 -15
- package/esm/components/Month/Day/Day.js.map +1 -1
- package/esm/components/Month/Day/Day.styles.js +2 -1
- package/esm/components/Month/Day/Day.styles.js.map +1 -1
- package/esm/components/Month/Day/get-day-autofocus/get-day-autofocus.js +9 -0
- package/esm/components/Month/Day/get-day-autofocus/get-day-autofocus.js.map +1 -0
- package/esm/components/Month/Day/get-day-tab-index/get-day-tab-index.js +12 -0
- package/esm/components/Month/Day/get-day-tab-index/get-day-tab-index.js.map +1 -0
- package/esm/components/Month/Month.js +38 -69
- package/esm/components/Month/Month.js.map +1 -1
- package/esm/components/Month/Month.styles.js +1 -1
- package/esm/components/Month/Month.styles.js.map +1 -1
- package/esm/components/Month/get-day-props/get-day-props.js +9 -20
- package/esm/components/Month/get-day-props/get-day-props.js.map +1 -1
- package/esm/components/Month/get-day-props/get-range-props/get-range-props.js +17 -0
- package/esm/components/Month/get-day-props/get-range-props/get-range-props.js.map +1 -0
- package/esm/components/Month/get-day-props/is-disabled/is-disabled.js +19 -0
- package/esm/components/Month/get-day-props/is-disabled/is-disabled.js.map +1 -0
- package/esm/components/Month/get-day-props/is-outside/is-outside.js +9 -0
- package/esm/components/Month/get-day-props/is-outside/is-outside.js.map +1 -0
- package/esm/components/Month/get-day-props/is-weekend/is-weekend.js +7 -0
- package/esm/components/Month/get-day-props/is-weekend/is-weekend.js.map +1 -0
- package/esm/components/RangeCalendar/RangeCalendar.js +20 -123
- package/esm/components/RangeCalendar/RangeCalendar.js.map +1 -1
- package/esm/components/TimeInput/TimeField/TimeField.js +6 -1
- package/esm/components/TimeInput/TimeField/TimeField.js.map +1 -1
- package/esm/components/TimeInput/TimeField/TimeField.styles.js +50 -0
- package/esm/components/TimeInput/TimeField/TimeField.styles.js.map +1 -0
- package/esm/components/TimeInput/TimeInput.styles.js +1 -24
- package/esm/components/TimeInput/TimeInput.styles.js.map +1 -1
- package/esm/components/TimeRangeInput/TimeRangeInput.styles.js +2 -19
- package/esm/components/TimeRangeInput/TimeRangeInput.styles.js.map +1 -1
- package/esm/utils/get-months-names/get-months-names.js +2 -2
- package/esm/utils/get-months-names/get-months-names.js.map +1 -1
- package/lib/components/Calendar/Calendar.d.ts +3 -45
- package/lib/components/Calendar/Calendar.d.ts.map +1 -1
- package/lib/components/Calendar/index.d.ts +1 -1
- package/lib/components/Calendar/index.d.ts.map +1 -1
- package/lib/components/CalendarBase/CalendarBase.d.ts +56 -0
- package/lib/components/CalendarBase/CalendarBase.d.ts.map +1 -0
- package/lib/components/CalendarBase/CalendarBase.styles.d.ts +13 -0
- package/lib/components/CalendarBase/CalendarBase.styles.d.ts.map +1 -0
- package/lib/components/CalendarBase/CalendarHeader/ArrowIcon.d.ts +10 -0
- package/lib/components/CalendarBase/CalendarHeader/ArrowIcon.d.ts.map +1 -0
- package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.d.ts +24 -0
- package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.d.ts.map +1 -0
- package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.styles.d.ts +18 -0
- package/lib/components/CalendarBase/CalendarHeader/CalendarHeader.styles.d.ts.map +1 -0
- package/lib/components/CalendarBase/MonthPicker/MonthPicker.d.ts +27 -0
- package/lib/components/CalendarBase/MonthPicker/MonthPicker.d.ts.map +1 -0
- package/lib/components/CalendarBase/MonthPicker/MonthPicker.styles.d.ts +11 -0
- package/lib/components/CalendarBase/MonthPicker/MonthPicker.styles.d.ts.map +1 -0
- package/lib/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.d.ts +8 -0
- package/lib/components/CalendarBase/MonthPicker/is-month-in-range/is-month-in-range.d.ts.map +1 -0
- package/lib/components/CalendarBase/MonthsList/MonthsList.d.ts +24 -0
- package/lib/components/CalendarBase/MonthsList/MonthsList.d.ts.map +1 -0
- package/lib/components/CalendarBase/MonthsList/format-month-label/format-month-label.d.ts +8 -0
- package/lib/components/CalendarBase/MonthsList/format-month-label/format-month-label.d.ts.map +1 -0
- package/lib/components/CalendarBase/YearPicker/YearPicker.d.ts +20 -0
- package/lib/components/CalendarBase/YearPicker/YearPicker.d.ts.map +1 -0
- package/lib/components/CalendarBase/YearPicker/YearPicker.styles.d.ts +11 -0
- package/lib/components/CalendarBase/YearPicker/YearPicker.styles.d.ts.map +1 -0
- package/lib/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.d.ts +2 -0
- package/lib/components/CalendarBase/YearPicker/get-decade-range/get-decade-range.d.ts.map +1 -0
- package/lib/components/DatePicker/DatePicker.d.ts +2 -2
- package/lib/components/DatePicker/DatePicker.d.ts.map +1 -1
- package/lib/components/DatePickerBase/DatePickerBase.d.ts +2 -2
- package/lib/components/DatePickerBase/DatePickerBase.d.ts.map +1 -1
- package/lib/components/DateRangePicker/DateRangePicker.d.ts +2 -2
- package/lib/components/DateRangePicker/DateRangePicker.d.ts.map +1 -1
- package/lib/components/Month/Day/Day.d.ts +3 -3
- package/lib/components/Month/Day/Day.d.ts.map +1 -1
- package/lib/components/Month/Day/Day.styles.d.ts +3 -2
- package/lib/components/Month/Day/Day.styles.d.ts.map +1 -1
- package/lib/components/Month/Day/get-day-autofocus/get-day-autofocus.d.ts +8 -0
- package/lib/components/Month/Day/get-day-autofocus/get-day-autofocus.d.ts.map +1 -0
- package/lib/components/Month/Day/get-day-tab-index/get-day-tab-index.d.ts +9 -0
- package/lib/components/Month/Day/get-day-tab-index/get-day-tab-index.d.ts.map +1 -0
- package/lib/components/Month/Month.d.ts +12 -11
- package/lib/components/Month/Month.d.ts.map +1 -1
- package/lib/components/Month/Month.styles.d.ts +2 -2
- package/lib/components/Month/get-day-props/get-day-props.d.ts +2 -27
- package/lib/components/Month/get-day-props/get-day-props.d.ts.map +1 -1
- package/lib/components/Month/get-day-props/get-range-props/get-range-props.d.ts +7 -0
- package/lib/components/Month/get-day-props/get-range-props/get-range-props.d.ts.map +1 -0
- package/lib/components/Month/get-day-props/is-disabled/is-disabled.d.ts +11 -0
- package/lib/components/Month/get-day-props/is-disabled/is-disabled.d.ts.map +1 -0
- package/lib/components/Month/get-day-props/is-outside/is-outside.d.ts +2 -0
- package/lib/components/Month/get-day-props/is-outside/is-outside.d.ts.map +1 -0
- package/lib/components/Month/get-day-props/is-weekend/is-weekend.d.ts +2 -0
- package/lib/components/Month/get-day-props/is-weekend/is-weekend.d.ts.map +1 -0
- package/lib/components/Month/index.d.ts +1 -0
- package/lib/components/Month/index.d.ts.map +1 -1
- package/lib/components/Month/types.d.ts +23 -0
- package/lib/components/Month/types.d.ts.map +1 -0
- package/lib/components/RangeCalendar/RangeCalendar.d.ts +2 -12
- package/lib/components/RangeCalendar/RangeCalendar.d.ts.map +1 -1
- package/lib/components/TimeInput/TimeField/TimeField.d.ts.map +1 -1
- package/lib/components/TimeInput/TimeField/TimeField.styles.d.ts +18 -0
- package/lib/components/TimeInput/TimeField/TimeField.styles.d.ts.map +1 -0
- package/lib/components/TimeInput/TimeInput.styles.d.ts +0 -7
- package/lib/components/TimeInput/TimeInput.styles.d.ts.map +1 -1
- package/lib/components/TimeRangeInput/TimeRangeInput.styles.d.ts +2 -2
- package/lib/components/TimeRangeInput/TimeRangeInput.styles.d.ts.map +1 -1
- package/lib/utils/get-months-names/get-months-names.d.ts +1 -1
- package/lib/utils/get-months-names/get-months-names.d.ts.map +1 -1
- package/package.json +3 -3
- package/cjs/components/Calendar/ArrowIcon.js.map +0 -1
- package/cjs/components/Calendar/CalendarHeader/CalendarHeader.js +0 -105
- package/cjs/components/Calendar/CalendarHeader/CalendarHeader.js.map +0 -1
- package/cjs/components/Calendar/CalendarLabel/CalendarLabel.js +0 -69
- package/cjs/components/Calendar/CalendarLabel/CalendarLabel.js.map +0 -1
- package/cjs/components/Calendar/CalendarLabel/CalendarLabel.styles.js +0 -14
- package/cjs/components/Calendar/CalendarLabel/CalendarLabel.styles.js.map +0 -1
- package/cjs/components/Calendar/CalendarWrapper/CalendarWrapper.js +0 -58
- package/cjs/components/Calendar/CalendarWrapper/CalendarWrapper.js.map +0 -1
- package/cjs/components/Calendar/get-disabled-state/get-disabled-state.js +0 -18
- package/cjs/components/Calendar/get-disabled-state/get-disabled-state.js.map +0 -1
- package/esm/components/Calendar/ArrowIcon.js.map +0 -1
- package/esm/components/Calendar/CalendarHeader/CalendarHeader.js +0 -97
- package/esm/components/Calendar/CalendarHeader/CalendarHeader.js.map +0 -1
- package/esm/components/Calendar/CalendarLabel/CalendarLabel.js +0 -60
- package/esm/components/Calendar/CalendarLabel/CalendarLabel.js.map +0 -1
- package/esm/components/Calendar/CalendarLabel/CalendarLabel.styles.js +0 -10
- package/esm/components/Calendar/CalendarLabel/CalendarLabel.styles.js.map +0 -1
- package/esm/components/Calendar/CalendarWrapper/CalendarWrapper.js +0 -50
- package/esm/components/Calendar/CalendarWrapper/CalendarWrapper.js.map +0 -1
- package/esm/components/Calendar/get-disabled-state/get-disabled-state.js +0 -10
- package/esm/components/Calendar/get-disabled-state/get-disabled-state.js.map +0 -1
- package/lib/components/Calendar/CalendarHeader/CalendarHeader.d.ts +0 -33
- package/lib/components/Calendar/CalendarHeader/CalendarHeader.d.ts.map +0 -1
- package/lib/components/Calendar/CalendarLabel/CalendarLabel.d.ts +0 -26
- package/lib/components/Calendar/CalendarLabel/CalendarLabel.d.ts.map +0 -1
- package/lib/components/Calendar/CalendarLabel/CalendarLabel.styles.d.ts +0 -7
- package/lib/components/Calendar/CalendarLabel/CalendarLabel.styles.d.ts.map +0 -1
- package/lib/components/Calendar/CalendarWrapper/CalendarWrapper.d.ts +0 -10
- package/lib/components/Calendar/CalendarWrapper/CalendarWrapper.d.ts.map +0 -1
- package/lib/components/Calendar/get-disabled-state/get-disabled-state.d.ts +0 -15
- 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;;;;"}
|