@codecademy/gamut-styles 16.1.3 → 16.1.4-alpha.ab0105.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,22 +1,20 @@
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 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() {
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 = () => {
20
18
  return /*#__PURE__*/_jsx(_Fragment, {
21
19
  children: createFontLinks()
22
20
  });
@@ -1,41 +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 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; }
15
1
  import { getContrast } from 'polished';
16
2
  import { forwardRef, useCallback, useMemo } from 'react';
17
3
  import { ColorMode, useColorModes } from './ColorMode';
18
4
  import { jsx as _jsx } from "react/jsx-runtime";
19
- var isColorAlias = function isColorAlias(mode, color) {
5
+ const isColorAlias = (mode, color) => {
20
6
  return Object.keys(mode).includes(color);
21
7
  };
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];
8
+ export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
9
+ let {
10
+ bg,
11
+ ...rest
12
+ } = _ref;
13
+ const [active, activeColors, modes, getColorValue] = useColorModes();
14
+
31
15
  /** If a color alias was used then look up the true color key from the active mode */
32
- var trueColor = useMemo(function () {
16
+ const trueColor = useMemo(() => {
33
17
  if (isColorAlias(activeColors, bg)) {
34
18
  return activeColors[bg];
35
19
  }
36
20
  return bg;
37
21
  }, [bg, activeColors]);
38
- var getTextContrast = useCallback(function (foreground) {
22
+ const getTextContrast = useCallback(foreground => {
39
23
  return getContrast(getColorValue(foreground), getColorValue(trueColor));
40
24
  }, [trueColor, getColorValue]);
41
25
 
@@ -49,10 +33,12 @@ export var Background = /*#__PURE__*/forwardRef(function (_ref, ref) {
49
33
  * This does not guarantee a level of A/AA/AA compliance.
50
34
  */
51
35
 
52
- var accessibleMode = useMemo(function () {
53
- var activeMode = modes[active],
54
- otherModes = _objectWithoutProperties(modes, [active].map(_toPropertyKey));
55
- var possibleModes = Object.entries(otherModes);
36
+ const accessibleMode = useMemo(() => {
37
+ const {
38
+ [active]: activeMode,
39
+ ...otherModes
40
+ } = modes;
41
+ const possibleModes = Object.entries(otherModes);
56
42
 
57
43
  /**
58
44
  * Reduce all remaining modes to the mode key with the highest contrast
@@ -62,25 +48,22 @@ export var Background = /*#__PURE__*/forwardRef(function (_ref, ref) {
62
48
  * it will likely fail to return a mode outside of the lightest and
63
49
  * darkest versions.
64
50
  */
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);
51
+ const [highestContrastMode] = possibleModes.reduce((_ref2, _ref3) => {
52
+ let [prevMode, prevContrast] = _ref2;
53
+ let [mode, {
54
+ text
55
+ }] = _ref3;
56
+ const contrast = getTextContrast(text);
73
57
 
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];
58
+ // Keep the higher contrast mode.
59
+ return contrast > prevContrast ? [mode, contrast] : [prevMode, prevContrast];
60
+ }, [active, getTextContrast(activeMode.text)]);
79
61
  return highestContrastMode;
80
62
  }, [modes, active, getTextContrast]);
81
- return /*#__PURE__*/_jsx(ColorMode, _objectSpread(_objectSpread({}, rest), {}, {
63
+ return /*#__PURE__*/_jsx(ColorMode, {
64
+ ...rest,
82
65
  mode: accessibleMode,
83
66
  bg: bg,
84
67
  ref: ref
85
- }));
68
+ });
86
69
  });
package/dist/ColorMode.js CHANGED
@@ -1,18 +1,4 @@
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
1
  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); }
16
2
  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); }
17
3
  import { serializeTokens, variance } from '@codecademy/variance';
18
4
  import { ThemeProvider, useTheme } from '@emotion/react';
@@ -21,26 +7,31 @@ import { createContext, forwardRef, useContext, useEffect, useMemo, useState } f
21
7
  import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
22
8
  import { styledOptions } from './variance/utils';
23
9
  import { jsx as _jsx } from "react/jsx-runtime";
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;
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;
33
21
  };
34
- var BackgroundCurrentContext = /*#__PURE__*/createContext({
22
+ const BackgroundCurrentContext = /*#__PURE__*/createContext({
35
23
  'background-current': undefined
36
24
  });
37
25
  export function useColorModes() {
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);
26
+ const bgCurrent = useContext(BackgroundCurrentContext);
27
+ const {
28
+ mode,
29
+ modes,
30
+ _getColorValue: getColorValue
31
+ } = useTheme() || {};
32
+ const modesCopy = {
33
+ ...modes
34
+ };
44
35
  if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
45
36
  /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
46
37
  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.
@@ -48,98 +39,100 @@ export function useColorModes() {
48
39
 
49
40
  modesCopy[mode]['background-current'] = bgCurrent['background-current'];
50
41
  }
51
- return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
42
+ return [mode, modesCopy?.[mode], modes, getColorValue];
52
43
  }
53
44
  export function useCurrentMode(mode) {
54
- var _useColorModes = useColorModes(),
55
- _useColorModes2 = _slicedToArray(_useColorModes, 1),
56
- activeMode = _useColorModes2[0];
57
- return mode !== null && mode !== void 0 ? mode : activeMode;
45
+ const [activeMode] = useColorModes();
46
+ return mode ?? activeMode;
58
47
  }
59
48
  export function usePrefersDarkMode() {
60
- var _useState = useState(false),
61
- _useState2 = _slicedToArray(_useState, 2),
62
- prefersDarkMode = _useState2[0],
63
- setPrefersDarkMode = _useState2[1];
64
- useEffect(function () {
49
+ const [prefersDarkMode, setPrefersDarkMode] = useState(false);
50
+ useEffect(() => {
65
51
  function onChange(event) {
66
52
  setPrefersDarkMode(event.matches);
67
53
  }
68
54
  if (window && 'matchMedia' in window) {
69
- var mq = window.matchMedia('(prefers-color-scheme: dark)');
55
+ const mq = window.matchMedia('(prefers-color-scheme: dark)');
70
56
  if (mq && 'addEventListener' in mq) {
71
57
  setPrefersDarkMode(mq.matches);
72
58
  mq.addEventListener('change', onChange);
73
- return function () {
74
- return mq.removeEventListener('change', onChange);
75
- };
59
+ return () => mq.removeEventListener('change', onChange);
76
60
  }
77
61
  }
78
62
  }, []);
79
63
  return prefersDarkMode;
80
64
  }
81
- export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
65
+ export const VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
82
66
  target: "e1skjn880",
83
67
  label: "VariableProvider"
84
- }, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
85
- var variables = _ref3.variables;
68
+ }, styledOptions(['variables', 'alwaysSetVariables'])))(_ref2 => {
69
+ let {
70
+ variables
71
+ } = _ref2;
86
72
  return variables;
87
73
  }, css({
88
74
  textColor: 'text'
89
75
  }), 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"]} */");
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"]);
76
+ export const ColorMode = /*#__PURE__*/forwardRef((_ref3, ref) => {
77
+ let {
78
+ mode: preference,
79
+ alwaysSetVariables,
80
+ bg,
81
+ ...rest
82
+ } = _ref3;
95
83
  // checks if the user has set 'system' as their color mode preference
96
84
  // then sets the color mode
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;
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;
104
94
  // This makes sure the background-current context is always set to the correct color + not the semantic color name.
105
- var currentParentBg = useContext(BackgroundCurrentContext);
106
- var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
95
+ const currentParentBg = useContext(BackgroundCurrentContext);
96
+ const bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
107
97
 
108
98
  /** Serialize color variables for the current mode
109
99
  * 1. If all variables are required add all mode variables to the current context
110
100
  * 2. If the user has specified a background color - set that color to the current-bg
111
101
  * 3. If not
112
102
  */
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;
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]);
122
113
  if (active === mode) {
123
- var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
114
+ const vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
124
115
  return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
125
116
  value: {
126
117
  'background-current': bgCurrent
127
118
  },
128
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
119
+ children: /*#__PURE__*/_jsx(VariableProvider, {
120
+ ...rest,
129
121
  variables: vars,
130
122
  bg: contextBg,
131
123
  ref: ref
132
- }))
124
+ })
133
125
  });
