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 +14 -0
- package/dist/es/Icon/staticTypes.d.ts +2 -0
- package/dist/es/Icon/types.js +26 -1
- package/dist/es/MultiSelect/MultiSelect.d.ts +8 -12
- package/dist/es/MultiSelect/MultiSelect.js +54 -8
- package/dist/es/MultiSelect/elements.d.ts +1 -0
- package/dist/es/MultiSelect/elements.js +51 -33
- package/dist/es/Shuttle/Shuttle.d.ts +1 -0
- package/package.json +5 -1
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']>;
|
package/dist/es/Icon/types.js
CHANGED
|
@@ -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
|
-
}),
|
|
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:
|
|
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 ?
|
|
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 ?
|
|
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
|
|
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:
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NdWx0aVNlbGVjdC9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUWtDIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9NdWx0aVNlbGVjdC9lbGVtZW50cy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE92ZXJyaWRhYmxlLCBnZXRPdmVycmlkZXMgfSBmcm9tICcuLi9UaGVtZVByb3ZpZGVyJ1xuaW1wb3J0IHsgbW90aW9uIH0gZnJvbSAnZnJhbWVyLW1vdGlvbidcbmltcG9ydCBSaWdodFRydW5jYXRlZFRleHQgZnJvbSAnLi4vUmlnaHRUcnVuY2F0ZWRUZXh0J1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgSW5wdXQgZnJvbSAnLi4vSW5wdXQnXG5pbXBvcnQgSWNvbiBmcm9tICcuLi9JY29uJ1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdFJvd1JlbmRlcmVyID0gc3R5bGVkKFJpZ2h0VHJ1bmNhdGVkVGV4dCkoXG4gICh7IHRoZW1lIH0pID0+ICh7XG4gICAgcGFkZGluZ0xlZnQ6IHRoZW1lLnNwYWNlWzJdLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUuc3BhY2VbMl0sXG4gICAgbGluZUhlaWdodDogJzMycHgnXG4gIH0pLFxuICBnZXRPdmVycmlkZXMoT3ZlcnJpZGFibGUuTXVsdGlTZWxlY3QuRGVmYXVsdFJvd1JlbmRlcmVyKVxuKVxuXG5leHBvcnQgY29uc3QgTm9Sb3dSZW5kZXIgPSBzdHlsZWQoRGVmYXVsdFJvd1JlbmRlcmVyKSgoeyB0aGVtZSB9KSA9PiAoe1xuICBmb250U2l6ZTogdGhlbWUuZm9udFNpemVbMF0sXG4gIGNvbG9yOiB0aGVtZS5jb2xvci5MaWdodERpc2FibGVkXG59KSlcblxuY29uc3QgQW5pbWF0ZWRMaXN0Q29udGFpbmVyOiBSZWFjdC5GQzxSZWFjdC5Db21wb25lbnRQcm9wczxcbiAgdHlwZW9mIG1vdGlvbi5kaXZcbj4+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NdWx0aVNlbGVjdC9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUIyQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvTXVsdGlTZWxlY3QvZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBPdmVycmlkYWJsZSwgZ2V0T3ZlcnJpZGVzIH0gZnJvbSAnLi4vVGhlbWVQcm92aWRlcidcbmltcG9ydCB7IG1vdGlvbiB9IGZyb20gJ2ZyYW1lci1tb3Rpb24nXG5pbXBvcnQgUmlnaHRUcnVuY2F0ZWRUZXh0IGZyb20gJy4uL1JpZ2h0VHJ1bmNhdGVkVGV4dCdcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vQnV0dG9uJ1xuaW1wb3J0IElucHV0IGZyb20gJy4uL0lucHV0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vSWNvbidcblxuZXhwb3J0IGNvbnN0IERlZmF1bHRSb3dSZW5kZXJlciA9IHN0eWxlZChSaWdodFRydW5jYXRlZFRleHQpKFxuICAoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS5zcGFjZVsyXSxcbiAgICBwYWRkaW5nUmlnaHQ6IHRoZW1lLnNwYWNlWzJdLFxuICAgIGxpbmVIZWlnaHQ6ICczMnB4J1xuICB9KSxcbiAgZ2V0T3ZlcnJpZGVzKE92ZXJyaWRhYmxlLk11bHRpU2VsZWN0LkRlZmF1bHRSb3dSZW5kZXJlcilcbilcblxuZXhwb3J0IGNvbnN0IE5vUm93UmVuZGVyID0gc3R5bGVkKERlZmF1bHRSb3dSZW5kZXJlcikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgZm9udFNpemU6IHRoZW1lLmZvbnRTaXplWzBdLFxuICBjb2xvcjogdGhlbWUuY29sb3IuTGlnaHREaXNhYmxlZFxufSkpXG5cbmNvbnN0IEFuaW1hdGVkTGlzdENvbnRhaW5lcjogUmVhY3QuRkM8UmVhY3QuQ29tcG9uZW50UHJvcHM8XG4gIHR5cGVvZiBtb3Rpb24uZGl2XG4+PiA9IHByb3BzID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NdWx0aVNlbGVjdC9lbGVtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkM2QiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvTXVsdGlTZWxlY3QvZWxlbWVudHMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBPdmVycmlkYWJsZSwgZ2V0T3ZlcnJpZGVzIH0gZnJvbSAnLi4vVGhlbWVQcm92aWRlcidcbmltcG9ydCB7IG1vdGlvbiB9IGZyb20gJ2ZyYW1lci1tb3Rpb24nXG5pbXBvcnQgUmlnaHRUcnVuY2F0ZWRUZXh0IGZyb20gJy4uL1JpZ2h0VHJ1bmNhdGVkVGV4dCdcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vQnV0dG9uJ1xuaW1wb3J0IElucHV0IGZyb20gJy4uL0lucHV0J1xuaW1wb3J0IEljb24gZnJvbSAnLi4vSWNvbidcblxuZXhwb3J0IGNvbnN0IERlZmF1bHRSb3dSZW5kZXJlciA9IHN0eWxlZChSaWdodFRydW5jYXRlZFRleHQpKFxuICAoeyB0aGVtZSB9KSA9PiAoe1xuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS5zcGFjZVsyXSxcbiAgICBwYWRkaW5nUmlnaHQ6IHRoZW1lLnNwYWNlWzJdLFxuICAgIGxpbmVIZWlnaHQ6ICczMnB4J1xuICB9KSxcbiAgZ2V0T3ZlcnJpZGVzKE92ZXJyaWRhYmxlLk11bHRpU2VsZWN0LkRlZmF1bHRSb3dSZW5kZXJlcilcbilcblxuZXhwb3J0IGNvbnN0IE5vUm93UmVuZGVyID0gc3R5bGVkKERlZmF1bHRSb3dSZW5kZXJlcikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgZm9udFNpemU6IHRoZW1lLmZvbnRTaXplWzBdLFxuICBjb2xvcjogdGhlbWUuY29sb3IuTGlnaHREaXNhYmxlZFxufSkpXG5cbmNvbnN0IEFuaW1hdGVkTGlzdENvbnRhaW5lcjogUmVhY3QuRkM8UmVhY3QuQ29tcG9uZW50UHJvcHM8XG4gIHR5cGVvZiBtb3Rpb24uZGl2XG4+PiA9IHByb3BzID0+
|
|
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
|
-
},
|
|
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,
|
|
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 (
|
|
205
|
-
var 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,
|
|
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 (
|
|
221
|
-
var 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,
|
|
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 (
|
|
236
|
-
var 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,
|
|
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 (
|
|
249
|
-
var 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,
|
|
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 (
|
|
269
|
-
var 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,
|
|
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 (
|
|
285
|
-
var 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,
|
|
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 (
|
|
303
|
-
var 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,
|
|
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(
|
|
314
|
-
var
|
|
315
|
-
value =
|
|
316
|
-
onChange =
|
|
317
|
-
name =
|
|
318
|
-
dataInstrumentation =
|
|
319
|
-
props = _objectWithoutProperties(
|
|
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.
|
|
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",
|