@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.
Files changed (25) hide show
  1. package/dist/components/DateInput/Context.cjs +2 -1
  2. package/dist/components/DateInput/Context.d.ts +1 -0
  3. package/dist/components/DateInput/Context.js +2 -1
  4. package/dist/components/DateInput/components/CalendarContent.cjs +77 -0
  5. package/dist/components/DateInput/components/CalendarContent.d.ts +1 -0
  6. package/dist/components/DateInput/components/CalendarContent.js +75 -0
  7. package/dist/components/DateInput/components/CalendarDaily.cjs +9 -9
  8. package/dist/components/DateInput/components/CalendarDaily.d.ts +1 -3
  9. package/dist/components/DateInput/components/CalendarDaily.js +9 -9
  10. package/dist/components/DateInput/components/CalendarMonthly.cjs +8 -8
  11. package/dist/components/DateInput/components/CalendarMonthly.d.ts +1 -3
  12. package/dist/components/DateInput/components/CalendarMonthly.js +8 -8
  13. package/dist/components/DateInput/components/Popup.cjs +8 -80
  14. package/dist/components/DateInput/components/Popup.d.ts +2 -1
  15. package/dist/components/DateInput/components/Popup.js +9 -81
  16. package/dist/components/DateInput/constants.cjs +0 -4
  17. package/dist/components/DateInput/constants.d.ts +0 -2
  18. package/dist/components/DateInput/constants.js +0 -4
  19. package/dist/components/DateInput/helpers.cjs +11 -4
  20. package/dist/components/DateInput/helpers.d.ts +5 -3
  21. package/dist/components/DateInput/helpers.js +12 -5
  22. package/dist/components/DateInput/index.cjs +26 -6
  23. package/dist/components/DateInput/index.d.ts +5 -1
  24. package/dist/components/DateInput/index.js +27 -7
  25. package/package.json +2 -2
@@ -15,6 +15,7 @@ const DateInputContext = React.createContext({
15
15
  DAYS: {},
16
16
  MONTHS_ARR: [],
17
17
  selectsRange: false,
18
- setVisible: () => null
18
+ setVisible: () => null,
19
+ readOnly: false
19
20
  });
20
21
  exports.DateInputContext = DateInputContext;
@@ -2,6 +2,7 @@ import type { Dispatch, SetStateAction } from 'react';
2
2
  export type ContextProps = {
3
3
  showMonthYearPicker?: boolean;
4
4
  disabled: boolean;
5
+ readOnly: boolean;
5
6
  /**
6
7
  * month to show on popup - NOT selectedValue
7
8
  */
@@ -13,7 +13,8 @@ const DateInputContext = createContext({
13
13
  DAYS: {},
14
14
  MONTHS_ARR: [],
15
15
  selectsRange: false,
16
- setVisible: () => null
16
+ setVisible: () => null,
17
+ readOnly: false
17
18
  });
18
19
  export {
19
20
  DateInputContext
@@ -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);
@@ -1,3 +1 @@
1
- export declare const Daily: ({ disabled }: {
2
- disabled: boolean;
3
- }) => import("@emotion/react/jsx-runtime").JSX.Element;
1
+ export declare const Daily: () => import("@emotion/react/jsx-runtime").JSX.Element;