@ultraviolet/ui 1.61.0 → 1.62.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 (56) hide show
  1. package/dist/components/DateInput/index.cjs +3 -3
  2. package/dist/components/DateInput/index.js +3 -3
  3. package/dist/components/Modal/ModalContent.cjs +53 -0
  4. package/dist/components/Modal/ModalContent.d.ts +17 -0
  5. package/dist/components/Modal/ModalContent.js +51 -0
  6. package/dist/components/Modal/ModalProvider.cjs +40 -0
  7. package/dist/components/Modal/ModalProvider.d.ts +14 -0
  8. package/dist/components/Modal/ModalProvider.js +40 -0
  9. package/dist/components/Modal/components/Dialog.cjs +162 -0
  10. package/dist/components/Modal/components/Dialog.d.ts +13 -0
  11. package/dist/components/Modal/components/Dialog.js +160 -0
  12. package/dist/components/Modal/{Disclosure.d.ts → components/Disclosure.d.ts} +1 -1
  13. package/dist/components/Modal/index.cjs +5 -29
  14. package/dist/components/Modal/index.js +6 -28
  15. package/dist/components/SearchInput/index.cjs +3 -3
  16. package/dist/components/SearchInput/index.js +3 -3
  17. package/dist/components/SearchInput/types.d.ts +2 -1
  18. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +2 -2
  19. package/dist/components/SelectInputV2/SearchBarDropdown.js +2 -2
  20. package/dist/components/Slider/components/DoubleSlider.cjs +287 -0
  21. package/dist/components/Slider/{DoubleSlider.d.ts → components/DoubleSlider.d.ts} +1 -1
  22. package/dist/components/Slider/components/DoubleSlider.js +285 -0
  23. package/dist/components/Slider/{Label.cjs → components/Label.cjs} +2 -2
  24. package/dist/components/Slider/{Label.d.ts → components/Label.d.ts} +1 -1
  25. package/dist/components/Slider/{Label.js → components/Label.js} +2 -2
  26. package/dist/components/Slider/components/Options.cjs +50 -0
  27. package/dist/components/Slider/components/Options.d.ts +13 -0
  28. package/dist/components/Slider/components/Options.js +48 -0
  29. package/dist/components/Slider/components/SingleSlider.cjs +210 -0
  30. package/dist/components/Slider/{SingleSlider.d.ts → components/SingleSlider.d.ts} +1 -1
  31. package/dist/components/Slider/components/SingleSlider.js +208 -0
  32. package/dist/components/Slider/index.cjs +2 -2
  33. package/dist/components/Slider/index.js +2 -2
  34. package/dist/components/Slider/styles.cjs +18 -36
  35. package/dist/components/Slider/styles.d.ts +2 -13
  36. package/dist/components/Slider/styles.js +18 -36
  37. package/dist/components/TextArea/index.cjs +5 -5
  38. package/dist/components/TextArea/index.js +5 -5
  39. package/dist/components/TextInputV2/index.cjs +28 -12
  40. package/dist/components/TextInputV2/index.d.ts +6 -3
  41. package/dist/components/TextInputV2/index.js +29 -13
  42. package/dist/components/UnitInput/index.cjs +5 -5
  43. package/dist/components/UnitInput/index.js +5 -5
  44. package/package.json +7 -7
  45. package/dist/components/Modal/Dialog.cjs +0 -144
  46. package/dist/components/Modal/Dialog.d.ts +0 -11
  47. package/dist/components/Modal/Dialog.js +0 -142
  48. package/dist/components/Slider/DoubleSlider.cjs +0 -280
  49. package/dist/components/Slider/DoubleSlider.js +0 -278
  50. package/dist/components/Slider/Options.cjs +0 -27
  51. package/dist/components/Slider/Options.d.ts +0 -2
  52. package/dist/components/Slider/Options.js +0 -27
  53. package/dist/components/Slider/SingleSlider.cjs +0 -207
  54. package/dist/components/Slider/SingleSlider.js +0 -205
  55. /package/dist/components/Modal/{Disclosure.cjs → components/Disclosure.cjs} +0 -0
  56. /package/dist/components/Modal/{Disclosure.js → components/Disclosure.js} +0 -0
@@ -111,7 +111,7 @@ const StyledWrapper = /* @__PURE__ */ _styled__default.default("div", process.en
111
111
  theme
112
112
  }) => theme.colors.neutral.textDisabled, ";}", PREFIX, "__day--disabled:hover{color:", ({
113
113
  theme
114
- }) => theme.colors.neutral.textDisabled, ";background-color:transparent;}}" + (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":"AAegC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat || ''}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */"));
114
+ }) => theme.colors.neutral.textDisabled, ";background-color:transparent;}}" + (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":"AAegC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */"));
115
115
  const StyledText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
116
116
  target: "e1bm75lk0"
117
117
  } : {
@@ -123,7 +123,7 @@ const StyledText = /* @__PURE__ */ _styled__default.default(index.Text, process.
123
123
  } : {
124
124
  name: "kff9ir",
125
125
  styles: "text-transform:capitalize",
126
- map: "/*# 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":"AA6K+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat || ''}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */",
126
+ map: "/*# 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":"AA6K+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */",
127
127
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
128
128
  });
129
129
  const DEFAULT_FORMAT = (value) => value instanceof Date ? value.toISOString() : value;
@@ -168,7 +168,7 @@ const DateInput = ({
168
168
  const valueFormat = selectsRange ? `${valueStart} ${valueEnd}` : format(value);
169
169
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
170
170
  /* @__PURE__ */ jsxRuntime.jsx(react.Global, { styles: datepicker }),
171
- /* @__PURE__ */ jsxRuntime.jsx(StyledWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(ReactDatePicker, { required, "data-testid": dataTestId, className, autoFocus, fixedHeight: true, name, locale: localeCode, onBlur, onChange, onFocus, selected: value && !selectsRange ? new Date(value) : void 0, selectsRange, excludeDates, showPopperArrow: false, popperPlacement: "bottom-start", customInput: /* @__PURE__ */ jsxRuntime.jsx(index$1.TextInputV2, { error, success, helper, id: localId, label, labelDescription, value: valueFormat || "", disabled, size, suffix: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: "calendar-range", color: "neutral", disabled }), readOnly, tooltip }), disabled, calendarClassName: "calendar", minDate, maxDate, startDate, endDate, renderCustomHeader: ({
171
+ /* @__PURE__ */ jsxRuntime.jsx(StyledWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(ReactDatePicker, { required, "data-testid": dataTestId, className, autoFocus, fixedHeight: true, name, locale: localeCode, onBlur, onChange, onFocus, selected: value && !selectsRange ? new Date(value) : void 0, selectsRange, excludeDates, showPopperArrow: false, popperPlacement: "bottom-start", customInput: /* @__PURE__ */ jsxRuntime.jsx(index$1.TextInputV2, { error, success, helper, id: localId, label, labelDescription, value: valueFormat, disabled, size, suffix: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: "calendar-range", color: "neutral", disabled }), readOnly, tooltip }), disabled, calendarClassName: "calendar", minDate, maxDate, startDate, endDate, renderCustomHeader: ({
172
172
  date,
173
173
  decreaseMonth,
174
174
  increaseMonth,
@@ -106,7 +106,7 @@ const StyledWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "p
106
106
  theme
107
107
  }) => theme.colors.neutral.textDisabled, ";}", PREFIX, "__day--disabled:hover{color:", ({
108
108
  theme
109
- }) => theme.colors.neutral.textDisabled, ";background-color:transparent;}}" + (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":"AAegC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat || ''}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */"));
109
+ }) => theme.colors.neutral.textDisabled, ";background-color:transparent;}}" + (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":"AAegC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */"));
110
110
  const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
111
111
  target: "e1bm75lk0"
112
112
  } : {
@@ -118,7 +118,7 @@ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
118
118
  } : {
119
119
  name: "kff9ir",
120
120
  styles: "text-transform:capitalize",
121
- map: "/*# 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":"AA6K+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat || ''}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */",
121
+ map: "/*# 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":"AA6K+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/DateInput/index.tsx","sourcesContent":["import { Global } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons'\nimport type { FocusEvent, ReactNode } from 'react'\nimport { useId } from 'react'\nimport type { ReactDatePickerProps } from 'react-datepicker'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport { Button } from '../Button'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { TextInputV2 } from '../TextInputV2'\nimport style from './datepicker.css?inline'\n\nconst PREFIX = '.react-datepicker'\n\nconst StyledWrapper = styled.div`\n  width: 100%;\n\n  div${PREFIX}-wrapper {\n    display: block;\n  }\n  div${PREFIX}__input-container {\n    display: block;\n  }\n  div${PREFIX}__triangle {\n    display: none;\n  }\n\n  div${PREFIX}__month-container {\n    padding: 16px;\n  }\n\n  ${PREFIX}-popper {\n    z-index: 1000;\n  }\n  .calendar {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily};\n    border-color: ${({ theme }) => theme.colors.neutral.borderWeak};\n    background-color: ${({ theme }) =>\n      theme.colors.other.elevation.background.raised};\n    box-shadows: ${({ theme }) => theme.shadows.raised};\n\n\n    ${PREFIX}__header {\n      color: ${({ theme }) => theme.colors.neutral.text};\n      background-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised};\n      border-bottom: none;\n      text-align: inherit;\n      display: block;\n      padding-top: 0;\n      position: inherit;\n    }\n\n    ${PREFIX}__triangle {\n      border-bottom-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    }\n    ${PREFIX}__month {\n      margin: 0;\n    }\n\n    ${PREFIX}__day-names {\n      margin-top: 8px;\n    }\n\n    ${PREFIX}__day-name {\n      font-family: ${({ theme }) => theme.typography.bodySmallStrong.fontFamily};\n      color: ${({ theme }) => theme.colors.neutral.text};\n      font-weight: ${({ theme }) => theme.typography.bodySmallStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodySmallStrong.fontSize};\n      line-height: ${({ theme }) => theme.typography.bodySmallStrong.lineHeight};\n      text-align: center;\n      margin: 3px;\n      text-transform: capitalize;\n    }\n\n    ${PREFIX}__day {\n      color: ${({ theme }) => theme.colors.neutral.textWeak};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n      width: 26px;\n      height: 26px;\n      margin-left: 3px;\n      margin-right: 3px;\n    }\n\n    ${PREFIX}__day--outside-month {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n      font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n    }\n\n    ${PREFIX}__day--selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-selecting-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--in-range {\n      color: ${({ theme }) => theme.colors.primary.text};\n      background-color: ${({ theme }) => theme.colors.primary.background};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-start {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--range-end {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      &[aria-disabled=\"true\"],\n      &:disabled {\n        color: ${({ theme }) => theme.colors.primary.textStrongDisabled};\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n\n    ${PREFIX}__day--keyboard-selected {\n      color: ${({ theme }) => theme.colors.primary.textStrong};\n      background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    }\n\n    ${PREFIX}__day:hover {\n      color: ${({ theme }) => theme.colors.neutral.textHover};\n      background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n    }\n\n    ${PREFIX}__day--disabled {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    ${PREFIX}__day--disabled:hover {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      background-color: transparent;\n    }\n  }\n`\n\nconst StyledText = styled(Text)`\n  text-transform: capitalize;\n`\n\ntype DateInputProps = Pick<\n  ReactDatePickerProps<boolean | undefined, boolean>,\n  'locale' | 'onChange'\n> & {\n  autoFocus?: boolean\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) => string | undefined\n  /**\n   * Label of the field\n   */\n  label?: string\n  value?: Date | string | [Date | null, Date | null]\n  className?: string\n  'data-testid'?: string\n  selectsRange?: boolean\n  startDate?: Date | null\n  endDate?: Date | null\n  excludeDates?: Date[]\n  id?: string\n  labelDescription?: ReactNode\n  success?: string | boolean\n  helper?: string\n  size?: 'small' | 'medium' | 'large'\n  readOnly?: boolean\n  tooltip?: string\n}\n\nconst DEFAULT_FORMAT: DateInputProps['format'] = value =>\n  value instanceof Date ? value.toISOString() : value\n\n/**\n * DateInput is a wrapper around react-datepicker that provides a consistent look and feel with the rest of the Ultraviolet UI.\n * See https://reactdatepicker.com/ for more information.\n */\nexport const DateInput = ({\n  autoFocus = false,\n  disabled = false,\n  error,\n  format = DEFAULT_FORMAT,\n  label,\n  labelDescription,\n  locale,\n  maxDate,\n  minDate,\n  startDate,\n  endDate,\n  name,\n  onBlur,\n  onChange,\n  onFocus,\n  required = false,\n  excludeDates,\n  value,\n  selectsRange,\n  className,\n  id,\n  success,\n  helper,\n  size = 'large',\n  readOnly = false,\n  tooltip,\n  'data-testid': dataTestId,\n}: DateInputProps) => {\n  const uniqueId = useId()\n  const localId = id ?? uniqueId\n\n  // Linked to: https://github.com/Hacker0x01/react-datepicker/issues/3834\n  const ReactDatePicker =\n    (DatePicker as unknown as { default: typeof DatePicker }).default ??\n    DatePicker\n\n  const localeCode =\n    (typeof locale === 'string' ? locale : locale?.code) ?? 'en-GB'\n\n  if (typeof locale === 'object') {\n    registerLocale(localeCode, locale)\n  }\n\n  const valueStart = `${\n    startDate !== undefined && startDate !== null\n      ? `${format(startDate)} -`\n      : ''\n  }`\n  const valueEnd = `${\n    endDate !== undefined && endDate !== null ? format(endDate) : ''\n  }`\n\n  const valueFormat = selectsRange\n    ? `${valueStart} ${valueEnd}`\n    : format(value as Date)\n\n  return (\n    <>\n      <Global styles={style} />\n      <StyledWrapper>\n        <ReactDatePicker\n          required={required}\n          data-testid={dataTestId}\n          className={className}\n          autoFocus={autoFocus}\n          fixedHeight\n          name={name}\n          locale={localeCode}\n          onBlur={onBlur}\n          onChange={onChange}\n          onFocus={onFocus}\n          selected={\n            value && !selectsRange ? new Date(value as Date) : undefined\n          }\n          selectsRange={selectsRange}\n          excludeDates={excludeDates}\n          showPopperArrow={false}\n          popperPlacement=\"bottom-start\"\n          customInput={\n            <TextInputV2\n              error={error}\n              success={success}\n              helper={helper}\n              id={localId}\n              label={label}\n              labelDescription={labelDescription}\n              value={valueFormat}\n              disabled={disabled}\n              size={size}\n              suffix={\n                <Icon\n                  name=\"calendar-range\"\n                  color=\"neutral\"\n                  disabled={disabled}\n                />\n              }\n              readOnly={readOnly}\n              tooltip={tooltip}\n            />\n          }\n          disabled={disabled}\n          calendarClassName=\"calendar\"\n          minDate={minDate}\n          maxDate={maxDate}\n          startDate={startDate}\n          endDate={endDate}\n          renderCustomHeader={({\n            date,\n            decreaseMonth,\n            increaseMonth,\n            prevMonthButtonDisabled,\n            nextMonthButtonDisabled,\n          }) => (\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              justifyContent=\"space-between\"\n              gap={3}\n            >\n              <Button\n                size=\"small\"\n                icon=\"arrow-left\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={decreaseMonth}\n                disabled={prevMonthButtonDisabled}\n              />\n              <StyledText variant=\"bodyStrong\" as=\"p\">\n                {new Date(date).toLocaleString(localeCode, {\n                  month: 'long',\n                  year: 'numeric',\n                })}\n              </StyledText>\n              <Button\n                size=\"small\"\n                icon=\"arrow-right\"\n                sentiment=\"neutral\"\n                variant=\"ghost\"\n                onClick={increaseMonth}\n                disabled={nextMonthButtonDisabled}\n              />\n            </Stack>\n          )}\n        />\n      </StyledWrapper>\n    </>\n  )\n}\n"]} */",
122
122
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
123
123
  });
124
124
  const DEFAULT_FORMAT = (value) => value instanceof Date ? value.toISOString() : value;
@@ -163,7 +163,7 @@ const DateInput = ({
163
163
  const valueFormat = selectsRange ? `${valueStart} ${valueEnd}` : format(value);
164
164
  return /* @__PURE__ */ jsxs(Fragment, { children: [
165
165
  /* @__PURE__ */ jsx(Global, { styles: style }),
166
- /* @__PURE__ */ jsx(StyledWrapper, { children: /* @__PURE__ */ jsx(ReactDatePicker, { required, "data-testid": dataTestId, className, autoFocus, fixedHeight: true, name, locale: localeCode, onBlur, onChange, onFocus, selected: value && !selectsRange ? new Date(value) : void 0, selectsRange, excludeDates, showPopperArrow: false, popperPlacement: "bottom-start", customInput: /* @__PURE__ */ jsx(TextInputV2, { error, success, helper, id: localId, label, labelDescription, value: valueFormat || "", disabled, size, suffix: /* @__PURE__ */ jsx(Icon, { name: "calendar-range", color: "neutral", disabled }), readOnly, tooltip }), disabled, calendarClassName: "calendar", minDate, maxDate, startDate, endDate, renderCustomHeader: ({
166
+ /* @__PURE__ */ jsx(StyledWrapper, { children: /* @__PURE__ */ jsx(ReactDatePicker, { required, "data-testid": dataTestId, className, autoFocus, fixedHeight: true, name, locale: localeCode, onBlur, onChange, onFocus, selected: value && !selectsRange ? new Date(value) : void 0, selectsRange, excludeDates, showPopperArrow: false, popperPlacement: "bottom-start", customInput: /* @__PURE__ */ jsx(TextInputV2, { error, success, helper, id: localId, label, labelDescription, value: valueFormat, disabled, size, suffix: /* @__PURE__ */ jsx(Icon, { name: "calendar-range", color: "neutral", disabled }), readOnly, tooltip }), disabled, calendarClassName: "calendar", minDate, maxDate, startDate, endDate, renderCustomHeader: ({
167
167
  date,
168
168
  decreaseMonth,
169
169
  increaseMonth,
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const index = require("../Button/index.cjs");
6
+ const Dialog = require("./components/Dialog.cjs");
7
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
8
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
9
+ const StyledContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
10
+ target: "e14rmpyf0"
11
+ } : {
12
+ target: "e14rmpyf0",
13
+ label: "StyledContainer"
14
+ })("position:absolute;top:", ({
15
+ theme
16
+ }) => theme.space["2"], ";right:", ({
17
+ theme
18
+ }) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IERpYWxvZyB9IGZyb20gJy4vY29tcG9uZW50cy9EaWFsb2cnXG5pbXBvcnQgdHlwZSB7IE1vZGFsUGxhY2VtZW50LCBNb2RhbFNpemUgfSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBNb2RhbCB9IGZyb20gJy4nXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICByaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBNb2RhbENvbnRlbnRQcm9wcyA9IENvbXBvbmVudFByb3BzPHR5cGVvZiBNb2RhbD4gJiB7XG4gIHZpc2libGU6IGJvb2xlYW5cbiAgb3BlbjogYm9vbGVhblxuICBvcGVuZWQ6IGJvb2xlYW5cbiAgcGxhY2VtZW50OiBNb2RhbFBsYWNlbWVudFxuICBmaW5hbFNpemU6IE1vZGFsU2l6ZVxuICBmaW5hbElkOiBzdHJpbmdcbiAgaGFuZGxlT3BlbjogKCkgPT4gdm9pZFxuICBoYW5kbGVUb2dnbGU6ICgpID0+IHZvaWRcbiAgaGFuZGxlQ2xvc2U6ICgpID0+IHZvaWRcbiAgZGF0YVRlc3RJZD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgTW9kYWxDb250ZW50ID0gKHtcbiAgdmlzaWJsZSxcbiAgb3BlbixcbiAgb3BlbmVkLFxuICBwbGFjZW1lbnQsXG4gIGZpbmFsU2l6ZSxcbiAgYXJpYUxhYmVsLFxuICBoaWRlT25DbGlja091dHNpZGUsXG4gIGhpZGVPbkVzYyxcbiAgcHJldmVudEJvZHlTY3JvbGwsXG4gIGhhbmRsZUNsb3NlLFxuICBjbGFzc05hbWUsXG4gIGJhY2tkcm9wQ2xhc3NOYW1lLFxuICBkYXRhVGVzdElkLFxuICBjdXN0b21EaWFsb2dTdHlsZXMsXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzLFxuICBpc0Nsb3NhYmxlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlT3BlbixcbiAgaGFuZGxlVG9nZ2xlLFxuICBmaW5hbElkLFxufTogTW9kYWxDb250ZW50UHJvcHMpID0+XG4gIHZpc2libGUgfHwgb3BlbiB8fCBvcGVuZWQgPyAoXG4gICAgPERpYWxvZ1xuICAgICAgb3Blbj17dmlzaWJsZSB8fCBvcGVuIHx8IG9wZW5lZH1cbiAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgc2l6ZT17ZmluYWxTaXplfVxuICAgICAgYXJpYUxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBoaWRlT25DbGlja091dHNpZGU9e2hpZGVPbkNsaWNrT3V0c2lkZX1cbiAgICAgIGhpZGVPbkVzYz17aGlkZU9uRXNjfVxuICAgICAgcHJldmVudEJvZHlTY3JvbGw9e3ByZXZlbnRCb2R5U2Nyb2xsfVxuICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGJhY2tkcm9wQ2xhc3NOYW1lPXtiYWNrZHJvcENsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICBkaWFsb2dDc3M9e2N1c3RvbURpYWxvZ1N0eWxlc31cbiAgICAgIGJhY2tkcm9wQ3NzPXtjdXN0b21EaWFsb2dCYWNrZHJvcFN0eWxlc31cbiAgICA+XG4gICAgICA8PlxuICAgICAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgPyBjaGlsZHJlbih7XG4gICAgICAgICAgICAgIHZpc2libGUsXG4gICAgICAgICAgICAgIG9uQ2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBvbk9wZW46IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgIHRvZ2dsZTogaGFuZGxlVG9nZ2xlLFxuICAgICAgICAgICAgICBtb2RhbElkOiBmaW5hbElkLFxuICAgICAgICAgICAgICBoaWRlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgY2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBzaG93OiBoYW5kbGVPcGVuLFxuICAgICAgICAgICAgfSlcbiAgICAgICAgICA6IGNoaWxkcmVufVxuICAgICAgICA8U3R5bGVkQ29udGFpbmVyPlxuICAgICAgICAgIHtpc0Nsb3NhYmxlID8gKFxuICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICBkYXRhLXRlc3RpZD17XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWNsb3NlLWJ1dHRvbmAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICAgIDwvPlxuICAgIDwvRGlhbG9nPlxuICApIDogbnVsbFxuIl19 */"));
19
+ const ModalContent = ({
20
+ visible,
21
+ open,
22
+ opened,
23
+ placement,
24
+ finalSize,
25
+ ariaLabel,
26
+ hideOnClickOutside,
27
+ hideOnEsc,
28
+ preventBodyScroll,
29
+ handleClose,
30
+ className,
31
+ backdropClassName,
32
+ dataTestId,
33
+ customDialogStyles,
34
+ customDialogBackdropStyles,
35
+ isClosable,
36
+ children,
37
+ handleOpen,
38
+ handleToggle,
39
+ finalId
40
+ }) => visible || open || opened ? /* @__PURE__ */ jsxRuntime.jsx(Dialog.Dialog, { open: visible || open || opened, placement, size: finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, onClose: handleClose, className, backdropClassName, "data-testid": dataTestId, id: finalId, dialogCss: customDialogStyles, backdropCss: customDialogBackdropStyles, children: /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
41
+ typeof children === "function" ? children({
42
+ visible,
43
+ onClose: handleClose,
44
+ onOpen: handleOpen,
45
+ toggle: handleToggle,
46
+ modalId: finalId,
47
+ hide: handleClose,
48
+ close: handleClose,
49
+ show: handleOpen
50
+ }) : children,
51
+ /* @__PURE__ */ jsxRuntime.jsx(StyledContainer, { children: isClosable ? /* @__PURE__ */ jsxRuntime.jsx(index.Button, { "data-testid": dataTestId ? `${dataTestId}-close-button` : void 0, onClick: handleClose, variant: "ghost", size: "small", icon: "close", sentiment: "neutral", "aria-label": "close" }) : null })
52
+ ] }) }) : null;
53
+ exports.ModalContent = ModalContent;
@@ -0,0 +1,17 @@
1
+ import type { ComponentProps } from 'react';
2
+ import type { ModalPlacement, ModalSize } from './types';
3
+ import type { Modal } from '.';
4
+ type ModalContentProps = ComponentProps<typeof Modal> & {
5
+ visible: boolean;
6
+ open: boolean;
7
+ opened: boolean;
8
+ placement: ModalPlacement;
9
+ finalSize: ModalSize;
10
+ finalId: string;
11
+ handleOpen: () => void;
12
+ handleToggle: () => void;
13
+ handleClose: () => void;
14
+ dataTestId?: string;
15
+ };
16
+ export declare const ModalContent: ({ visible, open, opened, placement, finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, handleClose, className, backdropClassName, dataTestId, customDialogStyles, customDialogBackdropStyles, isClosable, children, handleOpen, handleToggle, finalId, }: ModalContentProps) => import("@emotion/react/jsx-runtime").JSX.Element | null;
17
+ export {};
@@ -0,0 +1,51 @@
1
+ import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { Button } from "../Button/index.js";
4
+ import { Dialog } from "./components/Dialog.js";
5
+ const StyledContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
6
+ target: "e14rmpyf0"
7
+ } : {
8
+ target: "e14rmpyf0",
9
+ label: "StyledContainer"
10
+ })("position:absolute;top:", ({
11
+ theme
12
+ }) => theme.space["2"], ";right:", ({
13
+ theme
14
+ }) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL01vZGFsQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IERpYWxvZyB9IGZyb20gJy4vY29tcG9uZW50cy9EaWFsb2cnXG5pbXBvcnQgdHlwZSB7IE1vZGFsUGxhY2VtZW50LCBNb2RhbFNpemUgfSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBNb2RhbCB9IGZyb20gJy4nXG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICByaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBNb2RhbENvbnRlbnRQcm9wcyA9IENvbXBvbmVudFByb3BzPHR5cGVvZiBNb2RhbD4gJiB7XG4gIHZpc2libGU6IGJvb2xlYW5cbiAgb3BlbjogYm9vbGVhblxuICBvcGVuZWQ6IGJvb2xlYW5cbiAgcGxhY2VtZW50OiBNb2RhbFBsYWNlbWVudFxuICBmaW5hbFNpemU6IE1vZGFsU2l6ZVxuICBmaW5hbElkOiBzdHJpbmdcbiAgaGFuZGxlT3BlbjogKCkgPT4gdm9pZFxuICBoYW5kbGVUb2dnbGU6ICgpID0+IHZvaWRcbiAgaGFuZGxlQ2xvc2U6ICgpID0+IHZvaWRcbiAgZGF0YVRlc3RJZD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgTW9kYWxDb250ZW50ID0gKHtcbiAgdmlzaWJsZSxcbiAgb3BlbixcbiAgb3BlbmVkLFxuICBwbGFjZW1lbnQsXG4gIGZpbmFsU2l6ZSxcbiAgYXJpYUxhYmVsLFxuICBoaWRlT25DbGlja091dHNpZGUsXG4gIGhpZGVPbkVzYyxcbiAgcHJldmVudEJvZHlTY3JvbGwsXG4gIGhhbmRsZUNsb3NlLFxuICBjbGFzc05hbWUsXG4gIGJhY2tkcm9wQ2xhc3NOYW1lLFxuICBkYXRhVGVzdElkLFxuICBjdXN0b21EaWFsb2dTdHlsZXMsXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzLFxuICBpc0Nsb3NhYmxlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlT3BlbixcbiAgaGFuZGxlVG9nZ2xlLFxuICBmaW5hbElkLFxufTogTW9kYWxDb250ZW50UHJvcHMpID0+XG4gIHZpc2libGUgfHwgb3BlbiB8fCBvcGVuZWQgPyAoXG4gICAgPERpYWxvZ1xuICAgICAgb3Blbj17dmlzaWJsZSB8fCBvcGVuIHx8IG9wZW5lZH1cbiAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgc2l6ZT17ZmluYWxTaXplfVxuICAgICAgYXJpYUxhYmVsPXthcmlhTGFiZWx9XG4gICAgICBoaWRlT25DbGlja091dHNpZGU9e2hpZGVPbkNsaWNrT3V0c2lkZX1cbiAgICAgIGhpZGVPbkVzYz17aGlkZU9uRXNjfVxuICAgICAgcHJldmVudEJvZHlTY3JvbGw9e3ByZXZlbnRCb2R5U2Nyb2xsfVxuICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGJhY2tkcm9wQ2xhc3NOYW1lPXtiYWNrZHJvcENsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICBkaWFsb2dDc3M9e2N1c3RvbURpYWxvZ1N0eWxlc31cbiAgICAgIGJhY2tkcm9wQ3NzPXtjdXN0b21EaWFsb2dCYWNrZHJvcFN0eWxlc31cbiAgICA+XG4gICAgICA8PlxuICAgICAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgPyBjaGlsZHJlbih7XG4gICAgICAgICAgICAgIHZpc2libGUsXG4gICAgICAgICAgICAgIG9uQ2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBvbk9wZW46IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgIHRvZ2dsZTogaGFuZGxlVG9nZ2xlLFxuICAgICAgICAgICAgICBtb2RhbElkOiBmaW5hbElkLFxuICAgICAgICAgICAgICBoaWRlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgY2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICBzaG93OiBoYW5kbGVPcGVuLFxuICAgICAgICAgICAgfSlcbiAgICAgICAgICA6IGNoaWxkcmVufVxuICAgICAgICA8U3R5bGVkQ29udGFpbmVyPlxuICAgICAgICAgIHtpc0Nsb3NhYmxlID8gKFxuICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICBkYXRhLXRlc3RpZD17XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWNsb3NlLWJ1dHRvbmAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICAgIDwvPlxuICAgIDwvRGlhbG9nPlxuICApIDogbnVsbFxuIl19 */"));
15
+ const ModalContent = ({
16
+ visible,
17
+ open,
18
+ opened,
19
+ placement,
20
+ finalSize,
21
+ ariaLabel,
22
+ hideOnClickOutside,
23
+ hideOnEsc,
24
+ preventBodyScroll,
25
+ handleClose,
26
+ className,
27
+ backdropClassName,
28
+ dataTestId,
29
+ customDialogStyles,
30
+ customDialogBackdropStyles,
31
+ isClosable,
32
+ children,
33
+ handleOpen,
34
+ handleToggle,
35
+ finalId
36
+ }) => visible || open || opened ? /* @__PURE__ */ jsx(Dialog, { open: visible || open || opened, placement, size: finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, onClose: handleClose, className, backdropClassName, "data-testid": dataTestId, id: finalId, dialogCss: customDialogStyles, backdropCss: customDialogBackdropStyles, children: /* @__PURE__ */ jsxs(Fragment, { children: [
37
+ typeof children === "function" ? children({
38
+ visible,
39
+ onClose: handleClose,
40
+ onOpen: handleOpen,
41
+ toggle: handleToggle,
42
+ modalId: finalId,
43
+ hide: handleClose,
44
+ close: handleClose,
45
+ show: handleOpen
46
+ }) : children,
47
+ /* @__PURE__ */ jsx(StyledContainer, { children: isClosable ? /* @__PURE__ */ jsx(Button, { "data-testid": dataTestId ? `${dataTestId}-close-button` : void 0, onClick: handleClose, variant: "ghost", size: "small", icon: "close", sentiment: "neutral", "aria-label": "close" }) : null })
48
+ ] }) }) : null;
49
+ export {
50
+ ModalContent
51
+ };
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const React = require("react");
5
+ const ModalContext = React.createContext(void 0);
6
+ const useModal = () => {
7
+ const context = React.useContext(ModalContext);
8
+ if (!context) {
9
+ throw new Error("useModal must be used within a ModalProvider");
10
+ }
11
+ return context;
12
+ };
13
+ const ModalProvider = ({
14
+ children
15
+ }) => {
16
+ const [openedModals, setOpenedModals] = React.useState([]);
17
+ const [previsousOpenedModales, setPreviousOpenedModales] = React.useState([]);
18
+ const registerModal = React.useCallback((id) => {
19
+ setOpenedModals((prev) => {
20
+ setPreviousOpenedModales(prev);
21
+ return [...prev, id];
22
+ });
23
+ }, []);
24
+ const unregisterModal = React.useCallback((id) => {
25
+ setOpenedModals((prev) => {
26
+ setPreviousOpenedModales(prev);
27
+ return prev.filter((modalId) => modalId !== id);
28
+ });
29
+ }, []);
30
+ const value = React.useMemo(() => ({
31
+ openedModals,
32
+ registerModal,
33
+ unregisterModal,
34
+ previsousOpenedModales
35
+ }), [openedModals, registerModal, unregisterModal, previsousOpenedModales]);
36
+ return /* @__PURE__ */ jsxRuntime.jsx(ModalContext.Provider, { value, children });
37
+ };
38
+ exports.ModalContext = ModalContext;
39
+ exports.ModalProvider = ModalProvider;
40
+ exports.useModal = useModal;
@@ -0,0 +1,14 @@
1
+ import type { ReactNode } from 'react';
2
+ type ModalContextValues = {
3
+ openedModals: string[];
4
+ registerModal: (id: string) => void;
5
+ unregisterModal: (id: string) => void;
6
+ previsousOpenedModales: string[];
7
+ };
8
+ export declare const ModalContext: import("react").Context<ModalContextValues | undefined>;
9
+ export declare const useModal: () => ModalContextValues;
10
+ type ModalProviderProps = {
11
+ children: ReactNode;
12
+ };
13
+ export declare const ModalProvider: ({ children }: ModalProviderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
14
+ export {};
@@ -0,0 +1,40 @@
1
+ import { jsx } from "@emotion/react/jsx-runtime";
2
+ import { createContext, useState, useCallback, useMemo, useContext } from "react";
3
+ const ModalContext = createContext(void 0);
4
+ const useModal = () => {
5
+ const context = useContext(ModalContext);
6
+ if (!context) {
7
+ throw new Error("useModal must be used within a ModalProvider");
8
+ }
9
+ return context;
10
+ };
11
+ const ModalProvider = ({
12
+ children
13
+ }) => {
14
+ const [openedModals, setOpenedModals] = useState([]);
15
+ const [previsousOpenedModales, setPreviousOpenedModales] = useState([]);
16
+ const registerModal = useCallback((id) => {
17
+ setOpenedModals((prev) => {
18
+ setPreviousOpenedModales(prev);
19
+ return [...prev, id];
20
+ });
21
+ }, []);
22
+ const unregisterModal = useCallback((id) => {
23
+ setOpenedModals((prev) => {
24
+ setPreviousOpenedModales(prev);
25
+ return prev.filter((modalId) => modalId !== id);
26
+ });
27
+ }, []);
28
+ const value = useMemo(() => ({
29
+ openedModals,
30
+ registerModal,
31
+ unregisterModal,
32
+ previsousOpenedModales
33
+ }), [openedModals, registerModal, unregisterModal, previsousOpenedModales]);
34
+ return /* @__PURE__ */ jsx(ModalContext.Provider, { value, children });
35
+ };
36
+ export {
37
+ ModalContext,
38
+ ModalProvider,
39
+ useModal
40
+ };