@ultraviolet/ui 1.85.2 → 1.86.0

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 (41) hide show
  1. package/dist/components/Badge/index.cjs +1 -1
  2. package/dist/components/Badge/index.d.ts +1 -0
  3. package/dist/components/Badge/index.js +1 -1
  4. package/dist/components/DateInput/Context.cjs +3 -1
  5. package/dist/components/DateInput/Context.d.ts +3 -0
  6. package/dist/components/DateInput/Context.js +3 -1
  7. package/dist/components/DateInput/components/CalendarContent.cjs +77 -0
  8. package/dist/components/DateInput/components/CalendarContent.d.ts +1 -0
  9. package/dist/components/DateInput/components/CalendarContent.js +75 -0
  10. package/dist/components/DateInput/components/CalendarDaily.cjs +51 -41
  11. package/dist/components/DateInput/components/CalendarDaily.d.ts +1 -3
  12. package/dist/components/DateInput/components/CalendarDaily.js +51 -41
  13. package/dist/components/DateInput/components/CalendarMonthly.cjs +48 -56
  14. package/dist/components/DateInput/components/CalendarMonthly.d.ts +1 -3
  15. package/dist/components/DateInput/components/CalendarMonthly.js +46 -54
  16. package/dist/components/DateInput/components/Popup.cjs +8 -80
  17. package/dist/components/DateInput/components/Popup.d.ts +2 -1
  18. package/dist/components/DateInput/components/Popup.js +9 -81
  19. package/dist/components/DateInput/constants.cjs +0 -4
  20. package/dist/components/DateInput/constants.d.ts +0 -2
  21. package/dist/components/DateInput/constants.js +0 -4
  22. package/dist/components/DateInput/helpers.cjs +11 -4
  23. package/dist/components/DateInput/helpers.d.ts +5 -3
  24. package/dist/components/DateInput/helpers.js +12 -5
  25. package/dist/components/DateInput/index.cjs +30 -7
  26. package/dist/components/DateInput/index.d.ts +5 -1
  27. package/dist/components/DateInput/index.js +31 -8
  28. package/dist/components/Link/index.cjs +23 -11
  29. package/dist/components/Link/index.js +23 -11
  30. package/dist/components/List/Row.cjs +21 -9
  31. package/dist/components/List/Row.d.ts +4 -1
  32. package/dist/components/List/Row.js +22 -10
  33. package/dist/components/List/index.d.ts +1 -0
  34. package/dist/components/Separator/index.cjs +21 -22
  35. package/dist/components/Separator/index.d.ts +10 -2
  36. package/dist/components/Separator/index.js +21 -22
  37. package/dist/components/Table/Cell.cjs +1 -1
  38. package/dist/components/Table/Cell.d.ts +2 -2
  39. package/dist/components/Table/Cell.js +1 -1
  40. package/dist/components/Table/index.d.ts +1 -1
  41. package/package.json +2 -2
@@ -3,46 +3,29 @@ import _styled from "@emotion/styled/base";
3
3
  import { useContext, useState } from "react";
4
4
  import { Button } from "../../Button/index.js";
5
5
  import { Row } from "../../Row/index.js";
6
- import { Text } from "../../Text/index.js";
7
6
  import { DateInputContext } from "../Context.js";
8
7
  import { isSameMonth, formatValue } from "../helpers.js";
