@codecademy/gamut-styles 16.1.4-alpha.cd6532.0 → 16.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,20 +1,22 @@
1
1
  import { webFonts } from './remoteAssets/fonts';
2
2
  import { jsx as _jsx } from "react/jsx-runtime";
3
3
  import { Fragment as _Fragment } from "react/jsx-runtime";
4
- export const createFontLinks = () => webFonts.flatMap(_ref => {
5
- let {
6
- filePath,
7
- extensions
8
- } = _ref;
9
- return extensions.map(ext => /*#__PURE__*/_jsx("link", {
10
- rel: "preload",
11
- href: `${filePath}.${ext}`,
12
- crossOrigin: "anonymous",
13
- as: "font",
14
- type: `font/${ext}`
15
- }, `${filePath}-${ext}`));
16
- });
17
- export const AssetProvider = () => {
4
+ export var createFontLinks = function createFontLinks() {
5
+ return webFonts.flatMap(function (_ref) {
6
+ var filePath = _ref.filePath,
7
+ extensions = _ref.extensions;
8
+ return extensions.map(function (ext) {
9
+ return /*#__PURE__*/_jsx("link", {
10
+ rel: "preload",
11
+ href: "".concat(filePath, ".").concat(ext),
12
+ crossOrigin: "anonymous",
13
+ as: "font",
14
+ type: "font/".concat(ext)
15
+ }, "".concat(filePath, "-").concat(ext));
16
+ });
17
+ });
18
+ };
19
+ export var AssetProvider = function AssetProvider() {
18
20
  return /*#__PURE__*/_jsx(_Fragment, {
19
21
  children: createFontLinks()
20
22
  });
@@ -1,25 +1,41 @@
1
+ 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); }
2
+ 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; }
3
+ function _objectSpread(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; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
8
+ 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."); }
9
+ 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); }
10
+ 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; }
11
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
12
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
+ 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; }
14
+ 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; }
1
15
  import { getContrast } from 'polished';
2
16
  import { forwardRef, useCallback, useMemo } from 'react';
3
17
  import { ColorMode, useColorModes } from './ColorMode';
4
18
  import { jsx as _jsx } from "react/jsx-runtime";
5
- const isColorAlias = (mode, color) => {
19
+ var isColorAlias = function isColorAlias(mode, color) {
6
20
  return Object.keys(mode).includes(color);
7
21
  };
8
- export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
9
- let {
10
- bg,
11
- ...rest
12
- } = _ref;
13
- const [active, activeColors, modes, getColorValue] = useColorModes();
14
-
22
+ export var Background = /*#__PURE__*/forwardRef(function (_ref, ref) {
23
+ var bg = _ref.bg,
24
+ rest = _objectWithoutProperties(_ref, ["bg"]);
25
+ var _useColorModes = useColorModes(),
26
+ _useColorModes2 = _slicedToArray(_useColorModes, 4),
27
+ active = _useColorModes2[0],
28
+ activeColors = _useColorModes2[1],
29
+ modes = _useColorModes2[2],
30
+ getColorValue = _useColorModes2[3];
15
31
  /** If a color alias was used then look up the true color key from the active mode */
16
- const trueColor = useMemo(() => {
32
+ var trueColor = useMemo(function () {
17
33
  if (isColorAlias(activeColors, bg)) {
18
34
  return activeColors[bg];
19
35
  }
20
36
  return bg;
21
37
  }, [bg, activeColors]);
22
- const getTextContrast = useCallback(foreground => {
38
+ var getTextContrast = useCallback(function (foreground) {
23
39
  return getContrast(getColorValue(foreground), getColorValue(trueColor));
24
40
  }, [trueColor, getColorValue]);
25
41
 
@@ -33,12 +49,10 @@ export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
33
49
  * This does not guarantee a level of A/AA/AA compliance.
34
50
  */
35
51
 
36
- const accessibleMode = useMemo(() => {
37
- const {
38
- [active]: activeMode,
39
- ...otherModes
40
- } = modes;
41
- const possibleModes = Object.entries(otherModes);
52
+ var accessibleMode = useMemo(function () {
53
+ var activeMode = modes[active],
54
+ otherModes = _objectWithoutProperties(modes, [active].map(_toPropertyKey));
55
+ var possibleModes = Object.entries(otherModes);
42
56
 
43
57
  /**
44
58
  * Reduce all remaining modes to the mode key with the highest contrast
@@ -48,22 +62,25 @@ export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
48
62
  * it will likely fail to return a mode outside of the lightest and
49
63
  * darkest versions.
50
64
  */
51
- const [highestContrastMode] = possibleModes.reduce((_ref2, _ref3) => {
52
- let [prevMode, prevContrast] = _ref2;
53
- let [mode, {
54
- text
55
- }] = _ref3;
56
- const contrast = getTextContrast(text);
65
+ var _possibleModes$reduce = possibleModes.reduce(function (_ref2, _ref3) {
66
+ var _ref4 = _slicedToArray(_ref2, 2),
67
+ prevMode = _ref4[0],
68
+ prevContrast = _ref4[1];
69
+ var _ref5 = _slicedToArray(_ref3, 2),
70
+ mode = _ref5[0],
71
+ text = _ref5[1].text;
72
+ var contrast = getTextContrast(text);
57
73
 
58
- // Keep the higher contrast mode.
59
- return contrast > prevContrast ? [mode, contrast] : [prevMode, prevContrast];
60
- }, [active, getTextContrast(activeMode.text)]);
74
+ // Keep the higher contrast mode.
75
+ return contrast > prevContrast ? [mode, contrast] : [prevMode, prevContrast];
76
+ }, [active, getTextContrast(activeMode.text)]),
77
+ _possibleModes$reduce2 = _slicedToArray(_possibleModes$reduce, 1),
78
+ highestContrastMode = _possibleModes$reduce2[0];
61
79
  return highestContrastMode;
62
80
  }, [modes, active, getTextContrast]);
63
- return /*#__PURE__*/_jsx(ColorMode, {
64
- ...rest,
81
+ return /*#__PURE__*/_jsx(ColorMode, _objectSpread(_objectSpread({}, rest), {}, {
65
82
  mode: accessibleMode,
66
83
  bg: bg,
67
84
  ref: ref
68
- });
85
+ }));
69
86
  });
package/dist/ColorMode.js CHANGED
@@ -1,4 +1,18 @@
1
+ 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); }
1
2
  import _styled from "@emotion/styled/base";
3
+ 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; }
4
+ 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; }
5
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
6
+ 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."); }
7
+ 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); }
8
+ 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; }
9
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
10
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
11
+ 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; }
12
+ function _objectSpread(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; }
13
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
14
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
15
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
2
16
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
17
  import { serializeTokens, variance } from '@codecademy/variance';
4
18
  import { ThemeProvider, useTheme } from '@emotion/react';
@@ -7,31 +21,26 @@ import { createContext, forwardRef, useContext, useEffect, useMemo, useState } f
7
21
  import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
8
22
  import { styledOptions } from './variance/utils';
9
23
  import { jsx as _jsx } from "react/jsx-runtime";
