@ultraviolet/ui 1.85.2 → 1.85.3
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/dist/components/DateInput/Context.cjs +2 -1
- package/dist/components/DateInput/Context.d.ts +1 -0
- package/dist/components/DateInput/Context.js +2 -1
- package/dist/components/DateInput/components/CalendarContent.cjs +77 -0
- package/dist/components/DateInput/components/CalendarContent.d.ts +1 -0
- package/dist/components/DateInput/components/CalendarContent.js +75 -0
- package/dist/components/DateInput/components/CalendarDaily.cjs +9 -9
- package/dist/components/DateInput/components/CalendarDaily.d.ts +1 -3
- package/dist/components/DateInput/components/CalendarDaily.js +9 -9
- package/dist/components/DateInput/components/CalendarMonthly.cjs +8 -8
- package/dist/components/DateInput/components/CalendarMonthly.d.ts +1 -3
- package/dist/components/DateInput/components/CalendarMonthly.js +8 -8
- package/dist/components/DateInput/components/Popup.cjs +8 -80
- package/dist/components/DateInput/components/Popup.d.ts +2 -1
- package/dist/components/DateInput/components/Popup.js +9 -81
- package/dist/components/DateInput/constants.cjs +0 -4
- package/dist/components/DateInput/constants.d.ts +0 -2
- package/dist/components/DateInput/constants.js +0 -4
- package/dist/components/DateInput/helpers.cjs +11 -4
- package/dist/components/DateInput/helpers.d.ts +5 -3
- package/dist/components/DateInput/helpers.js +12 -5
- package/dist/components/DateInput/index.cjs +26 -6
- package/dist/components/DateInput/index.d.ts +5 -1
- package/dist/components/DateInput/index.js +27 -7
- package/package.json +2 -2
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
|
+
const _styled = require("@emotion/styled/base");
|
|
5
|
+
const React = require("react");
|
|
6
|
+
const index$2 = require("../../Button/index.cjs");
|
|
7
|
+
const index$1 = require("../../Stack/index.cjs");
|
|
8
|
+
const index = require("../../Text/index.cjs");
|
|
9
|
+
const Context = require("../Context.cjs");
|
|
10
|
+
const helpers = require("../helpers.cjs");
|
|
11
|
+
const CalendarDaily = require("./CalendarDaily.cjs");
|
|
12
|
+
const CalendarMonthly = require("./CalendarMonthly.cjs");
|
|
13
|
+
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
14
|
+
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
15
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
16
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
17
|
+
}
|
|
18
|
+
const CapitalizedText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
|
|
19
|
+
target: "e11qichn0"
|
|
20
|
+
} : {
|
|
21
|
+
target: "e11qichn0",
|
|
22
|
+
label: "CapitalizedText"
|
|
23
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
24
|
+
name: "kff9ir",
|
|
25
|
+
styles: "text-transform:capitalize"
|
|
26
|
+
} : {
|
|
27
|
+
name: "kff9ir",
|
|
28
|
+
styles: "text-transform:capitalize/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL0J1dHRvbidcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgZ2V0TmV4dE1vbnRoLCBnZXRQcmV2aW91c01vbnRoIH0gZnJvbSAnLi4vaGVscGVycydcbmltcG9ydCB7IERhaWx5IH0gZnJvbSAnLi9DYWxlbmRhckRhaWx5J1xuaW1wb3J0IHsgTW9udGhseSB9IGZyb20gJy4vQ2FsZW5kYXJNb250aGx5J1xuXG5jb25zdCBDYXBpdGFsaXplZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIHRleHQtdHJhbnNmb3JtOiBjYXBpdGFsaXplO1xuYFxuZXhwb3J0IGNvbnN0IENhbGVuZGFyQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICAgIHJlYWRPbmx5LFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICghbWluRGF0ZSB8fFxuICAgICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSkgJiZcbiAgICAgICAgICAgICAgIXJlYWRPbmx5XG4gICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgaWYgKCFzaG93TW9udGhZZWFyUGlja2VyKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgW3ByZXZNb250aCwgeWVhcl0gPSBnZXRQcmV2aW91c01vbnRoKFxuICAgICAgICAgICAgICAgICAgbW9udGhUb1Nob3csXG4gICAgICAgICAgICAgICAgICB5ZWFyVG9TaG93LFxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhwcmV2TW9udGgpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyAtIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1pbkRhdGUgJiYgbWluRGF0ZSA+IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMCkpIHx8XG4gICAgICAgICAgICBkaXNhYmxlZFxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgPlxuICAgICAgICAgIHshc2hvd01vbnRoWWVhclBpY2tlciA/IE1PTlRIU19BUlJbbW9udGhUb1Nob3cgLSAxXSA6IG51bGx9Jm5ic3A7XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAoIW1heERhdGUgfHwgbWF4RGF0ZSA+PSBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdywgMSkpICYmXG4gICAgICAgICAgICAgICFyZWFkT25seVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB8fFxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyA8TW9udGhseSAvPiA6IDxEYWlseSAvPn1cbiAgICA8L1N0YWNrPlxuICApXG59XG4iXX0= */",
|
|
29
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
30
|
+
});
|
|
31
|
+
const CalendarContent = () => {
|
|
32
|
+
const {
|
|
33
|
+
showMonthYearPicker,
|
|
34
|
+
disabled,
|
|
35
|
+
monthToShow,
|
|
36
|
+
yearToShow,
|
|
37
|
+
setMonthToShow,
|
|
38
|
+
setYearToShow,
|
|
39
|
+
maxDate,
|
|
40
|
+
minDate,
|
|
41
|
+
MONTHS_ARR,
|
|
42
|
+
readOnly
|
|
43
|
+
} = React.useContext(Context.DateInputContext);
|
|
44
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 2, children: [
|
|
45
|
+
/* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
46
|
+
/* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
47
|
+
if ((!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) && !readOnly) {
|
|
48
|
+
if (!showMonthYearPicker) {
|
|
49
|
+
const [prevMonth, year] = helpers.getPreviousMonth(monthToShow, yearToShow);
|
|
50
|
+
setMonthToShow(prevMonth);
|
|
51
|
+
setYearToShow(year);
|
|
52
|
+
} else {
|
|
53
|
+
setYearToShow(yearToShow - 1);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) || disabled }),
|
|
57
|
+
/* @__PURE__ */ jsxRuntime.jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", disabled, children: [
|
|
58
|
+
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
59
|
+
" ",
|
|
60
|
+
yearToShow
|
|
61
|
+
] }),
|
|
62
|
+
/* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
63
|
+
if ((!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) && !readOnly) {
|
|
64
|
+
if (!showMonthYearPicker) {
|
|
65
|
+
const [monthNext, year] = helpers.getNextMonth(monthToShow, yearToShow);
|
|
66
|
+
setMonthToShow(monthNext);
|
|
67
|
+
setYearToShow(year);
|
|
68
|
+
} else {
|
|
69
|
+
setYearToShow(yearToShow + 1);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) || disabled })
|
|
73
|
+
] }),
|
|
74
|
+
showMonthYearPicker ? /* @__PURE__ */ jsxRuntime.jsx(CalendarMonthly.Monthly, {}) : /* @__PURE__ */ jsxRuntime.jsx(CalendarDaily.Daily, {})
|
|
75
|
+
] });
|
|
76
|
+
};
|
|
77
|
+
exports.CalendarContent = CalendarContent;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const CalendarContent: () => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { useContext } from "react";
|
|
4
|
+
import { Button } from "../../Button/index.js";
|
|
5
|
+
import { Stack } from "../../Stack/index.js";
|
|
6
|
+
import { Text } from "../../Text/index.js";
|
|
7
|
+
import { DateInputContext } from "../Context.js";
|
|
8
|
+
import { getPreviousMonth, getNextMonth } from "../helpers.js";
|
|
9
|
+
import { Daily } from "./CalendarDaily.js";
|
|
10
|
+
import { Monthly } from "./CalendarMonthly.js";
|
|
11
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
12
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
13
|
+
}
|
|
14
|
+
const CapitalizedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
15
|
+
target: "e11qichn0"
|
|
16
|
+
} : {
|
|
17
|
+
target: "e11qichn0",
|
|
18
|
+
label: "CapitalizedText"
|
|
19
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
20
|
+
name: "kff9ir",
|
|
21
|
+
styles: "text-transform:capitalize"
|
|
22
|
+
} : {
|
|
23
|
+
name: "kff9ir",
|
|
24
|
+
styles: "text-transform:capitalize/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL0NhbGVuZGFyQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL0J1dHRvbidcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgZ2V0TmV4dE1vbnRoLCBnZXRQcmV2aW91c01vbnRoIH0gZnJvbSAnLi4vaGVscGVycydcbmltcG9ydCB7IERhaWx5IH0gZnJvbSAnLi9DYWxlbmRhckRhaWx5J1xuaW1wb3J0IHsgTW9udGhseSB9IGZyb20gJy4vQ2FsZW5kYXJNb250aGx5J1xuXG5jb25zdCBDYXBpdGFsaXplZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIHRleHQtdHJhbnNmb3JtOiBjYXBpdGFsaXplO1xuYFxuZXhwb3J0IGNvbnN0IENhbGVuZGFyQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICAgIHJlYWRPbmx5LFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICghbWluRGF0ZSB8fFxuICAgICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSkgJiZcbiAgICAgICAgICAgICAgIXJlYWRPbmx5XG4gICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgaWYgKCFzaG93TW9udGhZZWFyUGlja2VyKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgW3ByZXZNb250aCwgeWVhcl0gPSBnZXRQcmV2aW91c01vbnRoKFxuICAgICAgICAgICAgICAgICAgbW9udGhUb1Nob3csXG4gICAgICAgICAgICAgICAgICB5ZWFyVG9TaG93LFxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhwcmV2TW9udGgpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyAtIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1pbkRhdGUgJiYgbWluRGF0ZSA+IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMCkpIHx8XG4gICAgICAgICAgICBkaXNhYmxlZFxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dFxuICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgPlxuICAgICAgICAgIHshc2hvd01vbnRoWWVhclBpY2tlciA/IE1PTlRIU19BUlJbbW9udGhUb1Nob3cgLSAxXSA6IG51bGx9Jm5ic3A7XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAoIW1heERhdGUgfHwgbWF4RGF0ZSA+PSBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdywgMSkpICYmXG4gICAgICAgICAgICAgICFyZWFkT25seVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB8fFxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyA8TW9udGhseSAvPiA6IDxEYWlseSAvPn1cbiAgICA8L1N0YWNrPlxuICApXG59XG4iXX0= */",
|
|
25
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
26
|
+
});
|
|
27
|
+
const CalendarContent = () => {
|
|
28
|
+
const {
|
|
29
|
+
showMonthYearPicker,
|
|
30
|
+
disabled,
|
|
31
|
+
monthToShow,
|
|
32
|
+
yearToShow,
|
|
33
|
+
setMonthToShow,
|
|
34
|
+
setYearToShow,
|
|
35
|
+
maxDate,
|
|
36
|
+
minDate,
|
|
37
|
+
MONTHS_ARR,
|
|
38
|
+
readOnly
|
|
39
|
+
} = useContext(DateInputContext);
|
|
40
|
+
return /* @__PURE__ */ jsxs(Stack, { gap: 2, children: [
|
|
41
|
+
/* @__PURE__ */ jsxs(Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
42
|
+
/* @__PURE__ */ jsx(Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
43
|
+
if ((!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) && !readOnly) {
|
|
44
|
+
if (!showMonthYearPicker) {
|
|
45
|
+
const [prevMonth, year] = getPreviousMonth(monthToShow, yearToShow);
|
|
46
|
+
setMonthToShow(prevMonth);
|
|
47
|
+
setYearToShow(year);
|
|
48
|
+
} else {
|
|
49
|
+
setYearToShow(yearToShow - 1);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) || disabled }),
|
|
53
|
+
/* @__PURE__ */ jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", disabled, children: [
|
|
54
|
+
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
55
|
+
" ",
|
|
56
|
+
yearToShow
|
|
57
|
+
] }),
|
|
58
|
+
/* @__PURE__ */ jsx(Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
59
|
+
if ((!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) && !readOnly) {
|
|
60
|
+
if (!showMonthYearPicker) {
|
|
61
|
+
const [monthNext, year] = getNextMonth(monthToShow, yearToShow);
|
|
62
|
+
setMonthToShow(monthNext);
|
|
63
|
+
setYearToShow(year);
|
|
64
|
+
} else {
|
|
65
|
+
setYearToShow(yearToShow + 1);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) || disabled })
|
|
69
|
+
] }),
|
|
70
|
+
showMonthYearPicker ? /* @__PURE__ */ jsx(Monthly, {}) : /* @__PURE__ */ jsx(Daily, {})
|
|
71
|
+
] });
|
|
72
|
+
};
|
|
73
|
+
export {
|
|
74
|
+
CalendarContent
|
|
75
|
+
};
|
|
@@ -21,7 +21,7 @@ const ButtonDate = /* @__PURE__ */ _styled__default.default(index.Button, proces
|
|
|
21
21
|
label: "ButtonDate"
|
|
22
22
|
})("height:", ({
|
|
23
23
|
theme
|
|
24
|
-
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAgBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
24
|
+
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAgBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = () => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n          disabled={disabled}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
25
25
|
const RangeButton = /* @__PURE__ */ _styled__default.default(index.Button, process.env.NODE_ENV === "production" ? {
|
|
26
26
|
target: "e1ouebol1"
|
|
27
27
|
} : {
|
|
@@ -31,7 +31,7 @@ const RangeButton = /* @__PURE__ */ _styled__default.default(index.Button, proce
|
|
|
31
31
|
theme
|
|
32
32
|
}) => theme.colors.primary.background, ";height:", ({
|
|
33
33
|
theme
|
|
34
|
-
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
34
|
+
}) => theme.sizing["312"], ";width:100%;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = () => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n          disabled={disabled}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
|
|
35
35
|
const CapitalizedText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
|
|
36
36
|
target: "e1ouebol0"
|
|
37
37
|
} : {
|
|
@@ -42,12 +42,10 @@ const CapitalizedText = /* @__PURE__ */ _styled__default.default(index$1.Text, p
|
|
|
42
42
|
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}"
|
|
43
43
|
} : {
|
|
44
44
|
name: "88dib2",
|
|
45
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AA6BoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = ({ disabled }: { disabled: boolean }) => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */",
|
|
45
|
+
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx"],"names":[],"mappings":"AA6BoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarDaily.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { MouseEvent as MouseEventReact } from 'react'\nimport { useContext, useState } from 'react'\nimport { Button } from '../../Button'\nimport { Row } from '../../Row'\nimport { Text } from '../../Text'\nimport { DateInputContext } from '../Context'\nimport { CALENDAR_WEEKS } from '../constants'\nimport {\n  formatValue,\n  getMonthFirstDay,\n  getNextMonth,\n  getPreviousMonth,\n  isSameDay,\n} from '../helpers'\n\nconst ButtonDate = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst RangeButton = styled(Button)`\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n`\n\nconst CapitalizedText = styled(Text)`\n  display: inline-block;\n  text-transform: lowercase;\n\n  &::first-letter {\n    text-transform: uppercase;\n  }\n`\n\nexport const Daily = () => {\n  const {\n    value,\n    yearToShow,\n    monthToShow,\n    setValue,\n    setMonthToShow,\n    onChange,\n    setYearToShow,\n    excludeDates,\n    minDate,\n    maxDate,\n    DAYS,\n    selectsRange,\n    range,\n    setRange,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n  } = useContext(DateInputContext)\n\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. Kow the current state of the range: none when start date not selected, start when start date is selected, done when start & end date selected\n\n  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  const monthDays = new Date(yearToShow, monthToShow, 0).getDate() // Number of days in the month\n\n  const daysFromPreviousMonth = getMonthFirstDay(monthToShow, yearToShow) //  Number of days from the previous month to show.\n\n  const daysFromNextMonth =\n    CALENDAR_WEEKS * 7 - (daysFromPreviousMonth + monthDays) // We want to display 6 CALENDAR_WEEKS lines, so we show days from the next month\n\n  const [previousMonth, prevMonthYear] = getPreviousMonth(\n    monthToShow,\n    yearToShow,\n  )\n\n  const [nextMonth, nextMonthYear] = getNextMonth(monthToShow, yearToShow)\n  const previousMonthDays = new Date(prevMonthYear, previousMonth, 0).getDate() // Number of days in the previous month\n\n  // Get the dates to be displayed from the previous month\n  const prevMonthDates = Array.from(\n    { length: daysFromPreviousMonth },\n    (_, index) => ({\n      day: index + 1 + (previousMonthDays - daysFromPreviousMonth),\n      month: -1,\n    }),\n  )\n\n  // Get the dates to be displayed from the current month\n  const currentMonthDates = Array.from({ length: monthDays }, (_, index) => ({\n    day: index + 1,\n    month: 0,\n  }))\n\n  // Get the dates to be displayed from the next month\n  const nextMonthDates = Array.from(\n    { length: daysFromNextMonth },\n    (_, index) => ({ day: index + 1, month: 1 }),\n  )\n\n  const allDaysToShow = [\n    ...prevMonthDates,\n    ...currentMonthDates,\n    ...nextMonthDates,\n  ] // Array of the days to display { day : day n°, isCurrentMonth: if it is the current day}\n\n  return (\n    <Row templateColumns=\"repeat(7, 1fr)\" gap={1}>\n      {Object.entries(DAYS).map(day => (\n        <CapitalizedText\n          as=\"p\"\n          variant=\"bodyStrong\"\n          sentiment=\"neutral\"\n          key={day[0]}\n          disabled={disabled}\n        >\n          {day[1]}\n        </CapitalizedText>\n      ))}\n      {allDaysToShow.map(data => {\n        const constructedDate = new Date(\n          yearToShow,\n          monthToShow - 1 + data.month,\n          data.day,\n        )\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameDay(constructedDate, date))\n              .includes(true)\n          : false\n\n        // Whether the date < minDate or date > maxDate\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\n        // Whether the date is selected\n        const isSelected =\n          (value && isSameDay(constructedDate, new Date(value))) ||\n          (range?.end && isSameDay(constructedDate, range.end)) ||\n          (range?.start && isSameDay(constructedDate, range.start))\n\n        // Whether the date is after the start date - useful when selectsRange is set to true\n        const isAfterStartDate =\n          selectsRange && range?.start && constructedDate > range.start\n\n        const isInHoveredRange =\n          (selectsRange &&\n            range?.start &&\n            constructedDate > range.start &&\n            hoveredDate &&\n            constructedDate < hoveredDate) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const getNewDate = () => {\n          // Clicked on a day from the previous month\n          if (data.month !== 0 && data.day > 15) {\n            setMonthToShow(previousMonth)\n            setYearToShow(prevMonthYear)\n\n            return new Date(prevMonthYear, previousMonth - 1, data.day)\n          }\n\n          // Clicked on a day from the next month\n          if (data.month !== 0 && data.day < 15) {\n            setMonthToShow(nextMonth)\n            setYearToShow(nextMonthYear)\n\n            return new Date(nextMonthYear, nextMonth - 1, data.day)\n          }\n\n          return new Date(yearToShow, monthToShow - 1, data.day)\n        }\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          if (selectsRange) {\n            // Selecting start date\n            if (rangeState === 'none') {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('start')\n            }\n\n            // Selecting end date\n            else if (isAfterStartDate) {\n              setRange?.({ start: range.start, end: newDate })\n              onChange?.([range.start, newDate], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: range.start, end: newDate },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              setRangeState('done')\n            } else {\n              // End date before start\n              setRange?.({ start: newDate, end: null })\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  false,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const createTestId = () => {\n          if (isInHoveredRange) return 'rangeButton'\n          if (data.month === -1) return 'dayLastMonth'\n          if (data.month === 1) return 'dayNextMonth'\n\n          return undefined\n        }\n\n        const Day = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Day\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={`${data.month}-${data.day}`}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                const newDate = getNewDate()\n\n                if (selectsRange) {\n                  onClickRange(event, newDate)\n                } else {\n                  setValue(newDate)\n                  onChange?.(newDate, event)\n                  setInputValue(\n                    formatValue(newDate, null, false, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => {\n              if (selectsRange && range?.start) setHoveredDate(constructedDate)\n            }}\n            onMouseLeave={() => {\n              if (selectsRange && range?.start) setHoveredDate(null)\n            }}\n          >\n            <Text\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={\n                disabled || data.month !== 0 || isExcluded || isOutsideRange\n              }\n              data-testid={createTestId()}\n            >\n              {data.day}\n            </Text>\n          </Day>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */",
|
|
46
46
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
47
|
});
|
|
48
|
-
const Daily = ({
|
|
49
|
-
disabled
|
|
50
|
-
}) => {
|
|
48
|
+
const Daily = () => {
|
|
51
49
|
const {
|
|
52
50
|
value,
|
|
53
51
|
yearToShow,
|
|
@@ -65,7 +63,9 @@ const Daily = ({
|
|
|
65
63
|
setRange,
|
|
66
64
|
setInputValue,
|
|
67
65
|
format,
|
|
68
|
-
setVisible
|
|
66
|
+
setVisible,
|
|
67
|
+
readOnly,
|
|
68
|
+
disabled
|
|
69
69
|
} = React.useContext(Context.DateInputContext);
|
|
70
70
|
const [rangeState, setRangeState] = React.useState(range?.start ? "start" : "none");
|
|
71
71
|
const [hoveredDate, setHoveredDate] = React.useState(null);
|
|
@@ -95,7 +95,7 @@ const Daily = ({
|
|
|
95
95
|
}));
|
|
96
96
|
const allDaysToShow = [...prevMonthDates, ...currentMonthDates, ...nextMonthDates];
|
|
97
97
|
return /* @__PURE__ */ jsxRuntime.jsxs(index$2.Row, { templateColumns: "repeat(7, 1fr)", gap: 1, children: [
|
|
98
|
-
Object.entries(DAYS).map((day) => /* @__PURE__ */ jsxRuntime.jsx(CapitalizedText, { as: "p", variant: "bodyStrong", sentiment: "neutral", children: day[1] }, day[0])),
|
|
98
|
+
Object.entries(DAYS).map((day) => /* @__PURE__ */ jsxRuntime.jsx(CapitalizedText, { as: "p", variant: "bodyStrong", sentiment: "neutral", disabled, children: day[1] }, day[0])),
|
|
99
99
|
allDaysToShow.map((data) => {
|
|
100
100
|
const constructedDate = new Date(yearToShow, monthToShow - 1 + data.month, data.day);
|
|
101
101
|
const isExcluded = excludeDates ? excludeDates.map((date) => helpers.isSameDay(constructedDate, date)).includes(true) : false;
|
|
@@ -162,7 +162,7 @@ const Daily = ({
|
|
|
162
162
|
};
|
|
163
163
|
const Day = isInHoveredRange ? RangeButton : ButtonDate;
|
|
164
164
|
return /* @__PURE__ */ jsxRuntime.jsx(Day, { variant: isSelected || isInHoveredRange ? "filled" : "ghost", sentiment: isSelected || isInHoveredRange ? "primary" : "neutral", disabled: disabled || isExcluded || isOutsideRange, onClick: (event) => {
|
|
165
|
-
if (!isExcluded && !isOutsideRange) {
|
|
165
|
+
if (!isExcluded && !isOutsideRange && !readOnly) {
|
|
166
166
|
const newDate = getNewDate();
|
|
167
167
|
if (selectsRange) {
|
|
168
168
|
onClickRange(event, newDate);
|