@commercetools-uikit/selectable-search-input 16.0.0 → 16.1.0
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.
|
@@ -52,106 +52,79 @@ var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
|
52
52
|
var Select__default = /*#__PURE__*/_interopDefault(Select);
|
|
53
53
|
|
|
54
54
|
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
55
|
-
|
|
56
55
|
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__default["default"](_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
57
|
-
|
|
58
56
|
const getInputContainerBorderColor = function (props) {
|
|
59
57
|
let defaultColor = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : designSystem.designTokens.borderColorForInput;
|
|
60
|
-
|
|
61
58
|
if (props.isDisabled) {
|
|
62
59
|
return designSystem.designTokens.borderColorForInputWhenDisabled;
|
|
63
60
|
}
|
|
64
|
-
|
|
65
61
|
if (props.isReadOnly) {
|
|
66
62
|
return designSystem.designTokens.borderColorForInputWhenReadonly;
|
|
67
63
|
}
|
|
68
|
-
|
|
69
64
|
if (props.hasError) {
|
|
70
65
|
return designSystem.designTokens.borderColorForInputWhenError;
|
|
71
66
|
}
|
|
72
|
-
|
|
73
67
|
if (props.hasWarning) {
|
|
74
68
|
return designSystem.designTokens.borderColorForInputWhenWarning;
|
|
75
69
|
}
|
|
76
|
-
|
|
77
70
|
return defaultColor;
|
|
78
71
|
};
|
|
79
|
-
|
|
80
72
|
const getInputFontColor = props => {
|
|
81
73
|
if (props.isDisabled) {
|
|
82
74
|
return designSystem.designTokens.fontColorForInputWhenDisabled;
|
|
83
75
|
}
|
|
84
|
-
|
|
85
76
|
if (props.isReadOnly) {
|
|
86
77
|
return designSystem.designTokens.fontColorForInputWhenReadonly;
|
|
87
78
|
}
|
|
88
|
-
|
|
89
79
|
if (props.hasError) {
|
|
90
80
|
return designSystem.designTokens.fontColorForInputWhenError;
|
|
91
81
|
}
|
|
92
|
-
|
|
93
82
|
if (props.hasWarning) {
|
|
94
83
|
return designSystem.designTokens.fontColorForInputWhenWarning;
|
|
95
84
|
}
|
|
96
|
-
|
|
97
85
|
return designSystem.designTokens.fontColorForInput;
|
|
98
86
|
};
|
|
99
|
-
|
|
100
87
|
const getInputBoxShadow = props => {
|
|
101
88
|
if (props.hasError) {
|
|
102
89
|
return designSystem.designTokens.shadowForInputWhenError;
|
|
103
90
|
}
|
|
104
|
-
|
|
105
91
|
if (props.hasWarning) {
|
|
106
92
|
return designSystem.designTokens.shadowForInputWhenWarning;
|
|
107
93
|
}
|
|
108
|
-
|
|
109
94
|
return designSystem.designTokens.shadowForInput;
|
|
110
95
|
};
|
|
111
|
-
|
|
112
96
|
const getSelectableSearchInputStyles = props => [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA4DK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
|
|
113
|
-
|
|
114
97
|
const getButtonStyles = () => /*#__PURE__*/react.css("border:none;background:none;height:100%;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";margin-right:", designSystem.designTokens.marginRightForClearInputIcon, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA8EiC","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */");
|
|
115
|
-
|
|
116
98
|
const getIconColor = (props, defaultColor) => {
|
|
117
99
|
if (props.isDisabled) {
|
|
118
100
|
return designSystem.designTokens.fontColorForInputWhenDisabled;
|
|
119
101
|
}
|
|
120
|
-
|
|
121
102
|
if (props.isReadOnly) {
|
|
122
103
|
return designSystem.designTokens.fontColorForSearchInputIconWhenReadonly;
|
|
123
104
|
}
|
|
124
|
-
|
|
125
105
|
return defaultColor;
|
|
126
106
|
};
|
|
127
|
-
|
|
128
107
|
const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIcon), ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAyGK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
|
|
129
|
-
|
|
130
108
|
const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.marginRightForSearchInputIcon, ";fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIcon), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSearchIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAsHK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
|
|
131
|
-
|
|
132
109
|
const getBackgroundColor = (props, defaultColor) => {
|
|
133
110
|
if (props.isDisabled) {
|
|
134
111
|
return designSystem.designTokens.backgroundColorForInputWhenDisabled;
|
|
135
112
|
}
|
|
136
|
-
|
|
137
113
|
if (props.isReadOnly) {
|
|
138
114
|
return designSystem.designTokens.backgroundColorForInputWhenReadonly;
|
|
139
115
|
}
|
|
140
|
-
|
|
141
116
|
return defaultColor;
|
|
142
117
|
};
|
|
143
|
-
|
|
144
118
|
const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/react.css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", designSystem.designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:100%;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";&::placeholder{color:", designSystem.designTokens.placeholderFontColorForInput, ";}&:hover{border-color:", getInputContainerBorderColor(props, designSystem.designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA8IK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */"), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/react.css("&:focus-within{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";box-shadow:", designSystem.designTokens.boxShadowForDatetimeInputWhenHovered, " ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAsLO","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: 100%;\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  isNewTheme: boolean;\n  dropdownHasFocus?: boolean;\n  textInputHasFocus?: boolean;\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  isNewTheme,\n  dropdownHasFocus,\n  textInputHasFocus,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isNewTheme,\n    isDisabled,\n    isReadOnly,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (textInputHasFocus && !isNewTheme) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
|
|
145
|
-
|
|
146
119
|
const createSelectableSelectStyles = _ref => {
|
|
147
120
|
let hasWarning = _ref.hasWarning,
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
121
|
+
hasError = _ref.hasError,
|
|
122
|
+
isDisabled = _ref.isDisabled,
|
|
123
|
+
isReadOnly = _ref.isReadOnly,
|
|
124
|
+
menuPortalZIndex = _ref.menuPortalZIndex,
|
|
125
|
+
isNewTheme = _ref.isNewTheme,
|
|
126
|
+
dropdownHasFocus = _ref.dropdownHasFocus,
|
|
127
|
+
textInputHasFocus = _ref.textInputHasFocus;
|
|
155
128
|
const selectStyles = selectUtils.createSelectStyles({
|
|
156
129
|
hasWarning,
|
|
157
130
|
hasError,
|
|
@@ -172,15 +145,12 @@ const createSelectableSelectStyles = _ref => {
|
|
|
172
145
|
if (isReadOnly) return "".concat(designSystem.designTokens.borderColorForInputWhenReadonly, " !important");
|
|
173
146
|
if (hasError) return designSystem.designTokens.borderColorForInputWhenError;
|
|
174
147
|
if (hasWarning) return designSystem.designTokens.borderColorForInputWhenWarning;
|
|
175
|
-
|
|
176
148
|
if (textInputHasFocus && !isNewTheme) {
|
|
177
149
|
return designSystem.designTokens.borderColorForInputWhenFocused;
|
|
178
150
|
}
|
|
179
|
-
|
|
180
151
|
if (dropdownHasFocus) {
|
|
181
152
|
return designSystem.designTokens.borderColorForInputWhenFocused;
|
|
182
153
|
}
|
|
183
|
-
|
|
184
154
|
return designSystem.designTokens.borderColorForInput;
|
|
185
155
|
})(),
|
|
186
156
|
cursor: (() => {
|
|
@@ -216,15 +186,11 @@ const createSelectableSelectStyles = _ref => {
|
|
|
216
186
|
};
|
|
217
187
|
|
|
218
188
|
const _excluded = ["id"];
|
|
219
|
-
|
|
220
189
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
221
|
-
|
|
222
190
|
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__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
223
|
-
|
|
224
191
|
const SingleValue = _ref => {
|
|
225
192
|
let id = _ref.id,
|
|
226
|
-
|
|
227
|
-
|
|
193
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
228
194
|
return jsxRuntime.jsx(Select.components.SingleValue, _objectSpread$1(_objectSpread$1({}, props), {}, {
|
|
229
195
|
children: jsxRuntime.jsx("label", {
|
|
230
196
|
htmlFor: id,
|
|
@@ -232,18 +198,14 @@ const SingleValue = _ref => {
|
|
|
232
198
|
})
|
|
233
199
|
}));
|
|
234
200
|
};
|
|
235
|
-
|
|
236
201
|
SingleValue.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
237
202
|
id: _pt__default["default"].string,
|
|
238
203
|
children: _pt__default["default"].node
|
|
239
204
|
} : {};
|
|
240
|
-
|
|
241
205
|
const SelectableSelect = props => {
|
|
242
206
|
const intl = reactIntl.useIntl();
|
|
243
|
-
|
|
244
207
|
const _useTheme = designSystem.useTheme(),
|
|
245
|
-
|
|
246
|
-
|
|
208
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
247
209
|
const dropdownStyles = createSelectableSelectStyles({
|
|
248
210
|
hasWarning: props.hasWarning,
|
|
249
211
|
hasError: props.hasError,
|
|
@@ -255,12 +217,11 @@ const SelectableSelect = props => {
|
|
|
255
217
|
textInputHasFocus: props.textInputHasFocus
|
|
256
218
|
});
|
|
257
219
|
const onChange = props.onChange,
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
220
|
+
name = props.name,
|
|
221
|
+
id = props.id,
|
|
222
|
+
textInputRef = props.textInputRef;
|
|
261
223
|
const handleDropdownChange = react$1.useCallback(nextSelectedOptions => {
|
|
262
224
|
var _textInputRef$current;
|
|
263
|
-
|
|
264
225
|
if (onChange) {
|
|
265
226
|
onChange({
|
|
266
227
|
target: {
|
|
@@ -270,7 +231,6 @@ const SelectableSelect = props => {
|
|
|
270
231
|
}
|
|
271
232
|
});
|
|
272
233
|
}
|
|
273
|
-
|
|
274
234
|
(_textInputRef$current = textInputRef.current) === null || _textInputRef$current === void 0 ? void 0 : _textInputRef$current.focus();
|
|
275
235
|
}, [onChange, id, name, textInputRef]);
|
|
276
236
|
return jsxRuntime.jsx(Select__default["default"], {
|
|
@@ -305,7 +265,6 @@ const SelectableSelect = props => {
|
|
|
305
265
|
})
|
|
306
266
|
});
|
|
307
267
|
};
|
|
308
|
-
|
|
309
268
|
SelectableSelect.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
310
269
|
textInputHasFocus: _pt__default["default"].bool.isRequired,
|
|
311
270
|
dropdownHasFocus: _pt__default["default"].bool.isRequired,
|
|
@@ -318,11 +277,8 @@ SelectableSelect.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
318
277
|
var SelectableSelect$1 = SelectableSelect;
|
|
319
278
|
|
|
320
279
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
321
|
-
|
|
322
280
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
323
|
-
|
|
324
281
|
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)."; }
|
|
325
|
-
|
|
326
282
|
const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
327
283
|
target: "encv1cf0"
|
|
328
284
|
} : {
|
|
@@ -337,11 +293,8 @@ const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NO
|
|
|
337
293
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAgC4B","file":"selectable-search-input.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [textInputHasFocus, toggleTextInputHasFocus] = useToggleState(false);\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const { isNewTheme } = useTheme();\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n    toggleTextInputHasFocus(true);\n  }, [toggleTextInputHasFocus, onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n    toggleTextInputHasFocus(false);\n  }, [toggleTextInputHasFocus, onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            textInputHasFocus={textInputHasFocus}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            isNewTheme={isNewTheme}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              isNewTheme &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */",
|
|
338
294
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
339
295
|
});
|
|
340
|
-
|
|
341
296
|
const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
|
|
342
|
-
|
|
343
297
|
const getDropdownName = name => name ? "".concat(name, ".dropdown") : undefined;
|
|
344
|
-
|
|
345
298
|
const defaultProps = {
|
|
346
299
|
horizontalConstraint: 'scale',
|
|
347
300
|
isClearable: true,
|
|
@@ -351,57 +304,44 @@ const defaultProps = {
|
|
|
351
304
|
options: []
|
|
352
305
|
};
|
|
353
306
|
const selectableSearchInputSequentialId = utils.createSequentialId('selectable-search-input-');
|
|
354
|
-
|
|
355
307
|
const isOptionObject = option => option.options !== undefined;
|
|
356
|
-
|
|
357
308
|
const SelectableSearchInput = props => {
|
|
358
309
|
var _context;
|
|
359
|
-
|
|
360
310
|
const _useToggleState = hooks.useToggleState(false),
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
311
|
+
_useToggleState2 = _slicedToArray(_useToggleState, 2),
|
|
312
|
+
textInputHasFocus = _useToggleState2[0],
|
|
313
|
+
toggleTextInputHasFocus = _useToggleState2[1];
|
|
365
314
|
const _useToggleState3 = hooks.useToggleState(false),
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
315
|
+
_useToggleState4 = _slicedToArray(_useToggleState3, 2),
|
|
316
|
+
dropdownHasFocus = _useToggleState4[0],
|
|
317
|
+
toggleDropdownHasFocus = _useToggleState4[1];
|
|
370
318
|
const _useState = react$1.useState(props.value.text || ''),
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
319
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
320
|
+
searchValue = _useState2[0],
|
|
321
|
+
setSearchValue = _useState2[1];
|
|
375
322
|
const containerRef = react$1.useRef(null);
|
|
376
323
|
const textInputRef = react$1.useRef(null);
|
|
377
|
-
|
|
378
324
|
const _useTheme = designSystem.useTheme(),
|
|
379
|
-
|
|
380
|
-
|
|
325
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
381
326
|
const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context = props.options).call(_context, option => {
|
|
382
327
|
if (isOptionObject(option)) {
|
|
383
328
|
return option.options;
|
|
384
329
|
}
|
|
385
|
-
|
|
386
330
|
return option;
|
|
387
331
|
});
|
|
388
|
-
|
|
389
332
|
const selectedOption = _findInstanceProperty__default["default"](optionsWithoutGroups).call(optionsWithoutGroups, option => option.value === props.value.option);
|
|
390
|
-
|
|
391
333
|
const selectablSearchInputId = hooks.useFieldId(props.id, selectableSearchInputSequentialId);
|
|
392
|
-
|
|
393
334
|
if (!props.isReadOnly) {
|
|
394
335
|
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'SelectableSearchInput: `onChange` is required when is not read only.') : void 0;
|
|
395
336
|
}
|
|
396
|
-
|
|
397
337
|
selectUtils.warnIfMenuPortalPropsAreMissing({
|
|
398
338
|
menuPortalZIndex: props.menuPortalZIndex,
|
|
399
339
|
menuPortalTarget: props.menuPortalTarget,
|
|
400
340
|
componentName: 'SelectableSearchInput'
|
|
401
341
|
});
|
|
402
342
|
const onFocus = props.onFocus,
|
|
403
|
-
|
|
404
|
-
|
|
343
|
+
onBlur = props.onBlur,
|
|
344
|
+
name = props.name;
|
|
405
345
|
const handleTextInputFocus = react$1.useCallback(() => {
|
|
406
346
|
if (onFocus) {
|
|
407
347
|
onFocus({
|
|
@@ -411,7 +351,6 @@ const SelectableSearchInput = props => {
|
|
|
411
351
|
}
|
|
412
352
|
});
|
|
413
353
|
}
|
|
414
|
-
|
|
415
354
|
toggleTextInputHasFocus(true);
|
|
416
355
|
}, [toggleTextInputHasFocus, onFocus, selectablSearchInputId, name]);
|
|
417
356
|
const handleTextInputBlur = react$1.useCallback(() => {
|
|
@@ -423,21 +362,16 @@ const SelectableSearchInput = props => {
|
|
|
423
362
|
}
|
|
424
363
|
});
|
|
425
364
|
}
|
|
426
|
-
|
|
427
365
|
toggleTextInputHasFocus(false);
|
|
428
366
|
}, [toggleTextInputHasFocus, onBlur, selectablSearchInputId, name]);
|
|
429
|
-
|
|
430
367
|
const handleClear = () => {
|
|
431
368
|
setSearchValue('');
|
|
432
|
-
|
|
433
369
|
if (props.onReset) {
|
|
434
370
|
props.onReset();
|
|
435
371
|
}
|
|
436
372
|
};
|
|
437
|
-
|
|
438
373
|
const handleChange = event => {
|
|
439
374
|
setSearchValue(event.target.value);
|
|
440
|
-
|
|
441
375
|
if (props.onChange) {
|
|
442
376
|
props.onChange({
|
|
443
377
|
target: {
|
|
@@ -448,20 +382,16 @@ const SelectableSearchInput = props => {
|
|
|
448
382
|
});
|
|
449
383
|
}
|
|
450
384
|
};
|
|
451
|
-
|
|
452
385
|
const handleSubmit = event => {
|
|
453
386
|
event.preventDefault();
|
|
454
|
-
|
|
455
387
|
if (props.onSubmit) {
|
|
456
388
|
var _selectedOption$value;
|
|
457
|
-
|
|
458
389
|
props.onSubmit({
|
|
459
390
|
text: searchValue,
|
|
460
391
|
option: (_selectedOption$value = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value) !== null && _selectedOption$value !== void 0 ? _selectedOption$value : ''
|
|
461
392
|
});
|
|
462
393
|
}
|
|
463
394
|
};
|
|
464
|
-
|
|
465
395
|
const dropdownName = getDropdownName(props.name);
|
|
466
396
|
const dropdownId = SelectableSearchInput.getDropdownId(selectablSearchInputId);
|
|
467
397
|
const handleDropdownFocus = react$1.useCallback(() => {
|
|
@@ -473,7 +403,6 @@ const SelectableSearchInput = props => {
|
|
|
473
403
|
}
|
|
474
404
|
});
|
|
475
405
|
}
|
|
476
|
-
|
|
477
406
|
toggleDropdownHasFocus(true);
|
|
478
407
|
}, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);
|
|
479
408
|
const handleDropdownBlur = react$1.useCallback(() => {
|
|
@@ -485,12 +414,10 @@ const SelectableSearchInput = props => {
|
|
|
485
414
|
}
|
|
486
415
|
});
|
|
487
416
|
}
|
|
488
|
-
|
|
489
417
|
toggleDropdownHasFocus(false);
|
|
490
418
|
}, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);
|
|
491
419
|
const handleContainerBlur = react$1.useCallback(event => {
|
|
492
420
|
var _containerRef$current;
|
|
493
|
-
|
|
494
421
|
// ensures that both fields are marked as touched when one of them
|
|
495
422
|
// is blurred
|
|
496
423
|
if (typeof onBlur === 'function' && !((_containerRef$current = containerRef.current) !== null && _containerRef$current !== void 0 && _containerRef$current.contains(event.relatedTarget))) {
|
|
@@ -573,7 +500,6 @@ const SelectableSearchInput = props => {
|
|
|
573
500
|
})
|
|
574
501
|
});
|
|
575
502
|
};
|
|
576
|
-
|
|
577
503
|
SelectableSearchInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
578
504
|
id: _pt__default["default"].string,
|
|
579
505
|
autoComplete: _pt__default["default"].string,
|
|
@@ -612,19 +538,16 @@ SelectableSearchInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
612
538
|
} : {};
|
|
613
539
|
SelectableSearchInput.displayName = 'SelectableSearchInput';
|
|
614
540
|
SelectableSearchInput.defaultProps = defaultProps;
|
|
615
|
-
|
|
616
541
|
SelectableSearchInput.isEmpty = formValue => {
|
|
617
542
|
var _context2;
|
|
618
|
-
|
|
619
543
|
return !formValue || _trimInstanceProperty__default["default"](_context2 = formValue.text).call(_context2) === '';
|
|
620
544
|
};
|
|
621
|
-
|
|
622
545
|
SelectableSearchInput.getTextInputId = getTextInputName;
|
|
623
546
|
SelectableSearchInput.getDropdownId = getDropdownName;
|
|
624
547
|
var SelectableSearchInput$1 = SelectableSearchInput;
|
|
625
548
|
|
|
626
549
|
// NOTE: This string will be replaced on build time with the package version.
|
|
627
|
-
var version = "16.
|
|
550
|
+
var version = "16.1.0";
|
|
628
551
|
|
|
629
552
|
exports["default"] = SelectableSearchInput$1;
|
|
630
553
|
exports.version = version;
|