@codecademy/gamut-styles 16.1.2 → 16.1.3-alpha.187436.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 (82) hide show
  1. package/package.json +3 -7
  2. package/dist/AssetProvider.d.ts +0 -3
  3. package/dist/AssetProvider.js +0 -23
  4. package/dist/Background.d.ts +0 -6
  5. package/dist/Background.js +0 -86
  6. package/dist/ColorMode.d.ts +0 -1278
  7. package/dist/ColorMode.js +0 -145
  8. package/dist/GamutProvider.d.ts +0 -16
  9. package/dist/GamutProvider.js +0 -64
  10. package/dist/cache/createEmotionCache.d.ts +0 -4
  11. package/dist/cache/createEmotionCache.js +0 -40
  12. package/dist/cache/index.d.ts +0 -1
  13. package/dist/cache/index.js +0 -1
  14. package/dist/cache/stylisPlugins/focusVisible.d.ts +0 -2
  15. package/dist/cache/stylisPlugins/focusVisible.js +0 -9
  16. package/dist/cache/stylisPlugins/index.d.ts +0 -1
  17. package/dist/cache/stylisPlugins/index.js +0 -1
  18. package/dist/globals/Reboot.d.ts +0 -2
  19. package/dist/globals/Reboot.js +0 -9
  20. package/dist/globals/Typography.d.ts +0 -2
  21. package/dist/globals/Typography.js +0 -25
  22. package/dist/globals/Variables.d.ts +0 -5
  23. package/dist/globals/Variables.js +0 -31
  24. package/dist/globals/index.d.ts +0 -2
  25. package/dist/globals/index.js +0 -2
  26. package/dist/index.d.ts +0 -13
  27. package/dist/index.js +0 -13
  28. package/dist/remoteAssets/fonts.d.ts +0 -26
  29. package/dist/remoteAssets/fonts.js +0 -31
  30. package/dist/styles/boxShadow.d.ts +0 -26
  31. package/dist/styles/boxShadow.js +0 -45
  32. package/dist/styles/fontSmoothing.d.ts +0 -29
  33. package/dist/styles/fontSmoothing.js +0 -29
  34. package/dist/styles/index.d.ts +0 -7
  35. package/dist/styles/index.js +0 -7
  36. package/dist/styles/noSelect.d.ts +0 -1
  37. package/dist/styles/noSelect.js +0 -11
  38. package/dist/styles/pxRem.d.ts +0 -1
  39. package/dist/styles/pxRem.js +0 -4
  40. package/dist/styles/responsive.d.ts +0 -6
  41. package/dist/styles/responsive.js +0 -14
  42. package/dist/styles/screenReaderOnly.d.ts +0 -2
  43. package/dist/styles/screenReaderOnly.js +0 -20
  44. package/dist/styles/transitionConcat.d.ts +0 -3
  45. package/dist/styles/transitionConcat.js +0 -7
  46. package/dist/themes/admin.d.ts +0 -874
  47. package/dist/themes/admin.js +0 -15
  48. package/dist/themes/core.d.ts +0 -472
  49. package/dist/themes/core.js +0 -111
  50. package/dist/themes/index.d.ts +0 -3
  51. package/dist/themes/index.js +0 -3
  52. package/dist/themes/platform.d.ts +0 -1019
  53. package/dist/themes/platform.js +0 -73
  54. package/dist/typings/theme.d.ts +0 -6
  55. package/dist/utilities/index.d.ts +0 -1
  56. package/dist/utilities/index.js +0 -1
  57. package/dist/utilities/themed.d.ts +0 -14
  58. package/dist/utilities/themed.js +0 -17
  59. package/dist/variables/colors.d.ts +0 -193
  60. package/dist/variables/colors.js +0 -149
  61. package/dist/variables/deprecated-colors.d.ts +0 -156
  62. package/dist/variables/deprecated-colors.js +0 -155
  63. package/dist/variables/elements.d.ts +0 -11
  64. package/dist/variables/elements.js +0 -11
  65. package/dist/variables/index.d.ts +0 -7
  66. package/dist/variables/index.js +0 -8
  67. package/dist/variables/responsive.d.ts +0 -19
  68. package/dist/variables/responsive.js +0 -21
  69. package/dist/variables/spacing.d.ts +0 -13
  70. package/dist/variables/spacing.js +0 -14
  71. package/dist/variables/timing.d.ts +0 -10
  72. package/dist/variables/timing.js +0 -10
  73. package/dist/variables/typography.d.ts +0 -32
  74. package/dist/variables/typography.js +0 -33
  75. package/dist/variance/config.d.ts +0 -1002
  76. package/dist/variance/config.js +0 -471
  77. package/dist/variance/index.d.ts +0 -3
  78. package/dist/variance/index.js +0 -4
  79. package/dist/variance/props.d.ts +0 -1865
  80. package/dist/variance/props.js +0 -23
  81. package/dist/variance/utils.d.ts +0 -29
  82. package/dist/variance/utils.js +0 -43
