@codecademy/gamut-styles 16.3.1-alpha.8ea574.0 → 16.3.1-alpha.d1fa10.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 (47) hide show
  1. package/dist/AssetProvider.js +18 -15
  2. package/dist/Background.js +45 -28
  3. package/dist/ColorMode.d.ts +27 -0
  4. package/dist/ColorMode.js +77 -70
  5. package/dist/GamutProvider.js +22 -20
  6. package/dist/cache/createEmotionCache.d.ts +1 -1
  7. package/dist/cache/createEmotionCache.js +26 -11
  8. package/dist/cache/stylisPlugins/focusVisible.js +4 -4
  9. package/dist/globals/Reboot.js +6 -4
  10. package/dist/globals/Typography.js +20 -18
  11. package/dist/globals/Variables.js +21 -12
  12. package/dist/remoteAssets/fonts.js +8 -8
  13. package/dist/styles/boxShadow.d.ts +1 -1
  14. package/dist/styles/boxShadow.js +20 -10
  15. package/dist/styles/fontSmoothing.js +7 -5
  16. package/dist/styles/noSelect.d.ts +1 -1
  17. package/dist/styles/noSelect.js +1 -1
  18. package/dist/styles/pxRem.js +3 -3
  19. package/dist/styles/responsive.js +6 -4
  20. package/dist/styles/screenReaderOnly.d.ts +2 -2
  21. package/dist/styles/screenReaderOnly.js +2 -2
  22. package/dist/styles/transitionConcat.js +4 -4
  23. package/dist/themes/admin.d.ts +8 -0
  24. package/dist/themes/admin.js +1 -1
  25. package/dist/themes/core.d.ts +8 -0
  26. package/dist/themes/core.js +13 -14
  27. package/dist/themes/platform.d.ts +8 -0
  28. package/dist/themes/platform.js +1 -1
  29. package/dist/utilities/themed.js +2 -4
  30. package/dist/variables/borderRadii.d.ts +8 -0
  31. package/dist/variables/borderRadii.js +8 -0
  32. package/dist/variables/colors.js +18 -19
  33. package/dist/variables/deprecated-colors.js +16 -17
  34. package/dist/variables/elements.js +1 -1
  35. package/dist/variables/index.d.ts +3 -2
  36. package/dist/variables/index.js +3 -2
  37. package/dist/variables/responsive.js +6 -4
  38. package/dist/variables/spacing.js +1 -1
  39. package/dist/variables/timing.js +5 -5
  40. package/dist/variables/typography.js +8 -14
  41. package/dist/variance/config.d.ts +18 -0
  42. package/dist/variance/config.js +50 -58
  43. package/dist/variance/index.js +2 -1
  44. package/dist/variance/props.d.ts +36 -0
  45. package/dist/variance/props.js +16 -16
  46. package/dist/variance/utils.js +14 -6
  47. package/package.json +3 -3
@@ -1,19 +1,22 @@
1
1
  import { webFonts } from './remoteAssets/fonts';
