@codecademy/gamut-styles 17.2.0-alpha.89adc0.0 → 17.2.0-alpha.cbe1de.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.
Files changed (43) hide show
  1. package/dist/AssetProvider.d.ts +2 -3
  2. package/dist/AssetProvider.js +15 -18
  3. package/dist/Background.d.ts +1 -1
  4. package/dist/Background.js +28 -45
  5. package/dist/ColorMode.d.ts +21 -23
  6. package/dist/ColorMode.js +70 -77
  7. package/dist/GamutProvider.js +20 -22
  8. package/dist/cache/createEmotionCache.js +11 -26
  9. package/dist/cache/stylisPlugins/focusVisible.js +4 -4
  10. package/dist/globals/Reboot.d.ts +1 -2
  11. package/dist/globals/Reboot.js +4 -6
  12. package/dist/globals/Typography.d.ts +1 -2
  13. package/dist/globals/Typography.js +18 -20
  14. package/dist/globals/Variables.js +12 -21
  15. package/dist/remoteAssets/fonts.d.ts +1 -1
  16. package/dist/remoteAssets/fonts.js +8 -12
  17. package/dist/styles/boxShadow.js +10 -20
  18. package/dist/styles/fontSmoothing.js +5 -7
  19. package/dist/styles/noSelect.js +1 -1
  20. package/dist/styles/pxRem.js +3 -3
  21. package/dist/styles/responsive.js +4 -6
  22. package/dist/styles/screenReaderOnly.js +2 -2
  23. package/dist/styles/transitionConcat.js +4 -4
  24. package/dist/themes/admin.d.ts +2 -2
  25. package/dist/themes/admin.js +1 -1
  26. package/dist/themes/core.js +14 -12
  27. package/dist/themes/platform.d.ts +2 -2
  28. package/dist/themes/platform.js +1 -1
  29. package/dist/utilities/themed.js +4 -2
  30. package/dist/variables/borderRadii.js +1 -1
  31. package/dist/variables/colors.js +19 -18
  32. package/dist/variables/deprecated-colors.js +17 -16
  33. package/dist/variables/elements.js +1 -1
  34. package/dist/variables/responsive.js +4 -6
  35. package/dist/variables/spacing.js +1 -1
  36. package/dist/variables/timing.js +6 -6
  37. package/dist/variables/typography.js +14 -8
  38. package/dist/variance/config.js +49 -32
  39. package/dist/variance/index.js +1 -2
  40. package/dist/variance/props.js +16 -16
  41. package/dist/variance/utils.d.ts +3 -3
  42. package/dist/variance/utils.js +6 -14
  43. package/package.json +3 -3
package/dist/ColorMode.js CHANGED
@@ -1,19 +1,5 @@
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
- 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); }
2
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
17
3
  import { serializeTokens, variance } from '@codecademy/variance';
18
4
  import { ThemeProvider, useTheme } from '@emotion/react';
19
5
  import mapValues from 'lodash/mapValues';
@@ -22,26 +8,31 @@ import { createContext, forwardRef, useContext, useEffect, useMemo, useState } f
22
8
  import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
23
9
  import { styledOptions } from './variance/utils';
24
10
  import { jsx as _jsx } from "react/jsx-runtime";