package/dist/ColorMode.js DELETED
@@ -1,145 +0,0 @@
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
- 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); }
17
- import { serializeTokens, variance } from '@codecademy/variance';
18
- import { ThemeProvider, useTheme } from '@emotion/react';
19
- import { mapValues, pick } from 'lodash';
20
- import { createContext, forwardRef, useContext, useEffect, useMemo, useState } from 'react';
21
- import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
22
- import { styledOptions } from './variance/utils';
23
- 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;
33
- };
34
- var BackgroundCurrentContext = /*#__PURE__*/createContext({
35
- 'background-current': undefined
36
- });
37
- 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);
44
- if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
45
- /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
46
- we could potentially alter the Merge type utility function from createTheme, but since 'background-current' is the only exception to the type-merging rule and this is the only place we override, this seems to be a more straightforward + lower-risk solution.
47
- */
48
-
49
- modesCopy[mode]['background-current'] = bgCurrent['background-current'];
50
- }
51
- return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
52
- }
53
- 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;
58
- }
59
- export function usePrefersDarkMode() {
60
- var _useState = useState(false),
61
- _useState2 = _slicedToArray(_useState, 2),
62
- prefersDarkMode = _useState2[0],
63
- setPrefersDarkMode = _useState2[1];
64
- useEffect(function () {
65
- function onChange(event) {
66
- setPrefersDarkMode(event.matches);
67
- }
68
- if (window && 'matchMedia' in window) {
69
- var mq = window.matchMedia('(prefers-color-scheme: dark)');
70
- if (mq && 'addEventListener' in mq) {
71
- setPrefersDarkMode(mq.matches);
72
- mq.addEventListener('change', onChange);
73
- return function () {
74
- return mq.removeEventListener('change', onChange);
75
- };
76
- }
77
- }
78
- }, []);
79
- return prefersDarkMode;
80
- }
81
- export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
82
- target: "e1skjn880",
83
- label: "VariableProvider"
84
- }, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
85
- var variables = _ref3.variables;
86
- return variables;
87
- }, css({
88
- textColor: 'text'
89
- }), providerProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ColorMode.tsx"],"names":[],"mappings":"AAoIgC","file":"../src/ColorMode.tsx","sourcesContent":["import {\n  serializeTokens,\n  StyleProps,\n  ThemeProps,\n  variance,\n} from '@codecademy/variance';\nimport { CSSObject, Theme, ThemeProvider, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { mapValues, pick } from 'lodash';\nimport {\n  ComponentProps,\n  createContext,\n  forwardRef,\n  useContext,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react';\n\nimport { theme as GamutTheme } from '.';\nimport {\n  background,\n  border,\n  color,\n  css,\n  flex,\n  grid,\n  layout,\n  positioning,\n  space,\n} from './variance/props';\nimport { styledOptions } from './variance/utils';\n\nexport type Colors = keyof Theme['colors'];\nexport type ColorModeConfig = Theme['modes'];\nexport type ColorModes = keyof ColorModeConfig;\nexport type ColorModeShape = ColorModeConfig[ColorModes];\nexport type ColorAlias = keyof ColorModeShape;\n\nexport type ColorModeProps = {\n  mode: ColorModes | 'system';\n  bg?: Colors;\n};\n\nexport const providerProps = variance.compose(\n  layout,\n  color,\n  grid,\n  flex,\n  positioning,\n  space,\n  border,\n  background\n);\n\nexport const modeColorProps = ({\n  theme,\n  mode,\n}: ThemeProps<{ mode?: ColorModes }>) => {\n  if (!theme || !mode || mode === theme?.mode) return {};\n  const { colors } = theme;\n  return serializeTokens(\n    mapValues(theme?.modes[mode], (color) => colors[color]),\n    'color',\n    theme\n  ).variables;\n};\n\ninterface BackgroundCurrentContextInterface {\n  'background-current'?: keyof typeof GamutTheme.colors;\n}\n\nconst BackgroundCurrentContext = createContext<BackgroundCurrentContextInterface>(\n  {\n    'background-current': undefined,\n  }\n);\n\nexport function useColorModes(): [\n  ColorModes,\n  ColorModeShape,\n  ColorModeConfig,\n  (color: Colors) => string\n] {\n  const bgCurrent = useContext(BackgroundCurrentContext);\n  const { mode, modes, _getColorValue: getColorValue } = useTheme() || {};\n  const modesCopy = { ...modes };\n\n  if (\n    bgCurrent['background-current'] &&\n    modesCopy[mode]['background-current'] !== bgCurrent['background-current']\n  ) {\n    /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.\n    we could potentially alter the Merge type utility function from createTheme, but since 'background-current' is the only exception to the type-merging rule  and this is the only place we override, this seems to be a more straightforward + lower-risk solution.\n    */\n\n    modesCopy[mode]['background-current'] = bgCurrent['background-current'] as\n      | 'white'\n      | 'navy-800';\n  }\n\n  return [mode, modesCopy?.[mode], modes, getColorValue];\n}\n\nexport function useCurrentMode(mode?: ColorModes) {\n  const [activeMode] = useColorModes();\n  return mode ?? activeMode;\n}\n\nexport function usePrefersDarkMode() {\n  const [prefersDarkMode, setPrefersDarkMode] = useState(false);\n\n  useEffect(() => {\n    function onChange(event: MediaQueryListEvent) {\n      setPrefersDarkMode(event.matches);\n    }\n\n    if (window && 'matchMedia' in window) {\n      const mq = window.matchMedia('(prefers-color-scheme: dark)');\n\n      if (mq && 'addEventListener' in mq) {\n        setPrefersDarkMode(mq.matches);\n        mq.addEventListener('change', onChange);\n\n        return () => mq.removeEventListener('change', onChange);\n      }\n    }\n  }, []);\n\n  return prefersDarkMode;\n}\n\nexport const VariableProvider = styled(\n  'div',\n  styledOptions(['variables', 'alwaysSetVariables'])\n)<\n  StyleProps<typeof providerProps> & {\n    variables?: CSSObject;\n    alwaysSetVariables?: boolean;\n  }\n>(({ variables }) => variables, css({ textColor: 'text' }), providerProps);\n\nexport const ColorMode = forwardRef<\n  HTMLDivElement,\n  Omit<ComponentProps<typeof VariableProvider>, 'bg'> & ColorModeProps\n>(({ mode: preference, alwaysSetVariables, bg, ...rest }, ref) => {\n  // checks if the user has set 'system' as their color mode preference\n  // then sets the color mode\n  const prefersDarkMode = usePrefersDarkMode();\n  const mode =\n    preference === 'system' ? (prefersDarkMode ? 'dark' : 'light') : preference;\n\n  const theme = useTheme();\n  const { modes, mode: active, colors } = theme;\n  const contextBg = bg ? 'background-current' : undefined;\n  // This makes sure the background-current context is always set to the correct color + not the semantic color name.\n  const currentParentBg = useContext(BackgroundCurrentContext);\n\n  const bgCurrent =\n    bg === 'background-current'\n      ? currentParentBg['background-current']\n        ? currentParentBg['background-current']\n        : modes[active]['background-current']\n      : bg;\n\n  /** Serialize color variables for the current mode\n   * 1. If all variables are required add all mode variables to the current context\n   * 2. If the user has specified a background color - set that color to the current-bg\n   * 3. If not\n   */\n  const { variables } = useMemo(() => {\n    return serializeTokens(\n      mapValues(modes[mode], (color, key) => {\n        if (key === 'background-current' && typeof bg !== 'undefined') {\n          return colors[bg];\n        }\n        return colors[color];\n      }),\n      'color',\n      theme\n    );\n  }, [colors, mode, modes, theme, bg]);\n\n  if (active === mode) {\n    const vars = alwaysSetVariables\n      ? variables\n      : pick(variables, ['--color-background-current']);\n\n    return (\n      <BackgroundCurrentContext.Provider\n        value={{ 'background-current': bgCurrent }}\n      >\n        <VariableProvider {...rest} variables={vars} bg={contextBg} ref={ref} />\n      </BackgroundCurrentContext.Provider>\n    );\n  }\n\n  return (\n    <ThemeProvider theme={{ mode }}>\n      <VariableProvider\n        {...rest}\n        variables={variables}\n        bg={contextBg}\n        ref={ref}\n      />\n    </ThemeProvider>\n  );\n});\n"]} */");
90
- export var ColorMode = /*#__PURE__*/forwardRef(function ColorMode(_ref4, ref) {
91
- var preference = _ref4.mode,
92
- alwaysSetVariables = _ref4.alwaysSetVariables,
93
- bg = _ref4.bg,
94
- rest = _objectWithoutProperties(_ref4, ["mode", "alwaysSetVariables", "bg"]);
95
- // checks if the user has set 'system' as their color mode preference
96
- // 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;
104
- // 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;
107
-
108
- /** Serialize color variables for the current mode
109
- * 1. If all variables are required add all mode variables to the current context
110
- * 2. If the user has specified a background color - set that color to the current-bg
111
- * 3. If not
112
- */
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;
122
- if (active === mode) {
123
- var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
124
- return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
125
- value: {
126
- 'background-current': bgCurrent
127
- },
128
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
129
- variables: vars,
130
- bg: contextBg,
131
- ref: ref
132
- }))
133
- });
134
- }
135
- return /*#__PURE__*/_jsx(ThemeProvider, {
136
- theme: {
137
- mode: mode
138
- },
139
- children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
140
- variables: variables,
141
- bg: contextBg,
142
- ref: ref
143
- }))
144
- });
145
- });
@@ -1,16 +0,0 @@
1
- import { CSSObject } from '@codecademy/variance';
2
- import { EmotionCache, Theme } from '@emotion/react';
3
- import * as React from 'react';
4
- export interface GamutProviderProps {
5
- children?: React.ReactNode;
6
- useGlobals?: boolean;
7
- useCache?: boolean;
8
- theme: Theme;
9
- variables?: Record<string, CSSObject>;
10
- cache?: EmotionCache;
11
- }
12
- export declare const GamutContext: React.Context<{
13
- hasGlobals?: boolean | undefined;
14
- hasCache?: boolean | undefined;
15
- }>;
16
- export declare const GamutProvider: React.FC<GamutProviderProps>;
@@ -1,64 +0,0 @@
1
- import { CacheProvider, ThemeProvider } from '@emotion/react';
2
- import { useContext, useRef } from 'react';
3
- import * as React from 'react';
4
- import { createEmotionCache } from './cache';
5
- import { Reboot, Typography } from './globals';
6
- import { Variables } from './globals/Variables';
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({
12
- hasGlobals: false,
13
- hasCache: false
14
- });
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;
31
-
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 = {
35
- hasGlobals: shouldInsertGlobals,
36
- hasCache: shouldCreateCache
37
- };
38
- var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
39
- children: [/*#__PURE__*/_jsx(Typography, {}), /*#__PURE__*/_jsx(Reboot, {}), /*#__PURE__*/_jsx(Variables, {
40
- variables: theme._variables
41
- }), variables && /*#__PURE__*/_jsx(Variables, {
42
- variables: variables
43
- })]
44
- });
45
- if (activeCache.current) {
46
- return /*#__PURE__*/_jsx(GamutContext.Provider, {
47
- value: contextValue,
48
- children: /*#__PURE__*/_jsxs(CacheProvider, {
49
- value: activeCache.current,
50
- children: [globals, /*#__PURE__*/_jsx(ThemeProvider, {
51
- theme: theme,
52
- children: children
53
- })]
54
- })
55
- });
56
- }
57
- return /*#__PURE__*/_jsxs(GamutContext.Provider, {
58
- value: contextValue,
59
- children: [globals, /*#__PURE__*/_jsx(ThemeProvider, {
60
- theme: theme,
61
- children: children
62
- })]
63
- });
64
- };
@@ -1,4 +0,0 @@
1
- import { Options } from '@emotion/cache';
2
- export declare const EMOTION_KEY = "gamut";
3
- export declare const EMOTION_CONTAINER = "emotion-styles";
4
- export declare const createEmotionCache: (overrides?: Partial<Options> | undefined) => import("@emotion/cache").EmotionCache;
@@ -1,40 +0,0 @@
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
- import createCache from '@emotion/cache';
14
- import { prefixer } from 'stylis';
15
- import { focusVisible } from './stylisPlugins';
16
- export var EMOTION_KEY = 'gamut';
17
- export var EMOTION_CONTAINER = 'emotion-styles';
18
- var getEmotionNode = function getEmotionNode() {
19
- if (typeof document === 'undefined') {
20
- return;
21
- }
22
- var node = document.getElementById(EMOTION_CONTAINER);
23
- if (node) return node;
24
- node = document.createElement('div');
25
- node.setAttribute('id', EMOTION_CONTAINER);
26
-
27
- // if this has not been created add it to the DOM at the top of the body
28
- document.getElementsByTagName('body')[0].prepend(node);
29
- return node;
30
- };
31
- export var createEmotionCache = function createEmotionCache(overrides) {
32
- var _overrides$container, _overrides$stylisPlug;
33
- return createCache(_objectSpread(_objectSpread({
34
- key: EMOTION_KEY,
35
- speedy: process.env.NODE_ENV !== 'development',
36
- container: (_overrides$container = overrides === null || overrides === void 0 ? void 0 : overrides.container) !== null && _overrides$container !== void 0 ? _overrides$container : getEmotionNode()
37
- }, overrides), {}, {
38
- stylisPlugins: [].concat(_toConsumableArray((_overrides$stylisPlug = overrides === null || overrides === void 0 ? void 0 : overrides.stylisPlugins) !== null && _overrides$stylisPlug !== void 0 ? _overrides$stylisPlug : []), [focusVisible, prefixer])
39
- }));
40
- };
@@ -1 +0,0 @@
1
- export * from './createEmotionCache';
@@ -1 +0,0 @@
1
- export * from './createEmotionCache';
@@ -1,2 +0,0 @@
1
- import { StylisPlugin } from '@emotion/cache';
2
- export declare const focusVisible: StylisPlugin;
@@ -1,9 +0,0 @@
1
- export var focusVisible = function focusVisible(element) {
2
- if (element.type === 'rule' && element.value.includes(':focus-visible')) {
3
- element.props = element.props.map(function (prop) {
4
- var poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
5
- return "".concat(prop, ", ").concat(poly);
6
- });
7
- }
8
- return undefined;
9
- };
@@ -1 +0,0 @@
1
- export * from './focusVisible';
@@ -1 +0,0 @@
1
- export * from './focusVisible';
@@ -1,2 +0,0 @@
1
- /// <reference types="react" />
2
- export declare const Reboot: () => JSX.Element;
@@ -1,9 +0,0 @@
1
- import { css, Global } from '@emotion/react';
2
- import { coreTheme as theme } from '../themes';
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
- };
@@ -1,2 +0,0 @@
1
- /// <reference types="react" />
2
- export declare const Typography: () => JSX.Element;
@@ -1,25 +0,0 @@
1
- import { css, Global } from '@emotion/react';
2
- import { webFonts } from '../remoteAssets/fonts';
3
- import { coreTheme as theme } from '../themes';
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== */"));
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
- };
@@ -1,5 +0,0 @@
1
- import { CSSObject } from '@codecademy/variance';
2
- import * as React from 'react';
3
- export declare const Variables: React.FC<{
4
- variables: Record<string, CSSObject>;
5
- }>;
@@ -1,31 +0,0 @@
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
- import { css, Global } from '@emotion/react';
12
- 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== */"));
18
- };
19
- export var Variables = function Variables(_ref) {
20
- var variables = _ref.variables;
21
- 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];
26
- return /*#__PURE__*/_jsx(Global, {
27
- styles: scopeVariables(vars)
28
- }, key);
29
- })
30
- });
31
- };
@@ -1,2 +0,0 @@
1
- export * from './Typography';
2
- export * from './Reboot';
@@ -1,2 +0,0 @@
1
- export * from './Typography';
2
- export * from './Reboot';
package/dist/index.d.ts DELETED
@@ -1,13 +0,0 @@
1
- import '@emotion/react';
2
- export * from './AssetProvider';
3
- export * from './GamutProvider';
4
- export * from './ColorMode';
5
- export * from './Background';
6
- export * from './variance';
7
- export * from './cache';
8
- export * from './variables';
9
- export * from './styles';
10
- export * from './globals';
11
- export * from './utilities';
12
- export * from './themes';
13
- export { coreTheme as theme } from './themes';
package/dist/index.js DELETED
@@ -1,13 +0,0 @@
1
- import '@emotion/react';
2
- export * from './AssetProvider';
3
- export * from './GamutProvider';
4
- export * from './ColorMode';
5
- export * from './Background';
6
- export * from './variance';
7
- export * from './cache';
8
- export * from './variables';
9
- export * from './styles';
10
- export * from './globals';
11
- export * from './utilities';
12
- export * from './themes';
13
- export { coreTheme as theme } from './themes';
@@ -1,26 +0,0 @@
1
- export declare const FONT_ASSET_PATH = "https://static-assets.codecademy.com/gamut";
2
- export declare const webFonts: ({
3
- filePath: string;
4
- extensions: string[];
5
- name: string;
6
- style?: undefined;
7
- weight?: undefined;
8
- } | {
9
- filePath: string;
10
- extensions: string[];
11
- name: string;
12
- style: string;
13
- weight?: undefined;
14
- } | {
15
- filePath: string;
16
- extensions: string[];
17
- name: string;
18
- weight: string;
19
- style?: undefined;
20
- } | {
21
- filePath: string;
22
- extensions: string[];
23
- name: string;
24
- weight: string;
25
- style: string;
26
- })[];
@@ -1,31 +0,0 @@
1
- export var FONT_ASSET_PATH = "https://static-assets.codecademy.com/gamut";
2
- export var webFonts = [{
3
- filePath: "".concat(FONT_ASSET_PATH, "/apercu-regular-pro"),
4
- extensions: ['woff', 'woff2'],
5
- name: 'Apercu'
6
- }, {
7
- filePath: "".concat(FONT_ASSET_PATH, "/apercu-italic-pro"),
8
- extensions: ['woff', 'woff2'],
9
- name: 'Apercu',
10
- style: 'italic'
11
- }, {
12
- filePath: "".concat(FONT_ASSET_PATH, "/apercu-bold-pro"),
13
- extensions: ['woff', 'woff2'],
14
- name: 'Apercu',
15
- weight: 'bold'
16
- }, {
17
- filePath: "".concat(FONT_ASSET_PATH, "/apercu-bold-italic-pro"),
18
- extensions: ['woff', 'woff2'],
19
- name: 'Apercu',
20
- weight: 'bold',
21
- style: 'italic'
22
- }, {
23
- filePath: "".concat(FONT_ASSET_PATH, "/SuisseIntlMono-Bold-WebS"),
24
- extensions: ['woff', 'woff2'],
25
- name: 'Suisse',
26
- weight: 'bold'
27
- }, {
28
- filePath: "".concat(FONT_ASSET_PATH, "/SuisseIntlMono-Regular-WebS"),
29
- extensions: ['woff', 'woff2'],
30
- name: 'Suisse'
31
- }];
@@ -1,26 +0,0 @@
1
- export declare type ShadowDepth = keyof typeof shadowsForDepth;
2
- declare const shadowsForDepth: {
3
- 1: {
4
- offsets: number[];
5
- shades: number[];
6
- };
7
- 2: {
8
- offsets: number[];
9
- shades: number[];
10
- };
11
- 3: {
12
- offsets: number[];
13
- shades: number[];
14
- };
15
- 4: {
16
- offsets: number[];
17
- shades: number[];
18
- };
19
- 5: {
20
- offsets: number[];
21
- shades: number[];
22
- };
23
- };
24
- export declare const createShadow: (depth: ShadowDepth) => string;
25
- export declare const boxShadow: (depth?: ShadowDepth) => import("@emotion/react").SerializedStyles;
26
- export {};