@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
|
@@ -3,110 +3,38 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
|
3
3
|
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
4
|
const _styled = require("@emotion/styled/base");
|
|
5
5
|
const React = require("react");
|
|
6
|
-
const index
|
|
7
|
-
const index$1 = require("../../Popup/index.cjs");
|
|
8
|
-
const index$2 = require("../../Stack/index.cjs");
|
|
9
|
-
const index = require("../../Text/index.cjs");
|
|
10
|
-
const Context = require("../Context.cjs");
|
|
6
|
+
const index = require("../../Popup/index.cjs");
|
|
11
7
|
const constants = require("../constants.cjs");
|
|
12
8
|
const helpers = require("../helpers.cjs");
|
|
13
|
-
const CalendarDaily = require("./CalendarDaily.cjs");
|
|
14
|
-
const CalendarMonthly = require("./CalendarMonthly.cjs");
|
|
15
9
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
16
10
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
17
|
-
|
|
18
|
-
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).";
|
|
19
|
-
}
|
|
20
|
-
const CapitalizedText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
|
|
21
|
-
target: "e17y63oo1"
|
|
22
|
-
} : {
|
|
23
|
-
target: "e17y63oo1",
|
|
24
|
-
label: "CapitalizedText"
|
|
25
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
26
|
-
name: "88dib2",
|
|
27
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}"
|
|
28
|
-
} : {
|
|
29
|
-
name: "88dib2",
|
|
30
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhb0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRGF0ZUlucHV0L2NvbXBvbmVudHMvUG9wdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IERpc3BhdGNoLCBSZWFjdE5vZGUsIFJlZk9iamVjdCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNvbnRleHQsIHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi8uLi9CdXR0b24nXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uLy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi8uLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgRGF0ZUlucHV0Q29udGV4dCB9IGZyb20gJy4uL0NvbnRleHQnXG5pbXBvcnQgeyBQT1BVUF9XSURUSCB9IGZyb20gJy4uL2NvbnN0YW50cydcbmltcG9ydCB7IGdldE5leHRNb250aCwgZ2V0UHJldmlvdXNNb250aCB9IGZyb20gJy4uL2hlbHBlcnMnXG5pbXBvcnQgeyBEYWlseSB9IGZyb20gJy4vQ2FsZW5kYXJEYWlseSdcbmltcG9ydCB7IE1vbnRobHkgfSBmcm9tICcuL0NhbGVuZGFyTW9udGhseSdcblxuY29uc3QgQ2FwaXRhbGl6ZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHRleHQtdHJhbnNmb3JtOiBsb3dlcmNhc2U7XG5cbiAgJjo6Zmlyc3QtbGV0dGVyIHtcbiAgICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICB9XG5gXG50eXBlIFBvcHVwUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdmlzaWJsZTogYm9vbGVhblxuICBzZXRWaXNpYmxlOiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxib29sZWFuPj5cbiAgcmVmSW5wdXQ6IFJlZk9iamVjdDxIVE1MSW5wdXRFbGVtZW50IHwgbnVsbD5cbn1cblxuY29uc3QgU3R5bGVkUG9wdXAgPSBzdHlsZWQoUG9wdXApYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMub3RoZXIuZWxldmF0aW9uLmJhY2tncm91bmQucmFpc2VkfTtcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dH07XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5yYWlzZWRbMF19LCAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzFdfWB9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbmBcblxuY29uc3QgaGFuZGxlQ2xpY2tPdXRzaWRlID0gKFxuICBldmVudDogTW91c2VFdmVudCxcbiAgcmVmOiBSZWZPYmplY3Q8SFRNTERpdkVsZW1lbnQgfCBudWxsPixcbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+LFxuICByZWZJbnB1dDogUmVmT2JqZWN0PEhUTUxJbnB1dEVsZW1lbnQgfCBudWxsPixcbikgPT4ge1xuICBpZiAoXG4gICAgcmVmLmN1cnJlbnQgJiZcbiAgICAhcmVmLmN1cnJlbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0IGFzIE5vZGUpICYmXG4gICAgIXJlZklucHV0LmN1cnJlbnQ/LmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBOb2RlKVxuICApIHtcbiAgICBzZXRWaXNpYmxlKGZhbHNlKVxuICB9XG59XG5cbmNvbnN0IFBvcHVwQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICFtaW5EYXRlIHx8XG4gICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFtwcmV2TW9udGgsIHllYXJdID0gZ2V0UHJldmlvdXNNb250aChcbiAgICAgICAgICAgICAgICAgIG1vbnRoVG9TaG93LFxuICAgICAgICAgICAgICAgICAgeWVhclRvU2hvdyxcbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgc2V0TW9udGhUb1Nob3cocHJldk1vbnRoKVxuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhcilcbiAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXJUb1Nob3cgLSAxKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBkaXNhYmxlZD17XG4gICAgICAgICAgICAhIShtaW5EYXRlICYmIG1pbkRhdGUgPiBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdyAtIDEsIDApKVxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dCBhcz1cInNwYW5cIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiIHNlbnRpbWVudD1cIm5ldXRyYWxcIj5cbiAgICAgICAgICB7IXNob3dNb250aFllYXJQaWNrZXIgPyBNT05USFNfQVJSW21vbnRoVG9TaG93IC0gMV0gOiBudWxsfXsnICd9XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFtYXhEYXRlIHx8IG1heERhdGUgPj0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKVxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7c2hvd01vbnRoWWVhclBpY2tlciA/IChcbiAgICAgICAgPE1vbnRobHkgZGlzYWJsZWQ9e2Rpc2FibGVkfSAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPERhaWx5IGRpc2FibGVkPXtkaXNhYmxlZH0gLz5cbiAgICAgICl9XG4gICAgPC9TdGFjaz5cbiAgKVxufVxuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXJQb3B1cCA9ICh7XG4gIGNoaWxkcmVuLFxuICB2aXNpYmxlLFxuICBzZXRWaXNpYmxlLFxuICByZWZJbnB1dCxcbn06IFBvcHVwUHJvcHMpID0+IHtcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgIGhhbmRsZUNsaWNrT3V0c2lkZShldmVudCwgcmVmLCBzZXRWaXNpYmxlLCByZWZJbnB1dCksXG4gICAgKVxuXG4gICAgcmV0dXJuICgpID0+XG4gICAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdtb3VzZWRvd24nLCBldmVudCA9PlxuICAgICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgICAgKVxuICB9LCBbcmVmLCBzZXRWaXNpYmxlLCByZWZJbnB1dF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkUG9wdXBcbiAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICB0ZXh0PXs8UG9wdXBDb250ZW50IC8+fVxuICAgICAgcGxhY2VtZW50PVwiYm90dG9tXCJcbiAgICAgIHJlZj17cmVmfVxuICAgICAgaGFzQXJyb3c9e2ZhbHNlfVxuICAgICAgdGFiSW5kZXg9ezB9XG4gICAgICByb2xlPVwiZGlhbG9nXCJcbiAgICAgIGRlYm91bmNlRGVsYXk9ezB9XG4gICAgICBtYXhXaWR0aD17UE9QVVBfV0lEVEh9XG4gICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRQb3B1cD5cbiAgKVxufVxuIl19 */",
|
|
31
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
32
|
-
});
|
|
33
|
-
const StyledPopup = /* @__PURE__ */ _styled__default.default(index$1.Popup, process.env.NODE_ENV === "production" ? {
|
|
11
|
+
const StyledPopup = /* @__PURE__ */ _styled__default.default(index.Popup, process.env.NODE_ENV === "production" ? {
|
|
34
12
|
target: "e17y63oo0"
|
|
35
13
|
} : {
|
|
36
14
|
target: "e17y63oo0",
|
|
37
15
|
label: "StyledPopup"
|
|
38
|
-
})(
|
|
39
|
-
theme
|
|
40
|
-
}) => theme.colors.other.elevation.background.raised, ";color:", ({
|
|
16
|
+
})(({
|
|
41
17
|
theme
|
|
42
|
-
}) => theme
|
|
18
|
+
}) => helpers.styleCalendarContainer(theme), " box-shadow:", ({
|
|
43
19
|
theme
|
|
44
|
-
}) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";
|
|
45
|
-
theme
|
|
46
|
-
}) => theme.space[2], ";border-radius:", ({
|
|
47
|
-
theme
|
|
48
|
-
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgUmVhY3ROb2RlLCBSZWZPYmplY3QsIFNldFN0YXRlQWN0aW9uIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vLi4vQnV0dG9uJ1xuaW1wb3J0IHsgUG9wdXAgfSBmcm9tICcuLi8uLi9Qb3B1cCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgUE9QVVBfV0lEVEggfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXROZXh0TW9udGgsIGdldFByZXZpb3VzTW9udGggfSBmcm9tICcuLi9oZWxwZXJzJ1xuaW1wb3J0IHsgRGFpbHkgfSBmcm9tICcuL0NhbGVuZGFyRGFpbHknXG5pbXBvcnQgeyBNb250aGx5IH0gZnJvbSAnLi9DYWxlbmRhck1vbnRobHknXG5cbmNvbnN0IENhcGl0YWxpemVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICB0ZXh0LXRyYW5zZm9ybTogbG93ZXJjYXNlO1xuXG4gICY6OmZpcnN0LWxldHRlciB7XG4gICAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbiAgfVxuYFxudHlwZSBQb3B1cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHZpc2libGU6IGJvb2xlYW5cbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+XG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+XG59XG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwKWBcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm90aGVyLmVsZXZhdGlvbi5iYWNrZ3JvdW5kLnJhaXNlZH07XG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IGAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzBdfSwgJHt0aGVtZS5zaGFkb3dzLnJhaXNlZFsxXX1gfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG5gXG5cbmNvbnN0IGhhbmRsZUNsaWNrT3V0c2lkZSA9IChcbiAgZXZlbnQ6IE1vdXNlRXZlbnQsXG4gIHJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50IHwgbnVsbD4sXG4gIHNldFZpc2libGU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PixcbiAgcmVmSW5wdXQ6IFJlZk9iamVjdDxIVE1MSW5wdXRFbGVtZW50IHwgbnVsbD4sXG4pID0+IHtcbiAgaWYgKFxuICAgIHJlZi5jdXJyZW50ICYmXG4gICAgIXJlZi5jdXJyZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBOb2RlKSAmJlxuICAgICFyZWZJbnB1dC5jdXJyZW50Py5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSlcbiAgKSB7XG4gICAgc2V0VmlzaWJsZShmYWxzZSlcbiAgfVxufVxuXG5jb25zdCBQb3B1cENvbnRlbnQgPSAoKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBzaG93TW9udGhZZWFyUGlja2VyLFxuICAgIGRpc2FibGVkLFxuICAgIG1vbnRoVG9TaG93LFxuICAgIHllYXJUb1Nob3csXG4gICAgc2V0TW9udGhUb1Nob3csXG4gICAgc2V0WWVhclRvU2hvdyxcbiAgICBtYXhEYXRlLFxuICAgIG1pbkRhdGUsXG4gICAgTU9OVEhTX0FSUixcbiAgfSA9IHVzZUNvbnRleHQoRGF0ZUlucHV0Q29udGV4dClcblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBnYXA9ezJ9PlxuICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIHdpZHRoPVwiMTAwJVwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LWxlZnRcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPVwicHJldmlvdXMtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAhbWluRGF0ZSB8fFxuICAgICAgICAgICAgICBtaW5EYXRlIDw9IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICBpZiAoIXNob3dNb250aFllYXJQaWNrZXIpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBbcHJldk1vbnRoLCB5ZWFyXSA9IGdldFByZXZpb3VzTW9udGgoXG4gICAgICAgICAgICAgICAgICBtb250aFRvU2hvdyxcbiAgICAgICAgICAgICAgICAgIHllYXJUb1Nob3csXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KHByZXZNb250aClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93IC0gMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWluRGF0ZSAmJiBtaW5EYXRlID4gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSlcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICAgIDxDYXBpdGFsaXplZFRleHQgYXM9XCJzcGFuXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCI+XG4gICAgICAgICAgeyFzaG93TW9udGhZZWFyUGlja2VyID8gTU9OVEhTX0FSUlttb250aFRvU2hvdyAtIDFdIDogbnVsbH17JyAnfVxuICAgICAgICAgIHt5ZWFyVG9TaG93fVxuICAgICAgICA8L0NhcGl0YWxpemVkVGV4dD5cbiAgICAgICAgPEJ1dHRvblxuICAgICAgICAgIGljb249XCJhcnJvdy1yaWdodFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJuZXh0LW1vbnRoXCJcbiAgICAgICAgICB2YXJpYW50PVwiZ2hvc3RcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIHNpemU9XCJ4c21hbGxcIlxuICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgIGlmICghbWF4RGF0ZSB8fCBtYXhEYXRlID49IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93LCAxKSkge1xuICAgICAgICAgICAgICBpZiAoIXNob3dNb250aFllYXJQaWNrZXIpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBbbW9udGhOZXh0LCB5ZWFyXSA9IGdldE5leHRNb250aChtb250aFRvU2hvdywgeWVhclRvU2hvdylcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhtb250aE5leHQpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyArIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1heERhdGUgJiYgbWF4RGF0ZSA8IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93LCAxKSlcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyAoXG4gICAgICAgIDxNb250aGx5IGRpc2FibGVkPXtkaXNhYmxlZH0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxEYWlseSBkaXNhYmxlZD17ZGlzYWJsZWR9IC8+XG4gICAgICApfVxuICAgIDwvU3RhY2s+XG4gIClcbn1cblxuZXhwb3J0IGNvbnN0IENhbGVuZGFyUG9wdXAgPSAoe1xuICBjaGlsZHJlbixcbiAgdmlzaWJsZSxcbiAgc2V0VmlzaWJsZSxcbiAgcmVmSW5wdXQsXG59OiBQb3B1cFByb3BzKSA9PiB7XG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGV2ZW50ID0+XG4gICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgIClcblxuICAgIHJldHVybiAoKSA9PlxuICAgICAgZG9jdW1lbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgICAgaGFuZGxlQ2xpY2tPdXRzaWRlKGV2ZW50LCByZWYsIHNldFZpc2libGUsIHJlZklucHV0KSxcbiAgICAgIClcbiAgfSwgW3JlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFBvcHVwXG4gICAgICB2aXNpYmxlPXt2aXNpYmxlfVxuICAgICAgdGV4dD17PFBvcHVwQ29udGVudCAvPn1cbiAgICAgIHBsYWNlbWVudD1cImJvdHRvbVwiXG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Fycm93PXtmYWxzZX1cbiAgICAgIHRhYkluZGV4PXswfVxuICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgbWF4V2lkdGg9e1BPUFVQX1dJRFRIfVxuICAgICAgZGlzYWJsZUFuaW1hdGlvblxuICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkUG9wdXA+XG4gIClcbn1cbiJdfQ== */"));
|
|
20
|
+
}) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRGF0ZUlucHV0L2NvbXBvbmVudHMvUG9wdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IERpc3BhdGNoLCBSZWFjdE5vZGUsIFJlZk9iamVjdCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uLy4uL1BvcHVwJ1xuaW1wb3J0IHsgUE9QVVBfV0lEVEggfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyBzdHlsZUNhbGVuZGFyQ29udGFpbmVyIH0gZnJvbSAnLi4vaGVscGVycydcblxudHlwZSBQb3B1cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHZpc2libGU6IGJvb2xlYW5cbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+XG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+XG4gIGNvbnRlbnQ6IFJlYWN0Tm9kZVxufVxuXG5jb25zdCBTdHlsZWRQb3B1cCA9IHN0eWxlZChQb3B1cClgXG4gICR7KHsgdGhlbWUgfSkgPT4gc3R5bGVDYWxlbmRhckNvbnRhaW5lcih0aGVtZSl9XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5yYWlzZWRbMF19LCAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzFdfWB9O1xuYFxuXG5jb25zdCBoYW5kbGVDbGlja091dHNpZGUgPSAoXG4gIGV2ZW50OiBNb3VzZUV2ZW50LFxuICByZWY6IFJlZk9iamVjdDxIVE1MRGl2RWxlbWVudCB8IG51bGw+LFxuICBzZXRWaXNpYmxlOiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxib29sZWFuPj4sXG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+LFxuKSA9PiB7XG4gIGlmIChcbiAgICByZWYuY3VycmVudCAmJlxuICAgICFyZWYuY3VycmVudC5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSkgJiZcbiAgICAhcmVmSW5wdXQuY3VycmVudD8uY29udGFpbnMoZXZlbnQudGFyZ2V0IGFzIE5vZGUpXG4gICkge1xuICAgIHNldFZpc2libGUoZmFsc2UpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IENhbGVuZGFyUG9wdXAgPSAoe1xuICBjaGlsZHJlbixcbiAgdmlzaWJsZSxcbiAgc2V0VmlzaWJsZSxcbiAgcmVmSW5wdXQsXG4gIGNvbnRlbnQsXG59OiBQb3B1cFByb3BzKSA9PiB7XG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGV2ZW50ID0+XG4gICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgIClcblxuICAgIHJldHVybiAoKSA9PlxuICAgICAgZG9jdW1lbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgICAgaGFuZGxlQ2xpY2tPdXRzaWRlKGV2ZW50LCByZWYsIHNldFZpc2libGUsIHJlZklucHV0KSxcbiAgICAgIClcbiAgfSwgW3JlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFBvcHVwXG4gICAgICB2aXNpYmxlPXt2aXNpYmxlfVxuICAgICAgdGV4dD17Y29udGVudH1cbiAgICAgIHBsYWNlbWVudD1cImJvdHRvbVwiXG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Fycm93PXtmYWxzZX1cbiAgICAgIHRhYkluZGV4PXswfVxuICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgbWF4V2lkdGg9e1BPUFVQX1dJRFRIfVxuICAgICAgZGlzYWJsZUFuaW1hdGlvblxuICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkUG9wdXA+XG4gIClcbn1cbiJdfQ== */"));
|
|
49
21
|
const handleClickOutside = (event, ref, setVisible, refInput) => {
|
|
50
22
|
if (ref.current && !ref.current.contains(event.target) && !refInput.current?.contains(event.target)) {
|
|
51
23
|
setVisible(false);
|
|
52
24
|
}
|
|
53
25
|
};
|
|
54
|
-
const PopupContent = () => {
|
|
55
|
-
const {
|
|
56
|
-
showMonthYearPicker,
|
|
57
|
-
disabled,
|
|
58
|
-
monthToShow,
|
|
59
|
-
yearToShow,
|
|
60
|
-
setMonthToShow,
|
|
61
|
-
setYearToShow,
|
|
62
|
-
maxDate,
|
|
63
|
-
minDate,
|
|
64
|
-
MONTHS_ARR
|
|
65
|
-
} = React.useContext(Context.DateInputContext);
|
|
66
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(index$2.Stack, { gap: 2, children: [
|
|
67
|
-
/* @__PURE__ */ jsxRuntime.jsxs(index$2.Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
68
|
-
/* @__PURE__ */ jsxRuntime.jsx(index$3.Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
69
|
-
if (!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) {
|
|
70
|
-
if (!showMonthYearPicker) {
|
|
71
|
-
const [prevMonth, year] = helpers.getPreviousMonth(monthToShow, yearToShow);
|
|
72
|
-
setMonthToShow(prevMonth);
|
|
73
|
-
setYearToShow(year);
|
|
74
|
-
} else {
|
|
75
|
-
setYearToShow(yearToShow - 1);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) }),
|
|
79
|
-
/* @__PURE__ */ jsxRuntime.jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", children: [
|
|
80
|
-
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
81
|
-
" ",
|
|
82
|
-
yearToShow
|
|
83
|
-
] }),
|
|
84
|
-
/* @__PURE__ */ jsxRuntime.jsx(index$3.Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
85
|
-
if (!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) {
|
|
86
|
-
if (!showMonthYearPicker) {
|
|
87
|
-
const [monthNext, year] = helpers.getNextMonth(monthToShow, yearToShow);
|
|
88
|
-
setMonthToShow(monthNext);
|
|
89
|
-
setYearToShow(year);
|
|
90
|
-
} else {
|
|
91
|
-
setYearToShow(yearToShow + 1);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) })
|
|
95
|
-
] }),
|
|
96
|
-
showMonthYearPicker ? /* @__PURE__ */ jsxRuntime.jsx(CalendarMonthly.Monthly, { disabled }) : /* @__PURE__ */ jsxRuntime.jsx(CalendarDaily.Daily, { disabled })
|
|
97
|
-
] });
|
|
98
|
-
};
|
|
99
26
|
const CalendarPopup = ({
|
|
100
27
|
children,
|
|
101
28
|
visible,
|
|
102
29
|
setVisible,
|
|
103
|
-
refInput
|
|
30
|
+
refInput,
|
|
31
|
+
content
|
|
104
32
|
}) => {
|
|
105
33
|
const ref = React.useRef(null);
|
|
106
34
|
React.useEffect(() => {
|
|
107
35
|
document.addEventListener("mousedown", (event) => handleClickOutside(event, ref, setVisible, refInput));
|
|
108
36
|
return () => document.removeEventListener("mousedown", (event) => handleClickOutside(event, ref, setVisible, refInput));
|
|
109
37
|
}, [ref, setVisible, refInput]);
|
|
110
|
-
return /* @__PURE__ */ jsxRuntime.jsx(StyledPopup, { visible, text:
|
|
38
|
+
return /* @__PURE__ */ jsxRuntime.jsx(StyledPopup, { visible, text: content, placement: "bottom", ref, hasArrow: false, tabIndex: 0, role: "dialog", debounceDelay: 0, maxWidth: constants.POPUP_WIDTH, disableAnimation: true, align: "start", children });
|
|
111
39
|
};
|
|
112
40
|
exports.CalendarPopup = CalendarPopup;
|
|
@@ -4,6 +4,7 @@ type PopupProps = {
|
|
|
4
4
|
visible: boolean;
|
|
5
5
|
setVisible: Dispatch<SetStateAction<boolean>>;
|
|
6
6
|
refInput: RefObject<HTMLInputElement | null>;
|
|
7
|
+
content: ReactNode;
|
|
7
8
|
};
|
|
8
|
-
export declare const CalendarPopup: ({ children, visible, setVisible, refInput, }: PopupProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare const CalendarPopup: ({ children, visible, setVisible, refInput, content, }: PopupProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
9
10
|
export {};
|
|
@@ -1,109 +1,37 @@
|
|
|
1
|
-
import { jsx
|
|
1
|
+
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import _styled from "@emotion/styled/base";
|
|
3
|
-
import { useRef, useEffect
|
|
4
|
-
import { Button } from "../../Button/index.js";
|
|
3
|
+
import { useRef, useEffect } from "react";
|
|
5
4
|
import { Popup } from "../../Popup/index.js";
|
|
6
|
-
import { Stack } from "../../Stack/index.js";
|
|
7
|
-
import { Text } from "../../Text/index.js";
|
|
8
|
-
import { DateInputContext } from "../Context.js";
|
|
9
5
|
import { POPUP_WIDTH } from "../constants.js";
|
|
10
|
-
import {
|
|
11
|
-
import { Daily } from "./CalendarDaily.js";
|
|
12
|
-
import { Monthly } from "./CalendarMonthly.js";
|
|
13
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
14
|
-
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).";
|
|
15
|
-
}
|
|
16
|
-
const CapitalizedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
17
|
-
target: "e17y63oo1"
|
|
18
|
-
} : {
|
|
19
|
-
target: "e17y63oo1",
|
|
20
|
-
label: "CapitalizedText"
|
|
21
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
22
|
-
name: "88dib2",
|
|
23
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}"
|
|
24
|
-
} : {
|
|
25
|
-
name: "88dib2",
|
|
26
|
-
styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhb0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRGF0ZUlucHV0L2NvbXBvbmVudHMvUG9wdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IERpc3BhdGNoLCBSZWFjdE5vZGUsIFJlZk9iamVjdCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNvbnRleHQsIHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi8uLi9CdXR0b24nXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uLy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi8uLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi8uLi9UZXh0J1xuaW1wb3J0IHsgRGF0ZUlucHV0Q29udGV4dCB9IGZyb20gJy4uL0NvbnRleHQnXG5pbXBvcnQgeyBQT1BVUF9XSURUSCB9IGZyb20gJy4uL2NvbnN0YW50cydcbmltcG9ydCB7IGdldE5leHRNb250aCwgZ2V0UHJldmlvdXNNb250aCB9IGZyb20gJy4uL2hlbHBlcnMnXG5pbXBvcnQgeyBEYWlseSB9IGZyb20gJy4vQ2FsZW5kYXJEYWlseSdcbmltcG9ydCB7IE1vbnRobHkgfSBmcm9tICcuL0NhbGVuZGFyTW9udGhseSdcblxuY29uc3QgQ2FwaXRhbGl6ZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHRleHQtdHJhbnNmb3JtOiBsb3dlcmNhc2U7XG5cbiAgJjo6Zmlyc3QtbGV0dGVyIHtcbiAgICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICB9XG5gXG50eXBlIFBvcHVwUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdmlzaWJsZTogYm9vbGVhblxuICBzZXRWaXNpYmxlOiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxib29sZWFuPj5cbiAgcmVmSW5wdXQ6IFJlZk9iamVjdDxIVE1MSW5wdXRFbGVtZW50IHwgbnVsbD5cbn1cblxuY29uc3QgU3R5bGVkUG9wdXAgPSBzdHlsZWQoUG9wdXApYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMub3RoZXIuZWxldmF0aW9uLmJhY2tncm91bmQucmFpc2VkfTtcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dH07XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5yYWlzZWRbMF19LCAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzFdfWB9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbmBcblxuY29uc3QgaGFuZGxlQ2xpY2tPdXRzaWRlID0gKFxuICBldmVudDogTW91c2VFdmVudCxcbiAgcmVmOiBSZWZPYmplY3Q8SFRNTERpdkVsZW1lbnQgfCBudWxsPixcbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+LFxuICByZWZJbnB1dDogUmVmT2JqZWN0PEhUTUxJbnB1dEVsZW1lbnQgfCBudWxsPixcbikgPT4ge1xuICBpZiAoXG4gICAgcmVmLmN1cnJlbnQgJiZcbiAgICAhcmVmLmN1cnJlbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0IGFzIE5vZGUpICYmXG4gICAgIXJlZklucHV0LmN1cnJlbnQ/LmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBOb2RlKVxuICApIHtcbiAgICBzZXRWaXNpYmxlKGZhbHNlKVxuICB9XG59XG5cbmNvbnN0IFBvcHVwQ29udGVudCA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIHNob3dNb250aFllYXJQaWNrZXIsXG4gICAgZGlzYWJsZWQsXG4gICAgbW9udGhUb1Nob3csXG4gICAgeWVhclRvU2hvdyxcbiAgICBzZXRNb250aFRvU2hvdyxcbiAgICBzZXRZZWFyVG9TaG93LFxuICAgIG1heERhdGUsXG4gICAgbWluRGF0ZSxcbiAgICBNT05USFNfQVJSLFxuICB9ID0gdXNlQ29udGV4dChEYXRlSW5wdXRDb250ZXh0KVxuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIGdhcD17Mn0+XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgd2lkdGg9XCIxMDAlXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICAgIDxCdXR0b25cbiAgICAgICAgICBpY29uPVwiYXJyb3ctbGVmdFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJwcmV2aW91cy1tb250aFwiXG4gICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICBzaXplPVwieHNtYWxsXCJcbiAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICFtaW5EYXRlIHx8XG4gICAgICAgICAgICAgIG1pbkRhdGUgPD0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFtwcmV2TW9udGgsIHllYXJdID0gZ2V0UHJldmlvdXNNb250aChcbiAgICAgICAgICAgICAgICAgIG1vbnRoVG9TaG93LFxuICAgICAgICAgICAgICAgICAgeWVhclRvU2hvdyxcbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgc2V0TW9udGhUb1Nob3cocHJldk1vbnRoKVxuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhcilcbiAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXJUb1Nob3cgLSAxKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBkaXNhYmxlZD17XG4gICAgICAgICAgICAhIShtaW5EYXRlICYmIG1pbkRhdGUgPiBuZXcgRGF0ZSh5ZWFyVG9TaG93LCBtb250aFRvU2hvdyAtIDEsIDApKVxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgICAgPENhcGl0YWxpemVkVGV4dCBhcz1cInNwYW5cIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiIHNlbnRpbWVudD1cIm5ldXRyYWxcIj5cbiAgICAgICAgICB7IXNob3dNb250aFllYXJQaWNrZXIgPyBNT05USFNfQVJSW21vbnRoVG9TaG93IC0gMV0gOiBudWxsfXsnICd9XG4gICAgICAgICAge3llYXJUb1Nob3d9XG4gICAgICAgIDwvQ2FwaXRhbGl6ZWRUZXh0PlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LXJpZ2h0XCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD1cIm5leHQtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFtYXhEYXRlIHx8IG1heERhdGUgPj0gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKSB7XG4gICAgICAgICAgICAgIGlmICghc2hvd01vbnRoWWVhclBpY2tlcikge1xuICAgICAgICAgICAgICAgIGNvbnN0IFttb250aE5leHQsIHllYXJdID0gZ2V0TmV4dE1vbnRoKG1vbnRoVG9TaG93LCB5ZWFyVG9TaG93KVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KG1vbnRoTmV4dClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93ICsgMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWF4RGF0ZSAmJiBtYXhEYXRlIDwgbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3csIDEpKVxuICAgICAgICAgIH1cbiAgICAgICAgLz5cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7c2hvd01vbnRoWWVhclBpY2tlciA/IChcbiAgICAgICAgPE1vbnRobHkgZGlzYWJsZWQ9e2Rpc2FibGVkfSAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPERhaWx5IGRpc2FibGVkPXtkaXNhYmxlZH0gLz5cbiAgICAgICl9XG4gICAgPC9TdGFjaz5cbiAgKVxufVxuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXJQb3B1cCA9ICh7XG4gIGNoaWxkcmVuLFxuICB2aXNpYmxlLFxuICBzZXRWaXNpYmxlLFxuICByZWZJbnB1dCxcbn06IFBvcHVwUHJvcHMpID0+IHtcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgIGhhbmRsZUNsaWNrT3V0c2lkZShldmVudCwgcmVmLCBzZXRWaXNpYmxlLCByZWZJbnB1dCksXG4gICAgKVxuXG4gICAgcmV0dXJuICgpID0+XG4gICAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdtb3VzZWRvd24nLCBldmVudCA9PlxuICAgICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgICAgKVxuICB9LCBbcmVmLCBzZXRWaXNpYmxlLCByZWZJbnB1dF0pXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkUG9wdXBcbiAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICB0ZXh0PXs8UG9wdXBDb250ZW50IC8+fVxuICAgICAgcGxhY2VtZW50PVwiYm90dG9tXCJcbiAgICAgIHJlZj17cmVmfVxuICAgICAgaGFzQXJyb3c9e2ZhbHNlfVxuICAgICAgdGFiSW5kZXg9ezB9XG4gICAgICByb2xlPVwiZGlhbG9nXCJcbiAgICAgIGRlYm91bmNlRGVsYXk9ezB9XG4gICAgICBtYXhXaWR0aD17UE9QVVBfV0lEVEh9XG4gICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRQb3B1cD5cbiAgKVxufVxuIl19 */",
|
|
27
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
28
|
-
});
|
|
6
|
+
import { styleCalendarContainer } from "../helpers.js";
|
|
29
7
|
const StyledPopup = /* @__PURE__ */ _styled(Popup, process.env.NODE_ENV === "production" ? {
|
|
30
8
|
target: "e17y63oo0"
|
|
31
9
|
} : {
|
|
32
10
|
target: "e17y63oo0",
|
|
33
11
|
label: "StyledPopup"
|
|
34
|
-
})(
|
|
35
|
-
theme
|
|
36
|
-
}) => theme.colors.other.elevation.background.raised, ";color:", ({
|
|
12
|
+
})(({
|
|
37
13
|
theme
|
|
38
|
-
}) => theme
|
|
14
|
+
}) => styleCalendarContainer(theme), " box-shadow:", ({
|
|
39
15
|
theme
|
|
40
|
-
}) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";
|
|
41
|
-
theme
|
|
42
|
-
}) => theme.space[2], ";border-radius:", ({
|
|
43
|
-
theme
|
|
44
|
-
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBEaXNwYXRjaCwgUmVhY3ROb2RlLCBSZWZPYmplY3QsIFNldFN0YXRlQWN0aW9uIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDb250ZXh0LCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vLi4vQnV0dG9uJ1xuaW1wb3J0IHsgUG9wdXAgfSBmcm9tICcuLi8uLi9Qb3B1cCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vVGV4dCdcbmltcG9ydCB7IERhdGVJbnB1dENvbnRleHQgfSBmcm9tICcuLi9Db250ZXh0J1xuaW1wb3J0IHsgUE9QVVBfV0lEVEggfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXROZXh0TW9udGgsIGdldFByZXZpb3VzTW9udGggfSBmcm9tICcuLi9oZWxwZXJzJ1xuaW1wb3J0IHsgRGFpbHkgfSBmcm9tICcuL0NhbGVuZGFyRGFpbHknXG5pbXBvcnQgeyBNb250aGx5IH0gZnJvbSAnLi9DYWxlbmRhck1vbnRobHknXG5cbmNvbnN0IENhcGl0YWxpemVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICB0ZXh0LXRyYW5zZm9ybTogbG93ZXJjYXNlO1xuXG4gICY6OmZpcnN0LWxldHRlciB7XG4gICAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbiAgfVxuYFxudHlwZSBQb3B1cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHZpc2libGU6IGJvb2xlYW5cbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+XG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+XG59XG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwKWBcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm90aGVyLmVsZXZhdGlvbi5iYWNrZ3JvdW5kLnJhaXNlZH07XG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IGAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzBdfSwgJHt0aGVtZS5zaGFkb3dzLnJhaXNlZFsxXX1gfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsyXX07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG5gXG5cbmNvbnN0IGhhbmRsZUNsaWNrT3V0c2lkZSA9IChcbiAgZXZlbnQ6IE1vdXNlRXZlbnQsXG4gIHJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50IHwgbnVsbD4sXG4gIHNldFZpc2libGU6IERpc3BhdGNoPFNldFN0YXRlQWN0aW9uPGJvb2xlYW4+PixcbiAgcmVmSW5wdXQ6IFJlZk9iamVjdDxIVE1MSW5wdXRFbGVtZW50IHwgbnVsbD4sXG4pID0+IHtcbiAgaWYgKFxuICAgIHJlZi5jdXJyZW50ICYmXG4gICAgIXJlZi5jdXJyZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBOb2RlKSAmJlxuICAgICFyZWZJbnB1dC5jdXJyZW50Py5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSlcbiAgKSB7XG4gICAgc2V0VmlzaWJsZShmYWxzZSlcbiAgfVxufVxuXG5jb25zdCBQb3B1cENvbnRlbnQgPSAoKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBzaG93TW9udGhZZWFyUGlja2VyLFxuICAgIGRpc2FibGVkLFxuICAgIG1vbnRoVG9TaG93LFxuICAgIHllYXJUb1Nob3csXG4gICAgc2V0TW9udGhUb1Nob3csXG4gICAgc2V0WWVhclRvU2hvdyxcbiAgICBtYXhEYXRlLFxuICAgIG1pbkRhdGUsXG4gICAgTU9OVEhTX0FSUixcbiAgfSA9IHVzZUNvbnRleHQoRGF0ZUlucHV0Q29udGV4dClcblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBnYXA9ezJ9PlxuICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIHdpZHRoPVwiMTAwJVwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgaWNvbj1cImFycm93LWxlZnRcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPVwicHJldmlvdXMtbW9udGhcIlxuICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgc2l6ZT1cInhzbWFsbFwiXG4gICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgaWYgKFxuICAgICAgICAgICAgICAhbWluRGF0ZSB8fFxuICAgICAgICAgICAgICBtaW5EYXRlIDw9IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93IC0gMSwgMClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICBpZiAoIXNob3dNb250aFllYXJQaWNrZXIpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBbcHJldk1vbnRoLCB5ZWFyXSA9IGdldFByZXZpb3VzTW9udGgoXG4gICAgICAgICAgICAgICAgICBtb250aFRvU2hvdyxcbiAgICAgICAgICAgICAgICAgIHllYXJUb1Nob3csXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgIHNldE1vbnRoVG9TaG93KHByZXZNb250aClcbiAgICAgICAgICAgICAgICBzZXRZZWFyVG9TaG93KHllYXIpXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyVG9TaG93IC0gMSlcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgZGlzYWJsZWQ9e1xuICAgICAgICAgICAgISEobWluRGF0ZSAmJiBtaW5EYXRlID4gbmV3IERhdGUoeWVhclRvU2hvdywgbW9udGhUb1Nob3cgLSAxLCAwKSlcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICAgIDxDYXBpdGFsaXplZFRleHQgYXM9XCJzcGFuXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCI+XG4gICAgICAgICAgeyFzaG93TW9udGhZZWFyUGlja2VyID8gTU9OVEhTX0FSUlttb250aFRvU2hvdyAtIDFdIDogbnVsbH17JyAnfVxuICAgICAgICAgIHt5ZWFyVG9TaG93fVxuICAgICAgICA8L0NhcGl0YWxpemVkVGV4dD5cbiAgICAgICAgPEJ1dHRvblxuICAgICAgICAgIGljb249XCJhcnJvdy1yaWdodFwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9XCJuZXh0LW1vbnRoXCJcbiAgICAgICAgICB2YXJpYW50PVwiZ2hvc3RcIlxuICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgIHNpemU9XCJ4c21hbGxcIlxuICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgIGlmICghbWF4RGF0ZSB8fCBtYXhEYXRlID49IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93LCAxKSkge1xuICAgICAgICAgICAgICBpZiAoIXNob3dNb250aFllYXJQaWNrZXIpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBbbW9udGhOZXh0LCB5ZWFyXSA9IGdldE5leHRNb250aChtb250aFRvU2hvdywgeWVhclRvU2hvdylcbiAgICAgICAgICAgICAgICBzZXRNb250aFRvU2hvdyhtb250aE5leHQpXG4gICAgICAgICAgICAgICAgc2V0WWVhclRvU2hvdyh5ZWFyKVxuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNldFllYXJUb1Nob3coeWVhclRvU2hvdyArIDEpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIGRpc2FibGVkPXtcbiAgICAgICAgICAgICEhKG1heERhdGUgJiYgbWF4RGF0ZSA8IG5ldyBEYXRlKHllYXJUb1Nob3csIG1vbnRoVG9TaG93LCAxKSlcbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L1N0YWNrPlxuICAgICAge3Nob3dNb250aFllYXJQaWNrZXIgPyAoXG4gICAgICAgIDxNb250aGx5IGRpc2FibGVkPXtkaXNhYmxlZH0gLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxEYWlseSBkaXNhYmxlZD17ZGlzYWJsZWR9IC8+XG4gICAgICApfVxuICAgIDwvU3RhY2s+XG4gIClcbn1cblxuZXhwb3J0IGNvbnN0IENhbGVuZGFyUG9wdXAgPSAoe1xuICBjaGlsZHJlbixcbiAgdmlzaWJsZSxcbiAgc2V0VmlzaWJsZSxcbiAgcmVmSW5wdXQsXG59OiBQb3B1cFByb3BzKSA9PiB7XG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGV2ZW50ID0+XG4gICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgIClcblxuICAgIHJldHVybiAoKSA9PlxuICAgICAgZG9jdW1lbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgICAgaGFuZGxlQ2xpY2tPdXRzaWRlKGV2ZW50LCByZWYsIHNldFZpc2libGUsIHJlZklucHV0KSxcbiAgICAgIClcbiAgfSwgW3JlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFBvcHVwXG4gICAgICB2aXNpYmxlPXt2aXNpYmxlfVxuICAgICAgdGV4dD17PFBvcHVwQ29udGVudCAvPn1cbiAgICAgIHBsYWNlbWVudD1cImJvdHRvbVwiXG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Fycm93PXtmYWxzZX1cbiAgICAgIHRhYkluZGV4PXswfVxuICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgbWF4V2lkdGg9e1BPUFVQX1dJRFRIfVxuICAgICAgZGlzYWJsZUFuaW1hdGlvblxuICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkUG9wdXA+XG4gIClcbn1cbiJdfQ== */"));
|
|
16
|
+
}) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0RhdGVJbnB1dC9jb21wb25lbnRzL1BvcHVwLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRGF0ZUlucHV0L2NvbXBvbmVudHMvUG9wdXAudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IERpc3BhdGNoLCBSZWFjdE5vZGUsIFJlZk9iamVjdCwgU2V0U3RhdGVBY3Rpb24gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uLy4uL1BvcHVwJ1xuaW1wb3J0IHsgUE9QVVBfV0lEVEggfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyBzdHlsZUNhbGVuZGFyQ29udGFpbmVyIH0gZnJvbSAnLi4vaGVscGVycydcblxudHlwZSBQb3B1cFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHZpc2libGU6IGJvb2xlYW5cbiAgc2V0VmlzaWJsZTogRGlzcGF0Y2g8U2V0U3RhdGVBY3Rpb248Ym9vbGVhbj4+XG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+XG4gIGNvbnRlbnQ6IFJlYWN0Tm9kZVxufVxuXG5jb25zdCBTdHlsZWRQb3B1cCA9IHN0eWxlZChQb3B1cClgXG4gICR7KHsgdGhlbWUgfSkgPT4gc3R5bGVDYWxlbmRhckNvbnRhaW5lcih0aGVtZSl9XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5yYWlzZWRbMF19LCAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzFdfWB9O1xuYFxuXG5jb25zdCBoYW5kbGVDbGlja091dHNpZGUgPSAoXG4gIGV2ZW50OiBNb3VzZUV2ZW50LFxuICByZWY6IFJlZk9iamVjdDxIVE1MRGl2RWxlbWVudCB8IG51bGw+LFxuICBzZXRWaXNpYmxlOiBEaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxib29sZWFuPj4sXG4gIHJlZklucHV0OiBSZWZPYmplY3Q8SFRNTElucHV0RWxlbWVudCB8IG51bGw+LFxuKSA9PiB7XG4gIGlmIChcbiAgICByZWYuY3VycmVudCAmJlxuICAgICFyZWYuY3VycmVudC5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSkgJiZcbiAgICAhcmVmSW5wdXQuY3VycmVudD8uY29udGFpbnMoZXZlbnQudGFyZ2V0IGFzIE5vZGUpXG4gICkge1xuICAgIHNldFZpc2libGUoZmFsc2UpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IENhbGVuZGFyUG9wdXAgPSAoe1xuICBjaGlsZHJlbixcbiAgdmlzaWJsZSxcbiAgc2V0VmlzaWJsZSxcbiAgcmVmSW5wdXQsXG4gIGNvbnRlbnQsXG59OiBQb3B1cFByb3BzKSA9PiB7XG4gIGNvbnN0IHJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIGV2ZW50ID0+XG4gICAgICBoYW5kbGVDbGlja091dHNpZGUoZXZlbnQsIHJlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXQpLFxuICAgIClcblxuICAgIHJldHVybiAoKSA9PlxuICAgICAgZG9jdW1lbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2Vkb3duJywgZXZlbnQgPT5cbiAgICAgICAgaGFuZGxlQ2xpY2tPdXRzaWRlKGV2ZW50LCByZWYsIHNldFZpc2libGUsIHJlZklucHV0KSxcbiAgICAgIClcbiAgfSwgW3JlZiwgc2V0VmlzaWJsZSwgcmVmSW5wdXRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFBvcHVwXG4gICAgICB2aXNpYmxlPXt2aXNpYmxlfVxuICAgICAgdGV4dD17Y29udGVudH1cbiAgICAgIHBsYWNlbWVudD1cImJvdHRvbVwiXG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Fycm93PXtmYWxzZX1cbiAgICAgIHRhYkluZGV4PXswfVxuICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgbWF4V2lkdGg9e1BPUFVQX1dJRFRIfVxuICAgICAgZGlzYWJsZUFuaW1hdGlvblxuICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkUG9wdXA+XG4gIClcbn1cbiJdfQ== */"));
|
|
45
17
|
const handleClickOutside = (event, ref, setVisible, refInput) => {
|
|
46
18
|
if (ref.current && !ref.current.contains(event.target) && !refInput.current?.contains(event.target)) {
|
|
47
19
|
setVisible(false);
|
|
48
20
|
}
|
|
49
21
|
};
|
|
50
|
-
const PopupContent = () => {
|
|
51
|
-
const {
|
|
52
|
-
showMonthYearPicker,
|
|
53
|
-
disabled,
|
|
54
|
-
monthToShow,
|
|
55
|
-
yearToShow,
|
|
56
|
-
setMonthToShow,
|
|
57
|
-
setYearToShow,
|
|
58
|
-
maxDate,
|
|
59
|
-
minDate,
|
|
60
|
-
MONTHS_ARR
|
|
61
|
-
} = useContext(DateInputContext);
|
|
62
|
-
return /* @__PURE__ */ jsxs(Stack, { gap: 2, children: [
|
|
63
|
-
/* @__PURE__ */ jsxs(Stack, { direction: "row", width: "100%", justifyContent: "space-between", children: [
|
|
64
|
-
/* @__PURE__ */ jsx(Button, { icon: "arrow-left", "data-testid": "previous-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
65
|
-
if (!minDate || minDate <= new Date(yearToShow, monthToShow - 1, 0)) {
|
|
66
|
-
if (!showMonthYearPicker) {
|
|
67
|
-
const [prevMonth, year] = getPreviousMonth(monthToShow, yearToShow);
|
|
68
|
-
setMonthToShow(prevMonth);
|
|
69
|
-
setYearToShow(year);
|
|
70
|
-
} else {
|
|
71
|
-
setYearToShow(yearToShow - 1);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}, disabled: !!(minDate && minDate > new Date(yearToShow, monthToShow - 1, 0)) }),
|
|
75
|
-
/* @__PURE__ */ jsxs(CapitalizedText, { as: "span", variant: "bodyStrong", sentiment: "neutral", children: [
|
|
76
|
-
!showMonthYearPicker ? MONTHS_ARR[monthToShow - 1] : null,
|
|
77
|
-
" ",
|
|
78
|
-
yearToShow
|
|
79
|
-
] }),
|
|
80
|
-
/* @__PURE__ */ jsx(Button, { icon: "arrow-right", "data-testid": "next-month", variant: "ghost", sentiment: "neutral", size: "xsmall", onClick: () => {
|
|
81
|
-
if (!maxDate || maxDate >= new Date(yearToShow, monthToShow, 1)) {
|
|
82
|
-
if (!showMonthYearPicker) {
|
|
83
|
-
const [monthNext, year] = getNextMonth(monthToShow, yearToShow);
|
|
84
|
-
setMonthToShow(monthNext);
|
|
85
|
-
setYearToShow(year);
|
|
86
|
-
} else {
|
|
87
|
-
setYearToShow(yearToShow + 1);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}, disabled: !!(maxDate && maxDate < new Date(yearToShow, monthToShow, 1)) })
|
|
91
|
-
] }),
|
|
92
|
-
showMonthYearPicker ? /* @__PURE__ */ jsx(Monthly, { disabled }) : /* @__PURE__ */ jsx(Daily, { disabled })
|
|
93
|
-
] });
|
|
94
|
-
};
|
|
95
22
|
const CalendarPopup = ({
|
|
96
23
|
children,
|
|
97
24
|
visible,
|
|
98
25
|
setVisible,
|
|
99
|
-
refInput
|
|
26
|
+
refInput,
|
|
27
|
+
content
|
|
100
28
|
}) => {
|
|
101
29
|
const ref = useRef(null);
|
|
102
30
|
useEffect(() => {
|
|
103
31
|
document.addEventListener("mousedown", (event) => handleClickOutside(event, ref, setVisible, refInput));
|
|
104
32
|
return () => document.removeEventListener("mousedown", (event) => handleClickOutside(event, ref, setVisible, refInput));
|
|
105
33
|
}, [ref, setVisible, refInput]);
|
|
106
|
-
return /* @__PURE__ */ jsx(StyledPopup, { visible, text:
|
|
34
|
+
return /* @__PURE__ */ jsx(StyledPopup, { visible, text: content, placement: "bottom", ref, hasArrow: false, tabIndex: 0, role: "dialog", debounceDelay: 0, maxWidth: POPUP_WIDTH, disableAnimation: true, align: "start", children });
|
|
107
35
|
};
|
|
108
36
|
export {
|
|
109
37
|
CalendarPopup
|
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
3
|
const POPUP_WIDTH = "16.5rem";
|
|
4
|
-
const CURRENT_YEAR = (/* @__PURE__ */ new Date()).getFullYear();
|
|
5
|
-
const CURRENT_MONTH = (/* @__PURE__ */ new Date()).getMonth() + 1;
|
|
6
4
|
const CALENDAR_WEEKS = 6;
|
|
7
5
|
exports.CALENDAR_WEEKS = CALENDAR_WEEKS;
|
|
8
|
-
exports.CURRENT_MONTH = CURRENT_MONTH;
|
|
9
|
-
exports.CURRENT_YEAR = CURRENT_YEAR;
|
|
10
6
|
exports.POPUP_WIDTH = POPUP_WIDTH;
|
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
const POPUP_WIDTH = "16.5rem";
|
|
2
|
-
const CURRENT_YEAR = (/* @__PURE__ */ new Date()).getFullYear();
|
|
3
|
-
const CURRENT_MONTH = (/* @__PURE__ */ new Date()).getMonth() + 1;
|
|
4
2
|
const CALENDAR_WEEKS = 6;
|
|
5
3
|
export {
|
|
6
4
|
CALENDAR_WEEKS,
|
|
7
|
-
CURRENT_MONTH,
|
|
8
|
-
CURRENT_YEAR,
|
|
9
5
|
POPUP_WIDTH
|
|
10
6
|
};
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const
|
|
4
|
-
const getMonthFirstDay = (month = constants.CURRENT_MONTH, year = constants.CURRENT_YEAR) => {
|
|
3
|
+
const getMonthFirstDay = (month, year) => {
|
|
5
4
|
const firstDay = new Date(year, month - 1, 1).getDay();
|
|
6
5
|
return firstDay === 0 ? 6 : firstDay - 1;
|
|
7
6
|
};
|
|
@@ -18,8 +17,8 @@ const getNextMonth = (month, year) => {
|
|
|
18
17
|
}
|
|
19
18
|
return [month + 1, year];
|
|
20
19
|
};
|
|
21
|
-
const isSameMonth = (date, basedate
|
|
22
|
-
const isSameDay = (date, basedate
|
|
20
|
+
const isSameMonth = (date, basedate) => basedate.getMonth() === date.getMonth() && basedate.getFullYear() === date.getFullYear();
|
|
21
|
+
const isSameDay = (date, basedate) => basedate.getDate() === date.getDate() && basedate.getMonth() + 1 === date.getMonth() + 1 && basedate.getFullYear() === date.getFullYear();
|
|
23
22
|
const getDateISO = (showMonthYearPicker, date) => {
|
|
24
23
|
if (date) {
|
|
25
24
|
if (showMonthYearPicker) {
|
|
@@ -41,6 +40,13 @@ const formatValue = (computedValue, computedRange, showMonthYearPicker, selectsR
|
|
|
41
40
|
}
|
|
42
41
|
return void 0;
|
|
43
42
|
};
|
|
43
|
+
const styleCalendarContainer = (theme) => `
|
|
44
|
+
width: 100%;
|
|
45
|
+
color: ${theme.colors.neutral.text};
|
|
46
|
+
padding: ${theme.space[2]};
|
|
47
|
+
border-radius: ${theme.radii.default};
|
|
48
|
+
background-color: ${theme.colors.other.elevation.background.raised};
|
|
49
|
+
`;
|
|
44
50
|
exports.addZero = addZero;
|
|
45
51
|
exports.formatValue = formatValue;
|
|
46
52
|
exports.getMonthFirstDay = getMonthFirstDay;
|
|
@@ -48,3 +54,4 @@ exports.getNextMonth = getNextMonth;
|
|
|
48
54
|
exports.getPreviousMonth = getPreviousMonth;
|
|
49
55
|
exports.isSameDay = isSameDay;
|
|
50
56
|
exports.isSameMonth = isSameMonth;
|
|
57
|
+
exports.styleCalendarContainer = styleCalendarContainer;
|
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
|
|
1
|
+
import type { Theme } from '@emotion/react';
|
|
2
|
+
export declare const getMonthFirstDay: (month: number, year: number) => number;
|
|
2
3
|
export declare const addZero: (value: number) => string;
|
|
3
4
|
export declare const getPreviousMonth: (month: number, year: number) => number[];
|
|
4
5
|
export declare const getNextMonth: (month: number, year: number) => number[];
|
|
5
|
-
export declare const isSameMonth: (date: Date, basedate
|
|
6
|
-
export declare const isSameDay: (date: Date, basedate
|
|
6
|
+
export declare const isSameMonth: (date: Date, basedate: Date) => boolean;
|
|
7
|
+
export declare const isSameDay: (date: Date, basedate: Date) => boolean;
|
|
7
8
|
export declare const formatValue: (computedValue: Date | null, computedRange: {
|
|
8
9
|
start: Date | null;
|
|
9
10
|
end: Date | null;
|
|
10
11
|
} | null, showMonthYearPicker: boolean, selectsRange: boolean, format?: (value?: Date) => string | undefined) => string | undefined;
|
|
12
|
+
export declare const styleCalendarContainer: (theme: Theme) => string;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
const getMonthFirstDay = (month = CURRENT_MONTH, year = CURRENT_YEAR) => {
|
|
1
|
+
const getMonthFirstDay = (month, year) => {
|
|
3
2
|
const firstDay = new Date(year, month - 1, 1).getDay();
|
|
4
3
|
return firstDay === 0 ? 6 : firstDay - 1;
|
|
5
4
|
};
|
|
@@ -16,8 +15,8 @@ const getNextMonth = (month, year) => {
|
|
|
16
15
|
}
|
|
17
16
|
return [month + 1, year];
|
|
18
17
|
};
|
|
19
|
-
const isSameMonth = (date, basedate
|
|
20
|
-
const isSameDay = (date, basedate
|
|
18
|
+
const isSameMonth = (date, basedate) => basedate.getMonth() === date.getMonth() && basedate.getFullYear() === date.getFullYear();
|
|
19
|
+
const isSameDay = (date, basedate) => basedate.getDate() === date.getDate() && basedate.getMonth() + 1 === date.getMonth() + 1 && basedate.getFullYear() === date.getFullYear();
|
|
21
20
|
const getDateISO = (showMonthYearPicker, date) => {
|
|
22
21
|
if (date) {
|
|
23
22
|
if (showMonthYearPicker) {
|
|
@@ -39,6 +38,13 @@ const formatValue = (computedValue, computedRange, showMonthYearPicker, selectsR
|
|
|
39
38
|
}
|
|
40
39
|
return void 0;
|
|
41
40
|
};
|
|
41
|
+
const styleCalendarContainer = (theme) => `
|
|
42
|
+
width: 100%;
|
|
43
|
+
color: ${theme.colors.neutral.text};
|
|
44
|
+
padding: ${theme.space[2]};
|
|
45
|
+
border-radius: ${theme.radii.default};
|
|
46
|
+
background-color: ${theme.colors.other.elevation.background.raised};
|
|
47
|
+
`;
|
|
42
48
|
export {
|
|
43
49
|
addZero,
|
|
44
50
|
formatValue,
|
|
@@ -46,5 +52,6 @@ export {
|
|
|
46
52
|
getNextMonth,
|
|
47
53
|
getPreviousMonth,
|
|
48
54
|
isSameDay,
|
|
49
|
-
isSameMonth
|
|
55
|
+
isSameMonth,
|
|
56
|
+
styleCalendarContainer
|
|
50
57
|
};
|
|
@@ -4,8 +4,12 @@ const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
|
4
4
|
const _styled = require("@emotion/styled/base");
|
|
5
5
|
const Icon = require("@ultraviolet/icons");
|
|
6
6
|
const React = require("react");
|
|
7
|
-
const index = require("../
|
|
7
|
+
const index = require("../Card/index.cjs");
|
|
8
|
+
const index$2 = require("../Stack/index.cjs");
|
|
9
|
+
const index$3 = require("../Text/index.cjs");
|
|
10
|
+
const index$1 = require("../TextInputV2/index.cjs");
|
|
8
11
|
const Context = require("./Context.cjs");
|
|
12
|
+
const CalendarContent = require("./components/CalendarContent.cjs");
|
|
9
13
|
const Popup = require("./components/Popup.cjs");
|
|
10
14
|
const helpers = require("./helpers.cjs");
|
|
11
15
|
const helpersLocale = require("./helpersLocale.cjs");
|
|
@@ -15,18 +19,26 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
|
15
19
|
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).";
|
|
16
20
|
}
|
|
17
21
|
const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
18
|
-
target: "
|
|
22
|
+
target: "e1bm75lk1"
|
|
19
23
|
} : {
|
|
20
|
-
target: "
|
|
24
|
+
target: "e1bm75lk1",
|
|
21
25
|
label: "Container"
|
|
22
26
|
})(process.env.NODE_ENV === "production" ? {
|
|
23
27
|
name: "1d3w5wq",
|
|
24
28
|
styles: "width:100%"
|
|
25
29
|
} : {
|
|
26
30
|
name: "1d3w5wq",
|
|
27
|
-
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAW4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        <CalendarPopup\n          visible={isPopupVisible}\n          setVisible={setVisible}\n          refInput={refInput}\n        >\n          <TextInputV2\n            label={label}\n            placeholder={placeholder}\n            value={inputValue}\n            required={required}\n            error={error}\n            success={success}\n            readOnly={readOnly}\n            disabled={disabled}\n            size={size}\n            autoFocus={autoFocus}\n            helper={helper}\n            labelDescription={labelDescription}\n            name={name}\n            suffix={\n              <CalendarRangeIcon\n                size=\"medium\"\n                sentiment=\"neutral\"\n                disabled={disabled}\n              />\n            }\n            ref={refInput}\n            tooltip={tooltip}\n            autoComplete=\"false\"\n            onChange={manageOnChange}\n          />\n        </CalendarPopup>\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */",
|
|
31
|
+
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx"],"names":[],"mappings":"AAe4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */",
|
|
28
32
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
29
33
|
});
|
|
34
|
+
const StyledCard = /* @__PURE__ */ _styled__default.default(index.Card, process.env.NODE_ENV === "production" ? {
|
|
35
|
+
target: "e1bm75lk0"
|
|
36
|
+
} : {
|
|
37
|
+
target: "e1bm75lk0",
|
|
38
|
+
label: "StyledCard"
|
|
39
|
+
})(({
|
|
40
|
+
theme
|
|
41
|
+
}) => helpers.styleCalendarContainer(theme), ' width:16.5rem;&[data-disabled="true"]{cursor:not-allowed;}' + (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/index.tsx"],"names":[],"mappings":"AAkB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CalendarRangeIcon } from '@ultraviolet/icons'\nimport type { Locale } from 'date-fns'\nimport type { ChangeEvent, FocusEvent } from 'react'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport { Card } from '../Card'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport { type ContextProps, DateInputContext } from './Context'\nimport { CalendarContent } from './components/CalendarContent'\nimport { CalendarPopup } from './components/Popup'\nimport { formatValue, styleCalendarContainer } from './helpers'\nimport { getDays, getLocalizedMonths, getMonths } from './helpersLocale'\n\nconst Container = styled.div`\nwidth: 100%;`\n\nconst StyledCard = styled(Card)`\n  ${({ theme }) => styleCalendarContainer(theme)}\n  width: 16.5rem;\n\n  &[data-disabled=\"true\"] {\n      cursor: not-allowed;\n    }\n`\n\ntype DateInputProps<IsRange extends undefined | boolean = false> = {\n  autoFocus?: boolean\n  locale?: string | Locale\n  disabled?: boolean\n  maxDate?: Date | null\n  minDate?: Date | null\n  name?: string\n  onBlur?: (event: FocusEvent<HTMLInputElement>) => void\n  onFocus?: (event: FocusEvent<HTMLInputElement>) => void\n  error?: string\n  required?: boolean\n  format?: (value?: Date) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | null\n  className?: string\n  'data-testid'?: string\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: string\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n  showMonthYearPicker?: boolean\n  placeholder?: string\n  startDate?: Date | null\n  endDate?: Date | null\n  /**\n   * Display the component as an input + a calendar popup (\"text\") or only as a calendar (\"calendar\")\n   */\n  input?: 'calendar' | 'text'\n  selectsRange?: IsRange\n  onChange?: IsRange extends true\n    ? (\n        date: Date[] | [Date | null, Date | null],\n        event?: React.SyntheticEvent,\n      ) => void\n    : (date: Date | null, event?: React.SyntheticEvent) => void\n}\n\n/**\n * DateInput can be used to select a specific date\n */\nexport const DateInput = <IsRange extends undefined | boolean>({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format,\n  label,\n  labelDescription,\n  locale = 'en-US',\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  placeholder,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  selectsRange = false,\n  showMonthYearPicker = false,\n  input = 'text',\n  'data-testid': dataTestId,\n}: DateInputProps<IsRange>) => {\n  const defaultMonthToShow = useMemo(() => {\n    if (value) return new Date(value).getMonth() + 1\n    if (startDate && selectsRange) return startDate.getMonth() + 1\n    if (endDate && selectsRange) return endDate.getMonth() + 1\n\n    return new Date().getMonth() + 1\n  }, [endDate, selectsRange, startDate, value])\n\n  const defaultYearToShow = useMemo(() => {\n    if (value) return new Date(value).getFullYear()\n    if (startDate && selectsRange) return startDate.getFullYear()\n    if (endDate && selectsRange) return endDate.getFullYear()\n\n    return new Date().getFullYear()\n  }, [endDate, selectsRange, startDate, value])\n\n  const [computedValue, setValue] = useState(\n    value && !selectsRange ? new Date(value) : null,\n  )\n  const [computedRange, setRange] = useState({\n    start: startDate ?? null,\n    end: endDate ?? null,\n  })\n  const [isPopupVisible, setVisible] = useState(false)\n  const [monthToShow, setMonthToShow] = useState(defaultMonthToShow)\n  const [yearToShow, setYearToShow] = useState(defaultYearToShow)\n  const [inputValue, setInputValue] = useState(\n    formatValue(\n      computedValue,\n      computedRange,\n      showMonthYearPicker,\n      selectsRange,\n      format,\n    ),\n  )\n  const refInput = useRef<HTMLInputElement>(null)\n  const MONTHS = getMonths(locale)\n  const DAYS = getDays(locale)\n  const MONTHS_ARR = getLocalizedMonths(locale)\n\n  const valueContext = useMemo(\n    () =>\n      ({\n        showMonthYearPicker,\n        disabled,\n        readOnly,\n        value: computedValue,\n        range: computedRange,\n        setRange,\n        setValue,\n        monthToShow,\n        yearToShow,\n        setMonthToShow,\n        setYearToShow,\n        excludeDates,\n        maxDate,\n        minDate,\n        MONTHS,\n        MONTHS_ARR,\n        DAYS,\n        onChange,\n        selectsRange,\n        format,\n        setInputValue,\n        setVisible,\n      }) as ContextProps,\n    [\n      showMonthYearPicker,\n      disabled,\n      readOnly,\n      selectsRange,\n      computedValue,\n      computedRange,\n      monthToShow,\n      yearToShow,\n      excludeDates,\n      maxDate,\n      minDate,\n      MONTHS,\n      MONTHS_ARR,\n      DAYS,\n      onChange,\n      format,\n      setInputValue,\n      setVisible,\n    ],\n  )\n\n  useEffect(() => {\n    if (value && !selectsRange) {\n      setValue(new Date(value))\n      setInputValue(\n        formatValue(\n          new Date(value),\n          null,\n          showMonthYearPicker,\n          selectsRange,\n          format,\n        ),\n      )\n    }\n    if (selectsRange) {\n      setRange({\n        start: startDate ?? computedRange.start,\n        end: endDate ?? computedRange.end,\n      })\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [endDate, startDate, value])\n\n  const manageOnChange = (event: ChangeEvent<HTMLInputElement>) => {\n    const newValue = event.currentTarget.value\n\n    if (selectsRange) {\n      const [startDateInput, endDateInput] = newValue.split(' - ').map(val => {\n        if (showMonthYearPicker) {\n          // Force YYYY/MM (since MM/YYYY not recognised as a date in typescript)\n          const res = val.split(/\\D+/).map(aa => Number.parseInt(aa, 10))\n\n          return new Date(Math.max(...res), Math.min(...res) - 1)\n        }\n\n        return new Date(val)\n      })\n\n      const computedNewRange: [Date | null, Date | null] = [\n        startDateInput instanceof Date &&\n        !Number.isNaN(startDateInput.getTime())\n          ? startDateInput\n          : null,\n        endDateInput instanceof Date && !Number.isNaN(endDateInput.getTime())\n          ? endDateInput\n          : null,\n      ]\n\n      setRange({ start: computedNewRange[0], end: computedNewRange[1] })\n      setInputValue(newValue)\n\n      if (computedNewRange[0]) {\n        setMonthToShow(computedNewRange[0].getMonth() + 1)\n        setYearToShow(computedNewRange[0].getFullYear())\n      }\n      // TypeScript fails to automatically get the correct type of onChange here\n      ;(\n        onChange as (\n          date: Date[] | [Date | null, Date | null],\n          event: React.SyntheticEvent | undefined,\n        ) => void\n      )?.(computedNewRange, event)\n    } else {\n      const computedDate = new Date(newValue)\n      setInputValue(newValue)\n\n      if (Date.parse(newValue)) {\n        setValue(computedDate)\n        setMonthToShow(computedDate.getMonth() + 1)\n        setYearToShow(computedDate.getFullYear())\n\n        // TypeScript fails to automatically get the correct type of onChange here\n        ;(\n          onChange as (date: Date | null, event?: React.SyntheticEvent) => void\n        )?.(computedDate, event)\n      }\n    }\n  }\n\n  return (\n    <DateInputContext.Provider value={valueContext}>\n      <Container\n        id={id}\n        className={className}\n        data-testid={dataTestId}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={() => {\n          if (!isPopupVisible) setVisible(true)\n        }}\n      >\n        {input === 'text' ? (\n          <CalendarPopup\n            visible={isPopupVisible}\n            setVisible={setVisible}\n            refInput={refInput}\n            content={<CalendarContent />}\n          >\n            <TextInputV2\n              label={label}\n              placeholder={placeholder}\n              value={inputValue}\n              required={required}\n              error={error}\n              success={success}\n              readOnly={readOnly}\n              disabled={disabled}\n              size={size}\n              autoFocus={autoFocus}\n              helper={helper}\n              labelDescription={labelDescription}\n              name={name}\n              suffix={\n                <CalendarRangeIcon\n                  size=\"medium\"\n                  sentiment=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              ref={refInput}\n              tooltip={tooltip}\n              autoComplete=\"false\"\n              onChange={manageOnChange}\n            />\n          </CalendarPopup>\n        ) : (\n          <Stack gap={0.5}>\n            {labelDescription ? (\n              <Stack direction=\"row\" gap=\"1\">\n                <Text\n                  as=\"label\"\n                  variant=\"bodyStrong\"\n                  prominence=\"strong\"\n                  sentiment=\"neutral\"\n                >\n                  {label}\n                </Text>\n                {labelDescription}\n              </Stack>\n            ) : (\n              <Text\n                as=\"label\"\n                variant=\"bodyStrong\"\n                prominence=\"strong\"\n                sentiment=\"neutral\"\n              >\n                {label}\n              </Text>\n            )}\n\n            <StyledCard disabled={disabled}>\n              <CalendarContent />\n            </StyledCard>\n          </Stack>\n        )}\n      </Container>\n    </DateInputContext.Provider>\n  )\n}\n"]} */"));
|
|
30
42
|
const DateInput = ({
|
|
31
43
|
autoFocus = false,
|
|
32
44
|
disabled = false,
|
|
@@ -56,6 +68,7 @@ const DateInput = ({
|
|
|
56
68
|
tooltip,
|
|
57
69
|
selectsRange = false,
|
|
58
70
|
showMonthYearPicker = false,
|
|
71
|
+
input = "text",
|
|
59
72
|
"data-testid": dataTestId
|
|
60
73
|
}) => {
|
|
61
74
|
const defaultMonthToShow = React.useMemo(() => {
|
|
@@ -86,6 +99,7 @@ const DateInput = ({
|
|
|
86
99
|
const valueContext = React.useMemo(() => ({
|
|
87
100
|
showMonthYearPicker,
|
|
88
101
|
disabled,
|
|
102
|
+
readOnly,
|
|
89
103
|
value: computedValue,
|
|
90
104
|
range: computedRange,
|
|
91
105
|
setRange,
|
|
@@ -105,7 +119,7 @@ const DateInput = ({
|
|
|
105
119
|
format,
|
|
106
120
|
setInputValue,
|
|
107
121
|
setVisible
|
|
108
|
-
}), [showMonthYearPicker, disabled, selectsRange, computedValue, computedRange, monthToShow, yearToShow, excludeDates, maxDate, minDate, MONTHS, MONTHS_ARR, DAYS, onChange, format, setInputValue, setVisible]);
|
|
122
|
+
}), [showMonthYearPicker, disabled, readOnly, selectsRange, computedValue, computedRange, monthToShow, yearToShow, excludeDates, maxDate, minDate, MONTHS, MONTHS_ARR, DAYS, onChange, format, setInputValue, setVisible]);
|
|
109
123
|
React.useEffect(() => {
|
|
110
124
|
if (value && !selectsRange) {
|
|
111
125
|
setValue(new Date(value));
|
|
@@ -152,6 +166,12 @@ const DateInput = ({
|
|
|
152
166
|
};
|
|
153
167
|
return /* @__PURE__ */ jsxRuntime.jsx(Context.DateInputContext.Provider, { value: valueContext, children: /* @__PURE__ */ jsxRuntime.jsx(Container, { id, className, "data-testid": dataTestId, onBlur, onFocus, onClick: () => {
|
|
154
168
|
if (!isPopupVisible) setVisible(true);
|
|
155
|
-
}, children: /* @__PURE__ */ jsxRuntime.jsx(Popup.CalendarPopup, { visible: isPopupVisible, setVisible, refInput, children: /* @__PURE__ */ jsxRuntime.jsx(index.TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsxRuntime.jsx(Icon.CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange }) })
|
|
169
|
+
}, children: input === "text" ? /* @__PURE__ */ jsxRuntime.jsx(Popup.CalendarPopup, { visible: isPopupVisible, setVisible, refInput, content: /* @__PURE__ */ jsxRuntime.jsx(CalendarContent.CalendarContent, {}), children: /* @__PURE__ */ jsxRuntime.jsx(index$1.TextInputV2, { label, placeholder, value: inputValue, required, error, success, readOnly, disabled, size, autoFocus, helper, labelDescription, name, suffix: /* @__PURE__ */ jsxRuntime.jsx(Icon.CalendarRangeIcon, { size: "medium", sentiment: "neutral", disabled }), ref: refInput, tooltip, autoComplete: "false", onChange: manageOnChange }) }) : /* @__PURE__ */ jsxRuntime.jsxs(index$2.Stack, { gap: 0.5, children: [
|
|
170
|
+
labelDescription ? /* @__PURE__ */ jsxRuntime.jsxs(index$2.Stack, { direction: "row", gap: "1", children: [
|
|
171
|
+
/* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "label", variant: "bodyStrong", prominence: "strong", sentiment: "neutral", children: label }),
|
|
172
|
+
labelDescription
|
|
173
|
+
] }) : /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "label", variant: "bodyStrong", prominence: "strong", sentiment: "neutral", children: label }),
|
|
174
|
+
/* @__PURE__ */ jsxRuntime.jsx(StyledCard, { disabled, children: /* @__PURE__ */ jsxRuntime.jsx(CalendarContent.CalendarContent, {}) })
|
|
175
|
+
] }) }) });
|
|
156
176
|
};
|
|
157
177
|
exports.DateInput = DateInput;
|