@flodesk/grain 7.6.1 → 7.7.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.
@@ -96,7 +96,9 @@ export var Autocomplete = function Autocomplete(_ref2) {
96
96
  label = _ref2.label,
97
97
  hint = _ref2.hint,
98
98
  _ref2$menuItemsHaveEl = _ref2.menuItemsHaveEllipsis,
99
- menuItemsHaveEllipsis = _ref2$menuItemsHaveEl === void 0 ? true : _ref2$menuItemsHaveEl;
99
+ menuItemsHaveEllipsis = _ref2$menuItemsHaveEl === void 0 ? true : _ref2$menuItemsHaveEl,
100
+ _ref2$hasPortal = _ref2.hasPortal,
101
+ hasPortal = _ref2$hasPortal === void 0 ? true : _ref2$hasPortal;
100
102
 
101
103
  var _useState = useState(''),
102
104
  _useState2 = _slicedToArray(_useState, 2),
@@ -125,6 +127,7 @@ export var Autocomplete = function Autocomplete(_ref2) {
125
127
  floating = _useMenuPosition.floating,
126
128
  floatingStyles = _useMenuPosition.floatingStyles;
127
129
 
130
+ var OptionsRoot = hasPortal ? FloatingPortal : Fragment;
128
131
  return ___EmotionJSX(Combobox, {
129
132
  as: "div",
130
133
  value: selectedOption || '',
@@ -150,7 +153,7 @@ export var Autocomplete = function Autocomplete(_ref2) {
150
153
  return option && option.content;
151
154
  },
152
155
  paddingRight: "32px"
153
- }), ___EmotionJSX(ExpandIcon, null)), ___EmotionJSX(FloatingPortal, null, ___EmotionJSX(Combobox.Options, {
156
+ }), ___EmotionJSX(ExpandIcon, null)), ___EmotionJSX(OptionsRoot, null, ___EmotionJSX(Combobox.Options, {
154
157
  static: true,
155
158
  isOpen: open,
156
159
  className: "grn-context",
@@ -194,5 +197,6 @@ Autocomplete.propTypes = {
194
197
  menuZIndex: types.zIndex,
195
198
  label: types.label,
196
199
  hint: types.hint,
197
- menuItemsHaveEllipsis: PropTypes.bool
200
+ menuItemsHaveEllipsis: PropTypes.bool,
201
+ hasPortal: PropTypes.bool
198
202
  };
@@ -14,7 +14,9 @@ export var Dropdown = function Dropdown(_ref) {
14
14
  _ref$menuWidth = _ref.menuWidth,
15
15
  menuWidth = _ref$menuWidth === void 0 ? '192px' : _ref$menuWidth,
16
16
  menuZIndex = _ref.menuZIndex,
17
- trigger = _ref.trigger;
17
+ trigger = _ref.trigger,
18
+ _ref$hasPortal = _ref.hasPortal,
19
+ hasPortal = _ref$hasPortal === void 0 ? true : _ref$hasPortal;
18
20
 
19
21
  var _useMenuPosition = useMenuPosition({
20
22
  menuWidth: menuWidth,
@@ -24,12 +26,13 @@ export var Dropdown = function Dropdown(_ref) {
24
26
  floating = _useMenuPosition.floating,
25
27
  floatingStyles = _useMenuPosition.floatingStyles;
26
28
 
29
+ var ItemsRoot = hasPortal ? FloatingPortal : Fragment;
27
30
  return ___EmotionJSX(Menu, null, function (_ref2) {
28
31
  var open = _ref2.open;
29
32
  return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Menu.Button, {
30
33
  as: Fragment,
31
34
  ref: reference
32
- }, trigger), ___EmotionJSX(FloatingPortal, null, ___EmotionJSX(Menu.Items, {
35
+ }, trigger), ___EmotionJSX(ItemsRoot, null, ___EmotionJSX(Menu.Items, {
33
36
  static: true,
34
37
  isOpen: open,
35
38
  className: "grn-context",
@@ -60,5 +63,6 @@ Dropdown.propTypes = {
60
63
  options: PropTypes.array.isRequired,
61
64
  menuPlacement: types.menuPlacement,
62
65
  menuWidth: types.dimension,
63
- menuZIndex: types.zIndex
66
+ menuZIndex: types.zIndex,
67
+ hasPortal: PropTypes.bool
64
68
  };
@@ -3,7 +3,7 @@ import "core-js/modules/es.array.index-of.js";
3
3
  import "core-js/modules/es.symbol.js";
4
4
  import "core-js/modules/es.object.assign.js";
5
5
  import _styled from "@emotion/styled/base";
6
- var _excluded = ["children", "padding", "placement", "width", "trigger", "isOpen", "onClose", "zIndex"];
6
+ var _excluded = ["children", "padding", "placement", "width", "trigger", "isOpen", "onClose", "zIndex", "hasPortal"];
7
7
 
8
8
  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
9
 
@@ -11,7 +11,7 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
11
11
 
12
12
  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
13
 
14
- import React, { useRef, useEffect, cloneElement } from 'react';
14
+ import React, { useRef, useEffect, cloneElement, Fragment } from 'react';
15
15
  import PropTypes from 'prop-types';
16
16
  import { types } from '../types';
17
17
  import { placementsMap } from '../foundational';
@@ -37,7 +37,7 @@ var ChildrenWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
37
37
  }, ";transition-property:opacity;", function (_ref4) {
38
38
  var isOpen = _ref4.isOpen;
39
39
  return isOpen ? "transition-duration: ".concat(getTransition('xxFast')) : "transition-duration: ".concat(getTransition('xFast'), "; opacity: 0; pointer-events: none;");
40
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3BvcG92ZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdCa0MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcG9wb3Zlci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlUmVmLCB1c2VFZmZlY3QsIGNsb25lRWxlbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IHBsYWNlbWVudHNNYXAgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgdXNlS2V5UHJlc3MsIHVzZU9uQ2xpY2tPdXRzaWRlIH0gZnJvbSAnLi4vaG9va3MnO1xuaW1wb3J0IHtcbiAgZ2V0Q29sb3IsXG4gIGdldERpbWVuc2lvbixcbiAgZ2V0UmFkaXVzLFxuICBnZXRTaGFkb3csXG4gIGdldFNwYWNlLFxuICBnZXRUcmFuc2l0aW9uLFxufSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgdXNlRmxvYXRpbmcsXG4gIGF1dG9VcGRhdGUsXG4gIG9mZnNldCxcbiAgZmxpcCxcbiAgRmxvYXRpbmdQb3J0YWwsXG4gIHNoaWZ0LFxuICBsaW1pdFNoaWZ0LFxufSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QtZG9tLWludGVyYWN0aW9ucyc7XG5cbmNvbnN0IENoaWxkcmVuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gICR7KHsgd2lkdGggfSkgPT4gYHdpZHRoOiAke2dldERpbWVuc2lvbih3aWR0aCl9YH07XG4gICR7KHsgcGFkZGluZyB9KSA9PiBgcGFkZGluZzogJHtnZXRTcGFjZShwYWRkaW5nKX1gfTtcbiAgYm94LXNoYWRvdzogJHtnZXRTaGFkb3coJ20nKX07XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdtJyl9O1xuICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdmbG9hdGluZ0JhY2tncm91bmQnKX07XG4gICR7KHsgekluZGV4IH0pID0+IGB6LWluZGV4OiAke3pJbmRleH1gfTtcbiAgdHJhbnNpdGlvbi1wcm9wZXJ0eTogb3BhY2l0eTtcbiAgJHsoeyBpc09wZW4gfSkgPT5cbiAgICBpc09wZW5cbiAgICAgID8gYHRyYW5zaXRpb24tZHVyYXRpb246ICR7Z2V0VHJhbnNpdGlvbigneHhGYXN0Jyl9YFxuICAgICAgOiBgdHJhbnNpdGlvbi1kdXJhdGlvbjogJHtnZXRUcmFuc2l0aW9uKCd4RmFzdCcpfTsgb3BhY2l0eTogMDsgcG9pbnRlci1ldmVudHM6IG5vbmU7YH07XG5gO1xuXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9ICh7XG4gIGNoaWxkcmVuLFxuICBwYWRkaW5nID0gJ2wnLFxuICBwbGFjZW1lbnQgPSAnYm90dG9tJyxcbiAgd2lkdGggPSAnMjU2cHgnLFxuICB0cmlnZ2VyLFxuICBpc09wZW4sXG4gIG9uQ2xvc2UsXG4gIHpJbmRleCA9IDEsXG4gIC4uLnByb3BzXG59KSA9PiB7XG4gIGNvbnN0IGVzY1ByZXNzID0gdXNlS2V5UHJlc3MoJ0VzY2FwZScpO1xuICBjb25zdCB3cmFwcGVyUmVmID0gdXNlUmVmKG51bGwpO1xuICB1c2VPbkNsaWNrT3V0c2lkZSh3cmFwcGVyUmVmLCBvbkNsb3NlKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChlc2NQcmVzcykgb25DbG9zZSgpO1xuICB9LCBbZXNjUHJlc3MsIG9uQ2xvc2VdKTtcblxuICBjb25zdCB7IHgsIHksIHJlZmVyZW5jZSwgZmxvYXRpbmcsIHN0cmF0ZWd5IH0gPSB1c2VGbG9hdGluZyh7XG4gICAgcGxhY2VtZW50OiBwbGFjZW1lbnRzTWFwW3BsYWNlbWVudF0sXG4gICAgbWlkZGxld2FyZTogW29mZnNldCg0KSwgZmxpcCgpLCBzaGlmdCh7IHBhZGRpbmc6IDQsIGxpbWl0ZXI6IGxpbWl0U2hpZnQoKSB9KV0sXG4gICAgd2hpbGVFbGVtZW50c01vdW50ZWQ6IGF1dG9VcGRhdGUsXG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHtjbG9uZUVsZW1lbnQodHJpZ2dlciwgeyByZWY6IHJlZmVyZW5jZSB9KX1cbiAgICAgIDxGbG9hdGluZ1BvcnRhbD5cbiAgICAgICAgPGRpdiByZWY9e3dyYXBwZXJSZWZ9PlxuICAgICAgICAgIDxDaGlsZHJlbldyYXBwZXJcbiAgICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICAgIHBhZGRpbmc9e3BhZGRpbmd9XG4gICAgICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgICAgIGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCJcbiAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgcmVmPXtmbG9hdGluZ31cbiAgICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICAgIHBvc2l0aW9uOiBzdHJhdGVneSxcbiAgICAgICAgICAgICAgdG9wOiB5ID8/IDAsXG4gICAgICAgICAgICAgIGxlZnQ6IHggPz8gMCxcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgICAgPlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvRmxvYXRpbmdQb3J0YWw+XG4gICAgPC8+XG4gICk7XG59O1xuXG5Qb3BvdmVyLnByb3BUeXBlcyA9IHtcbiAgcGFkZGluZzogdHlwZXMuZGltZW5zaW9uLFxuICB3aWR0aDogdHlwZXMuZGltZW5zaW9uLFxuICBwbGFjZW1lbnQ6IHR5cGVzLnBsYWNlbWVudCxcbiAgdHJpZ2dlcjogUHJvcFR5cGVzLm5vZGUsXG4gIHpJbmRleDogdHlwZXMuekluZGV4LFxuICBpc09wZW46IFByb3BUeXBlcy5ib29sLFxuICBvbkNsb3NlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxufTtcbiJdfQ== */"));
40
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3BvcG92ZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdCa0MiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvcG9wb3Zlci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlUmVmLCB1c2VFZmZlY3QsIGNsb25lRWxlbWVudCwgRnJhZ21lbnQgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBwbGFjZW1lbnRzTWFwIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IHVzZUtleVByZXNzLCB1c2VPbkNsaWNrT3V0c2lkZSB9IGZyb20gJy4uL2hvb2tzJztcbmltcG9ydCB7XG4gIGdldENvbG9yLFxuICBnZXREaW1lbnNpb24sXG4gIGdldFJhZGl1cyxcbiAgZ2V0U2hhZG93LFxuICBnZXRTcGFjZSxcbiAgZ2V0VHJhbnNpdGlvbixcbn0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIHVzZUZsb2F0aW5nLFxuICBhdXRvVXBkYXRlLFxuICBvZmZzZXQsXG4gIGZsaXAsXG4gIEZsb2F0aW5nUG9ydGFsLFxuICBzaGlmdCxcbiAgbGltaXRTaGlmdCxcbn0gZnJvbSAnQGZsb2F0aW5nLXVpL3JlYWN0LWRvbS1pbnRlcmFjdGlvbnMnO1xuXG5jb25zdCBDaGlsZHJlbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICAkeyh7IHdpZHRoIH0pID0+IGB3aWR0aDogJHtnZXREaW1lbnNpb24od2lkdGgpfWB9O1xuICAkeyh7IHBhZGRpbmcgfSkgPT4gYHBhZGRpbmc6ICR7Z2V0U3BhY2UocGFkZGluZyl9YH07XG4gIGJveC1zaGFkb3c6ICR7Z2V0U2hhZG93KCdtJyl9O1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygnbScpfTtcbiAgYmFja2dyb3VuZDogJHtnZXRDb2xvcignZmxvYXRpbmdCYWNrZ3JvdW5kJyl9O1xuICAkeyh7IHpJbmRleCB9KSA9PiBgei1pbmRleDogJHt6SW5kZXh9YH07XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IG9wYWNpdHk7XG4gICR7KHsgaXNPcGVuIH0pID0+XG4gICAgaXNPcGVuXG4gICAgICA/IGB0cmFuc2l0aW9uLWR1cmF0aW9uOiAke2dldFRyYW5zaXRpb24oJ3h4RmFzdCcpfWBcbiAgICAgIDogYHRyYW5zaXRpb24tZHVyYXRpb246ICR7Z2V0VHJhbnNpdGlvbigneEZhc3QnKX07IG9wYWNpdHk6IDA7IHBvaW50ZXItZXZlbnRzOiBub25lO2B9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFBvcG92ZXIgPSAoe1xuICBjaGlsZHJlbixcbiAgcGFkZGluZyA9ICdsJyxcbiAgcGxhY2VtZW50ID0gJ2JvdHRvbScsXG4gIHdpZHRoID0gJzI1NnB4JyxcbiAgdHJpZ2dlcixcbiAgaXNPcGVuLFxuICBvbkNsb3NlLFxuICB6SW5kZXggPSAxLFxuICBoYXNQb3J0YWwgPSB0cnVlLFxuICAuLi5wcm9wc1xufSkgPT4ge1xuICBjb25zdCBlc2NQcmVzcyA9IHVzZUtleVByZXNzKCdFc2NhcGUnKTtcbiAgY29uc3Qgd3JhcHBlclJlZiA9IHVzZVJlZihudWxsKTtcbiAgdXNlT25DbGlja091dHNpZGUod3JhcHBlclJlZiwgb25DbG9zZSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoZXNjUHJlc3MpIG9uQ2xvc2UoKTtcbiAgfSwgW2VzY1ByZXNzLCBvbkNsb3NlXSk7XG5cbiAgY29uc3QgeyB4LCB5LCByZWZlcmVuY2UsIGZsb2F0aW5nLCBzdHJhdGVneSB9ID0gdXNlRmxvYXRpbmcoe1xuICAgIHBsYWNlbWVudDogcGxhY2VtZW50c01hcFtwbGFjZW1lbnRdLFxuICAgIG1pZGRsZXdhcmU6IFtvZmZzZXQoNCksIGZsaXAoKSwgc2hpZnQoeyBwYWRkaW5nOiA0LCBsaW1pdGVyOiBsaW1pdFNoaWZ0KCkgfSldLFxuICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxuICB9KTtcblxuICBjb25zdCBSb290ID0gaGFzUG9ydGFsID8gRmxvYXRpbmdQb3J0YWwgOiBGcmFnbWVudDtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7Y2xvbmVFbGVtZW50KHRyaWdnZXIsIHsgcmVmOiByZWZlcmVuY2UgfSl9XG4gICAgICA8Um9vdD5cbiAgICAgICAgPGRpdiByZWY9e3dyYXBwZXJSZWZ9PlxuICAgICAgICAgIDxDaGlsZHJlbldyYXBwZXJcbiAgICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICAgIHBhZGRpbmc9e3BhZGRpbmd9XG4gICAgICAgICAgICB6SW5kZXg9e3pJbmRleH1cbiAgICAgICAgICAgIGNsYXNzTmFtZT1cImdybi1jb250ZXh0XCJcbiAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgcmVmPXtmbG9hdGluZ31cbiAgICAgICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgICAgIHBvc2l0aW9uOiBzdHJhdGVneSxcbiAgICAgICAgICAgICAgdG9wOiB5ID8/IDAsXG4gICAgICAgICAgICAgIGxlZnQ6IHggPz8gMCxcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgICAgPlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvUm9vdD5cbiAgICA8Lz5cbiAgKTtcbn07XG5cblBvcG92ZXIucHJvcFR5cGVzID0ge1xuICBwYWRkaW5nOiB0eXBlcy5kaW1lbnNpb24sXG4gIHdpZHRoOiB0eXBlcy5kaW1lbnNpb24sXG4gIHBsYWNlbWVudDogdHlwZXMucGxhY2VtZW50LFxuICB0cmlnZ2VyOiBQcm9wVHlwZXMubm9kZSxcbiAgekluZGV4OiB0eXBlcy56SW5kZXgsXG4gIGlzT3BlbjogUHJvcFR5cGVzLmJvb2wsXG4gIG9uQ2xvc2U6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIGhhc1BvcnRhbDogUHJvcFR5cGVzLmJvb2wsXG59O1xuIl19 */"));
41
41
 
42
42
  export var Popover = function Popover(_ref5) {
43
43
  var children = _ref5.children,
@@ -52,6 +52,8 @@ export var Popover = function Popover(_ref5) {
52
52
  onClose = _ref5.onClose,
53
53
  _ref5$zIndex = _ref5.zIndex,
54
54
  zIndex = _ref5$zIndex === void 0 ? 1 : _ref5$zIndex,
55
+ _ref5$hasPortal = _ref5.hasPortal,
56
+ hasPortal = _ref5$hasPortal === void 0 ? true : _ref5$hasPortal,
55
57
  props = _objectWithoutProperties(_ref5, _excluded);
56
58
 
57
59
  var escPress = useKeyPress('Escape');
@@ -75,9 +77,10 @@ export var Popover = function Popover(_ref5) {
75
77
  floating = _useFloating.floating,
76
78
  strategy = _useFloating.strategy;
77
79
 
80
+ var Root = hasPortal ? FloatingPortal : Fragment;
78
81
  return ___EmotionJSX(React.Fragment, null, /*#__PURE__*/cloneElement(trigger, {
79
82
  ref: reference
80
- }), ___EmotionJSX(FloatingPortal, null, ___EmotionJSX("div", {
83
+ }), ___EmotionJSX(Root, null, ___EmotionJSX("div", {
81
84
  ref: wrapperRef
82
85
  }, ___EmotionJSX(ChildrenWrapper, _extends({
83
86
  width: width,
@@ -100,5 +103,6 @@ Popover.propTypes = {
100
103
  trigger: PropTypes.node,
101
104
  zIndex: types.zIndex,
102
105
  isOpen: PropTypes.bool,
103
- onClose: PropTypes.func.isRequired
106
+ onClose: PropTypes.func.isRequired,
107
+ hasPortal: PropTypes.bool
104
108
  };
@@ -5,7 +5,7 @@ import "core-js/modules/es.object.assign.js";
5
5
  import _styled from "@emotion/styled/base";
6
6
  var _excluded = ["children", "triggerVariant"],
7
7
  _excluded2 = ["option", "isSelected", "menuItemsHaveEllipsis"],
8
- _excluded3 = ["children", "floating"];
8
+ _excluded3 = ["children", "floating", "hasPortal"];
9
9
  import "core-js/modules/es.array.map.js";
10
10
  import "core-js/modules/es.object.to-string.js";
11
11
  import "core-js/modules/es.array.iterator.js";
@@ -38,7 +38,7 @@ var TriggerButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "pro
38
38
  } : {
39
39
  target: "e17qd7kh1",
40
40
  label: "TriggerButton"
41
- })(styles.buttonReset, ";", styles.transitions, ";color:inherit;display:flex;align-items:center;gap:8px;border:none;background:", getColor('fade1'), ";padding:0 ", fieldVars.xPadding, ";min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{background:", getColor('fade2'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  componentVars,\n  FieldHint,\n  FieldLabel,\n  fieldVars,\n  MenuCard,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${getColor('fade1')};\n  padding: 0 ${fieldVars.xPadding};\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    background: ${getColor('fade2')};\n  }\n`;\n\nconst Trigger = forwardRef(({ children, triggerVariant, ...props }, ref) => (\n  <>\n    {triggerVariant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {triggerVariant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected) => {\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, triggerVariant, isMultiple, selected }) => {\n  const trigger = getTriggerContent(isMultiple, selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger(selected)\n      ) : (\n        <Trigger triggerVariant={triggerVariant}>{trigger}</Trigger>\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({ option, isSelected, menuItemsHaveEllipsis, ...props }) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, ...props }) => (\n  <FloatingPortal>\n    <Listbox.Options static className=\"grn-context\" ref={floating} as={MenuCard} {...props}>\n      {children}\n    </Listbox.Options>\n  </FloatingPortal>\n);\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(\n    () => (allowMultiple ? value.map(value => optionMap.get(value)) : optionMap.get(value)),\n    [allowMultiple, optionMap, value],\n  );\n\n  return (\n    <Listbox\n      as={Root}\n      value={selected}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              triggerVariant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n            />\n\n            <SelectMenu\n              isOpen={open}\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.array]).isRequired,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n};\n"]} */"));
41
+ })(styles.buttonReset, ";", styles.transitions, ";color:inherit;display:flex;align-items:center;gap:8px;border:none;background:", getColor('fade1'), ";padding:0 ", fieldVars.xPadding, ";min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{background:", getColor('fade2'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  componentVars,\n  FieldHint,\n  FieldLabel,\n  fieldVars,\n  MenuCard,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${getColor('fade1')};\n  padding: 0 ${fieldVars.xPadding};\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    background: ${getColor('fade2')};\n  }\n`;\n\nconst Trigger = forwardRef(({ children, triggerVariant, ...props }, ref) => (\n  <>\n    {triggerVariant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {triggerVariant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected) => {\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, triggerVariant, isMultiple, selected }) => {\n  const trigger = getTriggerContent(isMultiple, selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger(selected)\n      ) : (\n        <Trigger triggerVariant={triggerVariant}>{trigger}</Trigger>\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({ option, isSelected, menuItemsHaveEllipsis, ...props }) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <Listbox.Options static className=\"grn-context\" ref={floating} as={MenuCard} {...props}>\n        {children}\n      </Listbox.Options>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(\n    () => (allowMultiple ? value.map(value => optionMap.get(value)) : optionMap.get(value)),\n    [allowMultiple, optionMap, value],\n  );\n\n  return (\n    <Listbox\n      as={Root}\n      value={selected}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              triggerVariant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n            />\n\n            <SelectMenu\n              isOpen={open}\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.array]).isRequired,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n};\n"]} */"));
42
42
 
43
43
  var Trigger = /*#__PURE__*/forwardRef(function (_ref, ref) {
44
44
  var children = _ref.children,
@@ -95,7 +95,7 @@ var Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
95
95
  } : {
96
96
  name: "wowqs1",
97
97
  styles: "min-width:0px",
98
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AA+EuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  componentVars,\n  FieldHint,\n  FieldLabel,\n  fieldVars,\n  MenuCard,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${getColor('fade1')};\n  padding: 0 ${fieldVars.xPadding};\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    background: ${getColor('fade2')};\n  }\n`;\n\nconst Trigger = forwardRef(({ children, triggerVariant, ...props }, ref) => (\n  <>\n    {triggerVariant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {triggerVariant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected) => {\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, triggerVariant, isMultiple, selected }) => {\n  const trigger = getTriggerContent(isMultiple, selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger(selected)\n      ) : (\n        <Trigger triggerVariant={triggerVariant}>{trigger}</Trigger>\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({ option, isSelected, menuItemsHaveEllipsis, ...props }) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, ...props }) => (\n  <FloatingPortal>\n    <Listbox.Options static className=\"grn-context\" ref={floating} as={MenuCard} {...props}>\n      {children}\n    </Listbox.Options>\n  </FloatingPortal>\n);\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(\n    () => (allowMultiple ? value.map(value => optionMap.get(value)) : optionMap.get(value)),\n    [allowMultiple, optionMap, value],\n  );\n\n  return (\n    <Listbox\n      as={Root}\n      value={selected}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              triggerVariant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n            />\n\n            <SelectMenu\n              isOpen={open}\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.array]).isRequired,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n};\n"]} */",
98
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AA+EuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  componentVars,\n  FieldHint,\n  FieldLabel,\n  fieldVars,\n  MenuCard,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${getColor('fade1')};\n  padding: 0 ${fieldVars.xPadding};\n  min-height: ${componentVars.textBoxHeight};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    background: ${getColor('fade2')};\n  }\n`;\n\nconst Trigger = forwardRef(({ children, triggerVariant, ...props }, ref) => (\n  <>\n    {triggerVariant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {triggerVariant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected) => {\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, triggerVariant, isMultiple, selected }) => {\n  const trigger = getTriggerContent(isMultiple, selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger(selected)\n      ) : (\n        <Trigger triggerVariant={triggerVariant}>{trigger}</Trigger>\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({ option, isSelected, menuItemsHaveEllipsis, ...props }) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <Listbox.Options static className=\"grn-context\" ref={floating} as={MenuCard} {...props}>\n        {children}\n      </Listbox.Options>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(\n    () => (allowMultiple ? value.map(value => optionMap.get(value)) : optionMap.get(value)),\n    [allowMultiple, optionMap, value],\n  );\n\n  return (\n    <Listbox\n      as={Root}\n      value={selected}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              triggerVariant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n            />\n\n            <SelectMenu\n              isOpen={open}\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.array]).isRequired,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n};\n"]} */",
99
99
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
100
100
  });
101
101
 
@@ -133,9 +133,11 @@ var SelectInfo = function SelectInfo(_ref5) {
133
133
  var SelectMenu = function SelectMenu(_ref6) {
134
134
  var children = _ref6.children,
135
135
  floating = _ref6.floating,
136
+ hasPortal = _ref6.hasPortal,
136
137
  props = _objectWithoutProperties(_ref6, _excluded3);
137
138
 
138
- return ___EmotionJSX(FloatingPortal, null, ___EmotionJSX(Listbox.Options, _extends({
139
+ var Root = hasPortal ? FloatingPortal : Fragment;
140
+ return ___EmotionJSX(Root, null, ___EmotionJSX(Listbox.Options, _extends({
139
141
  static: true,
140
142
  className: "grn-context",
141
143
  ref: floating,
@@ -170,7 +172,9 @@ export var Select = function Select(_ref7) {
170
172
  menuZIndex = _ref7.menuZIndex,
171
173
  _ref7$menuItemsHaveEl = _ref7.menuItemsHaveEllipsis,
172
174
  menuItemsHaveEllipsis = _ref7$menuItemsHaveEl === void 0 ? true : _ref7$menuItemsHaveEl,
173
- allowMultiple = _ref7.allowMultiple;
175
+ allowMultiple = _ref7.allowMultiple,
176
+ _ref7$hasPortal = _ref7.hasPortal,
177
+ hasPortal = _ref7$hasPortal === void 0 ? true : _ref7$hasPortal;
174
178
 
175
179
  var _useMenuPosition = useMenuPosition({
176
180
  menuWidth: menuWidth,
@@ -216,7 +220,8 @@ export var Select = function Select(_ref7) {
216
220
  maxHeight: menuMaxHeight,
217
221
  zIndex: menuZIndex,
218
222
  floating: floating,
219
- style: floatingStyles
223
+ style: floatingStyles,
224
+ hasPortal: hasPortal
220
225
  }, options.map(function (option, index) {
221
226
  var isSelected = getIsSelected(allowMultiple, option, selected);
222
227
  return ___EmotionJSX(SelectMenuOption, {
@@ -243,5 +248,6 @@ Select.propTypes = {
243
248
  label: types.label,
244
249
  hint: types.hint,
245
250
  menuItemsHaveEllipsis: PropTypes.bool,
246
- allowMultiple: PropTypes.bool
251
+ allowMultiple: PropTypes.bool,
252
+ hasPortal: PropTypes.bool
247
253
  };
@@ -39,7 +39,7 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy
39
39
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
40
40
 
41
41
  import { PropTypes } from 'prop-types';
42
- import React, { cloneElement, useState } from 'react';
42
+ import React, { cloneElement, useState, Fragment } from 'react';
43
43
  import { types } from '../types';
44
44
  import { useFloating, autoUpdate, offset, flip, useHover, useFocus, useDismiss, useRole, useInteractions, FloatingPortal, shift } from '@floating-ui/react-dom-interactions';
45
45
  import { getColor, getRadius, getTransition } from '../utilities';
@@ -54,13 +54,15 @@ var ContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produ
54
54
  })("background:", getColor('shade12'), ";color:", getColor('shade2'), ";padding:12px 16px;max-width:256px;width:max-content;border-radius:", getRadius('s'), ";", function (_ref) {
55
55
  var isOpen = _ref.isOpen;
56
56
  return !isOpen && "opacity: 0;";
57
- }, ";transition:opacity ", getTransition('fast'), " 0.07s;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Rvb2x0aXAuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CaUMiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdG9vbHRpcC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9wVHlwZXMgfSBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCwgeyBjbG9uZUVsZW1lbnQsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge1xuICB1c2VGbG9hdGluZyxcbiAgYXV0b1VwZGF0ZSxcbiAgb2Zmc2V0LFxuICBmbGlwLFxuICB1c2VIb3ZlcixcbiAgdXNlRm9jdXMsXG4gIHVzZURpc21pc3MsXG4gIHVzZVJvbGUsXG4gIHVzZUludGVyYWN0aW9ucyxcbiAgRmxvYXRpbmdQb3J0YWwsXG4gIHNoaWZ0LFxufSBmcm9tICdAZmxvYXRpbmctdWkvcmVhY3QtZG9tLWludGVyYWN0aW9ucyc7XG5pbXBvcnQgeyBnZXRDb2xvciwgZ2V0UmFkaXVzLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IHBsYWNlbWVudHNNYXAgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuXG5jb25zdCBDb250ZW50V3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQ6ICR7Z2V0Q29sb3IoJ3NoYWRlMTInKX07XG4gIGNvbG9yOiAke2dldENvbG9yKCdzaGFkZTInKX07XG4gIHBhZGRpbmc6IDEycHggMTZweDtcbiAgbWF4LXdpZHRoOiAyNTZweDtcbiAgd2lkdGg6IG1heC1jb250ZW50O1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcbiAgJHsoeyBpc09wZW4gfSkgPT4gIWlzT3BlbiAmJiBgb3BhY2l0eTogMDtgfTtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX0gMC4wN3M7XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2x0aXAgPSAoeyBjaGlsZHJlbiwgY29udGVudCwgcGxhY2VtZW50ID0gJ3RvcCcgfSkgPT4ge1xuICBjb25zdCBbaXNPcGVuLCBzZXRJc09wZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIGNvbnN0IHsgeCwgeSwgcmVmZXJlbmNlLCBmbG9hdGluZywgc3RyYXRlZ3ksIGNvbnRleHQgfSA9IHVzZUZsb2F0aW5nKHtcbiAgICBwbGFjZW1lbnQ6IHBsYWNlbWVudHNNYXBbcGxhY2VtZW50XSxcbiAgICBvbk9wZW5DaGFuZ2U6IHNldElzT3BlbixcbiAgICBtaWRkbGV3YXJlOiBbb2Zmc2V0KDQpLCBmbGlwKCksIHNoaWZ0KHsgcGFkZGluZzogNCB9KV0sXG4gICAgd2hpbGVFbGVtZW50c01vdW50ZWQ6IGF1dG9VcGRhdGUsXG4gIH0pO1xuXG4gIGNvbnN0IGhvdmVyID0gdXNlSG92ZXIoY29udGV4dCwge1xuICAgIG1vdmU6IGZhbHNlLFxuICB9KTtcbiAgY29uc3QgZm9jdXMgPSB1c2VGb2N1cyhjb250ZXh0KTtcbiAgY29uc3QgZGlzbWlzcyA9IHVzZURpc21pc3MoY29udGV4dCk7XG4gIGNvbnN0IHJvbGUgPSB1c2VSb2xlKGNvbnRleHQsIHsgcm9sZTogJ3Rvb2x0aXAnIH0pO1xuICBjb25zdCB7IGdldFJlZmVyZW5jZVByb3BzLCBnZXRGbG9hdGluZ1Byb3BzIH0gPSB1c2VJbnRlcmFjdGlvbnMoW2hvdmVyLCBmb2N1cywgZGlzbWlzcywgcm9sZV0pO1xuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxGbG9hdGluZ1BvcnRhbD5cbiAgICAgICAgPENvbnRlbnRXcmFwcGVyXG4gICAgICAgICAgY2xhc3NOYW1lPVwiZ3JuLWNvbnRleHRcIlxuICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgIHJlZj17ZmxvYXRpbmd9XG4gICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgIHBvc2l0aW9uOiBzdHJhdGVneSxcbiAgICAgICAgICAgIHRvcDogeSA/PyAwLFxuICAgICAgICAgICAgbGVmdDogeCA/PyAwLFxuICAgICAgICAgIH19XG4gICAgICAgICAgey4uLmdldEZsb2F0aW5nUHJvcHMoKX1cbiAgICAgICAgPlxuICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICA8L0NvbnRlbnRXcmFwcGVyPlxuICAgICAgPC9GbG9hdGluZ1BvcnRhbD5cblxuICAgICAge2Nsb25lRWxlbWVudChjaGlsZHJlbiwge1xuICAgICAgICByZWY6IHJlZmVyZW5jZSxcbiAgICAgICAgLi4uZ2V0UmVmZXJlbmNlUHJvcHMoKSxcbiAgICAgIH0pfVxuICAgIDwvPlxuICApO1xufTtcblxuVG9vbHRpcC5Db250ZW50ID0gQ29udGVudFdyYXBwZXI7XG5cblRvb2x0aXAucHJvcFR5cGVzID0ge1xuICBwbGFjZW1lbnQ6IHR5cGVzLnBsYWNlbWVudCxcbiAgY29udGVudDogUHJvcFR5cGVzLm5vZGUsXG59O1xuIl19 */"));
57
+ }, ";transition:opacity ", getTransition('fast'), " 0.07s;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3Rvb2x0aXAuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CaUMiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdG9vbHRpcC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9wVHlwZXMgfSBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCwgeyBjbG9uZUVsZW1lbnQsIHVzZVN0YXRlLCBGcmFnbWVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHtcbiAgdXNlRmxvYXRpbmcsXG4gIGF1dG9VcGRhdGUsXG4gIG9mZnNldCxcbiAgZmxpcCxcbiAgdXNlSG92ZXIsXG4gIHVzZUZvY3VzLFxuICB1c2VEaXNtaXNzLFxuICB1c2VSb2xlLFxuICB1c2VJbnRlcmFjdGlvbnMsXG4gIEZsb2F0aW5nUG9ydGFsLFxuICBzaGlmdCxcbn0gZnJvbSAnQGZsb2F0aW5nLXVpL3JlYWN0LWRvbS1pbnRlcmFjdGlvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0VHJhbnNpdGlvbiB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBwbGFjZW1lbnRzTWFwIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdzaGFkZTEyJyl9O1xuICBjb2xvcjogJHtnZXRDb2xvcignc2hhZGUyJyl9O1xuICBwYWRkaW5nOiAxMnB4IDE2cHg7XG4gIG1heC13aWR0aDogMjU2cHg7XG4gIHdpZHRoOiBtYXgtY29udGVudDtcbiAgYm9yZGVyLXJhZGl1czogJHtnZXRSYWRpdXMoJ3MnKX07XG4gICR7KHsgaXNPcGVuIH0pID0+ICFpc09wZW4gJiYgYG9wYWNpdHk6IDA7YH07XG4gIHRyYW5zaXRpb246IG9wYWNpdHkgJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9IDAuMDdzO1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gKHsgY2hpbGRyZW4sIGNvbnRlbnQsIHBsYWNlbWVudCA9ICd0b3AnLCBoYXNQb3J0YWwgPSB0cnVlIH0pID0+IHtcbiAgY29uc3QgW2lzT3Blbiwgc2V0SXNPcGVuXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICBjb25zdCB7IHgsIHksIHJlZmVyZW5jZSwgZmxvYXRpbmcsIHN0cmF0ZWd5LCBjb250ZXh0IH0gPSB1c2VGbG9hdGluZyh7XG4gICAgcGxhY2VtZW50OiBwbGFjZW1lbnRzTWFwW3BsYWNlbWVudF0sXG4gICAgb25PcGVuQ2hhbmdlOiBzZXRJc09wZW4sXG4gICAgbWlkZGxld2FyZTogW29mZnNldCg0KSwgZmxpcCgpLCBzaGlmdCh7IHBhZGRpbmc6IDQgfSldLFxuICAgIHdoaWxlRWxlbWVudHNNb3VudGVkOiBhdXRvVXBkYXRlLFxuICB9KTtcblxuICBjb25zdCBob3ZlciA9IHVzZUhvdmVyKGNvbnRleHQsIHtcbiAgICBtb3ZlOiBmYWxzZSxcbiAgfSk7XG4gIGNvbnN0IGZvY3VzID0gdXNlRm9jdXMoY29udGV4dCk7XG4gIGNvbnN0IGRpc21pc3MgPSB1c2VEaXNtaXNzKGNvbnRleHQpO1xuICBjb25zdCByb2xlID0gdXNlUm9sZShjb250ZXh0LCB7IHJvbGU6ICd0b29sdGlwJyB9KTtcbiAgY29uc3QgeyBnZXRSZWZlcmVuY2VQcm9wcywgZ2V0RmxvYXRpbmdQcm9wcyB9ID0gdXNlSW50ZXJhY3Rpb25zKFtob3ZlciwgZm9jdXMsIGRpc21pc3MsIHJvbGVdKTtcblxuICBjb25zdCBDb250ZW50Um9vdCA9IGhhc1BvcnRhbCA/IEZsb2F0aW5nUG9ydGFsIDogRnJhZ21lbnQ7XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPENvbnRlbnRSb290PlxuICAgICAgICA8Q29udGVudFdyYXBwZXJcbiAgICAgICAgICBjbGFzc05hbWU9XCJncm4tY29udGV4dFwiXG4gICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgcmVmPXtmbG9hdGluZ31cbiAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgcG9zaXRpb246IHN0cmF0ZWd5LFxuICAgICAgICAgICAgdG9wOiB5ID8/IDAsXG4gICAgICAgICAgICBsZWZ0OiB4ID8/IDAsXG4gICAgICAgICAgfX1cbiAgICAgICAgICB7Li4uZ2V0RmxvYXRpbmdQcm9wcygpfVxuICAgICAgICA+XG4gICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgIDwvQ29udGVudFdyYXBwZXI+XG4gICAgICA8L0NvbnRlbnRSb290PlxuXG4gICAgICB7Y2xvbmVFbGVtZW50KGNoaWxkcmVuLCB7XG4gICAgICAgIHJlZjogcmVmZXJlbmNlLFxuICAgICAgICAuLi5nZXRSZWZlcmVuY2VQcm9wcygpLFxuICAgICAgfSl9XG4gICAgPC8+XG4gICk7XG59O1xuXG5Ub29sdGlwLkNvbnRlbnQgPSBDb250ZW50V3JhcHBlcjtcblxuVG9vbHRpcC5wcm9wVHlwZXMgPSB7XG4gIHBsYWNlbWVudDogdHlwZXMucGxhY2VtZW50LFxuICBjb250ZW50OiBQcm9wVHlwZXMubm9kZSxcbiAgaGFzUG9ydGFsOiBQcm9wVHlwZXMuYm9vbCxcbn07XG4iXX0= */"));
58
58
 
59
59
  export var Tooltip = function Tooltip(_ref2) {
60
60
  var children = _ref2.children,
61
61
  content = _ref2.content,
62
62
  _ref2$placement = _ref2.placement,
63
- placement = _ref2$placement === void 0 ? 'top' : _ref2$placement;
63
+ placement = _ref2$placement === void 0 ? 'top' : _ref2$placement,
64
+ _ref2$hasPortal = _ref2.hasPortal,
65
+ hasPortal = _ref2$hasPortal === void 0 ? true : _ref2$hasPortal;
64
66
 
65
67
  var _useState = useState(false),
66
68
  _useState2 = _slicedToArray(_useState, 2),
@@ -95,7 +97,8 @@ export var Tooltip = function Tooltip(_ref2) {
95
97
  getReferenceProps = _useInteractions.getReferenceProps,
96
98
  getFloatingProps = _useInteractions.getFloatingProps;
97
99
 
98
- return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(FloatingPortal, null, ___EmotionJSX(ContentWrapper, _extends({
100
+ var ContentRoot = hasPortal ? FloatingPortal : Fragment;
101
+ return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(ContentRoot, null, ___EmotionJSX(ContentWrapper, _extends({
99
102
  className: "grn-context",
100
103
  isOpen: isOpen,
101
104
  ref: floating,
@@ -111,5 +114,6 @@ export var Tooltip = function Tooltip(_ref2) {
111
114
  Tooltip.Content = ContentWrapper;
112
115
  Tooltip.propTypes = {
113
116
  placement: types.placement,
114
- content: PropTypes.node
117
+ content: PropTypes.node,
118
+ hasPortal: PropTypes.bool
115
119
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "7.6.1",
3
+ "version": "7.7.0",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "author": "Flodesk",