9
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
- 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).";
11
- }
12
- const ButtonDate = /* @__PURE__ */ _styled(Button, process.env.NODE_ENV === "production" ? {
13
- target: "eaodfdc2"
8
+ const Month = /* @__PURE__ */ _styled(Button, process.env.NODE_ENV === "production" ? {
9
+ target: "eaodfdc0"
14
10
  } : {
15
- target: "eaodfdc2",
16
- label: "ButtonDate"
11
+ target: "eaodfdc0",
12
+ label: "Month"
17
13
  })("height:", ({
18
14
  theme
19
- }) => 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/CalendarMonthly.tsx"],"names":[],"mappings":"AASiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarMonthly.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 { formatValue, isSameMonth } 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)`\ndisplay: inline-block;\ntext-transform: lowercase;\n\n&::first-letter {\n  text-transform: uppercase;\n}\n`\n\nexport const Monthly = ({ disabled }: { disabled: boolean }) => {\n  const {\n    yearToShow,\n    setValue,\n    setMonthToShow,\n    MONTHS,\n    onChange,\n    selectsRange,\n    setRange,\n    range,\n    minDate,\n    maxDate,\n    excludeDates,\n    value,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. It is used to know 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  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  return (\n    <Row templateColumns=\"1fr 1fr 1fr\" gap={1}>\n      {Object.entries(MONTHS).map((month, index) => {\n        const constructedDate = new Date(yearToShow, index, 1)\n\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameMonth(constructedDate, date))\n              .includes(true)\n          : false\n\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\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 isSelected =\n          (value && isSameMonth(constructedDate, value)) ||\n          (range?.start && isSameMonth(constructedDate, range.start)) ||\n          (range?.end && isSameMonth(constructedDate, range.end))\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          // Must wrap inside this if otherwise TypeScript doesn't get the right type for onChange\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                  true,\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                  true,\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                  true,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const Month = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Month\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={month[0]}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                if (selectsRange) {\n                  onClickRange(event, constructedDate)\n                } else {\n                  setMonthToShow(index + 1)\n                  setValue(constructedDate)\n                  onChange?.(constructedDate, event)\n                  setInputValue(\n                    formatValue(constructedDate, null, true, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => setHoveredDate(constructedDate)}\n            onMouseLeave={() => setHoveredDate(null)}\n          >\n            <CapitalizedText\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={disabled || isExcluded || isOutsideRange}\n            >\n              {month[1]}\n            </CapitalizedText>\n          </Month>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
20
- const RangeButton = /* @__PURE__ */ _styled(Button, process.env.NODE_ENV === "production" ? {
21
- target: "eaodfdc1"
22
- } : {
23
- target: "eaodfdc1",
24
- label: "RangeButton"
25
- })("background-color:", ({
15
+ }) => theme.sizing["312"], ';width:100%;padding:0;text-transform:capitalize;&[aria-label="in-range"]{color:', ({
26
16
  theme
27
- }) => theme.colors.primary.background, ";height:", ({
17
+ }) => theme.colors.primary.textHover, ";background-color:", ({
28
18
  theme
29
- }) => 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/CalendarMonthly.tsx"],"names":[],"mappings":"AAekC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarMonthly.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 { formatValue, isSameMonth } 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)`\ndisplay: inline-block;\ntext-transform: lowercase;\n\n&::first-letter {\n  text-transform: uppercase;\n}\n`\n\nexport const Monthly = ({ disabled }: { disabled: boolean }) => {\n  const {\n    yearToShow,\n    setValue,\n    setMonthToShow,\n    MONTHS,\n    onChange,\n    selectsRange,\n    setRange,\n    range,\n    minDate,\n    maxDate,\n    excludeDates,\n    value,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. It is used to know 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  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  return (\n    <Row templateColumns=\"1fr 1fr 1fr\" gap={1}>\n      {Object.entries(MONTHS).map((month, index) => {\n        const constructedDate = new Date(yearToShow, index, 1)\n\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameMonth(constructedDate, date))\n              .includes(true)\n          : false\n\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\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 isSelected =\n          (value && isSameMonth(constructedDate, value)) ||\n          (range?.start && isSameMonth(constructedDate, range.start)) ||\n          (range?.end && isSameMonth(constructedDate, range.end))\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          // Must wrap inside this if otherwise TypeScript doesn't get the right type for onChange\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                  true,\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                  true,\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                  true,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const Month = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Month\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={month[0]}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                if (selectsRange) {\n                  onClickRange(event, constructedDate)\n                } else {\n                  setMonthToShow(index + 1)\n                  setValue(constructedDate)\n                  onChange?.(constructedDate, event)\n                  setInputValue(\n                    formatValue(constructedDate, null, true, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => setHoveredDate(constructedDate)}\n            onMouseLeave={() => setHoveredDate(null)}\n          >\n            <CapitalizedText\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={disabled || isExcluded || isOutsideRange}\n            >\n              {month[1]}\n            </CapitalizedText>\n          </Month>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
30
- const CapitalizedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
31
- target: "eaodfdc0"
32
- } : {
33
- target: "eaodfdc0",
34
- label: "CapitalizedText"
35
- })(process.env.NODE_ENV === "production" ? {
36
- name: "88dib2",
37
- styles: "display:inline-block;text-transform:lowercase;&::first-letter{text-transform:uppercase;}"
38
- } : {
39
- name: "88dib2",
40
- 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/CalendarMonthly.tsx"],"names":[],"mappings":"AAsBoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarMonthly.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 { formatValue, isSameMonth } 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)`\ndisplay: inline-block;\ntext-transform: lowercase;\n\n&::first-letter {\n  text-transform: uppercase;\n}\n`\n\nexport const Monthly = ({ disabled }: { disabled: boolean }) => {\n  const {\n    yearToShow,\n    setValue,\n    setMonthToShow,\n    MONTHS,\n    onChange,\n    selectsRange,\n    setRange,\n    range,\n    minDate,\n    maxDate,\n    excludeDates,\n    value,\n    setInputValue,\n    format,\n    setVisible,\n  } = useContext(DateInputContext)\n  const [rangeState, setRangeState] = useState<'start' | 'none' | 'done'>(\n    range?.start ? 'start' : 'none',\n  ) // Used when selectsRange is True. It is used to know 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  const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n\n  return (\n    <Row templateColumns=\"1fr 1fr 1fr\" gap={1}>\n      {Object.entries(MONTHS).map((month, index) => {\n        const constructedDate = new Date(yearToShow, index, 1)\n\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameMonth(constructedDate, date))\n              .includes(true)\n          : false\n\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\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 isSelected =\n          (value && isSameMonth(constructedDate, value)) ||\n          (range?.start && isSameMonth(constructedDate, range.start)) ||\n          (range?.end && isSameMonth(constructedDate, range.end))\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          // Must wrap inside this if otherwise TypeScript doesn't get the right type for onChange\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                  true,\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                  true,\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                  true,\n                  true,\n                  format,\n                ),\n              )\n              onChange?.([newDate, null], event)\n            }\n          }\n        }\n        const Month = isInHoveredRange ? RangeButton : ButtonDate\n\n        return (\n          <Month\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={month[0]}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange) {\n                if (selectsRange) {\n                  onClickRange(event, constructedDate)\n                } else {\n                  setMonthToShow(index + 1)\n                  setValue(constructedDate)\n                  onChange?.(constructedDate, event)\n                  setInputValue(\n                    formatValue(constructedDate, null, true, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => setHoveredDate(constructedDate)}\n            onMouseLeave={() => setHoveredDate(null)}\n          >\n            <CapitalizedText\n              as=\"span\"\n              variant=\"bodyStrong\"\n              prominence={isSelected && !isInHoveredRange ? 'strong' : 'weak'}\n              sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n              disabled={disabled || isExcluded || isOutsideRange}\n            >\n              {month[1]}\n            </CapitalizedText>\n          </Month>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */",
41
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
42
- });
43
- const Monthly = ({
44
- disabled
45
- }) => {
19
+ }) => theme.colors.primary.background, ';}&[aria-label="in-range"]:hover{color:', ({
20
+ theme
21
+ }) => theme.colors.neutral.textStronger, ";background-color:", ({
22
+ theme
23
+ }) => theme.colors.primary.backgroundStrongHover, ';}&[aria-label="not-current"]{color:', ({
24
+ theme
25
+ }) => theme.colors.neutral.textDisabled, ';}&[aria-label="selected"]{color:', ({
26
+ theme
27
+ }) => theme.colors.neutral.textStronger, ";}" + (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/CalendarMonthly.tsx"],"names":[],"mappings":"AAQ4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/components/CalendarMonthly.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 { DateInputContext } from '../Context'\nimport { formatValue, isSameMonth } from '../helpers'\n\nconst Month = styled(Button)`\n  height: ${({ theme }) => theme.sizing['312']};\n  width: 100%;\n  padding: 0;\n  text-transform: capitalize;\n\n  &[aria-label=\"in-range\"] {\n    color:  ${({ theme }) => theme.colors.primary.textHover};\n    background-color: ${({ theme }) => theme.colors.primary.background};\n  }\n\n  &[aria-label=\"in-range\"]:hover {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n  }\n\n  &[aria-label=\"not-current\"] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n\n  &[aria-label=\"selected\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStronger};\n  }\n`\n\nexport const Monthly = () => {\n  const {\n    yearToShow,\n    setValue,\n    setMonthToShow,\n    MONTHS,\n    onChange,\n    selectsRange,\n    setRange,\n    range,\n    minDate,\n    maxDate,\n    excludeDates,\n    value,\n    setInputValue,\n    format,\n    setVisible,\n    readOnly,\n    disabled,\n    setHoveredDate,\n    hoveredDate,\n  } = useContext(DateInputContext)\n  const [rangeState, setRangeState] = useState<'start' | 'end'>(\n    range?.start && !range.end ? 'end' : 'start',\n  ) // Used when selectsRange is True. It is used to know 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  return (\n    <Row templateColumns=\"1fr 1fr 1fr\" gap={1}>\n      {Object.entries(MONTHS).map((month, index) => {\n        const constructedDate = new Date(yearToShow, index, 1)\n\n        const isExcluded = excludeDates\n          ? excludeDates\n              .map(date => isSameMonth(constructedDate, date))\n              .includes(true)\n          : false\n\n        const isOutsideRange =\n          !!(minDate && constructedDate < minDate) ||\n          !!(maxDate && constructedDate > maxDate)\n\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.end) ||\n          (selectsRange &&\n            range?.start &&\n            constructedDate < range.start &&\n            hoveredDate &&\n            constructedDate > hoveredDate &&\n            !range.end) ||\n          (range?.start &&\n            range.end &&\n            constructedDate < range.end &&\n            constructedDate > range.start)\n\n        const isSelected =\n          (value && isSameMonth(constructedDate, value)) ||\n          (range?.start && isSameMonth(constructedDate, range.start)) ||\n          (range?.end && isSameMonth(constructedDate, range.end))\n\n        const onClickRange = (event: MouseEventReact, newDate: Date) => {\n          // Must wrap inside this if otherwise TypeScript doesn't get the right type for onChange\n          if (selectsRange) {\n            // Selecting end date\n            if (rangeState === 'end' && 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                  true,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              // If we click on another date, it will reset the range\n              setRangeState('start')\n            } else if (rangeState === 'end' && !isAfterStartDate && range) {\n              setRange?.({ start: newDate, end: range.start })\n              onChange?.([newDate, range.start], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: range.start },\n                  true,\n                  true,\n                  format,\n                ),\n              )\n              setVisible(false)\n              // If we click on another date, it will reset the range\n              setRangeState('start')\n            } else {\n              setRange?.({ start: newDate, end: null })\n              onChange?.([newDate, null], event)\n              setInputValue(\n                formatValue(\n                  null,\n                  { start: newDate, end: null },\n                  true,\n                  true,\n                  format,\n                ),\n              )\n              setRangeState('end')\n            }\n          }\n        }\n\n        const monthState = () => {\n          if (isSelected) return 'selected'\n          if (isInHoveredRange) return 'in-range'\n\n          return 'neutral'\n        }\n\n        return (\n          <Month\n            variant={isSelected || isInHoveredRange ? 'filled' : 'ghost'}\n            sentiment={isSelected || isInHoveredRange ? 'primary' : 'neutral'}\n            disabled={disabled || isExcluded || isOutsideRange}\n            key={month[0]}\n            onClick={event => {\n              if (!isExcluded && !isOutsideRange && !readOnly) {\n                if (selectsRange) {\n                  onClickRange(event, constructedDate)\n                } else {\n                  setMonthToShow(index + 1)\n                  setValue(constructedDate)\n                  onChange?.(constructedDate, event)\n                  setInputValue(\n                    formatValue(constructedDate, null, true, false, format),\n                  )\n                  setVisible(false)\n                }\n              }\n            }}\n            onMouseEnter={() => setHoveredDate(constructedDate)}\n            aria-label={monthState()}\n          >\n            {month[1]}\n          </Month>\n        )\n      })}\n    </Row>\n  )\n}\n"]} */"));
28
+ const Monthly = () => {
46
29
  const {
47
30
  yearToShow,
48
31
  setValue,
@@ -58,31 +41,23 @@ const Monthly = ({
58
41
  value,
59
42
  setInputValue,
60
43
  format,
61
- setVisible
44
+ setVisible,
45
+ readOnly,
46
+ disabled,
47
+ setHoveredDate,
48
+ hoveredDate
62
49
  } = useContext(DateInputContext);
63
- const [rangeState, setRangeState] = useState(range?.start ? "start" : "none");
64
- const [hoveredDate, setHoveredDate] = useState(null);
50
+ const [rangeState, setRangeState] = useState(range?.start && !range.end ? "end" : "start");
65
51
  return /* @__PURE__ */ jsx(Row, { templateColumns: "1fr 1fr 1fr", gap: 1, children: Object.entries(MONTHS).map((month, index) => {
66
52
  const constructedDate = new Date(yearToShow, index, 1);
67
53
  const isExcluded = excludeDates ? excludeDates.map((date) => isSameMonth(constructedDate, date)).includes(true) : false;
68
54
  const isOutsideRange = !!(minDate && constructedDate < minDate) || !!(maxDate && constructedDate > maxDate);
69
55
  const isAfterStartDate = selectsRange && range?.start && constructedDate > range.start;
70
- const isInHoveredRange = selectsRange && range?.start && constructedDate > range.start && hoveredDate && constructedDate < hoveredDate || range?.start && range.end && constructedDate < range.end && constructedDate > range.start;
56
+ const isInHoveredRange = selectsRange && range?.start && constructedDate > range.start && hoveredDate && constructedDate < hoveredDate && !range.end || selectsRange && range?.start && constructedDate < range.start && hoveredDate && constructedDate > hoveredDate && !range.end || range?.start && range.end && constructedDate < range.end && constructedDate > range.start;
71
57
  const isSelected = value && isSameMonth(constructedDate, value) || range?.start && isSameMonth(constructedDate, range.start) || range?.end && isSameMonth(constructedDate, range.end);
72
58
  const onClickRange = (event, newDate) => {
73
59
  if (selectsRange) {
74
- if (rangeState === "none") {
75
- setRange?.({
76
- start: newDate,
77
- end: null
78
- });
79
- onChange?.([newDate, null], event);
80
- setInputValue(formatValue(null, {
81
- start: newDate,
82
- end: null
83
- }, true, true, format));
84
- setRangeState("start");
85
- } else if (isAfterStartDate) {
60
+ if (rangeState === "end" && isAfterStartDate) {
86
61
  setRange?.({
87
62
  start: range.start,
88
63
  end: newDate
@@ -93,23 +68,40 @@ const Monthly = ({
93
68
  end: newDate
94
69
  }, true, true, format));
95
70
  setVisible(false);
96
- setRangeState("done");
71
+ setRangeState("start");
72
+ } else if (rangeState === "end" && !isAfterStartDate && range) {
73
+ setRange?.({
74
+ start: newDate,
75
+ end: range.start
76
+ });
77
+ onChange?.([newDate, range.start], event);
78
+ setInputValue(formatValue(null, {
79
+ start: newDate,
80
+ end: range.start
81
+ }, true, true, format));
82
+ setVisible(false);
83
+ setRangeState("start");
97
84
  } else {
98
85
  setRange?.({
99
86
  start: newDate,
100
87
  end: null
101
88
  });
89
+ onChange?.([newDate, null], event);
102
90
  setInputValue(formatValue(null, {
103
91
  start: newDate,
104
92
  end: null
105
93
  }, true, true, format));
106
- onChange?.([newDate, null], event);
94
+ setRangeState("end");
107
95
  }
108
96
  }
109
97
  };
110
- const Month = isInHoveredRange ? RangeButton : ButtonDate;
98
+ const monthState = () => {
99
+ if (isSelected) return "selected";
100
+ if (isInHoveredRange) return "in-range";
101
+ return "neutral";
102
+ };
111
103
  return /* @__PURE__ */ jsx(Month, { variant: isSelected || isInHoveredRange ? "filled" : "ghost", sentiment: isSelected || isInHoveredRange ? "primary" : "neutral", disabled: disabled || isExcluded || isOutsideRange, onClick: (event) => {
112
- if (!isExcluded && !isOutsideRange) {
104
+ if (!isExcluded && !isOutsideRange && !readOnly) {
113
105
  if (selectsRange) {
114
106
  onClickRange(event, constructedDate);
115
107
  } else {
@@ -120,7 +112,7 @@ const Monthly = ({
120
112
  setVisible(false);
121
113
  }
122
114
  }
123
- }, onMouseEnter: () => setHoveredDate(constructedDate), onMouseLeave: () => setHoveredDate(null), children: /* @__PURE__ */ jsx(CapitalizedText, { as: "span", variant: "bodyStrong", prominence: isSelected && !isInHoveredRange ? "strong" : "weak", sentiment: isSelected || isInHoveredRange ? "primary" : "neutral", disabled: disabled || isExcluded || isOutsideRange, children: month[1] }) }, month[0]);
115
+ }, onMouseEnter: () => setHoveredDate(constructedDate), "aria-label": monthState(), children: month[1] }, month[0]);
124
116
  }) });
125
117
  };
126
118
  export {
@@ -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$3 = require("../../Button/index.cjs");
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
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
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
- })("width:100%;background-color:", ({
39
- theme
40
- }) => theme.colors.other.elevation.background.raised, ";color:", ({
16
+ })(({
41
17
  theme
42
- }) => theme.colors.neutral.text, ";box-shadow:", ({
18
+ }) => helpers.styleCalendarContainer(theme), " box-shadow:", ({
43
19
  theme
44
- }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";padding:", ({
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: /* @__PURE__ */ jsxRuntime.jsx(PopupContent, {}), placement: "bottom", ref, hasArrow: false, tabIndex: 0, role: "dialog", debounceDelay: 0, maxWidth: constants.POPUP_WIDTH, disableAnimation: true, align: "start", children });
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, jsxs } from "@emotion/react/jsx-runtime";
1
+ import { jsx } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
- import { useRef, useEffect, useContext } from "react";
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 { getPreviousMonth, getNextMonth } from "../helpers.js";
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
- })("width:100%;background-color:", ({
35
- theme
36
- }) => theme.colors.other.elevation.background.raised, ";color:", ({
12
+ })(({
37
13
  theme
38
- }) => theme.colors.neutral.text, ";box-shadow:", ({
14
+ }) => styleCalendarContainer(theme), " box-shadow:", ({
39
15
  theme
40
- }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";padding:", ({
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: /* @__PURE__ */ jsx(PopupContent, {}), placement: "bottom", ref, hasArrow: false, tabIndex: 0, role: "dialog", debounceDelay: 0, maxWidth: POPUP_WIDTH, disableAnimation: true, align: "start", children });
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,4 +1,2 @@
1
1
  export declare const POPUP_WIDTH = "16.5rem";
2
- export declare const CURRENT_YEAR: number;
3
- export declare const CURRENT_MONTH: number;
4
2
  export declare const CALENDAR_WEEKS = 6;
@@ -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 constants = require("./constants.cjs");
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 = /* @__PURE__ */ new Date()) => basedate.getMonth() === date.getMonth() && basedate.getFullYear() === date.getFullYear();
22
- const isSameDay = (date, basedate = /* @__PURE__ */ new Date()) => basedate.getDate() === date.getDate() && basedate.getMonth() + 1 === date.getMonth() + 1 && basedate.getFullYear() === date.getFullYear();
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;