@orfium/ictinus 4.67.2 → 4.69.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/dist/components/Filter/components/MultiFilter/MultiFilter.js +13 -2
- package/dist/components/MultiTextFieldBase/MultiTextFieldBase.js +9 -6
- package/dist/components/MultiTextFieldBase/hooks.d.ts +2 -2
- package/dist/components/MultiTextFieldBase/hooks.js +7 -15
- package/dist/components/SearchField/SearchField.d.ts +1 -0
- package/dist/components/SearchField/SearchFieldShowcase.d.ts +1 -0
- package/dist/components/Select/Select.d.ts +1 -0
- package/dist/components/Select/Select.js +23 -11
- package/dist/components/Select/components/SelectMenu/SelectMenu.style.d.ts +1 -0
- package/dist/components/TextField/TextField.d.ts +4 -0
- package/dist/components/TextField/TextField.js +32 -8
- package/dist/components/TextField/hooks/useMultiTextFieldUtils.d.ts +2 -2
- package/dist/components/TextField/hooks/useMultiTextFieldUtils.js +7 -2
- package/dist/components/TextInputBase/TextInputBase.js +3 -1
- package/dist/components/TextInputBase/TextInputBase.style.d.ts +2 -2
- package/dist/components/TextInputBase/TextInputBase.style.js +14 -8
- package/package.json +1 -1
|
@@ -29,10 +29,20 @@ var MultiFilter = function MultiFilter(_ref) {
|
|
|
29
29
|
searchValue = _ref.searchValue,
|
|
30
30
|
isLoading = _ref.isLoading,
|
|
31
31
|
hasSelectAllOption = _ref.hasSelectAllOption;
|
|
32
|
+
|
|
33
|
+
var filterInputRef = _react["default"].useRef(null);
|
|
34
|
+
|
|
35
|
+
var handleClick = function handleClick() {
|
|
36
|
+
var _filterInputRef$curre;
|
|
37
|
+
|
|
38
|
+
filterInputRef == null ? void 0 : (_filterInputRef$curre = filterInputRef.current) == null ? void 0 : _filterInputRef$curre.focus();
|
|
39
|
+
};
|
|
40
|
+
|
|
32
41
|
return (0, _react2.jsx)("div", {
|
|
33
42
|
css: (0, _Filter.menuStyle)()
|
|
34
43
|
}, (0, _react2.jsx)("div", {
|
|
35
|
-
css: (0, _MultiFilter.textFieldWrapper)()
|
|
44
|
+
css: (0, _MultiFilter.textFieldWrapper)(),
|
|
45
|
+
onClick: handleClick
|
|
36
46
|
}, (0, _react2.jsx)(_MultiTextFieldBase["default"], {
|
|
37
47
|
selectedOptions: selectedItems,
|
|
38
48
|
onInput: onInput,
|
|
@@ -42,7 +52,8 @@ var MultiFilter = function MultiFilter(_ref) {
|
|
|
42
52
|
value: searchValue,
|
|
43
53
|
placeholder: "Search",
|
|
44
54
|
isResponsive: true,
|
|
45
|
-
isLoading: isLoading
|
|
55
|
+
isLoading: isLoading,
|
|
56
|
+
ref: filterInputRef
|
|
46
57
|
})), (0, _react2.jsx)("div", {
|
|
47
58
|
css: (0, _MultiFilter.optionsWrapper)()
|
|
48
59
|
}, (0, _react2.jsx)(_Options["default"], {
|
|
@@ -5,6 +5,8 @@ exports["default"] = void 0;
|
|
|
5
5
|
|
|
6
6
|
var _useTheme = _interopRequireDefault(require("../../hooks/useTheme"));
|
|
7
7
|
|
|
8
|
+
var _lodash = require("lodash");
|
|
9
|
+
|
|
8
10
|
var _omit = _interopRequireDefault(require("lodash/omit"));
|
|
9
11
|
|
|
10
12
|
var _react = _interopRequireWildcard(require("react"));
|
|
@@ -27,7 +29,7 @@ var _TextInputBase2 = require("../TextInputBase/TextInputBase.style");
|
|
|
27
29
|
|
|
28
30
|
var _react2 = require("@emotion/react");
|
|
29
31
|
|
|
30
|
-
var _excluded = ["selectedOptions", "value", "disabled", "locked", "status", "lean", "dark", "readOnly", "label", "id", "placeholder", "required", "styleType", "onOptionDelete", "onClearAllOptions", "isLoading", "
|
|
32
|
+
var _excluded = ["selectedOptions", "value", "disabled", "locked", "status", "lean", "dark", "readOnly", "label", "id", "placeholder", "required", "styleType", "onOptionDelete", "onClearAllOptions", "isLoading", "isInteractive", "isResponsive", "isTextfield", "onKeyDown", "sx"];
|
|
31
33
|
|
|
32
34
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
33
35
|
|
|
@@ -57,13 +59,14 @@ var MultiTextFieldBase = /*#__PURE__*/_react["default"].forwardRef(function (pro
|
|
|
57
59
|
onOptionDelete = props.onOptionDelete,
|
|
58
60
|
onClearAllOptions = props.onClearAllOptions,
|
|
59
61
|
isLoading = props.isLoading,
|
|
60
|
-
rightIcon = props.rightIcon,
|
|
61
62
|
_props$isInteractive = props.isInteractive,
|
|
62
63
|
isInteractive = _props$isInteractive === void 0 ? true : _props$isInteractive,
|
|
63
64
|
_props$isResponsive = props.isResponsive,
|
|
64
65
|
isResponsive = _props$isResponsive === void 0 ? false : _props$isResponsive,
|
|
65
66
|
_props$isTextfield = props.isTextfield,
|
|
66
67
|
isTextfield = _props$isTextfield === void 0 ? false : _props$isTextfield,
|
|
68
|
+
onKeyDown = props.onKeyDown,
|
|
69
|
+
sx = props.sx,
|
|
67
70
|
rest = _objectWithoutPropertiesLoose(props, _excluded);
|
|
68
71
|
|
|
69
72
|
var theme = (0, _useTheme["default"])();
|
|
@@ -77,9 +80,9 @@ var MultiTextFieldBase = /*#__PURE__*/_react["default"].forwardRef(function (pro
|
|
|
77
80
|
locked: locked,
|
|
78
81
|
hasValue: hasValue,
|
|
79
82
|
value: value,
|
|
80
|
-
rightIcon: rightIcon,
|
|
81
83
|
onOptionDelete: onOptionDelete,
|
|
82
|
-
onClearAllOptions: onClearAllOptions
|
|
84
|
+
onClearAllOptions: onClearAllOptions,
|
|
85
|
+
onKeyDown: onKeyDown
|
|
83
86
|
}),
|
|
84
87
|
inputPlaceholder = _useMultiTextFieldBas.inputPlaceholder,
|
|
85
88
|
handleKeyDown = _useMultiTextFieldBas.handleKeyDown,
|
|
@@ -119,13 +122,13 @@ var MultiTextFieldBase = /*#__PURE__*/_react["default"].forwardRef(function (pro
|
|
|
119
122
|
styleType: styleType
|
|
120
123
|
}, rest, {
|
|
121
124
|
isInteractive: isInteractive,
|
|
122
|
-
sx: (0, _MultiTextFieldBase.textInputBaseOverrides)({
|
|
125
|
+
sx: (0, _lodash.merge)((0, _MultiTextFieldBase.textInputBaseOverrides)({
|
|
123
126
|
hasValue: hasValue,
|
|
124
127
|
isLoading: isLoading,
|
|
125
128
|
hasLabel: hasLabel,
|
|
126
129
|
isResponsive: isResponsive,
|
|
127
130
|
isTextfield: isTextfield
|
|
128
|
-
})(theme)
|
|
131
|
+
})(theme), sx)
|
|
129
132
|
}), (0, _react2.jsx)("div", {
|
|
130
133
|
css: (0, _MultiTextFieldBase.inputContainer)()
|
|
131
134
|
}, chips, (0, _react2.jsx)("input", _extends({
|
|
@@ -5,10 +5,10 @@ declare type Props = {
|
|
|
5
5
|
hasValue: boolean;
|
|
6
6
|
isTextfield?: boolean;
|
|
7
7
|
} & Pick<MultiTextFieldBase, 'value' | 'onOptionDelete' | 'onClearAllOptions'> & Omit<TextFieldProps, 'size'>;
|
|
8
|
-
declare const useMultiTextFieldBaseUtils: ({ isTextfield, label, placeholder, required, locked, hasValue, value,
|
|
8
|
+
declare const useMultiTextFieldBaseUtils: ({ isTextfield, label, placeholder, required, locked, hasValue, value, onOptionDelete, onClearAllOptions, onKeyDown, }: Props) => {
|
|
9
9
|
inputPlaceholder: string | undefined;
|
|
10
10
|
handleKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;
|
|
11
|
-
icon: JSX.Element | undefined;
|
|
11
|
+
icon: import("@emotion/react/jsx-runtime").JSX.Element | undefined;
|
|
12
12
|
hasLabel: boolean;
|
|
13
13
|
TextfieldRef: React.RefObject<HTMLDivElement>;
|
|
14
14
|
};
|
|
@@ -25,9 +25,9 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
|
|
|
25
25
|
locked = _ref.locked,
|
|
26
26
|
hasValue = _ref.hasValue,
|
|
27
27
|
value = _ref.value,
|
|
28
|
-
rightIcon = _ref.rightIcon,
|
|
29
28
|
onOptionDelete = _ref.onOptionDelete,
|
|
30
|
-
onClearAllOptions = _ref.onClearAllOptions
|
|
29
|
+
onClearAllOptions = _ref.onClearAllOptions,
|
|
30
|
+
onKeyDown = _ref.onKeyDown;
|
|
31
31
|
|
|
32
32
|
var TextfieldRef = _react["default"].useRef(null);
|
|
33
33
|
|
|
@@ -60,21 +60,13 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
|
|
|
60
60
|
if (value === '' && event.key === 'Backspace') {
|
|
61
61
|
onOptionDelete();
|
|
62
62
|
}
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
var icon = (0, _react.useMemo)(function () {
|
|
66
|
-
if (rightIcon) {
|
|
67
|
-
if (typeof rightIcon === 'string') {
|
|
68
|
-
return (0, _react2.jsx)(_Icon["default"], {
|
|
69
|
-
name: rightIcon,
|
|
70
|
-
size: 20,
|
|
71
|
-
color: theme.utils.getColor('lightGrey', 650)
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
63
|
|
|
75
|
-
|
|
64
|
+
if (onKeyDown) {
|
|
65
|
+
onKeyDown(event);
|
|
76
66
|
}
|
|
67
|
+
};
|
|
77
68
|
|
|
69
|
+
var icon = (0, _react.useMemo)(function () {
|
|
78
70
|
var handleClick = function handleClick() {
|
|
79
71
|
if (!hasValue || locked) {
|
|
80
72
|
return undefined;
|
|
@@ -94,7 +86,7 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
|
|
|
94
86
|
}
|
|
95
87
|
|
|
96
88
|
return undefined;
|
|
97
|
-
}, [hasValue, iconName, locked, onClearAllOptions,
|
|
89
|
+
}, [hasValue, iconName, locked, onClearAllOptions, theme.utils]);
|
|
98
90
|
return {
|
|
99
91
|
inputPlaceholder: inputPlaceholder,
|
|
100
92
|
handleKeyDown: handleKeyDown,
|
|
@@ -18,5 +18,6 @@ declare const SearchField: React.ForwardRefExoticComponent<Props & {
|
|
|
18
18
|
onMultiValueCreate?: ((value?: string | undefined) => void) | undefined;
|
|
19
19
|
onMultiValueDelete?: ((value?: string | undefined) => void) | undefined;
|
|
20
20
|
onClearAllValues?: (() => void) | undefined;
|
|
21
|
+
multiValuesHandler?: ((tags: string) => string | string[]) | undefined;
|
|
21
22
|
} & import("components/TextInputBase").Props & TestProps & React.RefAttributes<HTMLInputElement>>;
|
|
22
23
|
export default SearchField;
|
|
@@ -15,6 +15,7 @@ declare const SearchFieldShowcase: ({ disabled, placeholder, initialValue, }: Pa
|
|
|
15
15
|
onMultiValueCreate?: ((value?: string | undefined) => void) | undefined;
|
|
16
16
|
onMultiValueDelete?: ((value?: string | undefined) => void) | undefined;
|
|
17
17
|
onClearAllValues?: (() => void) | undefined;
|
|
18
|
+
multiValuesHandler?: ((tags: string) => string | string[]) | undefined;
|
|
18
19
|
} & import("../TextInputBase").Props> & {
|
|
19
20
|
initialValue?: string | undefined;
|
|
20
21
|
}) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
@@ -113,5 +113,6 @@ declare const Select: React.ForwardRefExoticComponent<{
|
|
|
113
113
|
onMultiValueCreate?: ((value?: string | undefined) => void) | undefined;
|
|
114
114
|
onMultiValueDelete?: ((value?: string | undefined) => void) | undefined;
|
|
115
115
|
onClearAllValues?: (() => void) | undefined;
|
|
116
|
+
multiValuesHandler?: ((tags: string) => string | string[]) | undefined;
|
|
116
117
|
} & import("../TextInputBase").Props & Partial<Omit<React.InputHTMLAttributes<HTMLInputElement>, "size">> & TestProps & React.RefAttributes<HTMLInputElement>>;
|
|
117
118
|
export default Select;
|
|
@@ -157,15 +157,6 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
|
|
|
157
157
|
handleSelectedOption(option);
|
|
158
158
|
};
|
|
159
159
|
|
|
160
|
-
var handleOnKeyDown = function handleOnKeyDown(e) {
|
|
161
|
-
var isBackspaceKey = e.keyCode === 8;
|
|
162
|
-
|
|
163
|
-
if (isBackspaceKey) {
|
|
164
|
-
setInputValue(emptyValue);
|
|
165
|
-
debouncedOnChange('');
|
|
166
|
-
}
|
|
167
|
-
};
|
|
168
|
-
|
|
169
160
|
var debouncedOnChange = _react["default"].useCallback((0, _debounce["default"])(function (term) {
|
|
170
161
|
asyncSearch(term);
|
|
171
162
|
}, 400), []);
|
|
@@ -286,6 +277,25 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
|
|
|
286
277
|
|
|
287
278
|
|
|
288
279
|
var hasNoOptionsAndIsCreatable = creatable && filteredOptions.length === 1 && filteredOptions[0].isCreated;
|
|
280
|
+
|
|
281
|
+
var handleSingleKeyDown = function handleSingleKeyDown(event) {
|
|
282
|
+
var isBackspace = event.key === 'Backspace';
|
|
283
|
+
|
|
284
|
+
if (isBackspace) {
|
|
285
|
+
setInputValue(emptyValue);
|
|
286
|
+
debouncedOnChange('');
|
|
287
|
+
}
|
|
288
|
+
};
|
|
289
|
+
|
|
290
|
+
var handleMultiKeyDown = function handleMultiKeyDown(event) {
|
|
291
|
+
var isEnter = event.key === 'Enter';
|
|
292
|
+
|
|
293
|
+
if (hasNoOptionsAndIsCreatable && isEnter) {
|
|
294
|
+
handleMultiSelectOptionClick(filteredOptions[0]);
|
|
295
|
+
setSearchValue('');
|
|
296
|
+
}
|
|
297
|
+
};
|
|
298
|
+
|
|
289
299
|
return (0, _react2.jsx)(_ClickAwayListener["default"], {
|
|
290
300
|
onClick: function onClick() {
|
|
291
301
|
setOpen(false);
|
|
@@ -314,11 +324,13 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
|
|
|
314
324
|
}, restInputProps, {
|
|
315
325
|
status: status,
|
|
316
326
|
value: textFieldValue,
|
|
317
|
-
|
|
327
|
+
ref: combinedRefs,
|
|
328
|
+
autoComplete: "off",
|
|
329
|
+
onKeyDown: handleMultiKeyDown
|
|
318
330
|
})) : (0, _react2.jsx)(_TextField["default"], _extends({
|
|
319
331
|
styleType: styleType,
|
|
320
332
|
rightIcon: rightIconRender,
|
|
321
|
-
onKeyDown:
|
|
333
|
+
onKeyDown: handleSingleKeyDown,
|
|
322
334
|
onInput: handleOnInput,
|
|
323
335
|
onChange: ON_CHANGE_MOCK,
|
|
324
336
|
readOnly: !isSearchable,
|
|
@@ -22,5 +22,6 @@ export declare const optionStyle: ({ selected, size, noResultsExist, }: {
|
|
|
22
22
|
onMultiValueCreate?: ((value?: string | undefined) => void) | undefined;
|
|
23
23
|
onMultiValueDelete?: ((value?: string | undefined) => void) | undefined;
|
|
24
24
|
onClearAllValues?: (() => void) | undefined;
|
|
25
|
+
multiValuesHandler?: ((tags: string) => string | string[]) | undefined;
|
|
25
26
|
} & import("../../../TextInputBase").Props) => (theme: Theme) => SerializedStyles;
|
|
26
27
|
export declare const menuStyle: ({ status, size, isVirtualized }: Props & TextFieldProps) => (theme: Theme) => SerializedStyles;
|
|
@@ -29,6 +29,8 @@ export declare type Props = {
|
|
|
29
29
|
onMultiValueDelete?: (value?: string) => void;
|
|
30
30
|
/** A callback for when all values are deleted (the Clear All icon is clicked) */
|
|
31
31
|
onClearAllValues?: () => void;
|
|
32
|
+
/** The handler of multi values. If you pass a different handler function here it will change the way multi values are being calculated */
|
|
33
|
+
multiValuesHandler?: (tags: string) => string | string[];
|
|
32
34
|
} & TextInputWrapperProps;
|
|
33
35
|
export declare type InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;
|
|
34
36
|
declare const TextField: React.ForwardRefExoticComponent<{
|
|
@@ -59,5 +61,7 @@ declare const TextField: React.ForwardRefExoticComponent<{
|
|
|
59
61
|
onMultiValueDelete?: ((value?: string | undefined) => void) | undefined;
|
|
60
62
|
/** A callback for when all values are deleted (the Clear All icon is clicked) */
|
|
61
63
|
onClearAllValues?: (() => void) | undefined;
|
|
64
|
+
/** The handler of multi values. If you pass a different handler function here it will change the way multi values are being calculated */
|
|
65
|
+
multiValuesHandler?: ((tags: string) => string | string[]) | undefined;
|
|
62
66
|
} & TextInputWrapperProps & Partial<Omit<React.InputHTMLAttributes<HTMLInputElement>, "size">> & TestProps & React.RefAttributes<HTMLInputElement>>;
|
|
63
67
|
export default TextField;
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
exports.__esModule = true;
|
|
4
4
|
exports["default"] = void 0;
|
|
5
5
|
|
|
6
|
+
var _useCombinedRefs = _interopRequireDefault(require("../../hooks/useCombinedRefs"));
|
|
7
|
+
|
|
6
8
|
var _useTheme = _interopRequireDefault(require("../../hooks/useTheme"));
|
|
7
9
|
|
|
8
10
|
var _omit = _interopRequireDefault(require("lodash/omit"));
|
|
@@ -27,7 +29,7 @@ var _TextInputBase2 = require("../TextInputBase/TextInputBase.style");
|
|
|
27
29
|
|
|
28
30
|
var _react2 = require("@emotion/react");
|
|
29
31
|
|
|
30
|
-
var _excluded = ["id", "rightIcon", "leftIcon", "label", "placeholder", "required", "disabled", "locked", "size", "dark", "lean", "hintMsg", "styleType", "readOnly", "status", "hasMinWidthCompat", "onInput", "multi", "multiValues", "maxMultiValues", "onMultiValueCreate", "onMultiValueDelete", "onClearAllValues"];
|
|
32
|
+
var _excluded = ["id", "rightIcon", "leftIcon", "label", "placeholder", "required", "disabled", "locked", "size", "dark", "lean", "hintMsg", "styleType", "readOnly", "status", "hasMinWidthCompat", "onInput", "multi", "multiValues", "maxMultiValues", "onMultiValueCreate", "onMultiValueDelete", "onClearAllValues", "multiValuesHandler"];
|
|
31
33
|
|
|
32
34
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
33
35
|
|
|
@@ -45,7 +47,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
45
47
|
} : {
|
|
46
48
|
name: "1rlc0zw-TextField",
|
|
47
49
|
styles: "width:100% ;label:TextField;",
|
|
48
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
50
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AAgJiB","file":"../../../src/components/TextField/TextField.tsx","sourcesContent":["import useCombinedRefs from 'hooks/useCombinedRefs';\nimport useTheme from 'hooks/useTheme';\nimport omit from 'lodash/omit';\nimport React, { InputHTMLAttributes } from 'react';\nimport { DEFAULT_SIZE } from 'utils/size-utils';\n\nimport { TestProps } from '../../utils/types';\nimport Icon from '../Icon';\nimport Label from '../Label';\nimport { IconWrapper } from './components/commons';\nimport useMultiTextFieldUtils from './hooks/useMultiTextFieldUtils';\nimport { AcceptedIconNames } from 'components/Icon/types';\nimport MultiTextFieldBase from 'components/MultiTextFieldBase/MultiTextFieldBase';\nimport { SelectOption } from 'components/Select/Select';\nimport TextInputBase, { Props as TextInputWrapperProps } from 'components/TextInputBase';\nimport { inputStyle } from 'components/TextInputBase/TextInputBase.style';\n\nexport type Props = {\n  /** The id of the text field that will be used as for in label too */\n  id?: string;\n  /** Callback fired when the `input` is blurred. */\n  onBlur?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` is changed. */\n  onChange?: React.ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` is focused. */\n  onFocus?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` has a key down event. */\n  onKeyDown?: React.KeyboardEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` value typed is changed */\n  onInput?: React.EventHandler<any>;\n  /** @deprecated This is a compatibility prop that will be removed in the next version, along with the min-width value\n   * of the TextField. It will be replaced by a fullWidth prop. */\n  hasMinWidthCompat?: boolean;\n  /** If true the user can enter multiple values by pressing 'Enter' */\n  multi?: boolean;\n  /** The initial multi values */\n  multiValues?: string[];\n  /** Maximum multi values */\n  maxMultiValues?: number;\n  /** A callback for when a Chip value is created */\n  onMultiValueCreate?: (value?: string) => void;\n  /** A callback for when a Chip value is deleted */\n  onMultiValueDelete?: (value?: string) => void;\n  /** A callback for when all values are deleted (the Clear All icon is clicked) */\n  onClearAllValues?: () => void;\n  /** The handler of multi values. If you pass a different handler function here it will change the way multi values are being calculated */\n  multiValuesHandler?: (tags: string) => string | string[];\n} & TextInputWrapperProps;\n\nexport type InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;\n\nconsole.warn(\n  'Deprecation warning! min-width will be removed from the component in v5 of ictinus. ' +\n    'hasMinWidthCompat prop has been added to temporarily disable min-width when necessary'\n);\n\nconst TextField = React.forwardRef<HTMLInputElement, Props & InputProps & TestProps>(\n  (props, ref) => {\n    const {\n      id = undefined,\n      rightIcon = null,\n      leftIcon = null,\n      label,\n      placeholder = '',\n      required = false,\n      disabled,\n      locked = false,\n      size = DEFAULT_SIZE,\n      dark = false,\n      lean,\n      hintMsg: __hintMsg,\n      styleType: __styleType,\n      readOnly,\n      status,\n      hasMinWidthCompat = true,\n      onInput,\n      multi = false,\n      multiValues = [],\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      multiValuesHandler = (value) => value,\n      ...rest\n    } = props;\n    const theme = useTheme();\n\n    const inputRef = React.useRef<HTMLInputElement>(null);\n    const combinedRefs = useCombinedRefs(inputRef, ref);\n\n    const getIcon = (icon: AcceptedIconNames | JSX.Element | null) =>\n      icon ? (\n        typeof icon === 'string' ? (\n          <Icon\n            name={icon as AcceptedIconNames}\n            size={24}\n            color={theme.utils.getColor('lightGrey', 650)}\n          />\n        ) : (\n          icon\n        )\n      ) : null;\n\n    const handleClick = () => {\n      if (!locked && !disabled) {\n        combinedRefs.current?.focus();\n      }\n    };\n\n    const {\n      inputValue,\n      values,\n      handleValueDelete,\n      handleClearAllValues,\n      handleKeyDown,\n      handleTyping,\n    } = useMultiTextFieldUtils({\n      multiValues,\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      onInput,\n      multiValuesHandler,\n    });\n\n    return (\n      <div onClick={handleClick}>\n        {multi ? (\n          <MultiTextFieldBase\n            {...props}\n            isTextfield\n            onOptionDelete={handleValueDelete as (option?: string | SelectOption) => void}\n            onClearAllOptions={handleClearAllValues}\n            label={label}\n            onInput={handleTyping}\n            onKeyDown={handleKeyDown}\n            selectedOptions={values}\n            value={inputValue}\n            ref={combinedRefs}\n          />\n        ) : (\n          <TextInputBase {...props} hasMinWidthCompat={hasMinWidthCompat}>\n            {leftIcon && <IconWrapper iconPosition={'left'}>{getIcon(leftIcon)}</IconWrapper>}\n            <div css={{ width: '100% ' }}>\n              <input\n                readOnly={readOnly}\n                css={inputStyle({ label, placeholder, size, dark, lean, disabled, locked })}\n                placeholder={\n                  !label && placeholder ? `${placeholder} ${required ? '*' : ''}` : label\n                }\n                required={required}\n                id={id}\n                disabled={disabled || locked}\n                onInput={onInput}\n                {...omit(rest, 'dataTestId')}\n                ref={combinedRefs}\n              />\n              {label && (\n                <Label\n                  size={size}\n                  htmlFor={id}\n                  label={label}\n                  required={required}\n                  animateToTop={Boolean(rest.value)}\n                  error={status === 'error'}\n                />\n              )}\n            </div>\n            {rightIcon && !locked && (\n              <IconWrapper iconPosition={'right'}>{getIcon(rightIcon)}</IconWrapper>\n            )}\n            {locked && (\n              <IconWrapper iconPosition={'right'}>\n                <Icon\n                  name=\"lock\"\n                  size={size === 'md' ? 20 : 16}\n                  color={theme.utils.getColor('lightGrey', 650)}\n                />\n              </IconWrapper>\n            )}\n          </TextInputBase>\n        )}\n      </div>\n    );\n  }\n);\n\nTextField.displayName = 'TextField';\n\nexport default TextField;\n"]} */",
|
|
49
51
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
50
52
|
};
|
|
51
53
|
|
|
@@ -84,10 +86,18 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
84
86
|
onMultiValueCreate = props.onMultiValueCreate,
|
|
85
87
|
onMultiValueDelete = props.onMultiValueDelete,
|
|
86
88
|
onClearAllValues = props.onClearAllValues,
|
|
89
|
+
_props$multiValuesHan = props.multiValuesHandler,
|
|
90
|
+
multiValuesHandler = _props$multiValuesHan === void 0 ? function (value) {
|
|
91
|
+
return value;
|
|
92
|
+
} : _props$multiValuesHan,
|
|
87
93
|
rest = _objectWithoutPropertiesLoose(props, _excluded);
|
|
88
94
|
|
|
89
95
|
var theme = (0, _useTheme["default"])();
|
|
90
96
|
|
|
97
|
+
var inputRef = _react["default"].useRef(null);
|
|
98
|
+
|
|
99
|
+
var combinedRefs = (0, _useCombinedRefs["default"])(inputRef, ref);
|
|
100
|
+
|
|
91
101
|
var getIcon = function getIcon(icon) {
|
|
92
102
|
return icon ? typeof icon === 'string' ? (0, _react2.jsx)(_Icon["default"], {
|
|
93
103
|
name: icon,
|
|
@@ -96,13 +106,22 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
96
106
|
}) : icon : null;
|
|
97
107
|
};
|
|
98
108
|
|
|
109
|
+
var handleClick = function handleClick() {
|
|
110
|
+
if (!locked && !disabled) {
|
|
111
|
+
var _combinedRefs$current;
|
|
112
|
+
|
|
113
|
+
(_combinedRefs$current = combinedRefs.current) == null ? void 0 : _combinedRefs$current.focus();
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
|
|
99
117
|
var _useMultiTextFieldUti = (0, _useMultiTextFieldUtils["default"])({
|
|
100
118
|
multiValues: multiValues,
|
|
101
119
|
maxMultiValues: maxMultiValues,
|
|
102
120
|
onMultiValueCreate: onMultiValueCreate,
|
|
103
121
|
onMultiValueDelete: onMultiValueDelete,
|
|
104
122
|
onClearAllValues: onClearAllValues,
|
|
105
|
-
onInput: onInput
|
|
123
|
+
onInput: onInput,
|
|
124
|
+
multiValuesHandler: multiValuesHandler
|
|
106
125
|
}),
|
|
107
126
|
inputValue = _useMultiTextFieldUti.inputValue,
|
|
108
127
|
values = _useMultiTextFieldUti.values,
|
|
@@ -111,7 +130,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
111
130
|
handleKeyDown = _useMultiTextFieldUti.handleKeyDown,
|
|
112
131
|
handleTyping = _useMultiTextFieldUti.handleTyping;
|
|
113
132
|
|
|
114
|
-
return
|
|
133
|
+
return (0, _react2.jsx)("div", {
|
|
134
|
+
onClick: handleClick
|
|
135
|
+
}, multi ? (0, _react2.jsx)(_MultiTextFieldBase["default"], _extends({}, props, {
|
|
115
136
|
isTextfield: true,
|
|
116
137
|
onOptionDelete: handleValueDelete,
|
|
117
138
|
onClearAllOptions: handleClearAllValues,
|
|
@@ -119,8 +140,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
119
140
|
onInput: handleTyping,
|
|
120
141
|
onKeyDown: handleKeyDown,
|
|
121
142
|
selectedOptions: values,
|
|
122
|
-
value: inputValue
|
|
123
|
-
|
|
143
|
+
value: inputValue,
|
|
144
|
+
ref: combinedRefs
|
|
145
|
+
})) : (0, _react2.jsx)(_TextInputBase["default"], _extends({}, props, {
|
|
124
146
|
hasMinWidthCompat: hasMinWidthCompat
|
|
125
147
|
}), leftIcon && (0, _react2.jsx)(_commons.IconWrapper, {
|
|
126
148
|
iconPosition: 'left'
|
|
@@ -133,7 +155,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
133
155
|
placeholder: placeholder,
|
|
134
156
|
size: size,
|
|
135
157
|
dark: dark,
|
|
136
|
-
lean: lean
|
|
158
|
+
lean: lean,
|
|
159
|
+
disabled: disabled,
|
|
160
|
+
locked: locked
|
|
137
161
|
}),
|
|
138
162
|
placeholder: !label && placeholder ? placeholder + " " + (required ? '*' : '') : label,
|
|
139
163
|
required: required,
|
|
@@ -141,7 +165,7 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
|
|
|
141
165
|
disabled: disabled || locked,
|
|
142
166
|
onInput: onInput
|
|
143
167
|
}, (0, _omit["default"])(rest, 'dataTestId'), {
|
|
144
|
-
ref:
|
|
168
|
+
ref: combinedRefs
|
|
145
169
|
})), label && (0, _react2.jsx)(_Label["default"], {
|
|
146
170
|
size: size,
|
|
147
171
|
htmlFor: id,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Props as TextFieldProps } from '../TextField';
|
|
2
|
-
declare type Props = Pick<TextFieldProps, 'multiValues' | 'maxMultiValues' | 'onMultiValueCreate' | 'onMultiValueDelete' | 'onClearAllValues' | 'onInput'>;
|
|
3
|
-
declare const useMultiTextFieldUtils: ({ multiValues, maxMultiValues, onMultiValueCreate, onMultiValueDelete, onClearAllValues, onInput, }: Props) => {
|
|
2
|
+
declare type Props = Pick<TextFieldProps, 'multiValues' | 'maxMultiValues' | 'onMultiValueCreate' | 'onMultiValueDelete' | 'onClearAllValues' | 'onInput' | 'multiValuesHandler'>;
|
|
3
|
+
declare const useMultiTextFieldUtils: ({ multiValues, maxMultiValues, onMultiValueCreate, onMultiValueDelete, onClearAllValues, onInput, multiValuesHandler, }: Props) => {
|
|
4
4
|
values: string[];
|
|
5
5
|
handleValueDelete: (option?: string | undefined) => void;
|
|
6
6
|
handleClearAllValues: () => void;
|
|
@@ -12,7 +12,11 @@ var useMultiTextFieldUtils = function useMultiTextFieldUtils(_ref) {
|
|
|
12
12
|
onMultiValueCreate = _ref.onMultiValueCreate,
|
|
13
13
|
onMultiValueDelete = _ref.onMultiValueDelete,
|
|
14
14
|
onClearAllValues = _ref.onClearAllValues,
|
|
15
|
-
onInput = _ref.onInput
|
|
15
|
+
onInput = _ref.onInput,
|
|
16
|
+
_ref$multiValuesHandl = _ref.multiValuesHandler,
|
|
17
|
+
multiValuesHandler = _ref$multiValuesHandl === void 0 ? function (value) {
|
|
18
|
+
return value;
|
|
19
|
+
} : _ref$multiValuesHandl;
|
|
16
20
|
|
|
17
21
|
var _useState = (0, _react.useState)(multiValues),
|
|
18
22
|
values = _useState[0],
|
|
@@ -69,7 +73,8 @@ var useMultiTextFieldUtils = function useMultiTextFieldUtils(_ref) {
|
|
|
69
73
|
event.preventDefault();
|
|
70
74
|
}
|
|
71
75
|
|
|
72
|
-
|
|
76
|
+
var handledInputValue = multiValuesHandler(inputValue);
|
|
77
|
+
setValues([].concat(values, Array.isArray(handledInputValue) ? handledInputValue : [handledInputValue]));
|
|
73
78
|
|
|
74
79
|
if (onMultiValueCreate) {
|
|
75
80
|
onMultiValueCreate(inputValue);
|
|
@@ -71,7 +71,9 @@ var TextInputBase = function TextInputBase(_ref) {
|
|
|
71
71
|
}, (0, _react2.jsx)("div", {
|
|
72
72
|
css: (0, _TextInputBase.textFieldStyle)({
|
|
73
73
|
lean: lean,
|
|
74
|
-
sx: sx
|
|
74
|
+
sx: sx,
|
|
75
|
+
disabled: disabled,
|
|
76
|
+
locked: locked
|
|
75
77
|
})
|
|
76
78
|
}, children)), hintMsg && status !== 'normal' && hintMessageToShow);
|
|
77
79
|
};
|
|
@@ -6,6 +6,6 @@ import { Props } from './TextInputBase';
|
|
|
6
6
|
* in custom implementation needed eg: datepicker
|
|
7
7
|
* */
|
|
8
8
|
export declare const wrapperStyle: ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) => (theme: Theme) => SerializedStyles;
|
|
9
|
-
export declare const textFieldStyle: ({ lean, sx }: Props) => (theme: Theme) => SerializedStyles;
|
|
10
|
-
export declare const inputStyle: ({ label, placeholder, size, dark, sx }: Props) => (theme: Theme) => SerializedStyles;
|
|
9
|
+
export declare const textFieldStyle: ({ lean, sx, disabled, locked }: Props) => (theme: Theme) => SerializedStyles;
|
|
10
|
+
export declare const inputStyle: ({ label, placeholder, size, dark, sx, disabled, locked }: Props) => (theme: Theme) => SerializedStyles;
|
|
11
11
|
export declare const errorMsgStyle: ({ status }: Props) => (theme: Theme) => SerializedStyles;
|
|
@@ -87,8 +87,8 @@ var wrapperStyle = function wrapperStyle(_ref) {
|
|
|
87
87
|
borderRadius: theme.spacing.xsm,
|
|
88
88
|
userSelect: 'none',
|
|
89
89
|
opacity: disabled ? (0, _states.getDisabled)().opacity : 1,
|
|
90
|
-
cursor: disabled || locked ? (0, _states.getDisabled)().cursor : '
|
|
91
|
-
}, textFieldSize, wrapperStyleSwitch(theme, colorScheme, lean, error, Boolean(disabled || locked), isInteractive), sx == null ? void 0 : sx.wrapper), process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RVciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RVciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
|
|
90
|
+
cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text'
|
|
91
|
+
}, textFieldSize, wrapperStyleSwitch(theme, colorScheme, lean, error, Boolean(disabled || locked), isInteractive), sx == null ? void 0 : sx.wrapper), process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAwEW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAwEW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
|
|
92
92
|
);
|
|
93
93
|
};
|
|
94
94
|
};
|
|
@@ -97,7 +97,9 @@ exports.wrapperStyle = wrapperStyle;
|
|
|
97
97
|
|
|
98
98
|
var textFieldStyle = function textFieldStyle(_ref2) {
|
|
99
99
|
var lean = _ref2.lean,
|
|
100
|
-
sx = _ref2.sx
|
|
100
|
+
sx = _ref2.sx,
|
|
101
|
+
disabled = _ref2.disabled,
|
|
102
|
+
locked = _ref2.locked;
|
|
101
103
|
return function (theme) {
|
|
102
104
|
return (
|
|
103
105
|
/*#__PURE__*/
|
|
@@ -111,10 +113,11 @@ var textFieldStyle = function textFieldStyle(_ref2) {
|
|
|
111
113
|
verticalAlign: 'top',
|
|
112
114
|
width: 'fill-available',
|
|
113
115
|
padding: !lean ? "0 " + theme.spacing.md : '',
|
|
116
|
+
cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text',
|
|
114
117
|
'> div': {
|
|
115
118
|
position: 'relative'
|
|
116
119
|
}
|
|
117
|
-
}, sx == null ? void 0 : sx.textField), process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR1ciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR1ciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
|
|
120
|
+
}, sx == null ? void 0 : sx.textField), process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAsGW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAsGW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
|
|
118
121
|
);
|
|
119
122
|
};
|
|
120
123
|
};
|
|
@@ -127,7 +130,9 @@ var inputStyle = function inputStyle(_ref3) {
|
|
|
127
130
|
_ref3$size = _ref3.size,
|
|
128
131
|
size = _ref3$size === void 0 ? _sizeUtils.DEFAULT_SIZE : _ref3$size,
|
|
129
132
|
dark = _ref3.dark,
|
|
130
|
-
sx = _ref3.sx
|
|
133
|
+
sx = _ref3.sx,
|
|
134
|
+
disabled = _ref3.disabled,
|
|
135
|
+
locked = _ref3.locked;
|
|
131
136
|
return function (theme) {
|
|
132
137
|
return (
|
|
133
138
|
/*#__PURE__*/
|
|
@@ -146,7 +151,8 @@ var inputStyle = function inputStyle(_ref3) {
|
|
|
146
151
|
width: 0,
|
|
147
152
|
minWidth: '100%',
|
|
148
153
|
'& + label': {
|
|
149
|
-
fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12']
|
|
154
|
+
fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],
|
|
155
|
+
cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text'
|
|
150
156
|
},
|
|
151
157
|
'&:focus': {
|
|
152
158
|
outline: 'none'
|
|
@@ -168,7 +174,7 @@ var inputStyle = function inputStyle(_ref3) {
|
|
|
168
174
|
'&:disabled': {
|
|
169
175
|
cursor: 'not-allowed'
|
|
170
176
|
}
|
|
171
|
-
}, sx == null ? void 0 : sx.input), process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwSEkiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwSEkiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
|
|
177
|
+
}, sx == null ? void 0 : sx.input), process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA2HI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA2HI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
|
|
172
178
|
);
|
|
173
179
|
};
|
|
174
180
|
};
|
|
@@ -195,7 +201,7 @@ var errorMsgStyle = function errorMsgStyle(_ref4) {
|
|
|
195
201
|
alignItems: 'stretch',
|
|
196
202
|
padding: "0 " + (0, _utils.rem)(2)
|
|
197
203
|
}
|
|
198
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0S0kiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0S0kiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
|
|
204
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA+KI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA+KI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
|
|
199
205
|
);
|
|
200
206
|
};
|
|
201
207
|
};
|