2
- import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
3
- export const createFontLinks = () => webFonts.flatMap(_ref => {
4
- let {
5
- filePath,
6
- extensions
7
- } = _ref;
8
- return extensions.map(ext => /*#__PURE__*/_jsx("link", {
9
- rel: "preload",
10
- href: `${filePath}.${ext}`,
11
- crossOrigin: "anonymous",
12
- as: "font",
13
- type: `font/${ext}`
14
- }, `${filePath}-${ext}`));
15
- });
16
- export const AssetProvider = () => {
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Fragment as _Fragment } from "react/jsx-runtime";
4
+ export var createFontLinks = function createFontLinks() {
5
+ return webFonts.flatMap(function (_ref) {
6
+ var filePath = _ref.filePath,
7
+ extensions = _ref.extensions;
8
+ return extensions.map(function (ext) {
9
+ return /*#__PURE__*/_jsx("link", {
10
+ rel: "preload",
11
+ href: "".concat(filePath, ".").concat(ext),
12
+ crossOrigin: "anonymous",
13
+ as: "font",
14
+ type: "font/".concat(ext)
15
+ }, "".concat(filePath, "-").concat(ext));
16
+ });
17
+ });
18
+ };
19
+ export var AssetProvider = function AssetProvider() {
17
20
  return /*#__PURE__*/_jsx(_Fragment, {
18
21
  children: createFontLinks()
19
22
  });
@@ -1,25 +1,41 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
8
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
10
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
11
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
12
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
14
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
1
15
  import { getContrast } from 'polished';
2
16
  import { forwardRef, useCallback, useMemo } from 'react';
3
17
  import { ColorMode, useColorModes } from './ColorMode';
4
18
  import { jsx as _jsx } from "react/jsx-runtime";
5
- const isColorAlias = (mode, color) => {
19
+ var isColorAlias = function isColorAlias(mode, color) {
6
20
  return Object.keys(mode).includes(color);
7
21
  };
8
- export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
9
- let {
10
- bg,
11
- ...rest
12
- } = _ref;
13
- const [active, activeColors, modes, getColorValue] = useColorModes();
14
-
22
+ export var Background = /*#__PURE__*/forwardRef(function (_ref, ref) {
23
+ var bg = _ref.bg,
24
+ rest = _objectWithoutProperties(_ref, ["bg"]);
25
+ var _useColorModes = useColorModes(),
26
+ _useColorModes2 = _slicedToArray(_useColorModes, 4),
27
+ active = _useColorModes2[0],
28
+ activeColors = _useColorModes2[1],
29
+ modes = _useColorModes2[2],
30
+ getColorValue = _useColorModes2[3];
15
31
  /** If a color alias was used then look up the true color key from the active mode */
16
- const trueColor = useMemo(() => {
32
+ var trueColor = useMemo(function () {
17
33
  if (isColorAlias(activeColors, bg)) {
18
34
  return activeColors[bg];
19
35
  }
20
36
  return bg;
21
37
  }, [bg, activeColors]);
22
- const getTextContrast = useCallback(foreground => {
38
+ var getTextContrast = useCallback(function (foreground) {
23
39
  return getContrast(getColorValue(foreground), getColorValue(trueColor));
24
40
  }, [trueColor, getColorValue]);
25
41
 
@@ -33,12 +49,10 @@ export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
33
49
  * This does not guarantee a level of A/AA/AA compliance.
34
50
  */
35
51
 
36
- const accessibleMode = useMemo(() => {
37
- const {
38
- [active]: activeMode,
39
- ...otherModes
40
- } = modes;
41
- const possibleModes = Object.entries(otherModes);
52
+ var accessibleMode = useMemo(function () {
53
+ var activeMode = modes[active],
54
+ otherModes = _objectWithoutProperties(modes, [active].map(_toPropertyKey));
55
+ var possibleModes = Object.entries(otherModes);
42
56
 
43
57
  /**
44
58
  * Reduce all remaining modes to the mode key with the highest contrast
@@ -48,22 +62,25 @@ export const Background = /*#__PURE__*/forwardRef((_ref, ref) => {
48
62
  * it will likely fail to return a mode outside of the lightest and
49
63
  * darkest versions.
50
64
  */
51
- const [highestContrastMode] = possibleModes.reduce((_ref2, _ref3) => {
52
- let [prevMode, prevContrast] = _ref2;
53
- let [mode, {
54
- text
55
- }] = _ref3;
56
- const contrast = getTextContrast(text);
65
+ var _possibleModes$reduce = possibleModes.reduce(function (_ref2, _ref3) {
66
+ var _ref4 = _slicedToArray(_ref2, 2),
67
+ prevMode = _ref4[0],
68
+ prevContrast = _ref4[1];
69
+ var _ref5 = _slicedToArray(_ref3, 2),
70
+ mode = _ref5[0],
71
+ text = _ref5[1].text;
72
+ var contrast = getTextContrast(text);
57
73
 
58
- // Keep the higher contrast mode.
59
- return contrast > prevContrast ? [mode, contrast] : [prevMode, prevContrast];
60
- }, [active, getTextContrast(activeMode.text)]);
74
+ // Keep the higher contrast mode.
75
+ return contrast > prevContrast ? [mode, contrast] : [prevMode, prevContrast];
76
+ }, [active, getTextContrast(activeMode.text)]),
77
+ _possibleModes$reduce2 = _slicedToArray(_possibleModes$reduce, 1),
78
+ highestContrastMode = _possibleModes$reduce2[0];
61
79
  return highestContrastMode;
62
80
  }, [modes, active, getTextContrast]);
63
- return /*#__PURE__*/_jsx(ColorMode, {
64
- ...rest,
81
+ return /*#__PURE__*/_jsx(ColorMode, _objectSpread(_objectSpread({}, rest), {}, {
65
82
  mode: accessibleMode,
66
83
  bg: bg,
67
84
  ref: ref
68
- });
85
+ }));
69
86
  });
@@ -398,34 +398,43 @@ export declare const providerProps: import("@codecademy/variance/dist/types/conf
398
398
  };
399
399
  readonly borderRadius: {
400
400
  readonly property: "borderRadius";
401
+ readonly scale: "borderRadii";
401
402
  };
402
403
  readonly borderRadiusLeft: {
403
404
  readonly property: "borderRadius";
404
405
  readonly properties: readonly ["borderTopLeftRadius", "borderBottomLeftRadius"];
406
+ readonly scale: "borderRadii";
405
407
  };
406
408
  readonly borderRadiusTop: {
407
409
  readonly property: "borderRadius";
408
410
  readonly properties: readonly ["borderTopLeftRadius", "borderTopRightRadius"];
411
+ readonly scale: "borderRadii";
409
412
  };
410
413
  readonly borderRadiusBottom: {
411
414
  readonly property: "borderRadius";
412
415
  readonly properties: readonly ["borderBottomLeftRadius", "borderBottomRightRadius"];
416
+ readonly scale: "borderRadii";
413
417
  };
414
418
  readonly borderRadiusRight: {
415
419
  readonly property: "borderRadius";
416
420
  readonly properties: readonly ["borderTopRightRadius", "borderBottomRightRadius"];
421
+ readonly scale: "borderRadii";
417
422
  };
418
423
  readonly borderRadiusTopLeft: {
419
424
  readonly property: "borderTopLeftRadius";
425
+ readonly scale: "borderRadii";
420
426
  };
421
427
  readonly borderRadiusTopRight: {
422
428
  readonly property: "borderTopRightRadius";
429
+ readonly scale: "borderRadii";
423
430
  };
424
431
  readonly borderRadiusBottomRight: {
425
432
  readonly property: "borderBottomRightRadius";
433
+ readonly scale: "borderRadii";
426
434
  };
427
435
  readonly borderRadiusBottomLeft: {
428
436
  readonly property: "borderBottomLeftRadius";
437
+ readonly scale: "borderRadii";
429
438
  };
430
439
  readonly borderStyle: {
431
440
  readonly property: "borderStyle";
@@ -663,6 +672,7 @@ export declare const VariableProvider: import("@emotion/styled").StyledComponent
663
672
  }>;
664
673
  borderRadius?: import("@codecademy/variance/dist/types/config").Scale<{
665
674
  readonly property: "borderRadius";
675
+ readonly scale: "borderRadii";
666
676
  }>;
667
677
  borderRight?: import("@codecademy/variance/dist/types/config").Scale<{
668
678
  readonly property: "borderRight";
@@ -825,30 +835,38 @@ export declare const VariableProvider: import("@emotion/styled").StyledComponent
825
835
  borderRadiusLeft?: import("@codecademy/variance/dist/types/config").Scale<{
826
836
  readonly property: "borderRadius";
827
837
  readonly properties: readonly ["borderTopLeftRadius", "borderBottomLeftRadius"];
838
+ readonly scale: "borderRadii";
828
839
  }>;
829
840
  borderRadiusTop?: import("@codecademy/variance/dist/types/config").Scale<{
830
841
  readonly property: "borderRadius";
831
842
  readonly properties: readonly ["borderTopLeftRadius", "borderTopRightRadius"];
843
+ readonly scale: "borderRadii";
832
844
  }>;
833
845
  borderRadiusBottom?: import("@codecademy/variance/dist/types/config").Scale<{
834
846
  readonly property: "borderRadius";
835
847
  readonly properties: readonly ["borderBottomLeftRadius", "borderBottomRightRadius"];
848
+ readonly scale: "borderRadii";
836
849
  }>;
837
850
  borderRadiusRight?: import("@codecademy/variance/dist/types/config").Scale<{
838
851
  readonly property: "borderRadius";
839
852
  readonly properties: readonly ["borderTopRightRadius", "borderBottomRightRadius"];
853
+ readonly scale: "borderRadii";
840
854
  }>;
841
855
  borderRadiusTopLeft?: import("@codecademy/variance/dist/types/config").Scale<{
842
856
  readonly property: "borderTopLeftRadius";
857
+ readonly scale: "borderRadii";
843
858
  }>;
844
859
  borderRadiusTopRight?: import("@codecademy/variance/dist/types/config").Scale<{
845
860
  readonly property: "borderTopRightRadius";
861
+ readonly scale: "borderRadii";
846
862
  }>;
847
863
  borderRadiusBottomRight?: import("@codecademy/variance/dist/types/config").Scale<{
848
864
  readonly property: "borderBottomRightRadius";
865
+ readonly scale: "borderRadii";
849
866
  }>;
850
867
  borderRadiusBottomLeft?: import("@codecademy/variance/dist/types/config").Scale<{
851
868
  readonly property: "borderBottomLeftRadius";
869
+ readonly scale: "borderRadii";
852
870
  }>;
853
871
  borderStyleX?: import("@codecademy/variance/dist/types/config").Scale<{
854
872
  readonly property: "borderStyle";
@@ -1061,6 +1079,7 @@ export declare const ColorMode: import("react").ForwardRefExoticComponent<Pick<O
1061
1079
  }>;
1062
1080
  borderRadius?: import("@codecademy/variance/dist/types/config").Scale<{
1063
1081
  readonly property: "borderRadius";
1082
+ readonly scale: "borderRadii";
1064
1083
  }>;
1065
1084
  borderRight?: import("@codecademy/variance/dist/types/config").Scale<{
1066
1085
  readonly property: "borderRight";
@@ -1223,30 +1242,38 @@ export declare const ColorMode: import("react").ForwardRefExoticComponent<Pick<O
1223
1242
  borderRadiusLeft?: import("@codecademy/variance/dist/types/config").Scale<{
1224
1243
  readonly property: "borderRadius";
1225
1244
  readonly properties: readonly ["borderTopLeftRadius", "borderBottomLeftRadius"];
1245
+ readonly scale: "borderRadii";
1226
1246
  }>;
1227
1247
  borderRadiusTop?: import("@codecademy/variance/dist/types/config").Scale<{
1228
1248
  readonly property: "borderRadius";
1229
1249
  readonly properties: readonly ["borderTopLeftRadius", "borderTopRightRadius"];
1250
+ readonly scale: "borderRadii";
1230
1251
  }>;
1231
1252
  borderRadiusBottom?: import("@codecademy/variance/dist/types/config").Scale<{
1232
1253
  readonly property: "borderRadius";
1233
1254
  readonly properties: readonly ["borderBottomLeftRadius", "borderBottomRightRadius"];
1255
+ readonly scale: "borderRadii";
1234
1256
  }>;
1235
1257
  borderRadiusRight?: import("@codecademy/variance/dist/types/config").Scale<{
1236
1258
  readonly property: "borderRadius";
1237
1259
  readonly properties: readonly ["borderTopRightRadius", "borderBottomRightRadius"];
1260
+ readonly scale: "borderRadii";
1238
1261
  }>;
1239
1262
  borderRadiusTopLeft?: import("@codecademy/variance/dist/types/config").Scale<{
1240
1263
  readonly property: "borderTopLeftRadius";
1264
+ readonly scale: "borderRadii";
1241
1265
  }>;
1242
1266
  borderRadiusTopRight?: import("@codecademy/variance/dist/types/config").Scale<{
1243
1267
  readonly property: "borderTopRightRadius";
1268
+ readonly scale: "borderRadii";
1244
1269
  }>;
1245
1270
  borderRadiusBottomRight?: import("@codecademy/variance/dist/types/config").Scale<{
1246
1271
  readonly property: "borderBottomRightRadius";
1272
+ readonly scale: "borderRadii";
1247
1273
  }>;
1248
1274
  borderRadiusBottomLeft?: import("@codecademy/variance/dist/types/config").Scale<{
1249
1275
  readonly property: "borderBottomLeftRadius";
1276
+ readonly scale: "borderRadii";
1250
1277
  }>;
1251
1278
  borderStyleX?: import("@codecademy/variance/dist/types/config").Scale<{
1252
1279
  readonly property: "borderStyle";
package/dist/ColorMode.js CHANGED
@@ -1,5 +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); }
1
2
  import _styled from "@emotion/styled/base";
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); }
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); }
3
17
  import { serializeTokens, variance } from '@codecademy/variance';
4
18
  import { ThemeProvider, useTheme } from '@emotion/react';
5
19
  import mapValues from 'lodash/mapValues';
@@ -8,31 +22,26 @@ import { createContext, forwardRef, useContext, useEffect, useMemo, useState } f
8
22
  import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
9
23
  import { styledOptions } from './variance/utils';
10
24
  import { jsx as _jsx } from "react/jsx-runtime";
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;
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;
22
34
  };
23
- const BackgroundCurrentContext = /*#__PURE__*/createContext({
35
+ var BackgroundCurrentContext = /*#__PURE__*/createContext({
24
36
  'background-current': undefined
25
37
  });
26
38
  export function useColorModes() {
27
- const bgCurrent = useContext(BackgroundCurrentContext);
28
- const {
29
- mode,
30
- modes,
31
- _getColorValue: getColorValue
32
- } = useTheme() || {};
33
- const modesCopy = {
34
- ...modes
35
- };
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);
36
45
  if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
37
46
  /* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
38
47
  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.
@@ -40,100 +49,98 @@ export function useColorModes() {
40
49
 
41
50
  modesCopy[mode]['background-current'] = bgCurrent['background-current'];
42
51
  }
43
- return [mode, modesCopy?.[mode], modes, getColorValue];
52
+ return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
44
53
  }
45
54
  export function useCurrentMode(mode) {
46
- const [activeMode] = useColorModes();
47
- return mode ?? activeMode;
55
+ var _useColorModes = useColorModes(),
56
+ _useColorModes2 = _slicedToArray(_useColorModes, 1),
57
+ activeMode = _useColorModes2[0];
58
+ return mode !== null && mode !== void 0 ? mode : activeMode;
48
59
  }
49
60
  export function usePrefersDarkMode() {
50
- const [prefersDarkMode, setPrefersDarkMode] = useState(false);
51
- useEffect(() => {
61
+ var _useState = useState(false),
62
+ _useState2 = _slicedToArray(_useState, 2),
63
+ prefersDarkMode = _useState2[0],
64
+ setPrefersDarkMode = _useState2[1];
65
+ useEffect(function () {
52
66
  function onChange(event) {
53
67
  setPrefersDarkMode(event.matches);
54
68
  }
55
69
  if (window && 'matchMedia' in window) {
56
- const mq = window.matchMedia('(prefers-color-scheme: dark)');
70
+ var mq = window.matchMedia('(prefers-color-scheme: dark)');
57
71
  if (mq && 'addEventListener' in mq) {
58
72
  setPrefersDarkMode(mq.matches);
59
73
  mq.addEventListener('change', onChange);
60
- return () => mq.removeEventListener('change', onChange);
74
+ return function () {
75
+ return mq.removeEventListener('change', onChange);
76
+ };
61
77
  }
62
78
  }
63
79
  }, []);
64
80
  return prefersDarkMode;
65
81
  }
66
- export const VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
82
+ export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
67
83
  target: "e1skjn880",
68
84
  label: "VariableProvider"
69
- }, styledOptions(['variables', 'alwaysSetVariables'])))(_ref2 => {
70
- let {
71
- variables
72
- } = _ref2;
85
+ }, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
86
+ var variables = _ref3.variables;
73
87
  return variables;
74
88
  }, css({
75
89
  textColor: 'text'
76
90
  }), 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"]} */");
77
- export const ColorMode = /*#__PURE__*/forwardRef((_ref3, ref) => {
78
- let {
79
- mode: preference,
80
- alwaysSetVariables,
81
- bg,
82
- ...rest
83
- } = _ref3;
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"]);
84
96
  // checks if the user has set 'system' as their color mode preference
85
97
  // then sets the color mode
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;
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;
95
105
  // This makes sure the background-current context is always set to the correct color + not the semantic color name.
96
- const currentParentBg = useContext(BackgroundCurrentContext);
97
- const bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
106
+ var currentParentBg = useContext(BackgroundCurrentContext);
107
+ var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
98
108
 
99
109
  /** Serialize color variables for the current mode
100
110
  * 1. If all variables are required add all mode variables to the current context
101
111
  * 2. If the user has specified a background color - set that color to the current-bg
102
112
  * 3. If not
103
113
  */
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]);
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;
114
123
  if (active === mode) {
115
- const vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
124
+ var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
116
125
  return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
117
126
  value: {
118
127
  'background-current': bgCurrent
119
128
  },
120
- children: /*#__PURE__*/_jsx(VariableProvider, {
121
- ...rest,
129
+ children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
122
130
  variables: vars,
123
131
  bg: contextBg,
124
132
  ref: ref
125
- })
133
+ }))
126
134
  });
127
135
  }
128
136
  return /*#__PURE__*/_jsx(ThemeProvider, {
129
137
  theme: {
130
- mode
138
+ mode: mode
131
139
  },
132
- children: /*#__PURE__*/_jsx(VariableProvider, {
133
- ...rest,
140
+ children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
134
141
  variables: variables,
135
142
  bg: contextBg,
136
143
  ref: ref
137
- })
144
+ }))
138
145
  });
