@flodesk/grain 10.17.4 → 10.18.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.js +74 -34
- package/es/components/autocomplete.js +132 -28
- package/es/components/autocomplete2.js +359 -0
- package/es/components/badge.js +7 -8
- package/es/components/box.js +85 -14
- package/es/components/box2.js +223 -0
- package/es/components/button.js +8 -26
- package/es/components/checkbox.js +12 -18
- package/es/components/dropdown.js +81 -28
- package/es/components/flex.js +72 -36
- package/es/components/index.js +5 -1
- package/es/components/link.js +27 -16
- package/es/components/modal.js +89 -68
- package/es/components/nav.js +9 -19
- package/es/components/pagination.js +4 -4
- package/es/components/popover.js +33 -12
- package/es/components/provider.js +14 -0
- package/es/components/select.js +12 -10
- package/es/components/slider.js +6 -17
- package/es/components/spinner.js +4 -14
- package/es/components/stack.js +5 -4
- package/es/components/switch.js +5 -17
- package/es/components/tab.js +1 -1
- package/es/components/text-button.js +13 -12
- package/es/components/text.js +84 -28
- package/es/components/text2/index.js +100 -0
- package/es/components/text2/styles.module.css +22 -0
- package/es/components/textarea.js +34 -20
- package/es/components/toast.js +16 -53
- package/es/components/tooltip.js +4 -4
- package/es/foundational/field.js +52 -28
- package/es/foundational/menu.js +138 -60
- package/es/foundational/styles.js +11 -11
- package/es/hooks/index.js +2 -1
- package/es/hooks/useOnClickOutside.js +7 -6
- package/es/hooks/usePrev.js +8 -0
- package/es/icons/icon-archive.js +21 -0
- package/es/icons/icon-at.js +21 -0
- package/es/icons/icon-bold.js +28 -0
- package/es/icons/icon-bullet-list.js +21 -0
- package/es/icons/icon-column-and-rows.js +21 -0
- package/es/icons/icon-columns-and-row.js +21 -0
- package/es/icons/icon-columns.js +21 -0
- package/es/icons/icon-folder-move.js +21 -0
- package/es/icons/icon-folder-remove.js +21 -0
- package/es/icons/icon-italic.js +28 -0
- package/es/icons/icon-number-list.js +21 -0
- package/es/icons/icon-row-and-columns.js +21 -0
- package/es/icons/icon-rows-and-column.js +21 -0
- package/es/icons/icon-rows.js +21 -0
- package/es/icons/icon-strike.js +28 -0
- package/es/icons/icon-text-justify.js +21 -0
- package/es/icons/icon-underline.js +28 -0
- package/es/icons/index.js +18 -1
- package/es/index.js +2 -1
- package/es/styles/base.js +2 -0
- package/es/styles/colors/core.js +2 -0
- package/es/styles/colors/experimental.js +2 -0
- package/es/styles/colors/index.js +4 -0
- package/es/styles/colors/theme.js +2 -0
- package/es/styles/index.js +6 -0
- package/es/styles/shadows.js +2 -0
- package/es/styles/utilities.js +108 -0
- package/es/styles/variables.js +2 -0
- package/es/types.js +18 -7
- package/es/utilities/attributes.js +66 -0
- package/es/utilities/helpers.js +13 -1
- package/es/utilities/index.js +3 -1
- package/es/utilities/responsive.js +3 -0
- package/es/utilities/style-config.js +442 -0
- package/es/utilities/styles.js +14 -2
- package/es/variables/breakpoints.js +9 -0
- package/es/variables/colors.js +2 -1
- package/es/variables/index.js +2 -1
- package/es/variables/vars.js +3 -0
- package/package.json +1 -1
- package/es/styles/base.css +0 -53
- package/es/styles/colors/core.css +0 -74
- package/es/styles/colors/experimental.css +0 -3
- package/es/styles/colors/theme.css +0 -92
- package/es/styles/shadows.css +0 -60
- package/es/styles/variables.css +0 -66
package/es/foundational/menu.js
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import "
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
_excluded2 = ["children", "isDisabled", "hasIcon", "isSelected", "color", "columns"],
|
|
6
|
-
_excluded3 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasDivider", "hasEllipsis", "checkVariant"];
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
2
|
+
var _excluded = ["children", "show"],
|
|
3
|
+
_excluded2 = ["children", "zIndex", "maxHeight", "maxWidth", "isDisabled"],
|
|
4
|
+
_excluded3 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasEllipsis", "checkVariant"];
|
|
7
5
|
|
|
8
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); }
|
|
9
7
|
|
|
@@ -12,14 +10,20 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
12
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; }
|
|
13
11
|
|
|
14
12
|
import "core-js/modules/es.object.assign.js";
|
|
15
|
-
import
|
|
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
|
+
import React, { Fragment, forwardRef, useCallback, useEffect, useImperativeHandle, useRef } from 'react';
|
|
16
18
|
import PropTypes from 'prop-types';
|
|
17
|
-
import {
|
|
18
|
-
import { getColor, getDimension, getRadius, getShadow, getTransition } from '../utilities';
|
|
19
|
+
import { Global } from '@emotion/react';
|
|
20
|
+
import { getColor, getDimension, getRadius, getShadow, getSpace, getTransition } from '../utilities';
|
|
19
21
|
import { Box, Checkbox, Icon, Text } from '../components';
|
|
20
22
|
import { IconCheck } from '../icons';
|
|
21
23
|
import { componentVars } from './styles';
|
|
22
24
|
import { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';
|
|
25
|
+
import { Transition } from '@headlessui/react';
|
|
26
|
+
import { types } from '../types';
|
|
23
27
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
24
28
|
var cardPadding = 8;
|
|
25
29
|
var cardPaddingPx = "".concat(cardPadding, "px");
|
|
@@ -65,7 +69,8 @@ export var useMenuPosition = function useMenuPosition(_ref) {
|
|
|
65
69
|
y = _useFloating.y,
|
|
66
70
|
reference = _useFloating.reference,
|
|
67
71
|
floating = _useFloating.floating,
|
|
68
|
-
strategy = _useFloating.strategy
|
|
72
|
+
strategy = _useFloating.strategy,
|
|
73
|
+
refs = _useFloating.refs;
|
|
69
74
|
|
|
70
75
|
var floatingStyles = {
|
|
71
76
|
position: strategy,
|
|
@@ -74,25 +79,83 @@ export var useMenuPosition = function useMenuPosition(_ref) {
|
|
|
74
79
|
zIndex: 1100
|
|
75
80
|
};
|
|
76
81
|
return {
|
|
82
|
+
refs: refs,
|
|
77
83
|
reference: reference,
|
|
78
84
|
floating: floating,
|
|
79
85
|
floatingStyles: floatingStyles
|
|
80
86
|
};
|
|
81
87
|
};
|
|
82
|
-
|
|
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");
|
|
89
|
+
export var MenuCardTransition = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
|
83
90
|
var children = _ref3.children,
|
|
84
|
-
|
|
85
|
-
zIndex = _ref3$zIndex === void 0 ? 1 : _ref3$zIndex,
|
|
86
|
-
placement = _ref3.placement,
|
|
87
|
-
maxHeight = _ref3.maxHeight,
|
|
88
|
-
isOpen = _ref3.isOpen,
|
|
91
|
+
show = _ref3.show,
|
|
89
92
|
props = _objectWithoutProperties(_ref3, _excluded);
|
|
90
93
|
|
|
91
|
-
return ___EmotionJSX(
|
|
94
|
+
return ___EmotionJSX(Transition, _extends({
|
|
95
|
+
as: Fragment,
|
|
96
|
+
enterFrom: "menuCardEnterFrom",
|
|
97
|
+
enterTo: "menuCardEnterTo",
|
|
98
|
+
leaveFrom: "menuCardLeaveFrom",
|
|
99
|
+
leaveTo: "menuCardLeaveTo",
|
|
92
100
|
ref: ref,
|
|
93
|
-
|
|
101
|
+
show: show
|
|
94
102
|
}, props), children);
|
|
95
103
|
});
|
|
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":"AA2G4B","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, 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    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: ${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);
|
|
132
|
+
|
|
133
|
+
var menuCardRef = useRef(ref);
|
|
134
|
+
useImperativeHandle(ref, function () {
|
|
135
|
+
return menuCardRef.current;
|
|
136
|
+
}, []);
|
|
137
|
+
var scrollToActive = useCallback(function () {
|
|
138
|
+
// Note: this function is rely on data-headlessui-state attribute
|
|
139
|
+
var menuCard = menuCardRef.current;
|
|
140
|
+
var activeItem = menuCard === null || menuCard === void 0 ? void 0 : menuCard.querySelector('[data-headlessui-state="selected"]');
|
|
141
|
+
if (!menuCard || !activeItem) return;
|
|
142
|
+
var menuCardRect = menuCard.getBoundingClientRect();
|
|
143
|
+
var activeItemRect = activeItem.getBoundingClientRect();
|
|
144
|
+
menuCard.scrollTop = activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;
|
|
145
|
+
}, []);
|
|
146
|
+
useEffect(function () {
|
|
147
|
+
scrollToActive();
|
|
148
|
+
}, [scrollToActive]);
|
|
149
|
+
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
|
|
150
|
+
styles: menuCardStyles
|
|
151
|
+
}), ___EmotionJSX(MenuCardUl, _extends({
|
|
152
|
+
ref: menuCardRef,
|
|
153
|
+
zIndex: zIndex,
|
|
154
|
+
maxHeight: maxHeight,
|
|
155
|
+
maxWidth: maxWidth,
|
|
156
|
+
isDisabled: isDisabled
|
|
157
|
+
}, props), children));
|
|
158
|
+
});
|
|
96
159
|
var variantStyles = {
|
|
97
160
|
neutral: {
|
|
98
161
|
backgroundColorActive: getColor('fade1'),
|
|
@@ -105,55 +168,60 @@ var variantStyles = {
|
|
|
105
168
|
backgroundColorActive: componentVars.clearButtonDangerBackgroundHover
|
|
106
169
|
}
|
|
107
170
|
};
|
|
108
|
-
var MenuItemRoot = /*#__PURE__*/forwardRef(function (_ref4, ref) {
|
|
109
|
-
var children = _ref4.children,
|
|
110
|
-
isDisabled = _ref4.isDisabled,
|
|
111
|
-
hasIcon = _ref4.hasIcon,
|
|
112
|
-
isSelected = _ref4.isSelected,
|
|
113
|
-
color = _ref4.color,
|
|
114
|
-
columns = _ref4.columns,
|
|
115
|
-
props = _objectWithoutProperties(_ref4, _excluded2);
|
|
116
171
|
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
var
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
172
|
+
var MenuItemRoot = /*#__PURE__*/_styled("li", process.env.NODE_ENV === "production" ? {
|
|
173
|
+
target: "eil6qy20"
|
|
174
|
+
} : {
|
|
175
|
+
target: "eil6qy20",
|
|
176
|
+
label: "MenuItemRoot"
|
|
177
|
+
})("display:grid;grid-auto-flow:column;gap:8px;", function (_ref9) {
|
|
178
|
+
var isDisabled = _ref9.isDisabled;
|
|
179
|
+
return isDisabled && "color: ".concat(getColor('disabledContent'));
|
|
180
|
+
}, ";", function (_ref10) {
|
|
181
|
+
var isDisabled = _ref10.isDisabled;
|
|
182
|
+
return !isDisabled && "cursor: pointer;";
|
|
183
|
+
}, ";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) {
|
|
184
|
+
var color = _ref11.color;
|
|
185
|
+
return color;
|
|
186
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAgL8B","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, 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    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: ${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"]} */"));
|
|
187
|
+
|
|
188
|
+
export var MenuGroupTitle = function MenuGroupTitle(_ref12) {
|
|
189
|
+
var children = _ref12.children,
|
|
190
|
+
hasDivider = _ref12.hasDivider;
|
|
191
|
+
return ___EmotionJSX(React.Fragment, null, hasDivider && ___EmotionJSX(Box, {
|
|
192
|
+
height: "3px",
|
|
193
|
+
borderSide: hasDivider ? 'top' : undefined,
|
|
128
194
|
marginTop: cardPaddingPx,
|
|
129
|
-
paddingTop:
|
|
130
|
-
|
|
195
|
+
paddingTop: "".concat(cardPadding * 2, "px"),
|
|
196
|
+
marginX: "-".concat(cardPaddingPx)
|
|
197
|
+
}), ___EmotionJSX(Box, {
|
|
198
|
+
paddingX: "".concat(itemXPadding, "px"),
|
|
199
|
+
paddingBottom: cardPaddingPx,
|
|
200
|
+
paddingTop: hasDivider ? 0 : cardPaddingPx
|
|
131
201
|
}, ___EmotionJSX(Text, {
|
|
132
202
|
variant: "caps"
|
|
133
|
-
}, children));
|
|
203
|
+
}, children)));
|
|
134
204
|
};
|
|
135
|
-
|
|
136
|
-
var MenuItemDivider = function MenuItemDivider() {
|
|
205
|
+
export var MenuItemDivider = function MenuItemDivider() {
|
|
137
206
|
return ___EmotionJSX(Box, {
|
|
138
207
|
height: componentVars.dividerStrokeSize,
|
|
139
208
|
marginY: 1,
|
|
140
|
-
backgroundColor: "border"
|
|
209
|
+
backgroundColor: "border",
|
|
210
|
+
marginX: "-".concat(cardPaddingPx)
|
|
141
211
|
});
|
|
142
212
|
};
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
checkVariant = _ref6$checkVariant === void 0 ? 'check' : _ref6$checkVariant,
|
|
156
|
-
props = _objectWithoutProperties(_ref6, _excluded3);
|
|
213
|
+
export var MenuItem = /*#__PURE__*/forwardRef(function (_ref13, ref) {
|
|
214
|
+
var children = _ref13.children,
|
|
215
|
+
isSelected = _ref13.isSelected,
|
|
216
|
+
isActive = _ref13.isActive,
|
|
217
|
+
isDisabled = _ref13.isDisabled,
|
|
218
|
+
icon = _ref13.icon,
|
|
219
|
+
_ref13$variant = _ref13.variant,
|
|
220
|
+
variant = _ref13$variant === void 0 ? 'neutral' : _ref13$variant,
|
|
221
|
+
hasEllipsis = _ref13.hasEllipsis,
|
|
222
|
+
_ref13$checkVariant = _ref13.checkVariant,
|
|
223
|
+
checkVariant = _ref13$checkVariant === void 0 ? 'check' : _ref13$checkVariant,
|
|
224
|
+
props = _objectWithoutProperties(_ref13, _excluded3);
|
|
157
225
|
|
|
158
226
|
var hasCheck = checkVariant === 'check';
|
|
159
227
|
var hasCheckbox = checkVariant === 'checkbox';
|
|
@@ -163,7 +231,7 @@ export var MenuItem = /*#__PURE__*/forwardRef(function (_ref6, ref) {
|
|
|
163
231
|
if (hasCheck) return '1fr auto';
|
|
164
232
|
};
|
|
165
233
|
|
|
166
|
-
return ___EmotionJSX(
|
|
234
|
+
return ___EmotionJSX(MenuItemRoot, _extends({
|
|
167
235
|
ref: ref,
|
|
168
236
|
isSelected: isSelected,
|
|
169
237
|
isDisabled: isDisabled,
|
|
@@ -191,7 +259,7 @@ export var MenuItem = /*#__PURE__*/forwardRef(function (_ref6, ref) {
|
|
|
191
259
|
}, ___EmotionJSX(Icon, {
|
|
192
260
|
icon: ___EmotionJSX(IconCheck, null),
|
|
193
261
|
color: isActive ? 'content' : 'icon'
|
|
194
|
-
})))
|
|
262
|
+
})));
|
|
195
263
|
});
|
|
196
264
|
MenuItem.propTypes = {
|
|
197
265
|
isSelected: PropTypes.bool,
|
|
@@ -199,7 +267,17 @@ MenuItem.propTypes = {
|
|
|
199
267
|
isDisabled: PropTypes.bool,
|
|
200
268
|
icon: PropTypes.node,
|
|
201
269
|
variant: PropTypes.oneOf(['neutral', 'danger']),
|
|
202
|
-
hasDivider: PropTypes.bool,
|
|
203
270
|
hasEllipsis: PropTypes.bool,
|
|
204
271
|
checkVariant: PropTypes.oneOf(['check', 'checkbox', 'none'])
|
|
272
|
+
};
|
|
273
|
+
MenuCard.propTypes = {
|
|
274
|
+
children: PropTypes.node,
|
|
275
|
+
zIndex: types.zIndex,
|
|
276
|
+
maxHeight: types.dimension,
|
|
277
|
+
maxWidth: types.dimension,
|
|
278
|
+
isDisabled: PropTypes.bool
|
|
279
|
+
};
|
|
280
|
+
MenuCardTransition.propTypes = {
|
|
281
|
+
children: PropTypes.node,
|
|
282
|
+
show: PropTypes.bool
|
|
205
283
|
};
|
|
@@ -1,19 +1,19 @@
|
|
|
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)");
|
|
5
5
|
export var componentVars = {
|
|
6
6
|
strokeSize: '1px',
|
|
7
7
|
dividerStrokeSize: '1px',
|
|
8
|
-
activeBorderColor: getColor('
|
|
8
|
+
activeBorderColor: getColor('shade9'),
|
|
9
9
|
textBoxHeight: '40px',
|
|
10
10
|
clearButtonHeight: '36px',
|
|
11
11
|
clearButtonDangerBackgroundHover: 'hsl(var(--redHS) var(--redL) / 12%)',
|
|
12
|
-
clearButtonDangerBackgroundActive: 'hsl(var(--redHS) var(--redL) /
|
|
12
|
+
clearButtonDangerBackgroundActive: 'hsl(var(--redHS) var(--redL) / 19%)',
|
|
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
|
|
@@ -27,7 +27,7 @@ var variantStyles = {
|
|
|
27
27
|
iconColor: getColor('content')
|
|
28
28
|
},
|
|
29
29
|
active: {
|
|
30
|
-
|
|
30
|
+
backgroundColor: getColor('fade2')
|
|
31
31
|
}
|
|
32
32
|
},
|
|
33
33
|
danger: {
|
|
@@ -38,7 +38,7 @@ var variantStyles = {
|
|
|
38
38
|
iconColor: getColor('danger')
|
|
39
39
|
},
|
|
40
40
|
active: {
|
|
41
|
-
|
|
41
|
+
backgroundColor: componentVars.clearButtonDangerBackgroundActive
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
};
|
|
@@ -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 background-color: ").concat(variant && variantStyles[variant].active.backgroundColor, ";\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 ").concat(isDisabled && "color: ".concat(getColor('disabledIcon')), ";\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/hooks/index.js
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
|
+
import "core-js/modules/es.object.to-string.js";
|
|
1
2
|
import { useEffect } from 'react';
|
|
2
|
-
export function useOnClickOutside(
|
|
3
|
+
export function useOnClickOutside(refs, handler) {
|
|
3
4
|
useEffect(function () {
|
|
4
5
|
var listener = function listener(event) {
|
|
5
|
-
if (
|
|
6
|
-
return;
|
|
6
|
+
if (refs.every(function (ref) {
|
|
7
|
+
return ref.current && !ref.current.contains(event.target);
|
|
8
|
+
})) {
|
|
9
|
+
handler(event);
|
|
7
10
|
}
|
|
8
|
-
|
|
9
|
-
handler(event);
|
|
10
11
|
};
|
|
11
12
|
|
|
12
13
|
document.addEventListener('mousedown', listener);
|
|
@@ -15,5 +16,5 @@ export function useOnClickOutside(ref, handler) {
|
|
|
15
16
|
document.removeEventListener('mousedown', listener);
|
|
16
17
|
document.removeEventListener('touchstart', listener);
|
|
17
18
|
};
|
|
18
|
-
}, [
|
|
19
|
+
}, [refs, handler]);
|
|
19
20
|
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import "core-js/modules/es.object.assign.js";
|
|
2
|
+
|
|
3
|
+
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); }
|
|
4
|
+
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
7
|
+
|
|
8
|
+
var IconArchive = function IconArchive(props) {
|
|
9
|
+
return ___EmotionJSX("svg", _extends({
|
|
10
|
+
viewBox: "0 0 24 24",
|
|
11
|
+
fill: "none",
|
|
12
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
13
|
+
}, props), ___EmotionJSX("path", {
|
|
14
|
+
fillRule: "evenodd",
|
|
15
|
+
clipRule: "evenodd",
|
|
16
|
+
d: "M0 4a2 2 0 012-2h20a2 2 0 012 2v3a2 2 0 01-2 2v11a2 2 0 01-2 2H4a2 2 0 01-2-2V9a2 2 0 01-2-2V4zm22 3H2V4h20v3zm-2 2H4v11h16V9zm-3 2H7v2h10v-2z",
|
|
17
|
+
fill: "currentColor"
|
|
18
|
+
}));
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export default IconArchive;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import "core-js/modules/es.object.assign.js";
|
|
2
|
+
|
|
3
|
+
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); }
|
|
4
|
+
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
7
|
+
|
|
8
|
+
var IconAt = function IconAt(props) {
|
|
9
|
+
return ___EmotionJSX("svg", _extends({
|
|
10
|
+
viewBox: "0 0 24 24",
|
|
11
|
+
fill: "none",
|
|
12
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
13
|
+
}, props), ___EmotionJSX("path", {
|
|
14
|
+
fillRule: "evenodd",
|
|
15
|
+
clipRule: "evenodd",
|
|
16
|
+
d: "M2 12C2 6.477 6.477 2 12 2s10 4.477 10 10c0 1.689-.34 2.762-.868 3.384-.494.582-1.33 1.125-3.126 1.126-.78-.028-.89-.348-.89-1.126l.072-5.88c-.096-2.904-1.872-4.296-4.968-4.296-3.144 0-5.28 1.584-5.304 4.128l2.064.072c.144-1.512 1.128-2.472 3.168-2.472 1.92 0 3.072.888 3.072 2.832v.432l-2.52.36c-3.6.624-6.216 1.104-6.216 4.032 0 2.16 1.824 3.576 4.32 3.576 2.016 0 3.552-.864 4.2-1.92h.216c.096 1.272 1.274 1.9 2.786 1.9 1.853 0 3.527-.445 4.655-1.773C23.664 15.193 24 13.81 24 12c0-6.627-5.373-12-12-12S0 5.373 0 12s5.373 12 12 12c2.413 0 4.663-.713 6.546-1.941l-1.092-1.676A9.948 9.948 0 0112 22C6.477 22 2 17.523 2 12zm13.196.936v.336c-.12 2.16-1.8 3.216-3.96 3.216-1.488 0-2.52-.72-2.52-1.992 0-1.608 1.68-1.968 3.84-2.304l1.392-.216a13.38 13.38 0 001.416-.312l.024.024c-.096.264-.192.744-.192 1.248z",
|
|
17
|
+
fill: "currentColor"
|
|
18
|
+
}));
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export default IconAt;
|