UNPKG

@commercetools-uikit/calendar-utils

Version:

Utilities to work with values for a calendar.

212 lines (210 loc) • 152 kB
import _Number$isNaN from '@babel/runtime-corejs3/core-js-stable/number/is-nan'; import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice'; import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map'; import _Array$from from '@babel/runtime-corejs3/core-js-stable/array/from'; import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array'; import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort'; import moment from 'moment'; import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys'; import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols'; import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter'; import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor'; import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each'; import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors'; import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties'; import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property'; import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty'; import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray'; import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties'; import { useCallback, Component } from 'react'; import { ClockIcon, CalendarIcon, CloseIcon, AngleLeftIcon, CircleIcon, AngleRightIcon } from '@commercetools-uikit/icons'; import Inline from '@commercetools-uikit/spacings-inline'; import { useToggleState } from '@commercetools-uikit/hooks'; import AccessibleButton from '@commercetools-uikit/accessible-button'; import { css } from '@emotion/react'; import { designTokens } from '@commercetools-uikit/design-system'; import { getInputStyles } from '@commercetools-uikit/input-utils'; import { jsx, jsxs } from '@emotion/react/jsx-runtime'; import _styled from '@emotion/styled/base'; import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes'; import { defineMessages, useIntl } from 'react-intl'; import SecondaryIconButton from '@commercetools-uikit/secondary-icon-button'; import Text from '@commercetools-uikit/text'; import Tooltip from '@commercetools-uikit/tooltip'; import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct'; import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck'; import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass'; import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn'; import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf'; import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits'; const getDaysInMonth = day => moment(day).daysInMonth(); const getDateInMonth = day => moment(day).date(); const getToday = () => moment().format('YYYY-MM-DD'); const formatDate = (day, locale) => day ? moment(day, 'YYYY-MM-DD', locale).format('L') : ''; const changeMonth = (day, delta) => moment(day).add(delta, 'month').format('YYYY-MM-DD'); const getNextDay = day => moment(day).add(1, 'day').format('YYYY-MM-DD'); const getPreviousDay = day => moment(day).subtract(1, 'day').format('YYYY-MM-DD'); const getPaddingDayCount = (day, locale) => { const firstDayOfWeek = moment.localeData(locale).firstDayOfWeek(); const firstDayOfMonth = moment(day).startOf('month').day(); const paddingDayCount = (firstDayOfMonth - firstDayOfWeek + 7) % 7; return _Number$isNaN(paddingDayCount) ? 0 : paddingDayCount; }; const getWeekdayNames = locale => { const weekDays = moment.localeData(locale).weekdaysMin(); const firstDay = moment.localeData(locale).firstDayOfWeek(); return [..._sliceInstanceProperty(weekDays).call(weekDays, firstDay), ..._sliceInstanceProperty(weekDays).call(weekDays, 0, firstDay)]; }; const getMonthCalendarLabel = (day, locale) => moment(day, 'YYYY-MM-DD', locale).format('MMMM'); const getYearCalendarLabel = (day, locale) => moment(day, 'YYYY-MM-DD', locale).format('YYYY'); const isSameDay = (a, b) => moment(a).isSame(b, 'day'); const getCalendarDayLabel = day => moment(day).format('D'); const isBetween = (item, start, end) => { const itemDate = moment(item); const startDate = moment(start); const endDate = moment(end); return itemDate.isBetween(startDate, endDate) || itemDate.isBetween(endDate, startDate); }; const changeDateInMonth = (day, dayOfMonth) => moment(day).date(dayOfMonth).format('YYYY-MM-DD'); const createCalendarItems = day => { var _context; return _mapInstanceProperty(_context = _Array$from({ length: getDaysInMonth(day) })).call(_context, (_, i) => { const dayOfMonth = i + 1; const date = changeDateInMonth(day, dayOfMonth); return date; }); }; const createItemRangeToString = locale => item => _Array$isArray(item) ? _mapInstanceProperty(item).call(item, i => i ? formatDate(i, locale) : '').join(' - ') : formatDate(item, locale); const createItemToString = locale => item => item ? formatDate(item, locale) : ''; const formatRange = (range, locale) => { var _context2; return _mapInstanceProperty(_context2 = _sortInstanceProperty(range).call(range)).call(_context2, item => formatDate(item, locale)).join(' - '); }; const parseInputToDate = (text, locale) => { const localeDate = moment(text, moment.localeData(locale).longDateFormat('L'), locale); if (localeDate.isValid()) return localeDate.format('YYYY-MM-DD'); return ''; }; const getIsDateInRange = (item, min, max) => { const itemDate = moment(item); if (min && max) { return itemDate.isBetween(min, max, null, '[]'); } if (min && !max) { return itemDate.isSameOrAfter(min); } if (!min && max) { return itemDate.isSameOrBefore(max); } return true; }; const getExampleDateStrings = () => ({ currentDate: moment().format('YYYY-MM-DD'), preselectedDate: moment().add(3, 'days').format('YYYY-MM-DD'), minDate: moment().format('YYYY-MM-DD'), maxDate: moment().add(1, 'year').format('YYYY-MM-DD') }); function _EMOTION_STRINGIFIED_CSS_ERROR__$4() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } // NOTE: order is important here // * a disabled-field currently does not display warning/error-states so it takes precedence // * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first // how you can interact with the field is controlled separately by the props, this only influences visuals const getClearSectionStyles = () => { return /*#__PURE__*/css("align-items:center;box-sizing:border-box;display:flex;margin-right:", designTokens.spacing10, ";cursor:pointer;transition:color ", designTokens.transitionStandard, ",border-color ", designTokens.transitionStandard, ";& svg *:not([fill='none']){fill:", designTokens.colorNeutral40, ";}&:hover svg *{fill:", designTokens.colorError, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearSectionStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["calendar-body.styles.ts"],"names":[],"mappings":"AAUY","file":"calendar-body.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport type { TCalendarBody } from './calendar-body';\n\n// NOTE: order is important here\n// * a disabled-field currently does not display warning/error-states so it takes precedence\n// * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first\n// how you can interact with the field is controlled separately by the props, this only influences visuals\nconst getClearSectionStyles = () => {\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin-right: ${designTokens.spacing10};\n    cursor: pointer;\n    transition: color ${designTokens.transitionStandard},\n      border-color ${designTokens.transitionStandard};\n\n    & svg *:not([fill='none']) {\n      fill: ${designTokens.colorNeutral40};\n    }\n    &:hover svg * {\n      fill: ${designTokens.colorError};\n    }\n  `;\n};\n\ntype TState = {\n  isFocused?: boolean;\n};\n\nconst getIconBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getIconFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return 'initial';\n};\n\nconst getCalendarIconContainerStyles = (\n  props: TCalendarBody,\n  state: TState\n) => {\n  return [\n    css`\n      align-items: center;\n      box-sizing: border-box;\n      background: none;\n      border: 0;\n      border-top-right-radius: ${designTokens.borderRadiusForInput};\n      border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n      border-color: ${getIconBorderColor(props, state)};\n      color: ${getIconFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      height: 100%;\n      display: flex;\n      padding: ${designTokens.spacing10};\n      outline: 0;\n      transition: color ${designTokens.transitionStandard},\n        border-color ${designTokens.transitionStandard};\n      &:active,\n      &:hover:not(:disabled)&:not(:read-only),\n      &:focus {\n        border-color: ${props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n  ];\n};\n\nconst getInputBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getInputFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputContainerBackgroundColor = (props: TCalendarBody) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return designTokens.backgroundColorForInput;\n};\n\nconst getInputContainerStyles = (props: TCalendarBody, state: TState) => {\n  return [\n    css`\n      appearance: none;\n      background-color: ${getInputContainerBackgroundColor(props)};\n      border: 1px solid ${getInputBorderColor(props, state)};\n      border-radius: ${designTokens.borderRadiusForInput};\n      box-sizing: border-box;\n      color: ${getInputFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      width: 100%;\n      height: ${props.isCondensed\n        ? `${designTokens.heightForInputAsSmall}`\n        : `${designTokens.heightForInput}`};\n      align-items: center;\n      display: flex;\n      font-size: ${designTokens.fontSize30};\n      font-family: inherit;\n      min-width: ${designTokens.constraint5};\n      transition: border-color ${designTokens.transitionStandard},\n        box-shadow ${designTokens.transitionStandard};\n\n      &:hover:not(:focus) {\n        background-color: ${!props.isDisabled && !props.isReadOnly\n          ? props.appearance === 'filter'\n            ? designTokens.colorTransparent\n            : designTokens.backgroundColorForInputWhenHovered\n          : null};\n      }\n      &:focus {\n        border-color: ${props.isDisabled ||\n        props.hasError ||\n        props.hasWarning ||\n        props.isReadOnly ||\n        ((props.isOpen || state.isFocused) && !props.isReadOnly)\n          ? ''\n          : props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n    !props.isReadOnly &&\n      props.appearance !== 'filter' &&\n      css`\n        &:focus-within {\n          border-color: ${designTokens.borderColorForInputWhenFocused};\n          box-shadow: inset 0 0 0 1px\n            ${designTokens.borderColorForInputWhenFocused};\n          &:hover {\n            background-color: ${designTokens.colorSurface};\n          }\n        }\n      `,\n    (props.hasError || props.hasWarning) &&\n      props.appearance !== 'filter' &&\n      css`\n        box-shadow: inset 0 0 0 1px;\n      `,\n  ];\n};\n\nconst getDateTimeInputStyles = (props: TCalendarBody) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none !important;\n      &,\n      &:focus:not(:read-only) {\n        box-shadow: none;\n      }\n      font-size: ${props.isCondensed\n        ? `${designTokens.fontSize20}`\n        : `${designTokens.fontSize30}`};\n    `,\n  ];\n  return baseStyles;\n};\n\nexport {\n  getClearSectionStyles,\n  getInputContainerStyles,\n  getDateTimeInputStyles,\n  getCalendarIconContainerStyles,\n};\n"]} */"); }; const getIconBorderColor = (props, state) => { if (props.appearance === 'filter') { return designTokens.colorTransparent; } if (props.isDisabled) { return designTokens.borderColorForInputWhenDisabled; } if (props.hasError) { return designTokens.borderColorForInputWhenError; } if (props.hasWarning) { return designTokens.borderColorForInputWhenWarning; } if (props.isReadOnly) { return designTokens.borderColorForInputWhenReadonly; } if (props.isOpen || state.isFocused) { return designTokens.borderColorForInputWhenFocused; } return designTokens.borderColorForInput; }; const getIconFontColor = props => { if (props.isDisabled) { return designTokens.fontColorForInputWhenDisabled; } if (props.hasError) { return designTokens.fontColorForInputWhenError; } if (props.hasWarning) { return designTokens.fontColorForInputWhenWarning; } if (props.isReadOnly) { return designTokens.fontColorForInputWhenReadonly; } return 'initial'; }; const getCalendarIconContainerStyles = (props, state) => { return [/*#__PURE__*/css("align-items:center;box-sizing:border-box;background:none;border:0;border-top-right-radius:", designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designTokens.borderRadiusForInput, ";border-color:", getIconBorderColor(props, state), ";color:", getIconFontColor(props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";height:100%;display:flex;padding:", designTokens.spacing10, ";outline:0;transition:color ", designTokens.transitionStandard, ",border-color ", designTokens.transitionStandard, ";&:active,&:hover:not(:disabled)&:not(:read-only),&:focus{border-color:", props.appearance === 'filter' ? designTokens.colorTransparent : designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getCalendarIconContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["calendar-body.styles.ts"],"names":[],"mappings":"AA2EO","file":"calendar-body.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport type { TCalendarBody } from './calendar-body';\n\n// NOTE: order is important here\n// * a disabled-field currently does not display warning/error-states so it takes precedence\n// * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first\n// how you can interact with the field is controlled separately by the props, this only influences visuals\nconst getClearSectionStyles = () => {\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin-right: ${designTokens.spacing10};\n    cursor: pointer;\n    transition: color ${designTokens.transitionStandard},\n      border-color ${designTokens.transitionStandard};\n\n    & svg *:not([fill='none']) {\n      fill: ${designTokens.colorNeutral40};\n    }\n    &:hover svg * {\n      fill: ${designTokens.colorError};\n    }\n  `;\n};\n\ntype TState = {\n  isFocused?: boolean;\n};\n\nconst getIconBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getIconFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return 'initial';\n};\n\nconst getCalendarIconContainerStyles = (\n  props: TCalendarBody,\n  state: TState\n) => {\n  return [\n    css`\n      align-items: center;\n      box-sizing: border-box;\n      background: none;\n      border: 0;\n      border-top-right-radius: ${designTokens.borderRadiusForInput};\n      border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n      border-color: ${getIconBorderColor(props, state)};\n      color: ${getIconFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      height: 100%;\n      display: flex;\n      padding: ${designTokens.spacing10};\n      outline: 0;\n      transition: color ${designTokens.transitionStandard},\n        border-color ${designTokens.transitionStandard};\n      &:active,\n      &:hover:not(:disabled)&:not(:read-only),\n      &:focus {\n        border-color: ${props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n  ];\n};\n\nconst getInputBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getInputFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputContainerBackgroundColor = (props: TCalendarBody) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return designTokens.backgroundColorForInput;\n};\n\nconst getInputContainerStyles = (props: TCalendarBody, state: TState) => {\n  return [\n    css`\n      appearance: none;\n      background-color: ${getInputContainerBackgroundColor(props)};\n      border: 1px solid ${getInputBorderColor(props, state)};\n      border-radius: ${designTokens.borderRadiusForInput};\n      box-sizing: border-box;\n      color: ${getInputFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      width: 100%;\n      height: ${props.isCondensed\n        ? `${designTokens.heightForInputAsSmall}`\n        : `${designTokens.heightForInput}`};\n      align-items: center;\n      display: flex;\n      font-size: ${designTokens.fontSize30};\n      font-family: inherit;\n      min-width: ${designTokens.constraint5};\n      transition: border-color ${designTokens.transitionStandard},\n        box-shadow ${designTokens.transitionStandard};\n\n      &:hover:not(:focus) {\n        background-color: ${!props.isDisabled && !props.isReadOnly\n          ? props.appearance === 'filter'\n            ? designTokens.colorTransparent\n            : designTokens.backgroundColorForInputWhenHovered\n          : null};\n      }\n      &:focus {\n        border-color: ${props.isDisabled ||\n        props.hasError ||\n        props.hasWarning ||\n        props.isReadOnly ||\n        ((props.isOpen || state.isFocused) && !props.isReadOnly)\n          ? ''\n          : props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n    !props.isReadOnly &&\n      props.appearance !== 'filter' &&\n      css`\n        &:focus-within {\n          border-color: ${designTokens.borderColorForInputWhenFocused};\n          box-shadow: inset 0 0 0 1px\n            ${designTokens.borderColorForInputWhenFocused};\n          &:hover {\n            background-color: ${designTokens.colorSurface};\n          }\n        }\n      `,\n    (props.hasError || props.hasWarning) &&\n      props.appearance !== 'filter' &&\n      css`\n        box-shadow: inset 0 0 0 1px;\n      `,\n  ];\n};\n\nconst getDateTimeInputStyles = (props: TCalendarBody) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none !important;\n      &,\n      &:focus:not(:read-only) {\n        box-shadow: none;\n      }\n      font-size: ${props.isCondensed\n        ? `${designTokens.fontSize20}`\n        : `${designTokens.fontSize30}`};\n    `,\n  ];\n  return baseStyles;\n};\n\nexport {\n  getClearSectionStyles,\n  getInputContainerStyles,\n  getDateTimeInputStyles,\n  getCalendarIconContainerStyles,\n};\n"]} */")]; }; const getInputBorderColor = (props, state) => { if (props.isDisabled) { return designTokens.borderColorForInputWhenDisabled; } if (props.hasError) { return designTokens.borderColorForInputWhenError; } if (props.hasWarning) { return designTokens.borderColorForInputWhenWarning; } if (props.isReadOnly) { return designTokens.borderColorForInputWhenReadonly; } if (props.isOpen || state.isFocused) { return designTokens.borderColorForInputWhenFocused; } return designTokens.borderColorForInput; }; const getInputFontColor = props => { if (props.isDisabled) { return designTokens.fontColorForInputWhenDisabled; } if (props.hasError) { return designTokens.fontColorForInputWhenError; } if (props.hasWarning) { return designTokens.fontColorForInputWhenWarning; } if (props.isReadOnly) { return designTokens.fontColorForInputWhenReadonly; } return designTokens.fontColorForInput; }; const getInputContainerBackgroundColor = props => { if (props.appearance === 'filter') { return designTokens.colorTransparent; } if (props.isDisabled) { return designTokens.backgroundColorForInputWhenDisabled; } if (props.isReadOnly) { return designTokens.backgroundColorForInputWhenReadonly; } return designTokens.backgroundColorForInput; }; var _ref$2 = process.env.NODE_ENV === "production" ? { name: "64hrqb", styles: "box-shadow:inset 0 0 0 1px" } : { name: "ivtyg-getInputContainerStyles", styles: "box-shadow:inset 0 0 0 1px;label:getInputContainerStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["calendar-body.styles.ts"],"names":[],"mappings":"AA6MS","file":"calendar-body.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport type { TCalendarBody } from './calendar-body';\n\n// NOTE: order is important here\n// * a disabled-field currently does not display warning/error-states so it takes precedence\n// * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first\n// how you can interact with the field is controlled separately by the props, this only influences visuals\nconst getClearSectionStyles = () => {\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin-right: ${designTokens.spacing10};\n    cursor: pointer;\n    transition: color ${designTokens.transitionStandard},\n      border-color ${designTokens.transitionStandard};\n\n    & svg *:not([fill='none']) {\n      fill: ${designTokens.colorNeutral40};\n    }\n    &:hover svg * {\n      fill: ${designTokens.colorError};\n    }\n  `;\n};\n\ntype TState = {\n  isFocused?: boolean;\n};\n\nconst getIconBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getIconFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return 'initial';\n};\n\nconst getCalendarIconContainerStyles = (\n  props: TCalendarBody,\n  state: TState\n) => {\n  return [\n    css`\n      align-items: center;\n      box-sizing: border-box;\n      background: none;\n      border: 0;\n      border-top-right-radius: ${designTokens.borderRadiusForInput};\n      border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n      border-color: ${getIconBorderColor(props, state)};\n      color: ${getIconFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      height: 100%;\n      display: flex;\n      padding: ${designTokens.spacing10};\n      outline: 0;\n      transition: color ${designTokens.transitionStandard},\n        border-color ${designTokens.transitionStandard};\n      &:active,\n      &:hover:not(:disabled)&:not(:read-only),\n      &:focus {\n        border-color: ${props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n  ];\n};\n\nconst getInputBorderColor = (props: TCalendarBody, state: TState) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.isOpen || state.isFocused) {\n    return designTokens.borderColorForInputWhenFocused;\n  }\n  return designTokens.borderColorForInput;\n};\n\nconst getInputFontColor = (props: TCalendarBody) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputContainerBackgroundColor = (props: TCalendarBody) => {\n  if (props.appearance === 'filter') {\n    return designTokens.colorTransparent;\n  }\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return designTokens.backgroundColorForInput;\n};\n\nconst getInputContainerStyles = (props: TCalendarBody, state: TState) => {\n  return [\n    css`\n      appearance: none;\n      background-color: ${getInputContainerBackgroundColor(props)};\n      border: 1px solid ${getInputBorderColor(props, state)};\n      border-radius: ${designTokens.borderRadiusForInput};\n      box-sizing: border-box;\n      color: ${getInputFontColor(props)};\n      cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n      width: 100%;\n      height: ${props.isCondensed\n        ? `${designTokens.heightForInputAsSmall}`\n        : `${designTokens.heightForInput}`};\n      align-items: center;\n      display: flex;\n      font-size: ${designTokens.fontSize30};\n      font-family: inherit;\n      min-width: ${designTokens.constraint5};\n      transition: border-color ${designTokens.transitionStandard},\n        box-shadow ${designTokens.transitionStandard};\n\n      &:hover:not(:focus) {\n        background-color: ${!props.isDisabled && !props.isReadOnly\n          ? props.appearance === 'filter'\n            ? designTokens.colorTransparent\n            : designTokens.backgroundColorForInputWhenHovered\n          : null};\n      }\n      &:focus {\n        border-color: ${props.isDisabled ||\n        props.hasError ||\n        props.hasWarning ||\n        props.isReadOnly ||\n        ((props.isOpen || state.isFocused) && !props.isReadOnly)\n          ? ''\n          : props.appearance === 'filter'\n          ? designTokens.colorTransparent\n          : designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n    !props.isReadOnly &&\n      props.appearance !== 'filter' &&\n      css`\n        &:focus-within {\n          border-color: ${designTokens.borderColorForInputWhenFocused};\n          box-shadow: inset 0 0 0 1px\n            ${designTokens.borderColorForInputWhenFocused};\n          &:hover {\n            background-color: ${designTokens.colorSurface};\n          }\n        }\n      `,\n    (props.hasError || props.hasWarning) &&\n      props.appearance !== 'filter' &&\n      css`\n        box-shadow: inset 0 0 0 1px;\n      `,\n  ];\n};\n\nconst getDateTimeInputStyles = (props: TCalendarBody) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none !important;\n      &,\n      &:focus:not(:read-only) {\n        box-shadow: none;\n      }\n      font-size: ${props.isCondensed\n        ? `${designTokens.fontSize20}`\n        : `${designTokens.fontSize30}`};\n    `,\n  ];\n  return baseStyles;\n};\n\nexport {\n  getClearSectionStyles,\n  getInputContainerStyles,\n  getDateTimeInputStyles,\n  getCalendarIconContainerStyles,\n};\n"]} */", toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4 }; const getInputContainerStyles = (props, state) => { return [/*#__PURE__*/css("appearance:none;background-color:", getInputContainerBackgroundColor(props), ";border:1px solid ", getInputBorderColor(props, state), ";border-radius:", designTokens.borderRadiusForInput, ";box-sizing:border-box;color:", getInputFontColor(props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";width:100%;height:", props.isCondensed ? `${designTokens.heightForInputAsSmall}` : `${designTokens.heightForInput}`, ";align-items:center;display:flex;font-size:", designTokens.fontSize30, ";font-family:inherit;min-width:", designTokens.constraint5, ";transition:border-color ", designTokens.transitionStandard, ",box-shadow ", designTokens.transitionStandard, ";&:hover:not(:focus){background-color:", !props.isDisabled && !props.isReadOnly ? props.appearance === 'filter' ? designTokens.colorTransparent : designTokens.backgroundColorForInputWhenHovered : null, ";}&:focus{border-color:", props.isDisabled || props.hasError || props.hasWarning || props.isReadOnly || (props.isOpen || state.isFocused) && !props.isReadOnly ? '' : props.appearance === 'filter' ? designTokens.colorTransparent : designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNhbGVuZGFyLWJvZHkuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdKTyIsImZpbGUiOiJjYWxlbmRhci1ib2R5LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgZ2V0SW5wdXRTdHlsZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pbnB1dC11dGlscyc7XG5pbXBvcnQgdHlwZSB7IFRDYWxlbmRhckJvZHkgfSBmcm9tICcuL2NhbGVuZGFyLWJvZHknO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0Q2xlYXJTZWN0aW9uU3R5bGVzID0gKCkgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIG1hcmdpbi1yaWdodDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdHJhbnNpdGlvbjogY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJvcmRlci1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuXG4gICAgJiBzdmcgKjpub3QoW2ZpbGw9J25vbmUnXSkge1xuICAgICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICAgIH1cbiAgICAmOmhvdmVyIHN2ZyAqIHtcbiAgICAgIGZpbGw6ICR7ZGVzaWduVG9rZW5zLmNvbG9yRXJyb3J9O1xuICAgIH1cbiAgYDtcbn07XG5cbnR5cGUgVFN0YXRlID0ge1xuICBpc0ZvY3VzZWQ/OiBib29sZWFuO1xufTtcblxuY29uc3QgZ2V0SWNvbkJvcmRlckNvbG9yID0gKHByb3BzOiBUQ2FsZW5kYXJCb2R5LCBzdGF0ZTogVFN0YXRlKSA9PiB7XG4gIGlmIChwcm9wcy5hcHBlYXJhbmNlID09PSAnZmlsdGVyJykge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuY29sb3JUcmFuc3BhcmVudDtcbiAgfVxuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRXJyb3I7XG4gIH1cbiAgaWYgKHByb3BzLmhhc1dhcm5pbmcpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuV2FybmluZztcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5SZWFkb25seTtcbiAgfVxuICBpZiAocHJvcHMuaXNPcGVuIHx8IHN0YXRlLmlzRm9jdXNlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5Gb2N1c2VkO1xuICB9XG4gIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dDtcbn07XG5cbmNvbnN0IGdldEljb25Gb250Q29sb3IgPSAocHJvcHM6IFRDYWxlbmRhckJvZHkpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIGlmIChwcm9wcy5oYXNFcnJvcikge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRXJyb3I7XG4gIH1cbiAgaWYgKHByb3BzLmhhc1dhcm5pbmcpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbldhcm5pbmc7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlblJlYWRvbmx5O1xuICB9XG4gIHJldHVybiAnaW5pdGlhbCc7XG59O1xuXG5jb25zdCBnZXRDYWxlbmRhckljb25Db250YWluZXJTdHlsZXMgPSAoXG4gIHByb3BzOiBUQ2FsZW5kYXJCb2R5LFxuICBzdGF0ZTogVFN0YXRlXG4pID0+IHtcbiAgcmV0dXJuIFtcbiAgICBjc3NgXG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgICBib3JkZXI6IDA7XG4gICAgICBib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgICAgYm9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRJY29uQm9yZGVyQ29sb3IocHJvcHMsIHN0YXRlKX07XG4gICAgICBjb2xvcjogJHtnZXRJY29uRm9udENvbG9yKHByb3BzKX07XG4gICAgICBjdXJzb3I6ICR7cHJvcHMuaXNEaXNhYmxlZCA/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgICAgaGVpZ2h0OiAxMDAlO1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gICAgICBvdXRsaW5lOiAwO1xuICAgICAgdHJhbnNpdGlvbjogY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgICAgYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgICAmOmFjdGl2ZSxcbiAgICAgICY6aG92ZXI6bm90KDpkaXNhYmxlZCkmOm5vdCg6cmVhZC1vbmx5KSxcbiAgICAgICY6Zm9jdXMge1xuICAgICAgICBib3JkZXItY29sb3I6ICR7cHJvcHMuYXBwZWFyYW5jZSA9PT0gJ2ZpbHRlcidcbiAgICAgICAgICA/IGRlc2lnblRva2Vucy5jb2xvclRyYW5zcGFyZW50XG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5Gb2N1c2VkfTtcbiAgICAgIH1cbiAgICBgLFxuICBdO1xufTtcblxuY29uc3QgZ2V0SW5wdXRCb3JkZXJDb2xvciA9IChwcm9wczogVENhbGVuZGFyQm9keSwgc3RhdGU6IFRTdGF0ZSkgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRXJyb3I7XG4gIH1cbiAgaWYgKHByb3BzLmhhc1dhcm5pbmcpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuV2FybmluZztcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5SZWFkb25seTtcbiAgfVxuICBpZiAocHJvcHMuaXNPcGVuIHx8IHN0YXRlLmlzRm9jdXNlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5Gb2N1c2VkO1xuICB9XG4gIHJldHVybiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dDtcbn07XG5cbmNvbnN0IGdldElucHV0Rm9udENvbG9yID0gKHByb3BzOiBUQ2FsZW5kYXJCb2R5KSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkVycm9yO1xuICB9XG4gIGlmIChwcm9wcy5oYXNXYXJuaW5nKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5XYXJuaW5nO1xuICB9XG4gIGlmIChwcm9wcy5pc1JlYWRPbmx5KSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0O1xufTtcblxuY29uc3QgZ2V0SW5wdXRDb250YWluZXJCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRDYWxlbmRhckJvZHkpID0+IHtcbiAgaWYgKHByb3BzLmFwcGVhcmFuY2UgPT09ICdmaWx0ZXInKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5jb2xvclRyYW5zcGFyZW50O1xuICB9XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuUmVhZG9ubHk7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dDtcbn07XG5cbmNvbnN0IGdldElucHV0Q29udGFpbmVyU3R5bGVzID0gKHByb3BzOiBUQ2FsZW5kYXJCb2R5LCBzdGF0ZTogVFN0YXRlKSA9PiB7XG4gIHJldHVybiBbXG4gICAgY3NzYFxuICAgICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0SW5wdXRDb250YWluZXJCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7Z2V0SW5wdXRCb3JkZXJDb2xvcihwcm9wcywgc3RhdGUpfTtcbiAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgICBjb2xvcjogJHtnZXRJbnB1dEZvbnRDb2xvcihwcm9wcyl9O1xuICAgICAgY3Vyc29yOiAke3Byb3BzLmlzRGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ2RlZmF1bHQnfTtcbiAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgaGVpZ2h0OiAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgID8gYCR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbH1gXG4gICAgICAgIDogYCR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fWB9O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMzB9O1xuICAgICAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gICAgICBtaW4td2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN