UNPKG

@commercetools-uikit/calendar-utils

Version:

Utilities to work with values for a calendar.

242 lines (236 loc) • 158 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _Number$isNaN = require('@babel/runtime-corejs3/core-js-stable/number/is-nan'); var _sliceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/slice'); var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map'); var _Array$from = require('@babel/runtime-corejs3/core-js-stable/array/from'); var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array'); var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort'); var moment = require('moment'); var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys'); var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols'); var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter'); var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor'); var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each'); var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors'); var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties'); var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property'); var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty'); var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray'); var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties'); var react$1 = require('react'); var icons = require('@commercetools-uikit/icons'); var Inline = require('@commercetools-uikit/spacings-inline'); var hooks = require('@commercetools-uikit/hooks'); var AccessibleButton = require('@commercetools-uikit/accessible-button'); var react = require('@emotion/react'); var designSystem = require('@commercetools-uikit/design-system'); var inputUtils = require('@commercetools-uikit/input-utils'); var jsxRuntime = require('@emotion/react/jsx-runtime'); var _styled = require('@emotion/styled/base'); var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes'); var reactIntl = require('react-intl'); var SecondaryIconButton = require('@commercetools-uikit/secondary-icon-button'); var Text = require('@commercetools-uikit/text'); var Tooltip = require('@commercetools-uikit/tooltip'); var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct'); var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck'); var _createClass = require('@babel/runtime-corejs3/helpers/createClass'); var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn'); var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf'); var _inherits = require('@babel/runtime-corejs3/helpers/inherits'); function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; } var _Number$isNaN__default = /*#__PURE__*/_interopDefault(_Number$isNaN); var _sliceInstanceProperty__default = /*#__PURE__*/_interopDefault(_sliceInstanceProperty); var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty); var _Array$from__default = /*#__PURE__*/_interopDefault(_Array$from); var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray); var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty); var moment__default = /*#__PURE__*/_interopDefault(moment); var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys); var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols); var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty); var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor); var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty); var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors); var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties); var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty); var Inline__default = /*#__PURE__*/_interopDefault(Inline); var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton); var _styled__default = /*#__PURE__*/_interopDefault(_styled); var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty); var SecondaryIconButton__default = /*#__PURE__*/_interopDefault(SecondaryIconButton); var Text__default = /*#__PURE__*/_interopDefault(Text); var Tooltip__default = /*#__PURE__*/_interopDefault(Tooltip); var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct); const getDaysInMonth = day => moment__default["default"](day).daysInMonth(); const getDateInMonth = day => moment__default["default"](day).date(); const getToday = () => moment__default["default"]().format('YYYY-MM-DD'); const formatDate = (day, locale) => day ? moment__default["default"](day, 'YYYY-MM-DD', locale).format('L') : ''; const changeMonth = (day, delta) => moment__default["default"](day).add(delta, 'month').format('YYYY-MM-DD'); const getNextDay = day => moment__default["default"](day).add(1, 'day').format('YYYY-MM-DD'); const getPreviousDay = day => moment__default["default"](day).subtract(1, 'day').format('YYYY-MM-DD'); const getPaddingDayCount = (day, locale) => { const firstDayOfWeek = moment__default["default"].localeData(locale).firstDayOfWeek(); const firstDayOfMonth = moment__default["default"](day).startOf('month').day(); const paddingDayCount = (firstDayOfMonth - firstDayOfWeek + 7) % 7; return _Number$isNaN__default["default"](paddingDayCount) ? 0 : paddingDayCount; }; const getWeekdayNames = locale => { const weekDays = moment__default["default"].localeData(locale).weekdaysMin(); const firstDay = moment__default["default"].localeData(locale).firstDayOfWeek(); return [..._sliceInstanceProperty__default["default"](weekDays).call(weekDays, firstDay), ..._sliceInstanceProperty__default["default"](weekDays).call(weekDays, 0, firstDay)]; }; const getMonthCalendarLabel = (day, locale) => moment__default["default"](day, 'YYYY-MM-DD', locale).format('MMMM'); const getYearCalendarLabel = (day, locale) => moment__default["default"](day, 'YYYY-MM-DD', locale).format('YYYY'); const isSameDay = (a, b) => moment__default["default"](a).isSame(b, 'day'); const getCalendarDayLabel = day => moment__default["default"](day).format('D'); const isBetween = (item, start, end) => { const itemDate = moment__default["default"](item); const startDate = moment__default["default"](start); const endDate = moment__default["default"](end); return itemDate.isBetween(startDate, endDate) || itemDate.isBetween(endDate, startDate); }; const changeDateInMonth = (day, dayOfMonth) => moment__default["default"](day).date(dayOfMonth).format('YYYY-MM-DD'); const createCalendarItems = day => { var _context; return _mapInstanceProperty__default["default"](_context = _Array$from__default["default"]({ length: getDaysInMonth(day) })).call(_context, (_, i) => { const dayOfMonth = i + 1; const date = changeDateInMonth(day, dayOfMonth); return date; }); }; const createItemRangeToString = locale => item => _Array$isArray__default["default"](item) ? _mapInstanceProperty__default["default"](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__default["default"](_context2 = _sortInstanceProperty__default["default"](range).call(range)).call(_context2, item => formatDate(item, locale)).join(' - '); }; const parseInputToDate = (text, locale) => { const localeDate = moment__default["default"](text, moment__default["default"].localeData(locale).longDateFormat('L'), locale); if (localeDate.isValid()) return localeDate.format('YYYY-MM-DD'); return ''; }; const getIsDateInRange = (item, min, max) => { const itemDate = moment__default["default"](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__default["default"]().format('YYYY-MM-DD'), preselectedDate: moment__default["default"]().add(3, 'days').format('YYYY-MM-DD'), minDate: moment__default["default"]().format('YYYY-MM-DD'), maxDate: moment__default["default"]().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__*/react.css("align-items:center;box-sizing:border-box;display:flex;margin-right:", designSystem.designTokens.spacing10, ";cursor:pointer;transition:color ", designSystem.designTokens.transitionStandard, ",border-color ", designSystem.designTokens.transitionStandard, ";& svg *:not([fill='none']){fill:", designSystem.designTokens.colorNeutral40, ";}&:hover svg *{fill:", designSystem.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 designSystem.designTokens.colorTransparent; } if (props.isDisabled) { return designSystem.designTokens.borderColorForInputWhenDisabled; } if (props.hasError) { return designSystem.designTokens.borderColorForInputWhenError; } if (props.hasWarning) { return designSystem.designTokens.borderColorForInputWhenWarning; } if (props.isReadOnly) { return designSystem.designTokens.borderColorForInputWhenReadonly; } if (props.isOpen || state.isFocused) { return designSystem.designTokens.borderColorForInputWhenFocused; } return designSystem.designTokens.borderColorForInput; }; const getIconFontColor = props => { if (props.isDisabled) { return designSystem.designTokens.fontColorForInputWhenDisabled; } if (props.hasError) { return designSystem.designTokens.fontColorForInputWhenError; } if (props.hasWarning) { return designSystem.designTokens.fontColorForInputWhenWarning; } if (props.isReadOnly) { return designSystem.designTokens.fontColorForInputWhenReadonly; } return 'initial'; }; const getCalendarIconContainerStyles = (props, state) => { return [/*#__PURE__*/react.css("align-items:center;box-sizing:border-box;background:none;border:0;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-color:", getIconBorderColor(props, state), ";color:", getIconFontColor(props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";height:100%;display:flex;padding:", designSystem.designTokens.spacing10, ";outline:0;transition:color ", designSystem.designTokens.transitionStandard, ",border-color ", designSystem.designTokens.transitionStandard, ";&:active,&:hover:not(:disabled)&:not(:read-only),&:focus{border-color:", props.appearance === 'filter' ? designSystem.designTokens.colorTransparent : designSystem.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 designSystem.designTokens.borderColorForInputWhenDisabled; } if (props.hasError) { return designSystem.designTokens.borderColorForInputWhenError; } if (props.hasWarning) { return designSystem.designTokens.borderColorForInputWhenWarning; } if (props.isReadOnly) { return designSystem.designTokens.borderColorForInputWhenReadonly; } if (props.isOpen || state.isFocused) { return designSystem.designTokens.borderColorForInputWhenFocused; } return designSystem.designTokens.borderColorForInput; }; const getInputFontColor = props => { if (props.isDisabled) { return designSystem.designTokens.fontColorForInputWhenDisabled; } if (props.hasError) { return designSystem.designTokens.fontColorForInputWhenError; } if (props.hasWarning) { return designSystem.designTokens.fontColorForInputWhenWarning; } if (props.isReadOnly) { return designSystem.designTokens.fontColorForInputWhenReadonly; } return designSystem.designTokens.fontColorForInput; }; const getInputContainerBackgroundColor = props => { if (props.appearance === 'filter') { return designSystem.designTokens.colorTransparent; } if (props.isDisabled) { return designSystem.designTokens.backgroundColorForInputWhenDisabled; } if (props.isReadOnly) { return designSystem.designTokens.backgroundColorForInputWhenReadonly; } return designSystem.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__*/react.css("appearance:none;background-color:", getInputContainerBackgroundColor(props), ";border:1px solid ", getInputBorderColor(props, state), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-sizing:border-box;color:", getInputFontColor(props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";width:100%;height:", props.isCondensed ? `${designSystem.designTokens.heightForInputAsSmall}` : `${designSystem.designTokens.heightForInput}`, ";align-items:center;display:flex;font-size:", designSystem.designTokens.fontSize30, ";font-family:inherit;min-width:", designSystem.designTokens.constraint5, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";&:hover:not(:focus){background-color:", !props.isDisabled && !props.isReadOnly ? props.appearance === 'filter' ? designSystem.designTokens.colorTransparent : designSystem.designTokens.backgroundColorForInputWhenHovered : null, ";}&:focus{border-color:", props.isDisabled || props.hasError || props.hasWarning || props.isReadOnly || (props.isOpen || state.isFocused) && !props.isReadOnly ? '' : props.appearance === 'filter' ? designSystem.designTokens.colorTransparent : designSystem.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/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgICAgaGVpZ2h0OiAxMDAlO1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gICAgICBvdXRsaW5lOiAwO1xuICAgICAgdHJhbnNpdGlvbjogY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGl