@flodesk/grain 11.22.5 → 11.23.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/arrange/index.js +34 -47
- package/es/components/autocomplete.js +94 -149
- package/es/components/autocomplete2.js +127 -166
- package/es/components/badge.js +12 -17
- package/es/components/box.js +115 -126
- package/es/components/breakpoints-provider.js +6 -4
- package/es/components/button.js +26 -39
- package/es/components/checkbox.js +31 -28
- package/es/components/dropdown.js +52 -50
- package/es/components/flex/index.js +31 -46
- package/es/components/icon-button.js +17 -25
- package/es/components/icon-toggle.js +28 -32
- package/es/components/icon.js +10 -20
- package/es/components/link.js +18 -18
- package/es/components/modal.js +75 -69
- package/es/components/nav/index.js +36 -43
- package/es/components/pagination.js +45 -63
- package/es/components/popover.js +47 -48
- package/es/components/progress.js +12 -15
- package/es/components/provider.js +7 -6
- package/es/components/radio.js +25 -24
- package/es/components/select.js +90 -98
- package/es/components/slider.js +25 -29
- package/es/components/spinner.js +11 -26
- package/es/components/stack.js +10 -19
- package/es/components/switch.js +21 -21
- package/es/components/tab.js +18 -25
- package/es/components/text/index.js +38 -48
- package/es/components/text-button.js +28 -41
- package/es/components/text-input.js +52 -74
- package/es/components/text-toggle.js +20 -31
- package/es/components/textarea.js +38 -33
- package/es/components/toast.js +29 -28
- package/es/components/tooltip.js +43 -77
- package/es/foundational/field.js +37 -32
- package/es/foundational/menu.js +110 -96
- package/es/foundational/styles.js +23 -23
- package/es/hooks/useKeyPress.js +10 -31
- package/es/hooks/useMedia.js +8 -45
- package/es/hooks/useOnClickOutside.js +4 -7
- package/es/hooks/usePrev.js +3 -3
- package/es/hooks/useWidth.js +3 -29
- package/es/hooks/useWindowSize.js +4 -32
- package/es/icons/icon-align-center.js +28 -32
- package/es/icons/icon-align-left.js +35 -39
- package/es/icons/icon-align-right.js +35 -39
- package/es/icons/icon-archive.js +21 -25
- package/es/icons/icon-arrow-down.js +21 -25
- package/es/icons/icon-arrow-left.js +21 -25
- package/es/icons/icon-arrow-right.js +21 -25
- package/es/icons/icon-arrow-up.js +21 -25
- package/es/icons/icon-at.js +21 -25
- package/es/icons/icon-bold.js +28 -32
- package/es/icons/icon-bolt-filled.js +21 -25
- package/es/icons/icon-bolt.js +21 -25
- package/es/icons/icon-browser.js +21 -25
- package/es/icons/icon-brush.js +20 -24
- package/es/icons/icon-bullet-list.js +21 -25
- package/es/icons/icon-chart.js +29 -33
- package/es/icons/icon-check.js +21 -25
- package/es/icons/icon-chevron-down.js +21 -25
- package/es/icons/icon-chevron-horizontal.js +21 -25
- package/es/icons/icon-chevron-left.js +21 -25
- package/es/icons/icon-chevron-right.js +21 -25
- package/es/icons/icon-chevron-up.js +28 -32
- package/es/icons/icon-chevron-vertical.js +28 -32
- package/es/icons/icon-clip.js +37 -41
- package/es/icons/icon-clock.js +21 -25
- package/es/icons/icon-column-and-rows.js +25 -29
- package/es/icons/icon-column-one.js +21 -25
- package/es/icons/icon-column-two.js +21 -25
- package/es/icons/icon-columns-and-row.js +25 -29
- package/es/icons/icon-columns.js +21 -25
- package/es/icons/icon-content-align-bottom.js +21 -25
- package/es/icons/icon-content-align-center.js +21 -25
- package/es/icons/icon-content-align-top.js +21 -25
- package/es/icons/icon-crop.js +21 -25
- package/es/icons/icon-cross.js +23 -27
- package/es/icons/icon-download.js +28 -32
- package/es/icons/icon-drag.js +21 -25
- package/es/icons/icon-duplicate.js +21 -25
- package/es/icons/icon-ellipsis.js +21 -25
- package/es/icons/icon-file.js +28 -32
- package/es/icons/icon-folder-add.js +21 -25
- package/es/icons/icon-folder-move.js +21 -25
- package/es/icons/icon-folder-remove.js +21 -25
- package/es/icons/icon-folder.js +21 -25
- package/es/icons/icon-gear.js +35 -39
- package/es/icons/icon-globe.js +28 -32
- package/es/icons/icon-heart.js +21 -25
- package/es/icons/icon-hide.js +21 -25
- package/es/icons/icon-image.js +21 -25
- package/es/icons/icon-info.js +21 -25
- package/es/icons/icon-italic.js +28 -32
- package/es/icons/icon-layout-text-bottom.js +28 -32
- package/es/icons/icon-layout-text-left.js +21 -25
- package/es/icons/icon-layout-text-right.js +28 -32
- package/es/icons/icon-layout-text-top.js +21 -25
- package/es/icons/icon-link.js +21 -25
- package/es/icons/icon-location.js +21 -25
- package/es/icons/icon-mail.js +21 -25
- package/es/icons/icon-minus.js +19 -23
- package/es/icons/icon-monitor.js +21 -25
- package/es/icons/icon-number-list.js +29 -33
- package/es/icons/icon-pencil.js +28 -32
- package/es/icons/icon-phone.js +21 -25
- package/es/icons/icon-play.js +21 -25
- package/es/icons/icon-plus.js +21 -25
- package/es/icons/icon-question.js +21 -25
- package/es/icons/icon-redo.js +21 -25
- package/es/icons/icon-reset.js +22 -26
- package/es/icons/icon-row-and-columns.js +25 -29
- package/es/icons/icon-rows-and-column.js +25 -29
- package/es/icons/icon-rows.js +21 -25
- package/es/icons/icon-search.js +21 -25
- package/es/icons/icon-send.js +21 -25
- package/es/icons/icon-share.js +21 -25
- package/es/icons/icon-show.js +21 -25
- package/es/icons/icon-smile.js +28 -32
- package/es/icons/icon-square.js +21 -25
- package/es/icons/icon-strike.js +28 -32
- package/es/icons/icon-switch.js +21 -25
- package/es/icons/icon-tablet.js +21 -25
- package/es/icons/icon-text-align-center.js +21 -25
- package/es/icons/icon-text-align-left.js +21 -25
- package/es/icons/icon-text-align-right.js +21 -25
- package/es/icons/icon-text-justify.js +21 -25
- package/es/icons/icon-trash.js +28 -32
- package/es/icons/icon-type.js +28 -32
- package/es/icons/icon-underline.js +28 -32
- package/es/icons/icon-undo.js +28 -32
- package/es/icons/icon-upload.js +28 -32
- package/es/styles/base.js +1 -1
- package/es/styles/card.js +4 -8
- package/es/styles/colors/core.js +1 -1
- package/es/styles/colors/theme.js +1 -1
- package/es/styles/foundational-variables.js +5 -0
- package/es/styles/index.js +2 -2
- package/es/styles/shadows.js +1 -1
- package/es/styles/utilities.js +65 -90
- package/es/styles/variables.js +1 -1
- package/es/types.js +28 -29
- package/es/utilities/attributes.js +46 -49
- package/es/utilities/helpers.js +13 -36
- package/es/utilities/responsive.js +16 -43
- package/es/utilities/style-config.js +32 -76
- package/es/utilities/styles.js +17 -29
- package/es/variables/breakpoints.js +1 -1
- package/es/variables/colors.js +1 -1
- package/es/variables/vars.js +3 -13
- package/package.json +6 -6
- package/es/styles/component-variables.js +0 -2
package/es/foundational/field.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
const _excluded = ["paddingLeft", "paddingRight", "hasError", "isReadOnly", "isDisabled"],
|
|
3
|
+
_excluded2 = ["children"],
|
|
4
|
+
_excluded3 = ["children"];
|
|
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); }
|
|
7
7
|
|
|
@@ -9,17 +9,12 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
9
9
|
|
|
10
10
|
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
11
|
|
|
12
|
-
import "core-js/modules/es.array.concat.js";
|
|
13
|
-
import "core-js/modules/es.object.keys.js";
|
|
14
|
-
import "core-js/modules/es.array.index-of.js";
|
|
15
|
-
import "core-js/modules/es.symbol.js";
|
|
16
|
-
import "core-js/modules/es.object.assign.js";
|
|
17
12
|
import { forwardRef } from 'react';
|
|
18
13
|
import { Text } from '../components';
|
|
19
14
|
import { getColor, getRadius, getSpace, getTransition, getWeight } from '../utilities';
|
|
20
15
|
import { componentVars, styles } from './styles';
|
|
21
16
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
22
|
-
export
|
|
17
|
+
export const fieldVars = {
|
|
23
18
|
xPadding: '12px',
|
|
24
19
|
borderColor: getColor('fade3'),
|
|
25
20
|
borderColorHover: getColor('fade6'),
|
|
@@ -27,36 +22,42 @@ export var fieldVars = {
|
|
|
27
22
|
borderColorDisabled: getColor('shade5'),
|
|
28
23
|
backgroundColorDisabled: getColor('shade2')
|
|
29
24
|
};
|
|
30
|
-
export
|
|
31
|
-
export
|
|
32
|
-
|
|
25
|
+
export const fieldDisabledStyles = "\n background-color: ".concat(getColor('fieldBackgroundDisabled'), ";\n border-color: ").concat(getColor('fieldBorderDisabled'), ";\n /* fix for safari */\n -webkit-text-fill-color: ").concat(getColor('content'), ";\n opacity: 1;\n");
|
|
26
|
+
export const getFieldStyles = _ref => {
|
|
27
|
+
let {
|
|
28
|
+
hasError
|
|
29
|
+
} = _ref;
|
|
33
30
|
return "\n ".concat(styles.transitions, ";\n appearance: none;\n display: block;\n font: inherit;\n color: inherit;\n background-color: transparent;\n transition-property: border-color;\n width: 100%;\n border-radius: ").concat(getRadius('s'), ";\n\n outline: none;\n border: ").concat(componentVars.strokeSize, " solid;\n border-color: ").concat(getColor(hasError ? 'danger' : 'fieldBorder'), ";\n\n &::placeholder {\n color: ").concat(getColor('shade7'), ";\n }\n\n &:disabled,\n &:read-only {\n ").concat(fieldDisabledStyles, "\n }\n\n ").concat(!hasError && "\n &:not(:disabled, :read-only) {\n &:hover {\n border-color: ".concat(getColor('fieldBorderHover'), ";\n }\n\n &:focus {\n transition: ").concat(getTransition('active'), ";\n border-color: ").concat(getColor('fieldBorderFocus'), ";\n }\n }\n "), "\n");
|
|
34
31
|
};
|
|
35
32
|
|
|
36
|
-
|
|
33
|
+
const InputFieldRoot = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "production" ? {
|
|
37
34
|
target: "e1swxi6p1"
|
|
38
35
|
} : {
|
|
39
36
|
target: "e1swxi6p1",
|
|
40
37
|
label: "InputFieldRoot"
|
|
41
|
-
})(
|
|
42
|
-
|
|
38
|
+
})(_ref2 => {
|
|
39
|
+
let {
|
|
40
|
+
hasError
|
|
41
|
+
} = _ref2;
|
|
43
42
|
return getFieldStyles({
|
|
44
|
-
hasError
|
|
43
|
+
hasError
|
|
45
44
|
});
|
|
46
|
-
}, ";padding:",
|
|
47
|
-
|
|
48
|
-
|
|
45
|
+
}, ";padding:", _ref3 => {
|
|
46
|
+
let {
|
|
47
|
+
paddingLeft,
|
|
48
|
+
paddingRight
|
|
49
|
+
} = _ref3;
|
|
49
50
|
return "0 ".concat(paddingRight, " 0 ").concat(paddingLeft);
|
|
50
51
|
}, ";height:var(--grn-textBoxHeight);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdFbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQmFja2dyb3VuZERpc2FibGVkJyl9O1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gIC8qIGZpeCBmb3Igc2FmYXJpICovXG4gIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IgfSkgPT4gYFxuICAke3N0eWxlcy50cmFuc2l0aW9uc307XG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJvcmRlci1jb2xvcjtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuXG4gIG91dGxpbmU6IG5vbmU7XG4gIGJvcmRlcjogJHtjb21wb25lbnRWYXJzLnN0cm9rZVNpemV9IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoaGFzRXJyb3IgPyAnZGFuZ2VyJyA6ICdmaWVsZEJvcmRlcicpfTtcblxuICAmOjpwbGFjZWhvbGRlciB7XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNycpfTtcbiAgfVxuXG4gICY6ZGlzYWJsZWQsXG4gICY6cmVhZC1vbmx5IHtcbiAgICAke2ZpZWxkRGlzYWJsZWRTdHlsZXN9XG4gIH1cblxuICAke1xuICAgICFoYXNFcnJvciAmJlxuICAgIGBcbiAgICAmOm5vdCg6ZGlzYWJsZWQsIDpyZWFkLW9ubHkpIHtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVySG92ZXInKX07XG4gICAgICB9XG5cbiAgICAgICY6Zm9jdXMge1xuICAgICAgICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2FjdGl2ZScpfTtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJvcmRlckZvY3VzJyl9O1xuICAgICAgfVxuICAgIH1cbiAgYFxuICB9XG5gO1xuXG5jb25zdCBJbnB1dEZpZWxkUm9vdCA9IHN0eWxlZC5pbnB1dGBcbiAgJHsoeyBoYXNFcnJvciB9KSA9PiBnZXRGaWVsZFN0eWxlcyh7IGhhc0Vycm9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+IGAwICR7cGFkZGluZ1JpZ2h0fSAwICR7cGFkZGluZ0xlZnR9YH07XG4gIGhlaWdodDogdmFyKC0tZ3JuLXRleHRCb3hIZWlnaHQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0RmllbGQgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgcGFkZGluZ0xlZnQgPSBnZXRTcGFjZSgnZmllbGRQYWRkaW5nWCcpLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gZ2V0U3BhY2UoJ2ZpZWxkUGFkZGluZ1gnKSxcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICAuLi5wcm9wc1xuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8SW5wdXRGaWVsZFJvb3RcbiAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdH1cbiAgICAgIHBhZGRpbmdSaWdodD17cGFkZGluZ1JpZ2h0fVxuICAgICAgcmVhZE9ubHk9e2lzUmVhZE9ubHl9XG4gICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgIHJlZj17cmVmfVxuICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgey4uLnByb3BzfVxuICAgIC8+XG4gICksXG4pO1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5leHBvcnQgY29uc3QgRmllbGRIaW50ID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSwgcmVmKSA9PiAoXG4gIDxUZXh0IGNvbG9yPVwiY29udGVudDJcIiByZWY9e3JlZn0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGV4dD5cbikpO1xuIl19 */"));
|
|
51
52
|
|
|
52
|
-
export
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
53
|
+
export const InputField = /*#__PURE__*/forwardRef((_ref4, ref) => {
|
|
54
|
+
let {
|
|
55
|
+
paddingLeft = getSpace('fieldPaddingX'),
|
|
56
|
+
paddingRight = getSpace('fieldPaddingX'),
|
|
57
|
+
hasError,
|
|
58
|
+
isReadOnly,
|
|
59
|
+
isDisabled
|
|
60
|
+
} = _ref4,
|
|
60
61
|
props = _objectWithoutProperties(_ref4, _excluded);
|
|
61
62
|
|
|
62
63
|
return ___EmotionJSX(InputFieldRoot, _extends({
|
|
@@ -69,23 +70,27 @@ export var InputField = /*#__PURE__*/forwardRef(function (_ref4, ref) {
|
|
|
69
70
|
}, props));
|
|
70
71
|
});
|
|
71
72
|
|
|
72
|
-
|
|
73
|
+
const FieldLabelRoot = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production" ? {
|
|
73
74
|
target: "e1swxi6p0"
|
|
74
75
|
} : {
|
|
75
76
|
target: "e1swxi6p0",
|
|
76
77
|
label: "FieldLabelRoot"
|
|
77
78
|
})("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThGbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQmFja2dyb3VuZERpc2FibGVkJyl9O1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gIC8qIGZpeCBmb3Igc2FmYXJpICovXG4gIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IgfSkgPT4gYFxuICAke3N0eWxlcy50cmFuc2l0aW9uc307XG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJvcmRlci1jb2xvcjtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuXG4gIG91dGxpbmU6IG5vbmU7XG4gIGJvcmRlcjogJHtjb21wb25lbnRWYXJzLnN0cm9rZVNpemV9IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoaGFzRXJyb3IgPyAnZGFuZ2VyJyA6ICdmaWVsZEJvcmRlcicpfTtcblxuICAmOjpwbGFjZWhvbGRlciB7XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNycpfTtcbiAgfVxuXG4gICY6ZGlzYWJsZWQsXG4gICY6cmVhZC1vbmx5IHtcbiAgICAke2ZpZWxkRGlzYWJsZWRTdHlsZXN9XG4gIH1cblxuICAke1xuICAgICFoYXNFcnJvciAmJlxuICAgIGBcbiAgICAmOm5vdCg6ZGlzYWJsZWQsIDpyZWFkLW9ubHkpIHtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVySG92ZXInKX07XG4gICAgICB9XG5cbiAgICAgICY6Zm9jdXMge1xuICAgICAgICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2FjdGl2ZScpfTtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJvcmRlckZvY3VzJyl9O1xuICAgICAgfVxuICAgIH1cbiAgYFxuICB9XG5gO1xuXG5jb25zdCBJbnB1dEZpZWxkUm9vdCA9IHN0eWxlZC5pbnB1dGBcbiAgJHsoeyBoYXNFcnJvciB9KSA9PiBnZXRGaWVsZFN0eWxlcyh7IGhhc0Vycm9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+IGAwICR7cGFkZGluZ1JpZ2h0fSAwICR7cGFkZGluZ0xlZnR9YH07XG4gIGhlaWdodDogdmFyKC0tZ3JuLXRleHRCb3hIZWlnaHQpO1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0RmllbGQgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgcGFkZGluZ0xlZnQgPSBnZXRTcGFjZSgnZmllbGRQYWRkaW5nWCcpLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gZ2V0U3BhY2UoJ2ZpZWxkUGFkZGluZ1gnKSxcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICAuLi5wcm9wc1xuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8SW5wdXRGaWVsZFJvb3RcbiAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdH1cbiAgICAgIHBhZGRpbmdSaWdodD17cGFkZGluZ1JpZ2h0fVxuICAgICAgcmVhZE9ubHk9e2lzUmVhZE9ubHl9XG4gICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgIHJlZj17cmVmfVxuICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgey4uLnByb3BzfVxuICAgIC8+XG4gICksXG4pO1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5leHBvcnQgY29uc3QgRmllbGRIaW50ID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSwgcmVmKSA9PiAoXG4gIDxUZXh0IGNvbG9yPVwiY29udGVudDJcIiByZWY9e3JlZn0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvVGV4dD5cbikpO1xuIl19 */"));
|
|
78
79
|
|
|
79
|
-
export
|
|
80
|
-
|
|
80
|
+
export const FieldLabel = /*#__PURE__*/forwardRef((_ref5, ref) => {
|
|
81
|
+
let {
|
|
82
|
+
children
|
|
83
|
+
} = _ref5,
|
|
81
84
|
props = _objectWithoutProperties(_ref5, _excluded2);
|
|
82
85
|
|
|
83
86
|
return ___EmotionJSX(FieldLabelRoot, _extends({
|
|
84
87
|
ref: ref
|
|
85
88
|
}, props), children);
|
|
86
89
|
});
|
|
87
|
-
export
|
|
88
|
-
|
|
90
|
+
export const FieldHint = /*#__PURE__*/forwardRef((_ref6, ref) => {
|
|
91
|
+
let {
|
|
92
|
+
children
|
|
93
|
+
} = _ref6,
|
|
89
94
|
props = _objectWithoutProperties(_ref6, _excluded3);
|
|
90
95
|
|
|
91
96
|
return ___EmotionJSX(Text, _extends({
|
package/es/foundational/menu.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _styled from "@emotion/styled/base";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
const _excluded = ["children", "show"],
|
|
3
|
+
_excluded2 = ["children", "zIndex", "maxHeight", "maxWidth", "isDisabled"],
|
|
4
|
+
_excluded3 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasEllipsis", "checkVariant"];
|
|
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); }
|
|
7
7
|
|
|
@@ -9,11 +9,6 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
9
9
|
|
|
10
10
|
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
11
|
|
|
12
|
-
import "core-js/modules/es.object.assign.js";
|
|
13
|
-
import "core-js/modules/es.array.concat.js";
|
|
14
|
-
import "core-js/modules/es.object.keys.js";
|
|
15
|
-
import "core-js/modules/es.array.index-of.js";
|
|
16
|
-
import "core-js/modules/es.symbol.js";
|
|
17
12
|
import React, { Fragment, forwardRef, useCallback, useEffect, useImperativeHandle, useRef } from 'react';
|
|
18
13
|
import PropTypes from 'prop-types';
|
|
19
14
|
import { Global } from '@emotion/react';
|
|
@@ -25,10 +20,10 @@ import { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-inte
|
|
|
25
20
|
import { Transition } from '@headlessui/react';
|
|
26
21
|
import { types } from '../types';
|
|
27
22
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
export
|
|
23
|
+
const cardPadding = 8;
|
|
24
|
+
const cardPaddingPx = "".concat(cardPadding, "px");
|
|
25
|
+
const itemXPadding = 12;
|
|
26
|
+
export const placementsMap = {
|
|
32
27
|
top: 'top',
|
|
33
28
|
topStart: 'top-start',
|
|
34
29
|
topEnd: 'top-end',
|
|
@@ -42,52 +37,58 @@ export var placementsMap = {
|
|
|
42
37
|
leftStart: 'left-start',
|
|
43
38
|
leftEnd: 'left-end'
|
|
44
39
|
};
|
|
45
|
-
export
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
40
|
+
export const useMenuPosition = _ref => {
|
|
41
|
+
let {
|
|
42
|
+
menuWidth,
|
|
43
|
+
menuPlacement
|
|
44
|
+
} = _ref;
|
|
45
|
+
const {
|
|
46
|
+
x,
|
|
47
|
+
y,
|
|
48
|
+
reference,
|
|
49
|
+
floating,
|
|
50
|
+
strategy,
|
|
51
|
+
refs
|
|
52
|
+
} = useFloating({
|
|
50
53
|
placement: placementsMap[menuPlacement],
|
|
51
54
|
whileElementsMounted: autoUpdate,
|
|
52
55
|
middleware: [flip({
|
|
53
56
|
padding: 24,
|
|
54
57
|
flipAlignment: false
|
|
55
58
|
}), size({
|
|
56
|
-
apply
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
59
|
+
apply(_ref2) {
|
|
60
|
+
let {
|
|
61
|
+
rects,
|
|
62
|
+
elements
|
|
63
|
+
} = _ref2;
|
|
64
|
+
const width = getDimension(menuWidth) || "".concat(rects.reference.width, "px");
|
|
60
65
|
Object.assign(elements.floating.style, {
|
|
61
66
|
width: width
|
|
62
67
|
});
|
|
63
68
|
},
|
|
69
|
+
|
|
64
70
|
padding: 24
|
|
65
71
|
})]
|
|
66
|
-
})
|
|
67
|
-
|
|
68
|
-
y = _useFloating.y,
|
|
69
|
-
reference = _useFloating.reference,
|
|
70
|
-
floating = _useFloating.floating,
|
|
71
|
-
strategy = _useFloating.strategy,
|
|
72
|
-
refs = _useFloating.refs;
|
|
73
|
-
|
|
74
|
-
var floatingStyles = {
|
|
72
|
+
});
|
|
73
|
+
const floatingStyles = {
|
|
75
74
|
position: strategy,
|
|
76
75
|
top: y !== null && y !== void 0 ? y : 0,
|
|
77
76
|
left: x !== null && x !== void 0 ? x : 0,
|
|
78
77
|
zIndex: 1100
|
|
79
78
|
};
|
|
80
79
|
return {
|
|
81
|
-
refs
|
|
82
|
-
reference
|
|
83
|
-
floating
|
|
84
|
-
floatingStyles
|
|
80
|
+
refs,
|
|
81
|
+
reference,
|
|
82
|
+
floating,
|
|
83
|
+
floatingStyles
|
|
85
84
|
};
|
|
86
85
|
};
|
|
87
|
-
|
|
88
|
-
export
|
|
89
|
-
|
|
90
|
-
|
|
86
|
+
const menuCardStyles = "\n .menuCardLeaveTo,\n .menuCardEnterFrom {\n opacity: 0;\n }\n .menuCardEnterTo {\n transition-duration: ".concat(getTransition('xxFast'), ";\n }\n .menuCardLeaveTo {\n transition-duration: ").concat(getTransition('xFast'), ";\n }\n");
|
|
87
|
+
export const MenuCardTransition = /*#__PURE__*/forwardRef((_ref3, ref) => {
|
|
88
|
+
let {
|
|
89
|
+
children,
|
|
90
|
+
show
|
|
91
|
+
} = _ref3,
|
|
91
92
|
props = _objectWithoutProperties(_ref3, _excluded);
|
|
92
93
|
|
|
93
94
|
return ___EmotionJSX(Transition, _extends({
|
|
@@ -101,48 +102,55 @@ export var MenuCardTransition = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
|
|
101
102
|
}, props), children);
|
|
102
103
|
});
|
|
103
104
|
|
|
104
|
-
|
|
105
|
+
const MenuCardUl = /*#__PURE__*/_styled("ul", process.env.NODE_ENV === "production" ? {
|
|
105
106
|
target: "eil6qy21"
|
|
106
107
|
} : {
|
|
107
108
|
target: "eil6qy21",
|
|
108
109
|
label: "MenuCardUl"
|
|
109
|
-
})("padding:", cardPaddingPx, ";margin:0;background:", getColor('floatingBackground'), ";z-index:",
|
|
110
|
-
|
|
110
|
+
})("padding:", cardPaddingPx, ";margin:0;background:", getColor('floatingBackground'), ";z-index:", _ref4 => {
|
|
111
|
+
let {
|
|
112
|
+
zIndex
|
|
113
|
+
} = _ref4;
|
|
111
114
|
return zIndex;
|
|
112
|
-
}, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;",
|
|
113
|
-
|
|
115
|
+
}, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;", _ref5 => {
|
|
116
|
+
let {
|
|
117
|
+
maxHeight
|
|
118
|
+
} = _ref5;
|
|
114
119
|
return maxHeight && "max-height: ".concat(getSpace(maxHeight));
|
|
115
|
-
}, ";",
|
|
116
|
-
|
|
120
|
+
}, ";", _ref6 => {
|
|
121
|
+
let {
|
|
122
|
+
maxWidth
|
|
123
|
+
} = _ref6;
|
|
117
124
|
return maxWidth && "max-width: ".concat(getSpace(maxWidth));
|
|
118
|
-
}, ";",
|
|
119
|
-
|
|
125
|
+
}, ";", _ref7 => {
|
|
126
|
+
let {
|
|
127
|
+
isDisabled
|
|
128
|
+
} = _ref7;
|
|
120
129
|
return isDisabled && "pointer-events: none;";
|
|
121
130
|
}, " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AA0G4B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('fade1'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textBoxHeight);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children, hasDivider }) => (\n  <>\n    {hasDivider && (\n      <Box\n        height=\"3px\"\n        borderSide={hasDivider ? 'top' : undefined}\n        marginTop={cardPaddingPx}\n        paddingTop={`${cardPadding * 2}px`}\n        marginX={`-${cardPaddingPx}`}\n      />\n    )}\n    <Box\n      paddingX={`${itemXPadding}px`}\n      paddingBottom={cardPaddingPx}\n      paddingTop={hasDivider ? 0 : cardPaddingPx}\n    >\n      <Text variant=\"caps\">{children}</Text>\n    </Box>\n  </>\n);\n\nexport const MenuItemDivider = () => (\n  <Box\n    height={componentVars.dividerStrokeSize}\n    marginY={1}\n    backgroundColor=\"border\"\n    marginX={`-${cardPaddingPx}`}\n  />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
|
|
122
131
|
|
|
123
|
-
export
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
132
|
+
export const MenuCard = /*#__PURE__*/forwardRef((_ref8, ref) => {
|
|
133
|
+
let {
|
|
134
|
+
children,
|
|
135
|
+
zIndex = 1,
|
|
136
|
+
maxHeight,
|
|
137
|
+
maxWidth,
|
|
138
|
+
isDisabled
|
|
139
|
+
} = _ref8,
|
|
130
140
|
props = _objectWithoutProperties(_ref8, _excluded2);
|
|
131
141
|
|
|
132
|
-
|
|
133
|
-
useImperativeHandle(ref,
|
|
134
|
-
|
|
135
|
-
}, []);
|
|
136
|
-
var scrollToActive = useCallback(function () {
|
|
142
|
+
const menuCardRef = useRef(ref);
|
|
143
|
+
useImperativeHandle(ref, () => menuCardRef.current, []);
|
|
144
|
+
const scrollToActive = useCallback(() => {
|
|
137
145
|
// Note: this function is rely on data-headlessui-state attribute
|
|
138
|
-
|
|
139
|
-
|
|
146
|
+
const menuCard = menuCardRef.current;
|
|
147
|
+
const activeItem = menuCard === null || menuCard === void 0 ? void 0 : menuCard.querySelector('[data-headlessui-state="selected"]');
|
|
140
148
|
if (!menuCard || !activeItem) return;
|
|
141
|
-
|
|
142
|
-
|
|
149
|
+
const menuCardRect = menuCard.getBoundingClientRect();
|
|
150
|
+
const activeItemRect = activeItem.getBoundingClientRect();
|
|
143
151
|
menuCard.scrollTop = activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;
|
|
144
152
|
}, []);
|
|
145
|
-
useEffect(
|
|
153
|
+
useEffect(() => {
|
|
146
154
|
scrollToActive();
|
|
147
155
|
}, [scrollToActive]);
|
|
148
156
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
|
|
@@ -155,7 +163,7 @@ export var MenuCard = /*#__PURE__*/forwardRef(function (_ref8, ref) {
|
|
|
155
163
|
isDisabled: isDisabled
|
|
156
164
|
}, props), children));
|
|
157
165
|
});
|
|
158
|
-
|
|
166
|
+
const variantStyles = {
|
|
159
167
|
neutral: {
|
|
160
168
|
backgroundColorActive: getColor('fade1'),
|
|
161
169
|
iconColorActive: getColor('content')
|
|
@@ -168,25 +176,33 @@ var variantStyles = {
|
|
|
168
176
|
}
|
|
169
177
|
};
|
|
170
178
|
|
|
171
|
-
|
|
179
|
+
const MenuItemRoot = /*#__PURE__*/_styled("li", process.env.NODE_ENV === "production" ? {
|
|
172
180
|
target: "eil6qy20"
|
|
173
181
|
} : {
|
|
174
182
|
target: "eil6qy20",
|
|
175
183
|
label: "MenuItemRoot"
|
|
176
|
-
})("display:grid;grid-auto-flow:column;gap:8px;",
|
|
177
|
-
|
|
184
|
+
})("display:grid;grid-auto-flow:column;gap:8px;", _ref9 => {
|
|
185
|
+
let {
|
|
186
|
+
isDisabled
|
|
187
|
+
} = _ref9;
|
|
178
188
|
return isDisabled && "color: ".concat(getColor('disabledContent'));
|
|
179
|
-
}, ";",
|
|
180
|
-
|
|
189
|
+
}, ";", _ref10 => {
|
|
190
|
+
let {
|
|
191
|
+
isDisabled
|
|
192
|
+
} = _ref10;
|
|
181
193
|
return !isDisabled && "cursor: pointer;";
|
|
182
|
-
}, ";align-items:center;justify-content:start;list-style:none;padding-block:10px;padding-inline:", itemXPadding, "px;margin:0;min-height:var(--grn-textBoxHeight);border-radius:", getRadius('s'), ";appearance:none;color:",
|
|
183
|
-
|
|
194
|
+
}, ";align-items:center;justify-content:start;list-style:none;padding-block:10px;padding-inline:", itemXPadding, "px;margin:0;min-height:var(--grn-textBoxHeight);border-radius:", getRadius('s'), ";appearance:none;color:", _ref11 => {
|
|
195
|
+
let {
|
|
196
|
+
color
|
|
197
|
+
} = _ref11;
|
|
184
198
|
return color;
|
|
185
199
|
}, ";[data-experiment-compact-textbox] &{padding-block:", getSpace('s'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AA+K8B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('fade1'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textBoxHeight);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children, hasDivider }) => (\n  <>\n    {hasDivider && (\n      <Box\n        height=\"3px\"\n        borderSide={hasDivider ? 'top' : undefined}\n        marginTop={cardPaddingPx}\n        paddingTop={`${cardPadding * 2}px`}\n        marginX={`-${cardPaddingPx}`}\n      />\n    )}\n    <Box\n      paddingX={`${itemXPadding}px`}\n      paddingBottom={cardPaddingPx}\n      paddingTop={hasDivider ? 0 : cardPaddingPx}\n    >\n      <Text variant=\"caps\">{children}</Text>\n    </Box>\n  </>\n);\n\nexport const MenuItemDivider = () => (\n  <Box\n    height={componentVars.dividerStrokeSize}\n    marginY={1}\n    backgroundColor=\"border\"\n    marginX={`-${cardPaddingPx}`}\n  />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
|
|
186
200
|
|
|
187
|
-
export
|
|
188
|
-
|
|
189
|
-
|
|
201
|
+
export const MenuGroupTitle = _ref12 => {
|
|
202
|
+
let {
|
|
203
|
+
children,
|
|
204
|
+
hasDivider
|
|
205
|
+
} = _ref12;
|
|
190
206
|
return ___EmotionJSX(React.Fragment, null, hasDivider && ___EmotionJSX(Box, {
|
|
191
207
|
height: "3px",
|
|
192
208
|
borderSide: hasDivider ? 'top' : undefined,
|
|
@@ -201,30 +217,28 @@ export var MenuGroupTitle = function MenuGroupTitle(_ref12) {
|
|
|
201
217
|
variant: "caps"
|
|
202
218
|
}, children)));
|
|
203
219
|
};
|
|
204
|
-
export
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
_ref13$checkVariant = _ref13.checkVariant,
|
|
222
|
-
checkVariant = _ref13$checkVariant === void 0 ? 'check' : _ref13$checkVariant,
|
|
220
|
+
export const MenuItemDivider = () => ___EmotionJSX(Box, {
|
|
221
|
+
height: componentVars.dividerStrokeSize,
|
|
222
|
+
marginY: 1,
|
|
223
|
+
backgroundColor: "border",
|
|
224
|
+
marginX: "-".concat(cardPaddingPx)
|
|
225
|
+
});
|
|
226
|
+
export const MenuItem = /*#__PURE__*/forwardRef((_ref13, ref) => {
|
|
227
|
+
let {
|
|
228
|
+
children,
|
|
229
|
+
isSelected,
|
|
230
|
+
isActive,
|
|
231
|
+
isDisabled,
|
|
232
|
+
icon,
|
|
233
|
+
variant = 'neutral',
|
|
234
|
+
hasEllipsis,
|
|
235
|
+
checkVariant = 'check'
|
|
236
|
+
} = _ref13,
|
|
223
237
|
props = _objectWithoutProperties(_ref13, _excluded3);
|
|
224
238
|
|
|
225
|
-
|
|
239
|
+
const hasCheck = checkVariant === 'check';
|
|
226
240
|
|
|
227
|
-
|
|
241
|
+
const getColumns = () => {
|
|
228
242
|
if (Boolean(icon)) return 'auto 1fr';
|
|
229
243
|
if (hasCheck) return '1fr auto';
|
|
230
244
|
};
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import "core-js/modules/es.array.concat.js";
|
|
2
1
|
import { getColor, getRadius, getTextSize, getTransition, getWeight } from '../utilities';
|
|
3
|
-
export
|
|
4
|
-
export
|
|
5
|
-
export
|
|
2
|
+
export const capHeight = "0.74em";
|
|
3
|
+
export const lineHeightAndCapHeightOffset = "calc((var(--grn-lineHeight-global) - ".concat(capHeight, ") / 2)");
|
|
4
|
+
export const componentVars = {
|
|
6
5
|
strokeSize: '1px',
|
|
7
6
|
dividerStrokeSize: '1px',
|
|
8
7
|
activeBorderColor: getColor('shade9'),
|
|
@@ -12,13 +11,13 @@ export var componentVars = {
|
|
|
12
11
|
clearButtonDangerBackgroundActive: 'hsl(var(--redHS) var(--redL) / 19%)',
|
|
13
12
|
dangerIconColor: 'hsl(var(--redHS) var(--redL) / 70%)'
|
|
14
13
|
};
|
|
15
|
-
|
|
16
|
-
export
|
|
17
|
-
export
|
|
14
|
+
const buttonResetStyles = "\n appearance: none;\n font-family: inherit;\n font-size: inherit;\n font-weight: ".concat(getWeight('medium'), ";\n cursor: pointer;\n");
|
|
15
|
+
export const transitionStyles = "\n transition: ".concat(getTransition('leave'), ";\n\n &:hover {\n transition: ").concat(getTransition('hover'), ";\n }\n\n &:active {\n transition: ").concat(getTransition('active'), ";\n }\n");
|
|
16
|
+
export const styles = {
|
|
18
17
|
buttonReset: buttonResetStyles,
|
|
19
18
|
transitions: transitionStyles
|
|
20
19
|
};
|
|
21
|
-
|
|
20
|
+
const variantStyles = {
|
|
22
21
|
neutral: {
|
|
23
22
|
color: getColor('content'),
|
|
24
23
|
iconColor: getColor('icon'),
|
|
@@ -42,23 +41,24 @@ var variantStyles = {
|
|
|
42
41
|
}
|
|
43
42
|
}
|
|
44
43
|
};
|
|
45
|
-
export
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
44
|
+
export const getClearButtonStyles = _ref => {
|
|
45
|
+
let {
|
|
46
|
+
variant = 'neutral',
|
|
47
|
+
isActive,
|
|
48
|
+
isDisabled
|
|
49
|
+
} = _ref;
|
|
50
|
+
const box = "\n ".concat(buttonResetStyles, ";\n ").concat(transitionStyles, ";\n\n border: none;\n padding: 0;\n border-radius: ").concat(getRadius('s'), ";\n height: ").concat(componentVars.clearButtonHeight, ";\n background-color: transparent;\n display: flex;\n align-items: center;\n justify-content: center;\n\n @media(hover: hover) {\n &:hover {\n background-color: ").concat(variant && variantStyles[variant].hover.backgroundColor, ";\n\n .Icon {\n color: ").concat(variant && variantStyles[variant].hover.iconColor, ";\n }\n }\n &:active {\n background-color: ").concat(variant && variantStyles[variant].active.backgroundColor, ";\n }\n }\n\n ").concat(isDisabled && "pointer-events: none; ", "\n ");
|
|
51
|
+
const icon = "\n ".concat(transitionStyles, ";\n color: ").concat(variant && variantStyles[variant].iconColor, ";\n ").concat(isActive && "color: ".concat(variant && variantStyles[variant].color), ";\n ").concat(isDisabled && "color: ".concat(getColor('disabledIcon')), ";\n ");
|
|
52
|
+
const text = "\n color: ".concat(variant && variantStyles[variant].color, ";\n ").concat(isDisabled && "color: ".concat(getColor('disabledContent')), ";\n ");
|
|
53
|
+
const clearButtonStyles = {
|
|
54
|
+
box,
|
|
55
|
+
icon,
|
|
56
|
+
text
|
|
57
57
|
};
|
|
58
58
|
return clearButtonStyles;
|
|
59
59
|
};
|
|
60
|
-
|
|
61
|
-
export
|
|
60
|
+
const fullOffset = "calc(100% + var(--placementOffset, var(--grn-space-xs)))";
|
|
61
|
+
export const placementStyles = {
|
|
62
62
|
top: {
|
|
63
63
|
bottom: fullOffset,
|
|
64
64
|
left: "50%",
|
|
@@ -112,4 +112,4 @@ export var placementStyles = {
|
|
|
112
112
|
bottom: "0"
|
|
113
113
|
}
|
|
114
114
|
};
|
|
115
|
-
export
|
|
115
|
+
export const capStyles = "\n font-size: ".concat(getTextSize('s'), ";\n font-weight: ").concat(getWeight('medium'), ";\n text-transform: uppercase;\n letter-spacing: 0.05em;\n");
|
package/es/hooks/useKeyPress.js
CHANGED
|
@@ -1,53 +1,32 @@
|
|
|
1
|
-
import "core-js/modules/es.symbol.js";
|
|
2
|
-
import "core-js/modules/es.symbol.description.js";
|
|
3
|
-
import "core-js/modules/es.object.to-string.js";
|
|
4
|
-
import "core-js/modules/es.symbol.iterator.js";
|
|
5
|
-
import "core-js/modules/es.array.iterator.js";
|
|
6
|
-
import "core-js/modules/es.string.iterator.js";
|
|
7
1
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
8
|
-
import "core-js/modules/es.array.slice.js";
|
|
9
|
-
import "core-js/modules/es.array.from.js";
|
|
10
|
-
import "core-js/modules/es.regexp.exec.js";
|
|
11
|
-
|
|
12
|
-
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
13
|
-
|
|
14
|
-
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
15
|
-
|
|
16
|
-
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
17
|
-
|
|
18
|
-
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
19
|
-
|
|
20
|
-
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
21
|
-
|
|
22
|
-
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
23
|
-
|
|
24
2
|
import { useEffect, useState } from 'react';
|
|
25
3
|
export function useKeyPress(targetKey) {
|
|
26
|
-
|
|
27
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
28
|
-
keyPressed = _useState2[0],
|
|
29
|
-
setKeyPressed = _useState2[1];
|
|
4
|
+
const [keyPressed, setKeyPressed] = useState(false);
|
|
30
5
|
|
|
31
6
|
function downHandler(_ref) {
|
|
32
|
-
|
|
7
|
+
let {
|
|
8
|
+
key
|
|
9
|
+
} = _ref;
|
|
33
10
|
|
|
34
11
|
if (key === targetKey) {
|
|
35
12
|
setKeyPressed(true);
|
|
36
13
|
}
|
|
37
14
|
}
|
|
38
15
|
|
|
39
|
-
|
|
40
|
-
|
|
16
|
+
const upHandler = _ref2 => {
|
|
17
|
+
let {
|
|
18
|
+
key
|
|
19
|
+
} = _ref2;
|
|
41
20
|
|
|
42
21
|
if (key === targetKey) {
|
|
43
22
|
setKeyPressed(false);
|
|
44
23
|
}
|
|
45
24
|
};
|
|
46
25
|
|
|
47
|
-
useEffect(
|
|
26
|
+
useEffect(() => {
|
|
48
27
|
window.addEventListener('keydown', downHandler);
|
|
49
28
|
window.addEventListener('keyup', upHandler);
|
|
50
|
-
return
|
|
29
|
+
return () => {
|
|
51
30
|
window.removeEventListener('keydown', downHandler);
|
|
52
31
|
window.removeEventListener('keyup', upHandler);
|
|
53
32
|
};
|