@ultraviolet/ui 1.60.0 → 1.61.1

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 (35) hide show
  1. package/dist/components/DateInput/index.cjs +3 -3
  2. package/dist/components/DateInput/index.js +3 -3
  3. package/dist/components/Expandable/index.cjs +36 -21
  4. package/dist/components/Expandable/index.d.ts +3 -0
  5. package/dist/components/Expandable/index.js +36 -21
  6. package/dist/components/SearchInput/index.cjs +6 -3
  7. package/dist/components/SearchInput/index.js +6 -3
  8. package/dist/components/SearchInput/types.d.ts +2 -1
  9. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +2 -2
  10. package/dist/components/SelectInputV2/SearchBarDropdown.js +2 -2
  11. package/dist/components/Slider/components/DoubleSlider.cjs +280 -0
  12. package/dist/components/Slider/{DoubleSlider.d.ts → components/DoubleSlider.d.ts} +1 -1
  13. package/dist/components/Slider/components/DoubleSlider.js +278 -0
  14. package/dist/components/Slider/{Label.cjs → components/Label.cjs} +2 -2
  15. package/dist/components/Slider/{Label.d.ts → components/Label.d.ts} +1 -1
  16. package/dist/components/Slider/{Label.js → components/Label.js} +2 -2
  17. package/dist/components/Slider/{Options.cjs → components/Options.cjs} +3 -3
  18. package/dist/components/Slider/{Options.d.ts → components/Options.d.ts} +1 -1
  19. package/dist/components/Slider/{Options.js → components/Options.js} +3 -3
  20. package/dist/components/Slider/components/SingleSlider.cjs +207 -0
  21. package/dist/components/Slider/{SingleSlider.d.ts → components/SingleSlider.d.ts} +1 -1
  22. package/dist/components/Slider/components/SingleSlider.js +205 -0
  23. package/dist/components/Slider/index.cjs +2 -2
  24. package/dist/components/Slider/index.js +2 -2
  25. package/dist/components/Slider/styles.cjs +12 -12
  26. package/dist/components/Slider/styles.d.ts +1 -1
  27. package/dist/components/Slider/styles.js +12 -12
  28. package/dist/components/TextInputV2/index.cjs +28 -12
  29. package/dist/components/TextInputV2/index.d.ts +6 -3
  30. package/dist/components/TextInputV2/index.js +29 -13
  31. package/package.json +6 -6
  32. package/dist/components/Slider/DoubleSlider.cjs +0 -280
  33. package/dist/components/Slider/DoubleSlider.js +0 -278
  34. package/dist/components/Slider/SingleSlider.cjs +0 -207
  35. package/dist/components/Slider/SingleSlider.js +0 -205