10
- export const providerProps = variance.compose(layout, color, grid, flex, positioning, space, border, background);
11
- export const modeColorProps = _ref => {
12
- let {
13
- theme,
14
- mode
15
- } = _ref;
16
- if (!theme || !mode || mode === theme?.mode) return {};
17
- const {
18
- colors
19
- } = theme;
20
- return serializeTokens(mapValues(theme?.modes[mode], color => colors[color]), 'color', theme).variables;
24
+ export var providerProps = variance.compose(layout, color, grid, flex, positioning, space, border, background);
25
+ export var modeColorProps = function modeColorProps(_ref) {
26
+ var theme = _ref.theme,
27
+ mode = _ref.mode;
28
+ if (!theme || !mode || mode === (theme === null || theme === void 0 ? void 0 : theme.mode)) return {};
29
+ var colors = theme.colors;
30
+ return serializeTokens(mapValues(theme === null || theme === void 0 ? void 0 : theme.modes[mode], function (color) {
31
+ return colors[color];
32
+ }), 'color', theme).variables;
21
33
  };
22
- const BackgroundCurrentContext = /*#__PURE__*/createContext({
34
+ var BackgroundCurrentContext = /*#__PURE__*/createContext({
23
35
  'background-current': undefined
24
36
  });
25
37
  export function useColorModes() {
26
- const bgCurrent = useContext(BackgroundCurrentContext);
27
- const {
28
- mode,
29
- modes,
30
- _getColorValue: getColorValue
31
- } = useTheme() || {};
32
- const modesCopy = {
33
- ...modes
34
- };
38
+ var bgCurrent = useContext(BackgroundCurrentContext);
39
+ var _ref2 = useTheme() || {},
40
+ mode = _ref2.mode,
41
+ modes = _ref2.modes,
42
+ getColorValue = _ref2._getColorValue;
43
+ var modesCopy = _objectSpread({}, modes);
35
44
  if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
36
45
  /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
37
46
  we could potentially alter the Merge type utility function from createTheme, but since 'background-current' is the only exception to the type-merging rule and this is the only place we override, this seems to be a more straightforward + lower-risk solution.
@@ -39,100 +48,98 @@ export function useColorModes() {
39
48
 
40
49
  modesCopy[mode]['background-current'] = bgCurrent['background-current'];
41
50
  }
42
- return [mode, modesCopy?.[mode], modes, getColorValue];
51
+ return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
43
52
  }
44
53
  export function useCurrentMode(mode) {
45
- const [activeMode] = useColorModes();
46
- return mode ?? activeMode;
54
+ var _useColorModes = useColorModes(),
55
+ _useColorModes2 = _slicedToArray(_useColorModes, 1),
56
+ activeMode = _useColorModes2[0];
57
+ return mode !== null && mode !== void 0 ? mode : activeMode;
47
58
  }
48
59
  export function usePrefersDarkMode() {
49
- const [prefersDarkMode, setPrefersDarkMode] = useState(false);
50
- useEffect(() => {
60
+ var _useState = useState(false),
61
+ _useState2 = _slicedToArray(_useState, 2),
62
+ prefersDarkMode = _useState2[0],
63
+ setPrefersDarkMode = _useState2[1];
64
+ useEffect(function () {
51
65
  function onChange(event) {
52
66
  setPrefersDarkMode(event.matches);
53
67
  }
54
68
  if (window && 'matchMedia' in window) {
55
- const mq = window.matchMedia('(prefers-color-scheme: dark)');
69
+ var mq = window.matchMedia('(prefers-color-scheme: dark)');
56
70
  if (mq && 'addEventListener' in mq) {
57
71
  setPrefersDarkMode(mq.matches);
58
72
  mq.addEventListener('change', onChange);
59
- return () => mq.removeEventListener('change', onChange);
73
+ return function () {
74
+ return mq.removeEventListener('change', onChange);
75
+ };
60
76
  }
61
77
  }
62
78
  }, []);
63
79
  return prefersDarkMode;
64
80
  }
65
- export const VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
81
+ export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
66
82
  target: "e1skjn880",
67
83
  label: "VariableProvider"
68
- }, styledOptions(['variables', 'alwaysSetVariables'])))(_ref2 => {
69
- let {
70
- variables
71
- } = _ref2;
84
+ }, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
85
+ var variables = _ref3.variables;
72
86
  return variables;
73
87
  }, css({
74
88
  textColor: 'text'
75
89
  }), providerProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ColorMode.tsx"],"names":[],"mappings":"AAoIgC","file":"../src/ColorMode.tsx","sourcesContent":["import {\n  serializeTokens,\n  StyleProps,\n  ThemeProps,\n  variance,\n} from '@codecademy/variance';\nimport { CSSObject, Theme, ThemeProvider, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { mapValues, pick } from 'lodash';\nimport {\n  ComponentProps,\n  createContext,\n  forwardRef,\n  useContext,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react';\n\nimport { theme as GamutTheme } from '.';\nimport {\n  background,\n  border,\n  color,\n  css,\n  flex,\n  grid,\n  layout,\n  positioning,\n  space,\n} from './variance/props';\nimport { styledOptions } from './variance/utils';\n\nexport type Colors = keyof Theme['colors'];\nexport type ColorModeConfig = Theme['modes'];\nexport type ColorModes = keyof ColorModeConfig;\nexport type ColorModeShape = ColorModeConfig[ColorModes];\nexport type ColorAlias = keyof ColorModeShape;\n\nexport type ColorModeProps = {\n  mode: ColorModes | 'system';\n  bg?: Colors;\n};\n\nexport const providerProps = variance.compose(\n  layout,\n  color,\n  grid,\n  flex,\n  positioning,\n  space,\n  border,\n  background\n);\n\nexport const modeColorProps = ({\n  theme,\n  mode,\n}: ThemeProps<{ mode?: ColorModes }>) => {\n  if (!theme || !mode || mode === theme?.mode) return {};\n  const { colors } = theme;\n  return serializeTokens(\n    mapValues(theme?.modes[mode], (color) => colors[color]),\n    'color',\n    theme\n  ).variables;\n};\n\ninterface BackgroundCurrentContextInterface {\n  'background-current'?: keyof typeof GamutTheme.colors;\n}\n\nconst BackgroundCurrentContext = createContext<BackgroundCurrentContextInterface>(\n  {\n    'background-current': undefined,\n  }\n);\n\nexport function useColorModes(): [\n  ColorModes,\n  ColorModeShape,\n  ColorModeConfig,\n  (color: Colors) => string\n] {\n  const bgCurrent = useContext(BackgroundCurrentContext);\n  const { mode, modes, _getColorValue: getColorValue } = useTheme() || {};\n  const modesCopy = { ...modes };\n\n  if (\n    bgCurrent['background-current'] &&\n    modesCopy[mode]['background-current'] !== bgCurrent['background-current']\n  ) {\n    /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.\n    we could potentially alter the Merge type utility function from createTheme, but since 'background-current' is the only exception to the type-merging rule  and this is the only place we override, this seems to be a more straightforward + lower-risk solution.\n    */\n\n    modesCopy[mode]['background-current'] = bgCurrent['background-current'] as\n      | 'white'\n      | 'navy-800';\n  }\n\n  return [mode, modesCopy?.[mode], modes, getColorValue];\n}\n\nexport function useCurrentMode(mode?: ColorModes) {\n  const [activeMode] = useColorModes();\n  return mode ?? activeMode;\n}\n\nexport function usePrefersDarkMode() {\n  const [prefersDarkMode, setPrefersDarkMode] = useState(false);\n\n  useEffect(() => {\n    function onChange(event: MediaQueryListEvent) {\n      setPrefersDarkMode(event.matches);\n    }\n\n    if (window && 'matchMedia' in window) {\n      const mq = window.matchMedia('(prefers-color-scheme: dark)');\n\n      if (mq && 'addEventListener' in mq) {\n        setPrefersDarkMode(mq.matches);\n        mq.addEventListener('change', onChange);\n\n        return () => mq.removeEventListener('change', onChange);\n      }\n    }\n  }, []);\n\n  return prefersDarkMode;\n}\n\nexport const VariableProvider = styled(\n  'div',\n  styledOptions(['variables', 'alwaysSetVariables'])\n)<\n  StyleProps<typeof providerProps> & {\n    variables?: CSSObject;\n    alwaysSetVariables?: boolean;\n  }\n>(({ variables }) => variables, css({ textColor: 'text' }), providerProps);\n\nexport const ColorMode = forwardRef<\n  HTMLDivElement,\n  Omit<ComponentProps<typeof VariableProvider>, 'bg'> & ColorModeProps\n>(({ mode: preference, alwaysSetVariables, bg, ...rest }, ref) => {\n  // checks if the user has set 'system' as their color mode preference\n  // then sets the color mode\n  const prefersDarkMode = usePrefersDarkMode();\n  const mode =\n    preference === 'system' ? (prefersDarkMode ? 'dark' : 'light') : preference;\n\n  const theme = useTheme();\n  const { modes, mode: active, colors } = theme;\n  const contextBg = bg ? 'background-current' : undefined;\n  // This makes sure the background-current context is always set to the correct color + not the semantic color name.\n  const currentParentBg = useContext(BackgroundCurrentContext);\n\n  const bgCurrent =\n    bg === 'background-current'\n      ? currentParentBg['background-current']\n        ? currentParentBg['background-current']\n        : modes[active]['background-current']\n      : bg;\n\n  /** Serialize color variables for the current mode\n   * 1. If all variables are required add all mode variables to the current context\n   * 2. If the user has specified a background color - set that color to the current-bg\n   * 3. If not\n   */\n  const { variables } = useMemo(() => {\n    return serializeTokens(\n      mapValues(modes[mode], (color, key) => {\n        if (key === 'background-current' && typeof bg !== 'undefined') {\n          return colors[bg];\n        }\n        return colors[color];\n      }),\n      'color',\n      theme\n    );\n  }, [colors, mode, modes, theme, bg]);\n\n  if (active === mode) {\n    const vars = alwaysSetVariables\n      ? variables\n      : pick(variables, ['--color-background-current']);\n\n    return (\n      <BackgroundCurrentContext.Provider\n        value={{ 'background-current': bgCurrent }}\n      >\n        <VariableProvider {...rest} variables={vars} bg={contextBg} ref={ref} />\n      </BackgroundCurrentContext.Provider>\n    );\n  }\n\n  return (\n    <ThemeProvider theme={{ mode }}>\n      <VariableProvider\n        {...rest}\n        variables={variables}\n        bg={contextBg}\n        ref={ref}\n      />\n    </ThemeProvider>\n  );\n});\n"]} */");
76
- export const ColorMode = /*#__PURE__*/forwardRef((_ref3, ref) => {
77
- let {
78
- mode: preference,
79
- alwaysSetVariables,
80
- bg,
81
- ...rest
82
- } = _ref3;
90
+ export var ColorMode = /*#__PURE__*/forwardRef(function (_ref4, ref) {
91
+ var preference = _ref4.mode,
92
+ alwaysSetVariables = _ref4.alwaysSetVariables,
93
+ bg = _ref4.bg,
94
+ rest = _objectWithoutProperties(_ref4, ["mode", "alwaysSetVariables", "bg"]);
83
95
  // checks if the user has set 'system' as their color mode preference
84
96
  // then sets the color mode
85
- const prefersDarkMode = usePrefersDarkMode();
86
- const mode = preference === 'system' ? prefersDarkMode ? 'dark' : 'light' : preference;
87
- const theme = useTheme();
88
- const {
89
- modes,
90
- mode: active,
91
- colors
92
- } = theme;
93
- const contextBg = bg ? 'background-current' : undefined;
97
+ var prefersDarkMode = usePrefersDarkMode();
98
+ var mode = preference === 'system' ? prefersDarkMode ? 'dark' : 'light' : preference;
99
+ var theme = useTheme();
100
+ var modes = theme.modes,
101
+ active = theme.mode,
102
+ colors = theme.colors;
103
+ var contextBg = bg ? 'background-current' : undefined;
94
104
  // This makes sure the background-current context is always set to the correct color + not the semantic color name.
95
- const currentParentBg = useContext(BackgroundCurrentContext);
96
- const bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
105
+ var currentParentBg = useContext(BackgroundCurrentContext);
106
+ var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
97
107
 
98
108
  /** Serialize color variables for the current mode
99
109
  * 1. If all variables are required add all mode variables to the current context
100
110
  * 2. If the user has specified a background color - set that color to the current-bg
101
111
  * 3. If not
102
112
  */
103
- const {
104
- variables
105
- } = useMemo(() => {
106
- return serializeTokens(mapValues(modes[mode], (color, key) => {
107
- if (key === 'background-current' && typeof bg !== 'undefined') {
108
- return colors[bg];
109
- }
110
- return colors[color];
111
- }), 'color', theme);
112
- }, [colors, mode, modes, theme, bg]);
113
+ var _useMemo = useMemo(function () {
114
+ return serializeTokens(mapValues(modes[mode], function (color, key) {
115
+ if (key === 'background-current' && typeof bg !== 'undefined') {
116
+ return colors[bg];
117
+ }
118
+ return colors[color];
119
+ }), 'color', theme);
120
+ }, [colors, mode, modes, theme, bg]),
121
+ variables = _useMemo.variables;
113
122
  if (active === mode) {
114
- const vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
123
+ var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
115
124
  return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
116
125
  value: {
117
126
  'background-current': bgCurrent
118
127
  },
119
- children: /*#__PURE__*/_jsx(VariableProvider, {
120
- ...rest,
128
+ children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
121
129
  variables: vars,
122
130
  bg: contextBg,
123
131
  ref: ref
124
- })
132
+ }))
125
133
  });
126
134
  }
127
135
  return /*#__PURE__*/_jsx(ThemeProvider, {
128
136
  theme: {
129
- mode
137
+ mode: mode
130
138
  },
131
- children: /*#__PURE__*/_jsx(VariableProvider, {
132
- ...rest,
139
+ children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
133
140
  variables: variables,
134
141
  bg: contextBg,
135
142
  ref: ref
136
- })
143
+ }))
137
144
  });