139
146
  });
@@ -5,35 +5,37 @@ 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, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
9
- export const GamutContext = /*#__PURE__*/React.createContext({
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({
10
12
  hasGlobals: false,
11
13
  hasCache: false
12
14
  });
13
15
  GamutContext.displayName = 'GamutContext';
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;
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;
29
31
 
30
32
  // Do not initialize a new cache if one has been provided as props
31
- const activeCache = useRef(shouldCreateCache && (cache ?? createEmotionCache()));
32
- const contextValue = {
33
+ var activeCache = useRef(shouldCreateCache && (cache !== null && cache !== void 0 ? cache : createEmotionCache()));
34
+ var contextValue = {
33
35
  hasGlobals: shouldInsertGlobals,
34
36
  hasCache: shouldCreateCache
35
37
  };
36
- const globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
38
+ var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
37
39
  children: [/*#__PURE__*/_jsx(Typography, {}), /*#__PURE__*/_jsx(Reboot, {}), /*#__PURE__*/_jsx(Variables, {
38
40
  variables: theme._variables
39
41
  }), variables && /*#__PURE__*/_jsx(Variables, {
@@ -1,4 +1,4 @@
1
1
  import { Options } from '@emotion/cache';
2
2
  export declare const EMOTION_KEY = "gamut";
3
3
  export declare const EMOTION_CONTAINER = "emotion-styles";
4
- export declare const createEmotionCache: (overrides?: Partial<Options>) => import("@emotion/utils").EmotionCache;
4
+ export declare const createEmotionCache: (overrides?: Partial<Options>) => import("@emotion/cache").EmotionCache;