@uxf/ui 10.0.0-beta.4 → 10.0.0-beta.41

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 (104) hide show
  1. package/_file-input-base/file-input-base.js +9 -1
  2. package/_select-base/_select-base.d.ts +1 -1
  3. package/_select-base/_select-base.js +4 -3
  4. package/calendar/calendar-day-cell.d.ts +3 -0
  5. package/calendar/calendar-day-cell.js +14 -14
  6. package/{date-picker/date-picker-navigation.d.ts → calendar/calendar-navigation.d.ts} +2 -3
  7. package/{date-picker/date-picker-navigation.js → calendar/calendar-navigation.js} +6 -6
  8. package/calendar/calendar-provider.js +1 -1
  9. package/calendar/calendar.d.ts +5 -0
  10. package/calendar/calendar.js +5 -8
  11. package/calendar/index.d.ts +4 -1
  12. package/calendar/index.js +5 -15
  13. package/chip/chip.d.ts +5 -7
  14. package/chip/chip.js +22 -7
  15. package/chip/chip.spec.d.ts +1 -0
  16. package/chip/chip.spec.js +9 -0
  17. package/chip/chip.stories.d.ts +1 -1
  18. package/chip/chip.stories.js +37 -28
  19. package/chip/index.d.ts +3 -1
  20. package/chip/index.js +3 -15
  21. package/chip/theme.d.ts +3 -0
  22. package/css/calendar.css +116 -51
  23. package/css/chip.css +217 -318
  24. package/css/date-picker.css +10 -2
  25. package/css/date-range-picker.css +21 -0
  26. package/css/flash-messages.css +133 -9
  27. package/css/image-gallery.css +13 -9
  28. package/css/textarea.css +66 -74
  29. package/css/time-picker.css +11 -15
  30. package/date-picker/date-picker-decade.js +6 -6
  31. package/date-picker/date-picker-month.js +6 -6
  32. package/date-picker/date-picker-year.js +2 -2
  33. package/date-picker/date-picker.d.ts +1 -0
  34. package/date-picker/date-picker.js +1 -0
  35. package/date-picker-input/date-picker-input.js +3 -1
  36. package/date-range-picker/date-range-picker-content.d.ts +2 -0
  37. package/date-range-picker/date-range-picker-content.js +55 -0
  38. package/date-range-picker/date-range-picker-decade.d.ts +6 -0
  39. package/date-range-picker/date-range-picker-decade.js +72 -0
  40. package/date-range-picker/date-range-picker-month.d.ts +8 -0
  41. package/date-range-picker/date-range-picker-month.js +69 -0
  42. package/date-range-picker/date-range-picker-year.d.ts +7 -0
  43. package/date-range-picker/date-range-picker-year.js +80 -0
  44. package/date-range-picker/date-range-picker.d.ts +9 -0
  45. package/date-range-picker/date-range-picker.js +50 -0
  46. package/date-range-picker/date-range-picker.spec.d.ts +1 -0
  47. package/date-range-picker/date-range-picker.spec.js +9 -0
  48. package/date-range-picker/date-range-picker.stories.d.ts +7 -0
  49. package/date-range-picker/date-range-picker.stories.js +43 -0
  50. package/date-range-picker/index.d.ts +3 -0
  51. package/date-range-picker/index.js +5 -0
  52. package/date-range-picker/types.d.ts +5 -0
  53. package/date-range-picker-input/date-range-picker-input.d.ts +15 -0
  54. package/date-range-picker-input/date-range-picker-input.js +62 -0
  55. package/date-range-picker-input/date-range-picker-input.spec.d.ts +1 -0
  56. package/date-range-picker-input/date-range-picker-input.spec.js +9 -0
  57. package/date-range-picker-input/date-range-picker-input.stories.d.ts +10 -0
  58. package/date-range-picker-input/date-range-picker-input.stories.js +53 -0
  59. package/date-range-picker-input/index.d.ts +2 -0
  60. package/date-range-picker-input/index.js +5 -0
  61. package/datetime-picker/datetime-picker.js +2 -2
  62. package/datetime-picker-input/datetime-picker-input.js +3 -1
  63. package/dropzone/dropzone-input.js +10 -6
  64. package/flash-messages/flash-message.js +1 -1
  65. package/flash-messages/flash-messages.js +44 -10
  66. package/flash-messages/flash-messages.stories.js +12 -0
  67. package/image-gallery/components/close-button.d.ts +2 -1
  68. package/image-gallery/components/close-button.js +2 -3
  69. package/image-gallery/components/gallery.d.ts +6 -3
  70. package/image-gallery/components/gallery.js +15 -7
  71. package/image-gallery/components/next-button.d.ts +7 -0
  72. package/image-gallery/components/next-button.js +14 -0
  73. package/image-gallery/components/prev-button.d.ts +7 -0
  74. package/image-gallery/components/prev-button.js +14 -0
  75. package/image-gallery/image-gallery.d.ts +6 -1
  76. package/image-gallery/image-gallery.js +1 -1
  77. package/image-gallery/image-gallery.stories.js +5 -1
  78. package/multi-combobox/_multi-combobox-base.js +2 -1
  79. package/multi-combobox/types.d.ts +3 -0
  80. package/multi-select/_multi-select-base.js +2 -1
  81. package/multi-select/types.d.ts +3 -2
  82. package/package.json +12 -9
  83. package/radio-group/index.d.ts +1 -1
  84. package/radio-group/radio-group.d.ts +3 -3
  85. package/radio-group/radio-group.js +2 -2
  86. package/radio-group/radio-group.stories.js +4 -4
  87. package/raster-image/raster-image.js +1 -1
  88. package/textarea/textarea.js +5 -5
  89. package/time-picker/time-picker-hour.js +3 -3
  90. package/time-picker/time-picker-hours.js +1 -1
  91. package/time-picker/time-picker-minute.js +3 -3
  92. package/time-picker/time-picker-minutes.js +1 -1
  93. package/time-picker/time-picker.d.ts +1 -0
  94. package/time-picker/time-picker.js +3 -2
  95. package/time-picker-input/time-picker-input.js +3 -1
  96. package/tw-tokens/tw-z-index.d.ts +1 -0
  97. package/tw-tokens/tw-z-index.js +1 -0
  98. package/utils/mocks/uploadFIle.mock.js +1 -1
  99. package/utils/storybook-config.d.ts +1 -1
  100. package/utils/tailwind-config.js +1 -0
  101. package/image-gallery/components/arrow-button.d.ts +0 -7
  102. package/image-gallery/components/arrow-button.js +0 -14
  103. package/select/theme.d.ts +0 -5
  104. /package/{select/theme.js → date-range-picker/types.js} +0 -0
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.DateRangePickerContent = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const date_range_picker_year_1 = require("./date-range-picker-year");
29
+ const date_range_picker_decade_1 = require("./date-range-picker-decade");
30
+ const date_range_picker_month_1 = require("./date-range-picker-month");
31
+ const date_range_picker_context_1 = require("@uxf/datepicker/contexts/date-range-picker-context");
32
+ const DateRangePickerContent = (props) => {
33
+ // eslint-disable-next-line react/destructuring-assignment
34
+ const { goToDate, activeMonths } = (0, react_1.useContext)(date_range_picker_context_1.DateRangePickerContext);
35
+ const [viewMode, setViewMode] = (0, react_1.useState)("month");
36
+ const onYearSelect = (0, react_1.useCallback)(() => setViewMode("decade"), [setViewMode]);
37
+ const onMonthSelect = (0, react_1.useCallback)((date) => {
38
+ goToDate(date);
39
+ setViewMode("month");
40
+ }, [goToDate, setViewMode]);
41
+ const onDecadeYearSelect = (0, react_1.useCallback)((date) => {
42
+ goToDate(date);
43
+ setViewMode("year");
44
+ }, [goToDate, setViewMode]);
45
+ const datePickerComponents = (0, react_1.useMemo)(() => ({
46
+ month: (react_1.default.createElement("div", { className: "uxf-date-range-picker__months" }, activeMonths.map((activeMonth) => (react_1.default.createElement(date_range_picker_month_1.DateRangePickerMonth, { key: `${activeMonth.year}-${activeMonth.month}`, month: activeMonth.month, setViewMode: setViewMode, year: activeMonth.year }))))),
47
+ year: react_1.default.createElement(date_range_picker_year_1.DateRangePickerYear, { onMonthSelect: (date) => onMonthSelect(date), onYearSelect: onYearSelect }),
48
+ decade: react_1.default.createElement(date_range_picker_decade_1.DateRangePickerDecade, { onYearSelect: (date) => onDecadeYearSelect(date) }),
49
+ }), [onMonthSelect, onYearSelect, onDecadeYearSelect, setViewMode, activeMonths]);
50
+ return (react_1.default.createElement("div", { className: `uxf-date-range-picker ${activeMonths.length > 1 ? "uxf-date-range-picker--multi-month" : ""}` },
51
+ props.children,
52
+ datePickerComponents[viewMode]));
53
+ };
54
+ exports.DateRangePickerContent = DateRangePickerContent;
55
+ exports.DateRangePickerContent.displayName = "UxfUiDateRangePickerContent";
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ interface DatePickerDecadeProps {
3
+ onYearSelect: (date: Date) => void;
4
+ }
5
+ export declare const DateRangePickerDecade: React.NamedExoticComponent<DatePickerDecadeProps>;
6
+ export {};
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.DateRangePickerDecade = void 0;
30
+ const dayjs_1 = __importDefault(require("dayjs"));
31
+ const react_1 = __importStar(require("react"));
32
+ const use_decade_1 = require("@uxf/datepicker/hooks/use-decade");
33
+ const cx_1 = require("@uxf/core/utils/cx");
34
+ const classes_1 = require("@uxf/core/constants/classes");
35
+ const date_range_picker_context_1 = require("@uxf/datepicker/contexts/date-range-picker-context");
36
+ const calendar_1 = require("../calendar");
37
+ exports.DateRangePickerDecade = (0, react_1.memo)((props) => {
38
+ const { canGoToYear, goToNextYear, goToPrevYear, activeMonths } = (0, react_1.useContext)(date_range_picker_context_1.DateRangePickerContext);
39
+ const currentYear = activeMonths[0].year;
40
+ const { decadeLabel, years } = (0, use_decade_1.useDecade)({
41
+ year: currentYear,
42
+ });
43
+ const canGoToPrevDecade = canGoToYear((0, dayjs_1.default)(new Date(currentYear, 0)).subtract(5, "years").toDate());
44
+ const canGoToNextDecade = canGoToYear((0, dayjs_1.default)(new Date(currentYear, 0)).add(5, "years").toDate());
45
+ const handleGoToPrevDecadeClick = (0, react_1.useCallback)(() => {
46
+ if (canGoToPrevDecade) {
47
+ goToPrevYear(9);
48
+ }
49
+ }, [canGoToPrevDecade, goToPrevYear]);
50
+ const handleGoToNextDecadeClick = (0, react_1.useCallback)(() => {
51
+ if (canGoToNextDecade) {
52
+ goToNextYear(9);
53
+ }
54
+ }, [canGoToNextDecade, goToNextYear]);
55
+ const handleSelectYear = (0, react_1.useCallback)((date) => () => {
56
+ if (canGoToYear(date)) {
57
+ props.onYearSelect(date);
58
+ }
59
+ }, [canGoToYear, props]);
60
+ return (react_1.default.createElement(react_1.default.Fragment, null,
61
+ react_1.default.createElement(calendar_1.CalendarNavigation, { prevButtonProps: {
62
+ onClick: handleGoToPrevDecadeClick,
63
+ title: "Zpět",
64
+ }, nextButtonProps: {
65
+ onClick: handleGoToNextDecadeClick,
66
+ title: "Vpřed",
67
+ }, selectButtonProps: {
68
+ children: decadeLabel,
69
+ } }),
70
+ react_1.default.createElement("div", { className: "uxf-calendar__decade" }, years.map((year) => (react_1.default.createElement("button", { className: (0, cx_1.cx)("uxf-calendar__cell uxf-calendar__cell-year", !canGoToYear(year.date) && classes_1.CLASSES.IS_DISABLED, (0, dayjs_1.default)(year.date).year() === currentYear && "uxf-calendar__cell-year--current"), key: year.yearLabel, onClick: handleSelectYear(year.date), type: "button" }, year.yearLabel))))));
71
+ });
72
+ exports.DateRangePickerDecade.displayName = "UxfUiDatePickerDecade";
@@ -0,0 +1,8 @@
1
+ import { UseMonthProps } from "@uxf/datepicker/hooks/use-month";
2
+ import React, { Dispatch, SetStateAction } from "react";
3
+ import { ViewModeType } from "./types";
4
+ interface DatePickerMonthProps extends UseMonthProps {
5
+ setViewMode: Dispatch<SetStateAction<ViewModeType>>;
6
+ }
7
+ export declare const DateRangePickerMonth: React.NamedExoticComponent<DatePickerMonthProps>;
8
+ export {};
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.DateRangePickerMonth = void 0;
30
+ const use_month_1 = require("@uxf/datepicker/hooks/use-month");
31
+ const dayjs_1 = __importDefault(require("dayjs"));
32
+ const react_1 = __importStar(require("react"));
33
+ const calendar_1 = require("../calendar");
34
+ const date_range_picker_context_1 = require("@uxf/datepicker/contexts/date-range-picker-context");
35
+ exports.DateRangePickerMonth = (0, react_1.memo)((props) => {
36
+ const dateRangePickerProps = (0, react_1.useContext)(date_range_picker_context_1.DateRangePickerContext);
37
+ const { canGoToNextMonth, canGoToPrevMonth, firstDayOfWeek, goToNextMonthsByOneMonth, goToPrevMonthsByOneMonth } = dateRangePickerProps;
38
+ const { monthLabel } = (0, use_month_1.useMonth)({
39
+ dayLabelFormat: (date) => (0, dayjs_1.default)(date).format("D"),
40
+ firstDayOfWeek,
41
+ month: props.month,
42
+ monthLabelFormat: (date) => (0, dayjs_1.default)(date).format("MMMM YYYY"),
43
+ weekdayLabelFormat: (date) => (0, dayjs_1.default)(date).format("dd"),
44
+ year: props.year,
45
+ });
46
+ const handleGoToPrevMonth = (0, react_1.useCallback)(() => {
47
+ goToPrevMonthsByOneMonth();
48
+ }, [goToPrevMonthsByOneMonth]);
49
+ const handleGoToNextMonth = (0, react_1.useCallback)(() => goToNextMonthsByOneMonth(), [goToNextMonthsByOneMonth]);
50
+ const handleMonthClick = (0, react_1.useCallback)(() => {
51
+ props.setViewMode("year");
52
+ }, [props]);
53
+ return (react_1.default.createElement("div", { className: "uxf-date-range-picker__month" },
54
+ react_1.default.createElement(calendar_1.CalendarNavigation, { prevButtonProps: {
55
+ disabled: !canGoToPrevMonth,
56
+ onClick: canGoToPrevMonth ? handleGoToPrevMonth : undefined,
57
+ title: "Předchozí měsíc",
58
+ }, nextButtonProps: {
59
+ disabled: !canGoToNextMonth,
60
+ onClick: canGoToNextMonth ? handleGoToNextMonth : undefined,
61
+ title: "Nadcházející měsíc",
62
+ }, selectButtonProps: {
63
+ children: monthLabel,
64
+ onClick: handleMonthClick,
65
+ title: "Vybrat měsíc",
66
+ } }),
67
+ react_1.default.createElement(calendar_1.Calendar, { month: props.month, year: props.year, datePickerProps: dateRangePickerProps })));
68
+ });
69
+ exports.DateRangePickerMonth.displayName = "UxfUiDateRangePickerMonth";
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ interface DatePickerYearProps {
3
+ onMonthSelect: (date: Date) => void;
4
+ onYearSelect: () => void;
5
+ }
6
+ export declare const DateRangePickerYear: React.NamedExoticComponent<DatePickerYearProps>;
7
+ export {};
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.DateRangePickerYear = void 0;
30
+ const classes_1 = require("@uxf/core/constants/classes");
31
+ const cx_1 = require("@uxf/core/utils/cx");
32
+ const use_year_1 = require("@uxf/datepicker/hooks/use-year");
33
+ const dayjs_1 = __importDefault(require("dayjs"));
34
+ const react_1 = __importStar(require("react"));
35
+ const date_range_picker_context_1 = require("@uxf/datepicker/contexts/date-range-picker-context");
36
+ const calendar_1 = require("../calendar");
37
+ exports.DateRangePickerYear = (0, react_1.memo)((props) => {
38
+ const { canGoToNextYear, canGoToPrevYear, goToNextYear, goToPrevYear, canGoToMonth, activeMonths } = (0, react_1.useContext)(date_range_picker_context_1.DateRangePickerContext);
39
+ const currentMonth = activeMonths[0].month;
40
+ const currentYear = activeMonths[0].year;
41
+ const { months, yearLabel } = (0, use_year_1.useYear)({
42
+ year: currentYear,
43
+ yearLabelFormat: (date) => (0, dayjs_1.default)(date).format("YYYY"),
44
+ monthLabelFormat: (date) => (0, dayjs_1.default)(date).format("MMMM"),
45
+ });
46
+ const handleGoToNextYear = (0, react_1.useCallback)(() => {
47
+ if (canGoToNextYear) {
48
+ goToNextYear(1);
49
+ }
50
+ }, [canGoToNextYear, goToNextYear]);
51
+ const handleGoToPrevYear = (0, react_1.useCallback)(() => {
52
+ if (canGoToPrevYear) {
53
+ goToPrevYear(1);
54
+ }
55
+ }, [canGoToPrevYear, goToPrevYear]);
56
+ const handleYearClick = (0, react_1.useCallback)(() => {
57
+ props.onYearSelect();
58
+ }, [props]);
59
+ const handleMonthClick = (0, react_1.useCallback)((date) => () => {
60
+ if (canGoToMonth(date)) {
61
+ props.onMonthSelect(date);
62
+ }
63
+ }, [canGoToMonth, props]);
64
+ return (react_1.default.createElement(react_1.default.Fragment, null,
65
+ react_1.default.createElement(calendar_1.CalendarNavigation, { prevButtonProps: {
66
+ disabled: !canGoToPrevYear,
67
+ onClick: canGoToPrevYear ? handleGoToPrevYear : undefined,
68
+ title: "Předchozí rok",
69
+ }, nextButtonProps: {
70
+ disabled: !canGoToNextYear,
71
+ onClick: canGoToNextYear ? handleGoToNextYear : undefined,
72
+ title: "Nadcházející rok",
73
+ }, selectButtonProps: {
74
+ children: yearLabel,
75
+ onClick: handleYearClick,
76
+ title: "Vybrat rok",
77
+ } }),
78
+ react_1.default.createElement("div", { className: "uxf-calendar__year" }, months.map((month, index) => (react_1.default.createElement("button", { className: (0, cx_1.cx)("uxf-calendar__cell uxf-calendar__cell-month", !canGoToMonth(month.date) && classes_1.CLASSES.IS_DISABLED, (0, dayjs_1.default)(month.date).month() === currentMonth && "uxf-calendar__cell-month--current"), key: month.monthLabel + index, onClick: handleMonthClick(month.date), type: "button" }, month.monthLabel))))));
79
+ });
80
+ exports.DateRangePickerYear.displayName = "UxfUiDatePickerYear";
@@ -0,0 +1,9 @@
1
+ import { FC, PropsWithChildren } from "react";
2
+ import { DateRangePickerValueType } from "./types";
3
+ export interface DateRangePickerProps {
4
+ closePopoverHandler: () => void;
5
+ numberOfMonths?: number;
6
+ onChange: (data: DateRangePickerValueType) => void;
7
+ selectedDates: DateRangePickerValueType;
8
+ }
9
+ export declare const DateRangePicker: FC<PropsWithChildren<DateRangePickerProps>>;
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.DateRangePicker = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const date_range_picker_context_1 = require("@uxf/datepicker/contexts/date-range-picker-context");
29
+ const use_date_range_picker_1 = require("@uxf/datepicker/hooks/use-date-range-picker");
30
+ const date_range_picker_content_1 = require("./date-range-picker-content");
31
+ const DateRangePicker = (props) => {
32
+ var _a, _b, _c;
33
+ const [focusedInput, setFocusedInput] = (0, react_1.useState)(use_date_range_picker_1.START_DATE);
34
+ const onDatesChange = (0, react_1.useCallback)((data) => {
35
+ props.onChange({ from: data.startDate, to: data.endDate });
36
+ setFocusedInput(data.endDate ? use_date_range_picker_1.START_DATE : data.focusedInput);
37
+ }, [props]);
38
+ const dateRangePickerProps = (0, use_date_range_picker_1.useDateRangePicker)({
39
+ endDate: ((_a = props.selectedDates) === null || _a === void 0 ? void 0 : _a.to) || null,
40
+ firstDayOfWeek: 1,
41
+ focusedInput: focusedInput,
42
+ numberOfMonths: (_b = props.numberOfMonths) !== null && _b !== void 0 ? _b : 1,
43
+ onDatesChange,
44
+ startDate: ((_c = props.selectedDates) === null || _c === void 0 ? void 0 : _c.from) || null,
45
+ });
46
+ return (react_1.default.createElement(date_range_picker_context_1.DateRangePickerContext.Provider, { value: dateRangePickerProps },
47
+ react_1.default.createElement(date_range_picker_content_1.DateRangePickerContent, null)));
48
+ };
49
+ exports.DateRangePicker = DateRangePicker;
50
+ exports.DateRangePicker.displayName = "UxfUiDatePicker";
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const snap_test_1 = require("../utils/snap-test");
8
+ const date_range_picker_stories_1 = require("./date-range-picker.stories");
9
+ (0, snap_test_1.snapTest)("render stories", react_1.default.createElement(date_range_picker_stories_1.Default, null));
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ declare const _default: {
3
+ title: string;
4
+ component: React.FC<React.PropsWithChildren<import("./date-range-picker").DateRangePickerProps>>;
5
+ };
6
+ export default _default;
7
+ export declare function Default(): React.JSX.Element;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.Default = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const action_1 = require("../utils/action");
29
+ const date_range_picker_1 = require("./date-range-picker");
30
+ exports.default = {
31
+ title: "UI/DateRangePicker",
32
+ component: date_range_picker_1.DateRangePicker,
33
+ };
34
+ function Default() {
35
+ const [value, setValue] = (0, react_1.useState)(null);
36
+ const onChange = (0, action_1.action)("onChange", setValue);
37
+ const testDatePickers = (react_1.default.createElement(react_1.default.Fragment, null,
38
+ react_1.default.createElement(date_range_picker_1.DateRangePicker, { closePopoverHandler: close, onChange: onChange, selectedDates: value })));
39
+ return (react_1.default.createElement(react_1.default.Fragment, null,
40
+ react_1.default.createElement("div", { className: "light max-w-[640px] space-y-4 rounded bg-white p-8" }, testDatePickers),
41
+ react_1.default.createElement("div", { className: "dark max-w-[640px] space-y-4 rounded bg-gray-900 p-8 text-white" }, testDatePickers)));
42
+ }
43
+ exports.Default = Default;
@@ -0,0 +1,3 @@
1
+ export { DateRangePicker } from "./date-range-picker";
2
+ export type { DateRangePickerProps } from "./date-range-picker";
3
+ export type { ViewModeType, DateRangePickerValueType } from "./types";
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DateRangePicker = void 0;
4
+ var date_range_picker_1 = require("./date-range-picker");
5
+ Object.defineProperty(exports, "DateRangePicker", { enumerable: true, get: function () { return date_range_picker_1.DateRangePicker; } });
@@ -0,0 +1,5 @@
1
+ export type DateRangePickerValueType = {
2
+ from: Date | null;
3
+ to: Date | null;
4
+ } | null;
5
+ export type ViewModeType = "month" | "year" | "decade";
@@ -0,0 +1,15 @@
1
+ import React, { ReactNode } from "react";
2
+ import { InputWithPopoverProps } from "../_input-with-popover";
3
+ export declare const ALLOWED_DATE_FORMAT: string[];
4
+ export declare const DISPLAY_DATE_FORMAT = "D. M. YYYY";
5
+ export declare const SEPARATOR = " \u2013 ";
6
+ export declare const splitValueToRange: (value: string | undefined | null) => {
7
+ from: string | undefined;
8
+ to: string | undefined;
9
+ };
10
+ export interface DateRangePickerInputProps extends Omit<InputWithPopoverProps<string | null>, "children" | "placeholder" | "triggerElement"> {
11
+ numberOfMonths?: number;
12
+ placeholder?: string;
13
+ triggerElement?: ReactNode;
14
+ }
15
+ export declare const DateRangePickerInput: React.ForwardRefExoticComponent<DateRangePickerInputProps & React.RefAttributes<HTMLInputElement>>;
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.DateRangePickerInput = exports.splitValueToRange = exports.SEPARATOR = exports.DISPLAY_DATE_FORMAT = exports.ALLOWED_DATE_FORMAT = void 0;
30
+ const dayjs_1 = __importDefault(require("dayjs"));
31
+ const react_1 = __importStar(require("react"));
32
+ const _input_with_popover_1 = require("../_input-with-popover");
33
+ const date_range_picker_1 = require("../date-range-picker");
34
+ const icon_1 = require("../icon");
35
+ exports.ALLOWED_DATE_FORMAT = ["D. M. YYYY", "DD. MM. YYYY", "D.M.YYYY", "DD.MM.YYYY", "YYYY-MM-DD"];
36
+ exports.DISPLAY_DATE_FORMAT = "D. M. YYYY";
37
+ exports.SEPARATOR = " – ";
38
+ const splitValueToRange = (value) => {
39
+ const splitStr = value === null || value === void 0 ? void 0 : value.split(exports.SEPARATOR);
40
+ return { from: splitStr ? splitStr[0] : undefined, to: splitStr && splitStr.length > 0 ? splitStr[1] : undefined };
41
+ };
42
+ exports.splitValueToRange = splitValueToRange;
43
+ exports.DateRangePickerInput = (0, react_1.forwardRef)((props, ref) => {
44
+ var _a, _b;
45
+ const { numberOfMonths, ...restProps } = props;
46
+ const onChange = props.onChange;
47
+ const onDatePickerChange = (0, react_1.useCallback)((value) => {
48
+ onChange(value
49
+ ? (value.from ? (0, dayjs_1.default)(value.from).format(exports.DISPLAY_DATE_FORMAT) : "") +
50
+ exports.SEPARATOR +
51
+ (value.to ? (0, dayjs_1.default)(value.to).format(exports.DISPLAY_DATE_FORMAT) : "")
52
+ : "");
53
+ }, [onChange]);
54
+ const { from, to } = (0, exports.splitValueToRange)(props.value);
55
+ const parsedFrom = (0, dayjs_1.default)(from, exports.ALLOWED_DATE_FORMAT, true);
56
+ const parsedTo = (0, dayjs_1.default)(to, exports.ALLOWED_DATE_FORMAT, true);
57
+ const selectedDates = props.value
58
+ ? { from: parsedFrom.isValid() ? parsedFrom.toDate() : null, to: parsedTo.isValid() ? parsedTo.toDate() : null }
59
+ : null;
60
+ return (react_1.default.createElement(_input_with_popover_1._InputWithPopover, { ...restProps, placeholder: props.placeholder || "Vyberte datum...", ref: ref, triggerElement: (_a = props.triggerElement) !== null && _a !== void 0 ? _a : react_1.default.createElement(icon_1.Icon, { name: "calendar", size: 20 }), value: (_b = props.value) !== null && _b !== void 0 ? _b : "" }, ({ close }) => (react_1.default.createElement(date_range_picker_1.DateRangePicker, { closePopoverHandler: close, numberOfMonths: numberOfMonths, onChange: onDatePickerChange, selectedDates: selectedDates }))));
61
+ });
62
+ exports.DateRangePickerInput.displayName = "UxfUiDatePickerInput";
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const snap_test_1 = require("../utils/snap-test");
8
+ const date_range_picker_input_stories_1 = require("./date-range-picker-input.stories");
9
+ (0, snap_test_1.snapTest)("render stories", react_1.default.createElement(date_range_picker_input_stories_1.Default, null));
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ declare const _default: {
3
+ title: string;
4
+ component: React.ForwardRefExoticComponent<import("./date-range-picker-input").DateRangePickerInputProps & React.RefAttributes<HTMLInputElement>>;
5
+ parameters: {
6
+ docs: {};
7
+ };
8
+ };
9
+ export default _default;
10
+ export declare function Default(): React.JSX.Element;
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.Default = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const date_range_picker_input_1 = require("./date-range-picker-input");
29
+ // import Docs from "./date-picker.docs.mdx";
30
+ const action_1 = require("../utils/action");
31
+ exports.default = {
32
+ title: "UI/DateRangePickerInput",
33
+ component: date_range_picker_input_1.DateRangePickerInput,
34
+ parameters: {
35
+ docs: {
36
+ // page: Docs,
37
+ },
38
+ },
39
+ };
40
+ function Default() {
41
+ const [range, setRange] = (0, react_1.useState)(null);
42
+ const onChange = (0, action_1.action)("onChange", setRange);
43
+ const testDatePickers = (react_1.default.createElement(react_1.default.Fragment, null,
44
+ react_1.default.createElement(date_range_picker_input_1.DateRangePickerInput, { id: "date-test", name: "date", label: "Datum \u010Dehokoliv", value: range, onChange: onChange, isClearable: true }),
45
+ react_1.default.createElement(date_range_picker_input_1.DateRangePickerInput, { id: "date-test", name: "date", label: "Datum \u010Dehokoliv", value: range, onChange: onChange }),
46
+ react_1.default.createElement(date_range_picker_input_1.DateRangePickerInput, { id: "date-test-disabled", name: "date-disabled", label: "Datum disabled", value: range, onChange: onChange, isDisabled: true }),
47
+ react_1.default.createElement(date_range_picker_input_1.DateRangePickerInput, { id: "date-test-readonly", name: "date-readonly", label: "Datum readonly", value: range, onChange: onChange, isReadOnly: true }),
48
+ react_1.default.createElement(date_range_picker_input_1.DateRangePickerInput, { id: "date-test-invalid", name: "date-invalid", label: "Datum invalid", value: range, onChange: onChange, isInvalid: true, isClearable: true })));
49
+ return (react_1.default.createElement(react_1.default.Fragment, null,
50
+ react_1.default.createElement("div", { className: "light max-w-[640px] space-y-4 rounded bg-white p-8" }, testDatePickers),
51
+ react_1.default.createElement("div", { className: "dark max-w-[640px] space-y-4 rounded bg-gray-900 p-8 text-white" }, testDatePickers)));
52
+ }
53
+ exports.Default = Default;
@@ -0,0 +1,2 @@
1
+ export type { DateRangePickerInputProps } from "./date-range-picker-input";
2
+ export { DateRangePickerInput } from "./date-range-picker-input";
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DateRangePickerInput = void 0;
4
+ var date_range_picker_input_1 = require("./date-range-picker-input");
5
+ Object.defineProperty(exports, "DateRangePickerInput", { enumerable: true, get: function () { return date_range_picker_input_1.DateRangePickerInput; } });