@geist-ui/react
Version:
Modern and minimalist React UI library.
1,220 lines (1,054 loc) • 127 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var styledJsx_cjs = require('../styled-jsx.cjs.js');
var React = require('react');
var reactDom = require('react-dom');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
enumerableOnly && (symbols = symbols.filter(function (sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
})), keys.push.apply(keys, symbols);
}
return keys;
}
function _objectSpread2(target) {
for (var i = 1; i < arguments.length; i++) {
var source = null != arguments[i] ? arguments[i] : {};
i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {
_defineProperty(target, key, source[key]);
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
return target;
}
function _typeof(obj) {
"@babel/helpers - typeof";
return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
return typeof obj;
} : function (obj) {
return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
}, _typeof(obj);
}
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
function _extends() {
_extends = Object.assign || 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);
}
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;
}
function _objectWithoutProperties(source, excluded) {
if (source == null) return {};
var target = _objectWithoutPropertiesLoose(source, excluded);
var key, i;
if (Object.getOwnPropertySymbols) {
var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
for (i = 0; i < sourceSymbolKeys.length; i++) {
key = sourceSymbolKeys[i];
if (excluded.indexOf(key) >= 0) continue;
if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
target[key] = source[key];
}
}
return target;
}
function _slicedToArray(arr, i) {
return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
}
function _toConsumableArray(arr) {
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
}
function _arrayWithoutHoles(arr) {
if (Array.isArray(arr)) return _arrayLikeToArray(arr);
}
function _arrayWithHoles(arr) {
if (Array.isArray(arr)) return arr;
}
function _iterableToArray(iter) {
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
}
function _iterableToArrayLimit(arr, i) {
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
if (_i == null) return;
var _arr = [];
var _n = true;
var _d = false;
var _s, _e;
try {
for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
_arr.push(_s.value);
if (i && _arr.length === i) break;
}
} catch (err) {
_d = true;
_e = err;
} finally {
try {
if (!_n && _i["return"] != null) _i["return"]();
} finally {
if (_d) throw _e;
}
}
return _arr;
}
function _unsupportedIterableToArray(o, minLen) {
if (!o) return;
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor) n = o.constructor.name;
if (n === "Map" || n === "Set") return Array.from(o);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
}
function _arrayLikeToArray(arr, len) {
if (len == null || len > arr.length) len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
return arr2;
}
function _nonIterableSpread() {
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _createForOfIteratorHelper(o, allowArrayLike) {
var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
if (!it) {
if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
if (it) o = it;
var i = 0;
var F = function () {};
return {
s: F,
n: function () {
if (i >= o.length) return {
done: true
};
return {
done: false,
value: o[i++]
};
},
e: function (e) {
throw e;
},
f: F
};
}
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
var normalCompletion = true,
didErr = false,
err;
return {
s: function () {
it = it.call(o);
},
n: function () {
var step = it.next();
normalCompletion = step.done;
return step;
},
e: function (e) {
didErr = true;
err = e;
},
f: function () {
try {
if (!normalCompletion && it.return != null) it.return();
} finally {
if (didErr) throw err;
}
}
};
}
var defaultFont = {
sans: '"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif',
mono: 'Menlo, Monaco, Lucida Console, Liberation Mono, DejaVu Sans Mono, Bitstream Vera Sans Mono, Courier New, monospace'
};
var defaultBreakpoints = {
xs: {
min: '0',
max: '650px'
},
sm: {
min: '650px',
max: '900px'
},
md: {
min: '900px',
max: '1280px'
},
lg: {
min: '1280px',
max: '1920px'
},
xl: {
min: '1920px',
max: '10000px'
}
};
var defaultLayout = {
gap: '16pt',
gapNegative: '-16pt',
gapHalf: '8pt',
gapHalfNegative: '-8pt',
gapQuarter: '4pt',
gapQuarterNegative: '-4pt',
pageMargin: '16pt',
pageWidth: '750pt',
pageWidthWithMargin: '782pt',
breakpointMobile: defaultBreakpoints.xs.max,
breakpointTablet: defaultBreakpoints.sm.max,
radius: '5px',
unit: '16px'
};
var palette$1 = {
accents_1: '#fafafa',
accents_2: '#eaeaea',
accents_3: '#999',
accents_4: '#888',
accents_5: '#666',
accents_6: '#444',
accents_7: '#333',
accents_8: '#111',
background: '#fff',
foreground: '#000',
selection: '#79ffe1',
secondary: '#666',
code: '#f81ce5',
border: '#eaeaea',
error: '#e00',
errorLight: '#ff1a1a',
errorLighter: '#f7d4d6',
errorDark: '#c50000',
success: '#0070f3',
successLight: '#3291ff',
successLighter: '#d3e5ff',
successDark: '#0761d1',
warning: '#f5a623',
warningLight: '#f7b955',
warningLighter: '#ffefcf',
warningDark: '#ab570a',
cyan: '#50e3c2',
cyanLighter: '#aaffec',
cyanLight: '#79ffe1',
cyanDark: '#29bc9b',
violet: '#7928ca',
violetLighter: '#e3d7fc',
violetLight: '#8a63d2',
violetDark: '#4c2889',
purple: '#f81ce5',
alert: '#ff0080',
magenta: '#eb367f',
link: '#0070f3'
};
var expressiveness$1 = {
linkStyle: 'none',
linkHoverStyle: 'none',
dropdownBoxShadow: '0 4px 4px 0 rgba(0, 0, 0, 0.02)',
scrollerStart: 'rgba(255, 255, 255, 1)',
scrollerEnd: 'rgba(255, 255, 255, 0)',
shadowSmall: '0 5px 10px rgba(0, 0, 0, 0.12)',
shadowMedium: '0 8px 30px rgba(0, 0, 0, 0.12)',
shadowLarge: '0 30px 60px rgba(0, 0, 0, 0.12)',
portalOpacity: 0.25
};
var font$1 = defaultFont;
var breakpoints$1 = defaultBreakpoints;
var layout$1 = defaultLayout;
var themes$1 = {
type: 'light',
font: font$1,
layout: layout$1,
palette: palette$1,
breakpoints: breakpoints$1,
expressiveness: expressiveness$1
};
var palette = {
accents_1: '#111',
accents_2: '#333',
accents_3: '#444',
accents_4: '#666',
accents_5: '#888',
accents_6: '#999',
accents_7: '#eaeaea',
accents_8: '#fafafa',
background: '#000',
foreground: '#fff',
selection: '#f81ce5',
secondary: '#888',
code: '#79ffe1',
border: '#333',
error: '#e00',
errorLighter: '#f7d4d6',
errorLight: '#ff1a1a',
errorDark: '#c50000',
success: '#0070f3',
successLighter: '#d3e5ff',
successLight: '#3291ff',
successDark: '#0761d1',
warning: '#f5a623',
warningLighter: '#ffefcf',
warningLight: '#f7b955',
warningDark: '#ab570a',
cyan: '#50e3c2',
cyanLighter: '#aaffec',
cyanLight: '#79ffe1',
cyanDark: '#29bc9b',
violet: '#7928ca',
violetLighter: '#e3d7fc',
violetLight: '#8a63d2',
violetDark: '#4c2889',
purple: '#f81ce5',
alert: '#ff0080',
magenta: '#eb367f',
link: '#3291ff'
};
var expressiveness = {
linkStyle: 'none',
linkHoverStyle: 'none',
dropdownBoxShadow: '0 0 0 1px #333',
scrollerStart: 'rgba(255, 255, 255, 1)',
scrollerEnd: 'rgba(255, 255, 255, 0)',
shadowSmall: '0 0 0 1px #333',
shadowMedium: '0 0 0 1px #333',
shadowLarge: '0 0 0 1px #333',
portalOpacity: 0.75
};
var font = defaultFont;
var breakpoints = defaultBreakpoints;
var layout = defaultLayout;
var themes = {
type: 'dark',
font: font,
layout: layout,
palette: palette,
breakpoints: breakpoints,
expressiveness: expressiveness
};
var isObject = function isObject(target) {
return target && _typeof(target) === 'object';
};
var deepDuplicable = function deepDuplicable(source, target) {
if (!isObject(target) || !isObject(source)) return source;
var sourceKeys = Object.keys(source);
var result = {};
for (var _i = 0, _sourceKeys = sourceKeys; _i < _sourceKeys.length; _i++) {
var key = _sourceKeys[_i];
var sourceValue = source[key];
var targetValue = target[key];
if (Array.isArray(sourceValue) && Array.isArray(targetValue)) {
result[key] = targetValue.concat(sourceValue);
} else if (isObject(sourceValue) && isObject(targetValue)) {
result[key] = deepDuplicable(sourceValue, _objectSpread2({}, targetValue));
} else if (targetValue) {
result[key] = targetValue;
} else {
result[key] = sourceValue;
}
}
return result;
};
var getPresets = function getPresets() {
return [themes$1, themes];
};
var getPresetStaticTheme = function getPresetStaticTheme() {
return themes$1;
};
var isAvailableThemeType = function isAvailableThemeType(type) {
if (!type) return false;
var presetThemes = getPresets();
var hasType = presetThemes.find(function (theme) {
return theme.type === type;
});
return !hasType;
};
var isPresetTheme = function isPresetTheme(themeOrType) {
if (!themeOrType) return false;
var isType = typeof themeOrType === 'string';
var type = isType ? themeOrType : themeOrType.type;
return !isAvailableThemeType(type);
};
var hasUserCustomTheme = function hasUserCustomTheme() {
var themes = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
return !!themes.find(function (item) {
return isAvailableThemeType(item.type);
});
};
var create = function create(base, custom) {
if (!isAvailableThemeType(custom.type)) {
throw new Error('Duplicate or unavailable theme type');
}
return deepDuplicable(base, custom);
};
var createFromDark = function createFromDark(custom) {
return create(themes, custom);
};
var createFromLight = function createFromLight(custom) {
return create(themes$1, custom);
};
var Themes = {
isPresetTheme: isPresetTheme,
isAvailableThemeType: isAvailableThemeType,
hasUserCustomTheme: hasUserCustomTheme,
getPresets: getPresets,
getPresetStaticTheme: getPresetStaticTheme,
create: create,
createFromDark: createFromDark,
createFromLight: createFromLight
};
var defaultTheme = Themes.getPresetStaticTheme();
var ThemeContext = /*#__PURE__*/React__default["default"].createContext(defaultTheme);
var useTheme = function useTheme() {
return React__default["default"].useContext(ThemeContext);
};
var useCurrentState = function useCurrentState(initialState) {
var _useState = React.useState(function () {
return typeof initialState === 'function' ? initialState() : initialState;
}),
_useState2 = _slicedToArray(_useState, 2),
state = _useState2[0],
setState = _useState2[1];
var ref = React.useRef(initialState);
React.useEffect(function () {
ref.current = state;
}, [state]);
var setValue = function setValue(val) {
var result = typeof val === 'function' ? val(ref.current) : val;
ref.current = result;
setState(result);
};
return [state, setValue, ref];
};
var getId = function getId() {
return Math.random().toString(32).slice(2, 10);
};
var pickChildByProps = function pickChildByProps(children, key, value) {
var target = [];
var isArray = Array.isArray(value);
var withoutPropChildren = React__default["default"].Children.map(children, function (item) {
if (! /*#__PURE__*/React__default["default"].isValidElement(item)) return null;
if (!item.props) return item;
if (isArray) {
if (value.includes(item.props[key])) {
target.push(item);
return null;
}
return item;
}
if (item.props[key] === value) {
target.push(item);
return null;
}
return item;
});
var targetChildren = target.length >= 0 ? target : undefined;
return [withoutPropChildren, targetChildren];
};
var isBrowser = function isBrowser() {
return Boolean(typeof window !== 'undefined' && window.document && window.document.createElement);
};
var isCSSNumberValue = function isCSSNumberValue(value) {
return value !== undefined && !Number.isNaN(+value);
};
var SelectIconComponent = function SelectIconComponent() {
return /*#__PURE__*/React__default["default"].createElement("svg", {
viewBox: "0 0 24 24",
strokeWidth: "1",
strokeLinecap: "round",
strokeLinejoin: "round",
fill: "none",
shapeRendering: "geometricPrecision",
className: "jsx-2742933678"
}, /*#__PURE__*/React__default["default"].createElement("path", {
d: "M6 9l6 6 6-6",
className: "jsx-2742933678"
}), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, {
id: "2742933678"
}, "svg.jsx-2742933678{color:inherit;stroke:currentColor;-webkit-transition:all 200ms ease;transition:all 200ms ease;width:1.214em;height:1.214em;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZa0IsQUFHeUIsY0FDTSxvQkFDTSw0REFDWixjQUNDLGVBQ2pCIiwiZmlsZSI6InNlbGVjdC1pY29uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCdcblxuY29uc3QgU2VsZWN0SWNvbkNvbXBvbmVudDogUmVhY3QuRkM8dW5rbm93bj4gPSAoKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2Z1xuICAgICAgdmlld0JveD1cIjAgMCAyNCAyNFwiXG4gICAgICBzdHJva2VXaWR0aD1cIjFcIlxuICAgICAgc3Ryb2tlTGluZWNhcD1cInJvdW5kXCJcbiAgICAgIHN0cm9rZUxpbmVqb2luPVwicm91bmRcIlxuICAgICAgZmlsbD1cIm5vbmVcIlxuICAgICAgc2hhcGVSZW5kZXJpbmc9XCJnZW9tZXRyaWNQcmVjaXNpb25cIj5cbiAgICAgIDxwYXRoIGQ9XCJNNiA5bDYgNiA2LTZcIiAvPlxuICAgICAgPHN0eWxlIGpzeD57YFxuICAgICAgICBzdmcge1xuICAgICAgICAgIGNvbG9yOiBpbmhlcml0O1xuICAgICAgICAgIHN0cm9rZTogY3VycmVudENvbG9yO1xuICAgICAgICAgIHRyYW5zaXRpb246IGFsbCAyMDBtcyBlYXNlO1xuICAgICAgICAgIHdpZHRoOiAxLjIxNGVtO1xuICAgICAgICAgIGhlaWdodDogMS4yMTRlbTtcbiAgICAgICAgfVxuICAgICAgYH08L3N0eWxlPlxuICAgIDwvc3ZnPlxuICApXG59XG5cblNlbGVjdEljb25Db21wb25lbnQuZGlzcGxheU5hbWUgPSAnR2Vpc3RTZWxlY3RJY29uJ1xuY29uc3QgU2VsZWN0SWNvbiA9IFJlYWN0Lm1lbW8oU2VsZWN0SWNvbkNvbXBvbmVudClcbmV4cG9ydCBkZWZhdWx0IFNlbGVjdEljb25cbiJdfQ== */\n/*@ sourceURL=select-icon.tsx */"));
};
SelectIconComponent.displayName = 'GeistSelectIcon';
var SelectIcon = /*#__PURE__*/React__default["default"].memo(SelectIconComponent);
var defaultContext$1 = {
visible: false,
disableAll: false
};
var SelectContext = /*#__PURE__*/React__default["default"].createContext(defaultContext$1);
var useSelectContext = function useSelectContext() {
return React__default["default"].useContext(SelectContext);
};
var useSSR = function useSSR() {
var _useState = React.useState(false),
_useState2 = _slicedToArray(_useState, 2),
browser = _useState2[0],
setBrowser = _useState2[1];
React.useEffect(function () {
setBrowser(isBrowser());
}, []);
return {
isBrowser: browser,
isServer: !browser
};
};
var createElement = function createElement(id) {
var el = document.createElement('div');
el.setAttribute('id', id);
return el;
};
var usePortal = function usePortal() {
var selectId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getId();
var getContainer = arguments.length > 1 ? arguments[1] : undefined;
var id = "geist-ui-".concat(selectId);
var _useSSR = useSSR(),
isBrowser = _useSSR.isBrowser;
var _useState = React.useState(isBrowser ? createElement(id) : null),
_useState2 = _slicedToArray(_useState, 2),
elSnapshot = _useState2[0],
setElSnapshot = _useState2[1];
React.useEffect(function () {
var customContainer = getContainer ? getContainer() : null;
var parentElement = customContainer || document.body;
var hasElement = parentElement.querySelector("#".concat(id));
var el = hasElement || createElement(id);
if (!hasElement) {
parentElement.appendChild(el);
}
setElSnapshot(el);
}, []);
return elSnapshot;
};
var useResize = function useResize(callback) {
var immediatelyInvoke = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
React.useEffect(function () {
var fn = function fn() {
return callback();
};
if (immediatelyInvoke) {
fn();
}
window.addEventListener('resize', fn);
return function () {
return window.removeEventListener('resize', fn);
};
}, []);
};
var _excluded$6 = ["children", "className", "visible", "enterTime", "leaveTime", "clearTime", "name"];
var defaultProps$6 = {
visible: false,
enterTime: 60,
leaveTime: 60,
clearTime: 60,
className: '',
name: 'transition'
};
var CssTransition = function CssTransition(_ref) {
var children = _ref.children,
className = _ref.className,
visible = _ref.visible,
enterTime = _ref.enterTime,
leaveTime = _ref.leaveTime,
clearTime = _ref.clearTime,
name = _ref.name,
props = _objectWithoutProperties(_ref, _excluded$6);
var _useState = React.useState(''),
_useState2 = _slicedToArray(_useState, 2),
classes = _useState2[0],
setClasses = _useState2[1];
var _useState3 = React.useState(visible),
_useState4 = _slicedToArray(_useState3, 2),
renderable = _useState4[0],
setRenderable = _useState4[1];
React.useEffect(function () {
var statusClassName = visible ? 'enter' : 'leave';
var time = visible ? enterTime : leaveTime;
if (visible && !renderable) {
setRenderable(true);
}
setClasses("".concat(name, "-").concat(statusClassName)); // set class to active
var timer = setTimeout(function () {
setClasses("".concat(name, "-").concat(statusClassName, " ").concat(name, "-").concat(statusClassName, "-active"));
clearTimeout(timer);
}, time); // remove classess when animation over
var clearClassesTimer = setTimeout(function () {
if (!visible) {
setClasses('');
setRenderable(false);
}
clearTimeout(clearClassesTimer);
}, time + clearTime);
return function () {
clearTimeout(timer);
clearTimeout(clearClassesTimer);
};
}, [visible, renderable]);
if (! /*#__PURE__*/React__default["default"].isValidElement(children) || !renderable) return null;
return /*#__PURE__*/React__default["default"].cloneElement(children, _objectSpread2(_objectSpread2({}, props), {}, {
className: "".concat(children.props.className, " ").concat(className, " ").concat(classes)
}));
};
CssTransition.defaultProps = defaultProps$6;
CssTransition.displayName = 'GeistCssTransition';
var useClickAnyWhere = function useClickAnyWhere(handler) {
React.useEffect(function () {
var callback = function callback(event) {
return handler(event);
};
document.addEventListener('click', callback);
return function () {
return document.removeEventListener('click', callback);
};
}, [handler]);
};
var useDOMObserver = function useDOMObserver(ref) {
var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {};
var config = {
attributes: false,
childList: true,
subtree: true
};
React.useEffect(function () {
if (!ref || !ref.current) return;
var unmount = false;
var done = function done() {
if (unmount) return;
callback.apply(void 0, arguments);
};
var observer = new MutationObserver(done);
observer.observe(ref.current, config);
return function () {
unmount = true;
observer.disconnect();
};
}, [ref]);
};
var warningStack = {};
var useWarning = function useWarning(message, component) {
var tag = component ? " [".concat(component, "]") : ' ';
var log = "[Geist UI]".concat(tag, ": ").concat(message);
if (typeof console === 'undefined') return;
if (warningStack[log]) return;
warningStack[log] = true;
if (process.env.NODE_ENV !== 'production') {
return console.error(log);
}
console.warn(log);
};
var defaultRect = {
top: -1000,
left: -1000,
right: -1000,
width: 0
};
var getOffset = function getOffset(el) {
if (!el) return {
top: 0,
left: 0
};
var _el$getBoundingClient = el.getBoundingClientRect(),
top = _el$getBoundingClient.top,
left = _el$getBoundingClient.left;
return {
top: top,
left: left
};
};
var getRect = function getRect(ref, getContainer) {
if (!ref || !ref.current) return defaultRect;
var rect = ref.current.getBoundingClientRect();
var container = getContainer ? getContainer() : null;
var scrollElement = container || document.documentElement;
var _getOffset = getOffset(container),
offsetTop = _getOffset.top,
offsetLeft = _getOffset.left;
return _objectSpread2(_objectSpread2({}, rect), {}, {
width: rect.width || rect.right - rect.left,
top: rect.bottom + scrollElement.scrollTop - offsetTop,
left: rect.left + scrollElement.scrollLeft - offsetLeft
});
};
var Dropdown = /*#__PURE__*/React__default["default"].memo(function (_ref) {
var children = _ref.children,
parent = _ref.parent,
visible = _ref.visible,
disableMatchWidth = _ref.disableMatchWidth,
getPopupContainer = _ref.getPopupContainer;
var el = usePortal('dropdown', getPopupContainer);
var _useState = React.useState(defaultRect),
_useState2 = _slicedToArray(_useState, 2),
rect = _useState2[0],
setRect = _useState2[1];
if (!parent) return null;
/* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
if (getPopupContainer && getPopupContainer()) {
var _el = getPopupContainer();
var style = window.getComputedStyle(_el);
if (style.position === 'static') {
useWarning('The element specified by "getPopupContainer" must have "position" set.');
}
}
}
var updateRect = function updateRect() {
var _getRect = getRect(parent, getPopupContainer),
top = _getRect.top,
left = _getRect.left,
right = _getRect.right,
nativeWidth = _getRect.width;
setRect({
top: top,
left: left,
right: right,
width: nativeWidth
});
};
useResize(updateRect);
useClickAnyWhere(function () {
var _getRect2 = getRect(parent, getPopupContainer),
top = _getRect2.top,
left = _getRect2.left;
var shouldUpdatePosition = top !== rect.top || left !== rect.left;
if (!shouldUpdatePosition) return;
updateRect();
});
useDOMObserver(parent, function () {
updateRect();
});
React.useEffect(function () {
if (!parent || !parent.current) return;
parent.current.addEventListener('mouseenter', updateRect);
/* istanbul ignore next */
return function () {
if (!parent || !parent.current) return;
parent.current.removeEventListener('mouseenter', updateRect);
};
}, [parent]);
var clickHandler = function clickHandler(event) {
event.stopPropagation();
event.nativeEvent.stopImmediatePropagation();
event.preventDefault();
};
var mouseDownHandler = function mouseDownHandler(event) {
event.preventDefault();
};
if (!el) return null;
return /*#__PURE__*/reactDom.createPortal( /*#__PURE__*/React__default["default"].createElement(CssTransition, {
visible: visible
}, /*#__PURE__*/React__default["default"].createElement("div", {
onClick: clickHandler,
onMouseDown: mouseDownHandler,
className: styledJsx_cjs.style.dynamic([["2976859150", [rect.top + 2, rect.left, rect.width, rect.width]]]) + " " + "dropdown ".concat(disableMatchWidth ? 'disable-match' : 'width-match')
}, children, /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, {
id: "2976859150",
dynamic: [rect.top + 2, rect.left, rect.width, rect.width]
}, ".dropdown.__jsx-style-dynamic-selector{position:absolute;top:".concat(rect.top + 2, "px;left:").concat(rect.left, "px;z-index:1100;}.width-match.__jsx-style-dynamic-selector{width:").concat(rect.width, "px;}.disable-match.__jsx-style-dynamic-selector{min-width:").concat(rect.width, "px;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyb3Bkb3duLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1SHNCLEFBR2lDLEFBT21CLEFBSUksa0JBVk4sbUJBT3JDLElBSUEsWUFWc0Msb0NBQ3ZCLGFBQ2YiLCJmaWxlIjoiZHJvcGRvd24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IE11dGFibGVSZWZPYmplY3QsIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSdcbmltcG9ydCB1c2VQb3J0YWwgZnJvbSAnLi4vdXRpbHMvdXNlLXBvcnRhbCdcbmltcG9ydCB1c2VSZXNpemUgZnJvbSAnLi4vdXRpbHMvdXNlLXJlc2l6ZSdcbmltcG9ydCBDc3NUcmFuc2l0aW9uIGZyb20gJy4vY3NzLXRyYW5zaXRpb24nXG5pbXBvcnQgdXNlQ2xpY2tBbnlXaGVyZSBmcm9tICcuLi91dGlscy91c2UtY2xpY2stYW55d2hlcmUnXG5pbXBvcnQgdXNlRE9NT2JzZXJ2ZXIgZnJvbSAnLi4vdXRpbHMvdXNlLWRvbS1vYnNlcnZlcidcbmltcG9ydCB1c2VXYXJuaW5nIGZyb20gJy4uL3V0aWxzL3VzZS13YXJuaW5nJ1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBwYXJlbnQ/OiBNdXRhYmxlUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgbnVsbD4gfCB1bmRlZmluZWRcbiAgdmlzaWJsZTogYm9vbGVhblxuICBkaXNhYmxlTWF0Y2hXaWR0aD86IGJvb2xlYW5cbiAgZ2V0UG9wdXBDb250YWluZXI/OiAoKSA9PiBIVE1MRWxlbWVudCB8IG51bGxcbn1cblxuaW50ZXJmYWNlIFJlYWN0aXZlRG9tUmVhY3Qge1xuICB0b3A6IG51bWJlclxuICBsZWZ0OiBudW1iZXJcbiAgcmlnaHQ6IG51bWJlclxuICB3aWR0aDogbnVtYmVyXG59XG5cbmNvbnN0IGRlZmF1bHRSZWN0OiBSZWFjdGl2ZURvbVJlYWN0ID0ge1xuICB0b3A6IC0xMDAwLFxuICBsZWZ0OiAtMTAwMCxcbiAgcmlnaHQ6IC0xMDAwLFxuICB3aWR0aDogMCxcbn1cblxuY29uc3QgZ2V0T2Zmc2V0ID0gKGVsPzogSFRNTEVsZW1lbnQgfCBudWxsIHwgdW5kZWZpbmVkKSA9PiB7XG4gIGlmICghZWwpXG4gICAgcmV0dXJuIHtcbiAgICAgIHRvcDogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfVxuICBjb25zdCB7IHRvcCwgbGVmdCB9ID0gZWwuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgcmV0dXJuIHsgdG9wLCBsZWZ0IH1cbn1cblxuY29uc3QgZ2V0UmVjdCA9IChcbiAgcmVmOiBNdXRhYmxlUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgbnVsbD4sXG4gIGdldENvbnRhaW5lcj86ICgpID0+IEhUTUxFbGVtZW50IHwgbnVsbCxcbik6IFJlYWN0aXZlRG9tUmVhY3QgPT4ge1xuICBpZiAoIXJlZiB8fCAhcmVmLmN1cnJlbnQpIHJldHVybiBkZWZhdWx0UmVjdFxuICBjb25zdCByZWN0ID0gcmVmLmN1cnJlbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcbiAgY29uc3QgY29udGFpbmVyID0gZ2V0Q29udGFpbmVyID8gZ2V0Q29udGFpbmVyKCkgOiBudWxsXG4gIGNvbnN0IHNjcm9sbEVsZW1lbnQgPSBjb250YWluZXIgfHwgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50XG4gIGNvbnN0IHsgdG9wOiBvZmZzZXRUb3AsIGxlZnQ6IG9mZnNldExlZnQgfSA9IGdldE9mZnNldChjb250YWluZXIpXG5cbiAgcmV0dXJuIHtcbiAgICAuLi5yZWN0LFxuICAgIHdpZHRoOiByZWN0LndpZHRoIHx8IHJlY3QucmlnaHQgLSByZWN0LmxlZnQsXG4gICAgdG9wOiByZWN0LmJvdHRvbSArIHNjcm9sbEVsZW1lbnQuc2Nyb2xsVG9wIC0gb2Zmc2V0VG9wLFxuICAgIGxlZnQ6IHJlY3QubGVmdCArIHNjcm9sbEVsZW1lbnQuc2Nyb2xsTGVmdCAtIG9mZnNldExlZnQsXG4gIH1cbn1cblxuY29uc3QgRHJvcGRvd246IFJlYWN0LkZDPFJlYWN0LlByb3BzV2l0aENoaWxkcmVuPFByb3BzPj4gPSBSZWFjdC5tZW1vKFxuICAoeyBjaGlsZHJlbiwgcGFyZW50LCB2aXNpYmxlLCBkaXNhYmxlTWF0Y2hXaWR0aCwgZ2V0UG9wdXBDb250YWluZXIgfSkgPT4ge1xuICAgIGNvbnN0IGVsID0gdXNlUG9ydGFsKCdkcm9wZG93bicsIGdldFBvcHVwQ29udGFpbmVyKVxuICAgIGNvbnN0IFtyZWN0LCBzZXRSZWN0XSA9IHVzZVN0YXRlPFJlYWN0aXZlRG9tUmVhY3Q+KGRlZmF1bHRSZWN0KVxuICAgIGlmICghcGFyZW50KSByZXR1cm4gbnVsbFxuXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgaWYgKGdldFBvcHVwQ29udGFpbmVyICYmIGdldFBvcHVwQ29udGFpbmVyKCkpIHtcbiAgICAgICAgY29uc3QgZWwgPSBnZXRQb3B1cENvbnRhaW5lcigpXG4gICAgICAgIGNvbnN0IHN0eWxlID0gd2luZG93LmdldENvbXB1dGVkU3R5bGUoZWwgYXMgSFRNTERpdkVsZW1lbnQpXG4gICAgICAgIGlmIChzdHlsZS5wb3NpdGlvbiA9PT0gJ3N0YXRpYycpIHtcbiAgICAgICAgICB1c2VXYXJuaW5nKFxuICAgICAgICAgICAgJ1RoZSBlbGVtZW50IHNwZWNpZmllZCBieSBcImdldFBvcHVwQ29udGFpbmVyXCIgbXVzdCBoYXZlIFwicG9zaXRpb25cIiBzZXQuJyxcbiAgICAgICAgICApXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCB1cGRhdGVSZWN0ID0gKCkgPT4ge1xuICAgICAgY29uc3QgeyB0b3AsIGxlZnQsIHJpZ2h0LCB3aWR0aDogbmF0aXZlV2lkdGggfSA9IGdldFJlY3QocGFyZW50LCBnZXRQb3B1cENvbnRhaW5lcilcbiAgICAgIHNldFJlY3QoeyB0b3AsIGxlZnQsIHJpZ2h0LCB3aWR0aDogbmF0aXZlV2lkdGggfSlcbiAgICB9XG5cbiAgICB1c2VSZXNpemUodXBkYXRlUmVjdClcbiAgICB1c2VDbGlja0FueVdoZXJlKCgpID0+IHtcbiAgICAgIGNvbnN0IHsgdG9wLCBsZWZ0IH0gPSBnZXRSZWN0KHBhcmVudCwgZ2V0UG9wdXBDb250YWluZXIpXG4gICAgICBjb25zdCBzaG91bGRVcGRhdGVQb3NpdGlvbiA9IHRvcCAhPT0gcmVjdC50b3AgfHwgbGVmdCAhPT0gcmVjdC5sZWZ0XG4gICAgICBpZiAoIXNob3VsZFVwZGF0ZVBvc2l0aW9uKSByZXR1cm5cbiAgICAgIHVwZGF0ZVJlY3QoKVxuICAgIH0pXG4gICAgdXNlRE9NT2JzZXJ2ZXIocGFyZW50LCAoKSA9PiB7XG4gICAgICB1cGRhdGVSZWN0KClcbiAgICB9KVxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBpZiAoIXBhcmVudCB8fCAhcGFyZW50LmN1cnJlbnQpIHJldHVyblxuICAgICAgcGFyZW50LmN1cnJlbnQuYWRkRXZlbnRMaXN0ZW5lcignbW91c2VlbnRlcicsIHVwZGF0ZVJlY3QpXG4gICAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgaWYgKCFwYXJlbnQgfHwgIXBhcmVudC5jdXJyZW50KSByZXR1cm5cbiAgICAgICAgcGFyZW50LmN1cnJlbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2VlbnRlcicsIHVwZGF0ZVJlY3QpXG4gICAgICB9XG4gICAgfSwgW3BhcmVudF0pXG5cbiAgICBjb25zdCBjbGlja0hhbmRsZXIgPSAoZXZlbnQ6IFJlYWN0Lk1vdXNlRXZlbnQ8SFRNTERpdkVsZW1lbnQ+KSA9PiB7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKVxuICAgICAgZXZlbnQubmF0aXZlRXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKClcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICB9XG4gICAgY29uc3QgbW91c2VEb3duSGFuZGxlciA9IChldmVudDogUmVhY3QuTW91c2VFdmVudDxIVE1MRGl2RWxlbWVudD4pID0+IHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICB9XG5cbiAgICBpZiAoIWVsKSByZXR1cm4gbnVsbFxuICAgIHJldHVybiBjcmVhdGVQb3J0YWwoXG4gICAgICA8Q3NzVHJhbnNpdGlvbiB2aXNpYmxlPXt2aXNpYmxlfT5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNsYXNzTmFtZT17YGRyb3Bkb3duICR7ZGlzYWJsZU1hdGNoV2lkdGggPyAnZGlzYWJsZS1tYXRjaCcgOiAnd2lkdGgtbWF0Y2gnfWB9XG4gICAgICAgICAgb25DbGljaz17Y2xpY2tIYW5kbGVyfVxuICAgICAgICAgIG9uTW91c2VEb3duPXttb3VzZURvd25IYW5kbGVyfT5cbiAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPHN0eWxlIGpzeD57YFxuICAgICAgICAgICAgLmRyb3Bkb3duIHtcbiAgICAgICAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICAgICAgICB0b3A6ICR7cmVjdC50b3AgKyAyfXB4O1xuICAgICAgICAgICAgICBsZWZ0OiAke3JlY3QubGVmdH1weDtcbiAgICAgICAgICAgICAgei1pbmRleDogMTEwMDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgLndpZHRoLW1hdGNoIHtcbiAgICAgICAgICAgICAgd2lkdGg6ICR7cmVjdC53aWR0aH1weDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgLmRpc2FibGUtbWF0Y2gge1xuICAgICAgICAgICAgICBtaW4td2lkdGg6ICR7cmVjdC53aWR0aH1weDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICBgfTwvc3R5bGU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9Dc3NUcmFuc2l0aW9uPixcbiAgICAgIGVsLFxuICAgIClcbiAgfSxcbilcblxuZXhwb3J0IGRlZmF1bHQgRHJvcGRvd25cbiJdfQ== */\n/*@ sourceURL=dropdown.tsx */")))), el);
});
var defaultProps$5 = {
className: '',
dropdownStyle: {}
};
var SelectDropdown = /*#__PURE__*/React__default["default"].forwardRef(function (_ref, dropdownRef) {
var visible = _ref.visible,
children = _ref.children,
className = _ref.className,
dropdownStyle = _ref.dropdownStyle,
disableMatchWidth = _ref.disableMatchWidth,
getPopupContainer = _ref.getPopupContainer;
var theme = useTheme();
var internalDropdownRef = React.useRef(null);
var _useSelectContext = useSelectContext(),
ref = _useSelectContext.ref;
React.useImperativeHandle(dropdownRef, function () {
return internalDropdownRef.current;
});
return /*#__PURE__*/React__default["default"].createElement(Dropdown, {
parent: ref,
visible: visible,
disableMatchWidth: disableMatchWidth,
getPopupContainer: getPopupContainer
}, /*#__PURE__*/React__default["default"].createElement("div", {
ref: internalDropdownRef,
style: dropdownStyle,
className: styledJsx_cjs.style.dynamic([["2782510679", [theme.layout.radius, theme.expressiveness.shadowLarge, theme.palette.background]]]) + " " + "select-dropdown ".concat(className)
}, children, /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, {
id: "2782510679",
dynamic: [theme.layout.radius, theme.expressiveness.shadowLarge, theme.palette.background]
}, ".select-dropdown.__jsx-style-dynamic-selector{border-radius:".concat(theme.layout.radius, ";box-shadow:").concat(theme.expressiveness.shadowLarge, ";background-color:").concat(theme.palette.background, ";max-height:17em;overflow-y:auto;overflow-anchor:none;padding:0.38em 0;-webkit-scroll-behavior:smooth;-moz-scroll-behavior:smooth;-ms-scroll-behavior:smooth;scroll-behavior:smooth;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1kcm9wZG93bi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURzQixBQUcwRCwyQ0FDSCx3Q0FDTSw4Q0FDOUIsZ0JBQ0EsZ0JBQ0sscUJBQ0osaUJBQ00sNkdBQ3pCIiwiZmlsZSI6InNlbGVjdC1kcm9wZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgdXNlSW1wZXJhdGl2ZUhhbmRsZSwgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlVGhlbWUgZnJvbSAnLi4vdXNlLXRoZW1lJ1xuaW1wb3J0IHsgdXNlU2VsZWN0Q29udGV4dCB9IGZyb20gJy4vc2VsZWN0LWNvbnRleHQnXG5pbXBvcnQgRHJvcGRvd24gZnJvbSAnLi4vc2hhcmVkL2Ryb3Bkb3duJ1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICB2aXNpYmxlOiBib29sZWFuXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBkcm9wZG93blN0eWxlPzogQ1NTUHJvcGVydGllc1xuICBkaXNhYmxlTWF0Y2hXaWR0aD86IGJvb2xlYW5cbiAgZ2V0UG9wdXBDb250YWluZXI/OiAoKSA9PiBIVE1MRWxlbWVudCB8IG51bGxcbn1cblxuY29uc3QgZGVmYXVsdFByb3BzID0ge1xuICBjbGFzc05hbWU6ICcnLFxuICBkcm9wZG93blN0eWxlOiB7fSxcbn1cblxudHlwZSBOYXRpdmVBdHRycyA9IE9taXQ8UmVhY3QuSFRNTEF0dHJpYnV0ZXM8YW55Piwga2V5b2YgUHJvcHM+XG5leHBvcnQgdHlwZSBTZWxlY3REcm9wZG93blByb3BzID0gUHJvcHMgJiBOYXRpdmVBdHRyc1xuXG5jb25zdCBTZWxlY3REcm9wZG93biA9IFJlYWN0LmZvcndhcmRSZWY8XG4gIEhUTUxEaXZFbGVtZW50IHwgbnVsbCxcbiAgUmVhY3QuUHJvcHNXaXRoQ2hpbGRyZW48U2VsZWN0RHJvcGRvd25Qcm9wcz5cbj4oXG4gIChcbiAgICB7XG4gICAgICB2aXNpYmxlLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBkcm9wZG93blN0eWxlLFxuICAgICAgZGlzYWJsZU1hdGNoV2lkdGgsXG4gICAgICBnZXRQb3B1cENvbnRhaW5lcixcbiAgICB9OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxTZWxlY3REcm9wZG93blByb3BzPiAmIHR5cGVvZiBkZWZhdWx0UHJvcHMsXG4gICAgZHJvcGRvd25SZWYsXG4gICkgPT4ge1xuICAgIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICAgIGNvbnN0IGludGVybmFsRHJvcGRvd25SZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQgfCBudWxsPihudWxsKVxuICAgIGNvbnN0IHsgcmVmIH0gPSB1c2VTZWxlY3RDb250ZXh0KClcbiAgICB1c2VJbXBlcmF0aXZlSGFuZGxlPEhUTUxEaXZFbGVtZW50IHwgbnVsbCwgSFRNTERpdkVsZW1lbnQgfCBudWxsPihcbiAgICAgIGRyb3Bkb3duUmVmLFxuICAgICAgKCkgPT4gaW50ZXJuYWxEcm9wZG93blJlZi5jdXJyZW50LFxuICAgIClcblxuICAgIHJldHVybiAoXG4gICAgICA8RHJvcGRvd25cbiAgICAgICAgcGFyZW50PXtyZWZ9XG4gICAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICAgIGRpc2FibGVNYXRjaFdpZHRoPXtkaXNhYmxlTWF0Y2hXaWR0aH1cbiAgICAgICAgZ2V0UG9wdXBDb250YWluZXI9e2dldFBvcHVwQ29udGFpbmVyfT5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIHJlZj17aW50ZXJuYWxEcm9wZG93blJlZn1cbiAgICAgICAgICBjbGFzc05hbWU9e2BzZWxlY3QtZHJvcGRvd24gJHtjbGFzc05hbWV9YH1cbiAgICAgICAgICBzdHlsZT17ZHJvcGRvd25TdHlsZX0+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDxzdHlsZSBqc3g+e2BcbiAgICAgICAgICAgIC5zZWxlY3QtZHJvcGRvd24ge1xuICAgICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke3RoZW1lLmxheW91dC5yYWRpdXN9O1xuICAgICAgICAgICAgICBib3gtc2hhZG93OiAke3RoZW1lLmV4cHJlc3NpdmVuZXNzLnNoYWRvd0xhcmdlfTtcbiAgICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt0aGVtZS5wYWxldHRlLmJhY2tncm91bmR9O1xuICAgICAgICAgICAgICBtYXgtaGVpZ2h0OiAxN2VtO1xuICAgICAgICAgICAgICBvdmVyZmxvdy15OiBhdXRvO1xuICAgICAgICAgICAgICBvdmVyZmxvdy1hbmNob3I6IG5vbmU7XG4gICAgICAgICAgICAgIHBhZGRpbmc6IDAuMzhlbSAwO1xuICAgICAgICAgICAgICBzY3JvbGwtYmVoYXZpb3I6IHNtb290aDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICBgfTwvc3R5bGU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9Ecm9wZG93bj5cbiAgICApXG4gIH0sXG4pXG5cblNlbGVjdERyb3Bkb3duLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wc1xuU2VsZWN0RHJvcGRvd24uZGlzcGxheU5hbWUgPSAnR2Vpc3RTZWxlY3REcm9wZG93bidcbmV4cG9ydCBkZWZhdWx0IFNlbGVjdERyb3Bkb3duXG4iXX0= */\n/*@ sourceURL=select-dropdown.tsx */"))));
});
SelectDropdown.defaultProps = defaultProps$5;
SelectDropdown.displayName = 'GeistSelectDropdown';
var defaultDynamicLayoutPipe = function defaultDynamicLayoutPipe(scale1x) {
return "".concat(scale1x);
};
var defaultContext = {
getScaleableProps: function getScaleableProps() {
return undefined;
},
SCALES: {
pl: defaultDynamicLayoutPipe,
pr: defaultDynamicLayoutPipe,
pb: defaultDynamicLayoutPipe,
pt: defaultDynamicLayoutPipe,
px: defaultDynamicLayoutPipe,
py: defaultDynamicLayoutPipe,
mb: defaultDynamicLayoutPipe,
ml: defaultDynamicLayoutPipe,
mr: defaultDynamicLayoutPipe,
mt: defaultDynamicLayoutPipe,
mx: defaultDynamicLayoutPipe,
my: defaultDynamicLayoutPipe,
width: defaultDynamicLayoutPipe,
height: defaultDynamicLayoutPipe,
font: defaultDynamicLayoutPipe
},
unit: '16px'
};
var ScaleableContext = /*#__PURE__*/React__default["default"].createContext(defaultContext);
var useScaleable = function useScaleable() {
return React__default["default"].useContext(ScaleableContext);
};
var _excluded$5 = ["children"];
var reduceScaleCoefficient = function reduceScaleCoefficient(scale) {
if (scale === 1) return scale;
var diff = Math.abs((scale - 1) / 2);
return scale > 1 ? 1 + diff : 1 - diff;
};
var withScaleable = function withScaleable(Render) {
var ScaleableFC = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
var _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _ref10, _ref11, _ref12, _ref13, _ref14, _ref15, _ref16, _ref17, _ref18, _ref19, _ref20, _ref21, _ref22, _ref23, _ref24, _ref25, _ref26, _ref27, _ref28, _ref29, _ref30, _ref31, _ref32, _ref33;
var children = _ref.children,
props = _objectWithoutProperties(_ref, _excluded$5);
var _useTheme = useTheme(),
layout = _useTheme.layout;
var paddingLeft = props.paddingLeft,
pl = props.pl,
paddingRight = props.paddingRight,
pr = props.pr,
paddingTop = props.paddingTop,
pt = props.pt,
paddingBottom = props.paddingBottom,
pb = props.pb,
marginTop = props.marginTop,
mt = props.mt,
marginRight = props.marginRight,
mr = props.mr,
marginBottom = props.marginBottom,
mb = props.mb,
marginLeft = props.marginLeft,
ml = props.ml,
px = props.px,
py = props.py,
mx = props.mx,
my = props.my,
width = props.width,
height = props.height,
font = props.font,
w = props.w,
h = props.h,
margin = props.margin,
padding = props.padding,
_props$unit = props.unit,
unit = _props$unit === void 0 ? layout.unit : _props$unit,
_props$scale = props.scale,
scale = _props$scale === void 0 ? 1 : _props$scale;
var makeScaleHandler = function makeScaleHandler(attrValue) {
return function (scale1x, defaultValue) {
// 0 means disable scale and the default value is 0
if (scale1x === 0) {
scale1x = 1;
defaultValue = defaultValue || 0;
}
var factor = reduceScaleCoefficient(scale) * scale1x;
if (typeof attrValue === 'undefined') {
if (typeof defaultValue !== 'undefined') return "".concat(defaultValue);
return "calc(".concat(factor, " * ").concat(unit, ")");
}
if (!isCSSNumberValue(attrValue)) return "".concat(attrValue);
var customFactor = factor * Number(attrValue);
return "calc(".concat(customFactor, " * ").concat(unit, ")");
};
};
var getScaleableProps = function getScaleableProps(keyOrKeys) {
if (!Array.isArray(keyOrKeys)) return props[keyOrKeys];
var value = undefined;
var _iterator = _createForOfIteratorHelper(keyOrKeys),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var key = _step.value;
var currentValue = props[key];
if (typeof currentValue !== 'undefined') {
value = currentValue;
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
return value;
};
var value = {
unit: unit,
SCALES: {
pt: makeScaleHandler((_ref2 = (_ref3 = paddingTop !== null && paddingTop !== void 0 ? paddingTop : pt) !== null && _ref3 !== void 0 ? _ref3 : py) !== null && _ref2 !== void 0 ? _ref2 : padding),
pr: makeScaleHandler((_ref4 = (_ref5 = paddingRight !== null && paddingRight !== void 0 ? paddingRight : pr) !== null && _ref5 !== void 0 ? _ref5 : px) !== null && _ref4 !== void 0 ? _ref4 : padding),
pb: makeScaleHandler((_ref6 = (_ref7 = paddingBottom !== null && paddingBottom !== void 0 ? paddingBottom : pb) !== null && _ref7 !== void 0 ? _ref7 : py) !== null && _ref6 !== void 0 ? _ref6 : padding),
pl: makeScaleHandler((_ref8 = (_ref9 = paddingLeft !== null && paddingLeft !== void 0 ? paddingLeft : pl) !== null && _ref9 !== void 0 ? _ref9 : px) !== null && _ref8 !== void 0 ? _ref8 : padding),
px: makeScaleHandler((_ref10 = (_ref11 = (_ref12 = (_ref13 = px !== null && px !== void 0 ? px : paddingLeft) !== null && _ref13 !== void 0 ? _ref13 : paddingRight) !== null && _ref12 !== void 0 ? _ref12 : pl) !== null && _ref11 !== void 0 ? _ref11 : pr) !== null && _ref10 !== void 0 ? _ref10 : padding),
py: makeScaleHandler((_ref14 = (_ref15 = (_ref16 = (_ref17 = py !== null && py !== void 0 ? py : paddingTop) !== null && _ref17 !== void 0 ? _ref17 : paddingBottom) !== null && _ref16 !== void 0 ? _ref16 : pt) !== null && _ref15 !== void 0 ? _ref15 : pb) !== null && _ref14 !== void 0 ? _ref14 : padding),
mt: makeScaleHandler((_ref18 = (_ref19 = marginTop !== null && marginTop !== void 0 ? marginTop : mt) !== null && _ref19 !== void 0 ? _ref19 : my) !== null && _ref18 !== void 0 ? _ref18 : margin),
mr: makeScaleHandler((_ref20 = (_ref21 = marginRight !== null && marginRight !== void 0 ? marginRight : mr) !== null && _ref21 !== void 0 ? _ref21 : mx) !== null && _ref20 !== void 0 ? _ref20 : margin),
mb: makeScaleHandler((_ref22 = (_ref23 = marginBottom !== null && marginBottom !== void 0 ? marginBottom : mb) !== null && _ref23 !== void 0 ? _ref23 : my) !== null && _ref22 !== void 0 ? _ref22 : margin),
ml: makeScaleHandler((_ref24 = (_ref25 = marginLeft !== null && marginLeft !== void 0 ? marginLeft : ml) !== null && _ref25 !== void 0 ? _ref25 : mx) !== null && _ref24 !== void 0 ? _ref24 : margin),
mx: makeScaleHandler((_ref26 = (_ref27 = (_ref28 = (_ref29 = mx !== null && mx !== void 0 ? mx : marginLeft) !== null && _ref29 !== void 0 ? _ref29 : marginRight) !== null && _ref28 !== void 0 ? _ref28 : ml) !== null && _ref27 !== void 0 ? _ref27 : mr) !== null && _ref26 !== void 0 ? _ref26 : margin),
my: makeScaleHandler((_ref30 = (_ref31 = (_ref32 = (_ref33 = my !== null && my !== void 0 ? my : marginTop) !== null && _ref33 !== void 0 ? _ref33 : marginBottom) !== null && _ref32 !== void 0 ? _ref32 : mt) !== null && _ref31 !== void 0 ? _ref31 : mb) !== null && _ref30 !== void 0 ? _ref30 : margin),
width: makeScaleHandler(width !== null && width !== void 0 ? width : w),
height: makeScaleHandler(height !== null && height !== void 0 ? height : h),
font: makeScaleHandler(font)
},
getScaleableProps: getScaleableProps
};
return /*#__PURE__*/React__default["default"].createElement(ScaleableContext.Provider, {
value: value
}, /*#__PURE__*/React__default["default"].createElement(Render, _extends({}, props, {
ref: ref
}), children));
});
ScaleableFC.displayName = "Scaleable".concat(Render.displayName || 'Wrapper');
return ScaleableFC;
};
var ScaleablePropKeys = ['paddingLeft', 'pl', 'paddingRight', 'pr', 'paddingTop', 'pt', 'paddingBottom', 'pb', 'marginTop', 'mt', 'marginRight', 'mr', 'marginBottom', 'mb', 'marginLeft', 'ml', 'px', 'py', 'mx', 'my', 'width', 'height', 'font', 'unit', 'scale', 'size'];
var withPureProps = function withPureProps(props) {
if (!props) return {};
var keys = Object.keys(props).filter(function (key) {
return key !== '';
});
var nextProps = {};
var _iterator = _createForOfIteratorHelper(keys),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var key = _step.value;
if (!ScaleablePropKeys.includes(key)) {
nextProps[key] = props[key];
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
return nextProps;
};
var _excluded$4 = ["xs", "sm", "md", "lg", "xl", "justify", "direction", "alignItems", "alignContent", "children", "className"];
var defaultProps$4 = {
xs: false,
sm: false,
md: false,
lg: false,
xl: false,
className: ''
};
var getItemLayout = function getItemLayout(val) {
var display = val === 0 ? 'display: none;' : 'display: inherit;';
if (typeof val === 'number') {
var width = 100 / 24 * val;
var ratio = width > 100 ? '100%' : width < 0 ? '0' : "".concat(width, "%");
return {
grow: 0,
display: display,
width: ratio,
basis: ratio
};
}
return {
grow: 1,
display: display,
width: '100%',
basis: '0'
};
};
var GridBasicItem = function GridBasicItem(_ref) {
var xs = _ref.xs,
sm = _ref.sm,
md = _ref.md,
lg = _ref.lg,
xl = _ref.xl,
justify = _ref.justify,
direction = _ref.direction,
alignItems = _ref.alignItems,
alignContent = _ref.alignContent,
children = _ref.children,
className = _ref.className,
props = _objectWithoutProperties(_ref, _excluded$4);
var theme = useTheme();
var _useScaleable = useScaleable(),
SCALES = _useScaleable.SCALES;
var classes = React.useMemo(function () {
var aligns = {
justify: justify,
direction: direction,
alignItems: alignItems,
alignContent: alignContent,
xs: xs,
sm: sm,
md: md,
lg: lg,
xl: xl
};
var classString = Object.keys(aligns).reduce(function (pre, name) {
if (aligns[name] !== undefined && aligns[name] !== false) return "".concat(pre, " ").concat(name);
return pre;
}, '');
return classString.trim();
}, [justify, direction, alignItems, alignContent, xs, sm, md, lg, xl]);
var layout = React.useMemo(function () {
return {
xs: getItemLayout(xs),
sm: getItemLayout(sm),
md: getItemLayout(md),
lg: getItemLayout(lg),
xl: getItemLayout(xl)
};
}, [xs, sm, md, lg, xl]);
return /*#__PURE__*/React__default["default"].createElement("div", _extends({}, withPureProps(props), {
className: styledJsx_cjs.style.dynamic([["2419486498", [SCALES.font(1, 'inherit'), SCALES.height(1, 'auto'), justify, direction, alignContent, alignItems, layout.xs.grow, layout.xs.width, layout.xs.basis, layout.xs.display, theme.breakpoints.sm.min, layout.sm.grow, layout.sm.width, layout.sm.basis, layout.sm.display, theme.breakpoints.md.min, layout.md.grow, layout.md.width, layout.md.basis, layout.md.display, theme.breakpoints.lg.min, layout.lg.grow, layout.lg.width, layout.lg.basis, layout.lg.display, theme.breakpoints.xl.min, layout.xl.grow, layout.xl.width, layout.xl.basis, layout.xl.display]]]) + " " + "item ".concat(classes, " ").concat(className)
}), children, /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, {
id: "2419486498",
dynamic: [SCALES.font(1, 'inherit'), SCALES.height(1, 'auto'), justify, direction, alignContent, alignItems, layout.xs.grow, layout.xs.width, layout.xs.basis, layout.xs.display, theme.breakpoints.sm.min, layout.sm.grow, layout.sm.width, layout.sm.basis, layout.sm.display, theme.breakpoints.md.min, layout.md.grow, layout.md.width, layout.md.basis, layout.md.display, theme.breakpoints.lg.min, layout.lg.grow, layout.lg.width, layout.lg.bas