td-stylekit 28.26.0 → 28.28.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.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,17 @@
1
+ # [28.28.0](https://github.com/treasure-data/td-stylekit/compare/v28.27.0...v28.28.0) (2023-11-02)
2
+
3
+
4
+ ### Features
5
+
6
+ * **CON-14086:** Add Format Icon ([#1507](https://github.com/treasure-data/td-stylekit/issues/1507)) ([463fe01](https://github.com/treasure-data/td-stylekit/commit/463fe01))
7
+
8
+ # [28.27.0](https://github.com/treasure-data/td-stylekit/compare/v28.26.0...v28.27.0) (2023-10-31)
9
+
10
+
11
+ ### Features
12
+
13
+ * **CON-14212:** Shuttle - add support for disabled options ([#1506](https://github.com/treasure-data/td-stylekit/issues/1506)) ([1697b0c](https://github.com/treasure-data/td-stylekit/commit/1697b0c))
14
+
1
15
  # [28.26.0](https://github.com/treasure-data/td-stylekit/compare/v28.25.1...v28.26.0) (2023-10-18)
2
16
 
3
17
 
@@ -494,6 +494,8 @@ export type IconTypes = {
494
494
  FolderOpenedIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
495
495
  FolderTagPerson: React.ComponentType<JSX.IntrinsicElements['svg']>;
496
496
  FolderTagPersonIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
497
+ Format: React.ComponentType<JSX.IntrinsicElements['svg']>;
498
+ FormatIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
497
499
  Funnel: React.ComponentType<JSX.IntrinsicElements['svg']>;
498
500
  FunnelIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
499
501
  GoToTop: React.ComponentType<JSX.IntrinsicElements['svg']>;
@@ -964,7 +964,32 @@ React.createElement("g", null, /*#__PURE__*/React.createElement("path", {
964
964
  React.createElement("path", {
965
965
  d: "M6 5.5a2 2 0 00-2 2v9a2 2 0 002 2h12a2 2 0 002-2v-7a2 2 0 00-2-2h-4.847a2 2 0 01-.625-.14l-1.79-1.605a1 1 0 00-.668-.255H6zm5.21 4.577c0-.963-.823-1.743-1.84-1.743-1.015 0-1.838.78-1.838 1.743v.29c0 .963.823 1.743 1.839 1.743s1.839-.78 1.839-1.743v-.29zm1.418 4.542c-.454-.558-2.03-1.242-3.257-1.242-1.228 0-2.804.684-3.258 1.242-.28.345-.013 1.77.447 1.77h5.621c.46 0 .727-1.425.447-1.77z",
966
966
  fillRule: "evenodd"
967
- }),Funnel: /*#__PURE__*/
967
+ }),Format: /*#__PURE__*/
968
+ React.createElement("g", null, /*#__PURE__*/React.createElement("rect", {
969
+ height: "2",
970
+ width: "9",
971
+ rx: "1",
972
+ x: "5",
973
+ y: "5"
974
+ }), /*#__PURE__*/React.createElement("rect", {
975
+ height: "2",
976
+ width: "12",
977
+ rx: "1",
978
+ x: "8",
979
+ y: "9"
980
+ }), /*#__PURE__*/React.createElement("rect", {
981
+ height: "2",
982
+ width: "12",
983
+ rx: "1",
984
+ x: "8",
985
+ y: "13"
986
+ }), /*#__PURE__*/React.createElement("rect", {
987
+ height: "2",
988
+ width: "9",
989
+ rx: "1",
990
+ x: "5",
991
+ y: "17"
992
+ })),Funnel: /*#__PURE__*/
968
993
  React.createElement("path", {
969
994
  d: "M4 4.5a.5.5 0 01.5-.5h15a.5.5 0 01.5.5v1.385a.5.5 0 01-.5.5h-15a.5.5 0 01-.5-.5V4.5zM6.856 8a.3.3 0 00-.233.49l3.486 4.26a.5.5 0 01.113.317v6.07a.5.5 0 00.749.434l2.555-1.463a.5.5 0 00.252-.434v-4.607a.5.5 0 01.113-.316l3.486-4.26a.3.3 0 00-.233-.49H6.856z"
970
995
  }),GoToTop: /*#__PURE__*/
@@ -1,11 +1,13 @@
1
1
  import React from 'react';
2
2
  import type { CSSProperties } from 'react';
3
3
  import type { Theme } from '../ThemeProvider';
4
+ type Option = {
5
+ name: string;
6
+ value: string;
7
+ disabled?: boolean;
8
+ };
4
9
  export type MultiSelectProps = {
5
- options: Array<{
6
- name: string;
7
- value: string;
8
- }>;
10
+ options: Array<Option>;
9
11
  rowRenderer: (optionItem: {
10
12
  option: {
11
13
  name: string;
@@ -45,10 +47,7 @@ type SelectProps = {
45
47
  export declare class MultiSelect extends React.Component<MultiSelectProps, MultiSelectState> {
46
48
  static defaultProps: {
47
49
  rowRenderer: ({ option }: {
48
- option: {
49
- name: string;
50
- value: string;
51
- };
50
+ option: Option;
52
51
  index: number;
53
52
  }) => import("@emotion/react/jsx-runtime").JSX.Element;
54
53
  initiallySelected: never[];
@@ -81,10 +80,7 @@ export declare class MultiSelect extends React.Component<MultiSelectProps, Multi
81
80
  }
82
81
  declare const ThemedComponent: React.FC<Pick<Pick<MultiSelectProps, "filter" | "ref" | "theme" | "height" | "width" | "options" | "onSelectionChange" | "onEnterKey" | "onFilterChange" | "inputName" | "inputPlaceholder"> & Partial<Pick<MultiSelectProps, "data-instrumentation" | "rowRenderer" | "initiallySelected" | "showTotal" | "selectedLabel" | "totalLabel">> & Partial<Pick<{
83
82
  rowRenderer: ({ option }: {
84
- option: {
85
- name: string;
86
- value: string;
87
- };
83
+ option: Option;
88
84
  index: number;
89
85
  }) => import("@emotion/react/jsx-runtime").JSX.Element;
90
86
  initiallySelected: never[];
@@ -15,6 +15,10 @@ var _lodash2 = _interopRequireDefault(require("lodash.range"));
15
15
 
16
16
  var _lodash3 = _interopRequireDefault(require("lodash.uniq"));
17
17
 
18
+ var _lodash4 = _interopRequireDefault(require("lodash.findindex"));
19
+
20
+ var _lodash5 = _interopRequireDefault(require("lodash.findlastindex"));
21
+
18
22
  var _react2 = _interopRequireDefault(require("react"));
19
23
 
20
24
  var _reactVirtualized = require("react-virtualized");
@@ -81,6 +85,11 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
81
85
 
82
86
  if (index === null) {
83
87
  return;
88
+ } // if the item is disabled - do not allow it to be selected
89
+
90
+
91
+ if (_this.props.options[index].disabled && !contiguous) {
92
+ return;
84
93
  }
85
94
 
86
95
  _this.setState(function (state) {
@@ -91,10 +100,14 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
91
100
  var start = Math.min(lastSelected, index);
92
101
  var end = Math.max(lastSelected, index);
93
102
  selected = (0, _lodash3["default"])([].concat(_toConsumableArray(selected), _toConsumableArray((0, _lodash2["default"])(start, end + 1))));
94
- }
103
+ } // filter out the disabled options
95
104
 
105
+
106
+ var sansDisabled = selected.filter(function (option) {
107
+ return !_this.props.options[option].disabled;
108
+ });
96
109
  return {
97
- selected: selected,
110
+ selected: sansDisabled,
98
111
  lastSelected: index
99
112
  };
100
113
  }, function () {
@@ -109,6 +122,11 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
109
122
 
110
123
  if (index === null) {
111
124
  return;
125
+ } // if the item is disabled - do not allow it to be deselected
126
+
127
+
128
+ if (_this.props.options[index].disabled && !contiguous) {
129
+ return;
112
130
  }
113
131
 
114
132
  _this.setState(function (state) {
@@ -161,17 +179,35 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
161
179
  });
162
180
 
163
181
  _defineProperty(_assertThisInitialized(_this), "focusPrevious", function () {
182
+ var nextIndex = 0;
183
+
184
+ if (_this.state.focusedIndex) {
185
+ var next = (0, _lodash5["default"])(_this.props.options, function (option) {
186
+ return !option.disabled;
187
+ }, _this.state.focusedIndex - 1);
188
+ nextIndex = next !== -1 ? next : _this.state.focusedIndex;
189
+ }
190
+
164
191
  _this.setState(function (state) {
165
192
  return {
166
- focusedIndex: state.focusedIndex ? Math.max(state.focusedIndex - 1, 0) : 0
193
+ focusedIndex: state.focusedIndex ? nextIndex : 0
167
194
  };
168
195
  });
169
196
  });
170
197
 
171
198
  _defineProperty(_assertThisInitialized(_this), "focusNext", function () {
199
+ var nextIndex = 0; // find the next focussable item - it should not be disabled.
200
+
201
+ if (_this.state.focusedIndex) {
202
+ var next = (0, _lodash4["default"])(_this.props.options, function (option) {
203
+ return !option.disabled;
204
+ }, _this.state.focusedIndex + 1);
205
+ nextIndex = next !== -1 ? next : _this.state.focusedIndex;
206
+ }
207
+
172
208
  _this.setState(function (state, props) {
173
209
  return {
174
- focusedIndex: Math.min(state.focusedIndex ? state.focusedIndex + 1 : 1, props.options.length - 1)
210
+ focusedIndex: Math.min(state.focusedIndex ? nextIndex : 1, props.options.length - 1)
175
211
  };
176
212
  });
177
213
  });
@@ -269,6 +305,8 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
269
305
  });
270
306
 
271
307
  _defineProperty(_assertThisInitialized(_this), "rowRender", function (_ref4) {
308
+ var _options$index$disabl;
309
+
272
310
  var index = _ref4.index,
273
311
  key = _ref4.key,
274
312
  style = _ref4.style;
@@ -279,7 +317,8 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
279
317
  options = _this$props.options,
280
318
  dataInstrumentation = _this$props['data-instrumentation'],
281
319
  rowRenderer = _this$props.rowRenderer;
282
- var isSelected = (0, _lodash["default"])(selected, index);
320
+ var isDisabled = (_options$index$disabl = options[index].disabled) !== null && _options$index$disabl !== void 0 ? _options$index$disabl : false;
321
+ var isSelected = (0, _lodash["default"])(selected, index) && !isDisabled;
283
322
  return (0, _jsxRuntime.jsx)(_elements.ListItem, {
284
323
  "data-gs-c": gsC(rowRenderer({
285
324
  option: options[index],
@@ -288,6 +327,7 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
288
327
  "data-gs": gs("src", "multiselect", "multiselect.tsx", "multi-select", "list-item"),
289
328
  "aria-selected": isSelected ? 'true' : undefined,
290
329
  selected: isSelected,
330
+ disabled: isDisabled,
291
331
  style: style,
292
332
  "data-instrumentation": "".concat(dataInstrumentation, "-item").concat(index),
293
333
  focused: index === focusedIndex,
@@ -305,6 +345,7 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
305
345
  _defineProperty(_assertThisInitialized(_this), "noRowsRenderer", function () {
306
346
  return (0, _jsxRuntime.jsx)(_elements.NoRowRender, {
307
347
  "data-gs": gs("src", "multiselect", "multiselect.tsx", "multi-select", "no-row-render"),
348
+ "data-testid": "no-row-renderer",
308
349
  text: ""
309
350
  });
310
351
  });
@@ -341,10 +382,15 @@ var MultiSelect = /*#__PURE__*/function (_React$Component) {
341
382
  value: function selectAll() {
342
383
  var _this3 = this;
343
384
 
385
+ var selectedIndices = this.props.options.reduce(function (list, option, index) {
386
+ if (!option.disabled) {
387
+ list.push(index);
388
+ }
389
+
390
+ return list;
391
+ }, []);
344
392
  this.setState({
345
- selected: this.props.options.map(function (_, idx) {
346
- return idx;
347
- }),
393
+ selected: selectedIndices,
348
394
  lastSelected: this.props.options.length
349
395
  }, function () {
350
396
  _this3.props.onSelectionChange(_this3.state.selected);
@@ -9,6 +9,7 @@ export declare const ListItem: import("@emotion/styled").StyledComponent<{
9
9
  } & {
10
10
  focused: boolean;
11
11
  selected: boolean;
12
+ disabled: boolean;
12
13
  }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
13
14
  export declare const SelectContainer: import("@emotion/styled").StyledComponent<{
14
15
  theme?: import("@emotion/react").Theme | undefined;
@@ -53,7 +53,7 @@ var DefaultRowRenderer = ( /*#__PURE__*/0, _base["default"])(_RightTruncatedText
53
53
  paddingRight: theme.space[2],
54
54
  lineHeight: '32px'
55
55
  };
56
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.DefaultRowRenderer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAQkC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
56
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.DefaultRowRenderer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAQkC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
57
57
  exports.DefaultRowRenderer = DefaultRowRenderer;
58
58
  var NoRowRender = ( /*#__PURE__*/0, _base["default"])(DefaultRowRenderer, process.env.NODE_ENV === "production" ? {
59
59
  target: "e1y7a7qq10"
@@ -66,7 +66,7 @@ var NoRowRender = ( /*#__PURE__*/0, _base["default"])(DefaultRowRenderer, proces
66
66
  fontSize: theme.fontSize[0],
67
67
  color: theme.color.LightDisabled
68
68
  };
69
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiB2B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
69
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiB2B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
70
70
  exports.NoRowRender = NoRowRender;
71
71
 
72
72
  var AnimatedListContainer = function AnimatedListContainer(props) {
@@ -119,7 +119,7 @@ var ListContainer = ( /*#__PURE__*/0, _base["default"])(AnimatedListContainer, p
119
119
  borderRight: "1px solid ".concat(theme.palette.neutral[4]),
120
120
  padding: "0 ".concat(theme.space[2], " ").concat(theme.space[2], " ").concat(theme.space[2])
121
121
  };
122
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ListContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA6C6B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
122
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ListContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA6C6B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
123
123
  exports.ListContainer = ListContainer;
124
124
  var ListItem = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
125
125
  target: "e1y7a7qq8"
@@ -179,7 +179,25 @@ var ListItem = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV =
179
179
  border: "1px solid ".concat(theme.palette.primary[1]),
180
180
  color: theme.palette.neutral[0]
181
181
  };
182
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ListItem), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiEwB","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
182
+ }, function (_ref9) {
183
+ var disabled = _ref9.disabled,
184
+ theme = _ref9.theme;
185
+ return disabled && {
186
+ color: theme.palette.neutral[7],
187
+ backgroundColor: 'transparent',
188
+ '&:hover': {
189
+ backgroundColor: 'transparent'
190
+ }
191
+ };
192
+ }, function (_ref10) {
193
+ var disabled = _ref10.disabled,
194
+ focused = _ref10.focused,
195
+ selected = _ref10.selected;
196
+ return disabled && (focused || selected) && {
197
+ backgroundColor: 'transparent',
198
+ border: 'none'
199
+ };
200
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ListItem), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiEwB","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
183
201
  exports.ListItem = ListItem;
184
202
  var SelectContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
185
203
  target: "e1y7a7qq7"
@@ -192,7 +210,7 @@ var SelectContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NOD
192
210
  } : {
193
211
  name: "fxr865",
194
212
  styles: "display:flex;flex:1 1 auto;flex-direction:column",
195
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAgH+B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */",
213
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA+H+B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */",
196
214
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
197
215
  });
198
216
  exports.SelectContainer = SelectContainer;
@@ -201,8 +219,8 @@ var Counter = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV =
201
219
  } : {
202
220
  target: "e1y7a7qq6",
203
221
  label: "Counter"
204
- })(function (_ref9) {
205
- var theme = _ref9.theme;
222
+ })(function (_ref11) {
223
+ var theme = _ref11.theme;
206
224
  return {
207
225
  width: '100%',
208
226
  textAlign: 'center',
@@ -210,43 +228,43 @@ var Counter = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV =
210
228
  color: theme.palette.neutral[8],
211
229
  fontSize: theme.fontSize[0]
212
230
  };
213
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.Counter), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAsHuB","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
231
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.Counter), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAqIuB","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
214
232
  exports.Counter = Counter;
215
233
  var SelectSpacer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
216
234
  target: "e1y7a7qq5"
217
235
  } : {
218
236
  target: "e1y7a7qq5",
219
237
  label: "SelectSpacer"
220
- })(function (_ref10) {
221
- var theme = _ref10.theme;
238
+ })(function (_ref12) {
239
+ var theme = _ref12.theme;
222
240
  return {
223
241
  borderLeft: "1px solid ".concat(theme.palette.neutral[4]),
224
242
  borderRight: "1px solid ".concat(theme.palette.neutral[4]),
225
243
  height: '0.5rem',
226
244
  padding: "0 ".concat(theme.space[2])
227
245
  };
228
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SelectSpacer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiI4B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
246
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SelectSpacer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAgJ4B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
229
247
  exports.SelectSpacer = SelectSpacer;
230
248
  var SelectDivider = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
231
249
  target: "e1y7a7qq4"
232
250
  } : {
233
251
  target: "e1y7a7qq4",
234
252
  label: "SelectDivider"
235
- })(function (_ref11) {
236
- var theme = _ref11.theme;
253
+ })(function (_ref13) {
254
+ var theme = _ref13.theme;
237
255
  return {
238
256
  borderTop: "1px solid ".concat(theme.palette.neutral[4]),
239
257
  margin: "0 ".concat(theme.space[2])
240
258
  };
241
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SelectDivider), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA2I6B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
259
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SelectDivider), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA0J6B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
242
260
  exports.SelectDivider = SelectDivider;
243
261
  var SearchInputWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
244
262
  target: "e1y7a7qq3"
245
263
  } : {
246
264
  target: "e1y7a7qq3",
247
265
  label: "SearchInputWrapper"
248
- })(function (_ref12) {
249
- var theme = _ref12.theme;
266
+ })(function (_ref14) {
267
+ var theme = _ref14.theme;
250
268
  return {
251
269
  borderTopLeftRadius: theme.radius[2],
252
270
  borderTopRightRadius: theme.radius[2],
@@ -258,15 +276,15 @@ var SearchInputWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.
258
276
  borderRight: "1px solid ".concat(theme.palette.neutral[4]),
259
277
  position: 'relative'
260
278
  };
261
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchInputWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAmJkC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
279
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchInputWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAkKkC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
262
280
  exports.SearchInputWrapper = SearchInputWrapper;
263
281
  var SearchIcon = ( /*#__PURE__*/0, _base["default"])(_Icon["default"].Medium.MagnifierOriginal, process.env.NODE_ENV === "production" ? {
264
282
  target: "e1y7a7qq2"
265
283
  } : {
266
284
  target: "e1y7a7qq2",
267
285
  label: "SearchIcon"
268
- })(function (_ref13) {
269
- var theme = _ref13.theme;
286
+ })(function (_ref15) {
287
+ var theme = _ref15.theme;
270
288
  return {
271
289
  position: 'absolute',
272
290
  right: theme.space[4],
@@ -274,15 +292,15 @@ var SearchIcon = ( /*#__PURE__*/0, _base["default"])(_Icon["default"].Medium.Mag
274
292
  transform: 'translateY(-50%)',
275
293
  color: theme.palette.neutral[8]
276
294
  };
277
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAkK0B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
295
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAiL0B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
278
296
  exports.SearchIcon = SearchIcon;
279
297
  var ClearButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], process.env.NODE_ENV === "production" ? {
280
298
  target: "e1y7a7qq1"
281
299
  } : {
282
300
  target: "e1y7a7qq1",
283
301
  label: "ClearButton"
284
- })(function (_ref14) {
285
- var theme = _ref14.theme;
302
+ })(function (_ref16) {
303
+ var theme = _ref16.theme;
286
304
  return {
287
305
  position: 'absolute',
288
306
  right: theme.space[4],
@@ -292,31 +310,31 @@ var ClearButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], proces
292
310
  minWidth: 0,
293
311
  minHeight: 0
294
312
  };
295
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ClearButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA6K2B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
313
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.ClearButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA4L2B","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
296
314
  exports.ClearButton = ClearButton;
297
315
  var SearchInputStyled = ( /*#__PURE__*/0, _base["default"])(_Input["default"], process.env.NODE_ENV === "production" ? {
298
316
  target: "e1y7a7qq0"
299
317
  } : {
300
318
  target: "e1y7a7qq0",
301
319
  label: "SearchInputStyled"
302
- })(function (_ref15) {
303
- var theme = _ref15.theme;
320
+ })(function (_ref17) {
321
+ var theme = _ref17.theme;
304
322
  return {
305
323
  borderColor: 'transparent',
306
324
  width: '100%',
307
325
  paddingLeft: theme.space[4],
308
326
  paddingRight: theme.space[6]
309
327
  };
310
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchInputStyled), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AA0LiC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
328
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.MultiSelect.SearchInputStyled), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MultiSelect/elements.tsx"],"names":[],"mappings":"AAyMiC","file":"../../../src/MultiSelect/elements.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Overridable, getOverrides } from '../ThemeProvider'\nimport { motion } from 'framer-motion'\nimport RightTruncatedText from '../RightTruncatedText'\nimport Button from '../Button'\nimport Input from '../Input'\nimport Icon from '../Icon'\n\nexport const DefaultRowRenderer = styled(RightTruncatedText)(\n  ({ theme }) => ({\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2],\n    lineHeight: '32px'\n  }),\n  getOverrides(Overridable.MultiSelect.DefaultRowRenderer)\n)\n\nexport const NoRowRender = styled(DefaultRowRenderer)(({ theme }) => ({\n  fontSize: theme.fontSize[0],\n  color: theme.color.LightDisabled\n}))\n\nconst AnimatedListContainer: React.FC<React.ComponentProps<\n  typeof motion.div\n>> = props => {\n  const variants = {\n    flash: {\n      backgroundColor: '#c1e8f6', // theme.color.PrimaryLight - 30% lighter\n      transition: {\n        duration: 0.5,\n        ease: 'easeOut'\n      }\n    },\n    idle: {\n      backgroundColor: '#ffffff', // theme.color.PrimaryContrast\n      transition: {\n        duration: 0.5,\n        ease: 'easeIn'\n      }\n    }\n  }\n\n  return <motion.div {...props} initial=\"idle\" variants={variants} />\n}\n\nexport const ListContainer = styled(AnimatedListContainer)(\n  ({ theme }) => ({\n    fontSize: theme.fontSize[1],\n    margin: 0,\n    height: '10rem',\n    overflow: 'hidden',\n    ':focus': {\n      border: `1px solid ${theme.palette.neutral[4]}`\n    },\n    borderBottomLeftRadius: theme.radius[2],\n    borderBottomRightRadius: theme.radius[2],\n    borderTop: 0,\n    borderBottom: `1px solid ${theme.palette.neutral[4]}`,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    padding: `0 ${theme.space[2]} ${theme.space[2]} ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.ListContainer)\n)\n\nexport const ListItem = styled('div')<{\n  focused: boolean\n  selected: boolean\n  disabled: boolean\n}>(\n  () => ({\n    cursor: 'pointer',\n    position: 'relative',\n    userSelect: 'none',\n    width: 'calc(100% - 2px) !important', // the border doesn't get displayed otherwise,\n    border: `1px solid transparent`,\n    height: '32px !important',\n    ':focus': {\n      outline: 'none'\n    }\n  }),\n  ({ theme }) => ({\n    '&:hover': {\n      backgroundColor: theme.palette.primary[1],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, theme }) =>\n    focused && {\n      border: `1px solid ${theme.palette.primary[3]}`,\n      borderRadius: theme.radius[4]\n    },\n  ({ selected, theme }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4],\n      color: theme.palette.neutral[0]\n    },\n  ({ selected, theme }) => ({\n    '&:hover': selected && {\n      backgroundColor: theme.palette.primary[3],\n      borderRadius: theme.radius[4]\n    }\n  }),\n  ({ focused, selected, theme }) =>\n    focused &&\n    selected && {\n      border: `1px solid ${theme.palette.primary[1]}`,\n      color: theme.palette.neutral[0]\n    },\n  ({ disabled, theme }) =>\n    disabled && {\n      color: theme.palette.neutral[7],\n      backgroundColor: 'transparent',\n      '&:hover': {\n        backgroundColor: 'transparent'\n      }\n    },\n  ({ disabled, focused, selected }) =>\n    disabled &&\n    (focused || selected) && {\n      backgroundColor: 'transparent',\n      border: 'none'\n    },\n  getOverrides(Overridable.MultiSelect.ListItem)\n)\n\nexport const SelectContainer = styled('div')({\n  display: 'flex',\n  flex: '1 1 auto',\n  flexDirection: 'column'\n})\n\nexport const Counter = styled('span')(\n  ({ theme }) => ({\n    width: '100%',\n    textAlign: 'center',\n    marginTop: theme.space[2],\n    color: theme.palette.neutral[8],\n    fontSize: theme.fontSize[0]\n  }),\n  getOverrides(Overridable.MultiSelect.Counter)\n)\n\nexport const SelectSpacer = styled('div')(\n  ({ theme }) => ({\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    height: '0.5rem',\n    padding: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectSpacer)\n)\n\nexport const SelectDivider = styled('div')(\n  ({ theme }) => ({\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    margin: `0 ${theme.space[2]}`\n  }),\n  getOverrides(Overridable.MultiSelect.SelectDivider)\n)\n\nexport const SearchInputWrapper = styled('div')(\n  ({ theme }) => ({\n    borderTopLeftRadius: theme.radius[2],\n    borderTopRightRadius: theme.radius[2],\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n    borderTop: `1px solid ${theme.palette.neutral[4]}`,\n    borderBottom: 0,\n    borderLeft: `1px solid ${theme.palette.neutral[4]}`,\n    borderRight: `1px solid ${theme.palette.neutral[4]}`,\n    position: 'relative'\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputWrapper)\n)\n\nexport const SearchIcon = styled(Icon.Medium.MagnifierOriginal)<{}>(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchIcon)\n)\n\nexport const ClearButton = styled(Button)(\n  ({ theme }) => ({\n    position: 'absolute',\n    right: theme.space[4],\n    top: '50%',\n    transform: 'translateY(-50%)',\n    color: theme.palette.neutral[8],\n    minWidth: 0,\n    minHeight: 0\n  }),\n  getOverrides(Overridable.MultiSelect.ClearButton)\n)\n\nexport const SearchInputStyled = styled(Input)(\n  ({ theme }) => ({\n    borderColor: 'transparent',\n    width: '100%',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[6]\n  }),\n  getOverrides(Overridable.MultiSelect.SearchInputStyled)\n)\n\ntype SearchInputProps = {\n  onChange: (arg0: { name: string; value?: string }) => void\n  'data-instrumentation'?: string\n  name: string\n  value?: string\n  placeholder?: string\n}\nexport function SearchInput({\n  value = '',\n  onChange,\n  name,\n  'data-instrumentation': dataInstrumentation,\n  ...props\n}: SearchInputProps) {\n  return (\n    <SearchInputWrapper>\n      <SearchInputStyled\n        value={value}\n        name={name}\n        onChange={onChange}\n        data-instrumentation={dataInstrumentation}\n        {...props}\n      />\n      {value ? (\n        <ClearButton\n          plain\n          data-instrumentation={dataInstrumentation}\n          icon\n          onClick={() => onChange({ name, value: '' })}\n        >\n          <Icon.Medium.CircleFillCancel />\n        </ClearButton>\n      ) : (\n        <SearchIcon />\n      )}\n    </SearchInputWrapper>\n  )\n}\n"]} */");
311
329
  exports.SearchInputStyled = SearchInputStyled;
312
330
 
313
- function SearchInput(_ref16) {
314
- var _ref16$value = _ref16.value,
315
- value = _ref16$value === void 0 ? '' : _ref16$value,
316
- onChange = _ref16.onChange,
317
- name = _ref16.name,
318
- dataInstrumentation = _ref16['data-instrumentation'],
319
- props = _objectWithoutProperties(_ref16, _excluded);
331
+ function SearchInput(_ref18) {
332
+ var _ref18$value = _ref18.value,
333
+ value = _ref18$value === void 0 ? '' : _ref18$value,
334
+ onChange = _ref18.onChange,
335
+ name = _ref18.name,
336
+ dataInstrumentation = _ref18['data-instrumentation'],
337
+ props = _objectWithoutProperties(_ref18, _excluded);
320
338
 
321
339
  return (0, _jsxRuntime.jsxs)(SearchInputWrapper, {
322
340
  "data-gs": gs("src", "multiselect", "elements.tsx", "search-input", "search-input-wrapper"),
@@ -6,6 +6,7 @@ export declare const REMOVE_BUTTON_ID = "_SHUTTLE_REMOVE_BUTTON";
6
6
  export type Option = {
7
7
  name: string;
8
8
  value: string;
9
+ disabled?: boolean;
9
10
  };
10
11
  export type Options = Array<Option>;
11
12
  export type ShuttleProps = Omit<MultiSelectProps, 'rowRenderer' | 'initiallySelected' | 'onEnterKey' | 'filter' | 'onFilterChange' | 'inputName' | 'inputPlaceholder' | 'selectedLabel' | 'totalLabel'> & {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "28.26.0",
3
+ "version": "28.28.0",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",
@@ -58,6 +58,8 @@
58
58
  "lodash.clamp": "^4.0.3",
59
59
  "lodash.curry": "^4.1.1",
60
60
  "lodash.debounce": "^4.0.8",
61
+ "lodash.findindex": "^4.6.0",
62
+ "lodash.findlastindex": "^4.6.0",
61
63
  "lodash.has": "^4.5.2",
62
64
  "lodash.includes": "^4.3.0",
63
65
  "lodash.isempty": "^4.4.0",
@@ -128,6 +130,8 @@
128
130
  "@types/lodash.clamp": "^4.0.6",
129
131
  "@types/lodash.curry": "^4.1.6",
130
132
  "@types/lodash.debounce": "^4",
133
+ "@types/lodash.findindex": "^4",
134
+ "@types/lodash.findlastindex": "^4",
131
135
  "@types/lodash.has": "^4.5.6",
132
136
  "@types/lodash.includes": "^4.3.6",
133
137
  "@types/lodash.isempty": "^4.4.6",