25
- export var providerProps = variance.compose(layout, color, grid, flex, positioning, space, border, background);
26
- export var modeColorProps = function modeColorProps(_ref) {
27
- var theme = _ref.theme,
28
- mode = _ref.mode;
29
- if (!theme || !mode || mode === (theme === null || theme === void 0 ? void 0 : theme.mode)) return {};
30
- var colors = theme.colors;
31
- return serializeTokens(mapValues(theme === null || theme === void 0 ? void 0 : theme.modes[mode], function (color) {
32
- return colors[color];
33
- }), 'color', theme).variables;
11
+ export const providerProps = variance.compose(layout, color, grid, flex, positioning, space, border, background);
12
+ export const modeColorProps = _ref => {
13
+ let {
14
+ theme,
15
+ mode
16
+ } = _ref;
17
+ if (!theme || !mode || mode === theme?.mode) return {};
18
+ const {
19
+ colors
20
+ } = theme;
21
+ return serializeTokens(mapValues(theme?.modes[mode], color => colors[color]), 'color', theme).variables;
34
22
  };
35
- var BackgroundCurrentContext = /*#__PURE__*/createContext({
23
+ const BackgroundCurrentContext = /*#__PURE__*/createContext({
36
24
  'background-current': undefined
37
25
  });
38
26
  export function useColorModes() {
39
- var bgCurrent = useContext(BackgroundCurrentContext);
40
- var _ref2 = useTheme() || {},
41
- mode = _ref2.mode,
42
- modes = _ref2.modes,
43
- getColorValue = _ref2._getColorValue;
44
- var modesCopy = _objectSpread({}, modes);
27
+ const bgCurrent = useContext(BackgroundCurrentContext);
28
+ const {
29
+ mode,
30
+ modes,
31
+ _getColorValue: getColorValue
32
+ } = useTheme() || {};
33
+ const modesCopy = {
34
+ ...modes
35
+ };
45
36
  if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
46
37
  /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
47
38
  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.
@@ -49,98 +40,100 @@ export function useColorModes() {
49
40
 
50
41
  modesCopy[mode]['background-current'] = bgCurrent['background-current'];
51
42
  }
52
- return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
43
+ return [mode, modesCopy?.[mode], modes, getColorValue];
53
44
  }
54
45
  export function useCurrentMode(mode) {
55
- var _useColorModes = useColorModes(),
56
- _useColorModes2 = _slicedToArray(_useColorModes, 1),
57
- activeMode = _useColorModes2[0];
58
- return mode !== null && mode !== void 0 ? mode : activeMode;
46
+ const [activeMode] = useColorModes();
47
+ return mode ?? activeMode;
59
48
  }
60
49
  export function usePrefersDarkMode() {
61
- var _useState = useState(false),
62
- _useState2 = _slicedToArray(_useState, 2),
63
- prefersDarkMode = _useState2[0],
64
- setPrefersDarkMode = _useState2[1];
65
- useEffect(function () {
50
+ const [prefersDarkMode, setPrefersDarkMode] = useState(false);
51
+ useEffect(() => {
66
52
  function onChange(event) {
67
53
  setPrefersDarkMode(event.matches);
68
54
  }
69
55
  if (window && 'matchMedia' in window) {
70
- var mq = window.matchMedia('(prefers-color-scheme: dark)');
56
+ const mq = window.matchMedia('(prefers-color-scheme: dark)');
71
57
  if (mq && 'addEventListener' in mq) {
72
58
  setPrefersDarkMode(mq.matches);
73
59
  mq.addEventListener('change', onChange);
74
- return function () {
75
- return mq.removeEventListener('change', onChange);
76
- };
60
+ return () => mq.removeEventListener('change', onChange);
77
61
  }
78
62
  }
79
63
  }, []);
80
64
  return prefersDarkMode;
81
65
  }
82
- export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
66
+ export const VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
83
67
  target: "e1skjn880",
84
68
  label: "VariableProvider"
85
- }, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
86
- var variables = _ref3.variables;
69
+ }, styledOptions(['variables', 'alwaysSetVariables'])))(_ref2 => {
70
+ let {
71
+ variables
72
+ } = _ref2;
87
73
  return variables;
88
74
  }, css({
89
75
  textColor: 'text'
90
76
  }), providerProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ColorMode.tsx"],"names":[],"mappings":"AAqIgC","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 from 'lodash/mapValues';\nimport pick from 'lodash/pick';\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"]} */");
91
- export var ColorMode = /*#__PURE__*/forwardRef(function (_ref4, ref) {
92
- var preference = _ref4.mode,
93
- alwaysSetVariables = _ref4.alwaysSetVariables,
94
- bg = _ref4.bg,
95
- rest = _objectWithoutProperties(_ref4, ["mode", "alwaysSetVariables", "bg"]);
77
+ export const ColorMode = /*#__PURE__*/forwardRef((_ref3, ref) => {
78
+ let {
79
+ mode: preference,
80
+ alwaysSetVariables,
81
+ bg,
82
+ ...rest
83
+ } = _ref3;
96
84
  // checks if the user has set 'system' as their color mode preference
97
85
  // then sets the color mode
98
- var prefersDarkMode = usePrefersDarkMode();
99
- var mode = preference === 'system' ? prefersDarkMode ? 'dark' : 'light' : preference;
100
- var theme = useTheme();
101
- var modes = theme.modes,
102
- active = theme.mode,
103
- colors = theme.colors;
104
- var contextBg = bg ? 'background-current' : undefined;
86
+ const prefersDarkMode = usePrefersDarkMode();
87
+ const mode = preference === 'system' ? prefersDarkMode ? 'dark' : 'light' : preference;
88
+ const theme = useTheme();
89
+ const {
90
+ modes,
91
+ mode: active,
92
+ colors
93
+ } = theme;
94
+ const contextBg = bg ? 'background-current' : undefined;
105
95
  // This makes sure the background-current context is always set to the correct color + not the semantic color name.
106
- var currentParentBg = useContext(BackgroundCurrentContext);
107
- var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
96
+ const currentParentBg = useContext(BackgroundCurrentContext);
97
+ const bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
108
98
 
109
99
  /** Serialize color variables for the current mode
110
100
  * 1. If all variables are required add all mode variables to the current context
111
101
  * 2. If the user has specified a background color - set that color to the current-bg
112
102
  * 3. If not
113
103
  */
114
- var _useMemo = useMemo(function () {
115
- return serializeTokens(mapValues(modes[mode], function (color, key) {
116
- if (key === 'background-current' && typeof bg !== 'undefined') {
117
- return colors[bg];
118
- }
119
- return colors[color];
120
- }), 'color', theme);
121
- }, [colors, mode, modes, theme, bg]),
122
- variables = _useMemo.variables;
104
+ const {
105
+ variables
106
+ } = useMemo(() => {
107
+ return serializeTokens(mapValues(modes[mode], (color, key) => {
108
+ if (key === 'background-current' && typeof bg !== 'undefined') {
109
+ return colors[bg];
110
+ }
111
+ return colors[color];
112
+ }), 'color', theme);
113
+ }, [colors, mode, modes, theme, bg]);
123
114
  if (active === mode) {
124
- var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
115
+ const vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
125
116
  return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
126
117
  value: {
127
118
  'background-current': bgCurrent
128
119
  },
129
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
120
+ children: /*#__PURE__*/_jsx(VariableProvider, {
121
+ ...rest,
130
122
  variables: vars,
131
123
  bg: contextBg,
132
124
  ref: ref
133
- }))
125
+ })
134
126
  });
135
127
  }