138
145
  });
@@ -8,34 +8,34 @@ import { coreTheme } from './themes/core';
8
8
  import { jsx as _jsx } from "react/jsx-runtime";
9
9
  import { Fragment as _Fragment } from "react/jsx-runtime";
10
10
  import { jsxs as _jsxs } from "react/jsx-runtime";
11
- export const GamutContext = /*#__PURE__*/React.createContext({
11
+ export var GamutContext = /*#__PURE__*/React.createContext({
12
12
  hasGlobals: false,
13
13
  hasCache: false
14
14
  });
15
15
  GamutContext.displayName = 'GamutContext';
16
- export const GamutProvider = _ref => {
17
- let {
18
- children,
19
- cache,
20
- theme = coreTheme,
21
- variables,
22
- useGlobals = true,
23
- useCache = true
24
- } = _ref;
25
- const {
26
- hasGlobals,
27
- hasCache
28
- } = useContext(GamutContext);
29
- const shouldCreateCache = useCache && !hasCache;
30
- const shouldInsertGlobals = useGlobals && !hasGlobals;
16
+ export var GamutProvider = function GamutProvider(_ref) {
17
+ var children = _ref.children,
18
+ cache = _ref.cache,
19
+ _ref$theme = _ref.theme,
20
+ theme = _ref$theme === void 0 ? coreTheme : _ref$theme,
21
+ variables = _ref.variables,
22
+ _ref$useGlobals = _ref.useGlobals,
23
+ useGlobals = _ref$useGlobals === void 0 ? true : _ref$useGlobals,
24
+ _ref$useCache = _ref.useCache,
25
+ useCache = _ref$useCache === void 0 ? true : _ref$useCache;
26
+ var _useContext = useContext(GamutContext),
27
+ hasGlobals = _useContext.hasGlobals,
28
+ hasCache = _useContext.hasCache;
29
+ var shouldCreateCache = useCache && !hasCache;
30
+ var shouldInsertGlobals = useGlobals && !hasGlobals;
31
31
 
32
32
  // Do not initialize a new cache if one has been provided as props
33
- const activeCache = useRef(shouldCreateCache && (cache ?? createEmotionCache()));
34
- const contextValue = {
33
+ var activeCache = useRef(shouldCreateCache && (cache !== null && cache !== void 0 ? cache : createEmotionCache()));
34
+ var contextValue = {
35
35
  hasGlobals: shouldInsertGlobals,
36
36
  hasCache: shouldCreateCache
37
37
  };
38
- const globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
38
+ var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
39
39
  children: [/*#__PURE__*/_jsx(Typography, {}), /*#__PURE__*/_jsx(Reboot, {}), /*#__PURE__*/_jsx(Variables, {
40
40
  variables: theme._variables
41
41
  }), variables && /*#__PURE__*/_jsx(Variables, {
@@ -1,13 +1,25 @@
1
+ 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); }
2
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
3
+ 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."); }
4
+ 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); }
5
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
6
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
7
+ 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; }
8
+ 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; }
9
+ function _objectSpread(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; }
10
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
11
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
12
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
1
13
  import createCache from '@emotion/cache';
2
14
  import { prefixer } from 'stylis';
3
15
  import { focusVisible } from './stylisPlugins';
4
- export const EMOTION_KEY = 'gamut';
5
- export const EMOTION_CONTAINER = 'emotion-styles';
6
- const getEmotionNode = () => {
16
+ export var EMOTION_KEY = 'gamut';
17
+ export var EMOTION_CONTAINER = 'emotion-styles';
18
+ var getEmotionNode = function getEmotionNode() {
7
19
  if (typeof document === 'undefined') {
8
20
  return;
9
21
  }
10
- let node = document.getElementById(EMOTION_CONTAINER);
22
+ var node = document.getElementById(EMOTION_CONTAINER);
11
23
  if (node) return node;
12
24
  node = document.createElement('div');
13
25
  node.setAttribute('id', EMOTION_CONTAINER);
@@ -16,10 +28,13 @@ const getEmotionNode = () => {
16
28
  document.getElementsByTagName('body')[0].prepend(node);
17
29
  return node;
18
30
  };
19
- export const createEmotionCache = overrides => createCache({
20
- key: EMOTION_KEY,
21
- speedy: process.env.NODE_ENV !== 'development',
22
- container: overrides?.container ?? getEmotionNode(),
23
- ...overrides,
24
- stylisPlugins: [...(overrides?.stylisPlugins ?? []), focusVisible, prefixer]
25
- });
31
+ export var createEmotionCache = function createEmotionCache(overrides) {
32
+ var _overrides$container, _overrides$stylisPlug;
33
+ return createCache(_objectSpread(_objectSpread({
34
+ key: EMOTION_KEY,
35
+ speedy: process.env.NODE_ENV !== 'development',
36
+ container: (_overrides$container = overrides === null || overrides === void 0 ? void 0 : overrides.container) !== null && _overrides$container !== void 0 ? _overrides$container : getEmotionNode()
37
+ }, overrides), {}, {
38
+ stylisPlugins: [].concat(_toConsumableArray((_overrides$stylisPlug = overrides === null || overrides === void 0 ? void 0 : overrides.stylisPlugins) !== null && _overrides$stylisPlug !== void 0 ? _overrides$stylisPlug : []), [focusVisible, prefixer])
39
+ }));
40
+ };
@@ -1,9 +1,9 @@
1
- export const focusVisible = element => {
1
+ export var focusVisible = function focusVisible(element) {
2
2
  if (element.type === 'rule' && element.value.includes(':focus-visible')) {
3
3
  if (typeof element.props === 'string') element.props = [element.props];
4
- element.props = element.props.map(prop => {
5
- const poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
6
- return `${prop}, ${poly}`;
4
+ element.props = element.props.map(function (prop) {
5
+ var poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
6
+ return "".concat(prop, ", ").concat(poly);
7
7
  });
8
8
  }
9
9
  return undefined;
@@ -1,7 +1,9 @@
1
1
  import { css, Global } from '@emotion/react';
2
2
  import { coreTheme as theme } from '../themes';
3
3
  import { jsx as _jsx } from "react/jsx-runtime";
4
- const rebootStyles = /*#__PURE__*/css("/**\n * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n * Reboot\n * Normalization of HTML elements, manually forked from Normalize.css to remove\n * styles targeting irrelevant browsers while applying new styles.\n * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n * Document\n * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n * 2 Change the default font family in all browsers.\n * 3 Correct the line height in all browsers.\n * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n * we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n * 6 Change the default tap highlight to be completely transparent in iOS.\n*/*,*::before,*::after{box-sizing:border-box;}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0, 0, 0, 0);}article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block;}body{margin:0;font-family:", theme.fontFamily.base, ";font-weight:", theme.fontWeight.base, ";line-height:", theme.lineHeight.base, ";color:", theme.colors.text, ";text-align:left;background-color:", theme.colors.background, ";}[tabindex='-1']:focus{outline:0!important;}hr{box-sizing:content-box;height:0;overflow:visible;}h1,h2,h3,h4,h5,h6{margin-top:0;}p{margin-top:0;margin-bottom:", theme.spacing[16], ";}abbr[title],abbr[data-original-title]{text-decoration:underline;text-decoration:underline dotted;cursor:help;border-bottom:0;}address{margin-bottom:1rem;font-style:normal;line-height:inherit;}ol,ul,dl{margin-top:0;margin-bottom:1rem;}ol ol,ul ul,ol ul,ul ol{margin-bottom:0;}dt{font-weight:", theme.fontWeight.title, ";}dd{margin-bottom:0.5rem;margin-left:0;}blockquote{margin:0 0 1rem;}dfn{font-style:italic;}b,strong{font-weight:", theme.fontWeight.title, ";}small{font-size:", theme.fontSize[14], ";}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline;}sub{bottom:-0.25em;}sup{top:-0.5em;}a{color:", theme.colors.primary, ";text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects;&:hover{text-decoration:underline;}}a:not([href]):not([tabindex]){color:inherit;text-decoration:none;&:hover,&:focus{color:inherit;text-decoration:none;}&:focus{outline:0;}}pre,code,kbd,samp{font-family:monospace,monospace;font-size:1em;}pre{margin-top:0;margin-bottom:1rem;overflow:auto;/* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */-ms-overflow-style:scrollbar;}figure{margin:0 0 1rem;}img{vertical-align:middle;border-style:none;}svg:not(:root){overflow:hidden;}table{border-collapse:collapse;}caption{padding-top:", theme.spacing[16], ";padding-bottom:", theme.spacing[16], ";color:", theme.spacing[16], ";text-align:left;caption-side:bottom;}th{text-align:inherit;}label{display:inline-block;margin-bottom:0;}button{border-radius:0;}button:focus-visible{outline:1px dotted;outline:5px auto -webkit-focus-ring-color;}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit;}button,input{overflow:visible;}button,select{text-transform:none;}button,html [type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;}input[type='radio'],input[type='checkbox']{box-sizing:border-box;padding:0;}input[type='date'],input[type='time'],input[type='datetime-local'],input[type='month']{-webkit-appearance:listbox;}textarea{overflow:auto;resize:vertical;}fieldset{min-width:0;padding:0;margin:0;border:0;}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:0.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal;}progress{vertical-align:baseline;}[type='number']::-webkit-inner-spin-button,[type='number']::-webkit-outer-spin-button{height:auto;}[type='search']{outline-offset:-2px;-webkit-appearance:none;}[type='search']::-webkit-search-cancel-button,[type='search']::-webkit-search-decoration{-webkit-appearance:none;}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button;}output{display:inline-block;}summary{display:list-item;cursor:pointer;}template{display:none;}[hidden]{display:none!important;};label:rebootStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/globals/Reboot.tsx"],"names":[],"mappings":"AAIwB","file":"../../src/globals/Reboot.tsx","sourcesContent":["import { css, Global } from '@emotion/react';\n\nimport { coreTheme as theme } from '../themes';\n\nconst rebootStyles = css`\n  /**\n  * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n  * Reboot\n  * Normalization of HTML elements, manually forked from Normalize.css to remove\n  * styles targeting irrelevant browsers while applying new styles.\n  * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n  * Document\n  * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n  * 2 Change the default font family in all browsers.\n  * 3 Correct the line height in all browsers.\n  * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n  * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n  *    we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n  * 6 Change the default tap highlight to be completely transparent in iOS.\n*/\n\n  *,\n  *::before,\n  *::after {\n    /* This is changed from content-box to border-box as all of our css relies on it */\n    box-sizing: border-box; /** 1 */\n  }\n\n  html {\n    font-family: sans-serif; /** 2 */\n    line-height: 1.15; /** 3 */\n    -webkit-text-size-adjust: 100%; /** 4 */\n    -ms-text-size-adjust: 100%; /** 4 */\n    -ms-overflow-style: scrollbar; /** 5 */\n    -webkit-tap-highlight-color: rgba(0, 0, 0, 0); /** 6 */\n  }\n\n  /**Shim for \"new\" HTML5 structural elements to display correctly (IE10, older browsers) */\n\n  article,\n  aside,\n  dialog,\n  figcaption,\n  figure,\n  footer,\n  header,\n  hgroup,\n  main,\n  nav,\n  section {\n    display: block;\n  }\n  /** Body\n   1. Remove the margin in all browsers.\n   2. As a best practice, apply a default \\`background-color\\`.\n   3. Set an explicit initial text-align value so that we can later use the\n      the \\`inherit\\` value on things like \\`<th>\\` elements.\n   */\n\n  body {\n    margin: 0;\n    font-family: ${theme.fontFamily.base};\n    font-weight: ${theme.fontWeight.base};\n    line-height: ${theme.lineHeight.base};\n    color: ${theme.colors.text};\n    text-align: left;\n    background-color: ${theme.colors.background};\n  }\n\n  /* Suppress the focus outline on elements that cannot be accessed via keyboard.\n  This prevents an unwanted focus outline from appearing around elements that\n  might still respond to pointer events.\n Credit: https://github.com/suitcss/base */\n\n  [tabindex='-1']:focus {\n    outline: 0 !important;\n  }\n\n  /*\n  Content grouping\n 1. Add the correct box sizing in Firefox.\n  2. Show the overflow in Edge and IE.\n*/\n\n  hr {\n    box-sizing: content-box;\n    /* 1 */\n    height: 0;\n    /* 2 */\n    overflow: visible;\n  }\n  /* Typography */\n  /*\n  Remove top margins from headings\n   By default, \\`<h1>\\`-\\`<h6>\\` all receive top and bottom margins. We nuke the top\n  margin for easier control within type scales as it avoids margin collapsing.\n*/\n\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6 {\n    margin-top: 0;\n  }\n\n  /*\n  Reset margins on paragraphs\n  Similarly, the top margin on \\`<p>\\`s get reset. However, we also reset the\n  bottom margin to use \\`rem\\` units instead of \\`em\\`.\n  */\n\n  p {\n    margin-top: 0;\n    margin-bottom: ${theme.spacing[16]};\n  }\n\n  /*\n  Abbreviations\n  1. Remove the bottom border in Firefox 39-.\n  2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n  3. Add explicit cursor to indicate changed behavior.\n  4. Duplicate behavior to the data-* attribute for our tooltip plugin\n  */\n\n  abbr[title],\n  abbr[data-original-title] {\n    /* 4 */\n    text-decoration: underline;\n    text-decoration: underline dotted;\n    cursor: help;\n    border-bottom: 0;\n  }\n\n  address {\n    margin-bottom: 1rem;\n    font-style: normal;\n    line-height: inherit;\n  }\n\n  ol,\n  ul,\n  dl {\n    margin-top: 0;\n    margin-bottom: 1rem;\n  }\n\n  ol ol,\n  ul ul,\n  ol ul,\n  ul ol {\n    margin-bottom: 0;\n  }\n\n  dt {\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  dd {\n    /* Undo browser default */\n    margin-bottom: 0.5rem;\n    margin-left: 0;\n  }\n\n  blockquote {\n    margin: 0 0 1rem;\n  }\n\n  dfn {\n    /* Add the correct font style in Android 4.3- */\n    font-style: italic;\n  }\n\n  b,\n  strong {\n    /* Add the correct font weight in Chrome, Edge, and Safari */\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  small {\n    /* Add the correct font size in all browsers */\n    font-size: ${theme.fontSize[14]};\n  }\n\n  /*\n Prevent \\`sub\\` and \\`sup\\` elements from affecting the line height in\n  all browsers.\n*/\n  sub,\n  sup {\n    position: relative;\n    font-size: 75%;\n    line-height: 0;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n  sup {\n    top: -0.5em;\n  }\n\n  /*\n Links\n  Remove the gray background on active links in IE 10.\n  Remove gaps in links underline in iOS 8+ and Safari 8+.\n*/\n\n  a {\n    color: ${theme.colors.primary};\n    text-decoration: none;\n\n    background-color: transparent;\n    -webkit-text-decoration-skip: objects;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n\n  /*\n  And undo these styles for placeholder links/named anchors (without href)\n  which have not been made explicitly keyboard-focusable (without tabindex).\n  It would be more straightforward to just use a[href] in previous block, but that\n  causes specificity issues in many other styles that are too complex to fix.\n  */\n\n  a:not([href]):not([tabindex]) {\n    color: inherit;\n    text-decoration: none;\n\n    &:hover,\n    &:focus {\n      color: inherit;\n      text-decoration: none;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n  }\n\n  /* Code */\n\n  pre,\n  code,\n  kbd,\n  samp {\n    /* Correct the inheritance and scaling of font size in all browsers. */\n    font-family: monospace, monospace;\n    /* Correct the odd \\`em\\` font sizing in all browsers.*/\n    font-size: 1em;\n  }\n  /* stylelint-enable font-family-no-duplicate-names */\n\n  pre {\n    /* Remove browser default top margin */\n    margin-top: 0;\n    /* Reset browser default of \\`1em\\` to use \\`rem\\`s */\n    margin-bottom: 1rem;\n    /* Don't allow content to break outside */\n    overflow: auto;\n    /* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */\n    /* we force a non-overlapping, non-auto-hiding scrollbar to counteract. */\n    -ms-overflow-style: scrollbar;\n  }\n\n  /*\nFigures\n*/\n  figure {\n    /* Apply a consistent margin strategy (matches our type styles). */\n    margin: 0 0 1rem;\n  }\n\n  /* Images and content */\n  img {\n    vertical-align: middle;\n    /* Remove the border on images inside links in IE 10-. */\n    border-style: none;\n  }\n\n  svg:not(:root) {\n    /* Hide the overflow in IE */\n    overflow: hidden;\n  }\n\n  /* Tables  */\n  table {\n    /* *  Prevent double borders */\n    border-collapse: collapse;\n  }\n\n  caption {\n    padding-top: ${theme.spacing[16]};\n    padding-bottom: ${theme.spacing[16]};\n    color: ${theme.spacing[16]};\n    text-align: left;\n    caption-side: bottom;\n  }\n\n  th {\n    /*  Matches default \\`<td>\\` alignment by inheriting from the \\`<body>\\`, or the\n  closest parent with a set \\`text-align\\`. */\n    text-align: inherit;\n  }\n\n  /* Forms */\n\n  label {\n    /* Allow labels to use \\`margin\\` for spacing. */\n    display: inline-block;\n    margin-bottom: 0;\n  }\n\n  /* Remove the default \\`border-radius\\` that macOS Chrome adds.\n Details at https://github.com/twbs/bootstrap/issues/24093     */\n\n  button {\n    border-radius: 0;\n  }\n\n  /*\n  Work around a Firefox/IE bug where the transparent \\`button\\` background\n  results in a loss of the default \\`button\\` focus styles.\n  Credit: https://github.com/suitcss/base/\n  */\n\n  button:focus-visible {\n    outline: 1px dotted;\n    outline: 5px auto -webkit-focus-ring-color;\n  }\n\n  input,\n  button,\n  select,\n  optgroup,\n  textarea {\n    /* Remove the margin in Firefox and Safari */\n    margin: 0;\n    font-family: inherit;\n    font-size: inherit;\n    line-height: inherit;\n  }\n\n  button,\n  input {\n    /* Show the overflow in Edge */\n    overflow: visible;\n  }\n\n  button,\n  select {\n    /* Remove the inheritance of text transform in Firefox */\n    text-transform: none;\n  }\n\n  /*\n  1. Prevent a WebKit bug where (2) destroys native \\`audio\\` and \\`video\\`\n    controls in Android 4.\n  2. Correct the inability to style clickable types in iOS and Safari.\n  */\n  button,\n  html [type='button'],\n  [type='reset'],\n  [type='submit'] {\n    /* 2 */\n    -webkit-appearance: button;\n  }\n\n  input[type='radio'],\n  input[type='checkbox'] {\n    /*  1. Add the correct box sizing in IE 10- */\n    box-sizing: border-box;\n    /* 2. Remove the padding in IE 10- */\n    padding: 0;\n  }\n\n  input[type='date'],\n  input[type='time'],\n  input[type='datetime-local'],\n  input[type='month'] {\n    /* Remove the default appearance of temporal inputs to avoid a Mobile Safari\n    bug where setting a custom line-height prevents text from being vertically\n    centered within the input.\n    See https://bugs.webkit.org/show_bug.cgi?id=139848\n    and https://github.com/twbs/bootstrap/issues/11266 */\n    -webkit-appearance: listbox;\n  }\n\n  textarea {\n    /* Remove the default vertical scrollbar in IE. */\n    overflow: auto;\n    /* Textareas should really only resize vertically so they don't break their (horizontal) containers. */\n    resize: vertical;\n  }\n\n  fieldset {\n    /* Browsers set a default \\`min-width: min-content;\\` on fieldsets,\n  unlike e.g. \\`<div>\\`s, which have \\`min-width: 0;\\` by default.\n  So we reset that to ensure fieldsets behave more like a standard block element.\n  See https://github.com/twbs/bootstrap/issues/12359\n  and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements */\n    min-width: 0;\n    /* Reset the default outline behavior of fieldsets so they don't affect page layout.*/\n    padding: 0;\n    margin: 0;\n    border: 0;\n  }\n\n  /* 1. Correct the text wrapping in Edge and IE. */\n  /* 2. Correct the color inheritance from \\`fieldset\\` elements in IE. */\n  legend {\n    display: block;\n    width: 100%;\n    /* 1 */\n    max-width: 100%;\n    padding: 0;\n    margin-bottom: 0.5rem;\n    font-size: 1.5rem;\n    line-height: inherit;\n    /* 2 */\n    color: inherit;\n    /* 1 */\n    white-space: normal;\n  }\n\n  progress {\n    /* Add the correct vertical alignment in Chrome, Firefox, and Opera. */\n    vertical-align: baseline;\n  }\n\n  /* Correct the cursor style of increment and decrement buttons in Chrome. */\n  [type='number']::-webkit-inner-spin-button,\n  [type='number']::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  [type='search'] {\n    /*\n    This overrides the extra rounded corners on search inputs in iOS so that our\n    \\`.form-control\\` class can properly style them. Note that this cannot simply\n    be added to \\`.form-control\\` as it's not specific enough. For details, see\n    https://github.com/twbs/bootstrap/issues/11586.\n    */\n    /* 2. Correct the outline style in Safari. */\n    outline-offset: -2px;\n    -webkit-appearance: none;\n  }\n\n  /* Remove the inner padding and cancel buttons in Chrome and Safari on macOS. */\n\n  [type='search']::-webkit-search-cancel-button,\n  [type='search']::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  /*\n  1. Correct the inability to style clickable types in iOS and Safari.\n  2. Change font properties to \\`inherit\\` in Safari.\n  */\n  ::-webkit-file-upload-button {\n    /* 2 */\n    font: inherit;\n    /* 1 */\n    -webkit-appearance: button;\n  }\n\n  /* Correct element displays */\n\n  output {\n    display: inline-block;\n  }\n\n  summary {\n    /* Add the correct display in all browsers */\n    display: list-item;\n    cursor: pointer;\n  }\n\n  template {\n    /* Add the correct display in IE */\n    display: none;\n  }\n\n  /*\n  Always hide an element with the \\`hidden\\` HTML attribute (from PureCSS).\n  Needed for proper display in IE 10-.\n  */\n  [hidden] {\n    display: none !important;\n  }\n`;\n\nexport const Reboot = () => <Global styles={rebootStyles} />;\n"]} */"));
5
- export const Reboot = () => /*#__PURE__*/_jsx(Global, {
6
- styles: rebootStyles
7
- });
4
+ var rebootStyles = /*#__PURE__*/css("/**\n * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n * Reboot\n * Normalization of HTML elements, manually forked from Normalize.css to remove\n * styles targeting irrelevant browsers while applying new styles.\n * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n * Document\n * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n * 2 Change the default font family in all browsers.\n * 3 Correct the line height in all browsers.\n * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n * we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n * 6 Change the default tap highlight to be completely transparent in iOS.\n*/*,*::before,*::after{box-sizing:border-box;}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0, 0, 0, 0);}article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block;}body{margin:0;font-family:", theme.fontFamily.base, ";font-weight:", theme.fontWeight.base, ";line-height:", theme.lineHeight.base, ";color:", theme.colors.text, ";text-align:left;background-color:", theme.colors.background, ";}[tabindex='-1']:focus{outline:0!important;}hr{box-sizing:content-box;height:0;overflow:visible;}h1,h2,h3,h4,h5,h6{margin-top:0;}p{margin-top:0;margin-bottom:", theme.spacing[16], ";}abbr[title],abbr[data-original-title]{text-decoration:underline;text-decoration:underline dotted;cursor:help;border-bottom:0;}address{margin-bottom:1rem;font-style:normal;line-height:inherit;}ol,ul,dl{margin-top:0;margin-bottom:1rem;}ol ol,ul ul,ol ul,ul ol{margin-bottom:0;}dt{font-weight:", theme.fontWeight.title, ";}dd{margin-bottom:0.5rem;margin-left:0;}blockquote{margin:0 0 1rem;}dfn{font-style:italic;}b,strong{font-weight:", theme.fontWeight.title, ";}small{font-size:", theme.fontSize[14], ";}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline;}sub{bottom:-0.25em;}sup{top:-0.5em;}a{color:", theme.colors.primary, ";text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects;&:hover{text-decoration:underline;}}a:not([href]):not([tabindex]){color:inherit;text-decoration:none;&:hover,&:focus{color:inherit;text-decoration:none;}&:focus{outline:0;}}pre,code,kbd,samp{font-family:monospace,monospace;font-size:1em;}pre{margin-top:0;margin-bottom:1rem;overflow:auto;/* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */-ms-overflow-style:scrollbar;}figure{margin:0 0 1rem;}img{vertical-align:middle;border-style:none;}svg:not(:root){overflow:hidden;}table{border-collapse:collapse;}caption{padding-top:", theme.spacing[16], ";padding-bottom:", theme.spacing[16], ";color:", theme.spacing[16], ";text-align:left;caption-side:bottom;}th{text-align:inherit;}label{display:inline-block;margin-bottom:0;}button{border-radius:0;}button:focus-visible{outline:1px dotted;outline:5px auto -webkit-focus-ring-color;}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit;}button,input{overflow:visible;}button,select{text-transform:none;}button,html [type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;}input[type='radio'],input[type='checkbox']{box-sizing:border-box;padding:0;}input[type='date'],input[type='time'],input[type='datetime-local'],input[type='month']{-webkit-appearance:listbox;}textarea{overflow:auto;resize:vertical;}fieldset{min-width:0;padding:0;margin:0;border:0;}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:0.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal;}progress{vertical-align:baseline;}[type='number']::-webkit-inner-spin-button,[type='number']::-webkit-outer-spin-button{height:auto;}[type='search']{outline-offset:-2px;-webkit-appearance:none;}[type='search']::-webkit-search-cancel-button,[type='search']::-webkit-search-decoration{-webkit-appearance:none;}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button;}output{display:inline-block;}summary{display:list-item;cursor:pointer;}template{display:none;}[hidden]{display:none!important;};label:rebootStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/globals/Reboot.tsx"],"names":[],"mappings":"AAIwB","file":"../../src/globals/Reboot.tsx","sourcesContent":["import { css, Global } from '@emotion/react';\n\nimport { coreTheme as theme } from '../themes';\n\nconst rebootStyles = css`\n  /**\n  * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n  * Reboot\n  * Normalization of HTML elements, manually forked from Normalize.css to remove\n  * styles targeting irrelevant browsers while applying new styles.\n  * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n  * Document\n  * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n  * 2 Change the default font family in all browsers.\n  * 3 Correct the line height in all browsers.\n  * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n  * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n  *    we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n  * 6 Change the default tap highlight to be completely transparent in iOS.\n*/\n\n  *,\n  *::before,\n  *::after {\n    /* This is changed from content-box to border-box as all of our css relies on it */\n    box-sizing: border-box; /** 1 */\n  }\n\n  html {\n    font-family: sans-serif; /** 2 */\n    line-height: 1.15; /** 3 */\n    -webkit-text-size-adjust: 100%; /** 4 */\n    -ms-text-size-adjust: 100%; /** 4 */\n    -ms-overflow-style: scrollbar; /** 5 */\n    -webkit-tap-highlight-color: rgba(0, 0, 0, 0); /** 6 */\n  }\n\n  /**Shim for \"new\" HTML5 structural elements to display correctly (IE10, older browsers) */\n\n  article,\n  aside,\n  dialog,\n  figcaption,\n  figure,\n  footer,\n  header,\n  hgroup,\n  main,\n  nav,\n  section {\n    display: block;\n  }\n  /** Body\n   1. Remove the margin in all browsers.\n   2. As a best practice, apply a default \\`background-color\\`.\n   3. Set an explicit initial text-align value so that we can later use the\n      the \\`inherit\\` value on things like \\`<th>\\` elements.\n   */\n\n  body {\n    margin: 0;\n    font-family: ${theme.fontFamily.base};\n    font-weight: ${theme.fontWeight.base};\n    line-height: ${theme.lineHeight.base};\n    color: ${theme.colors.text};\n    text-align: left;\n    background-color: ${theme.colors.background};\n  }\n\n  /* Suppress the focus outline on elements that cannot be accessed via keyboard.\n  This prevents an unwanted focus outline from appearing around elements that\n  might still respond to pointer events.\n Credit: https://github.com/suitcss/base */\n\n  [tabindex='-1']:focus {\n    outline: 0 !important;\n  }\n\n  /*\n  Content grouping\n 1. Add the correct box sizing in Firefox.\n  2. Show the overflow in Edge and IE.\n*/\n\n  hr {\n    box-sizing: content-box;\n    /* 1 */\n    height: 0;\n    /* 2 */\n    overflow: visible;\n  }\n  /* Typography */\n  /*\n  Remove top margins from headings\n   By default, \\`<h1>\\`-\\`<h6>\\` all receive top and bottom margins. We nuke the top\n  margin for easier control within type scales as it avoids margin collapsing.\n*/\n\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6 {\n    margin-top: 0;\n  }\n\n  /*\n  Reset margins on paragraphs\n  Similarly, the top margin on \\`<p>\\`s get reset. However, we also reset the\n  bottom margin to use \\`rem\\` units instead of \\`em\\`.\n  */\n\n  p {\n    margin-top: 0;\n    margin-bottom: ${theme.spacing[16]};\n  }\n\n  /*\n  Abbreviations\n  1. Remove the bottom border in Firefox 39-.\n  2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n  3. Add explicit cursor to indicate changed behavior.\n  4. Duplicate behavior to the data-* attribute for our tooltip plugin\n  */\n\n  abbr[title],\n  abbr[data-original-title] {\n    /* 4 */\n    text-decoration: underline;\n    text-decoration: underline dotted;\n    cursor: help;\n    border-bottom: 0;\n  }\n\n  address {\n    margin-bottom: 1rem;\n    font-style: normal;\n    line-height: inherit;\n  }\n\n  ol,\n  ul,\n  dl {\n    margin-top: 0;\n    margin-bottom: 1rem;\n  }\n\n  ol ol,\n  ul ul,\n  ol ul,\n  ul ol {\n    margin-bottom: 0;\n  }\n\n  dt {\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  dd {\n    /* Undo browser default */\n    margin-bottom: 0.5rem;\n    margin-left: 0;\n  }\n\n  blockquote {\n    margin: 0 0 1rem;\n  }\n\n  dfn {\n    /* Add the correct font style in Android 4.3- */\n    font-style: italic;\n  }\n\n  b,\n  strong {\n    /* Add the correct font weight in Chrome, Edge, and Safari */\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  small {\n    /* Add the correct font size in all browsers */\n    font-size: ${theme.fontSize[14]};\n  }\n\n  /*\n Prevent \\`sub\\` and \\`sup\\` elements from affecting the line height in\n  all browsers.\n*/\n  sub,\n  sup {\n    position: relative;\n    font-size: 75%;\n    line-height: 0;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n  sup {\n    top: -0.5em;\n  }\n\n  /*\n Links\n  Remove the gray background on active links in IE 10.\n  Remove gaps in links underline in iOS 8+ and Safari 8+.\n*/\n\n  a {\n    color: ${theme.colors.primary};\n    text-decoration: none;\n\n    background-color: transparent;\n    -webkit-text-decoration-skip: objects;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n\n  /*\n  And undo these styles for placeholder links/named anchors (without href)\n  which have not been made explicitly keyboard-focusable (without tabindex).\n  It would be more straightforward to just use a[href] in previous block, but that\n  causes specificity issues in many other styles that are too complex to fix.\n  */\n\n  a:not([href]):not([tabindex]) {\n    color: inherit;\n    text-decoration: none;\n\n    &:hover,\n    &:focus {\n      color: inherit;\n      text-decoration: none;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n  }\n\n  /* Code */\n\n  pre,\n  code,\n  kbd,\n  samp {\n    /* Correct the inheritance and scaling of font size in all browsers. */\n    font-family: monospace, monospace;\n    /* Correct the odd \\`em\\` font sizing in all browsers.*/\n    font-size: 1em;\n  }\n  /* stylelint-enable font-family-no-duplicate-names */\n\n  pre {\n    /* Remove browser default top margin */\n    margin-top: 0;\n    /* Reset browser default of \\`1em\\` to use \\`rem\\`s */\n    margin-bottom: 1rem;\n    /* Don't allow content to break outside */\n    overflow: auto;\n    /* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */\n    /* we force a non-overlapping, non-auto-hiding scrollbar to counteract. */\n    -ms-overflow-style: scrollbar;\n  }\n\n  /*\nFigures\n*/\n  figure {\n    /* Apply a consistent margin strategy (matches our type styles). */\n    margin: 0 0 1rem;\n  }\n\n  /* Images and content */\n  img {\n    vertical-align: middle;\n    /* Remove the border on images inside links in IE 10-. */\n    border-style: none;\n  }\n\n  svg:not(:root) {\n    /* Hide the overflow in IE */\n    overflow: hidden;\n  }\n\n  /* Tables  */\n  table {\n    /* *  Prevent double borders */\n    border-collapse: collapse;\n  }\n\n  caption {\n    padding-top: ${theme.spacing[16]};\n    padding-bottom: ${theme.spacing[16]};\n    color: ${theme.spacing[16]};\n    text-align: left;\n    caption-side: bottom;\n  }\n\n  th {\n    /*  Matches default \\`<td>\\` alignment by inheriting from the \\`<body>\\`, or the\n  closest parent with a set \\`text-align\\`. */\n    text-align: inherit;\n  }\n\n  /* Forms */\n\n  label {\n    /* Allow labels to use \\`margin\\` for spacing. */\n    display: inline-block;\n    margin-bottom: 0;\n  }\n\n  /* Remove the default \\`border-radius\\` that macOS Chrome adds.\n Details at https://github.com/twbs/bootstrap/issues/24093     */\n\n  button {\n    border-radius: 0;\n  }\n\n  /*\n  Work around a Firefox/IE bug where the transparent \\`button\\` background\n  results in a loss of the default \\`button\\` focus styles.\n  Credit: https://github.com/suitcss/base/\n  */\n\n  button:focus-visible {\n    outline: 1px dotted;\n    outline: 5px auto -webkit-focus-ring-color;\n  }\n\n  input,\n  button,\n  select,\n  optgroup,\n  textarea {\n    /* Remove the margin in Firefox and Safari */\n    margin: 0;\n    font-family: inherit;\n    font-size: inherit;\n    line-height: inherit;\n  }\n\n  button,\n  input {\n    /* Show the overflow in Edge */\n    overflow: visible;\n  }\n\n  button,\n  select {\n    /* Remove the inheritance of text transform in Firefox */\n    text-transform: none;\n  }\n\n  /*\n  1. Prevent a WebKit bug where (2) destroys native \\`audio\\` and \\`video\\`\n    controls in Android 4.\n  2. Correct the inability to style clickable types in iOS and Safari.\n  */\n  button,\n  html [type='button'],\n  [type='reset'],\n  [type='submit'] {\n    /* 2 */\n    -webkit-appearance: button;\n  }\n\n  input[type='radio'],\n  input[type='checkbox'] {\n    /*  1. Add the correct box sizing in IE 10- */\n    box-sizing: border-box;\n    /* 2. Remove the padding in IE 10- */\n    padding: 0;\n  }\n\n  input[type='date'],\n  input[type='time'],\n  input[type='datetime-local'],\n  input[type='month'] {\n    /* Remove the default appearance of temporal inputs to avoid a Mobile Safari\n    bug where setting a custom line-height prevents text from being vertically\n    centered within the input.\n    See https://bugs.webkit.org/show_bug.cgi?id=139848\n    and https://github.com/twbs/bootstrap/issues/11266 */\n    -webkit-appearance: listbox;\n  }\n\n  textarea {\n    /* Remove the default vertical scrollbar in IE. */\n    overflow: auto;\n    /* Textareas should really only resize vertically so they don't break their (horizontal) containers. */\n    resize: vertical;\n  }\n\n  fieldset {\n    /* Browsers set a default \\`min-width: min-content;\\` on fieldsets,\n  unlike e.g. \\`<div>\\`s, which have \\`min-width: 0;\\` by default.\n  So we reset that to ensure fieldsets behave more like a standard block element.\n  See https://github.com/twbs/bootstrap/issues/12359\n  and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements */\n    min-width: 0;\n    /* Reset the default outline behavior of fieldsets so they don't affect page layout.*/\n    padding: 0;\n    margin: 0;\n    border: 0;\n  }\n\n  /* 1. Correct the text wrapping in Edge and IE. */\n  /* 2. Correct the color inheritance from \\`fieldset\\` elements in IE. */\n  legend {\n    display: block;\n    width: 100%;\n    /* 1 */\n    max-width: 100%;\n    padding: 0;\n    margin-bottom: 0.5rem;\n    font-size: 1.5rem;\n    line-height: inherit;\n    /* 2 */\n    color: inherit;\n    /* 1 */\n    white-space: normal;\n  }\n\n  progress {\n    /* Add the correct vertical alignment in Chrome, Firefox, and Opera. */\n    vertical-align: baseline;\n  }\n\n  /* Correct the cursor style of increment and decrement buttons in Chrome. */\n  [type='number']::-webkit-inner-spin-button,\n  [type='number']::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  [type='search'] {\n    /*\n    This overrides the extra rounded corners on search inputs in iOS so that our\n    \\`.form-control\\` class can properly style them. Note that this cannot simply\n    be added to \\`.form-control\\` as it's not specific enough. For details, see\n    https://github.com/twbs/bootstrap/issues/11586.\n    */\n    /* 2. Correct the outline style in Safari. */\n    outline-offset: -2px;\n    -webkit-appearance: none;\n  }\n\n  /* Remove the inner padding and cancel buttons in Chrome and Safari on macOS. */\n\n  [type='search']::-webkit-search-cancel-button,\n  [type='search']::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  /*\n  1. Correct the inability to style clickable types in iOS and Safari.\n  2. Change font properties to \\`inherit\\` in Safari.\n  */\n  ::-webkit-file-upload-button {\n    /* 2 */\n    font: inherit;\n    /* 1 */\n    -webkit-appearance: button;\n  }\n\n  /* Correct element displays */\n\n  output {\n    display: inline-block;\n  }\n\n  summary {\n    /* Add the correct display in all browsers */\n    display: list-item;\n    cursor: pointer;\n  }\n\n  template {\n    /* Add the correct display in IE */\n    display: none;\n  }\n\n  /*\n  Always hide an element with the \\`hidden\\` HTML attribute (from PureCSS).\n  Needed for proper display in IE 10-.\n  */\n  [hidden] {\n    display: none !important;\n  }\n`;\n\nexport const Reboot = () => <Global styles={rebootStyles} />;\n"]} */"));
5
+ export var Reboot = function Reboot() {
6
+ return /*#__PURE__*/_jsx(Global, {
7
+ styles: rebootStyles
8
+ });
9
+ };