@flodesk/grain 10.8.0 → 10.8.2
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 +3 -2
- package/es/components/autocomplete2.js +5 -5
- package/es/components/badge.js +5 -6
- package/es/components/box.js +83 -14
- package/es/components/button.js +5 -23
- package/es/components/checkbox.js +12 -18
- package/es/components/link.js +27 -16
- package/es/components/modal.js +78 -58
- package/es/components/nav.js +9 -19
- package/es/components/slider.js +6 -17
- package/es/components/spinner.js +3 -13
- package/es/components/switch.js +4 -16
- package/es/components/text-button.js +13 -12
- package/es/components/text.js +84 -28
- package/es/components/textarea.js +34 -20
- package/es/foundational/field.js +52 -28
- package/es/foundational/menu.js +73 -46
- package/es/foundational/styles.js +7 -7
- package/es/styles/base.js +2 -12
- package/es/styles/colors/core.js +2 -12
- package/es/styles/colors/experimental.js +2 -12
- package/es/styles/colors/index.js +1 -2
- package/es/styles/colors/theme.js +2 -12
- package/es/styles/index.js +1 -2
- package/es/styles/shadows.js +2 -12
- package/es/styles/variables.js +2 -12
- package/package.json +1 -1
package/es/foundational/field.js
CHANGED
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import "core-js/modules/es.array.index-of.js";
|
|
3
|
-
import "core-js/modules/es.symbol.js";
|
|
4
|
-
import "core-js/modules/es.object.assign.js";
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
5
2
|
var _excluded = ["paddingLeft", "paddingRight", "hasError", "isReadOnly", "isDisabled"],
|
|
6
3
|
_excluded2 = ["children"],
|
|
7
4
|
_excluded3 = ["children"];
|
|
@@ -13,7 +10,10 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
13
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; }
|
|
14
11
|
|
|
15
12
|
import "core-js/modules/es.array.concat.js";
|
|
16
|
-
import
|
|
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
17
|
import { forwardRef } from 'react';
|
|
18
18
|
import { Text } from '../components';
|
|
19
19
|
import { getColor, getRadius, getSpace, getTransition, getWeight } from '../utilities';
|
|
@@ -29,39 +29,63 @@ export var fieldVars = {
|
|
|
29
29
|
};
|
|
30
30
|
export var getFieldStyles = function getFieldStyles(_ref) {
|
|
31
31
|
var hasError = _ref.hasError;
|
|
32
|
-
return
|
|
32
|
+
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 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 }\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");
|
|
33
33
|
};
|
|
34
|
-
export var InputField = /*#__PURE__*/forwardRef(function (_ref2, ref) {
|
|
35
|
-
var _ref2$paddingLeft = _ref2.paddingLeft,
|
|
36
|
-
paddingLeft = _ref2$paddingLeft === void 0 ? getSpace('fieldPaddingX') : _ref2$paddingLeft,
|
|
37
|
-
_ref2$paddingRight = _ref2.paddingRight,
|
|
38
|
-
paddingRight = _ref2$paddingRight === void 0 ? getSpace('fieldPaddingX') : _ref2$paddingRight,
|
|
39
|
-
hasError = _ref2.hasError,
|
|
40
|
-
isReadOnly = _ref2.isReadOnly,
|
|
41
|
-
isDisabled = _ref2.isDisabled,
|
|
42
|
-
props = _objectWithoutProperties(_ref2, _excluded);
|
|
43
34
|
|
|
44
|
-
|
|
35
|
+
var InputFieldRoot = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "production" ? {
|
|
36
|
+
target: "e1swxi6p1"
|
|
37
|
+
} : {
|
|
38
|
+
target: "e1swxi6p1",
|
|
39
|
+
label: "InputFieldRoot"
|
|
40
|
+
})(function (_ref2) {
|
|
41
|
+
var hasError = _ref2.hasError;
|
|
42
|
+
return getFieldStyles({
|
|
43
|
+
hasError: hasError
|
|
44
|
+
});
|
|
45
|
+
}, ";padding:", function (_ref3) {
|
|
46
|
+
var paddingLeft = _ref3.paddingLeft,
|
|
47
|
+
paddingRight = _ref3.paddingRight;
|
|
48
|
+
return "0 ".concat(paddingRight, " 0 ").concat(paddingLeft);
|
|
49
|
+
}, ";height:", componentVars.textBoxHeight, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IgfSkgPT4gYFxuICAke3N0eWxlcy50cmFuc2l0aW9uc307XG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJvcmRlci1jb2xvcjtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuXG4gIG91dGxpbmU6IG5vbmU7XG4gIGJvcmRlcjogJHtjb21wb25lbnRWYXJzLnN0cm9rZVNpemV9IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoaGFzRXJyb3IgPyAnZGFuZ2VyJyA6ICdmaWVsZEJvcmRlcicpfTtcblxuICAmOjpwbGFjZWhvbGRlciB7XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNycpfTtcbiAgfVxuXG4gICY6ZGlzYWJsZWQsXG4gICY6cmVhZC1vbmx5IHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJhY2tncm91bmREaXNhYmxlZCcpfTtcbiAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gICAgLyogZml4IGZvciBzYWZhcmkgKi9cbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJvcmRlckhvdmVyJyl9O1xuICAgICAgfVxuXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdhY3RpdmUnKX07XG4gICAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJGb2N1cycpfTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbiAgfVxuYDtcblxuY29uc3QgSW5wdXRGaWVsZFJvb3QgPSBzdHlsZWQuaW5wdXRgXG4gICR7KHsgaGFzRXJyb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciB9KX07XG4gIHBhZGRpbmc6ICR7KHsgcGFkZGluZ0xlZnQsIHBhZGRpbmdSaWdodCB9KSA9PiBgMCAke3BhZGRpbmdSaWdodH0gMCAke3BhZGRpbmdMZWZ0fWB9O1xuICBoZWlnaHQ6ICR7Y29tcG9uZW50VmFycy50ZXh0Qm94SGVpZ2h0fTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gZ2V0U3BhY2UoJ2ZpZWxkUGFkZGluZ1gnKSxcbiAgICAgIHBhZGRpbmdSaWdodCA9IGdldFNwYWNlKCdmaWVsZFBhZGRpbmdYJyksXG4gICAgICBoYXNFcnJvcixcbiAgICAgIGlzUmVhZE9ubHksXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiAoXG4gICAgPElucHV0RmllbGRSb290XG4gICAgICBwYWRkaW5nTGVmdD17cGFkZGluZ0xlZnR9XG4gICAgICBwYWRkaW5nUmlnaHQ9e3BhZGRpbmdSaWdodH1cbiAgICAgIHJlYWRPbmx5PXtpc1JlYWRPbmx5fVxuICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuY29uc3QgRmllbGRMYWJlbFJvb3QgPSBzdHlsZWQubGFiZWxgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250LXdlaWdodDogJHtnZXRXZWlnaHQoJ21lZGl1bScpfTtcbiAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuXG4gIC8qIFRPRE86IHJlbW92ZSBhZnRlciBkZWxldGluZyBCb290c3RyYXAgKi9cbiAgbWFyZ2luOiB1bnNldDtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZExhYmVsID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSwgcmVmKSA9PiAoXG4gIDxGaWVsZExhYmVsUm9vdCByZWY9e3JlZn0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvRmllbGRMYWJlbFJvb3Q+XG4pKTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcbiJdfQ== */"));
|
|
50
|
+
|
|
51
|
+
export var InputField = /*#__PURE__*/forwardRef(function (_ref4, ref) {
|
|
52
|
+
var _ref4$paddingLeft = _ref4.paddingLeft,
|
|
53
|
+
paddingLeft = _ref4$paddingLeft === void 0 ? getSpace('fieldPaddingX') : _ref4$paddingLeft,
|
|
54
|
+
_ref4$paddingRight = _ref4.paddingRight,
|
|
55
|
+
paddingRight = _ref4$paddingRight === void 0 ? getSpace('fieldPaddingX') : _ref4$paddingRight,
|
|
56
|
+
hasError = _ref4.hasError,
|
|
57
|
+
isReadOnly = _ref4.isReadOnly,
|
|
58
|
+
isDisabled = _ref4.isDisabled,
|
|
59
|
+
props = _objectWithoutProperties(_ref4, _excluded);
|
|
60
|
+
|
|
61
|
+
return ___EmotionJSX(InputFieldRoot, _extends({
|
|
62
|
+
paddingLeft: paddingLeft,
|
|
63
|
+
paddingRight: paddingRight,
|
|
45
64
|
readOnly: isReadOnly,
|
|
46
65
|
disabled: isDisabled,
|
|
47
66
|
ref: ref,
|
|
48
|
-
|
|
49
|
-
hasError: hasError
|
|
50
|
-
}), ";padding:0 ", paddingRight, " 0 ", paddingLeft, ";height:", componentVars.textBoxHeight, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:InputField;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBFYyIsImZpbGUiOiIuLi8uLi9zcmMvZm91bmRhdGlvbmFsL2ZpZWxkLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vY29tcG9uZW50cyc7XG5pbXBvcnQgeyBnZXRDb2xvciwgZ2V0UmFkaXVzLCBnZXRTcGFjZSwgZ2V0VHJhbnNpdGlvbiwgZ2V0V2VpZ2h0IH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IGNvbXBvbmVudFZhcnMsIHN0eWxlcyB9IGZyb20gJy4vc3R5bGVzJztcblxuZXhwb3J0IGNvbnN0IGZpZWxkVmFycyA9IHtcbiAgeFBhZGRpbmc6ICcxMnB4JyxcbiAgYm9yZGVyQ29sb3I6IGdldENvbG9yKCdmYWRlMycpLFxuICBib3JkZXJDb2xvckhvdmVyOiBnZXRDb2xvcignZmFkZTYnKSxcbiAgYm9yZGVyQ29sb3JGb2N1czogZ2V0Q29sb3IoJ3NoYWRlOScpLFxuICBib3JkZXJDb2xvckRpc2FibGVkOiBnZXRDb2xvcignc2hhZGU1JyksXG4gIGJhY2tncm91bmRDb2xvckRpc2FibGVkOiBnZXRDb2xvcignc2hhZGUyJyksXG59O1xuXG5leHBvcnQgY29uc3QgZ2V0RmllbGRTdHlsZXMgPSAoeyBoYXNFcnJvciB9KSA9PiBjc3NgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgdHJhbnNpdGlvbi1wcm9wZXJ0eTogYm9yZGVyLWNvbG9yO1xuICB3aWR0aDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogJHtnZXRSYWRpdXMoJ3MnKX07XG5cbiAgb3V0bGluZTogbm9uZTtcbiAgYm9yZGVyOiAke2NvbXBvbmVudFZhcnMuc3Ryb2tlU2l6ZX0gc29saWQ7XG4gIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcihoYXNFcnJvciA/ICdkYW5nZXInIDogJ2ZpZWxkQm9yZGVyJyl9O1xuXG4gICY6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogJHtnZXRDb2xvcignc2hhZGU3Jyl9O1xuICB9XG5cbiAgJjpkaXNhYmxlZCxcbiAgJjpyZWFkLW9ubHkge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQmFja2dyb3VuZERpc2FibGVkJyl9O1xuICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJEaXNhYmxlZCcpfTtcbiAgICAvKiBmaXggZm9yIHNhZmFyaSAqL1xuICAgIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICAgIG9wYWNpdHk6IDE7XG4gIH1cblxuICAkeyFoYXNFcnJvciAmJlxuICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJvcmRlckhvdmVyJyl9O1xuICAgICAgfVxuXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdhY3RpdmUnKX07XG4gICAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJGb2N1cycpfTtcbiAgICAgIH1cbiAgICB9XG4gIGB9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRGaWVsZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBwYWRkaW5nTGVmdCA9IGdldFNwYWNlKCdmaWVsZFBhZGRpbmdYJyksXG4gICAgICBwYWRkaW5nUmlnaHQgPSBnZXRTcGFjZSgnZmllbGRQYWRkaW5nWCcpLFxuICAgICAgaGFzRXJyb3IsXG4gICAgICBpc1JlYWRPbmx5LFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxpbnB1dFxuICAgICAgcmVhZE9ubHk9e2lzUmVhZE9ubHl9XG4gICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgIHJlZj17cmVmfVxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgICR7Z2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciB9KX07XG4gICAgICAgIHBhZGRpbmc6IDAgJHtwYWRkaW5nUmlnaHR9IDAgJHtwYWRkaW5nTGVmdH07XG4gICAgICAgIGhlaWdodDogJHtjb21wb25lbnRWYXJzLnRleHRCb3hIZWlnaHR9O1xuICAgICAgYH1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPGxhYmVsXG4gICAgcmVmPXtyZWZ9XG4gICAgY3NzPXtjc3NgXG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICAgICAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuXG4gICAgICAvKiBUT0RPOiByZW1vdmUgYWZ0ZXIgZGVsZXRpbmcgQm9vdHN0cmFwICovXG4gICAgICBtYXJnaW46IHVuc2V0O1xuICAgIGB9XG4gICAgey4uLnByb3BzfVxuICA+XG4gICAge2NoaWxkcmVufVxuICA8L2xhYmVsPlxuKSk7XG5cbmV4cG9ydCBjb25zdCBGaWVsZEhpbnQgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPFRleHQgY29sb3I9XCJjb250ZW50MlwiIHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9UZXh0PlxuKSk7XG4iXX0= */")
|
|
67
|
+
hasError: hasError
|
|
51
68
|
}, props));
|
|
52
69
|
});
|
|
53
|
-
export var FieldLabel = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
|
54
|
-
var children = _ref3.children,
|
|
55
|
-
props = _objectWithoutProperties(_ref3, _excluded2);
|
|
56
70
|
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
71
|
+
var FieldLabelRoot = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production" ? {
|
|
72
|
+
target: "e1swxi6p0"
|
|
73
|
+
} : {
|
|
74
|
+
target: "e1swxi6p0",
|
|
75
|
+
label: "FieldLabelRoot"
|
|
76
|
+
})("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBmaWVsZFZhcnMgPSB7XG4gIHhQYWRkaW5nOiAnMTJweCcsXG4gIGJvcmRlckNvbG9yOiBnZXRDb2xvcignZmFkZTMnKSxcbiAgYm9yZGVyQ29sb3JIb3ZlcjogZ2V0Q29sb3IoJ2ZhZGU2JyksXG4gIGJvcmRlckNvbG9yRm9jdXM6IGdldENvbG9yKCdzaGFkZTknKSxcbiAgYm9yZGVyQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlNScpLFxuICBiYWNrZ3JvdW5kQ29sb3JEaXNhYmxlZDogZ2V0Q29sb3IoJ3NoYWRlMicpLFxufTtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IgfSkgPT4gYFxuICAke3N0eWxlcy50cmFuc2l0aW9uc307XG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJvcmRlci1jb2xvcjtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuXG4gIG91dGxpbmU6IG5vbmU7XG4gIGJvcmRlcjogJHtjb21wb25lbnRWYXJzLnN0cm9rZVNpemV9IHNvbGlkO1xuICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoaGFzRXJyb3IgPyAnZGFuZ2VyJyA6ICdmaWVsZEJvcmRlcicpfTtcblxuICAmOjpwbGFjZWhvbGRlciB7XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNycpfTtcbiAgfVxuXG4gICY6ZGlzYWJsZWQsXG4gICY6cmVhZC1vbmx5IHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJhY2tncm91bmREaXNhYmxlZCcpfTtcbiAgICBib3JkZXItY29sb3I6ICR7Z2V0Q29sb3IoJ2ZpZWxkQm9yZGVyRGlzYWJsZWQnKX07XG4gICAgLyogZml4IGZvciBzYWZhcmkgKi9cbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKCdmaWVsZEJvcmRlckhvdmVyJyl9O1xuICAgICAgfVxuXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdhY3RpdmUnKX07XG4gICAgICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcignZmllbGRCb3JkZXJGb2N1cycpfTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbiAgfVxuYDtcblxuY29uc3QgSW5wdXRGaWVsZFJvb3QgPSBzdHlsZWQuaW5wdXRgXG4gICR7KHsgaGFzRXJyb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciB9KX07XG4gIHBhZGRpbmc6ICR7KHsgcGFkZGluZ0xlZnQsIHBhZGRpbmdSaWdodCB9KSA9PiBgMCAke3BhZGRpbmdSaWdodH0gMCAke3BhZGRpbmdMZWZ0fWB9O1xuICBoZWlnaHQ6ICR7Y29tcG9uZW50VmFycy50ZXh0Qm94SGVpZ2h0fTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gZ2V0U3BhY2UoJ2ZpZWxkUGFkZGluZ1gnKSxcbiAgICAgIHBhZGRpbmdSaWdodCA9IGdldFNwYWNlKCdmaWVsZFBhZGRpbmdYJyksXG4gICAgICBoYXNFcnJvcixcbiAgICAgIGlzUmVhZE9ubHksXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiAoXG4gICAgPElucHV0RmllbGRSb290XG4gICAgICBwYWRkaW5nTGVmdD17cGFkZGluZ0xlZnR9XG4gICAgICBwYWRkaW5nUmlnaHQ9e3BhZGRpbmdSaWdodH1cbiAgICAgIHJlYWRPbmx5PXtpc1JlYWRPbmx5fVxuICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICByZWY9e3JlZn1cbiAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuY29uc3QgRmllbGRMYWJlbFJvb3QgPSBzdHlsZWQubGFiZWxgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250LXdlaWdodDogJHtnZXRXZWlnaHQoJ21lZGl1bScpfTtcbiAgdHJhbnNpdGlvbjogJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuXG4gIC8qIFRPRE86IHJlbW92ZSBhZnRlciBkZWxldGluZyBCb290c3RyYXAgKi9cbiAgbWFyZ2luOiB1bnNldDtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZExhYmVsID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSwgcmVmKSA9PiAoXG4gIDxGaWVsZExhYmVsUm9vdCByZWY9e3JlZn0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvRmllbGRMYWJlbFJvb3Q+XG4pKTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcbiJdfQ== */"));
|
|
77
|
+
|
|
78
|
+
export var FieldLabel = /*#__PURE__*/forwardRef(function (_ref5, ref) {
|
|
79
|
+
var children = _ref5.children,
|
|
80
|
+
props = _objectWithoutProperties(_ref5, _excluded2);
|
|
81
|
+
|
|
82
|
+
return ___EmotionJSX(FieldLabelRoot, _extends({
|
|
83
|
+
ref: ref
|
|
60
84
|
}, props), children);
|
|
61
85
|
});
|
|
62
|
-
export var FieldHint = /*#__PURE__*/forwardRef(function (
|
|
63
|
-
var children =
|
|
64
|
-
props = _objectWithoutProperties(
|
|
86
|
+
export var FieldHint = /*#__PURE__*/forwardRef(function (_ref6, ref) {
|
|
87
|
+
var children = _ref6.children,
|
|
88
|
+
props = _objectWithoutProperties(_ref6, _excluded3);
|
|
65
89
|
|
|
66
90
|
return ___EmotionJSX(Text, _extends({
|
|
67
91
|
color: "content2",
|
package/es/foundational/menu.js
CHANGED
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import "
|
|
2
|
-
import "core-js/modules/es.array.index-of.js";
|
|
3
|
-
import "core-js/modules/es.symbol.js";
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
4
2
|
var _excluded = ["children", "show"],
|
|
5
3
|
_excluded2 = ["children", "zIndex", "maxHeight", "maxWidth", "isDisabled"],
|
|
6
|
-
_excluded3 = ["children", "isDisabled", "
|
|
7
|
-
_excluded4 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasEllipsis", "checkVariant"];
|
|
4
|
+
_excluded3 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasEllipsis", "checkVariant"];
|
|
8
5
|
|
|
9
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); }
|
|
10
7
|
|
|
@@ -13,9 +10,13 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
13
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; }
|
|
14
11
|
|
|
15
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";
|
|
16
17
|
import React, { Fragment, forwardRef } from 'react';
|
|
17
18
|
import PropTypes from 'prop-types';
|
|
18
|
-
import { Global
|
|
19
|
+
import { Global } from '@emotion/react';
|
|
19
20
|
import { getColor, getDimension, getRadius, getShadow, getSpace, getTransition } from '../utilities';
|
|
20
21
|
import { Box, Checkbox, Icon, Text } from '../components';
|
|
21
22
|
import { IconCheck } from '../icons';
|
|
@@ -84,7 +85,7 @@ export var useMenuPosition = function useMenuPosition(_ref) {
|
|
|
84
85
|
floatingStyles: floatingStyles
|
|
85
86
|
};
|
|
86
87
|
};
|
|
87
|
-
var menuCardStyles = /*#__PURE__*/css(".menuCardLeaveTo,.menuCardEnterFrom{opacity:0;}.menuCardEnterTo{transition-duration:", getTransition('xxFast'), ";}.menuCardLeaveTo{transition-duration:", getTransition('xFast'), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuCardStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAuE0B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Checkbox, 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';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          ${maxHeight && `max-height: ${getSpace(maxHeight)}`};\n          ${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 && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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 = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', '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"]} */");
|
|
88
|
+
var 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");
|
|
88
89
|
export var MenuCardTransition = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
|
89
90
|
var children = _ref3.children,
|
|
90
91
|
show = _ref3.show,
|
|
@@ -100,20 +101,43 @@ export var MenuCardTransition = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
|
|
100
101
|
show: show
|
|
101
102
|
}, props), children);
|
|
102
103
|
});
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
104
|
+
|
|
105
|
+
var MenuCardUl = /*#__PURE__*/_styled("ul", process.env.NODE_ENV === "production" ? {
|
|
106
|
+
target: "eil6qy21"
|
|
107
|
+
} : {
|
|
108
|
+
target: "eil6qy21",
|
|
109
|
+
label: "MenuCardUl"
|
|
110
|
+
})("padding:", cardPaddingPx, ";margin:0;background:", getColor('floatingBackground'), ";z-index:", function (_ref4) {
|
|
111
|
+
var zIndex = _ref4.zIndex;
|
|
112
|
+
return zIndex;
|
|
113
|
+
}, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;", function (_ref5) {
|
|
114
|
+
var maxHeight = _ref5.maxHeight;
|
|
115
|
+
return maxHeight && "max-height: ".concat(getSpace(maxHeight));
|
|
116
|
+
}, ";", function (_ref6) {
|
|
117
|
+
var maxWidth = _ref6.maxWidth;
|
|
118
|
+
return maxWidth && "max-width: ".concat(getSpace(maxWidth));
|
|
119
|
+
}, ";", function (_ref7) {
|
|
120
|
+
var isDisabled = _ref7.isDisabled;
|
|
121
|
+
return isDisabled && "pointer-events: none;";
|
|
122
|
+
}, " &: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":"AAoG4B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } 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, Checkbox, 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 itemYPadding = 10;\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    <>\n      <Global styles={menuCardStyles} />\n      <MenuCardUl\n        zIndex={zIndex}\n        maxHeight={maxHeight}\n        maxWidth={maxWidth}\n        isDisabled={isDisabled}\n        ref={ref}\n        {...props}\n      >\n        {children}\n      </MenuCardUl>\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: ${itemYPadding}px ${itemXPadding}px;\n  margin: 0;\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', '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"]} */"));
|
|
123
|
+
|
|
124
|
+
export var MenuCard = /*#__PURE__*/forwardRef(function (_ref8, ref) {
|
|
125
|
+
var children = _ref8.children,
|
|
126
|
+
_ref8$zIndex = _ref8.zIndex,
|
|
127
|
+
zIndex = _ref8$zIndex === void 0 ? 1 : _ref8$zIndex,
|
|
128
|
+
maxHeight = _ref8.maxHeight,
|
|
129
|
+
maxWidth = _ref8.maxWidth,
|
|
130
|
+
isDisabled = _ref8.isDisabled,
|
|
131
|
+
props = _objectWithoutProperties(_ref8, _excluded2);
|
|
111
132
|
|
|
112
133
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
|
|
113
134
|
styles: menuCardStyles
|
|
114
|
-
}), ___EmotionJSX(
|
|
115
|
-
|
|
116
|
-
css: /*#__PURE__*/css("padding:", cardPaddingPx, ";margin:0;background:", getColor('floatingBackground'), ";z-index:", zIndex, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;", maxHeight && "max-height: ".concat(getSpace(maxHeight)), ";", maxWidth && "max-width: ".concat(getSpace(maxWidth)), ";", isDisabled && "pointer-events: none;", " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAyGgB","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Checkbox, 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';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          ${maxHeight && `max-height: ${getSpace(maxHeight)}`};\n          ${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 && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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 = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', '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"]} */")
|
|
135
|
+
}), ___EmotionJSX(MenuCardUl, _extends({
|
|
136
|
+
zIndex: zIndex,
|
|
137
|
+
maxHeight: maxHeight,
|
|
138
|
+
maxWidth: maxWidth,
|
|
139
|
+
isDisabled: isDisabled,
|
|
140
|
+
ref: ref
|
|
117
141
|
}, props), children));
|
|
118
142
|
});
|
|
119
143
|
var variantStyles = {
|
|
@@ -128,23 +152,26 @@ var variantStyles = {
|
|
|
128
152
|
backgroundColorActive: componentVars.clearButtonDangerBackgroundHover
|
|
129
153
|
}
|
|
130
154
|
};
|
|
131
|
-
var MenuItemRoot = /*#__PURE__*/forwardRef(function (_ref5, ref) {
|
|
132
|
-
var children = _ref5.children,
|
|
133
|
-
isDisabled = _ref5.isDisabled,
|
|
134
|
-
hasIcon = _ref5.hasIcon,
|
|
135
|
-
isSelected = _ref5.isSelected,
|
|
136
|
-
color = _ref5.color,
|
|
137
|
-
columns = _ref5.columns,
|
|
138
|
-
props = _objectWithoutProperties(_ref5, _excluded3);
|
|
139
155
|
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
css: /*#__PURE__*/css("display:grid;grid-auto-flow:column;gap:8px;", isDisabled && "color: ".concat(getColor('disabledContent')), ";", !isDisabled && "cursor: pointer;", ";align-items:center;justify-content:start;list-style:none;padding:", itemYPadding, "px ", itemXPadding, "px;margin:0;min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";appearance:none;color:", color, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuItemRoot;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAmJc","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Checkbox, 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';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          ${maxHeight && `max-height: ${getSpace(maxHeight)}`};\n          ${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 && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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 = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', '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"]} */")
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
var
|
|
147
|
-
|
|
156
|
+
var MenuItemRoot = /*#__PURE__*/_styled("li", process.env.NODE_ENV === "production" ? {
|
|
157
|
+
target: "eil6qy20"
|
|
158
|
+
} : {
|
|
159
|
+
target: "eil6qy20",
|
|
160
|
+
label: "MenuItemRoot"
|
|
161
|
+
})("display:grid;grid-auto-flow:column;gap:8px;", function (_ref9) {
|
|
162
|
+
var isDisabled = _ref9.isDisabled;
|
|
163
|
+
return isDisabled && "color: ".concat(getColor('disabledContent'));
|
|
164
|
+
}, ";", function (_ref10) {
|
|
165
|
+
var isDisabled = _ref10.isDisabled;
|
|
166
|
+
return !isDisabled && "cursor: pointer;";
|
|
167
|
+
}, ";align-items:center;justify-content:start;list-style:none;padding:", itemYPadding, "px ", itemXPadding, "px;margin:0;min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";appearance:none;color:", function (_ref11) {
|
|
168
|
+
var color = _ref11.color;
|
|
169
|
+
return color;
|
|
170
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAqJ8B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } 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, Checkbox, 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 itemYPadding = 10;\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    <>\n      <Global styles={menuCardStyles} />\n      <MenuCardUl\n        zIndex={zIndex}\n        maxHeight={maxHeight}\n        maxWidth={maxWidth}\n        isDisabled={isDisabled}\n        ref={ref}\n        {...props}\n      >\n        {children}\n      </MenuCardUl>\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: ${itemYPadding}px ${itemXPadding}px;\n  margin: 0;\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', '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"]} */"));
|
|
171
|
+
|
|
172
|
+
export var MenuGroupTitle = function MenuGroupTitle(_ref12) {
|
|
173
|
+
var children = _ref12.children,
|
|
174
|
+
hasDivider = _ref12.hasDivider;
|
|
148
175
|
return ___EmotionJSX(React.Fragment, null, hasDivider && ___EmotionJSX(Box, {
|
|
149
176
|
height: "3px",
|
|
150
177
|
borderSide: hasDivider ? 'top' : undefined,
|
|
@@ -167,18 +194,18 @@ export var MenuItemDivider = function MenuItemDivider() {
|
|
|
167
194
|
marginX: "-".concat(cardPaddingPx)
|
|
168
195
|
});
|
|
169
196
|
};
|
|
170
|
-
export var MenuItem = /*#__PURE__*/forwardRef(function (
|
|
171
|
-
var children =
|
|
172
|
-
isSelected =
|
|
173
|
-
isActive =
|
|
174
|
-
isDisabled =
|
|
175
|
-
icon =
|
|
176
|
-
|
|
177
|
-
variant =
|
|
178
|
-
hasEllipsis =
|
|
179
|
-
|
|
180
|
-
checkVariant =
|
|
181
|
-
props = _objectWithoutProperties(
|
|
197
|
+
export var MenuItem = /*#__PURE__*/forwardRef(function (_ref13, ref) {
|
|
198
|
+
var children = _ref13.children,
|
|
199
|
+
isSelected = _ref13.isSelected,
|
|
200
|
+
isActive = _ref13.isActive,
|
|
201
|
+
isDisabled = _ref13.isDisabled,
|
|
202
|
+
icon = _ref13.icon,
|
|
203
|
+
_ref13$variant = _ref13.variant,
|
|
204
|
+
variant = _ref13$variant === void 0 ? 'neutral' : _ref13$variant,
|
|
205
|
+
hasEllipsis = _ref13.hasEllipsis,
|
|
206
|
+
_ref13$checkVariant = _ref13.checkVariant,
|
|
207
|
+
checkVariant = _ref13$checkVariant === void 0 ? 'check' : _ref13$checkVariant,
|
|
208
|
+
props = _objectWithoutProperties(_ref13, _excluded3);
|
|
182
209
|
|
|
183
210
|
var hasCheck = checkVariant === 'check';
|
|
184
211
|
var hasCheckbox = checkVariant === 'checkbox';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import "core-js/modules/es.array.concat.js";
|
|
2
2
|
import { getColor, getRadius, getTextSize, getTransition, getWeight } from '../utilities';
|
|
3
3
|
export var capHeight = "0.74em";
|
|
4
4
|
export var lineHeightAndCapHeightOffset = "calc((var(--grn-lineHeight-global) - ".concat(capHeight, ") / 2)");
|
|
@@ -12,8 +12,8 @@ export var componentVars = {
|
|
|
12
12
|
clearButtonDangerBackgroundActive: 'hsl(var(--redHS) var(--redL) / 60%)',
|
|
13
13
|
dangerIconColor: 'hsl(var(--redHS) var(--redL) / 70%)'
|
|
14
14
|
};
|
|
15
|
-
var buttonResetStyles =
|
|
16
|
-
export var transitionStyles =
|
|
15
|
+
var buttonResetStyles = "\n appearance: none;\n font-family: inherit;\n font-size: inherit;\n font-weight: ".concat(getWeight('medium'), ";\n cursor: pointer;\n");
|
|
16
|
+
export var 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");
|
|
17
17
|
export var styles = {
|
|
18
18
|
buttonReset: buttonResetStyles,
|
|
19
19
|
transitions: transitionStyles
|
|
@@ -47,9 +47,9 @@ export var getClearButtonStyles = function getClearButtonStyles(_ref) {
|
|
|
47
47
|
variant = _ref$variant === void 0 ? 'neutral' : _ref$variant,
|
|
48
48
|
isActive = _ref.isActive,
|
|
49
49
|
isDisabled = _ref.isDisabled;
|
|
50
|
-
var box =
|
|
51
|
-
var icon =
|
|
52
|
-
var text =
|
|
50
|
+
var 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 &:hover {\n background-color: ").concat(variant && variantStyles[variant].hover.backgroundColor, ";\n\n .Icon {\n color: ").concat(variant && variantStyles[variant].hover.iconColor, ";\n }\n }\n\n &:active {\n --border: ").concat(componentVars.strokeSize, " ").concat(variantStyles[variant].active.borderColor, ";\n background-color: transparent;\n box-shadow: inset 0 0 0 var(--border);\n }\n\n ").concat(isDisabled && "pointer-events: none; ", "\n ");
|
|
51
|
+
var icon = "\n ".concat(transitionStyles, ";\n color: ").concat(variant && variantStyles[variant].iconColor, ";\n ").concat(isActive && "color: ".concat(variant && variantStyles[variant].color), ";\n ");
|
|
52
|
+
var text = "\n color: ".concat(variant && variantStyles[variant].color, ";\n ").concat(isDisabled && "color: ".concat(getColor('disabledContent')), ";\n ");
|
|
53
53
|
var clearButtonStyles = {
|
|
54
54
|
box: box,
|
|
55
55
|
icon: icon,
|
|
@@ -112,4 +112,4 @@ export var placementStyles = {
|
|
|
112
112
|
bottom: "0"
|
|
113
113
|
}
|
|
114
114
|
};
|
|
115
|
-
export var capStyles =
|
|
115
|
+
export var 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/styles/base.js
CHANGED
|
@@ -1,12 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { css } from '@emotion/react';
|
|
4
|
-
export default process.env.NODE_ENV === "production" ? {
|
|
5
|
-
name: "1inf83a",
|
|
6
|
-
styles: ":root{--grn-lineHeight-fixed:7px;--grn-lineHeight-relative:0.9em;--grn-lineHeight-global:calc(var(--grn-lineHeight-fixed) + var(--grn-lineHeight-relative));--grn-font-global:'Flodesk Sans',sans-serif;--grn-radius-button:var(--grn-radius-s);}.grn-context,.grn-context *{line-height:var(--grn-lineHeight-global);outline-color:var(--grn-color-selection);}.grn-context{font-family:var(--grn-font-global);font-size:var(--grn-text-m);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}[data-theme],.grn-context{color:var(--grn-color-content);}*,*:before,*:after{box-sizing:border-box;}.grn-link-context a{transition:var(--grn-transition-slow);text-underline-position:under;text-underline-offset:calc(2px - 0.1em);color:inherit;cursor:pointer;text-decoration-color:var(--grn-color-fade3);}.grn-link-context a:hover{transition:var(--grn-transition-fast);text-decoration-color:currentColor;}.grn-link-context a:active{transition:var(--grn-transition-xxFast);}"
|
|
7
|
-
} : {
|
|
8
|
-
name: "1inf83a",
|
|
9
|
-
styles: ":root{--grn-lineHeight-fixed:7px;--grn-lineHeight-relative:0.9em;--grn-lineHeight-global:calc(var(--grn-lineHeight-fixed) + var(--grn-lineHeight-relative));--grn-font-global:'Flodesk Sans',sans-serif;--grn-radius-button:var(--grn-radius-s);}.grn-context,.grn-context *{line-height:var(--grn-lineHeight-global);outline-color:var(--grn-color-selection);}.grn-context{font-family:var(--grn-font-global);font-size:var(--grn-text-m);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}[data-theme],.grn-context{color:var(--grn-color-content);}*,*:before,*:after{box-sizing:border-box;}.grn-link-context a{transition:var(--grn-transition-slow);text-underline-position:under;text-underline-offset:calc(2px - 0.1em);color:inherit;cursor:pointer;text-decoration-color:var(--grn-color-fade3);}.grn-link-context a:hover{transition:var(--grn-transition-fast);text-decoration-color:currentColor;}.grn-link-context a:active{transition:var(--grn-transition-xxFast);}",
|
|
10
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdHlsZXMvYmFzZS5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRWtCIiwiZmlsZSI6Ii4uLy4uL3NyYy9zdHlsZXMvYmFzZS5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBkZWZhdWx0IGNzc2BcbiAgOnJvb3Qge1xuICAgIC0tZ3JuLWxpbmVIZWlnaHQtZml4ZWQ6IDdweDtcbiAgICAtLWdybi1saW5lSGVpZ2h0LXJlbGF0aXZlOiAwLjllbTtcbiAgICAtLWdybi1saW5lSGVpZ2h0LWdsb2JhbDogY2FsYyh2YXIoLS1ncm4tbGluZUhlaWdodC1maXhlZCkgKyB2YXIoLS1ncm4tbGluZUhlaWdodC1yZWxhdGl2ZSkpO1xuXG4gICAgLS1ncm4tZm9udC1nbG9iYWw6ICdGbG9kZXNrIFNhbnMnLCBzYW5zLXNlcmlmO1xuICAgIC0tZ3JuLXJhZGl1cy1idXR0b246IHZhcigtLWdybi1yYWRpdXMtcyk7XG4gIH1cblxuICAuZ3JuLWNvbnRleHQsXG4gIC5ncm4tY29udGV4dCAqIHtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZ3JuLWxpbmVIZWlnaHQtZ2xvYmFsKTtcbiAgICBvdXRsaW5lLWNvbG9yOiB2YXIoLS1ncm4tY29sb3Itc2VsZWN0aW9uKTtcbiAgfVxuXG4gIC5ncm4tY29udGV4dCB7XG4gICAgZm9udC1mYW1pbHk6IHZhcigtLWdybi1mb250LWdsb2JhbCk7XG4gICAgZm9udC1zaXplOiB2YXIoLS1ncm4tdGV4dC1tKTtcbiAgICAtd2Via2l0LWZvbnQtc21vb3RoaW5nOiBhbnRpYWxpYXNlZDtcbiAgICAtbW96LW9zeC1mb250LXNtb290aGluZzogZ3JheXNjYWxlO1xuICB9XG5cbiAgW2RhdGEtdGhlbWVdLFxuICAuZ3JuLWNvbnRleHQge1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gIH1cblxuICAqLFxuICAqOmJlZm9yZSxcbiAgKjphZnRlciB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuXG4gIC5ncm4tbGluay1jb250ZXh0IGEge1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLXNsb3cpO1xuICAgIHRleHQtdW5kZXJsaW5lLXBvc2l0aW9uOiB1bmRlcjtcbiAgICB0ZXh0LXVuZGVybGluZS1vZmZzZXQ6IGNhbGMoMnB4IC0gMC4xZW0pO1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IHZhcigtLWdybi1jb2xvci1mYWRlMyk7XG4gIH1cblxuICAuZ3JuLWxpbmstY29udGV4dCBhOmhvdmVyIHtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1mYXN0KTtcbiAgICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IGN1cnJlbnRDb2xvcjtcbiAgfVxuXG4gIC5ncm4tbGluay1jb250ZXh0IGE6YWN0aXZlIHtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi14eEZhc3QpO1xuICB9XG5gO1xuIl19 */",
|
|
11
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
12
|
-
};
|
|
1
|
+
var base = "\n :root {\n --grn-lineHeight-fixed: 7px;\n --grn-lineHeight-relative: 0.9em;\n --grn-lineHeight-global: calc(var(--grn-lineHeight-fixed) + var(--grn-lineHeight-relative));\n\n --grn-font-global: 'Flodesk Sans', sans-serif;\n --grn-radius-button: var(--grn-radius-s);\n }\n\n .grn-context,\n .grn-context * {\n line-height: var(--grn-lineHeight-global);\n outline-color: var(--grn-color-selection);\n }\n\n .grn-context {\n font-family: var(--grn-font-global);\n font-size: var(--grn-text-m);\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n }\n\n [data-theme],\n .grn-context {\n color: var(--grn-color-content);\n }\n\n *,\n *:before,\n *:after {\n box-sizing: border-box;\n }\n\n .grn-link-context a {\n transition: var(--grn-transition-slow);\n text-underline-position: under;\n text-underline-offset: calc(2px - 0.1em);\n color: inherit;\n cursor: pointer;\n text-decoration-color: var(--grn-color-fade3);\n }\n\n .grn-link-context a:hover {\n transition: var(--grn-transition-fast);\n text-decoration-color: currentColor;\n }\n\n .grn-link-context a:active {\n transition: var(--grn-transition-xxFast);\n }\n";
|
|
2
|
+
export default base;
|