UNPKG

@geist-ui/react

Version:

Modern and minimalist React UI library.

975 lines (849 loc) 84.1 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var styledJsx_cjs = require('../styled-jsx.cjs.js'); var React = require('react'); 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 _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } 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 _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 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 isCSSNumberValue = function isCSSNumberValue(value) { return value !== undefined && !Number.isNaN(+value); }; var _excluded$4 = ["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$4); 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$3 = ["opacity"]; var defaultProps$3 = { opacity: 0.5 }; var ImageSkeleton = /*#__PURE__*/React__default["default"].memo(function (_ref) { var opacity = _ref.opacity, props = _objectWithoutProperties(_ref, _excluded$3); var theme = useTheme(); return /*#__PURE__*/React__default["default"].createElement("div", _extends({}, withPureProps(props), { className: styledJsx_cjs.style.dynamic([["2946022605", [theme.palette.accents_1, theme.palette.accents_2, theme.palette.accents_2, theme.palette.accents_1, opacity]]]) + " " + "skeleton" }), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "2946022605", dynamic: [theme.palette.accents_1, theme.palette.accents_2, theme.palette.accents_2, theme.palette.accents_1, opacity] }, ".skeleton.__jsx-style-dynamic-selector{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background-image:linear-gradient( 270deg, ".concat(theme.palette.accents_1, ", ").concat(theme.palette.accents_2, ", ").concat(theme.palette.accents_2, ", ").concat(theme.palette.accents_1, " );background-size:400% 100%;-webkit-animation:loading-__jsx-style-dynamic-selector 3s ease-in-out infinite;animation:loading-__jsx-style-dynamic-selector 3s ease-in-out infinite;opacity:").concat(opacity, ";-webkit-transition:opacity 300ms ease-out;transition:opacity 300ms ease-out;}@-webkit-keyframes loading-__jsx-style-dynamic-selector{0%{background-position:200% 0;}to{background-position:-200% 0;}}@keyframes loading-__jsx-style-dynamic-selector{0%{background-position:200% 0;}to{background-position:-200% 0;}}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImltYWdlLnNrZWxldG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQm9CLEFBRytCLEFBc0JXLEFBR0Msa0JBeEJ4QixNQUNDLEdBcUJQLENBR0EsR0F2QlEsUUFDQyxTQUNFLFdBQ0MsWUFPWCxtS0FDeUIsMEJBQ2dCLHNKQUNMLHFDQUNILDRFQUNwQyIsImZpbGUiOiJpbWFnZS5za2VsZXRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgdXNlVGhlbWUgZnJvbSAnLi4vdXNlLXRoZW1lJ1xuaW1wb3J0IHsgd2l0aFB1cmVQcm9wcyB9IGZyb20gJy4uL3VzZS1zY2FsZWFibGUnXG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIG9wYWNpdHk/OiBudW1iZXJcbn1cblxuY29uc3QgZGVmYXVsdFByb3BzID0ge1xuICBvcGFjaXR5OiAwLjUsXG59XG5cbmV4cG9ydCB0eXBlIEltYWdlU2tlbGV0b25Qcm9wcyA9IFByb3BzXG5cbmNvbnN0IEltYWdlU2tlbGV0b246IFJlYWN0LkZDPEltYWdlU2tlbGV0b25Qcm9wcz4gPSBSZWFjdC5tZW1vKFxuICAoeyBvcGFjaXR5LCAuLi5wcm9wcyB9OiBJbWFnZVNrZWxldG9uUHJvcHMgJiB0eXBlb2YgZGVmYXVsdFByb3BzKSA9PiB7XG4gICAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gICAgcmV0dXJuIChcbiAgICAgIDxkaXYgY2xhc3NOYW1lPVwic2tlbGV0b25cIiB7Li4ud2l0aFB1cmVQcm9wcyhwcm9wcyl9PlxuICAgICAgICA8c3R5bGUganN4PntgXG4gICAgICAgICAgLnNrZWxldG9uIHtcbiAgICAgICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgICAgIHRvcDogMDtcbiAgICAgICAgICAgIGxlZnQ6IDA7XG4gICAgICAgICAgICByaWdodDogMDtcbiAgICAgICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgICAgaGVpZ2h0OiAxMDAlO1xuICAgICAgICAgICAgYmFja2dyb3VuZC1pbWFnZTogbGluZWFyLWdyYWRpZW50KFxuICAgICAgICAgICAgICAyNzBkZWcsXG4gICAgICAgICAgICAgICR7dGhlbWUucGFsZXR0ZS5hY2NlbnRzXzF9LFxuICAgICAgICAgICAgICAke3RoZW1lLnBhbGV0dGUuYWNjZW50c18yfSxcbiAgICAgICAgICAgICAgJHt0aGVtZS5wYWxldHRlLmFjY2VudHNfMn0sXG4gICAgICAgICAgICAgICR7dGhlbWUucGFsZXR0ZS5hY2NlbnRzXzF9XG4gICAgICAgICAgICApO1xuICAgICAgICAgICAgYmFja2dyb3VuZC1zaXplOiA0MDAlIDEwMCU7XG4gICAgICAgICAgICBhbmltYXRpb246IGxvYWRpbmcgM3MgZWFzZS1pbi1vdXQgaW5maW5pdGU7XG4gICAgICAgICAgICBvcGFjaXR5OiAke29wYWNpdHl9O1xuICAgICAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAzMDBtcyBlYXNlLW91dDtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBAa2V5ZnJhbWVzIGxvYWRpbmcge1xuICAgICAgICAgICAgMCUge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAyMDAlIDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0byB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IC0yMDAlIDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICBgfTwvc3R5bGU+XG4gICAgICA8L2Rpdj5cbiAgICApXG4gIH0sXG4pXG5cbkltYWdlU2tlbGV0b24uZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzXG5JbWFnZVNrZWxldG9uLmRpc3BsYXlOYW1lID0gJ0dlaXN0SW1hZ2VTa2VsZXRvbidcbmV4cG9ydCBkZWZhdWx0IEltYWdlU2tlbGV0b25cbiJdfQ== */\n/*@ sourceURL=image.skeleton.tsx */"))); }); ImageSkeleton.defaultProps = defaultProps$3; ImageSkeleton.displayName = 'GeistImageSkeleton'; var _excluded$2 = ["src", "disableSkeleton", "className", "maxDelay"]; var defaultProps$2 = { disableSkeleton: false, className: '', maxDelay: 3000 }; var ImageComponent = function ImageComponent(_ref) { var src = _ref.src, disableSkeleton = _ref.disableSkeleton, className = _ref.className, maxDelay = _ref.maxDelay, props = _objectWithoutProperties(_ref, _excluded$2); var _useScaleable = useScaleable(), SCALES = _useScaleable.SCALES, getScaleableProps = _useScaleable.getScaleableProps; var width = getScaleableProps(['width', 'w']); var height = getScaleableProps(['height', 'h']); var showAnimation = !disableSkeleton && width && height; var theme = useTheme(); var _useState = React.useState(true), _useState2 = _slicedToArray(_useState, 2), loading = _useState2[0], setLoading = _useState2[1]; var _useState3 = React.useState(true), _useState4 = _slicedToArray(_useState3, 2), showSkeleton = _useState4[0], setShowSkeleton = _useState4[1]; var imageRef = React.useRef(null); var imageLoaded = function imageLoaded() { if (!showAnimation) return; setLoading(false); }; React.useEffect(function () { if (!showAnimation) return; if (!imageRef.current) return; if (imageRef.current.complete) { setLoading(false); setShowSkeleton(false); } }); React.useEffect(function () { var timer = setTimeout(function () { if (showAnimation) { setShowSkeleton(false); } clearTimeout(timer); }, maxDelay); return function () { return clearTimeout(timer); }; }, [loading]); return /*#__PURE__*/React__default["default"].createElement("div", { className: styledJsx_cjs.style.dynamic([["932238951", [theme.layout.radius, SCALES.width(1, 'auto'), SCALES.height(1, 'auto'), SCALES.mt(0), SCALES.mr(0, 'auto'), SCALES.mb(0), SCALES.ml(0, 'auto'), SCALES.pt(0), SCALES.pr(0), SCALES.pb(0), SCALES.pl(0), SCALES.width(1, 'auto'), SCALES.height(1, 'auto')]]]) + " " + "image ".concat(className) }, showSkeleton && showAnimation && /*#__PURE__*/React__default["default"].createElement(ImageSkeleton, { opacity: loading ? 0.5 : 0 }), /*#__PURE__*/React__default["default"].createElement("img", _extends({ ref: imageRef, onLoad: imageLoaded, src: src }, withPureProps(props), { className: styledJsx_cjs.style.dynamic([["932238951", [theme.layout.radius, SCALES.width(1, 'auto'), SCALES.height(1, 'auto'), SCALES.mt(0), SCALES.mr(0, 'auto'), SCALES.mb(0), SCALES.ml(0, 'auto'), SCALES.pt(0), SCALES.pr(0), SCALES.pb(0), SCALES.pl(0), SCALES.width(1, 'auto'), SCALES.height(1, 'auto')]]]) })), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "932238951", dynamic: [theme.layout.radius, SCALES.width(1, 'auto'), SCALES.height(1, 'auto'), SCALES.mt(0), SCALES.mr(0, 'auto'), SCALES.mb(0), SCALES.ml(0, 'auto'), SCALES.pt(0), SCALES.pr(0), SCALES.pb(0), SCALES.pl(0), SCALES.width(1, 'auto'), SCALES.height(1, 'auto')] }, ".image.__jsx-style-dynamic-selector{position:relative;border-radius:".concat(theme.layout.radius, ";overflow:hidden;max-width:100%;width:").concat(SCALES.width(1, 'auto'), ";height:").concat(SCALES.height(1, 'auto'), ";margin:").concat(SCALES.mt(0), " ").concat(SCALES.mr(0, 'auto'), " ").concat(SCALES.mb(0), " ").concat(SCALES.ml(0, 'auto'), ";padding:").concat(SCALES.pt(0), " ").concat(SCALES.pr(0), " ").concat(SCALES.pb(0), " ").concat(SCALES.pl(0), ";}img.__jsx-style-dynamic-selector{width:").concat(SCALES.width(1, 'auto'), ";height:").concat(SCALES.height(1, 'auto'), ";object-fit:scale-down;display:block;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRWtCLEFBRzZCLEFBWWtCLGtCQVhPLGtCQVlOLHlCQVhyQixZQVlNLElBWFAsZUFDb0IsR0FXckIsY0FDaEIsa0JBWHNDLG9DQUVOLDJIQUMrRiw2SEFDL0giLCJmaWxlIjoiaW1hZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHVzZVRoZW1lIGZyb20gJy4uL3VzZS10aGVtZSdcbmltcG9ydCBJbWFnZVNrZWxldG9uIGZyb20gJy4vaW1hZ2Uuc2tlbGV0b24nXG5pbXBvcnQgdXNlU2NhbGVhYmxlLCB7IHdpdGhQdXJlUHJvcHMsIHdpdGhTY2FsZWFibGUgfSBmcm9tICcuLi91c2Utc2NhbGVhYmxlJ1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBzcmM6IHN0cmluZ1xuICBkaXNhYmxlU2tlbGV0b24/OiBib29sZWFuXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBtYXhEZWxheT86IG51bWJlclxufVxuXG5jb25zdCBkZWZhdWx0UHJvcHMgPSB7XG4gIGRpc2FibGVTa2VsZXRvbjogZmFsc2UsXG4gIGNsYXNzTmFtZTogJycsXG4gIG1heERlbGF5OiAzMDAwLFxufVxuXG50eXBlIE5hdGl2ZUF0dHJzID0gT21pdDxSZWFjdC5JbWdIVE1MQXR0cmlidXRlczxhbnk+LCBrZXlvZiBQcm9wcz5cbmV4cG9ydCB0eXBlIEltYWdlUHJvcHMgPSBQcm9wcyAmIE5hdGl2ZUF0dHJzXG5cbmNvbnN0IEltYWdlQ29tcG9uZW50OiBSZWFjdC5GQzxJbWFnZVByb3BzPiA9ICh7XG4gIHNyYyxcbiAgZGlzYWJsZVNrZWxldG9uLFxuICBjbGFzc05hbWUsXG4gIG1heERlbGF5LFxuICAuLi5wcm9wc1xufTogSW1hZ2VQcm9wcyAmIHR5cGVvZiBkZWZhdWx0UHJvcHMpID0+IHtcbiAgY29uc3QgeyBTQ0FMRVMsIGdldFNjYWxlYWJsZVByb3BzIH0gPSB1c2VTY2FsZWFibGUoKVxuICBjb25zdCB3aWR0aCA9IGdldFNjYWxlYWJsZVByb3BzKFsnd2lkdGgnLCAndyddKVxuICBjb25zdCBoZWlnaHQgPSBnZXRTY2FsZWFibGVQcm9wcyhbJ2hlaWdodCcsICdoJ10pXG4gIGNvbnN0IHNob3dBbmltYXRpb24gPSAhZGlzYWJsZVNrZWxldG9uICYmIHdpZHRoICYmIGhlaWdodFxuXG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbbG9hZGluZywgc2V0TG9hZGluZ10gPSB1c2VTdGF0ZTxib29sZWFuPih0cnVlKVxuICBjb25zdCBbc2hvd1NrZWxldG9uLCBzZXRTaG93U2tlbGV0b25dID0gdXNlU3RhdGU8Ym9vbGVhbj4odHJ1ZSlcbiAgY29uc3QgaW1hZ2VSZWYgPSB1c2VSZWY8SFRNTEltYWdlRWxlbWVudD4obnVsbClcblxuICBjb25zdCBpbWFnZUxvYWRlZCA9ICgpID0+IHtcbiAgICBpZiAoIXNob3dBbmltYXRpb24pIHJldHVyblxuICAgIHNldExvYWRpbmcoZmFsc2UpXG4gIH1cblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghc2hvd0FuaW1hdGlvbikgcmV0dXJuXG4gICAgaWYgKCFpbWFnZVJlZi5jdXJyZW50KSByZXR1cm5cbiAgICBpZiAoaW1hZ2VSZWYuY3VycmVudC5jb21wbGV0ZSkge1xuICAgICAgc2V0TG9hZGluZyhmYWxzZSlcbiAgICAgIHNldFNob3dTa2VsZXRvbihmYWxzZSlcbiAgICB9XG4gIH0pXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCB0aW1lciA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYgKHNob3dBbmltYXRpb24pIHtcbiAgICAgICAgc2V0U2hvd1NrZWxldG9uKGZhbHNlKVxuICAgICAgfVxuICAgICAgY2xlYXJUaW1lb3V0KHRpbWVyKVxuICAgIH0sIG1heERlbGF5KVxuICAgIHJldHVybiAoKSA9PiBjbGVhclRpbWVvdXQodGltZXIpXG4gIH0sIFtsb2FkaW5nXSlcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtgaW1hZ2UgJHtjbGFzc05hbWV9YH0+XG4gICAgICB7c2hvd1NrZWxldG9uICYmIHNob3dBbmltYXRpb24gJiYgPEltYWdlU2tlbGV0b24gb3BhY2l0eT17bG9hZGluZyA/IDAuNSA6IDB9IC8+fVxuICAgICAgPGltZyByZWY9e2ltYWdlUmVmfSBvbkxvYWQ9e2ltYWdlTG9hZGVkfSBzcmM9e3NyY30gey4uLndpdGhQdXJlUHJvcHMocHJvcHMpfSAvPlxuICAgICAgPHN0eWxlIGpzeD57YFxuICAgICAgICAuaW1hZ2Uge1xuICAgICAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiAke3RoZW1lLmxheW91dC5yYWRpdXN9O1xuICAgICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICAgICAgbWF4LXdpZHRoOiAxMDAlO1xuICAgICAgICAgIHdpZHRoOiAke1NDQUxFUy53aWR0aCgxLCAnYXV0bycpfTtcbiAgICAgICAgICBoZWlnaHQ6ICR7U0NBTEVTLmhlaWdodCgxLCAnYXV0bycpfTtcbiAgICAgICAgICBtYXJnaW46ICR7U0NBTEVTLm10KDApfSAke1NDQUxFUy5tcigwLCAnYXV0bycpfSAke1NDQUxFUy5tYigwKX1cbiAgICAgICAgICAgICR7U0NBTEVTLm1sKDAsICdhdXRvJyl9O1xuICAgICAgICAgIHBhZGRpbmc6ICR7U0NBTEVTLnB0KDApfSAke1NDQUxFUy5wcigwKX0gJHtTQ0FMRVMucGIoMCl9ICR7U0NBTEVTLnBsKDApfTtcbiAgICAgICAgfVxuXG4gICAgICAgIGltZyB7XG4gICAgICAgICAgd2lkdGg6ICR7U0NBTEVTLndpZHRoKDEsICdhdXRvJyl9O1xuICAgICAgICAgIGhlaWdodDogJHtTQ0FMRVMuaGVpZ2h0KDEsICdhdXRvJyl9O1xuICAgICAgICAgIG9iamVjdC1maXQ6IHNjYWxlLWRvd247XG4gICAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICAgIH1cbiAgICAgIGB9PC9zdHlsZT5cbiAgICA8L2Rpdj5cbiAgKVxufVxuXG5JbWFnZUNvbXBvbmVudC5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHNcbkltYWdlQ29tcG9uZW50LmRpc3BsYXlOYW1lID0gJ0dlaXN0SW1hZ2UnXG5jb25zdCBJbWFnZSA9IHdpdGhTY2FsZWFibGUoSW1hZ2VDb21wb25lbnQpXG5leHBvcnQgZGVmYXVsdCBJbWFnZVxuIl19 */\n/*@ sourceURL=image.tsx */"))); }; ImageComponent.defaultProps = defaultProps$2; ImageComponent.displayName = 'GeistImage'; var Image = withScaleable(ImageComponent); 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 LinkIconComponent = function LinkIconComponent() { return /*#__PURE__*/React__default["default"].createElement("svg", { viewBox: "0 0 24 24", width: "1em", height: "1em", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round", fill: "none", shapeRendering: "geometricPrecision", className: "jsx-3000088640" + " " + "icon" }, /*#__PURE__*/React__default["default"].createElement("path", { d: "M18 13v6a2 2 0 01-2 2H5a2 2 0 01-2-2V8a2 2 0 012-2h6", className: "jsx-3000088640" }), /*#__PURE__*/React__default["default"].createElement("path", { d: "M15 3h6v6", className: "jsx-3000088640" }), /*#__PURE__*/React__default["default"].createElement("path", { d: "M10 14L21 3", className: "jsx-3000088640" }), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "3000088640" }, ".icon.jsx-3000088640{margin:0 0.3125em;display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-self:center;-ms-flex-item-align:center;align-self:center;color:currentColor;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImljb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ca0IsQUFHNkIsa0JBQ0Usc0dBQ0YsdUVBQ0MsbUJBQ3JCIiwiZmlsZSI6Imljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgY29uc3QgTGlua0ljb25Db21wb25lbnQ6IFJlYWN0LkZDPHVua25vd24+ID0gKCkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHZpZXdCb3g9XCIwIDAgMjQgMjRcIlxuICAgICAgd2lkdGg9XCIxZW1cIlxuICAgICAgaGVpZ2h0PVwiMWVtXCJcbiAgICAgIHN0cm9rZT1cImN1cnJlbnRDb2xvclwiXG4gICAgICBzdHJva2VXaWR0aD1cIjEuNVwiXG4gICAgICBzdHJva2VMaW5lY2FwPVwicm91bmRcIlxuICAgICAgc3Ryb2tlTGluZWpvaW49XCJyb3VuZFwiXG4gICAgICBmaWxsPVwibm9uZVwiXG4gICAgICBzaGFwZVJlbmRlcmluZz1cImdlb21ldHJpY1ByZWNpc2lvblwiXG4gICAgICBjbGFzc05hbWU9XCJpY29uXCI+XG4gICAgICA8cGF0aCBkPVwiTTE4IDEzdjZhMiAyIDAgMDEtMiAySDVhMiAyIDAgMDEtMi0yVjhhMiAyIDAgMDEyLTJoNlwiIC8+XG4gICAgICA8cGF0aCBkPVwiTTE1IDNoNnY2XCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNMTAgMTRMMjEgM1wiIC8+XG5cbiAgICAgIDxzdHlsZSBqc3g+e2BcbiAgICAgICAgLmljb24ge1xuICAgICAgICAgIG1hcmdpbjogMCAwLjMxMjVlbTtcbiAgICAgICAgICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgICAgICAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gICAgICAgICAgY29sb3I6IGN1cnJlbnRDb2xvcjtcbiAgICAgICAgfVxuICAgICAgYH08L3N0eWxlPlxuICAgIDwvc3ZnPlxuICApXG59XG5cbkxpbmtJY29uQ29tcG9uZW50LmRpc3BsYXlOYW1lID0gJ0dlaXN0TGlua0ljb24nXG5jb25zdCBMaW5rSWNvbiA9IFJlYWN0Lm1lbW8oTGlua0ljb25Db21wb25lbnQpXG5leHBvcnQgZGVmYXVsdCBMaW5rSWNvblxuIl19 */\n/*@ sourceURL=icon.tsx */")); }; LinkIconComponent.displayName = 'GeistLinkIcon'; var LinkIcon = /*#__PURE__*/React__default["default"].memo(LinkIconComponent); var hexToRgb = function hexToRgb(color) { var fullReg = /^#?([a-f\d])([a-f\d])([a-f\d])$/i; var full = color.replace(fullReg, function (_, r, g, b) { return "".concat(r).concat(r).concat(g).concat(g).concat(b).concat(b); }); var values = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(full); if (!values) { throw new Error("Geist UI: Unsupported ".concat(color, " color.")); } return [Number.parseInt(values[1], 16), Number.parseInt(values[2], 16), Number.parseInt(values[3], 16)]; }; var colorToRgbValues = function colorToRgbValues(color) { if (color.charAt(0) === '#') return hexToRgb(color); var safeColor = color.replace(/ /g, ''); var colorType = color.substr(0, 4); var regArray = safeColor.match(/\((.+)\)/); if (!colorType.startsWith('rgb') || !regArray) { console.log(color); throw new Error("Geist UI: Only support [\"RGB\", \"RGBA\", \"HEX\"] color."); } return regArray[1].split(',').map(function (str) { return Number.parseFloat(str); }); }; var addColorAlpha = function addColorAlpha(color, alpha) { if (!/^#|rgb|RGB/.test(color)) return color; var _colorToRgbValues = colorToRgbValues(color), _colorToRgbValues2 = _slicedToArray(_colorToRgbValues, 3), r = _colorToRgbValues2[0], g = _colorToRgbValues2[1], b = _colorToRgbValues2[2]; var safeAlpha = alpha > 1 ? 1 : alpha < 0 ? 0 : alpha; return "rgba(".concat(r, ", ").concat(g, ", ").concat(b, ", ").concat(safeAlpha, ")"); }; var _excluded$1 = ["href", "color", "underline", "pure", "children", "className", "block", "icon"]; var defaultProps$1 = { href: '', color: false, pure: false, icon: false, underline: false, block: false, className: '' }; var LinkComponent = /*#__PURE__*/React__default["default"].forwardRef(function (_ref, ref) { var href = _ref.href, color = _ref.color, underline = _ref.underline, pure = _ref.pure, children = _ref.children, className = _ref.className, block = _ref.block, icon = _ref.icon, props = _objectWithoutProperties(_ref, _excluded$1); var theme = useTheme(); var _useScaleable = useScaleable(), SCALES = _useScaleable.SCALES; var linkColor = color || block ? theme.palette.link : 'inherit'; var hoverColor = color || block ? theme.palette.successLight : 'inherit'; var decoration = underline ? 'underline' : 'none'; if (pure) { useWarning('Props "pure" is deprecated, now the default Link is pure.'); } return /*#__PURE__*/React__default["default"].createElement("a", _extends({ href: href }, withPureProps(props), { ref: ref, className: styledJsx_cjs.style.dynamic([["3960817863", [linkColor, block ? theme.layout.radius : 0, SCALES.font(1, 'inherit'), SCALES.width(1, 'fit-content'), SCALES.height(1, 'auto'), SCALES.mt(0), SCALES.mr(0), SCALES.mb(0), SCALES.ml(0), SCALES.pt(0), SCALES.pr(0), SCALES.pb(0), SCALES.pl(0), SCALES.pt(0.268), SCALES.pr(0.5625), SCALES.pb(0.268), SCALES.pl(0.5625), decoration, block ? addColorAlpha(theme.palette.link, 0.1) : 'unset', hoverColor]]]) + " " + "link ".concat(block ? 'block' : '', " ").concat(className) }), children, icon && /*#__PURE__*/React__default["default"].createElement(LinkIcon, null), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "3960817863", dynamic: [linkColor, block ? theme.layout.radius : 0, SCALES.font(1, 'inherit'), SCALES.width(1, 'fit-content'), SCALES.height(1, 'auto'), SCALES.mt(0), SCALES.mr(0), SCALES.mb(0), SCALES.ml(0), SCALES.pt(0), SCALES.pr(0), SCALES.pb(0), SCALES.pl(0), SCALES.pt(0.268), SCALES.pr(0.5625), SCALES.pb(0.268), SCALES.pl(0.5625), decoration, block ? addColorAlpha(theme.palette.link, 0.1) : 'unset', hoverColor] }, ".link.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-align-items:baseline;-webkit-box-align:baseline;-ms-flex-align:baseline;align-items:baseline;line-height:inherit;color:".concat(linkColor, ";-webkit-text-decoration:none;text-decoration:none;border-radius:").concat(block ? theme.layout.radius : 0, ";-webkit-transition:color 200ms ease 0ms;transition:color 200ms ease 0ms;font-size:").concat(SCALES.font(1, 'inherit'), ";width:").concat(SCALES.width(1, 'fit-content'), ";height:").concat(SCALES.height(1, 'auto'), ";margin:").concat(SCALES.mt(0), " ").concat(SCALES.mr(0), " ").concat(SCALES.mb(0), " ").concat(SCALES.ml(0), ";padding:").concat(SCALES.pt(0), " ").concat(SCALES.pr(0), " ").concat(SCALES.pb(0), " ").concat(SCALES.pl(0), ";}.block.__jsx-style-dynamic-selector{padding:").concat(SCALES.pt(0.268), " ").concat(SCALES.pr(0.5625), " ").concat(SCALES.pb(0.268), " ").concat(SCALES.pl(0.5625), ";}.link.__jsx-style-dynamic-selector:hover,.link.__jsx-style-dynamic-selector:active,.link.__jsx-style-dynamic-selector:focus{-webkit-text-decoration:").concat(decoration, ";text-decoration:").concat(decoration, ";}.link.__jsx-style-dynamic-selector:hover{background-color:").concat(block ? addColorAlpha(theme.palette.link, 0.1) : 'unset', ";color:").concat(hoverColor, ";}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpbmsudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlFb0IsQUFHaUMsQUFlVyxBQU1lLEFBSUMsK0NBQ1gsb0NBQ3RDLGlCQUxBLEVBckJ1QiwwQkFldkIsMkVBZHNCLG9CQUNlLG1DQUNkLGtEQUNzQiwyQ0FDWCx3RUFDTyx1Q0FDSixtQ0FDQyxvQ0FDdUYsMkhBQ0ksK0hBQ2pJIiwiZmlsZSI6ImxpbmsudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHVzZVRoZW1lIGZyb20gJy4uL3VzZS10aGVtZSdcbmltcG9ydCB1c2VXYXJuaW5nIGZyb20gJy4uL3V0aWxzL3VzZS13YXJuaW5nJ1xuaW1wb3J0IExpbmtJY29uIGZyb20gJy4vaWNvbidcbmltcG9ydCB7IGFkZENvbG9yQWxwaGEgfSBmcm9tICcuLi91dGlscy9jb2xvcidcbmltcG9ydCB1c2VTY2FsZWFibGUsIHsgd2l0aFB1cmVQcm9wcywgd2l0aFNjYWxlYWJsZSB9IGZyb20gJy4uL3VzZS1zY2FsZWFibGUnXG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvcHMge1xuICBocmVmPzogc3RyaW5nXG4gIGNvbG9yPzogYm9vbGVhblxuICBwdXJlPzogYm9vbGVhblxuICBpY29uPzogYm9vbGVhblxuICB1bmRlcmxpbmU/OiBib29sZWFuXG4gIGJsb2NrPzogYm9vbGVhblxuICBjbGFzc05hbWU/OiBzdHJpbmdcbn1cblxuY29uc3QgZGVmYXVsdFByb3BzID0ge1xuICBocmVmOiAnJyxcbiAgY29sb3I6IGZhbHNlLFxuICBwdXJlOiBmYWxzZSxcbiAgaWNvbjogZmFsc2UsXG4gIHVuZGVybGluZTogZmFsc2UsXG4gIGJsb2NrOiBmYWxzZSxcbiAgY2xhc3NOYW1lOiAnJyxcbn1cblxudHlwZSBOYXRpdmVBdHRycyA9IE9taXQ8UmVhY3QuQW5jaG9ySFRNTEF0dHJpYnV0ZXM8YW55Piwga2V5b2YgUHJvcHM+XG5leHBvcnQgdHlwZSBMaW5rUHJvcHMgPSBQcm9wcyAmIE5hdGl2ZUF0dHJzXG5cbmNvbnN0IExpbmtDb21wb25lbnQgPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MQW5jaG9yRWxlbWVudCxcbiAgUmVhY3QuUHJvcHNXaXRoQ2hpbGRyZW48TGlua1Byb3BzPlxuPihcbiAgKFxuICAgIHtcbiAgICAgIGhyZWYsXG4gICAgICBjb2xvcixcbiAgICAgIHVuZGVybGluZSxcbiAgICAgIHB1cmUsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIGJsb2NrLFxuICAgICAgaWNvbixcbiAgICAgIC4uLnByb3BzXG4gICAgfTogUmVhY3QuUHJvcHNXaXRoQ2hpbGRyZW48TGlua1Byb3BzPiAmIHR5cGVvZiBkZWZhdWx0UHJvcHMsXG4gICAgcmVmOiBSZWFjdC5SZWY8SFRNTEFuY2hvckVsZW1lbnQ+LFxuICApID0+IHtcbiAgICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKClcbiAgICBjb25zdCB7IFNDQUxFUyB9ID0gdXNlU2NhbGVhYmxlKClcbiAgICBjb25zdCBsaW5rQ29sb3IgPSBjb2xvciB8fCBibG9jayA/IHRoZW1lLnBhbGV0dGUubGluayA6ICdpbmhlcml0J1xuICAgIGNvbnN0IGhvdmVyQ29sb3IgPSBjb2xvciB8fCBibG9jayA/IHRoZW1lLnBhbGV0dGUuc3VjY2Vzc0xpZ2h0IDogJ2luaGVyaXQnXG4gICAgY29uc3QgZGVjb3JhdGlvbiA9IHVuZGVybGluZSA/ICd1bmRlcmxpbmUnIDogJ25vbmUnXG4gICAgaWYgKHB1cmUpIHtcbiAgICAgIHVzZVdhcm5pbmcoJ1Byb3BzIFwicHVyZVwiIGlzIGRlcHJlY2F0ZWQsIG5vdyB0aGUgZGVmYXVsdCBMaW5rIGlzIHB1cmUuJylcbiAgICB9XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGFcbiAgICAgICAgY2xhc3NOYW1lPXtgbGluayAke2Jsb2NrID8gJ2Jsb2NrJyA6ICcnfSAke2NsYXNzTmFtZX1gfVxuICAgICAgICBocmVmPXtocmVmfVxuICAgICAgICB7Li4ud2l0aFB1cmVQcm9wcyhwcm9wcyl9XG4gICAgICAgIHJlZj17cmVmfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aWNvbiAmJiA8TGlua0ljb24gLz59XG4gICAgICAgIDxzdHlsZSBqc3g+e2BcbiAgICAgICAgICAubGluayB7XG4gICAgICAgICAgICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgICAgICAgICAgIGxpbmUtaGVpZ2h0OiBpbmhlcml0O1xuICAgICAgICAgICAgY29sb3I6ICR7bGlua0NvbG9yfTtcbiAgICAgICAgICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7YmxvY2sgPyB0aGVtZS5sYXlvdXQucmFkaXVzIDogMH07XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBjb2xvciAyMDBtcyBlYXNlIDBtcztcbiAgICAgICAgICAgIGZvbnQtc2l6ZTogJHtTQ0FMRVMuZm9udCgxLCAnaW5oZXJpdCcpfTtcbiAgICAgICAgICAgIHdpZHRoOiAke1NDQUxFUy53aWR0aCgxLCAnZml0LWNvbnRlbnQnKX07XG4gICAgICAgICAgICBoZWlnaHQ6ICR7U0NBTEVTLmhlaWdodCgxLCAnYXV0bycpfTtcbiAgICAgICAgICAgIG1hcmdpbjogJHtTQ0FMRVMubXQoMCl9ICR7U0NBTEVTLm1yKDApfSAke1NDQUxFUy5tYigwKX0gJHtTQ0FMRVMubWwoMCl9O1xuICAgICAgICAgICAgcGFkZGluZzogJHtTQ0FMRVMucHQoMCl9ICR7U0NBTEVTLnByKDApfSAke1NDQUxFUy5wYigwKX0gJHtTQ0FMRVMucGwoMCl9O1xuICAgICAgICAgIH1cbiAgICAgICAgICAuYmxvY2sge1xuICAgICAgICAgICAgcGFkZGluZzogJHtTQ0FMRVMucHQoMC4yNjgpfSAke1NDQUxFUy5wcigwLjU2MjUpfSAke1NDQUxFUy5wYigwLjI2OCl9XG4gICAgICAgICAgICAgICR7U0NBTEVTLnBsKDAuNTYyNSl9O1xuICAgICAgICAgIH1cblxuICAgICAgICAgIC5saW5rOmhvdmVyLFxuICAgICAgICAgIC5saW5rOmFjdGl2ZSxcbiAgICAgICAgICAubGluazpmb2N1cyB7XG4gICAgICAgICAgICB0ZXh0LWRlY29yYXRpb246ICR7ZGVjb3JhdGlvbn07XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLmxpbms6aG92ZXIge1xuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtibG9jayA/IGFkZENvbG9yQWxwaGEodGhlbWUucGFsZXR0ZS5saW5rLCAwLjEpIDogJ3Vuc2V0J307XG4gICAgICAgICAgICBjb2xvcjogJHtob3ZlckNvbG9yfTtcbiAgICAgICAgICB9XG4gICAgICAgIGB9PC9zdHlsZT5cbiAgICAgIDwvYT5cbiAgICApXG4gIH0sXG4pXG5cbkxpbmtDb21wb25lbnQuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzXG5MaW5rQ29tcG9uZW50LmRpc3BsYXlOYW1lID0gJ0dlaXN0TGluaydcbmNvbnN0IExpbmsgPSB3aXRoU2NhbGVhYmxlKExpbmtDb21wb25lbnQpXG5leHBvcnQgZGVmYXVsdCBMaW5rXG4iXX0= */\n/*@ sourceURL=link.tsx */"))); }); LinkComponent.defaultProps = defaultProps$1; LinkComponent.displayName = 'GeistLink'; var Link = withScaleable(LinkComponent); var ImageBrowserHttpsIcon = function ImageBrowserHttpsIcon() { return /*#__PURE__*/React__default["default"].createElement("svg", { viewBox: "0 0 24 24", fill: "currentColor", className: "jsx-4165143638" }, /*#__PURE__*/React__default["default"].createElement("path", { d: "M5 10.2H19V21H5V10.2Z", className: "jsx-4165143638" }), /*#__PURE__*/React__default["default"].createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M12 12C13.933 12 15.5 10.3882 15.5 8.4C15.5 6.41177 13.933 4.8 12 4.8C10.067 4.8 8.5 6.41177 8.5 8.4C8.5 10.3882 10.067 12 12 12ZM12 13.8C14.8995 13.8 17.25 11.3823 17.25 8.4C17.25 5.41766 14.8995 3 12 3C9.10051 3 6.75 5.41766 6.75 8.4C6.75 11.3823 9.10051 13.8 12 13.8Z", className: "jsx-4165143638" }), /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "4165143638" }, "svg.jsx-4165143638{width:1em;height:1em;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImltYWdlLWJyb3dzZXItaHR0cHMtaWNvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV2tCLEFBR3FCLFVBQ0MsV0FDYiIsImZpbGUiOiJpbWFnZS1icm93c2VyLWh0dHBzLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuXG5jb25zdCBJbWFnZUJyb3dzZXJIdHRwc0ljb24gPSAoKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2ZyB2aWV3Qm94PVwiMCAwIDI0IDI0XCIgZmlsbD1cImN1cnJlbnRDb2xvclwiPlxuICAgICAgPHBhdGggZD1cIk01IDEwLjJIMTlWMjFINVYxMC4yWlwiIC8+XG4gICAgICA8cGF0aFxuICAgICAgICBmaWxsUnVsZT1cImV2ZW5vZGRcIlxuICAgICAgICBjbGlwUnVsZT1cImV2ZW5vZGRcIlxuICAgICAgICBkPVwiTTEyIDEyQzEzLjkzMyAxMiAxNS41IDEwLjM4ODIgMTUuNSA4LjRDMTUuNSA2LjQxMTc3IDEzLjkzMyA0LjggMTIgNC44QzEwLjA2NyA0LjggOC41IDYuNDExNzcgOC41IDguNEM4LjUgMTAuMzg4MiAxMC4wNjcgMTIgMTIgMTJaTTEyIDEzLjhDMTQuODk5NSAxMy44IDE3LjI1IDExLjM4MjMgMTcuMjUgOC40QzE3LjI1IDUuNDE3NjYgMTQuODk5NSAzIDEyIDNDOS4xMDA1MSAzIDYuNzUgNS40MTc2NiA2Ljc1IDguNEM2Ljc1IDExLjM4MjMgOS4xMDA1MSAxMy44IDEyIDEzLjhaXCJcbiAgICAgIC8+XG4gICAgICA8c3R5bGUganN4PntgXG4gICAgICAgIHN2ZyB7XG4gICAgICAgICAgd2lkdGg6IDFlbTtcbiAgICAgICAgICBoZWlnaHQ6IDFlbTtcbiAgICAgICAgfVxuICAgICAgYH08L3N0eWxlPlxuICAgIDwvc3ZnPlxuICApXG59XG5cbmNvbnN0IE1lbW9JbWFnZUJyb3dzZXJIdHRwc0ljb24gPSBSZWFjdC5tZW1vKEltYWdlQnJvd3Nlckh0dHBzSWNvbilcblxuZXhwb3J0IGRlZmF1bHQgTWVtb0ltYWdlQnJvd3Nlckh0dHBzSWNvblxuIl19 */\n/*@ sourceURL=image-browser-https-icon.tsx */")); }; var MemoImageBrowserHttpsIcon = /*#__PURE__*/React__default["default"].memo(ImageBrowserHttpsIcon); var getBrowserColors = function getBrowserColors(invert, palette) { return invert ? { color: palette.background, barBgColor: palette.foreground, inputBgColor: palette.accents_8, borderColor: palette.accents_7, titleColor: palette.accents_2 } : { color: palette.foreground, barBgColor: palette.background, inputBgColor: palette.accents_1, borderColor: palette.border, titleColor: palette.accents_5 }; }; var _excluded = ["url", "title", "children", "showFullLink", "invert", "anchorProps", "className"]; var defaultProps = { className: '', showFullLink: false, anchorProps: {}, invert: false }; var getHostFromUrl = function getHostFromUrl(url) { try { return new URL(url).host; } catch (e) { return url; } }; var getTitle = function getTitle(title, colors) { return /*#__PURE__*/React__default["default"].createElement("div", { className: styledJsx_cjs.style.dynamic([["524099755", [colors.titleColor]]]) + " " + "title" }, title, /*#__PURE__*/React__default["default"].createElement(styledJsx_cjs.style, { id: "524099755", dynamic: [colors.titleColor] }, ".title.__jsx-style-dynamic-selector{color:".concat(colors.titleColor, ";font-size:0.75em;}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImltYWdlLWJyb3dzZXIudHN4Il0sIm5hbW