@flodesk/grain 11.24.0 → 11.25.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/es/components/autocomplete.js +49 -24
- package/es/components/autocomplete2.js +58 -33
- package/es/components/link.js +2 -2
- package/es/components/modal.js +3 -3
- package/es/components/popover.js +2 -2
- package/es/components/text-input.js +4 -5
- package/es/foundational/field.js +40 -8
- package/es/types.js +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const _excluded = ["options", "value", "onChange", "isCreatable", "onCreate", "menuPlacement", "menuWidth", "menuMaxHeight", "menuZIndex", "placeholder", "label", "hint", "menuItemsHaveEllipsis", "hasPortal", "hasError", "errorMessage", "searchField", "backgroundColor"];
|
|
1
|
+
const _excluded = ["options", "value", "onChange", "isCreatable", "onCreate", "menuPlacement", "menuWidth", "menuMaxHeight", "menuZIndex", "placeholder", "label", "hint", "menuItemsHaveEllipsis", "hasPortal", "hasError", "errorMessage", "searchField", "backgroundColor", "onClear"];
|
|
2
2
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
3
3
|
|
|
4
4
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
@@ -9,11 +9,11 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
|
|
|
9
9
|
|
|
10
10
|
import PropTypes from 'prop-types';
|
|
11
11
|
import React, { forwardRef, Fragment, useMemo, useRef, useState } from 'react';
|
|
12
|
-
import { Icon, Box, Text } from '.';
|
|
12
|
+
import { Icon, Box, Text, Arrange } from '.';
|
|
13
13
|
import { IconCheck, IconChevronDown, IconPlus } from '../icons';
|
|
14
14
|
import { Combobox } from '@headlessui/react';
|
|
15
15
|
import { defaultProps, types } from '../types';
|
|
16
|
-
import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint } from '../foundational';
|
|
16
|
+
import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, FieldClearButton } from '../foundational';
|
|
17
17
|
import { MenuItemDivider, useMenuPosition } from '../foundational/menu';
|
|
18
18
|
import { FloatingPortal } from '@floating-ui/react-dom-interactions';
|
|
19
19
|
import { Global } from '@emotion/react';
|
|
@@ -35,16 +35,35 @@ const EmptyState = () => ___EmotionJSX(Box, {
|
|
|
35
35
|
color: "content2"
|
|
36
36
|
}, "No results"));
|
|
37
37
|
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
38
|
+
const ActionsSection = _ref2 => {
|
|
39
|
+
let {
|
|
40
|
+
children
|
|
41
|
+
} = _ref2;
|
|
42
|
+
return ___EmotionJSX(Arrange, {
|
|
43
|
+
right: "fieldPaddingX",
|
|
44
|
+
gap: "xs",
|
|
45
|
+
position: "absolute",
|
|
46
|
+
top: "0px",
|
|
47
|
+
bottom: "0px",
|
|
48
|
+
margin: "auto",
|
|
49
|
+
height: "fit-content"
|
|
50
|
+
}, children);
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
const ClearButton = _ref3 => {
|
|
54
|
+
let {
|
|
55
|
+
onClick
|
|
56
|
+
} = _ref3;
|
|
57
|
+
|
|
58
|
+
const handleClear = e => {
|
|
59
|
+
e.stopPropagation();
|
|
60
|
+
onClick();
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
return ___EmotionJSX(FieldClearButton, {
|
|
64
|
+
onClick: e => handleClear(e)
|
|
65
|
+
});
|
|
66
|
+
};
|
|
48
67
|
|
|
49
68
|
const getFilteredOptions = (query, options, searchField) => {
|
|
50
69
|
if (query === '') return options;
|
|
@@ -58,7 +77,7 @@ const getShowGroupTitle = (index, option, filteredOptions) => {
|
|
|
58
77
|
};
|
|
59
78
|
|
|
60
79
|
const menuItemStyles = "\n .autocompleteMenuItem {\n display: flex;\n gap: 8px;\n align-items: center;\n list-style: none;\n padding: 4px 12px;\n min-height: var(--grn-textbox-height-m);\n border-radius: ".concat(getRadius('s'), ";\n appearance: none;\n\n &.hasPreContent {\n padding-left: 0;\n }\n }\n\n .autocompleteMenuItemText {\n flex-grow: 1;\n\n &.hasEllipsis {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n");
|
|
61
|
-
export const Autocomplete =
|
|
80
|
+
export const Autocomplete = _ref4 => {
|
|
62
81
|
let {
|
|
63
82
|
options,
|
|
64
83
|
value,
|
|
@@ -77,9 +96,10 @@ export const Autocomplete = _ref2 => {
|
|
|
77
96
|
hasError,
|
|
78
97
|
errorMessage,
|
|
79
98
|
searchField = 'content',
|
|
80
|
-
backgroundColor
|
|
81
|
-
|
|
82
|
-
|
|
99
|
+
backgroundColor,
|
|
100
|
+
onClear
|
|
101
|
+
} = _ref4,
|
|
102
|
+
props = _objectWithoutProperties(_ref4, _excluded);
|
|
83
103
|
|
|
84
104
|
const [query, setQuery] = useState('');
|
|
85
105
|
|
|
@@ -129,16 +149,17 @@ export const Autocomplete = _ref2 => {
|
|
|
129
149
|
setPreContentWidth(preContentRef.current.offsetWidth);
|
|
130
150
|
}
|
|
131
151
|
}, [selectedOption, preContentRef]);
|
|
152
|
+
const hasClearButton = onClear && Boolean(selectedOption);
|
|
132
153
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
|
|
133
154
|
styles: menuItemStyles
|
|
134
155
|
}), ___EmotionJSX(Combobox, _extends({
|
|
135
156
|
as: "div",
|
|
136
157
|
value: selectedOption || '',
|
|
137
158
|
onChange: handleChange
|
|
138
|
-
}, props),
|
|
159
|
+
}, props), _ref5 => {
|
|
139
160
|
let {
|
|
140
161
|
open
|
|
141
|
-
} =
|
|
162
|
+
} = _ref5;
|
|
142
163
|
const hasPreContent = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.preContent;
|
|
143
164
|
return ___EmotionJSX(React.Fragment, null, label && ___EmotionJSX(Combobox.Label, {
|
|
144
165
|
as: FieldLabel
|
|
@@ -167,7 +188,11 @@ export const Autocomplete = _ref2 => {
|
|
|
167
188
|
paddingLeft: !open && hasPreContent ? "".concat(preContentWidth + 8, "px") : undefined,
|
|
168
189
|
hasError: hasError,
|
|
169
190
|
backgroundColor: backgroundColor
|
|
170
|
-
}), ___EmotionJSX(
|
|
191
|
+
}), ___EmotionJSX(ActionsSection, null, hasClearButton && ___EmotionJSX(ClearButton, {
|
|
192
|
+
onClick: onClear
|
|
193
|
+
}), ___EmotionJSX(Icon, {
|
|
194
|
+
icon: ___EmotionJSX(IconChevronDown, null)
|
|
195
|
+
}))), ___EmotionJSX(OptionsRoot, null, ___EmotionJSX(MenuCardTransition, {
|
|
171
196
|
afterLeave: () => setQuery('')
|
|
172
197
|
}, ___EmotionJSX(Combobox.Options, {
|
|
173
198
|
static: true,
|
|
@@ -188,10 +213,10 @@ export const Autocomplete = _ref2 => {
|
|
|
188
213
|
value: option,
|
|
189
214
|
as: Fragment,
|
|
190
215
|
disabled: option.isDisabled
|
|
191
|
-
},
|
|
216
|
+
}, _ref6 => {
|
|
192
217
|
let {
|
|
193
218
|
active
|
|
194
|
-
} =
|
|
219
|
+
} = _ref6;
|
|
195
220
|
const isDisabled = option.isDisabled;
|
|
196
221
|
const isSelected = option.value === value;
|
|
197
222
|
const isActive = !option.isDisabled && active;
|
|
@@ -216,10 +241,10 @@ export const Autocomplete = _ref2 => {
|
|
|
216
241
|
}));
|
|
217
242
|
}), isShowCreateOption && ___EmotionJSX(React.Fragment, null, filteredOptions.length > 0 && ___EmotionJSX(MenuItemDivider, null), ___EmotionJSX(Combobox.Option, {
|
|
218
243
|
value: newOption
|
|
219
|
-
},
|
|
244
|
+
}, _ref7 => {
|
|
220
245
|
let {
|
|
221
246
|
active
|
|
222
|
-
} =
|
|
247
|
+
} = _ref7;
|
|
223
248
|
const isActive = active;
|
|
224
249
|
return ___EmotionJSX("li", {
|
|
225
250
|
className: "autocompleteMenuItem",
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
2
|
const _excluded = ["children", "hasEllipsis", "paddingLeft"],
|
|
3
|
-
_excluded2 = ["options", "value", "onChange", "isCreatable", "onCreate", "menuPlacement", "menuWidth", "menuMaxHeight", "menuZIndex", "placeholder", "label", "hint", "menuItemsHaveEllipsis", "hasPortal", "hasError", "errorMessage", "searchField", "backgroundColor"];
|
|
3
|
+
_excluded2 = ["options", "value", "onChange", "isCreatable", "onCreate", "menuPlacement", "menuWidth", "menuMaxHeight", "menuZIndex", "placeholder", "label", "hint", "menuItemsHaveEllipsis", "hasPortal", "hasError", "errorMessage", "searchField", "backgroundColor", "onClear"];
|
|
4
4
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
5
5
|
|
|
6
6
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
@@ -17,7 +17,7 @@ import { Icon, Box, Arrange } from '.';
|
|
|
17
17
|
import { IconChevronDown, IconPlus } from '../icons';
|
|
18
18
|
import { Combobox } from '@headlessui/react';
|
|
19
19
|
import { defaultProps, types } from '../types';
|
|
20
|
-
import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, componentVars, styles } from '../foundational';
|
|
20
|
+
import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, componentVars, styles, FieldClearButton } from '../foundational';
|
|
21
21
|
import { MenuItemDivider, useMenuPosition } from '../foundational/menu';
|
|
22
22
|
import { FloatingPortal } from '@floating-ui/react-dom-interactions';
|
|
23
23
|
import { Global } from '@emotion/react';
|
|
@@ -54,7 +54,7 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
54
54
|
open
|
|
55
55
|
} = _ref5;
|
|
56
56
|
return open ? 'auto' : 'none';
|
|
57
|
-
}, ";transition:opacity ", getTransition('xxFast'), ";&:focus-visible{opacity:1;pointer-events:auto;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAsBuB","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */"));
|
|
57
|
+
}, ";transition:opacity ", getTransition('xxFast'), ";&:focus-visible{opacity:1;pointer-events:auto;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAuBuB","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\n};\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */"));
|
|
58
58
|
|
|
59
59
|
const EmptyState = () => ___EmotionJSX(Box, {
|
|
60
60
|
paddingY: "s",
|
|
@@ -62,16 +62,35 @@ const EmptyState = () => ___EmotionJSX(Box, {
|
|
|
62
62
|
color: "content2"
|
|
63
63
|
}, "No results");
|
|
64
64
|
|
|
65
|
-
const
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
65
|
+
const ActionsSection = _ref6 => {
|
|
66
|
+
let {
|
|
67
|
+
children
|
|
68
|
+
} = _ref6;
|
|
69
|
+
return ___EmotionJSX(Arrange, {
|
|
70
|
+
right: "fieldPaddingX",
|
|
71
|
+
gap: "xs",
|
|
72
|
+
position: "absolute",
|
|
73
|
+
top: "0px",
|
|
74
|
+
bottom: "0px",
|
|
75
|
+
margin: "auto",
|
|
76
|
+
height: "fit-content"
|
|
77
|
+
}, children);
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
const ClearButton = _ref7 => {
|
|
81
|
+
let {
|
|
82
|
+
onClick
|
|
83
|
+
} = _ref7;
|
|
84
|
+
|
|
85
|
+
const handleClear = e => {
|
|
86
|
+
e.stopPropagation();
|
|
87
|
+
onClick();
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
return ___EmotionJSX(FieldClearButton, {
|
|
91
|
+
onClick: e => handleClear(e)
|
|
92
|
+
});
|
|
93
|
+
};
|
|
75
94
|
|
|
76
95
|
const getFilteredOptions = (query, options, searchField) => {
|
|
77
96
|
if (query === '') return options;
|
|
@@ -85,13 +104,13 @@ const getShowGroupTitle = (index, option, filteredOptions) => {
|
|
|
85
104
|
};
|
|
86
105
|
|
|
87
106
|
const menuItemStyles = "\n .autocompleteMenuItem {\n display: flex;\n align-items: center;\n list-style: none;\n min-height: var(--grn-textbox-height-m);\n border-radius: ".concat(getRadius('s'), ";\n appearance: none;\n padding-block: 0;\n padding: 4px 12px;\n\n --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n &[data-headlessui-state='active'],\n &[data-headlessui-state='active selected'] {\n background-color: ").concat(getColor('fade1'), ";\n }\n\n &[data-headlessui-state='selected'],\n &[data-headlessui-state='active selected'] {\n background-image: var(--checkUri);\n background-repeat: no-repeat;\n background-position: center right 12px;\n background-size: auto ").concat(getIconSize('m'), ";\n }\n\n &[data-headlessui-state='active selected'] {\n background-image: var(--checkUriActive);\n }\n\n &[data-headlessui-state='disabled'] {\n color: ").concat(getColor('disabledContent'), ";\n cursor: default;\n }\n\n ul & {\n cursor: pointer;\n padding-right: 40px;\n }\n }\n\n .autocompleteMenuItemText {\n flex-grow: 1;\n\n &.hasEllipsis {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n");
|
|
88
|
-
const Item = /*#__PURE__*/forwardRef((
|
|
107
|
+
const Item = /*#__PURE__*/forwardRef((_ref8, ref) => {
|
|
89
108
|
let {
|
|
90
109
|
children,
|
|
91
110
|
hasEllipsis,
|
|
92
111
|
paddingLeft = '12px'
|
|
93
|
-
} =
|
|
94
|
-
props = _objectWithoutProperties(
|
|
112
|
+
} = _ref8,
|
|
113
|
+
props = _objectWithoutProperties(_ref8, _excluded);
|
|
95
114
|
|
|
96
115
|
return ___EmotionJSX("li", _extends({
|
|
97
116
|
className: "autocompleteMenuItem",
|
|
@@ -109,17 +128,17 @@ const Trigger = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
|
|
|
109
128
|
} : {
|
|
110
129
|
target: "ea1qwwn1",
|
|
111
130
|
label: "Trigger"
|
|
112
|
-
})("text-align:left;height:var(--grn-textbox-height-m);background-color:transparent;cursor:text;appearance:none;display:block;font:inherit;color:inherit;width:100%;outline:none;border:none;padding:0;opacity:",
|
|
131
|
+
})("text-align:left;height:var(--grn-textbox-height-m);background-color:transparent;cursor:text;appearance:none;display:block;font:inherit;color:inherit;width:100%;outline:none;border:none;padding:0;opacity:", _ref9 => {
|
|
113
132
|
let {
|
|
114
133
|
open
|
|
115
|
-
} =
|
|
134
|
+
} = _ref9;
|
|
116
135
|
return open ? 0 : 1;
|
|
117
|
-
}, ";pointer-events:",
|
|
136
|
+
}, ";pointer-events:", _ref10 => {
|
|
118
137
|
let {
|
|
119
138
|
open
|
|
120
|
-
} =
|
|
139
|
+
} = _ref10;
|
|
121
140
|
return open ? 'none' : 'auto';
|
|
122
|
-
}, ";position:absolute;top:0;left:0;transition:opacity ", getTransition('xxFast'), ";.autocompleteMenuItem{padding-right:34px;}.autocompleteInput:focus-visible+&{opacity:0;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AA8J6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */"));
|
|
141
|
+
}, ";position:absolute;top:0;left:0;transition:opacity ", getTransition('xxFast'), ";.autocompleteMenuItem{padding-right:34px;}.autocompleteInput:focus-visible+&{opacity:0;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAwK6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\n};\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */"));
|
|
123
142
|
|
|
124
143
|
const TriggerText = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
|
|
125
144
|
target: "ea1qwwn0"
|
|
@@ -132,11 +151,11 @@ const TriggerText = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "produ
|
|
|
132
151
|
} : {
|
|
133
152
|
name: "nabtlt",
|
|
134
153
|
styles: "line-height:1.4;display:block;padding-block:0;padding-left:12px;padding-right:32px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap",
|
|
135
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AA4L+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */",
|
|
154
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAsM+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError }) =>\n    hasError\n      ? `--borderColor: ${getColor('danger')};`\n      : `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n  background-color: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'transparent')};\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\n};\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: var(--grn-textbox-height-m);\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n              >\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0}>\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\n                        </>\n                      )}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  backgroundColor: types.color,\n};\n"]} */",
|
|
136
155
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
137
156
|
});
|
|
138
157
|
|
|
139
|
-
export const Autocomplete2 =
|
|
158
|
+
export const Autocomplete2 = _ref11 => {
|
|
140
159
|
let {
|
|
141
160
|
options,
|
|
142
161
|
value,
|
|
@@ -155,9 +174,10 @@ export const Autocomplete2 = _ref9 => {
|
|
|
155
174
|
hasError,
|
|
156
175
|
errorMessage,
|
|
157
176
|
searchField = 'content',
|
|
158
|
-
backgroundColor
|
|
159
|
-
|
|
160
|
-
|
|
177
|
+
backgroundColor,
|
|
178
|
+
onClear
|
|
179
|
+
} = _ref11,
|
|
180
|
+
props = _objectWithoutProperties(_ref11, _excluded2);
|
|
161
181
|
|
|
162
182
|
const [query, setQuery] = useState('');
|
|
163
183
|
|
|
@@ -200,16 +220,17 @@ export const Autocomplete2 = _ref9 => {
|
|
|
200
220
|
menuPlacement
|
|
201
221
|
});
|
|
202
222
|
const OptionsRoot = hasPortal ? FloatingPortal : Fragment;
|
|
223
|
+
const hasClearButton = onClear && Boolean(selectedOption);
|
|
203
224
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
|
|
204
225
|
styles: menuItemStyles
|
|
205
226
|
}), ___EmotionJSX(Combobox, _extends({
|
|
206
227
|
as: "div",
|
|
207
228
|
value: selectedOption || '',
|
|
208
229
|
onChange: handleChange
|
|
209
|
-
}, props),
|
|
230
|
+
}, props), _ref12 => {
|
|
210
231
|
let {
|
|
211
232
|
open
|
|
212
|
-
} =
|
|
233
|
+
} = _ref12;
|
|
213
234
|
const hasItem = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.item;
|
|
214
235
|
return ___EmotionJSX(React.Fragment, null, label && ___EmotionJSX(Combobox.Label, {
|
|
215
236
|
as: FieldLabel
|
|
@@ -238,7 +259,11 @@ export const Autocomplete2 = _ref9 => {
|
|
|
238
259
|
isActive: false,
|
|
239
260
|
isSelected: false,
|
|
240
261
|
isDisabled: false
|
|
241
|
-
}), !hasItem && selectedOption && ___EmotionJSX(TriggerText, null, selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.content)), ___EmotionJSX(
|
|
262
|
+
}), !hasItem && selectedOption && ___EmotionJSX(TriggerText, null, selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.content)), ___EmotionJSX(ActionsSection, null, hasClearButton && ___EmotionJSX(ClearButton, {
|
|
263
|
+
onClick: onClear
|
|
264
|
+
}), ___EmotionJSX(Icon, {
|
|
265
|
+
icon: ___EmotionJSX(IconChevronDown, null)
|
|
266
|
+
}))), ___EmotionJSX(OptionsRoot, null, ___EmotionJSX(MenuCardTransition, {
|
|
242
267
|
afterLeave: () => setQuery('')
|
|
243
268
|
}, ___EmotionJSX(Combobox.Options, {
|
|
244
269
|
static: true,
|
|
@@ -259,10 +284,10 @@ export const Autocomplete2 = _ref9 => {
|
|
|
259
284
|
value: option,
|
|
260
285
|
as: Fragment,
|
|
261
286
|
disabled: option.isDisabled
|
|
262
|
-
},
|
|
287
|
+
}, _ref13 => {
|
|
263
288
|
let {
|
|
264
289
|
active
|
|
265
|
-
} =
|
|
290
|
+
} = _ref13;
|
|
266
291
|
const isDisabled = option.isDisabled;
|
|
267
292
|
const isSelected = option.value === value;
|
|
268
293
|
const isActive = !option.isDisabled && active;
|
|
@@ -284,10 +309,10 @@ export const Autocomplete2 = _ref9 => {
|
|
|
284
309
|
}), isShowCreateOption && ___EmotionJSX(React.Fragment, null, filteredOptions.length > 0 && ___EmotionJSX(MenuItemDivider, null), ___EmotionJSX(Combobox.Option, {
|
|
285
310
|
value: newOption,
|
|
286
311
|
as: Fragment
|
|
287
|
-
},
|
|
312
|
+
}, _ref14 => {
|
|
288
313
|
let {
|
|
289
314
|
active
|
|
290
|
-
} =
|
|
315
|
+
} = _ref14;
|
|
291
316
|
return ___EmotionJSX(Item, {
|
|
292
317
|
isActive: active,
|
|
293
318
|
hasEllipsis: menuItemsHaveEllipsis
|
package/es/components/link.js
CHANGED
|
@@ -27,12 +27,12 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
27
27
|
as
|
|
28
28
|
} = _ref;
|
|
29
29
|
return as === 'button' && "\n ".concat(styles.buttonReset, ";\n border: none;\n background: transparent;\n padding: 0;\n text-decoration: underline;\n font-weight: unset;\n ");
|
|
30
|
-
}, ";", styles.transitions, ";text-underline
|
|
30
|
+
}, ";", styles.transitions, ";--capFallback:0.74em;--cap:1cap;--lineHeightAndCapOffset:calc(\n (var(--grn-lineHeight-global) - var(--cap, var(--capFallback))) / 2\n );--line-thickness:0.1em;--line-offset:calc(var(--lineHeightAndCapOffset) - var(--line-thickness));text-decoration:underline;text-underline-offset:var(--line-offset);text-decoration-thickness:var(--line-thickness);text-decoration-color:", _ref2 => {
|
|
31
31
|
let {
|
|
32
32
|
variant
|
|
33
33
|
} = _ref2;
|
|
34
34
|
return textDecorationColorStyles[variant];
|
|
35
|
-
}, ";color:inherit;cursor:pointer;@media (hover: hover){&:hover{text-decoration-color:currentColor;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2xpbmsuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVd1QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9saW5rLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgdGV4dERlY29yYXRpb25Db2xvclN0eWxlcyA9IHtcbiAgbmV1dHJhbDogYGN1cnJlbnRDb2xvcmAsXG4gIHN1YnRsZTogYHRyYW5zcGFyZW50YCxcbn07XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuICAkeyh7IGFzIH0pID0+
|
|
35
|
+
}, ";color:inherit;cursor:pointer;@media (hover: hover){&:hover{text-decoration-color:currentColor;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2xpbmsuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVd1QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9saW5rLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgdGV4dERlY29yYXRpb25Db2xvclN0eWxlcyA9IHtcbiAgbmV1dHJhbDogYGN1cnJlbnRDb2xvcmAsXG4gIHN1YnRsZTogYHRyYW5zcGFyZW50YCxcbn07XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuICAkeyh7IGFzIH0pID0+XG4gICAgYXMgPT09ICdidXR0b24nICYmXG4gICAgYFxuICAgICR7c3R5bGVzLmJ1dHRvblJlc2V0fTtcbiAgICAgYm9yZGVyOiBub25lO1xuICAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICAgcGFkZGluZzogMDtcbiAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG4gICAgIGZvbnQtd2VpZ2h0OiB1bnNldDtcbiAgYH07XG5cbiAgJHtzdHlsZXMudHJhbnNpdGlvbnN9O1xuXG4gIC0tY2FwRmFsbGJhY2s6IDAuNzRlbTtcbiAgLS1jYXA6IDFjYXA7XG4gIC0tbGluZUhlaWdodEFuZENhcE9mZnNldDogY2FsYyhcbiAgICAodmFyKC0tZ3JuLWxpbmVIZWlnaHQtZ2xvYmFsKSAtIHZhcigtLWNhcCwgdmFyKC0tY2FwRmFsbGJhY2spKSkgLyAyXG4gICk7XG4gIC0tbGluZS10aGlja25lc3M6IDAuMWVtO1xuXG4gIC8qIHNldHMgdGhlIGxpbmUgaW5zaWRlIG9mIHRoZSBsaW5lIGhlaWdodCBib3gsIHByZXZlbnRzIGNpaXBwaW5nIHdoZW4gaGFzIGVsbGlwc2lzIGluIFNhZmFyaSAgKi9cbiAgLS1saW5lLW9mZnNldDogY2FsYyh2YXIoLS1saW5lSGVpZ2h0QW5kQ2FwT2Zmc2V0KSAtIHZhcigtLWxpbmUtdGhpY2tuZXNzKSk7XG5cbiAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG4gIHRleHQtdW5kZXJsaW5lLW9mZnNldDogdmFyKC0tbGluZS1vZmZzZXQpO1xuICB0ZXh0LWRlY29yYXRpb24tdGhpY2tuZXNzOiB2YXIoLS1saW5lLXRoaWNrbmVzcyk7XG4gIHRleHQtZGVjb3JhdGlvbi1jb2xvcjogJHsoeyB2YXJpYW50IH0pID0+IHRleHREZWNvcmF0aW9uQ29sb3JTdHlsZXNbdmFyaWFudF19O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgY3Vyc29yOiBwb2ludGVyO1xuXG4gIEBtZWRpYSAoaG92ZXI6IGhvdmVyKSB7XG4gICAgJjpob3ZlciB7XG4gICAgICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IGN1cnJlbnRDb2xvcjtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBMaW5rID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgdGFnID0gJ2EnLCB2YXJpYW50ID0gJ25ldXRyYWwnLCAuLi5wcm9wcyB9LCByZWYpID0+IHtcbiAgY29uc3QgdHlwZSA9IHRhZyA9PT0gJ2J1dHRvbicgPyAnYnV0dG9uJyA6IHVuZGVmaW5lZDtcbiAgcmV0dXJuIChcbiAgICA8Um9vdCB0eXBlPXt0eXBlfSByZWY9e3JlZn0gYXM9e3RhZ30gdmFyaWFudD17dmFyaWFudH0gey4uLnByb3BzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1Jvb3Q+XG4gICk7XG59KTtcblxuTGluay5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaHJlZjogUHJvcFR5cGVzLnN0cmluZyxcbiAgdGFyZ2V0OiBQcm9wVHlwZXMuc3RyaW5nLFxuICB2YXJpYW50OiBQcm9wVHlwZXMub25lT2YoWyduZXV0cmFsJywgJ3N1YnRsZSddKSxcbiAgdGFnOiB0eXBlcy5idXR0b25UYWcsXG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxufTtcbiJdfQ== */"));
|
|
36
36
|
|
|
37
37
|
export const Link = /*#__PURE__*/forwardRef((_ref3, ref) => {
|
|
38
38
|
let {
|
package/es/components/modal.js
CHANGED
|
@@ -86,7 +86,7 @@ const TitleRoot = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "productio
|
|
|
86
86
|
} : {
|
|
87
87
|
name: "ti75j2",
|
|
88
88
|
styles: "margin:0",
|
|
89
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRThCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBEaWFsb2csIFRyYW5zaXRpb24gfSBmcm9tICdAaGVhZGxlc3N1aS9yZWFjdCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi90ZXh0JztcbmltcG9ydCB7IGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEljb25Dcm9zcyB9IGZyb20gJy4uL2ljb25zJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBtb2RhbFpJbmRleCA9IDEwOTk7XG5cbmNvbnN0IGNhcmRNYXhXaWR0aHMgPSB7XG4gIG5hcnJvdzogNTUsXG4gIG1lZGl1bTogNzIsXG4gIHdpZGU6IDEzMCxcbn07XG5cbmNvbnN0IE1vZGFsQ2FyZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjYXJkUGFkZGluZyxcbiAgICAgIGNhcmRNYXhXaWR0aCxcbiAgICAgIGNhcmRNYXhIZWlnaHQsXG4gICAgICBjYXJkUmFkaXVzLFxuICAgICAgY2FyZEhlaWdodCxcbiAgICAgIGNhcmRUb3AsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIG9uQ2xvc2VDbGljayxcbiAgICAgIGNsb3NlQnV0dG9uUHJvcHMsXG4gICAgICBoYXNDbG9zZUJ1dHRvbixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICA8Qm94XG4gICAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgICAgIG1heFdpZHRoPXtjYXJkTWF4V2lkdGhzW2NhcmRNYXhXaWR0aF0gfHwgY2FyZE1heFdpZHRofVxuICAgICAgICBjbGFzc05hbWU9XCJncm4tY2FyZC1jb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8Qm94XG4gICAgICAgICAgY2xhc3NOYW1lPVwiZ3JuLWNhcmRcIlxuICAgICAgICAgIHBvc2l0aW9uPVwicmVsYXRpdmVcIlxuICAgICAgICAgIHJhZGl1cz17Y2FyZFJhZGl1c31cbiAgICAgICAgICBvdmVyZmxvdz1cImhpZGRlblwiXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPVwiZmxvYXRpbmdCYWNrZ3JvdW5kXCJcbiAgICAgICAgICBzaGFkb3c9XCJsXCJcbiAgICAgICAgICB0b3A9e2NhcmRUb3B9XG4gICAgICAgICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICA+XG4gICAgICAgICAgPEJveCBwYWRkaW5nPXtjYXJkUGFkZGluZ30gb3ZlcmZsb3c9XCJhdXRvXCIgbWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fSBoZWlnaHQ9e2NhcmRIZWlnaHR9PlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQm94PlxuICAgICAgICAgIHtoYXNDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgICA8Qm94IHBvc2l0aW9uPVwiYWJzb2x1dGVcIiByaWdodD1cInhzXCIgdG9wPVwieHNcIiB6SW5kZXg9ezF9PlxuICAgICAgICAgICAgICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsb3NlQ2xpY2t9IHsuLi5jbG9zZUJ1dHRvblByb3BzfSAvPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JveD5cbiAgICApO1xuICB9LFxuKTtcblxuY29uc3QgVGl0bGVSb290ID0gc3R5bGVkKFRleHQpYFxuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBUaXRsZSA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGl0bGVSb290IHRhZz1cImgzXCIgcmVmPXtyZWZ9IHNpemU9XCJ4bFwiIHdlaWdodD1cIm1lZGl1bVwiIHRyaW1Ub3Agey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGl0bGVSb290PlxuKSk7XG5cbmNvbnN0IENvbnRhaW5lclJvb3QgPSBzdHlsZWQuZGl2YFxuICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuICBwYWRkaW5nLWxlZnQ6ICR7KHsgcGFkZGluZ1ggfSkgPT4gZ2V0U3BhY2UocGFkZGluZ1gpfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyBwYWRkaW5nWCB9KSA9PiBnZXRTcGFjZShwYWRkaW5nWCl9O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgYWxpZ24taXRlbXM6ICR7KHsgY2FyZFRvcCB9KSA9PiAoY2FyZFRvcCA/ICdzdGFydCcgOiAnY2VudGVyJyl9O1xuICBqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG4gIC5sZWF2ZVRvLFxuICAuZW50ZXJGcm9tIHtcbiAgICBvcGFjaXR5OiAwO1xuICB9XG4gIC5lbnRlclRvLFxuICAubGVhdmVUbyB7XG4gICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuICB9XG5gO1xuXG5jb25zdCBDb250YWluZXIgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBjYXJkVG9wLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPENvbnRhaW5lclJvb3QgcmVmPXtyZWZ9IGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCIgY2FyZFRvcD17Y2FyZFRvcH0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvQ29udGFpbmVyUm9vdD5cbikpO1xuXG5jb25zdCBCYWNrZHJvcCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8Qm94XG4gICAgcmVmPXtyZWZ9XG4gICAgcG9zaXRpb249XCJmaXhlZFwiXG4gICAgdG9wPVwiMFwiXG4gICAgbGVmdD1cIjBcIlxuICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgYmFja2dyb3VuZENvbG9yPVwiYmFja2Ryb3BcIlxuICAgIHsuLi5wcm9wc31cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9Cb3g+XG4pKTtcblxuY29uc3QgdHJhbnNpdGlvbkNoaWxkUHJvcHMgPSB7XG4gIGVudGVyOiAnZW50ZXInLFxuICBlbnRlckZyb206ICdlbnRlckZyb20nLFxuICBlbnRlclRvOiAnZW50ZXJUbycsXG4gIGxlYXZlOiAnbGVhdmUnLFxuICBsZWF2ZUZyb206ICdsZWF2ZUZyb20nLFxuICBsZWF2ZVRvOiAnbGVhdmVUbycsXG59O1xuXG5leHBvcnQgY29uc3QgTW9kYWwgPSAoe1xuICBpc09wZW4sXG4gIGNoaWxkcmVuLFxuICBvbkNsb3NlLFxuICB0aXRsZSxcbiAgZGVzY3JpcHRpb24sXG4gIHBhZGRpbmdYID0gJ2wnLFxuICBjYXJkUGFkZGluZyA9ICd4bCcsXG4gIGNhcmRSYWRpdXMgPSAnbCcsXG4gIGNhcmRNYXhXaWR0aCA9IDY4LFxuICBjYXJkTWF4SGVpZ2h0ID0gJzkwdmgnLFxuICBjYXJkSGVpZ2h0LFxuICBjYXJkVG9wLFxuICB6SW5kZXggPSBtb2RhbFpJbmRleCxcbiAgaW5pdGlhbEZvY3VzLFxuICByZXR1cm5Gb2N1cyxcbiAgY2xvc2VCdXR0b25Qcm9wcyxcbiAgaGFzQ2xvc2VCdXR0b24gPSB0cnVlLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyID0gZmFsc2UsXG4gIC4uLnByb3BzXG59KSA9PiB7XG4gIGNvbnN0IGhhc0JhY2tkcm9wID0gY2FyZEhlaWdodCAhPT0gJzEwMHZoJztcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICBpZiAoZGlzYWJsZUNsb3NlSGFuZGxlcikgcmV0dXJuO1xuXG4gICAgaWYgKEJvb2xlYW4ob25DbG9zZSkpIHtcbiAgICAgIG9uQ2xvc2UoKTtcbiAgICB9XG4gICAgaWYgKHJldHVybkZvY3VzKSB7XG4gICAgICByZXR1cm5Gb2N1cy5mb2N1cygpO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxUcmFuc2l0aW9uIGFwcGVhciBzaG93PXtpc09wZW59IGFzPXtGcmFnbWVudH0+XG4gICAgICA8RGlhbG9nXG4gICAgICAgIGFzPXtDb250YWluZXJ9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgaW5pdGlhbEZvY3VzPXtpbml0aWFsRm9jdXN9XG4gICAgICAgIHBhZGRpbmdYPXtwYWRkaW5nWH1cbiAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aGFzQmFja2Ryb3AgJiYgPFRyYW5zaXRpb24uQ2hpbGQgYXM9e0JhY2tkcm9wfSB7Li4udHJhbnNpdGlvbkNoaWxkUHJvcHN9IC8+fVxuXG4gICAgICAgIDxUcmFuc2l0aW9uLkNoaWxkIGFzPXtGcmFnbWVudH0gey4uLnRyYW5zaXRpb25DaGlsZFByb3BzfT5cbiAgICAgICAgICA8RGlhbG9nLlBhbmVsXG4gICAgICAgICAgICBhcz17TW9kYWxDYXJkfVxuICAgICAgICAgICAgb25DbG9zZUNsaWNrPXtvbkNsb3NlfVxuICAgICAgICAgICAgY2FyZFBhZGRpbmc9e2NhcmRQYWRkaW5nfVxuICAgICAgICAgICAgY2FyZE1heFdpZHRoPXtjYXJkTWF4V2lkdGh9XG4gICAgICAgICAgICBjYXJkTWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fVxuICAgICAgICAgICAgY2FyZEhlaWdodD17Y2FyZEhlaWdodH1cbiAgICAgICAgICAgIGNsb3NlQnV0dG9uUHJvcHM9e2Nsb3NlQnV0dG9uUHJvcHN9XG4gICAgICAgICAgICBjYXJkUmFkaXVzPXtjYXJkUmFkaXVzfVxuICAgICAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgICAgIGhhc0Nsb3NlQnV0dG9uPXtoYXNDbG9zZUJ1dHRvbn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dGl0bGUgJiYgPERpYWxvZy5UaXRsZSBhcz17VGl0bGV9Pnt0aXRsZX08L0RpYWxvZy5UaXRsZT59XG4gICAgICAgICAgICB7ZGVzY3JpcHRpb24gJiYgKFxuICAgICAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInNcIj5cbiAgICAgICAgICAgICAgICA8RGlhbG9nLkRlc2NyaXB0aW9uIGFzPVwiZGl2XCI+e2Rlc2NyaXB0aW9ufTwvRGlhbG9nLkRlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICA8L0JveD5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9EaWFsb2cuUGFuZWw+
|
|
89
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRThCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBEaWFsb2csIFRyYW5zaXRpb24gfSBmcm9tICdAaGVhZGxlc3N1aS9yZWFjdCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi90ZXh0JztcbmltcG9ydCB7IGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEljb25Dcm9zcyB9IGZyb20gJy4uL2ljb25zJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBtb2RhbFpJbmRleCA9IDEwOTk7XG5cbmNvbnN0IGNhcmRNYXhXaWR0aHMgPSB7XG4gIG5hcnJvdzogNTUsXG4gIG1lZGl1bTogNzIsXG4gIHdpZGU6IDEzMCxcbn07XG5cbmNvbnN0IE1vZGFsQ2FyZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjYXJkUGFkZGluZyxcbiAgICAgIGNhcmRNYXhXaWR0aCxcbiAgICAgIGNhcmRNYXhIZWlnaHQsXG4gICAgICBjYXJkUmFkaXVzLFxuICAgICAgY2FyZEhlaWdodCxcbiAgICAgIGNhcmRUb3AsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIG9uQ2xvc2VDbGljayxcbiAgICAgIGNsb3NlQnV0dG9uUHJvcHMsXG4gICAgICBoYXNDbG9zZUJ1dHRvbixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICA8Qm94XG4gICAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgICAgIG1heFdpZHRoPXtjYXJkTWF4V2lkdGhzW2NhcmRNYXhXaWR0aF0gfHwgY2FyZE1heFdpZHRofVxuICAgICAgICBjbGFzc05hbWU9XCJncm4tY2FyZC1jb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8Qm94XG4gICAgICAgICAgY2xhc3NOYW1lPVwiZ3JuLWNhcmRcIlxuICAgICAgICAgIHBvc2l0aW9uPVwicmVsYXRpdmVcIlxuICAgICAgICAgIHJhZGl1cz17Y2FyZFJhZGl1c31cbiAgICAgICAgICBvdmVyZmxvdz1cImhpZGRlblwiXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPVwiZmxvYXRpbmdCYWNrZ3JvdW5kXCJcbiAgICAgICAgICBzaGFkb3c9XCJsXCJcbiAgICAgICAgICB0b3A9e2NhcmRUb3B9XG4gICAgICAgICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICA+XG4gICAgICAgICAgPEJveCBwYWRkaW5nPXtjYXJkUGFkZGluZ30gb3ZlcmZsb3c9XCJhdXRvXCIgbWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fSBoZWlnaHQ9e2NhcmRIZWlnaHR9PlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQm94PlxuICAgICAgICAgIHtoYXNDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgICA8Qm94IHBvc2l0aW9uPVwiYWJzb2x1dGVcIiByaWdodD1cInhzXCIgdG9wPVwieHNcIiB6SW5kZXg9ezF9PlxuICAgICAgICAgICAgICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsb3NlQ2xpY2t9IHsuLi5jbG9zZUJ1dHRvblByb3BzfSAvPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JveD5cbiAgICApO1xuICB9LFxuKTtcblxuY29uc3QgVGl0bGVSb290ID0gc3R5bGVkKFRleHQpYFxuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBUaXRsZSA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGl0bGVSb290IHRhZz1cImgzXCIgcmVmPXtyZWZ9IHNpemU9XCJ4bFwiIHdlaWdodD1cIm1lZGl1bVwiIHRyaW1Ub3Agey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGl0bGVSb290PlxuKSk7XG5cbmNvbnN0IENvbnRhaW5lclJvb3QgPSBzdHlsZWQuZGl2YFxuICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuICBwYWRkaW5nLWxlZnQ6ICR7KHsgcGFkZGluZ1ggfSkgPT4gZ2V0U3BhY2UocGFkZGluZ1gpfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyBwYWRkaW5nWCB9KSA9PiBnZXRTcGFjZShwYWRkaW5nWCl9O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgYWxpZ24taXRlbXM6ICR7KHsgY2FyZFRvcCB9KSA9PiAoY2FyZFRvcCA/ICdzdGFydCcgOiAnY2VudGVyJyl9O1xuICBqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG4gIC5sZWF2ZVRvLFxuICAuZW50ZXJGcm9tIHtcbiAgICBvcGFjaXR5OiAwO1xuICB9XG4gIC5lbnRlclRvLFxuICAubGVhdmVUbyB7XG4gICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuICB9XG5gO1xuXG5jb25zdCBDb250YWluZXIgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBjYXJkVG9wLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPENvbnRhaW5lclJvb3QgcmVmPXtyZWZ9IGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCIgY2FyZFRvcD17Y2FyZFRvcH0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvQ29udGFpbmVyUm9vdD5cbikpO1xuXG5jb25zdCBCYWNrZHJvcCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8Qm94XG4gICAgcmVmPXtyZWZ9XG4gICAgcG9zaXRpb249XCJmaXhlZFwiXG4gICAgdG9wPVwiMFwiXG4gICAgbGVmdD1cIjBcIlxuICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgYmFja2dyb3VuZENvbG9yPVwiYmFja2Ryb3BcIlxuICAgIHsuLi5wcm9wc31cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9Cb3g+XG4pKTtcblxuY29uc3QgdHJhbnNpdGlvbkNoaWxkUHJvcHMgPSB7XG4gIGVudGVyOiAnZW50ZXInLFxuICBlbnRlckZyb206ICdlbnRlckZyb20nLFxuICBlbnRlclRvOiAnZW50ZXJUbycsXG4gIGxlYXZlOiAnbGVhdmUnLFxuICBsZWF2ZUZyb206ICdsZWF2ZUZyb20nLFxuICBsZWF2ZVRvOiAnbGVhdmVUbycsXG59O1xuXG5leHBvcnQgY29uc3QgTW9kYWwgPSAoe1xuICBpc09wZW4sXG4gIGNoaWxkcmVuLFxuICBvbkNsb3NlLFxuICB0aXRsZSxcbiAgZGVzY3JpcHRpb24sXG4gIHBhZGRpbmdYID0gJ2wnLFxuICBjYXJkUGFkZGluZyA9ICd4bCcsXG4gIGNhcmRSYWRpdXMgPSAnbCcsXG4gIGNhcmRNYXhXaWR0aCA9IDY4LFxuICBjYXJkTWF4SGVpZ2h0ID0gJzkwdmgnLFxuICBjYXJkSGVpZ2h0LFxuICBjYXJkVG9wLFxuICB6SW5kZXggPSBtb2RhbFpJbmRleCxcbiAgaW5pdGlhbEZvY3VzLFxuICByZXR1cm5Gb2N1cyxcbiAgY2xvc2VCdXR0b25Qcm9wcyxcbiAgaGFzQ2xvc2VCdXR0b24gPSB0cnVlLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyID0gZmFsc2UsXG4gIC4uLnByb3BzXG59KSA9PiB7XG4gIGNvbnN0IGhhc0JhY2tkcm9wID0gY2FyZEhlaWdodCAhPT0gJzEwMHZoJztcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICBpZiAoZGlzYWJsZUNsb3NlSGFuZGxlcikgcmV0dXJuO1xuXG4gICAgaWYgKEJvb2xlYW4ob25DbG9zZSkpIHtcbiAgICAgIG9uQ2xvc2UoKTtcbiAgICB9XG4gICAgaWYgKHJldHVybkZvY3VzKSB7XG4gICAgICByZXR1cm5Gb2N1cy5mb2N1cygpO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxUcmFuc2l0aW9uIGFwcGVhciBzaG93PXtpc09wZW59IGFzPXtGcmFnbWVudH0+XG4gICAgICA8RGlhbG9nXG4gICAgICAgIGFzPXtDb250YWluZXJ9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgaW5pdGlhbEZvY3VzPXtpbml0aWFsRm9jdXN9XG4gICAgICAgIHBhZGRpbmdYPXtwYWRkaW5nWH1cbiAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aGFzQmFja2Ryb3AgJiYgPFRyYW5zaXRpb24uQ2hpbGQgYXM9e0JhY2tkcm9wfSB7Li4udHJhbnNpdGlvbkNoaWxkUHJvcHN9IC8+fVxuXG4gICAgICAgIDxUcmFuc2l0aW9uLkNoaWxkIGFzPXtGcmFnbWVudH0gey4uLnRyYW5zaXRpb25DaGlsZFByb3BzfT5cbiAgICAgICAgICA8RGlhbG9nLlBhbmVsXG4gICAgICAgICAgICBhcz17TW9kYWxDYXJkfVxuICAgICAgICAgICAgb25DbG9zZUNsaWNrPXtvbkNsb3NlfVxuICAgICAgICAgICAgY2FyZFBhZGRpbmc9e2NhcmRQYWRkaW5nfVxuICAgICAgICAgICAgY2FyZE1heFdpZHRoPXtjYXJkTWF4V2lkdGh9XG4gICAgICAgICAgICBjYXJkTWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fVxuICAgICAgICAgICAgY2FyZEhlaWdodD17Y2FyZEhlaWdodH1cbiAgICAgICAgICAgIGNsb3NlQnV0dG9uUHJvcHM9e2Nsb3NlQnV0dG9uUHJvcHN9XG4gICAgICAgICAgICBjYXJkUmFkaXVzPXtjYXJkUmFkaXVzfVxuICAgICAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgICAgIGhhc0Nsb3NlQnV0dG9uPXtoYXNDbG9zZUJ1dHRvbn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dGl0bGUgJiYgPERpYWxvZy5UaXRsZSBhcz17VGl0bGV9Pnt0aXRsZX08L0RpYWxvZy5UaXRsZT59XG4gICAgICAgICAgICB7ZGVzY3JpcHRpb24gJiYgKFxuICAgICAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInNcIj5cbiAgICAgICAgICAgICAgICA8RGlhbG9nLkRlc2NyaXB0aW9uIGFzPVwiZGl2XCI+e2Rlc2NyaXB0aW9ufTwvRGlhbG9nLkRlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICA8L0JveD5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9EaWFsb2cuUGFuZWw+XG4gICAgICAgIDwvVHJhbnNpdGlvbi5DaGlsZD5cbiAgICAgIDwvRGlhbG9nPlxuICAgIDwvVHJhbnNpdGlvbj5cbiAgKTtcbn07XG5cbk1vZGFsLlRpdGxlID0gVGl0bGU7XG5cbk1vZGFsLnByb3BUeXBlcyA9IHtcbiAgaXNPcGVuOiBQcm9wVHlwZXMuYm9vbCxcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBvbkNsb3NlOiBQcm9wVHlwZXMuZnVuYyxcbiAgaGFzQ2xvc2VCdXR0b246IFByb3BUeXBlcy5ib29sLFxuICB0aXRsZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLnN0cmluZywgUHJvcFR5cGVzLm5vZGVdKSxcbiAgZGVzY3JpcHRpb246IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5ub2RlXSksXG4gIGNhcmRQYWRkaW5nOiB0eXBlcy5kaW1lbnNpb24sXG4gIGNhcmRNYXhXaWR0aDogUHJvcFR5cGVzLm9uZU9mVHlwZShbXG4gICAgUHJvcFR5cGVzLm51bWJlcixcbiAgICBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIFByb3BUeXBlcy5vbmVPZihbJ25hcnJvdycsICdtZWRpdW0nLCAnd2lkZSddKSxcbiAgXSksXG4gIGNhcmRIZWlnaHQ6IHR5cGVzLmRpbWVuc2lvbixcbiAgY2FyZE1heEhlaWdodDogdHlwZXMuZGltZW5zaW9uLFxuICBjYXJkUmFkaXVzOiB0eXBlcy5yYWRpdXMsXG4gIGNhcmRUb3A6IHR5cGVzLnNwYWNlLFxuICB6SW5kZXg6IHR5cGVzLnpJbmRleCxcbiAgaW5pdGlhbEZvY3VzOiBQcm9wVHlwZXMubm9kZSxcbiAgcmV0dXJuRm9jdXM6IFByb3BUeXBlcy5ub2RlLFxuICBjbG9zZUJ1dHRvblByb3BzOiBQcm9wVHlwZXMub2JqZWN0LFxuICBwYWRkaW5nWDogdHlwZXMuZGltZW5zaW9uLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyOiBQcm9wVHlwZXMuYm9vbCxcbn07XG4iXX0= */",
|
|
90
90
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
91
91
|
});
|
|
92
92
|
|
|
@@ -130,7 +130,7 @@ const ContainerRoot = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
|
|
|
130
130
|
cardTop
|
|
131
131
|
} = _ref6;
|
|
132
132
|
return cardTop ? 'start' : 'center';
|
|
133
|
-
}, ";justify-items:center;.leaveTo,.enterFrom{opacity:0;}.enterTo,.leaveTo{transition-duration:", getTransition('fast'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RWdDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBEaWFsb2csIFRyYW5zaXRpb24gfSBmcm9tICdAaGVhZGxlc3N1aS9yZWFjdCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi90ZXh0JztcbmltcG9ydCB7IGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEljb25Dcm9zcyB9IGZyb20gJy4uL2ljb25zJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBtb2RhbFpJbmRleCA9IDEwOTk7XG5cbmNvbnN0IGNhcmRNYXhXaWR0aHMgPSB7XG4gIG5hcnJvdzogNTUsXG4gIG1lZGl1bTogNzIsXG4gIHdpZGU6IDEzMCxcbn07XG5cbmNvbnN0IE1vZGFsQ2FyZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjYXJkUGFkZGluZyxcbiAgICAgIGNhcmRNYXhXaWR0aCxcbiAgICAgIGNhcmRNYXhIZWlnaHQsXG4gICAgICBjYXJkUmFkaXVzLFxuICAgICAgY2FyZEhlaWdodCxcbiAgICAgIGNhcmRUb3AsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIG9uQ2xvc2VDbGljayxcbiAgICAgIGNsb3NlQnV0dG9uUHJvcHMsXG4gICAgICBoYXNDbG9zZUJ1dHRvbixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICA8Qm94XG4gICAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgICAgIG1heFdpZHRoPXtjYXJkTWF4V2lkdGhzW2NhcmRNYXhXaWR0aF0gfHwgY2FyZE1heFdpZHRofVxuICAgICAgICBjbGFzc05hbWU9XCJncm4tY2FyZC1jb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8Qm94XG4gICAgICAgICAgY2xhc3NOYW1lPVwiZ3JuLWNhcmRcIlxuICAgICAgICAgIHBvc2l0aW9uPVwicmVsYXRpdmVcIlxuICAgICAgICAgIHJhZGl1cz17Y2FyZFJhZGl1c31cbiAgICAgICAgICBvdmVyZmxvdz1cImhpZGRlblwiXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPVwiZmxvYXRpbmdCYWNrZ3JvdW5kXCJcbiAgICAgICAgICBzaGFkb3c9XCJsXCJcbiAgICAgICAgICB0b3A9e2NhcmRUb3B9XG4gICAgICAgICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICA+XG4gICAgICAgICAgPEJveCBwYWRkaW5nPXtjYXJkUGFkZGluZ30gb3ZlcmZsb3c9XCJhdXRvXCIgbWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fSBoZWlnaHQ9e2NhcmRIZWlnaHR9PlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQm94PlxuICAgICAgICAgIHtoYXNDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgICA8Qm94IHBvc2l0aW9uPVwiYWJzb2x1dGVcIiByaWdodD1cInhzXCIgdG9wPVwieHNcIiB6SW5kZXg9ezF9PlxuICAgICAgICAgICAgICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsb3NlQ2xpY2t9IHsuLi5jbG9zZUJ1dHRvblByb3BzfSAvPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JveD5cbiAgICApO1xuICB9LFxuKTtcblxuY29uc3QgVGl0bGVSb290ID0gc3R5bGVkKFRleHQpYFxuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBUaXRsZSA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGl0bGVSb290IHRhZz1cImgzXCIgcmVmPXtyZWZ9IHNpemU9XCJ4bFwiIHdlaWdodD1cIm1lZGl1bVwiIHRyaW1Ub3Agey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGl0bGVSb290PlxuKSk7XG5cbmNvbnN0IENvbnRhaW5lclJvb3QgPSBzdHlsZWQuZGl2YFxuICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuICBwYWRkaW5nLWxlZnQ6ICR7KHsgcGFkZGluZ1ggfSkgPT4gZ2V0U3BhY2UocGFkZGluZ1gpfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyBwYWRkaW5nWCB9KSA9PiBnZXRTcGFjZShwYWRkaW5nWCl9O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgYWxpZ24taXRlbXM6ICR7KHsgY2FyZFRvcCB9KSA9PiAoY2FyZFRvcCA/ICdzdGFydCcgOiAnY2VudGVyJyl9O1xuICBqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG4gIC5sZWF2ZVRvLFxuICAuZW50ZXJGcm9tIHtcbiAgICBvcGFjaXR5OiAwO1xuICB9XG4gIC5lbnRlclRvLFxuICAubGVhdmVUbyB7XG4gICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuICB9XG5gO1xuXG5jb25zdCBDb250YWluZXIgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBjYXJkVG9wLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPENvbnRhaW5lclJvb3QgcmVmPXtyZWZ9IGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCIgY2FyZFRvcD17Y2FyZFRvcH0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvQ29udGFpbmVyUm9vdD5cbikpO1xuXG5jb25zdCBCYWNrZHJvcCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8Qm94XG4gICAgcmVmPXtyZWZ9XG4gICAgcG9zaXRpb249XCJmaXhlZFwiXG4gICAgdG9wPVwiMFwiXG4gICAgbGVmdD1cIjBcIlxuICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgYmFja2dyb3VuZENvbG9yPVwiYmFja2Ryb3BcIlxuICAgIHsuLi5wcm9wc31cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9Cb3g+XG4pKTtcblxuY29uc3QgdHJhbnNpdGlvbkNoaWxkUHJvcHMgPSB7XG4gIGVudGVyOiAnZW50ZXInLFxuICBlbnRlckZyb206ICdlbnRlckZyb20nLFxuICBlbnRlclRvOiAnZW50ZXJUbycsXG4gIGxlYXZlOiAnbGVhdmUnLFxuICBsZWF2ZUZyb206ICdsZWF2ZUZyb20nLFxuICBsZWF2ZVRvOiAnbGVhdmVUbycsXG59O1xuXG5leHBvcnQgY29uc3QgTW9kYWwgPSAoe1xuICBpc09wZW4sXG4gIGNoaWxkcmVuLFxuICBvbkNsb3NlLFxuICB0aXRsZSxcbiAgZGVzY3JpcHRpb24sXG4gIHBhZGRpbmdYID0gJ2wnLFxuICBjYXJkUGFkZGluZyA9ICd4bCcsXG4gIGNhcmRSYWRpdXMgPSAnbCcsXG4gIGNhcmRNYXhXaWR0aCA9IDY4LFxuICBjYXJkTWF4SGVpZ2h0ID0gJzkwdmgnLFxuICBjYXJkSGVpZ2h0LFxuICBjYXJkVG9wLFxuICB6SW5kZXggPSBtb2RhbFpJbmRleCxcbiAgaW5pdGlhbEZvY3VzLFxuICByZXR1cm5Gb2N1cyxcbiAgY2xvc2VCdXR0b25Qcm9wcyxcbiAgaGFzQ2xvc2VCdXR0b24gPSB0cnVlLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyID0gZmFsc2UsXG4gIC4uLnByb3BzXG59KSA9PiB7XG4gIGNvbnN0IGhhc0JhY2tkcm9wID0gY2FyZEhlaWdodCAhPT0gJzEwMHZoJztcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICBpZiAoZGlzYWJsZUNsb3NlSGFuZGxlcikgcmV0dXJuO1xuXG4gICAgaWYgKEJvb2xlYW4ob25DbG9zZSkpIHtcbiAgICAgIG9uQ2xvc2UoKTtcbiAgICB9XG4gICAgaWYgKHJldHVybkZvY3VzKSB7XG4gICAgICByZXR1cm5Gb2N1cy5mb2N1cygpO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxUcmFuc2l0aW9uIGFwcGVhciBzaG93PXtpc09wZW59IGFzPXtGcmFnbWVudH0+XG4gICAgICA8RGlhbG9nXG4gICAgICAgIGFzPXtDb250YWluZXJ9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgaW5pdGlhbEZvY3VzPXtpbml0aWFsRm9jdXN9XG4gICAgICAgIHBhZGRpbmdYPXtwYWRkaW5nWH1cbiAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aGFzQmFja2Ryb3AgJiYgPFRyYW5zaXRpb24uQ2hpbGQgYXM9e0JhY2tkcm9wfSB7Li4udHJhbnNpdGlvbkNoaWxkUHJvcHN9IC8+fVxuXG4gICAgICAgIDxUcmFuc2l0aW9uLkNoaWxkIGFzPXtGcmFnbWVudH0gey4uLnRyYW5zaXRpb25DaGlsZFByb3BzfT5cbiAgICAgICAgICA8RGlhbG9nLlBhbmVsXG4gICAgICAgICAgICBhcz17TW9kYWxDYXJkfVxuICAgICAgICAgICAgb25DbG9zZUNsaWNrPXtvbkNsb3NlfVxuICAgICAgICAgICAgY2FyZFBhZGRpbmc9e2NhcmRQYWRkaW5nfVxuICAgICAgICAgICAgY2FyZE1heFdpZHRoPXtjYXJkTWF4V2lkdGh9XG4gICAgICAgICAgICBjYXJkTWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fVxuICAgICAgICAgICAgY2FyZEhlaWdodD17Y2FyZEhlaWdodH1cbiAgICAgICAgICAgIGNsb3NlQnV0dG9uUHJvcHM9e2Nsb3NlQnV0dG9uUHJvcHN9XG4gICAgICAgICAgICBjYXJkUmFkaXVzPXtjYXJkUmFkaXVzfVxuICAgICAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgICAgIGhhc0Nsb3NlQnV0dG9uPXtoYXNDbG9zZUJ1dHRvbn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dGl0bGUgJiYgPERpYWxvZy5UaXRsZSBhcz17VGl0bGV9Pnt0aXRsZX08L0RpYWxvZy5UaXRsZT59XG4gICAgICAgICAgICB7ZGVzY3JpcHRpb24gJiYgKFxuICAgICAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInNcIj5cbiAgICAgICAgICAgICAgICA8RGlhbG9nLkRlc2NyaXB0aW9uIGFzPVwiZGl2XCI+e2Rlc2NyaXB0aW9ufTwvRGlhbG9nLkRlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICA8L0JveD5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9EaWFsb2cuUGFuZWw+
|
|
133
|
+
}, ";justify-items:center;.leaveTo,.enterFrom{opacity:0;}.enterTo,.leaveTo{transition-duration:", getTransition('fast'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RWdDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBEaWFsb2csIFRyYW5zaXRpb24gfSBmcm9tICdAaGVhZGxlc3N1aS9yZWFjdCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi90ZXh0JztcbmltcG9ydCB7IGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEljb25Dcm9zcyB9IGZyb20gJy4uL2ljb25zJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBtb2RhbFpJbmRleCA9IDEwOTk7XG5cbmNvbnN0IGNhcmRNYXhXaWR0aHMgPSB7XG4gIG5hcnJvdzogNTUsXG4gIG1lZGl1bTogNzIsXG4gIHdpZGU6IDEzMCxcbn07XG5cbmNvbnN0IE1vZGFsQ2FyZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjYXJkUGFkZGluZyxcbiAgICAgIGNhcmRNYXhXaWR0aCxcbiAgICAgIGNhcmRNYXhIZWlnaHQsXG4gICAgICBjYXJkUmFkaXVzLFxuICAgICAgY2FyZEhlaWdodCxcbiAgICAgIGNhcmRUb3AsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIG9uQ2xvc2VDbGljayxcbiAgICAgIGNsb3NlQnV0dG9uUHJvcHMsXG4gICAgICBoYXNDbG9zZUJ1dHRvbixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICA8Qm94XG4gICAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgICAgIG1heFdpZHRoPXtjYXJkTWF4V2lkdGhzW2NhcmRNYXhXaWR0aF0gfHwgY2FyZE1heFdpZHRofVxuICAgICAgICBjbGFzc05hbWU9XCJncm4tY2FyZC1jb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8Qm94XG4gICAgICAgICAgY2xhc3NOYW1lPVwiZ3JuLWNhcmRcIlxuICAgICAgICAgIHBvc2l0aW9uPVwicmVsYXRpdmVcIlxuICAgICAgICAgIHJhZGl1cz17Y2FyZFJhZGl1c31cbiAgICAgICAgICBvdmVyZmxvdz1cImhpZGRlblwiXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPVwiZmxvYXRpbmdCYWNrZ3JvdW5kXCJcbiAgICAgICAgICBzaGFkb3c9XCJsXCJcbiAgICAgICAgICB0b3A9e2NhcmRUb3B9XG4gICAgICAgICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICA+XG4gICAgICAgICAgPEJveCBwYWRkaW5nPXtjYXJkUGFkZGluZ30gb3ZlcmZsb3c9XCJhdXRvXCIgbWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fSBoZWlnaHQ9e2NhcmRIZWlnaHR9PlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQm94PlxuICAgICAgICAgIHtoYXNDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgICA8Qm94IHBvc2l0aW9uPVwiYWJzb2x1dGVcIiByaWdodD1cInhzXCIgdG9wPVwieHNcIiB6SW5kZXg9ezF9PlxuICAgICAgICAgICAgICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsb3NlQ2xpY2t9IHsuLi5jbG9zZUJ1dHRvblByb3BzfSAvPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JveD5cbiAgICApO1xuICB9LFxuKTtcblxuY29uc3QgVGl0bGVSb290ID0gc3R5bGVkKFRleHQpYFxuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBUaXRsZSA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGl0bGVSb290IHRhZz1cImgzXCIgcmVmPXtyZWZ9IHNpemU9XCJ4bFwiIHdlaWdodD1cIm1lZGl1bVwiIHRyaW1Ub3Agey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGl0bGVSb290PlxuKSk7XG5cbmNvbnN0IENvbnRhaW5lclJvb3QgPSBzdHlsZWQuZGl2YFxuICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuICBwYWRkaW5nLWxlZnQ6ICR7KHsgcGFkZGluZ1ggfSkgPT4gZ2V0U3BhY2UocGFkZGluZ1gpfTtcbiAgcGFkZGluZy1yaWdodDogJHsoeyBwYWRkaW5nWCB9KSA9PiBnZXRTcGFjZShwYWRkaW5nWCl9O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgYWxpZ24taXRlbXM6ICR7KHsgY2FyZFRvcCB9KSA9PiAoY2FyZFRvcCA/ICdzdGFydCcgOiAnY2VudGVyJyl9O1xuICBqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG4gIC5sZWF2ZVRvLFxuICAuZW50ZXJGcm9tIHtcbiAgICBvcGFjaXR5OiAwO1xuICB9XG4gIC5lbnRlclRvLFxuICAubGVhdmVUbyB7XG4gICAgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuICB9XG5gO1xuXG5jb25zdCBDb250YWluZXIgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBjYXJkVG9wLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPENvbnRhaW5lclJvb3QgcmVmPXtyZWZ9IGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCIgY2FyZFRvcD17Y2FyZFRvcH0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvQ29udGFpbmVyUm9vdD5cbikpO1xuXG5jb25zdCBCYWNrZHJvcCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8Qm94XG4gICAgcmVmPXtyZWZ9XG4gICAgcG9zaXRpb249XCJmaXhlZFwiXG4gICAgdG9wPVwiMFwiXG4gICAgbGVmdD1cIjBcIlxuICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgaGVpZ2h0PVwiMTAwJVwiXG4gICAgYmFja2dyb3VuZENvbG9yPVwiYmFja2Ryb3BcIlxuICAgIHsuLi5wcm9wc31cbiAgPlxuICAgIHtjaGlsZHJlbn1cbiAgPC9Cb3g+XG4pKTtcblxuY29uc3QgdHJhbnNpdGlvbkNoaWxkUHJvcHMgPSB7XG4gIGVudGVyOiAnZW50ZXInLFxuICBlbnRlckZyb206ICdlbnRlckZyb20nLFxuICBlbnRlclRvOiAnZW50ZXJUbycsXG4gIGxlYXZlOiAnbGVhdmUnLFxuICBsZWF2ZUZyb206ICdsZWF2ZUZyb20nLFxuICBsZWF2ZVRvOiAnbGVhdmVUbycsXG59O1xuXG5leHBvcnQgY29uc3QgTW9kYWwgPSAoe1xuICBpc09wZW4sXG4gIGNoaWxkcmVuLFxuICBvbkNsb3NlLFxuICB0aXRsZSxcbiAgZGVzY3JpcHRpb24sXG4gIHBhZGRpbmdYID0gJ2wnLFxuICBjYXJkUGFkZGluZyA9ICd4bCcsXG4gIGNhcmRSYWRpdXMgPSAnbCcsXG4gIGNhcmRNYXhXaWR0aCA9IDY4LFxuICBjYXJkTWF4SGVpZ2h0ID0gJzkwdmgnLFxuICBjYXJkSGVpZ2h0LFxuICBjYXJkVG9wLFxuICB6SW5kZXggPSBtb2RhbFpJbmRleCxcbiAgaW5pdGlhbEZvY3VzLFxuICByZXR1cm5Gb2N1cyxcbiAgY2xvc2VCdXR0b25Qcm9wcyxcbiAgaGFzQ2xvc2VCdXR0b24gPSB0cnVlLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyID0gZmFsc2UsXG4gIC4uLnByb3BzXG59KSA9PiB7XG4gIGNvbnN0IGhhc0JhY2tkcm9wID0gY2FyZEhlaWdodCAhPT0gJzEwMHZoJztcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICBpZiAoZGlzYWJsZUNsb3NlSGFuZGxlcikgcmV0dXJuO1xuXG4gICAgaWYgKEJvb2xlYW4ob25DbG9zZSkpIHtcbiAgICAgIG9uQ2xvc2UoKTtcbiAgICB9XG4gICAgaWYgKHJldHVybkZvY3VzKSB7XG4gICAgICByZXR1cm5Gb2N1cy5mb2N1cygpO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxUcmFuc2l0aW9uIGFwcGVhciBzaG93PXtpc09wZW59IGFzPXtGcmFnbWVudH0+XG4gICAgICA8RGlhbG9nXG4gICAgICAgIGFzPXtDb250YWluZXJ9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgaW5pdGlhbEZvY3VzPXtpbml0aWFsRm9jdXN9XG4gICAgICAgIHBhZGRpbmdYPXtwYWRkaW5nWH1cbiAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aGFzQmFja2Ryb3AgJiYgPFRyYW5zaXRpb24uQ2hpbGQgYXM9e0JhY2tkcm9wfSB7Li4udHJhbnNpdGlvbkNoaWxkUHJvcHN9IC8+fVxuXG4gICAgICAgIDxUcmFuc2l0aW9uLkNoaWxkIGFzPXtGcmFnbWVudH0gey4uLnRyYW5zaXRpb25DaGlsZFByb3BzfT5cbiAgICAgICAgICA8RGlhbG9nLlBhbmVsXG4gICAgICAgICAgICBhcz17TW9kYWxDYXJkfVxuICAgICAgICAgICAgb25DbG9zZUNsaWNrPXtvbkNsb3NlfVxuICAgICAgICAgICAgY2FyZFBhZGRpbmc9e2NhcmRQYWRkaW5nfVxuICAgICAgICAgICAgY2FyZE1heFdpZHRoPXtjYXJkTWF4V2lkdGh9XG4gICAgICAgICAgICBjYXJkTWF4SGVpZ2h0PXtjYXJkTWF4SGVpZ2h0fVxuICAgICAgICAgICAgY2FyZEhlaWdodD17Y2FyZEhlaWdodH1cbiAgICAgICAgICAgIGNsb3NlQnV0dG9uUHJvcHM9e2Nsb3NlQnV0dG9uUHJvcHN9XG4gICAgICAgICAgICBjYXJkUmFkaXVzPXtjYXJkUmFkaXVzfVxuICAgICAgICAgICAgY2FyZFRvcD17Y2FyZFRvcH1cbiAgICAgICAgICAgIGhhc0Nsb3NlQnV0dG9uPXtoYXNDbG9zZUJ1dHRvbn1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dGl0bGUgJiYgPERpYWxvZy5UaXRsZSBhcz17VGl0bGV9Pnt0aXRsZX08L0RpYWxvZy5UaXRsZT59XG4gICAgICAgICAgICB7ZGVzY3JpcHRpb24gJiYgKFxuICAgICAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInNcIj5cbiAgICAgICAgICAgICAgICA8RGlhbG9nLkRlc2NyaXB0aW9uIGFzPVwiZGl2XCI+e2Rlc2NyaXB0aW9ufTwvRGlhbG9nLkRlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICA8L0JveD5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9EaWFsb2cuUGFuZWw+XG4gICAgICAgIDwvVHJhbnNpdGlvbi5DaGlsZD5cbiAgICAgIDwvRGlhbG9nPlxuICAgIDwvVHJhbnNpdGlvbj5cbiAgKTtcbn07XG5cbk1vZGFsLlRpdGxlID0gVGl0bGU7XG5cbk1vZGFsLnByb3BUeXBlcyA9IHtcbiAgaXNPcGVuOiBQcm9wVHlwZXMuYm9vbCxcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBvbkNsb3NlOiBQcm9wVHlwZXMuZnVuYyxcbiAgaGFzQ2xvc2VCdXR0b246IFByb3BUeXBlcy5ib29sLFxuICB0aXRsZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLnN0cmluZywgUHJvcFR5cGVzLm5vZGVdKSxcbiAgZGVzY3JpcHRpb246IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5ub2RlXSksXG4gIGNhcmRQYWRkaW5nOiB0eXBlcy5kaW1lbnNpb24sXG4gIGNhcmRNYXhXaWR0aDogUHJvcFR5cGVzLm9uZU9mVHlwZShbXG4gICAgUHJvcFR5cGVzLm51bWJlcixcbiAgICBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIFByb3BUeXBlcy5vbmVPZihbJ25hcnJvdycsICdtZWRpdW0nLCAnd2lkZSddKSxcbiAgXSksXG4gIGNhcmRIZWlnaHQ6IHR5cGVzLmRpbWVuc2lvbixcbiAgY2FyZE1heEhlaWdodDogdHlwZXMuZGltZW5zaW9uLFxuICBjYXJkUmFkaXVzOiB0eXBlcy5yYWRpdXMsXG4gIGNhcmRUb3A6IHR5cGVzLnNwYWNlLFxuICB6SW5kZXg6IHR5cGVzLnpJbmRleCxcbiAgaW5pdGlhbEZvY3VzOiBQcm9wVHlwZXMubm9kZSxcbiAgcmV0dXJuRm9jdXM6IFByb3BUeXBlcy5ub2RlLFxuICBjbG9zZUJ1dHRvblByb3BzOiBQcm9wVHlwZXMub2JqZWN0LFxuICBwYWRkaW5nWDogdHlwZXMuZGltZW5zaW9uLFxuICBkaXNhYmxlQ2xvc2VIYW5kbGVyOiBQcm9wVHlwZXMuYm9vbCxcbn07XG4iXX0= */"));
|
|
134
134
|
|
|
135
135
|
const Container = /*#__PURE__*/forwardRef((_ref7, ref) => {
|
|
136
136
|
let {
|
|
@@ -253,7 +253,7 @@ Modal.propTypes = {
|
|
|
253
253
|
cardHeight: types.dimension,
|
|
254
254
|
cardMaxHeight: types.dimension,
|
|
255
255
|
cardRadius: types.radius,
|
|
256
|
-
cardTop: types.
|
|
256
|
+
cardTop: types.space,
|
|
257
257
|
zIndex: types.zIndex,
|
|
258
258
|
initialFocus: PropTypes.node,
|
|
259
259
|
returnFocus: PropTypes.node,
|
package/es/components/popover.js
CHANGED
|
@@ -41,7 +41,7 @@ const ChildrenWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
41
41
|
isOpen
|
|
42
42
|
} = _ref4;
|
|
43
43
|
return isOpen ? "transition-duration: ".concat(getTransition('xxFast')) : "transition-duration: ".concat(getTransition('xFast'), "; opacity: 0; pointer-events: none;");
|
|
44
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3BvcG92ZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCa0MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcG9wb3Zlci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlUmVmLCB1c2VFZmZlY3QsIGNsb25lRWxlbWVudCwgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBwbGFjZW1lbnRzTWFwIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IHVzZUtleVByZXNzLCB1c2VPbkNsaWNrT3V0c2lkZSB9IGZyb20gJy4uL2hvb2tzJztcbmltcG9ydCB7XG4gIGdldENvbG9yLFxuICBnZXREaW1lbnNpb24sXG4gIGdldFJhZGl1cyxcbiAgZ2V0U2hhZG93LFxuICBnZXRTcGFjZSxcbiAgZ2V0VHJhbnNpdGlvbixcbiAgbWVyZ2VSZWZzLFxufSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgdXNlRmxvYXRpbmcsXG4gIGF1dG9VcGRhdGUsXG4gIG9mZnNldCxcbiAgZmxpcCxcbiAgRmxvYXRpbmdQb3J0YWwsXG4gIHNoaWZ0LFxuICBsaW1pdFNoaWZ0LFxufSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QtZG9tLWludGVyYWN0aW9ucyc7XG5cbmNvbnN0IENoaWxkcmVuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICR7KHsgd2lkdGggfSkgPT4gYHdpZHRoOiAke2dldERpbWVuc2lvbih3aWR0aCl9YH07XG4gICR7KHsgcGFkZGluZyB9KSA9PiBgcGFkZGluZzogJHtnZXRTcGFjZShwYWRkaW5nKX1gfTtcbiAgYm94LXNoYWRvdzogJHtnZXRTaGFkb3coJ20nKX07XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdtJyl9O1xuICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdmbG9hdGluZ0JhY2tncm91bmQnKX07XG4gICR7KHsgekluZGV4IH0pID0+IGB6LWluZGV4OiAke3pJbmRleH1gfTtcbiAgdHJhbnNpdGlvbi1wcm9wZXJ0eTogb3BhY2l0eTtcbiAgJHsoeyBpc09wZW4gfSkgPT5cbiAgICBpc09wZW5cbiAgICAgID8gYHRyYW5zaXRpb24tZHVyYXRpb246ICR7Z2V0VHJhbnNpdGlvbigneHhGYXN0Jyl9YFxuICAgICAgOiBgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCd4RmFzdCcpfTsgb3BhY2l0eTogMDsgcG9pbnRlci1ldmVudHM6IG5vbmU7YH07XG5gO1xuXG5jb25zdCBwb3BvdmVyT2Zmc2V0cyA9IHtcbiAgeHM6IDggLyAyLFxuICBzOiA4ICogMSxcbiAgczI6IDggKiAxLjUsXG4gIG06IDggKiAyLFxuICBsOiA4ICogMyxcbiAgbDI6IDggKiA0LFxuICB4bDogOCAqIDUsXG4gIHhsMjogOCAqIDYsXG4gIHh4bDogOCAqIDcsXG59O1xuXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIHBhZGRpbmcgPSAnbCcsXG4gICAgICBwbGFjZW1lbnQgPSAnYm90dG9tJyxcbiAgICAgIHdpZHRoID0gJzI1NnB4JyxcbiAgICAgIHRyaWdnZXIsXG4gICAgICBpc09wZW4sXG4gICAgICBvbkNsb3NlLFxuICAgICAgekluZGV4ID0gMSxcbiAgICAgIGhhc1BvcnRhbCA9IHRydWUsXG4gICAgICBvZmZzZXQ6IHBvcG92ZXJPZmZzZXQgPSAneHMnLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgZXNjUHJlc3MgPSB1c2VLZXlQcmVzcygnRXNjYXBlJyk7XG4gICAgY29uc3Qgd3JhcHBlclJlZiA9IHVzZVJlZihudWxsKTtcblxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBpZiAoZXNjUHJlc3MpIG9uQ2xvc2UoKTtcbiAgICB9LCBbZXNjUHJlc3MsIG9uQ2xvc2VdKTtcblxuICAgIGNvbnN0IHsgeCwgeSwgcmVmZXJlbmNlLCBmbG9hdGluZywgc3RyYXRlZ3kgfSA9IHVzZUZsb2F0aW5nKHtcbiAgICAgIHBsYWNlbWVudDogcGxhY2VtZW50c01hcFtwbGFjZW1lbnRdLFxuICAgICAgbWlkZGxld2FyZTogW1xuICAgICAgICBvZmZzZXQocG9wb3Zlck9mZnNldHNbcG9wb3Zlck9mZnNldF0pLFxuICAgICAgICBmbGlwKCksXG4gICAgICAgIHNoaWZ0KHtcbiAgICAgICAgICBwYWRkaW5nOiA0LFxuICAgICAgICAgIGNyb3NzQXhpczogdHJ1ZSxcbiAgICAgICAgICBsaW1pdGVyOiBsaW1pdFNoaWZ0KHtcbiAgICAgICAgICAgIGNyb3NzQXhpczogZmFsc2UsXG4gICAgICAgICAgfSksXG4gICAgICAgIH0pLFxuICAgICAgXSxcbiAgICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxuICAgIH0pO1xuXG4gICAgY29uc3QgUm9vdCA9IGhhc1BvcnRhbCA/IEZsb2F0aW5nUG9ydGFsIDogRnJhZ21lbnQ7XG4gICAgY29uc3QgbWVyZ2VkUmVmID0gbWVyZ2VSZWZzKFtyZWYsIHdyYXBwZXJSZWZdKTtcbiAgICAvLyB1c2VkIGZvciBjbGljayBvdXRzaWRlXG4gICAgY29uc3QgdHJpZ2dlclJlZiA9IHVzZVJlZihudWxsKTtcbiAgICBjb25zdCBtZXJnZWRUcmlnZ2VyUmVmID0gbWVyZ2VSZWZzKFtyZWZlcmVuY2UsIHRyaWdnZXIucmVmLCB0cmlnZ2VyUmVmXSk7XG5cbiAgICB1c2VPbkNsaWNrT3V0c2lkZShbd3JhcHBlclJlZiwgdHJpZ2dlclJlZl0sIG9uQ2xvc2UpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDw+XG4gICAgICAgIHtjbG9uZUVsZW1lbnQodHJpZ2dlciwgeyByZWY6IG1lcmdlZFRyaWdnZXJSZWYgfSl9XG4gICAgICAgIDxSb290PlxuICAgICAgICAgIDxkaXYgcmVmPXttZXJnZWRSZWZ9PlxuICAgICAgICAgICAgPENoaWxkcmVuV3JhcHBlclxuICAgICAgICAgICAgICB3aWR0aD17d2lkdGh9XG4gICAgICAgICAgICAgIHBhZGRpbmc9e3BhZGRpbmd9XG4gICAgICAgICAgICAgIHpJbmRleD17ekluZGV4fVxuICAgICAgICAgICAgICBjbGFzc05hbWU9XCJncm4tY29udGV4dFwiXG4gICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICByZWY9e2Zsb2F0aW5nfVxuICAgICAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgICAgIHBvc2l0aW9uOiBzdHJhdGVneSxcbiAgICAgICAgICAgICAgICB0b3A6IHkgPz8gMCxcbiAgICAgICAgICAgICAgICBsZWZ0OiB4ID8/IDAsXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9DaGlsZHJlbldyYXBwZXI+XG4gICAgICAgICAgPC9kaXY+
|
|
44
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3BvcG92ZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCa0MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcG9wb3Zlci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlUmVmLCB1c2VFZmZlY3QsIGNsb25lRWxlbWVudCwgRnJhZ21lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBwbGFjZW1lbnRzTWFwIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IHVzZUtleVByZXNzLCB1c2VPbkNsaWNrT3V0c2lkZSB9IGZyb20gJy4uL2hvb2tzJztcbmltcG9ydCB7XG4gIGdldENvbG9yLFxuICBnZXREaW1lbnNpb24sXG4gIGdldFJhZGl1cyxcbiAgZ2V0U2hhZG93LFxuICBnZXRTcGFjZSxcbiAgZ2V0VHJhbnNpdGlvbixcbiAgbWVyZ2VSZWZzLFxufSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgdXNlRmxvYXRpbmcsXG4gIGF1dG9VcGRhdGUsXG4gIG9mZnNldCxcbiAgZmxpcCxcbiAgRmxvYXRpbmdQb3J0YWwsXG4gIHNoaWZ0LFxuICBsaW1pdFNoaWZ0LFxufSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QtZG9tLWludGVyYWN0aW9ucyc7XG5cbmNvbnN0IENoaWxkcmVuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICR7KHsgd2lkdGggfSkgPT4gYHdpZHRoOiAke2dldERpbWVuc2lvbih3aWR0aCl9YH07XG4gICR7KHsgcGFkZGluZyB9KSA9PiBgcGFkZGluZzogJHtnZXRTcGFjZShwYWRkaW5nKX1gfTtcbiAgYm94LXNoYWRvdzogJHtnZXRTaGFkb3coJ20nKX07XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdtJyl9O1xuICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdmbG9hdGluZ0JhY2tncm91bmQnKX07XG4gICR7KHsgekluZGV4IH0pID0+IGB6LWluZGV4OiAke3pJbmRleH1gfTtcbiAgdHJhbnNpdGlvbi1wcm9wZXJ0eTogb3BhY2l0eTtcbiAgJHsoeyBpc09wZW4gfSkgPT5cbiAgICBpc09wZW5cbiAgICAgID8gYHRyYW5zaXRpb24tZHVyYXRpb246ICR7Z2V0VHJhbnNpdGlvbigneHhGYXN0Jyl9YFxuICAgICAgOiBgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCd4RmFzdCcpfTsgb3BhY2l0eTogMDsgcG9pbnRlci1ldmVudHM6IG5vbmU7YH07XG5gO1xuXG5jb25zdCBwb3BvdmVyT2Zmc2V0cyA9IHtcbiAgeHM6IDggLyAyLFxuICBzOiA4ICogMSxcbiAgczI6IDggKiAxLjUsXG4gIG06IDggKiAyLFxuICBsOiA4ICogMyxcbiAgbDI6IDggKiA0LFxuICB4bDogOCAqIDUsXG4gIHhsMjogOCAqIDYsXG4gIHh4bDogOCAqIDcsXG59O1xuXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIHBhZGRpbmcgPSAnbCcsXG4gICAgICBwbGFjZW1lbnQgPSAnYm90dG9tJyxcbiAgICAgIHdpZHRoID0gJzI1NnB4JyxcbiAgICAgIHRyaWdnZXIsXG4gICAgICBpc09wZW4sXG4gICAgICBvbkNsb3NlLFxuICAgICAgekluZGV4ID0gMSxcbiAgICAgIGhhc1BvcnRhbCA9IHRydWUsXG4gICAgICBvZmZzZXQ6IHBvcG92ZXJPZmZzZXQgPSAneHMnLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgZXNjUHJlc3MgPSB1c2VLZXlQcmVzcygnRXNjYXBlJyk7XG4gICAgY29uc3Qgd3JhcHBlclJlZiA9IHVzZVJlZihudWxsKTtcblxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBpZiAoZXNjUHJlc3MpIG9uQ2xvc2UoKTtcbiAgICB9LCBbZXNjUHJlc3MsIG9uQ2xvc2VdKTtcblxuICAgIGNvbnN0IHsgeCwgeSwgcmVmZXJlbmNlLCBmbG9hdGluZywgc3RyYXRlZ3kgfSA9IHVzZUZsb2F0aW5nKHtcbiAgICAgIHBsYWNlbWVudDogcGxhY2VtZW50c01hcFtwbGFjZW1lbnRdLFxuICAgICAgbWlkZGxld2FyZTogW1xuICAgICAgICBvZmZzZXQocG9wb3Zlck9mZnNldHNbcG9wb3Zlck9mZnNldF0pLFxuICAgICAgICBmbGlwKCksXG4gICAgICAgIHNoaWZ0KHtcbiAgICAgICAgICBwYWRkaW5nOiA0LFxuICAgICAgICAgIGNyb3NzQXhpczogdHJ1ZSxcbiAgICAgICAgICBsaW1pdGVyOiBsaW1pdFNoaWZ0KHtcbiAgICAgICAgICAgIGNyb3NzQXhpczogZmFsc2UsXG4gICAgICAgICAgfSksXG4gICAgICAgIH0pLFxuICAgICAgXSxcbiAgICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxuICAgIH0pO1xuXG4gICAgY29uc3QgUm9vdCA9IGhhc1BvcnRhbCA/IEZsb2F0aW5nUG9ydGFsIDogRnJhZ21lbnQ7XG4gICAgY29uc3QgbWVyZ2VkUmVmID0gbWVyZ2VSZWZzKFtyZWYsIHdyYXBwZXJSZWZdKTtcbiAgICAvLyB1c2VkIGZvciBjbGljayBvdXRzaWRlXG4gICAgY29uc3QgdHJpZ2dlclJlZiA9IHVzZVJlZihudWxsKTtcbiAgICBjb25zdCBtZXJnZWRUcmlnZ2VyUmVmID0gbWVyZ2VSZWZzKFtyZWZlcmVuY2UsIHRyaWdnZXIucmVmLCB0cmlnZ2VyUmVmXSk7XG5cbiAgICB1c2VPbkNsaWNrT3V0c2lkZShbd3JhcHBlclJlZiwgdHJpZ2dlclJlZl0sIG9uQ2xvc2UpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDw+XG4gICAgICAgIHtjbG9uZUVsZW1lbnQodHJpZ2dlciwgeyByZWY6IG1lcmdlZFRyaWdnZXJSZWYgfSl9XG4gICAgICAgIDxSb290PlxuICAgICAgICAgIDxkaXYgcmVmPXttZXJnZWRSZWZ9PlxuICAgICAgICAgICAgPENoaWxkcmVuV3JhcHBlclxuICAgICAgICAgICAgICB3aWR0aD17d2lkdGh9XG4gICAgICAgICAgICAgIHBhZGRpbmc9e3BhZGRpbmd9XG4gICAgICAgICAgICAgIHpJbmRleD17ekluZGV4fVxuICAgICAgICAgICAgICBjbGFzc05hbWU9XCJncm4tY29udGV4dFwiXG4gICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICByZWY9e2Zsb2F0aW5nfVxuICAgICAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgICAgIHBvc2l0aW9uOiBzdHJhdGVneSxcbiAgICAgICAgICAgICAgICB0b3A6IHkgPz8gMCxcbiAgICAgICAgICAgICAgICBsZWZ0OiB4ID8/IDAsXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9DaGlsZHJlbldyYXBwZXI+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvUm9vdD5cbiAgICAgIDwvPlxuICAgICk7XG4gIH0sXG4pO1xuXG5Qb3BvdmVyLnByb3BUeXBlcyA9IHtcbiAgcGFkZGluZzogdHlwZXMuZGltZW5zaW9uLFxuICB3aWR0aDogdHlwZXMuZGltZW5zaW9uLFxuICBwbGFjZW1lbnQ6IHR5cGVzLnBsYWNlbWVudCxcbiAgdHJpZ2dlcjogUHJvcFR5cGVzLm5vZGUsXG4gIHpJbmRleDogdHlwZXMuekluZGV4LFxuICBpc09wZW46IFByb3BUeXBlcy5ib29sLFxuICBvbkNsb3NlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICBoYXNQb3J0YWw6IFByb3BUeXBlcy5ib29sLFxuICBvZmZzZXQ6IHR5cGVzLnNwYWNlLFxufTtcbiJdfQ== */"));
|
|
45
45
|
|
|
46
46
|
const popoverOffsets = {
|
|
47
47
|
xs: 8 / 2,
|
|
@@ -124,5 +124,5 @@ Popover.propTypes = {
|
|
|
124
124
|
isOpen: PropTypes.bool,
|
|
125
125
|
onClose: PropTypes.func.isRequired,
|
|
126
126
|
hasPortal: PropTypes.bool,
|
|
127
|
-
offset: types.
|
|
127
|
+
offset: types.space
|
|
128
128
|
};
|
|
@@ -15,9 +15,9 @@ import React from 'react';
|
|
|
15
15
|
import { Box, Text } from '.';
|
|
16
16
|
import { Icon } from './icon';
|
|
17
17
|
import { IconButton } from './icon-button';
|
|
18
|
-
import { componentVars, FieldHint, FieldLabel, InputField } from '../foundational';
|
|
18
|
+
import { componentVars, FieldClearButton, FieldHint, FieldLabel, InputField } from '../foundational';
|
|
19
19
|
import { types } from '../types';
|
|
20
|
-
import {
|
|
20
|
+
import { IconHide, IconShow } from '../icons';
|
|
21
21
|
import { useWidth } from '../hooks';
|
|
22
22
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
23
23
|
const iconOffsetPx = 12;
|
|
@@ -28,7 +28,7 @@ const IconSection = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
|
|
|
28
28
|
} : {
|
|
29
29
|
target: "e1o9e51y0",
|
|
30
30
|
label: "IconSection"
|
|
31
|
-
})("position:absolute;margin:auto;left:", iconOffsetPx, "px;top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
})("position:absolute;margin:auto;left:", iconOffsetPx, "px;top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtaW5wdXQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9COEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dC1pbnB1dC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEJveCwgVGV4dCB9IGZyb20gJy4nO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi9pY29uLWJ1dHRvbic7XG5pbXBvcnQge1xuICBjb21wb25lbnRWYXJzLFxuICBGaWVsZENsZWFyQnV0dG9uLFxuICBGaWVsZEhpbnQsXG4gIEZpZWxkTGFiZWwsXG4gIElucHV0RmllbGQsXG59IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEljb25IaWRlLCBJY29uU2hvdyB9IGZyb20gJy4uL2ljb25zJztcbmltcG9ydCB7IHVzZVdpZHRoIH0gZnJvbSAnLi4vaG9va3MnO1xuXG5jb25zdCBpY29uT2Zmc2V0UHggPSAxMjtcbmNvbnN0IGljb25UZXh0R2FwUHggPSA4O1xuXG5jb25zdCBJY29uU2VjdGlvbiA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgbWFyZ2luOiBhdXRvO1xuICBsZWZ0OiAke2ljb25PZmZzZXRQeH1weDtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIGhlaWdodDogZml0LWNvbnRlbnQ7XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuYDtcblxuY29uc3QgQWN0aW9uQnV0dG9uV3JhcHBlciA9ICh7IGNoaWxkcmVuIH0pID0+IHtcbiAgY29uc3QgcmlnaHRPZmZzZXQgPSBgY2FsYygodmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LW0pIC0gJHtjb21wb25lbnRWYXJzLmNsZWFyQnV0dG9uSGVpZ2h0fSkgLyAyKWA7XG4gIHJldHVybiAoXG4gICAgPEJveFxuICAgICAgcG9zaXRpb249XCJhYnNvbHV0ZVwiXG4gICAgICByaWdodD17cmlnaHRPZmZzZXR9XG4gICAgICB0b3A9XCIwXCJcbiAgICAgIGJvdHRvbT1cIjBcIlxuICAgICAgbWFyZ2luPVwiYXV0b1wiXG4gICAgICBoZWlnaHQ9XCJmaXQtY29udGVudFwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQm94PlxuICApO1xufTtcblxuY29uc3QgVmlzaWJpbGl0eUJ1dHRvbiA9ICh7IGNoaWxkcmVuLCBpbnRlcm5hbFR5cGUsIHNldEludGVybmFsVHlwZSwgLi4ucHJvcHMgfSkgPT4ge1xuICBjb25zdCB0eXBlQW5kSWNvbk1hcCA9IHtcbiAgICBwYXNzd29yZDogPEljb25TaG93IC8+LFxuICAgIHRleHQ6IDxJY29uSGlkZSAvPixcbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxBY3Rpb25CdXR0b25XcmFwcGVyPlxuICAgICAgPEljb25CdXR0b25cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgICBpY29uPXt0eXBlQW5kSWNvbk1hcFtpbnRlcm5hbFR5cGVdfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRJbnRlcm5hbFR5cGUoaW50ZXJuYWxUeXBlID09PSAndGV4dCcgPyAncGFzc3dvcmQnIDogJ3RleHQnKX1cbiAgICAgIC8+XG4gICAgPC9BY3Rpb25CdXR0b25XcmFwcGVyPlxuICApO1xufTtcblxuY29uc3QgQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrIH0pID0+IChcbiAgPEFjdGlvbkJ1dHRvbldyYXBwZXI+XG4gICAgPEZpZWxkQ2xlYXJCdXR0b24gb25DbGljaz17b25DbGlja30gLz5cbiAgPC9BY3Rpb25CdXR0b25XcmFwcGVyPlxuKTtcblxuZXhwb3J0IGNvbnN0IFRleHRJbnB1dExhYmVsID0gKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0pID0+IChcbiAgPEZpZWxkTGFiZWwgey4uLnByb3BzfT57Y2hpbGRyZW59PC9GaWVsZExhYmVsPlxuKTtcblxuZXhwb3J0IGNvbnN0IFRleHRJbnB1dCA9IFJlYWN0LmZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICB2YWx1ZSxcbiAgICAgIHBsYWNlaG9sZGVyLFxuICAgICAgbGFiZWwsXG4gICAgICBpZCxcbiAgICAgIGljb24sXG4gICAgICBoYXNFcnJvcixcbiAgICAgIGVycm9yTWVzc2FnZSxcbiAgICAgIGlzUmVhZE9ubHksXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgdHlwZSA9ICd0ZXh0JyxcbiAgICAgIGhpbnQsXG4gICAgICBvbkNsZWFyLFxuICAgICAgYmFja2dyb3VuZENvbG9yLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgaWNvblJlZiA9IFJlYWN0LnVzZVJlZihudWxsKTtcbiAgICBjb25zdCBbaW50ZXJuYWxUeXBlLCBzZXRJbnRlcm5hbFR5cGVdID0gUmVhY3QudXNlU3RhdGUodHlwZSk7XG5cbiAgICBjb25zdCBpY29uV2lkdGggPSB1c2VXaWR0aChpY29uUmVmKTtcbiAgICBjb25zdCBoYXNWaXNpYmlsaXR5QnV0dG9uID0gdHlwZSA9PT0gJ3Bhc3N3b3JkJyAmJiAhaXNSZWFkT25seSAmJiAhaXNEaXNhYmxlZDtcbiAgICBjb25zdCBoYXNDbGVhckJ1dHRvbiA9IG9uQ2xlYXIgJiYgIWlzUmVhZE9ubHkgJiYgIWlzRGlzYWJsZWQ7XG4gICAgY29uc3QgaGFzQnV0dG9uID0gaGFzVmlzaWJpbGl0eUJ1dHRvbiB8fCBoYXNDbGVhckJ1dHRvbjtcbiAgICBjb25zdCBwYWRkaW5nTGVmdCA9IGljb24gPyBgJHtpY29uT2Zmc2V0UHggKyBpY29uV2lkdGggKyBpY29uVGV4dEdhcFB4fXB4YCA6IHVuZGVmaW5lZDtcbiAgICBjb25zdCBwYWRkaW5nUmlnaHQgPSBoYXNCdXR0b24gPyAndmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LW0pJyA6IHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGZpZWxkTWFyZ2luVG9wID0gbGFiZWwgfHwgaGludCA/ICdiZXR3ZWVuRm9ybUNvbnRyb2xBbmRMYWJlbCcgOiB1bmRlZmluZWQ7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdj5cbiAgICAgICAge2xhYmVsICYmIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfT57bGFiZWx9PC9GaWVsZExhYmVsPn1cbiAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDxCb3ggcG9zaXRpb249XCJyZWxhdGl2ZVwiIG1hcmdpblRvcD17ZmllbGRNYXJnaW5Ub3B9PlxuICAgICAgICAgIHtpY29uICYmIChcbiAgICAgICAgICAgIDxJY29uU2VjdGlvbj5cbiAgICAgICAgICAgICAgPEljb24gcmVmPXtpY29uUmVmfSBpY29uPXtpY29ufSAvPlxuICAgICAgICAgICAgPC9JY29uU2VjdGlvbj5cbiAgICAgICAgICApfVxuICAgICAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIHR5cGU9e2ludGVybmFsVHlwZX1cbiAgICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdH1cbiAgICAgICAgICAgIHBhZGRpbmdSaWdodD17cGFkZGluZ1JpZ2h0fVxuICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgaXNSZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICAgIHtoYXNWaXNpYmlsaXR5QnV0dG9uICYmIChcbiAgICAgICAgICAgIDxWaXNpYmlsaXR5QnV0dG9uIHNldEludGVybmFsVHlwZT17c2V0SW50ZXJuYWxUeXBlfSBpbnRlcm5hbFR5cGU9e2ludGVybmFsVHlwZX0gLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtoYXNDbGVhckJ1dHRvbiAmJiB2YWx1ZSAmJiA8Q2xlYXJCdXR0b24gb25DbGljaz17b25DbGVhcn0gLz59XG4gICAgICAgIDwvQm94PlxuICAgICAgICB7ZXJyb3JNZXNzYWdlICYmIChcbiAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cImJldHdlZW5Gb3JtQ29udHJvbEFuZExhYmVsXCI+XG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cImRhbmdlclwiPntlcnJvck1lc3NhZ2V9PC9UZXh0PlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgKTtcbiAgfSxcbik7XG5cblRleHRJbnB1dC5MYWJlbCA9IFRleHRJbnB1dExhYmVsO1xuVGV4dElucHV0LkhpbnQgPSBGaWVsZEhpbnQ7XG5cblRleHRJbnB1dC5wcm9wVHlwZXMgPSB7XG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gIHBsYWNlaG9sZGVyOiBQcm9wVHlwZXMuc3RyaW5nLFxuICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLnN0cmluZywgUHJvcFR5cGVzLm51bWJlcl0pLFxuICBsYWJlbDogdHlwZXMubGFiZWwsXG4gIGljb246IFByb3BUeXBlcy5ub2RlLFxuICBoYXNFcnJvcjogUHJvcFR5cGVzLmJvb2wsXG4gIGVycm9yTWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgaXNSZWFkT25seTogUHJvcFR5cGVzLmJvb2wsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICB0eXBlOiB0eXBlcy50ZXh0SW5wdXQsXG4gIGhpbnQ6IHR5cGVzLmhpbnQsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuIl19 */"));
|
|
32
32
|
|
|
33
33
|
const ActionButtonWrapper = _ref => {
|
|
34
34
|
let {
|
|
@@ -67,8 +67,7 @@ const ClearButton = _ref3 => {
|
|
|
67
67
|
let {
|
|
68
68
|
onClick
|
|
69
69
|
} = _ref3;
|
|
70
|
-
return ___EmotionJSX(ActionButtonWrapper, null, ___EmotionJSX(
|
|
71
|
-
icon: ___EmotionJSX(IconCross, null),
|
|
70
|
+
return ___EmotionJSX(ActionButtonWrapper, null, ___EmotionJSX(FieldClearButton, {
|
|
72
71
|
onClick: onClick
|
|
73
72
|
}));
|
|
74
73
|
};
|
package/es/foundational/field.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
2
|
const _excluded = ["paddingLeft", "paddingRight", "hasError", "isReadOnly", "isDisabled", "backgroundColor"],
|
|
3
3
|
_excluded2 = ["children"],
|
|
4
|
-
_excluded3 = ["children"]
|
|
4
|
+
_excluded3 = ["children"],
|
|
5
|
+
_excluded4 = ["onClick"];
|
|
5
6
|
|
|
6
7
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
7
8
|
|
|
@@ -10,9 +11,12 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
10
11
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
11
12
|
|
|
12
13
|
import { forwardRef } from 'react';
|
|
13
|
-
import { Text } from '../components';
|
|
14
|
+
import { Text, IconButton } from '../components';
|
|
15
|
+
import { IconCross } from '../icons';
|
|
14
16
|
import { getColor, getRadius, getSpace, getTransition, getWeight } from '../utilities';
|
|
15
17
|
import { componentVars, styles } from './styles';
|
|
18
|
+
import { types } from '../types';
|
|
19
|
+
import PropTypes from 'prop-types';
|
|
16
20
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
17
21
|
export const fieldVars = {
|
|
18
22
|
xPadding: '12px',
|
|
@@ -50,13 +54,13 @@ const InputFieldRoot = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "p
|
|
|
50
54
|
paddingLeft,
|
|
51
55
|
paddingRight
|
|
52
56
|
} = _ref3;
|
|
53
|
-
return "0 ".concat(paddingRight, " 0 ").concat(paddingLeft);
|
|
54
|
-
}, ";height:var(--grn-textbox-height-m);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
57
|
+
return "0 ".concat(getSpace(paddingRight), " 0 ").concat(getSpace(paddingLeft));
|
|
58
|
+
}, ";height:var(--grn-textbox-height-m);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1FbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQmFja2dyb3VuZERpc2FibGVkJyl9O1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gIC8qIGZpeCBmb3Igc2FmYXJpICovXG4gIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6ICR7Y29tcG9uZW50VmFycy5zdHJva2VTaXplfSBzb2xpZDtcbiAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKGhhc0Vycm9yID8gJ2RhbmdlcicgOiAnZmllbGRCb3JkZXInKX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoYmFja2dyb3VuZENvbG9yID8gYmFja2dyb3VuZENvbG9yIDogJ3RyYW5zcGFyZW50Jyl9O1xuXG4gICY6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogJHtnZXRDb2xvcignc2hhZGU3Jyl9O1xuICB9XG5cbiAgJjpkaXNhYmxlZCxcbiAgJjpyZWFkLW9ubHkge1xuICAgICR7ZmllbGREaXNhYmxlZFN0eWxlc31cbiAgfVxuXG4gICR7XG4gICAgIWhhc0Vycm9yICYmXG4gICAgYFxuICAgICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSkge1xuICAgICAgJjpob3ZlciB7XG4gICAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJIb3ZlcicpfTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246ICR7Z2V0VHJhbnNpdGlvbignYWN0aXZlJyl9O1xuICAgICAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRm9jdXMnKX07XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6IHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gJ2ZpZWxkUGFkZGluZ1gnLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gJ2ZpZWxkUGFkZGluZ1gnLFxuICAgICAgaGFzRXJyb3IsXG4gICAgICBpc1JlYWRPbmx5LFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxJbnB1dEZpZWxkUm9vdFxuICAgICAgcGFkZGluZ0xlZnQ9e3BhZGRpbmdMZWZ0fVxuICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHR9XG4gICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuSW5wdXRGaWVsZC5wcm9wVHlwZXMgPSB7XG4gIHBhZGRpbmdMZWZ0OiB0eXBlcy5zcGFjZSxcbiAgcGFkZGluZ1JpZ2h0OiB0eXBlcy5zcGFjZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBpc1JlYWRPbmx5OiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCAuLi5wcm9wcyB9KSA9PiAoXG4gIDxJY29uQnV0dG9uIGljb249ezxJY29uQ3Jvc3MgLz59IG9uQ2xpY2s9e29uQ2xpY2t9IHsuLi5wcm9wc30gLz5cbik7XG5cbkZpZWxkQ2xlYXJCdXR0b24ucHJvcFR5cGVzID0ge1xuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
|
|
55
59
|
|
|
56
60
|
export const InputField = /*#__PURE__*/forwardRef((_ref4, ref) => {
|
|
57
61
|
let {
|
|
58
|
-
paddingLeft =
|
|
59
|
-
paddingRight =
|
|
62
|
+
paddingLeft = 'fieldPaddingX',
|
|
63
|
+
paddingRight = 'fieldPaddingX',
|
|
60
64
|
hasError,
|
|
61
65
|
isReadOnly,
|
|
62
66
|
isDisabled,
|
|
@@ -74,13 +78,21 @@ export const InputField = /*#__PURE__*/forwardRef((_ref4, ref) => {
|
|
|
74
78
|
backgroundColor: backgroundColor
|
|
75
79
|
}, props));
|
|
76
80
|
});
|
|
81
|
+
InputField.propTypes = {
|
|
82
|
+
paddingLeft: types.space,
|
|
83
|
+
paddingRight: types.space,
|
|
84
|
+
hasError: PropTypes.bool,
|
|
85
|
+
isReadOnly: PropTypes.bool,
|
|
86
|
+
isDisabled: PropTypes.bool,
|
|
87
|
+
backgroundColor: types.color
|
|
88
|
+
};
|
|
77
89
|
|
|
78
90
|
const FieldLabelRoot = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production" ? {
|
|
79
91
|
target: "e1swxi6p0"
|
|
80
92
|
} : {
|
|
81
93
|
target: "e1swxi6p0",
|
|
82
94
|
label: "FieldLabelRoot"
|
|
83
|
-
})("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
95
|
+
})("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZHbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQmFja2dyb3VuZERpc2FibGVkJyl9O1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gIC8qIGZpeCBmb3Igc2FmYXJpICovXG4gIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6ICR7Y29tcG9uZW50VmFycy5zdHJva2VTaXplfSBzb2xpZDtcbiAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKGhhc0Vycm9yID8gJ2RhbmdlcicgOiAnZmllbGRCb3JkZXInKX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoYmFja2dyb3VuZENvbG9yID8gYmFja2dyb3VuZENvbG9yIDogJ3RyYW5zcGFyZW50Jyl9O1xuXG4gICY6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogJHtnZXRDb2xvcignc2hhZGU3Jyl9O1xuICB9XG5cbiAgJjpkaXNhYmxlZCxcbiAgJjpyZWFkLW9ubHkge1xuICAgICR7ZmllbGREaXNhYmxlZFN0eWxlc31cbiAgfVxuXG4gICR7XG4gICAgIWhhc0Vycm9yICYmXG4gICAgYFxuICAgICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSkge1xuICAgICAgJjpob3ZlciB7XG4gICAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJIb3ZlcicpfTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246ICR7Z2V0VHJhbnNpdGlvbignYWN0aXZlJyl9O1xuICAgICAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRm9jdXMnKX07XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6IHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gJ2ZpZWxkUGFkZGluZ1gnLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gJ2ZpZWxkUGFkZGluZ1gnLFxuICAgICAgaGFzRXJyb3IsXG4gICAgICBpc1JlYWRPbmx5LFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxJbnB1dEZpZWxkUm9vdFxuICAgICAgcGFkZGluZ0xlZnQ9e3BhZGRpbmdMZWZ0fVxuICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHR9XG4gICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuSW5wdXRGaWVsZC5wcm9wVHlwZXMgPSB7XG4gIHBhZGRpbmdMZWZ0OiB0eXBlcy5zcGFjZSxcbiAgcGFkZGluZ1JpZ2h0OiB0eXBlcy5zcGFjZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBpc1JlYWRPbmx5OiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCAuLi5wcm9wcyB9KSA9PiAoXG4gIDxJY29uQnV0dG9uIGljb249ezxJY29uQ3Jvc3MgLz59IG9uQ2xpY2s9e29uQ2xpY2t9IHsuLi5wcm9wc30gLz5cbik7XG5cbkZpZWxkQ2xlYXJCdXR0b24ucHJvcFR5cGVzID0ge1xuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
|
|
84
96
|
|
|
85
97
|
export const FieldLabel = /*#__PURE__*/forwardRef((_ref5, ref) => {
|
|
86
98
|
let {
|
|
@@ -92,6 +104,9 @@ export const FieldLabel = /*#__PURE__*/forwardRef((_ref5, ref) => {
|
|
|
92
104
|
ref: ref
|
|
93
105
|
}, props), children);
|
|
94
106
|
});
|
|
107
|
+
FieldLabel.propTypes = {
|
|
108
|
+
children: PropTypes.node
|
|
109
|
+
};
|
|
95
110
|
export const FieldHint = /*#__PURE__*/forwardRef((_ref6, ref) => {
|
|
96
111
|
let {
|
|
97
112
|
children
|
|
@@ -102,4 +117,21 @@ export const FieldHint = /*#__PURE__*/forwardRef((_ref6, ref) => {
|
|
|
102
117
|
color: "content2",
|
|
103
118
|
ref: ref
|
|
104
119
|
}, props), children);
|
|
105
|
-
});
|
|
120
|
+
});
|
|
121
|
+
FieldHint.propTypes = {
|
|
122
|
+
children: PropTypes.node
|
|
123
|
+
};
|
|
124
|
+
export const FieldClearButton = _ref7 => {
|
|
125
|
+
let {
|
|
126
|
+
onClick
|
|
127
|
+
} = _ref7,
|
|
128
|
+
props = _objectWithoutProperties(_ref7, _excluded4);
|
|
129
|
+
|
|
130
|
+
return ___EmotionJSX(IconButton, _extends({
|
|
131
|
+
icon: ___EmotionJSX(IconCross, null),
|
|
132
|
+
onClick: onClick
|
|
133
|
+
}, props));
|
|
134
|
+
};
|
|
135
|
+
FieldClearButton.propTypes = {
|
|
136
|
+
onClick: PropTypes.func
|
|
137
|
+
};
|
package/es/types.js
CHANGED
|
@@ -27,7 +27,7 @@ export const textDisplays = ['block', 'inline-block', 'inline'];
|
|
|
27
27
|
export const textAlignments = ['left', 'center', 'right'];
|
|
28
28
|
export const spaces = Object.keys(vars.spaces);
|
|
29
29
|
export const types = {
|
|
30
|
-
|
|
30
|
+
space: PropTypes.oneOfType([PropTypes.oneOf(spaces), PropTypes.number, PropTypes.string]),
|
|
31
31
|
color: PropTypes.oneOfType([PropTypes.oneOf(Object.keys(vars.colors)), PropTypes.string]),
|
|
32
32
|
responsiveSpace: PropTypes.oneOfType([PropTypes.oneOf(spaces), PropTypes.number, PropTypes.string, PropTypes.object]),
|
|
33
33
|
dimension: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|