136
128
  return /*#__PURE__*/_jsx(ThemeProvider, {
137
129
  theme: {
138
- mode: mode
130
+ mode
139
131
  },
140
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
132
+ children: /*#__PURE__*/_jsx(VariableProvider, {
133
+ ...rest,
141
134
  variables: variables,
142
135
  bg: contextBg,
143
136
  ref: ref
144
- }))
137
+ })
145
138
  });
146
139
  });
@@ -5,37 +5,35 @@ import { createEmotionCache } from './cache';
5
5
  import { Reboot, Typography } from './globals';
6
6
  import { Variables } from './globals/Variables';
7
7
  import { coreTheme } from './themes/core';
8
- import { jsx as _jsx } from "react/jsx-runtime";
9
- import { Fragment as _Fragment } from "react/jsx-runtime";
10
- import { jsxs as _jsxs } from "react/jsx-runtime";
11
- export var GamutContext = /*#__PURE__*/React.createContext({
8
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
9
+ export const GamutContext = /*#__PURE__*/React.createContext({
12
10
  hasGlobals: false,
13
11
  hasCache: false
14
12
  });
15
13
  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;
14
+ export const GamutProvider = _ref => {
15
+ let {
16
+ children,
17
+ cache,
18
+ theme = coreTheme,
19
+ variables,
20
+ useGlobals = true,
21
+ useCache = true
22
+ } = _ref;
23
+ const {
24
+ hasGlobals,
25
+ hasCache
26
+ } = useContext(GamutContext);
27
+ const shouldCreateCache = useCache && !hasCache;
28
+ const shouldInsertGlobals = useGlobals && !hasGlobals;
31
29
 
32
30
  // 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 = {
31
+ const activeCache = useRef(shouldCreateCache && (cache ?? createEmotionCache()));
32
+ const contextValue = {
35
33
  hasGlobals: shouldInsertGlobals,
36
34
  hasCache: shouldCreateCache
37
35
  };
38
- var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
36
+ const globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
39
37
  children: [/*#__PURE__*/_jsx(Typography, {}), /*#__PURE__*/_jsx(Reboot, {}), /*#__PURE__*/_jsx(Variables, {
40
38
  variables: theme._variables
41
39
  }), 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,2 +1 @@
1
- /// <reference types="react" />
2
- export declare const Reboot: () => JSX.Element;
1
+ export declare const Reboot: () => import("react/jsx-runtime").JSX.Element;
@@ -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
+ });
@@ -1,2 +1 @@
1
- /// <reference types="react" />
2
- export declare const Typography: () => JSX.Element;
1
+ export declare const Typography: () => import("react/jsx-runtime").JSX.Element;
@@ -2,24 +2,22 @@ import { css, Global } from '@emotion/react';
2
2
  import { webFonts } from '../remoteAssets/fonts';
3
3
  import { coreTheme as theme } from '../themes';
4
4
  import { jsx as _jsx } from "react/jsx-runtime";
5
- var fontSize = theme.fontSize,
6
- spacing = theme.spacing,
7
- fontWeight = theme.fontWeight,
8
- lineHeight = theme.lineHeight;
9
- var typographyGlobals = /*#__PURE__*/css(webFonts.map(function (_ref) {
10
- var name = _ref.name,
11
- _ref$style = _ref.style,
12
- style = _ref$style === void 0 ? 'normal' : _ref$style,
13
- _ref$weight = _ref.weight,
14
- weight = _ref$weight === void 0 ? 'normal' : _ref$weight,
15
- extensions = _ref.extensions,
16
- filePath = _ref.filePath;
17
- return /*#__PURE__*/css("@font-face{font-display:swap;font-family:'", name, "';font-style:", style, ";font-weight:", weight, ";src:", extensions.map(function (ext) {
18
- return "url(\"".concat(filePath, ".").concat(ext, "\") format(\"").concat(ext, "\")");
19
- }).join(', '), ";};label:typographyGlobals;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nbG9iYWxzL1R5cG9ncmFwaHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVhIiwiZmlsZSI6Ii4uLy4uL3NyYy9nbG9iYWxzL1R5cG9ncmFwaHkudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBHbG9iYWwgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IHdlYkZvbnRzIH0gZnJvbSAnLi4vcmVtb3RlQXNzZXRzL2ZvbnRzJztcbmltcG9ydCB7IGNvcmVUaGVtZSBhcyB0aGVtZSB9IGZyb20gJy4uL3RoZW1lcyc7XG5cbmNvbnN0IHsgZm9udFNpemUsIHNwYWNpbmcsIGZvbnRXZWlnaHQsIGxpbmVIZWlnaHQgfSA9IHRoZW1lO1xuXG5jb25zdCB0eXBvZ3JhcGh5R2xvYmFscyA9IGNzc2BcbiAgJHt3ZWJGb250cy5tYXAoXG4gICAgKHtcbiAgICAgIG5hbWUsXG4gICAgICBzdHlsZSA9ICdub3JtYWwnLFxuICAgICAgd2VpZ2h0ID0gJ25vcm1hbCcsXG4gICAgICBleHRlbnNpb25zLFxuICAgICAgZmlsZVBhdGgsXG4gICAgfSkgPT4gY3NzYFxuICAgICAgQGZvbnQtZmFjZSB7XG4gICAgICAgIGZvbnQtZGlzcGxheTogc3dhcDtcbiAgICAgICAgZm9udC1mYW1pbHk6ICcke25hbWV9JztcbiAgICAgICAgZm9udC1zdHlsZTogJHtzdHlsZX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke3dlaWdodH07XG4gICAgICAgIHNyYzogJHtleHRlbnNpb25zXG4gICAgICAgICAgLm1hcCgoZXh0KSA9PiBgdXJsKFwiJHtmaWxlUGF0aH0uJHtleHR9XCIpIGZvcm1hdChcIiR7ZXh0fVwiKWApXG4gICAgICAgICAgLmpvaW4oJywgJyl9O1xuICAgICAgfVxuICAgIGBcbiAgKX1cblxuICBoMSxcbiAgaDIsXG4gIGgzLFxuICBoNCxcbiAgaDUsXG4gIGg2IHtcbiAgICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmdbMTZdfTtcbiAgICBmb250LXdlaWdodDogJHtmb250V2VpZ2h0LnRpdGxlfTtcbiAgICBsaW5lLWhlaWdodDogJHtsaW5lSGVpZ2h0LnRpdGxlfTtcbiAgfVxuXG4gIGgxIHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbNjRdfTtcbiAgfVxuICBoMiB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzQ0XX07XG4gIH1cbiAgaDMge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVszNF19O1xuICB9XG4gIGg0IHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbMjZdfTtcbiAgfVxuICBoNSB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzIyXX07XG4gIH1cbiAgaDYge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVsyMF19O1xuICB9XG5cbiAgc21hbGwge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVsxNF19O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRXZWlnaHQuYmFzZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUeXBvZ3JhcGh5ID0gKCkgPT4gPEdsb2JhbCBzdHlsZXM9e3R5cG9ncmFwaHlHbG9iYWxzfSAvPjtcbiJdfQ== */"));
5
+ const {
6
+ fontSize,
7
+ spacing,
8
+ fontWeight,
9
+ lineHeight
10
+ } = theme;
11
+ const typographyGlobals = /*#__PURE__*/css(webFonts.map(_ref => {
12
+ let {
13
+ name,
14
+ style = 'normal',
15
+ weight = 'normal',
16
+ extensions,
17
+ filePath
18
+ } = _ref;
19
+ return /*#__PURE__*/css("@font-face{font-display:swap;font-family:'", name, "';font-style:", style, ";font-weight:", weight, ";src:", extensions.map(ext => `url("${filePath}.${ext}") format("${ext}")`).join(', '), ";};label:typographyGlobals;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nbG9iYWxzL1R5cG9ncmFwaHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVhIiwiZmlsZSI6Ii4uLy4uL3NyYy9nbG9iYWxzL1R5cG9ncmFwaHkudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBHbG9iYWwgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IHdlYkZvbnRzIH0gZnJvbSAnLi4vcmVtb3RlQXNzZXRzL2ZvbnRzJztcbmltcG9ydCB7IGNvcmVUaGVtZSBhcyB0aGVtZSB9IGZyb20gJy4uL3RoZW1lcyc7XG5cbmNvbnN0IHsgZm9udFNpemUsIHNwYWNpbmcsIGZvbnRXZWlnaHQsIGxpbmVIZWlnaHQgfSA9IHRoZW1lO1xuXG5jb25zdCB0eXBvZ3JhcGh5R2xvYmFscyA9IGNzc2BcbiAgJHt3ZWJGb250cy5tYXAoXG4gICAgKHtcbiAgICAgIG5hbWUsXG4gICAgICBzdHlsZSA9ICdub3JtYWwnLFxuICAgICAgd2VpZ2h0ID0gJ25vcm1hbCcsXG4gICAgICBleHRlbnNpb25zLFxuICAgICAgZmlsZVBhdGgsXG4gICAgfSkgPT4gY3NzYFxuICAgICAgQGZvbnQtZmFjZSB7XG4gICAgICAgIGZvbnQtZGlzcGxheTogc3dhcDtcbiAgICAgICAgZm9udC1mYW1pbHk6ICcke25hbWV9JztcbiAgICAgICAgZm9udC1zdHlsZTogJHtzdHlsZX07XG4gICAgICAgIGZvbnQtd2VpZ2h0OiAke3dlaWdodH07XG4gICAgICAgIHNyYzogJHtleHRlbnNpb25zXG4gICAgICAgICAgLm1hcCgoZXh0KSA9PiBgdXJsKFwiJHtmaWxlUGF0aH0uJHtleHR9XCIpIGZvcm1hdChcIiR7ZXh0fVwiKWApXG4gICAgICAgICAgLmpvaW4oJywgJyl9O1xuICAgICAgfVxuICAgIGBcbiAgKX1cblxuICBoMSxcbiAgaDIsXG4gIGgzLFxuICBoNCxcbiAgaDUsXG4gIGg2IHtcbiAgICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmdbMTZdfTtcbiAgICBmb250LXdlaWdodDogJHtmb250V2VpZ2h0LnRpdGxlfTtcbiAgICBsaW5lLWhlaWdodDogJHtsaW5lSGVpZ2h0LnRpdGxlfTtcbiAgfVxuXG4gIGgxIHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbNjRdfTtcbiAgfVxuICBoMiB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzQ0XX07XG4gIH1cbiAgaDMge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVszNF19O1xuICB9XG4gIGg0IHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbMjZdfTtcbiAgfVxuICBoNSB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzIyXX07XG4gIH1cbiAgaDYge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVsyMF19O1xuICB9XG5cbiAgc21hbGwge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVsxNF19O1xuICAgIGZvbnQtd2VpZ2h0OiAke2ZvbnRXZWlnaHQuYmFzZX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUeXBvZ3JhcGh5ID0gKCkgPT4gPEdsb2JhbCBzdHlsZXM9e3R5cG9ncmFwaHlHbG9iYWxzfSAvPjtcbiJdfQ== */"));
20
20
  }), " h1,h2,h3,h4,h5,h6{margin-bottom:", spacing[16], ";font-weight:", fontWeight.title, ";line-height:", lineHeight.title, ";}h1{font-size:", fontSize[64], ";}h2{font-size:", fontSize[44], ";}h3{font-size:", fontSize[34], ";}h4{font-size:", fontSize[26], ";}h5{font-size:", fontSize[22], ";}h6{font-size:", fontSize[20], ";}small{font-size:", fontSize[14], ";font-weight:", fontWeight.base, ";};label:typographyGlobals;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nbG9iYWxzL1R5cG9ncmFwaHkudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU82QiIsImZpbGUiOiIuLi8uLi9zcmMvZ2xvYmFscy9UeXBvZ3JhcGh5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgR2xvYmFsIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5pbXBvcnQgeyB3ZWJGb250cyB9IGZyb20gJy4uL3JlbW90ZUFzc2V0cy9mb250cyc7XG5pbXBvcnQgeyBjb3JlVGhlbWUgYXMgdGhlbWUgfSBmcm9tICcuLi90aGVtZXMnO1xuXG5jb25zdCB7IGZvbnRTaXplLCBzcGFjaW5nLCBmb250V2VpZ2h0LCBsaW5lSGVpZ2h0IH0gPSB0aGVtZTtcblxuY29uc3QgdHlwb2dyYXBoeUdsb2JhbHMgPSBjc3NgXG4gICR7d2ViRm9udHMubWFwKFxuICAgICh7XG4gICAgICBuYW1lLFxuICAgICAgc3R5bGUgPSAnbm9ybWFsJyxcbiAgICAgIHdlaWdodCA9ICdub3JtYWwnLFxuICAgICAgZXh0ZW5zaW9ucyxcbiAgICAgIGZpbGVQYXRoLFxuICAgIH0pID0+IGNzc2BcbiAgICAgIEBmb250LWZhY2Uge1xuICAgICAgICBmb250LWRpc3BsYXk6IHN3YXA7XG4gICAgICAgIGZvbnQtZmFtaWx5OiAnJHtuYW1lfSc7XG4gICAgICAgIGZvbnQtc3R5bGU6ICR7c3R5bGV9O1xuICAgICAgICBmb250LXdlaWdodDogJHt3ZWlnaHR9O1xuICAgICAgICBzcmM6ICR7ZXh0ZW5zaW9uc1xuICAgICAgICAgIC5tYXAoKGV4dCkgPT4gYHVybChcIiR7ZmlsZVBhdGh9LiR7ZXh0fVwiKSBmb3JtYXQoXCIke2V4dH1cIilgKVxuICAgICAgICAgIC5qb2luKCcsICcpfTtcbiAgICAgIH1cbiAgICBgXG4gICl9XG5cbiAgaDEsXG4gIGgyLFxuICBoMyxcbiAgaDQsXG4gIGg1LFxuICBoNiB7XG4gICAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nWzE2XX07XG4gICAgZm9udC13ZWlnaHQ6ICR7Zm9udFdlaWdodC50aXRsZX07XG4gICAgbGluZS1oZWlnaHQ6ICR7bGluZUhlaWdodC50aXRsZX07XG4gIH1cblxuICBoMSB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzY0XX07XG4gIH1cbiAgaDIge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVs0NF19O1xuICB9XG4gIGgzIHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbMzRdfTtcbiAgfVxuICBoNCB7XG4gICAgZm9udC1zaXplOiAke2ZvbnRTaXplWzI2XX07XG4gIH1cbiAgaDUge1xuICAgIGZvbnQtc2l6ZTogJHtmb250U2l6ZVsyMl19O1xuICB9XG4gIGg2IHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbMjBdfTtcbiAgfVxuXG4gIHNtYWxsIHtcbiAgICBmb250LXNpemU6ICR7Zm9udFNpemVbMTRdfTtcbiAgICBmb250LXdlaWdodDogJHtmb250V2VpZ2h0LmJhc2V9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgVHlwb2dyYXBoeSA9ICgpID0+IDxHbG9iYWwgc3R5bGVzPXt0eXBvZ3JhcGh5R2xvYmFsc30gLz47XG4iXX0= */"));
21
- export var Typography = function Typography() {
22
- return /*#__PURE__*/_jsx(Global, {
23
- styles: typographyGlobals
24
- });
25
- };
21
+ export const Typography = () => /*#__PURE__*/_jsx(Global, {
22
+ styles: typographyGlobals
23
+ });
@@ -1,28 +1,19 @@
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 _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
3
- 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."); }
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 _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; }
6
- 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; } }
7
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
8
- 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; }
9
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
10
- 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); }
11
1
  import { css, Global } from '@emotion/react';
