@commercetools-uikit/calendar-utils
Version:
Utilities to work with values for a calendar.
242 lines (236 loc) • 158 kB
JavaScript
'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