@@ -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,
@@ -13,11 +13,11 @@ const StyledExpandable = /* @__PURE__ */ _styled__default.default("div", process
13
13
  shouldForwardProp: (prop) => !["animationDuration"].includes(prop),
14
14
  target: "e5hc7t70",
15
15
  label: "StyledExpandable"
16
- })("transition:max-height ", ({
16
+ })('&[data-is-animated="true"]{transition:max-height ', ({
17
17
  animationDuration
18
18
  }) => animationDuration, "ms ease-out,opacity ", ({
19
19
  animationDuration
20
- }) => animationDuration, "ms ease-out;height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gMzAwIC8vIGluIG1zXG5cbnR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKipcbiAgICogVGhlIGNvbnRlbnQgdG8gZGlzcGxheVxuICAgKi9cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVG8gZGlzcGxheSBvciBub3QgdGhlIGNvbnRlbnRcbiAgICovXG4gIG9wZW5lZD86IGJvb2xlYW5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIGhlaWdodCBvZiB0aGUgY29udGVudFxuICAgKi9cbiAgbWluSGVpZ2h0PzogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2FuaW1hdGlvbkR1cmF0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGFuaW1hdGlvbkR1cmF0aW9uOiBudW1iZXIgfT5gXG4gIHRyYW5zaXRpb246XG4gICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgIG9wYWNpdHkgJHsoeyBhbmltYXRpb25EdXJhdGlvbiB9KSA9PiBhbmltYXRpb25EdXJhdGlvbn1tcyBlYXNlLW91dDtcbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG4vKipcbiAqIFRoZSBFeHBhbmRhYmxlIGNvbXBvbmVudCBpcyBhIGR5bmFtaWMgUmVhY3QgY29tcG9uZW50IHRoYXQgYWxsb3dzIGZvciB0aGUgZXhwYW5zaW9uIG9mIGl0cyBjaGlsZHJlbiBjb250ZW50XG4gKiBiYXNlZCBvbiBpdHMgaGVpZ2h0LiBUaGUgY29tcG9uZW50IGNvbWVzIHdpdGggYSBzbGVlayBhbmQgc21vb3RoIGFuaW1hdGlvbiwgcHJvdmlkaW5nIGEgdmlzdWFsbHkgcGxlYXNpbmdcbiAqIHVzZXIgZXhwZXJpZW5jZS5cbiAqL1xuZXhwb3J0IGNvbnN0IEV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQgPSAwLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGFuaW1hdGlvbkR1cmF0aW9uID0gQU5JTUFUSU9OX0RVUkFUSU9OLFxufTogRXhwYW5kYWJsZVByb3BzKSA9PiB7XG4gIGNvbnN0IFtoZWlnaHQsIHNldEhlaWdodF0gPSB1c2VTdGF0ZTxudW1iZXIgfCBudWxsPihudWxsKVxuICBjb25zdCB0cmFuc2l0aW9uVGltZXIgPSB1c2VSZWY8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIC8qKlxuICAgKiBBdCBtb3VudCwgd2Ugc2V0IHRoZSBoZWlnaHQgdmFyaWFibGUgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCBvbmx5IGlmIHRoZSBjb21wb25lbnQgaXMgY2xvc2VkLlxuICAgKiBUaGlzIGlzIHRvIGVuc3VyZSB3ZSBkb24ndCBoYXZlIGFuaW1hdGlvbiB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkIGF0IG1vdW50LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldEhlaWdodChyZWYuY3VycmVudC5zY3JvbGxIZWlnaHQgPz8gMClcbiAgICB9XG4gIH0sIFtyZWYuY3VycmVudD8uc2Nyb2xsSGVpZ2h0XSlcblxuICAvKipcbiAgICogSGVyZSB3ZSBzZXQgbWF4SGVpZ2h0IHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZFxuICAgKiBhbmQgYWZ0ZXIgMzAwbXMgd2Ugc2V0IG1heEhlaWdodCB0byBpbml0aWFsIHRvIGxldCB0aGUgY29udGVudCBncm93IHdpdGggYW5pbWF0aW9uLlxuICAgKiBTZXR0aW5nIGl0IHRvIGluaXRpYWwgaXMgcmVxdWlyZWQgdG8gYmUgYWJsZSB0byBoYXZlIG5lc3RlZCBleHBhbmRhYmxlIG9yIHRoZSBoZWlnaHQgd29uJ3QgZm9sbG93LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAob3BlbmVkICYmIHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUudmlzaWJpbGl0eSA9ICcnXG4gICAgICB0cmFuc2l0aW9uVGltZXIuY3VycmVudCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICB9XG4gICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgfSBlbHNlIHtcbiAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcblxuICAgICAgaWYgKHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHtoZWlnaHR9cHhgXG4gICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHttaW5IZWlnaHR9cHhgXG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgICAgaWYgKHJlZi5jdXJyZW50ICYmICFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSwgQU5JTUFUSU9OX0RVUkFUSU9OKVxuICAgICAgICAgIH1cbiAgICAgICAgfSwgMClcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgY2xlYXJUaW1lb3V0KHRyYW5zaXRpb25UaW1lci5jdXJyZW50KVxuICAgIH1cbiAgfSwgW2hlaWdodCwgbWluSGVpZ2h0LCBvcGVuZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEV4cGFuZGFibGVcbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG4iXX0= */"));
20
+ }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gMzAwIC8vIGluIG1zXG5cbnR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKipcbiAgICogVGhlIGNvbnRlbnQgdG8gZGlzcGxheVxuICAgKi9cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVG8gZGlzcGxheSBvciBub3QgdGhlIGNvbnRlbnRcbiAgICovXG4gIG9wZW5lZD86IGJvb2xlYW5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIGhlaWdodCBvZiB0aGUgY29udGVudFxuICAgKi9cbiAgbWluSGVpZ2h0PzogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIC8qKlxuICAgKiBUaGUgZHVyYXRpb24gb2YgdGhlIGFuaW1hdGlvbiBpbiBtcy4gSWYgc2V0IHRvIDAsIHRoZSBhbmltYXRpb24gd2lsbCBiZSBkaXNhYmxlZC5cbiAgICovXG4gIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2FuaW1hdGlvbkR1cmF0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGFuaW1hdGlvbkR1cmF0aW9uOiBudW1iZXIgfT5gXG4gICZbZGF0YS1pcy1hbmltYXRlZD1cInRydWVcIl0ge1xuICAgIHRyYW5zaXRpb246XG4gICAgICBtYXgtaGVpZ2h0ICR7KHsgYW5pbWF0aW9uRHVyYXRpb24gfSkgPT4gYW5pbWF0aW9uRHVyYXRpb259bXMgZWFzZS1vdXQsXG4gICAgICBvcGFjaXR5ICR7KHsgYW5pbWF0aW9uRHVyYXRpb24gfSkgPT4gYW5pbWF0aW9uRHVyYXRpb259bXMgZWFzZS1vdXQ7XG4gICAgfVxuICBoZWlnaHQ6IGF1dG87XG5gXG5cbi8qKlxuICogVGhlIEV4cGFuZGFibGUgY29tcG9uZW50IGlzIGEgZHluYW1pYyBSZWFjdCBjb21wb25lbnQgdGhhdCBhbGxvd3MgZm9yIHRoZSBleHBhbnNpb24gb2YgaXRzIGNoaWxkcmVuIGNvbnRlbnRcbiAqIGJhc2VkIG9uIGl0cyBoZWlnaHQuIFRoZSBjb21wb25lbnQgY29tZXMgd2l0aCBhIHNsZWVrIGFuZCBzbW9vdGggYW5pbWF0aW9uLCBwcm92aWRpbmcgYSB2aXN1YWxseSBwbGVhc2luZ1xuICogdXNlciBleHBlcmllbmNlLlxuICovXG5leHBvcnQgY29uc3QgRXhwYW5kYWJsZSA9ICh7XG4gIGNoaWxkcmVuLFxuICBvcGVuZWQsXG4gIG1pbkhlaWdodCA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgYW5pbWF0aW9uRHVyYXRpb24gPSBBTklNQVRJT05fRFVSQVRJT04sXG59OiBFeHBhbmRhYmxlUHJvcHMpID0+IHtcbiAgY29uc3QgW2hlaWdodCwgc2V0SGVpZ2h0XSA9IHVzZVN0YXRlPG51bWJlciB8IG51bGw+KG51bGwpXG4gIGNvbnN0IHRyYW5zaXRpb25UaW1lciA9IHVzZVJlZjxSZXR1cm5UeXBlPHR5cGVvZiBzZXRUaW1lb3V0PiB8IHVuZGVmaW5lZD4oKVxuICBjb25zdCByZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gIGNvbnN0IHNob3VsZEJlQW5pbWF0ZWQgPSBhbmltYXRpb25EdXJhdGlvbiA+IDBcblxuICAvKipcbiAgICogQXQgbW91bnQsIHdlIHNldCB0aGUgaGVpZ2h0IHZhcmlhYmxlIHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgb25seSBpZiB0aGUgY29tcG9uZW50IGlzIGNsb3NlZC5cbiAgICogVGhpcyBpcyB0byBlbnN1cmUgd2UgZG9uJ3QgaGF2ZSBhbmltYXRpb24gd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZCBhdCBtb3VudC5cbiAgICovXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICBzZXRIZWlnaHQocmVmLmN1cnJlbnQuc2Nyb2xsSGVpZ2h0ID8/IDApXG4gICAgfVxuICB9LCBbcmVmLmN1cnJlbnQ/LnNjcm9sbEhlaWdodF0pXG5cbiAgLyoqXG4gICAqIEhlcmUgd2Ugc2V0IG1heEhlaWdodCB0byB0aGUgaGVpZ2h0IG9mIHRoZSBjb250ZW50IHdoZW4gdGhlIGNvbXBvbmVudCBpcyBvcGVuZWRcbiAgICogYW5kIGFmdGVyIDMwMG1zIHdlIHNldCBtYXhIZWlnaHQgdG8gaW5pdGlhbCB0byBsZXQgdGhlIGNvbnRlbnQgZ3JvdyB3aXRoIGFuaW1hdGlvbi5cbiAgICogU2V0dGluZyBpdCB0byBpbml0aWFsIGlzIHJlcXVpcmVkIHRvIGJlIGFibGUgdG8gaGF2ZSBuZXN0ZWQgZXhwYW5kYWJsZSBvciB0aGUgaGVpZ2h0IHdvbid0IGZvbGxvdy5cbiAgICovXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKG9wZW5lZCAmJiByZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke2hlaWdodH1weGBcbiAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgaWYgKHNob3VsZEJlQW5pbWF0ZWQpIHtcbiAgICAgICAgdHJhbnNpdGlvblRpbWVyLmN1cnJlbnQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9ICdpbml0aWFsJ1xuICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUub3ZlcmZsb3cgPSAndmlzaWJsZSdcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICAgIH1cbiAgICAgICAgfSwgQU5JTUFUSU9OX0RVUkFUSU9OKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gJ2luaXRpYWwnXG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ3Zpc2libGUnXG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG5cbiAgICAgIGlmIChyZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgICBpZiAoc2hvdWxkQmVBbmltYXRlZCkge1xuICAgICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7bWluSGVpZ2h0fXB4YFxuICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChyZWYuY3VycmVudCAmJiAhbWluSGVpZ2h0KSB7XG4gICAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LCAwKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgaWYgKCFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG4gICAgfVxuICB9LCBbYW5pbWF0aW9uRHVyYXRpb24sIGhlaWdodCwgbWluSGVpZ2h0LCBvcGVuZWQsIHNob3VsZEJlQW5pbWF0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEV4cGFuZGFibGVcbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICAgIGRhdGEtaXMtYW5pbWF0ZWQ9e3Nob3VsZEJlQW5pbWF0ZWR9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkRXhwYW5kYWJsZT5cbiAgKVxufVxuIl19 */"));
21
21
  const Expandable = ({
22
22
  children,
23
23
  opened,
@@ -29,6 +29,7 @@ const Expandable = ({
29
29
  const [height, setHeight] = React.useState(null);
30
30
  const transitionTimer = React.useRef();
31
31
  const ref = React.useRef(null);
32
+ const shouldBeAnimated = animationDuration > 0;
32
33
  React.useEffect(() => {
33
34
  if (ref.current) {
34
35
  setHeight(ref.current.scrollHeight ?? 0);
@@ -38,35 +39,49 @@ const Expandable = ({
38
39
  if (opened && ref.current && height) {
39
40
  ref.current.style.maxHeight = `${height}px`;
40
41
  ref.current.style.visibility = "";
41
- transitionTimer.current = setTimeout(() => {
42
- if (ref.current) {
43
- ref.current.style.maxHeight = "initial";
44
- ref.current.style.overflow = "visible";
45
- ref.current.style.visibility = "";
46
- }
47
- }, ANIMATION_DURATION);
42
+ if (shouldBeAnimated) {
43
+ transitionTimer.current = setTimeout(() => {
44
+ if (ref.current) {
45
+ ref.current.style.maxHeight = "initial";
46
+ ref.current.style.overflow = "visible";
47
+ ref.current.style.visibility = "";
48
+ }
49
+ }, ANIMATION_DURATION);
50
+ } else {
51
+ ref.current.style.maxHeight = "initial";
52
+ ref.current.style.overflow = "visible";
53
+ ref.current.style.visibility = "";
54
+ }
48
55
  } else {
49
56
  clearTimeout(transitionTimer.current);
50
57
  if (ref.current && height) {
51
58
  ref.current.style.maxHeight = `${height}px`;
52
- transitionTimer.current = setTimeout(() => {
53
- if (ref.current) {
54
- ref.current.style.maxHeight = `${minHeight}px`;
55
- ref.current.style.overflow = "hidden";
56
- setTimeout(() => {
57
- if (ref.current && !minHeight) {
58
- ref.current.style.visibility = "hidden";
59
- }
60
- }, ANIMATION_DURATION);
59
+ if (shouldBeAnimated) {
60
+ transitionTimer.current = setTimeout(() => {
61
+ if (ref.current) {
62
+ ref.current.style.maxHeight = `${minHeight}px`;
63
+ ref.current.style.overflow = "hidden";
64
+ setTimeout(() => {
65
+ if (ref.current && !minHeight) {
66
+ ref.current.style.visibility = "hidden";
67
+ }
68
+ }, ANIMATION_DURATION);
69
+ }
70
+ }, 0);
71
+ } else {
72
+ ref.current.style.maxHeight = `${minHeight}px`;
73
+ ref.current.style.overflow = "hidden";
74
+ if (!minHeight) {
75
+ ref.current.style.visibility = "hidden";
61
76
  }
62
- }, 0);
77
+ }
63
78
  }
64
79
  }
65
80
  return () => {
66
81
  clearTimeout(transitionTimer.current);
67
82
  };
68
- }, [height, minHeight, opened]);
69
- return /* @__PURE__ */ jsxRuntime.jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, children });
83
+ }, [animationDuration, height, minHeight, opened, shouldBeAnimated]);
84
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, "data-is-animated": shouldBeAnimated, children });
70
85
  };
71
86
  exports.Expandable = Expandable;
72
87
  exports.StyledExpandable = StyledExpandable;
@@ -14,6 +14,9 @@ type ExpandableProps = {
14
14
  minHeight?: number;
15
15
  className?: string;
16
16
  'data-testid'?: string;
17
+ /**
18
+ * The duration of the animation in ms. If set to 0, the animation will be disabled.
19
+ */
17
20
  animationDuration?: number;
18
21
  };
19
22
  export declare const StyledExpandable: import("@emotion/styled").StyledComponent<{
@@ -9,11 +9,11 @@ const StyledExpandable = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
9
9
  shouldForwardProp: (prop) => !["animationDuration"].includes(prop),
10
10
  target: "e5hc7t70",
11
11
  label: "StyledExpandable"
12
- })("transition:max-height ", ({
12
+ })('&[data-is-animated="true"]{transition:max-height ', ({
13
13
  animationDuration
14
14
  }) => animationDuration, "ms ease-out,opacity ", ({
15
15
  animationDuration
16
- }) => animationDuration, "ms ease-out;height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gMzAwIC8vIGluIG1zXG5cbnR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKipcbiAgICogVGhlIGNvbnRlbnQgdG8gZGlzcGxheVxuICAgKi9cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVG8gZGlzcGxheSBvciBub3QgdGhlIGNvbnRlbnRcbiAgICovXG4gIG9wZW5lZD86IGJvb2xlYW5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIGhlaWdodCBvZiB0aGUgY29udGVudFxuICAgKi9cbiAgbWluSGVpZ2h0PzogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2FuaW1hdGlvbkR1cmF0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGFuaW1hdGlvbkR1cmF0aW9uOiBudW1iZXIgfT5gXG4gIHRyYW5zaXRpb246XG4gICAgbWF4LWhlaWdodCAkeyh7IGFuaW1hdGlvbkR1cmF0aW9uIH0pID0+IGFuaW1hdGlvbkR1cmF0aW9ufW1zIGVhc2Utb3V0LFxuICAgIG9wYWNpdHkgJHsoeyBhbmltYXRpb25EdXJhdGlvbiB9KSA9PiBhbmltYXRpb25EdXJhdGlvbn1tcyBlYXNlLW91dDtcbiAgaGVpZ2h0OiBhdXRvO1xuYFxuXG4vKipcbiAqIFRoZSBFeHBhbmRhYmxlIGNvbXBvbmVudCBpcyBhIGR5bmFtaWMgUmVhY3QgY29tcG9uZW50IHRoYXQgYWxsb3dzIGZvciB0aGUgZXhwYW5zaW9uIG9mIGl0cyBjaGlsZHJlbiBjb250ZW50XG4gKiBiYXNlZCBvbiBpdHMgaGVpZ2h0LiBUaGUgY29tcG9uZW50IGNvbWVzIHdpdGggYSBzbGVlayBhbmQgc21vb3RoIGFuaW1hdGlvbiwgcHJvdmlkaW5nIGEgdmlzdWFsbHkgcGxlYXNpbmdcbiAqIHVzZXIgZXhwZXJpZW5jZS5cbiAqL1xuZXhwb3J0IGNvbnN0IEV4cGFuZGFibGUgPSAoe1xuICBjaGlsZHJlbixcbiAgb3BlbmVkLFxuICBtaW5IZWlnaHQgPSAwLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGFuaW1hdGlvbkR1cmF0aW9uID0gQU5JTUFUSU9OX0RVUkFUSU9OLFxufTogRXhwYW5kYWJsZVByb3BzKSA9PiB7XG4gIGNvbnN0IFtoZWlnaHQsIHNldEhlaWdodF0gPSB1c2VTdGF0ZTxudW1iZXIgfCBudWxsPihudWxsKVxuICBjb25zdCB0cmFuc2l0aW9uVGltZXIgPSB1c2VSZWY8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KClcbiAgY29uc3QgcmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuXG4gIC8qKlxuICAgKiBBdCBtb3VudCwgd2Ugc2V0IHRoZSBoZWlnaHQgdmFyaWFibGUgdG8gdGhlIGhlaWdodCBvZiB0aGUgY29udGVudCBvbmx5IGlmIHRoZSBjb21wb25lbnQgaXMgY2xvc2VkLlxuICAgKiBUaGlzIGlzIHRvIGVuc3VyZSB3ZSBkb24ndCBoYXZlIGFuaW1hdGlvbiB3aGVuIHRoZSBjb21wb25lbnQgaXMgb3BlbmVkIGF0IG1vdW50LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldEhlaWdodChyZWYuY3VycmVudC5zY3JvbGxIZWlnaHQgPz8gMClcbiAgICB9XG4gIH0sIFtyZWYuY3VycmVudD8uc2Nyb2xsSGVpZ2h0XSlcblxuICAvKipcbiAgICogSGVyZSB3ZSBzZXQgbWF4SGVpZ2h0IHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZFxuICAgKiBhbmQgYWZ0ZXIgMzAwbXMgd2Ugc2V0IG1heEhlaWdodCB0byBpbml0aWFsIHRvIGxldCB0aGUgY29udGVudCBncm93IHdpdGggYW5pbWF0aW9uLlxuICAgKiBTZXR0aW5nIGl0IHRvIGluaXRpYWwgaXMgcmVxdWlyZWQgdG8gYmUgYWJsZSB0byBoYXZlIG5lc3RlZCBleHBhbmRhYmxlIG9yIHRoZSBoZWlnaHQgd29uJ3QgZm9sbG93LlxuICAgKi9cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAob3BlbmVkICYmIHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgcmVmLmN1cnJlbnQuc3R5bGUudmlzaWJpbGl0eSA9ICcnXG4gICAgICB0cmFuc2l0aW9uVGltZXIuY3VycmVudCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSAnaW5pdGlhbCdcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICd2aXNpYmxlJ1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICB9XG4gICAgICB9LCBBTklNQVRJT05fRFVSQVRJT04pXG4gICAgfSBlbHNlIHtcbiAgICAgIGNsZWFyVGltZW91dCh0cmFuc2l0aW9uVGltZXIuY3VycmVudClcblxuICAgICAgaWYgKHJlZi5jdXJyZW50ICYmIGhlaWdodCkge1xuICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHtoZWlnaHR9cHhgXG4gICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5tYXhIZWlnaHQgPSBgJHttaW5IZWlnaHR9cHhgXG4gICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgICAgaWYgKHJlZi5jdXJyZW50ICYmICFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSwgQU5JTUFUSU9OX0RVUkFUSU9OKVxuICAgICAgICAgIH1cbiAgICAgICAgfSwgMClcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgY2xlYXJUaW1lb3V0KHRyYW5zaXRpb25UaW1lci5jdXJyZW50KVxuICAgIH1cbiAgfSwgW2hlaWdodCwgbWluSGVpZ2h0LCBvcGVuZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEV4cGFuZGFibGVcbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRFeHBhbmRhYmxlPlxuICApXG59XG4iXX0= */"));
16
+ }) => animationDuration, "ms ease-out;}height:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0V4cGFuZGFibGUvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvRXhwYW5kYWJsZS9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gMzAwIC8vIGluIG1zXG5cbnR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKipcbiAgICogVGhlIGNvbnRlbnQgdG8gZGlzcGxheVxuICAgKi9cbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVG8gZGlzcGxheSBvciBub3QgdGhlIGNvbnRlbnRcbiAgICovXG4gIG9wZW5lZD86IGJvb2xlYW5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIGhlaWdodCBvZiB0aGUgY29udGVudFxuICAgKi9cbiAgbWluSGVpZ2h0PzogbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIC8qKlxuICAgKiBUaGUgZHVyYXRpb24gb2YgdGhlIGFuaW1hdGlvbiBpbiBtcy4gSWYgc2V0IHRvIDAsIHRoZSBhbmltYXRpb24gd2lsbCBiZSBkaXNhYmxlZC5cbiAgICovXG4gIGFuaW1hdGlvbkR1cmF0aW9uPzogbnVtYmVyXG59XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2FuaW1hdGlvbkR1cmF0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGFuaW1hdGlvbkR1cmF0aW9uOiBudW1iZXIgfT5gXG4gICZbZGF0YS1pcy1hbmltYXRlZD1cInRydWVcIl0ge1xuICAgIHRyYW5zaXRpb246XG4gICAgICBtYXgtaGVpZ2h0ICR7KHsgYW5pbWF0aW9uRHVyYXRpb24gfSkgPT4gYW5pbWF0aW9uRHVyYXRpb259bXMgZWFzZS1vdXQsXG4gICAgICBvcGFjaXR5ICR7KHsgYW5pbWF0aW9uRHVyYXRpb24gfSkgPT4gYW5pbWF0aW9uRHVyYXRpb259bXMgZWFzZS1vdXQ7XG4gICAgfVxuICBoZWlnaHQ6IGF1dG87XG5gXG5cbi8qKlxuICogVGhlIEV4cGFuZGFibGUgY29tcG9uZW50IGlzIGEgZHluYW1pYyBSZWFjdCBjb21wb25lbnQgdGhhdCBhbGxvd3MgZm9yIHRoZSBleHBhbnNpb24gb2YgaXRzIGNoaWxkcmVuIGNvbnRlbnRcbiAqIGJhc2VkIG9uIGl0cyBoZWlnaHQuIFRoZSBjb21wb25lbnQgY29tZXMgd2l0aCBhIHNsZWVrIGFuZCBzbW9vdGggYW5pbWF0aW9uLCBwcm92aWRpbmcgYSB2aXN1YWxseSBwbGVhc2luZ1xuICogdXNlciBleHBlcmllbmNlLlxuICovXG5leHBvcnQgY29uc3QgRXhwYW5kYWJsZSA9ICh7XG4gIGNoaWxkcmVuLFxuICBvcGVuZWQsXG4gIG1pbkhlaWdodCA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgYW5pbWF0aW9uRHVyYXRpb24gPSBBTklNQVRJT05fRFVSQVRJT04sXG59OiBFeHBhbmRhYmxlUHJvcHMpID0+IHtcbiAgY29uc3QgW2hlaWdodCwgc2V0SGVpZ2h0XSA9IHVzZVN0YXRlPG51bWJlciB8IG51bGw+KG51bGwpXG4gIGNvbnN0IHRyYW5zaXRpb25UaW1lciA9IHVzZVJlZjxSZXR1cm5UeXBlPHR5cGVvZiBzZXRUaW1lb3V0PiB8IHVuZGVmaW5lZD4oKVxuICBjb25zdCByZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gIGNvbnN0IHNob3VsZEJlQW5pbWF0ZWQgPSBhbmltYXRpb25EdXJhdGlvbiA+IDBcblxuICAvKipcbiAgICogQXQgbW91bnQsIHdlIHNldCB0aGUgaGVpZ2h0IHZhcmlhYmxlIHRvIHRoZSBoZWlnaHQgb2YgdGhlIGNvbnRlbnQgb25seSBpZiB0aGUgY29tcG9uZW50IGlzIGNsb3NlZC5cbiAgICogVGhpcyBpcyB0byBlbnN1cmUgd2UgZG9uJ3QgaGF2ZSBhbmltYXRpb24gd2hlbiB0aGUgY29tcG9uZW50IGlzIG9wZW5lZCBhdCBtb3VudC5cbiAgICovXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHJlZi5jdXJyZW50KSB7XG4gICAgICBzZXRIZWlnaHQocmVmLmN1cnJlbnQuc2Nyb2xsSGVpZ2h0ID8/IDApXG4gICAgfVxuICB9LCBbcmVmLmN1cnJlbnQ/LnNjcm9sbEhlaWdodF0pXG5cbiAgLyoqXG4gICAqIEhlcmUgd2Ugc2V0IG1heEhlaWdodCB0byB0aGUgaGVpZ2h0IG9mIHRoZSBjb250ZW50IHdoZW4gdGhlIGNvbXBvbmVudCBpcyBvcGVuZWRcbiAgICogYW5kIGFmdGVyIDMwMG1zIHdlIHNldCBtYXhIZWlnaHQgdG8gaW5pdGlhbCB0byBsZXQgdGhlIGNvbnRlbnQgZ3JvdyB3aXRoIGFuaW1hdGlvbi5cbiAgICogU2V0dGluZyBpdCB0byBpbml0aWFsIGlzIHJlcXVpcmVkIHRvIGJlIGFibGUgdG8gaGF2ZSBuZXN0ZWQgZXhwYW5kYWJsZSBvciB0aGUgaGVpZ2h0IHdvbid0IGZvbGxvdy5cbiAgICovXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKG9wZW5lZCAmJiByZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke2hlaWdodH1weGBcbiAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgaWYgKHNob3VsZEJlQW5pbWF0ZWQpIHtcbiAgICAgICAgdHJhbnNpdGlvblRpbWVyLmN1cnJlbnQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9ICdpbml0aWFsJ1xuICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUub3ZlcmZsb3cgPSAndmlzaWJsZSdcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgICAgIH1cbiAgICAgICAgfSwgQU5JTUFUSU9OX0RVUkFUSU9OKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gJ2luaXRpYWwnXG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm92ZXJmbG93ID0gJ3Zpc2libGUnXG4gICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnJ1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG5cbiAgICAgIGlmIChyZWYuY3VycmVudCAmJiBoZWlnaHQpIHtcbiAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7aGVpZ2h0fXB4YFxuICAgICAgICBpZiAoc2hvdWxkQmVBbmltYXRlZCkge1xuICAgICAgICAgIHRyYW5zaXRpb25UaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICAgICAgcmVmLmN1cnJlbnQuc3R5bGUubWF4SGVpZ2h0ID0gYCR7bWluSGVpZ2h0fXB4YFxuICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChyZWYuY3VycmVudCAmJiAhbWluSGVpZ2h0KSB7XG4gICAgICAgICAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ2hpZGRlbidcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH0sIEFOSU1BVElPTl9EVVJBVElPTilcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LCAwKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLm1heEhlaWdodCA9IGAke21pbkhlaWdodH1weGBcbiAgICAgICAgICByZWYuY3VycmVudC5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nXG4gICAgICAgICAgaWYgKCFtaW5IZWlnaHQpIHtcbiAgICAgICAgICAgIHJlZi5jdXJyZW50LnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJ1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBjbGVhclRpbWVvdXQodHJhbnNpdGlvblRpbWVyLmN1cnJlbnQpXG4gICAgfVxuICB9LCBbYW5pbWF0aW9uRHVyYXRpb24sIGhlaWdodCwgbWluSGVpZ2h0LCBvcGVuZWQsIHNob3VsZEJlQW5pbWF0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEV4cGFuZGFibGVcbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGFuaW1hdGlvbkR1cmF0aW9uPXthbmltYXRpb25EdXJhdGlvbn1cbiAgICAgIGRhdGEtaXMtYW5pbWF0ZWQ9e3Nob3VsZEJlQW5pbWF0ZWR9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkRXhwYW5kYWJsZT5cbiAgKVxufVxuIl19 */"));
17
17
  const Expandable = ({
18
18
  children,
19
19
  opened,
@@ -25,6 +25,7 @@ const Expandable = ({
25
25
  const [height, setHeight] = useState(null);
26
26
  const transitionTimer = useRef();
27
27
  const ref = useRef(null);
28
+ const shouldBeAnimated = animationDuration > 0;
28
29
  useEffect(() => {
29
30
  if (ref.current) {
30
31
  setHeight(ref.current.scrollHeight ?? 0);
@@ -34,35 +35,49 @@ const Expandable = ({
34
35
  if (opened && ref.current && height) {
35
36
  ref.current.style.maxHeight = `${height}px`;
36
37
  ref.current.style.visibility = "";
37
- transitionTimer.current = setTimeout(() => {
38
- if (ref.current) {
39
- ref.current.style.maxHeight = "initial";
40
- ref.current.style.overflow = "visible";
41
- ref.current.style.visibility = "";
42
- }
43
- }, ANIMATION_DURATION);
38
+ if (shouldBeAnimated) {
39
+ transitionTimer.current = setTimeout(() => {
40
+ if (ref.current) {
41
+ ref.current.style.maxHeight = "initial";
42
+ ref.current.style.overflow = "visible";
43
+ ref.current.style.visibility = "";
44
+ }
45
+ }, ANIMATION_DURATION);
46
+ } else {
47
+ ref.current.style.maxHeight = "initial";
48
+ ref.current.style.overflow = "visible";
49
+ ref.current.style.visibility = "";
50
+ }
44
51
  } else {
45
52
  clearTimeout(transitionTimer.current);
46
53
  if (ref.current && height) {
47
54
  ref.current.style.maxHeight = `${height}px`;
48
- transitionTimer.current = setTimeout(() => {
49
- if (ref.current) {
50
- ref.current.style.maxHeight = `${minHeight}px`;
51
- ref.current.style.overflow = "hidden";
52
- setTimeout(() => {
53
- if (ref.current && !minHeight) {
54
- ref.current.style.visibility = "hidden";
55
- }
56
- }, ANIMATION_DURATION);
55
+ if (shouldBeAnimated) {
56
+ transitionTimer.current = setTimeout(() => {
57
+ if (ref.current) {
58
+ ref.current.style.maxHeight = `${minHeight}px`;
59
+ ref.current.style.overflow = "hidden";
60
+ setTimeout(() => {
61
+ if (ref.current && !minHeight) {
62
+ ref.current.style.visibility = "hidden";
63
+ }
64
+ }, ANIMATION_DURATION);
65
+ }
66
+ }, 0);
67
+ } else {
68
+ ref.current.style.maxHeight = `${minHeight}px`;
69
+ ref.current.style.overflow = "hidden";
70
+ if (!minHeight) {
71
+ ref.current.style.visibility = "hidden";
57
72
  }
58
- }, 0);
73
+ }
59
74
  }
60
75
  }
61
76
  return () => {
62
77
  clearTimeout(transitionTimer.current);
63
78
  };
64
- }, [height, minHeight, opened]);
65
- return /* @__PURE__ */ jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, children });
79
+ }, [animationDuration, height, minHeight, opened, shouldBeAnimated]);
80
+ return /* @__PURE__ */ jsx(StyledExpandable, { "data-testid": dataTestId, ref, className, animationDuration, "data-is-animated": shouldBeAnimated, children });
66
81
  };
67
82
  export {
68
83
  Expandable,