134
126
  }
135
127
  return /*#__PURE__*/_jsx(ThemeProvider, {
136
128
  theme: {
137
- mode: mode
129
+ mode
138
130
  },
139
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
131
+ children: /*#__PURE__*/_jsx(VariableProvider, {
132
+ ...rest,
140
133
  variables: variables,
141
134
  bg: contextBg,
142
135
  ref: ref
143
- }))
136
+ })
144
137
  });
145
138
  });
@@ -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 var GamutContext = /*#__PURE__*/React.createContext({
11
+ export const GamutContext = /*#__PURE__*/React.createContext({
12
12
  hasGlobals: false,
13
13
  hasCache: false
14
14
  });
15
15
  GamutContext.displayName = 'GamutContext';
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;
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;
31
31
 
32
32
  // Do not initialize a new cache if one has been provided as props
33
- var activeCache = useRef(shouldCreateCache && (cache !== null && cache !== void 0 ? cache : createEmotionCache()));
34
- var contextValue = {
33
+ const activeCache = useRef(shouldCreateCache && (cache ?? createEmotionCache()));
34
+ const contextValue = {
35
35
  hasGlobals: shouldInsertGlobals,
36
36
  hasCache: shouldCreateCache
37
37
  };
38
- var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
38
+ const 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,25 +1,13 @@
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); }
13
1
  import createCache from '@emotion/cache';
14
2
  import { prefixer } from 'stylis';
15
3
  import { focusVisible } from './stylisPlugins';
16
- export var EMOTION_KEY = 'gamut';
17
- export var EMOTION_CONTAINER = 'emotion-styles';
18
- var getEmotionNode = function getEmotionNode() {
4
+ export const EMOTION_KEY = 'gamut';
5
+ export const EMOTION_CONTAINER = 'emotion-styles';
6
+ const getEmotionNode = () => {
19
7
  if (typeof document === 'undefined') {
20
8
  return;
21
9
  }
22
- var node = document.getElementById(EMOTION_CONTAINER);
10
+ let node = document.getElementById(EMOTION_CONTAINER);
23
11
  if (node) return node;
24
12
  node = document.createElement('div');
25
13
  node.setAttribute('id', EMOTION_CONTAINER);
@@ -28,13 +16,10 @@ var getEmotionNode = function getEmotionNode() {
28
16
  document.getElementsByTagName('body')[0].prepend(node);
29
17
  return node;
30
18
  };
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
- };
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
+ });
@@ -1,9 +1,9 @@
1
- export var focusVisible = function focusVisible(element) {
1
+ export const 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(function (prop) {
5
- var poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
6
- return "".concat(prop, ", ").concat(poly);
4
+ element.props = element.props.map(prop => {
5
+ const poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
6
+ return `${prop}, ${poly}`;
7
7
  });
8
8
  }
9
9
  return undefined;
@@ -1,9 +1,7 @@
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
- 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
- };
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
+ });