@commercetools-uikit/time-input 12.2.7 → 13.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +23 -15
- package/dist/commercetools-uikit-time-input.cjs.d.ts +2 -0
- package/dist/commercetools-uikit-time-input.cjs.dev.js +45 -116
- package/dist/commercetools-uikit-time-input.cjs.prod.js +17 -18
- package/dist/commercetools-uikit-time-input.esm.js +44 -115
- package/dist/declarations/src/index.d.ts +2 -0
- package/dist/declarations/src/messages.d.ts +8 -0
- package/dist/declarations/src/time-input-body.d.ts +20 -0
- package/dist/declarations/src/time-input-body.styles.d.ts +16 -0
- package/dist/declarations/src/time-input.d.ts +33 -0
- package/dist/declarations/src/version.d.ts +2 -0
- package/package.json +14 -14
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
2
|
+
import _pt from 'prop-types';
|
|
2
3
|
import _padStartInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/pad-start';
|
|
3
4
|
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
4
5
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
@@ -10,7 +11,6 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
|
|
|
10
11
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
11
12
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
12
13
|
import { useCallback } from 'react';
|
|
13
|
-
import PropTypes from 'prop-types';
|
|
14
14
|
import { defineMessages, useIntl } from 'react-intl';
|
|
15
15
|
import Constraints from '@commercetools-uikit/constraints';
|
|
16
16
|
import { filterDataAttributes, createSequentialId, parseTime } from '@commercetools-uikit/utils';
|
|
@@ -24,19 +24,20 @@ import { customProperties } from '@commercetools-uikit/design-system';
|
|
|
24
24
|
import { getInputStyles } from '@commercetools-uikit/input-utils';
|
|
25
25
|
import { jsx, jsxs } from '@emotion/react/jsx-runtime';
|
|
26
26
|
|
|
27
|
-
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object);
|
|
27
|
+
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
28
28
|
|
|
29
|
-
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
29
|
+
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
30
30
|
|
|
31
31
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { 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)."; }
|
|
32
|
+
|
|
33
|
+
// NOTE: order is important here
|
|
32
34
|
// * a disabled-field currently does not display warning/error-states so it takes precedence
|
|
33
35
|
// * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first
|
|
34
36
|
// how you can interact with the field is controlled separately by the props, this only influences visuals
|
|
35
|
-
|
|
36
37
|
var getClearSectionStyles = function getClearSectionStyles(theme) {
|
|
37
38
|
var overwrittenVars = _objectSpread$2(_objectSpread$2({}, customProperties), theme);
|
|
38
39
|
|
|
39
|
-
return /*#__PURE__*/css("align-items:center;box-sizing:border-box;display:flex;margin:", overwrittenVars.spacingXs, ";cursor:pointer;&:hover svg *{fill:", overwrittenVars.colorWarning, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearSectionStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
40
|
+
return /*#__PURE__*/css("align-items:center;box-sizing:border-box;display:flex;margin:", overwrittenVars.spacingXs, ";cursor:pointer;&:hover svg *{fill:", overwrittenVars.colorWarning, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearSectionStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AAgBY","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */");
|
|
40
41
|
};
|
|
41
42
|
|
|
42
43
|
var getClockIconContainerColor = function getClockIconContainerColor(vars, props) {
|
|
@@ -74,7 +75,7 @@ var getClockIconContainerFontColor = function getClockIconContainerFontColor(var
|
|
|
74
75
|
var getClockIconContainerStyles = function getClockIconContainerStyles(props, theme) {
|
|
75
76
|
var overwrittenVars = _objectSpread$2(_objectSpread$2({}, customProperties), theme);
|
|
76
77
|
|
|
77
|
-
return /*#__PURE__*/css("align-items:center;box-sizing:border-box;background:none;background-color:", props.isDisabled ? overwrittenVars.backgroundColorForInputWhenDisabled : 'none', ";border:0;border-left:1px solid ", overwrittenVars.borderColorForInput, ";border-top-right-radius:", overwrittenVars.borderRadiusForInput, ";border-bottom-right-radius:", overwrittenVars.borderRadiusForInput, ";border-color:", getClockIconContainerColor(overwrittenVars, props), ";color:", getClockIconContainerFontColor(overwrittenVars, props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";height:100%;display:flex;padding:", overwrittenVars.spacingXs, ";outline:0;transition:color ", overwrittenVars.transitionStandard, ",border-color ", overwrittenVars.transitionStandard, ";&:hover:not(:disabled):not(:read-only),&:focus{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClockIconContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
78
|
+
return /*#__PURE__*/css("align-items:center;box-sizing:border-box;background:none;background-color:", props.isDisabled ? overwrittenVars.backgroundColorForInputWhenDisabled : 'none', ";border:0;border-left:1px solid ", overwrittenVars.borderColorForInput, ";border-top-right-radius:", overwrittenVars.borderRadiusForInput, ";border-bottom-right-radius:", overwrittenVars.borderRadiusForInput, ";border-color:", getClockIconContainerColor(overwrittenVars, props), ";color:", getClockIconContainerFontColor(overwrittenVars, props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";height:100%;display:flex;padding:", overwrittenVars.spacingXs, ";outline:0;transition:color ", overwrittenVars.transitionStandard, ",border-color ", overwrittenVars.transitionStandard, ";&:hover:not(:disabled):not(:read-only),&:focus{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClockIconContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AAqEY","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */");
|
|
78
79
|
};
|
|
79
80
|
|
|
80
81
|
var getInputContainerBorderColor = function getInputContainerBorderColor(vars, props) {
|
|
@@ -112,7 +113,7 @@ var getInputContainerFontColor = function getInputContainerFontColor(vars, props
|
|
|
112
113
|
var getInputContainerStyles = function getInputContainerStyles(props, theme) {
|
|
113
114
|
var overwrittenVars = _objectSpread$2(_objectSpread$2({}, customProperties), theme);
|
|
114
115
|
|
|
115
|
-
return /*#__PURE__*/css("appearance:none;background-color:", props.isDisabled ? overwrittenVars.backgroundColorForInputWhenDisabled : overwrittenVars.backgroundColorForInput, ";border:1px solid ", getInputContainerBorderColor(overwrittenVars, props), ";border-radius:", overwrittenVars.borderRadiusForInput, ";box-sizing:border-box;color:", getInputContainerFontColor(overwrittenVars, props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";width:100%;height:", overwrittenVars.sizeHeightInput, ";align-items:center;display:flex;font-size:", overwrittenVars.fontSizeDefault, ";font-family:inherit;transition:border-color ", overwrittenVars.transitionStandard, ",box-shadow ", overwrittenVars.transitionStandard, ";svg{fill:", props.isReadOnly ? overwrittenVars.fontColorForInputWhenReadonly : 'inherit', ";}&:focus-within{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 2px ", overwrittenVars.borderColorForInputWhenFocused, ";}:hover:not(:disabled):not(:read-only),:focus{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
116
|
+
return /*#__PURE__*/css("appearance:none;background-color:", props.isDisabled ? overwrittenVars.backgroundColorForInputWhenDisabled : overwrittenVars.backgroundColorForInput, ";border:1px solid ", getInputContainerBorderColor(overwrittenVars, props), ";border-radius:", overwrittenVars.borderRadiusForInput, ";box-sizing:border-box;color:", getInputContainerFontColor(overwrittenVars, props), ";cursor:", props.isDisabled ? 'not-allowed' : 'default', ";width:100%;height:", overwrittenVars.sizeHeightInput, ";align-items:center;display:flex;font-size:", overwrittenVars.fontSizeDefault, ";font-family:inherit;transition:border-color ", overwrittenVars.transitionStandard, ",box-shadow ", overwrittenVars.transitionStandard, ";svg{fill:", props.isReadOnly ? overwrittenVars.fontColorForInputWhenReadonly : 'inherit', ";}&:focus-within{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 2px ", overwrittenVars.borderColorForInputWhenFocused, ";}:hover:not(:disabled):not(:read-only),:focus{border-color:", overwrittenVars.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AAoIY","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */");
|
|
116
117
|
};
|
|
117
118
|
|
|
118
119
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
@@ -121,7 +122,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
121
122
|
} : {
|
|
122
123
|
name: "1u9y195-baseStyles",
|
|
123
124
|
styles: "border:none;background:none;&:focus{box-shadow:none;};label:baseStyles;",
|
|
124
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
125
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AA4KO","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */",
|
|
125
126
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
126
127
|
};
|
|
127
128
|
|
|
@@ -132,41 +133,41 @@ var getTimeInputStyles = function getTimeInputStyles(props) {
|
|
|
132
133
|
|
|
133
134
|
|
|
134
135
|
var StyledClockIconContainer = _styled("label", process.env.NODE_ENV === "production" ? {
|
|
135
|
-
target: "
|
|
136
|
+
target: "e1dwg5ng1"
|
|
136
137
|
} : {
|
|
137
|
-
target: "
|
|
138
|
+
target: "e1dwg5ng1",
|
|
138
139
|
label: "StyledClockIconContainer"
|
|
139
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
140
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AAwL6C","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */");
|
|
140
141
|
|
|
141
142
|
var StyledInputContainer = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
142
|
-
target: "
|
|
143
|
+
target: "e1dwg5ng0"
|
|
143
144
|
} : {
|
|
144
|
-
target: "
|
|
145
|
+
target: "e1dwg5ng0",
|
|
145
146
|
label: "StyledInputContainer"
|
|
146
|
-
})("&:hover,&:hover ", StyledClockIconContainer, ",&:focus-within ", StyledClockIconContainer, "{border-color:", customProperties.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
147
|
+
})("&:hover,&:hover ", StyledClockIconContainer, ",&:focus-within ", StyledClockIconContainer, "{border-color:", customProperties.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["time-input-body.styles.ts"],"names":[],"mappings":"AA0LuC","file":"time-input-body.styles.ts","sourcesContent":["import { css, type Theme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { type TTimeInputProps } from './time-input';\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 = (theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    display: flex;\n    margin: ${overwrittenVars.spacingXs};\n    cursor: pointer;\n\n    &:hover svg * {\n      fill: ${overwrittenVars.colorWarning};\n    }\n  `;\n};\n\ntype TExtendedTheme = Theme & {\n  [key: string]: string;\n};\n\nconst getClockIconContainerColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getClockIconContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getClockIconContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    align-items: center;\n    box-sizing: border-box;\n    background: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : 'none'};\n    border: 0;\n    border-left: 1px solid ${overwrittenVars.borderColorForInput};\n    border-top-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-bottom-right-radius: ${overwrittenVars.borderRadiusForInput};\n    border-color: ${getClockIconContainerColor(overwrittenVars, props)};\n    color: ${getClockIconContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    height: 100%;\n    display: flex;\n    padding: ${overwrittenVars.spacingXs};\n    outline: 0;\n    transition: color ${overwrittenVars.transitionStandard},\n      border-color ${overwrittenVars.transitionStandard};\n    &:hover:not(:disabled):not(:read-only),\n    &:focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\n\nconst getInputContainerBorderColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.borderColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.borderColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.borderColorForInputWhenReadonly;\n  }\n  return vars.borderColorForInput;\n};\nconst getInputContainerFontColor = (\n  vars: TExtendedTheme,\n  props: TTimeInputProps\n) => {\n  if (props.isDisabled) {\n    return vars.fontColorForInputWhenDisabled;\n  }\n  if (props.hasError) {\n    return vars.fontColorForInputWhenError;\n  }\n  if (props.isReadOnly) {\n    return vars.fontColorForInputWhenReadonly;\n  }\n  return vars.fontColorForInput;\n};\nconst getInputContainerStyles = (props: TTimeInputProps, theme: Theme) => {\n  const overwrittenVars = {\n    ...customProperties,\n    ...theme,\n  };\n\n  return css`\n    appearance: none;\n    background-color: ${props.isDisabled\n      ? overwrittenVars.backgroundColorForInputWhenDisabled\n      : overwrittenVars.backgroundColorForInput};\n    border: 1px solid ${getInputContainerBorderColor(overwrittenVars, props)};\n    border-radius: ${overwrittenVars.borderRadiusForInput};\n    box-sizing: border-box;\n    color: ${getInputContainerFontColor(overwrittenVars, props)};\n    cursor: ${props.isDisabled ? 'not-allowed' : 'default'};\n    width: 100%;\n    height: ${overwrittenVars.sizeHeightInput};\n    align-items: center;\n    display: flex;\n    font-size: ${overwrittenVars.fontSizeDefault};\n    font-family: inherit;\n    transition: border-color ${overwrittenVars.transitionStandard},\n      box-shadow ${overwrittenVars.transitionStandard};\n\n    svg {\n      fill: ${props.isReadOnly\n        ? overwrittenVars.fontColorForInputWhenReadonly\n        : 'inherit'};\n    }\n\n    &:focus-within {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n      box-shadow: inset 0 0 0 2px\n        ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n\n    :hover:not(:disabled):not(:read-only),\n    :focus {\n      border-color: ${overwrittenVars.borderColorForInputWhenFocused};\n    }\n  `;\n};\nconst getTimeInputStyles = (props: TTimeInputProps) => {\n  const baseStyles = [\n    getInputStyles(props),\n    css`\n      border: none;\n      background: none;\n      &:focus {\n        box-shadow: none;\n      }\n    `,\n  ];\n  return baseStyles;\n};\n\n// This styled component is only useful because it's referenced in the `StyledInputContainer`.\nconst StyledClockIconContainer = styled.label``;\n\nconst StyledInputContainer = styled.div`\n  &:hover,\n  &:hover\n    ${StyledClockIconContainer},\n    &:focus-within\n    ${StyledClockIconContainer} {\n    border-color: ${customProperties.borderColorForInputWhenFocused};\n  }\n`;\n\nexport {\n  getClearSectionStyles,\n  getClockIconContainerStyles,\n  getInputContainerStyles,\n  getTimeInputStyles,\n  StyledInputContainer,\n  StyledClockIconContainer,\n};\n"]} */"));
|
|
147
148
|
|
|
148
|
-
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object);
|
|
149
|
+
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
149
150
|
|
|
150
|
-
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
151
|
+
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
151
152
|
var ClearSection = function ClearSection(props) {
|
|
152
153
|
var theme = useTheme();
|
|
153
154
|
return jsx(AccessibleButton, {
|
|
154
|
-
theme: theme,
|
|
155
155
|
css: getClearSectionStyles(theme),
|
|
156
156
|
label: "clear",
|
|
157
157
|
"aria-label": "clear",
|
|
158
158
|
onClick: props.onClear,
|
|
159
|
-
hasError: props.hasError,
|
|
160
159
|
children: jsx(CloseIcon, {
|
|
161
160
|
size: "medium"
|
|
162
161
|
})
|
|
163
162
|
});
|
|
164
163
|
};
|
|
165
|
-
ClearSection.displayName = 'ClearSection';
|
|
166
164
|
ClearSection.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
167
|
-
|
|
168
|
-
|
|
165
|
+
isDisabled: _pt.bool,
|
|
166
|
+
hasError: _pt.bool,
|
|
167
|
+
isReadOnly: _pt.bool,
|
|
168
|
+
onClear: _pt.func.isRequired
|
|
169
169
|
} : {};
|
|
170
|
+
ClearSection.displayName = 'ClearSection';
|
|
170
171
|
|
|
171
172
|
var TimeInputBody = function TimeInputBody(props) {
|
|
172
173
|
var theme = useTheme();
|
|
@@ -175,7 +176,7 @@ var TimeInputBody = function TimeInputBody(props) {
|
|
|
175
176
|
children: jsxs(StyledInputContainer, {
|
|
176
177
|
css: getInputContainerStyles(props, theme),
|
|
177
178
|
children: [jsx("input", _objectSpread$1(_objectSpread$1({
|
|
178
|
-
css: getTimeInputStyles(props
|
|
179
|
+
css: getTimeInputStyles(props),
|
|
179
180
|
id: props.id,
|
|
180
181
|
name: props.name,
|
|
181
182
|
autoComplete: props.autoComplete,
|
|
@@ -208,23 +209,10 @@ var TimeInputBody = function TimeInputBody(props) {
|
|
|
208
209
|
});
|
|
209
210
|
};
|
|
210
211
|
|
|
211
|
-
TimeInputBody.displayName = 'TimeInputBody';
|
|
212
212
|
TimeInputBody.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
213
|
-
|
|
214
|
-
autoComplete: PropTypes.string,
|
|
215
|
-
name: PropTypes.string,
|
|
216
|
-
value: PropTypes.string,
|
|
217
|
-
isAutofocussed: PropTypes.bool,
|
|
218
|
-
isDisabled: PropTypes.bool,
|
|
219
|
-
isReadOnly: PropTypes.bool,
|
|
220
|
-
hasError: PropTypes.bool,
|
|
221
|
-
onClear: PropTypes.func,
|
|
222
|
-
onChange: PropTypes.func.isRequired,
|
|
223
|
-
onBlur: PropTypes.func.isRequired,
|
|
224
|
-
onFocus: PropTypes.func,
|
|
225
|
-
placeholder: PropTypes.string,
|
|
226
|
-
horizontalConstraint: PropTypes.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
|
|
213
|
+
onClear: _pt.func.isRequired
|
|
227
214
|
} : {};
|
|
215
|
+
TimeInputBody.displayName = 'TimeInputBody';
|
|
228
216
|
var TimeInputBody$1 = TimeInputBody;
|
|
229
217
|
|
|
230
218
|
var messages = defineMessages({
|
|
@@ -235,9 +223,9 @@ var messages = defineMessages({
|
|
|
235
223
|
}
|
|
236
224
|
});
|
|
237
225
|
|
|
238
|
-
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object);
|
|
226
|
+
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
239
227
|
|
|
240
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
228
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context6, _context7; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context6 = ownKeys(Object(source), !0)).call(_context6, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context7 = ownKeys(Object(source))).call(_context7, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
241
229
|
var sequentialId = createSequentialId('time-input-');
|
|
242
230
|
|
|
243
231
|
var leftPad = function leftPad(value) {
|
|
@@ -287,7 +275,7 @@ var TimeInput = function TimeInput(props) {
|
|
|
287
275
|
}, [id, name, onChange]);
|
|
288
276
|
var handleBlur = useCallback(function (event) {
|
|
289
277
|
// check formatting and reformat when necessary
|
|
290
|
-
var formattedTime = TimeInput.toLocaleTime(value, intl.locale);
|
|
278
|
+
var formattedTime = value && TimeInput.toLocaleTime(value, intl.locale);
|
|
291
279
|
if (formattedTime !== value) emitChange(formattedTime); // forward the onBlur call
|
|
292
280
|
|
|
293
281
|
if (onBlur) onBlur(event);
|
|
@@ -320,6 +308,21 @@ var TimeInput = function TimeInput(props) {
|
|
|
320
308
|
});
|
|
321
309
|
};
|
|
322
310
|
|
|
311
|
+
TimeInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
312
|
+
id: _pt.string,
|
|
313
|
+
horizontalConstraint: _pt.oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
314
|
+
name: _pt.string,
|
|
315
|
+
autoComplete: _pt.string,
|
|
316
|
+
value: _pt.string,
|
|
317
|
+
onChange: _pt.func.isRequired,
|
|
318
|
+
onBlur: _pt.func,
|
|
319
|
+
onFocus: _pt.func,
|
|
320
|
+
isAutofocussed: _pt.bool,
|
|
321
|
+
isDisabled: _pt.bool,
|
|
322
|
+
placeholder: _pt.string,
|
|
323
|
+
hasError: _pt.bool,
|
|
324
|
+
isReadOnly: _pt.bool
|
|
325
|
+
} : {};
|
|
323
326
|
TimeInput.displayName = 'TimeInput'; // Takes any input like 15:10, 3 AM, 3AM, 3:15AM, 3:5AM and turns it
|
|
324
327
|
// into a 24h format (with seconds and milliseconds if present)
|
|
325
328
|
|
|
@@ -328,80 +331,6 @@ TimeInput.to24h = function (time) {
|
|
|
328
331
|
return parsedTime ? format24hr(parsedTime) : '';
|
|
329
332
|
};
|
|
330
333
|
|
|
331
|
-
TimeInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
332
|
-
/**
|
|
333
|
-
* Used as HTML id property. An id is auto-generated when it is not specified.
|
|
334
|
-
*/
|
|
335
|
-
id: PropTypes.string,
|
|
336
|
-
|
|
337
|
-
/**
|
|
338
|
-
* Horizontal size limit of the input fields.
|
|
339
|
-
*/
|
|
340
|
-
horizontalConstraint: PropTypes.oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
341
|
-
|
|
342
|
-
/**
|
|
343
|
-
* Used as HTML name of the input component.
|
|
344
|
-
*/
|
|
345
|
-
name: PropTypes.string,
|
|
346
|
-
|
|
347
|
-
/**
|
|
348
|
-
* Used as HTML autocomplete of the input component.
|
|
349
|
-
*/
|
|
350
|
-
autoComplete: PropTypes.string,
|
|
351
|
-
|
|
352
|
-
/**
|
|
353
|
-
* Value of the input
|
|
354
|
-
*/
|
|
355
|
-
value: PropTypes.string,
|
|
356
|
-
|
|
357
|
-
/**
|
|
358
|
-
* Called with an event holding the new value.
|
|
359
|
-
* <br/>
|
|
360
|
-
* Required when input is not read only. Parent should pass it back as `value`-
|
|
361
|
-
* <br />
|
|
362
|
-
* Signature: `(event) => void`
|
|
363
|
-
*/
|
|
364
|
-
onChange: PropTypes.func.isRequired,
|
|
365
|
-
|
|
366
|
-
/**
|
|
367
|
-
* Called when input is blurred
|
|
368
|
-
* <br/>
|
|
369
|
-
* Signature: `(event) => void`
|
|
370
|
-
*/
|
|
371
|
-
onBlur: PropTypes.func,
|
|
372
|
-
|
|
373
|
-
/**
|
|
374
|
-
* Called when input is focused
|
|
375
|
-
* <br/>
|
|
376
|
-
* Signature: `(event) => void`
|
|
377
|
-
*/
|
|
378
|
-
onFocus: PropTypes.func,
|
|
379
|
-
|
|
380
|
-
/**
|
|
381
|
-
* Focus the input on initial render
|
|
382
|
-
*/
|
|
383
|
-
isAutofocussed: PropTypes.bool,
|
|
384
|
-
|
|
385
|
-
/**
|
|
386
|
-
* Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).
|
|
387
|
-
*/
|
|
388
|
-
isDisabled: PropTypes.bool,
|
|
389
|
-
|
|
390
|
-
/**
|
|
391
|
-
* Placeholder text for the input
|
|
392
|
-
*/
|
|
393
|
-
placeholder: PropTypes.string,
|
|
394
|
-
|
|
395
|
-
/**
|
|
396
|
-
* Indicates if the input has invalid values
|
|
397
|
-
*/
|
|
398
|
-
hasError: PropTypes.bool,
|
|
399
|
-
|
|
400
|
-
/**
|
|
401
|
-
* Indicates that the field is displaying read-only content
|
|
402
|
-
*/
|
|
403
|
-
isReadOnly: PropTypes.bool
|
|
404
|
-
} : {};
|
|
405
334
|
TimeInput.defaultProps = {
|
|
406
335
|
horizontalConstraint: 'scale'
|
|
407
336
|
}; // Converts any value to either a formatted value or an empty string
|
|
@@ -432,6 +361,6 @@ TimeInput.toLocaleTime = function (time, locale) {
|
|
|
432
361
|
var TimeInput$1 = TimeInput;
|
|
433
362
|
|
|
434
363
|
// NOTE: This string will be replaced on build time with the package version.
|
|
435
|
-
var version = "
|
|
364
|
+
var version = "13.0.2";
|
|
436
365
|
|
|
437
366
|
export { TimeInput$1 as default, version };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { KeyboardEvent, MouseEvent } from 'react';
|
|
2
|
+
import type { TTimeInputProps } from './time-input';
|
|
3
|
+
declare type TTimeInputBodyProps = TTimeInputProps & {
|
|
4
|
+
onClear: (event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>) => void;
|
|
5
|
+
};
|
|
6
|
+
declare type TClearSectionProps = {
|
|
7
|
+
isDisabled?: boolean;
|
|
8
|
+
hasError?: boolean;
|
|
9
|
+
isReadOnly?: boolean;
|
|
10
|
+
onClear: (event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>) => void;
|
|
11
|
+
};
|
|
12
|
+
export declare const ClearSection: {
|
|
13
|
+
(props: TClearSectionProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
14
|
+
displayName: string;
|
|
15
|
+
};
|
|
16
|
+
declare const TimeInputBody: {
|
|
17
|
+
(props: TTimeInputBodyProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
18
|
+
displayName: string;
|
|
19
|
+
};
|
|
20
|
+
export default TimeInputBody;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { type Theme } from '@emotion/react';
|
|
3
|
+
import { type TTimeInputProps } from './time-input';
|
|
4
|
+
declare const getClearSectionStyles: (theme: Theme) => import("@emotion/utils").SerializedStyles;
|
|
5
|
+
declare const getClockIconContainerStyles: (props: TTimeInputProps, theme: Theme) => import("@emotion/utils").SerializedStyles;
|
|
6
|
+
declare const getInputContainerStyles: (props: TTimeInputProps, theme: Theme) => import("@emotion/utils").SerializedStyles;
|
|
7
|
+
declare const getTimeInputStyles: (props: TTimeInputProps) => import("@emotion/utils").SerializedStyles[];
|
|
8
|
+
declare const StyledClockIconContainer: import("@emotion/styled").StyledComponent<{
|
|
9
|
+
theme?: Theme | undefined;
|
|
10
|
+
as?: import("react").ElementType<any> | undefined;
|
|
11
|
+
}, import("react").DetailedHTMLProps<import("react").LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>, {}>;
|
|
12
|
+
declare const StyledInputContainer: import("@emotion/styled").StyledComponent<{
|
|
13
|
+
theme?: Theme | undefined;
|
|
14
|
+
as?: import("react").ElementType<any> | undefined;
|
|
15
|
+
}, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
|
|
16
|
+
export { getClearSectionStyles, getClockIconContainerStyles, getInputContainerStyles, getTimeInputStyles, StyledInputContainer, StyledClockIconContainer, };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { type FocusEventHandler } from 'react';
|
|
2
|
+
declare type TEvent = {
|
|
3
|
+
target: {
|
|
4
|
+
id: string;
|
|
5
|
+
name?: string;
|
|
6
|
+
value: unknown;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
export declare type TTimeInputProps = {
|
|
10
|
+
id?: string;
|
|
11
|
+
horizontalConstraint?: 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
12
|
+
name?: string;
|
|
13
|
+
autoComplete?: string;
|
|
14
|
+
value?: string;
|
|
15
|
+
onChange: (event: TEvent) => void;
|
|
16
|
+
onBlur?: FocusEventHandler;
|
|
17
|
+
onFocus?: FocusEventHandler;
|
|
18
|
+
isAutofocussed?: boolean;
|
|
19
|
+
isDisabled?: boolean;
|
|
20
|
+
placeholder?: string;
|
|
21
|
+
hasError?: boolean;
|
|
22
|
+
isReadOnly?: boolean;
|
|
23
|
+
};
|
|
24
|
+
declare const TimeInput: {
|
|
25
|
+
(props: TTimeInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
26
|
+
displayName: string;
|
|
27
|
+
to24h(time: string): string;
|
|
28
|
+
defaultProps: {
|
|
29
|
+
horizontalConstraint: string;
|
|
30
|
+
};
|
|
31
|
+
toLocaleTime(time: string, locale: string): string;
|
|
32
|
+
};
|
|
33
|
+
export default TimeInput;
|