12
2
  import * as React from 'react';
13
- import { jsx as _jsx } from "react/jsx-runtime";
14
- import { Fragment as _Fragment } from "react/jsx-runtime";
15
- var scopeVariables = function scopeVariables(vars) {
16
- var scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ':root';
17
- return /*#__PURE__*/css(_defineProperty({}, scope, vars), ";label:scopeVariables;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nbG9iYWxzL1ZhcmlhYmxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0UiLCJmaWxlIjoiLi4vLi4vc3JjL2dsb2JhbHMvVmFyaWFibGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0Bjb2RlY2FkZW15L3ZhcmlhbmNlJztcbmltcG9ydCB7IGNzcywgR2xvYmFsIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5jb25zdCBzY29wZVZhcmlhYmxlcyA9ICh2YXJzOiBDU1NPYmplY3QsIHNjb3BlID0gJzpyb290JykgPT5cbiAgY3NzKHsgW3Njb3BlXTogdmFycyB9KTtcblxuZXhwb3J0IGNvbnN0IFZhcmlhYmxlczogUmVhY3QuRkM8e1xuICB2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIENTU09iamVjdD47XG59PiA9ICh7IHZhcmlhYmxlcyB9KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHtPYmplY3QuZW50cmllcyh2YXJpYWJsZXMpLm1hcCgoW2tleSwgdmFyc10pID0+IChcbiAgICAgICAgPEdsb2JhbCBrZXk9e2tleX0gc3R5bGVzPXtzY29wZVZhcmlhYmxlcyh2YXJzKX0gLz5cbiAgICAgICkpfVxuICAgIDwvPlxuICApO1xufTtcbiJdfQ== */"));
3
+ import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
4
+ const scopeVariables = function (vars) {
5
+ let scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ':root';
6
+ return /*#__PURE__*/css({
7
+ [scope]: vars
8
+ }, ";label:scopeVariables;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nbG9iYWxzL1ZhcmlhYmxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0UiLCJmaWxlIjoiLi4vLi4vc3JjL2dsb2JhbHMvVmFyaWFibGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0Bjb2RlY2FkZW15L3ZhcmlhbmNlJztcbmltcG9ydCB7IGNzcywgR2xvYmFsIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5jb25zdCBzY29wZVZhcmlhYmxlcyA9ICh2YXJzOiBDU1NPYmplY3QsIHNjb3BlID0gJzpyb290JykgPT5cbiAgY3NzKHsgW3Njb3BlXTogdmFycyB9KTtcblxuZXhwb3J0IGNvbnN0IFZhcmlhYmxlczogUmVhY3QuRkM8e1xuICB2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIENTU09iamVjdD47XG59PiA9ICh7IHZhcmlhYmxlcyB9KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHtPYmplY3QuZW50cmllcyh2YXJpYWJsZXMpLm1hcCgoW2tleSwgdmFyc10pID0+IChcbiAgICAgICAgPEdsb2JhbCBrZXk9e2tleX0gc3R5bGVzPXtzY29wZVZhcmlhYmxlcyh2YXJzKX0gLz5cbiAgICAgICkpfVxuICAgIDwvPlxuICApO1xufTtcbiJdfQ== */"));
18
9
  };
19
- export var Variables = function Variables(_ref) {
20
- var variables = _ref.variables;
10
+ export const Variables = _ref => {
11
+ let {
12
+ variables
13
+ } = _ref;
21
14
  return /*#__PURE__*/_jsx(_Fragment, {
22
- children: Object.entries(variables).map(function (_ref2) {
23
- var _ref3 = _slicedToArray(_ref2, 2),
24
- key = _ref3[0],
25
- vars = _ref3[1];
15
+ children: Object.entries(variables).map(_ref2 => {
16
+ let [key, vars] = _ref2;
26
17
  return /*#__PURE__*/_jsx(Global, {
27
18
  styles: scopeVariables(vars)
28
19
  }, key);
@@ -1,4 +1,4 @@
1
- export declare const FONT_ASSET_PATH = "https://static-assets.codecademy.com/gamut";
1
+ export declare const FONT_ASSET_PATH = "https://www.codecademy.com/gamut";
2
2
  export declare const webFonts: ({
3
3
  filePath: string;
4
4
  extensions: string[];