@codecademy/gamut-styles 14.1.0 → 14.1.1-alpha.79dadf.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.
package/dist/ColorMode.js CHANGED
@@ -102,7 +102,7 @@ export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
102
102
  return variables;
103
103
  }, css({
104
104
  textColor: 'text'
105
- }), providerProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9Db2xvck1vZGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1JZ0MiLCJmaWxlIjoiLi4vc3JjL0NvbG9yTW9kZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBzZXJpYWxpemVUb2tlbnMsXG4gIFN0eWxlUHJvcHMsXG4gIFRoZW1lUHJvcHMsXG4gIHZhcmlhbmNlLFxufSBmcm9tICdAY29kZWNhZGVteS92YXJpYW5jZSc7XG5pbXBvcnQgeyBDU1NPYmplY3QsIFRoZW1lLCBUaGVtZVByb3ZpZGVyLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IG1hcFZhbHVlcywgcGljayB9IGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgUmVhY3QsIHtcbiAgQ29tcG9uZW50UHJvcHMsXG4gIGZvcndhcmRSZWYsXG4gIHVzZUNvbnRleHQsXG4gIHVzZUVmZmVjdCxcbiAgdXNlTWVtbyxcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgdGhlbWUgYXMgR2FtdXRUaGVtZSB9IGZyb20gJy4nO1xuaW1wb3J0IHtcbiAgYmFja2dyb3VuZCxcbiAgYm9yZGVyLFxuICBjb2xvcixcbiAgY3NzLFxuICBmbGV4LFxuICBncmlkLFxuICBsYXlvdXQsXG4gIHBvc2l0aW9uaW5nLFxuICBzcGFjZSxcbn0gZnJvbSAnLi92YXJpYW5jZS9wcm9wcyc7XG5pbXBvcnQgeyBzdHlsZWRPcHRpb25zIH0gZnJvbSAnLi92YXJpYW5jZS91dGlscyc7XG5cbmV4cG9ydCB0eXBlIENvbG9ycyA9IGtleW9mIFRoZW1lWydjb2xvcnMnXTtcbmV4cG9ydCB0eXBlIENvbG9yTW9kZUNvbmZpZyA9IFRoZW1lWydtb2RlcyddO1xuZXhwb3J0IHR5cGUgQ29sb3JNb2RlcyA9IGtleW9mIENvbG9yTW9kZUNvbmZpZztcbmV4cG9ydCB0eXBlIENvbG9yTW9kZVNoYXBlID0gQ29sb3JNb2RlQ29uZmlnW0NvbG9yTW9kZXNdO1xuZXhwb3J0IHR5cGUgQ29sb3JBbGlhcyA9IGtleW9mIENvbG9yTW9kZVNoYXBlO1xuXG5leHBvcnQgdHlwZSBDb2xvck1vZGVQcm9wcyA9IHtcbiAgbW9kZTogQ29sb3JNb2RlcyB8ICdzeXN0ZW0nO1xuICBiZz86IENvbG9ycztcbn07XG5cbmV4cG9ydCBjb25zdCBwcm92aWRlclByb3BzID0gdmFyaWFuY2UuY29tcG9zZShcbiAgbGF5b3V0LFxuICBjb2xvcixcbiAgZ3JpZCxcbiAgZmxleCxcbiAgcG9zaXRpb25pbmcsXG4gIHNwYWNlLFxuICBib3JkZXIsXG4gIGJhY2tncm91bmRcbik7XG5cbmV4cG9ydCBjb25zdCBtb2RlQ29sb3JQcm9wcyA9ICh7XG4gIHRoZW1lLFxuICBtb2RlLFxufTogVGhlbWVQcm9wczx7IG1vZGU/OiBDb2xvck1vZGVzIH0+KSA9PiB7XG4gIGlmICghdGhlbWUgfHwgIW1vZGUgfHwgbW9kZSA9PT0gdGhlbWU/Lm1vZGUpIHJldHVybiB7fTtcbiAgY29uc3QgeyBjb2xvcnMgfSA9IHRoZW1lO1xuICByZXR1cm4gc2VyaWFsaXplVG9rZW5zKFxuICAgIG1hcFZhbHVlcyh0aGVtZT8ubW9kZXNbbW9kZV0sIChjb2xvcikgPT4gY29sb3JzW2NvbG9yXSksXG4gICAgJ2NvbG9yJyxcbiAgICB0aGVtZVxuICApLnZhcmlhYmxlcztcbn07XG5cbmludGVyZmFjZSBCYWNrZ3JvdW5kQ3VycmVudENvbnRleHRJbnRlcmZhY2Uge1xuICAnYmFja2dyb3VuZC1jdXJyZW50Jz86IGtleW9mIHR5cGVvZiBHYW11dFRoZW1lLmNvbG9ycztcbn1cblxuY29uc3QgQmFja2dyb3VuZEN1cnJlbnRDb250ZXh0ID0gUmVhY3QuY3JlYXRlQ29udGV4dDxCYWNrZ3JvdW5kQ3VycmVudENvbnRleHRJbnRlcmZhY2U+KFxuICB7XG4gICAgJ2JhY2tncm91bmQtY3VycmVudCc6IHVuZGVmaW5lZCxcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUNvbG9yTW9kZXMoKTogW1xuICBDb2xvck1vZGVzLFxuICBDb2xvck1vZGVTaGFwZSxcbiAgQ29sb3JNb2RlQ29uZmlnLFxuICAoY29sb3I6IENvbG9ycykgPT4gc3RyaW5nXG5dIHtcbiAgY29uc3QgYmdDdXJyZW50ID0gdXNlQ29udGV4dChCYWNrZ3JvdW5kQ3VycmVudENvbnRleHQpO1xuICBjb25zdCB7IG1vZGUsIG1vZGVzLCBfZ2V0Q29sb3JWYWx1ZTogZ2V0Q29sb3JWYWx1ZSB9ID0gdXNlVGhlbWUoKSB8fCB7fTtcbiAgY29uc3QgbW9kZXNDb3B5ID0geyAuLi5tb2RlcyB9O1xuXG4gIGlmIChcbiAgICBiZ0N1cnJlbnRbJ2JhY2tncm91bmQtY3VycmVudCddICYmXG4gICAgbW9kZXNDb3B5W21vZGVdWydiYWNrZ3JvdW5kLWN1cnJlbnQnXSAhPT0gYmdDdXJyZW50WydiYWNrZ3JvdW5kLWN1cnJlbnQnXVxuICApIHtcbiAgICAvKiBzZXRzIHRoZSBjb2xvciB0byB0aGUgY29weSBvZiBvdXIgbW9kZXMgb2JqZWN0LCBhbmQgY2FzdHMgdGhlIHR5cGUgYXMgdGhlIGRlZmF1bHQgY29sb3IgdmFsdWVzIGZvciBiYWNrZ3JvdW5kLWN1cnJlbnQuXG4gICAgd2UgY291bGQgcG90ZW50aWFsbHkgYWx0ZXIgdGhlIE1lcmdlIHR5cGUgdXRpbGl0eSBmdW5jdGlvbiBmcm9tIGNyZWF0ZVRoZW1lLCBidXQgc2luY2UgJ2JhY2tncm91bmQtY3VycmVudCcgaXMgdGhlIG9ubHkgZXhjZXB0aW9uIHRvIHRoZSB0eXBlLW1lcmdpbmcgcnVsZSAgYW5kIHRoaXMgaXMgdGhlIG9ubHkgcGxhY2Ugd2Ugb3ZlcnJpZGUsIHRoaXMgc2VlbXMgdG8gYmUgYSBtb3JlIHN0cmFpZ2h0Zm9yd2FyZCArIGxvd2VyLXJpc2sgc29sdXRpb24uXG4gICAgKi9cblxuICAgIG1vZGVzQ29weVttb2RlXVsnYmFja2dyb3VuZC1jdXJyZW50J10gPSBiZ0N1cnJlbnRbJ2JhY2tncm91bmQtY3VycmVudCddIGFzXG4gICAgICB8ICd3aGl0ZSdcbiAgICAgIHwgJ25hdnktODAwJztcbiAgfVxuXG4gIHJldHVybiBbbW9kZSwgbW9kZXNDb3B5Py5bbW9kZV0sIG1vZGVzLCBnZXRDb2xvclZhbHVlXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUN1cnJlbnRNb2RlKG1vZGU/OiBDb2xvck1vZGVzKSB7XG4gIGNvbnN0IFthY3RpdmVNb2RlXSA9IHVzZUNvbG9yTW9kZXMoKTtcbiAgcmV0dXJuIG1vZGUgPz8gYWN0aXZlTW9kZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVByZWZlcnNEYXJrTW9kZSgpIHtcbiAgY29uc3QgW3ByZWZlcnNEYXJrTW9kZSwgc2V0UHJlZmVyc0RhcmtNb2RlXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGZ1bmN0aW9uIG9uQ2hhbmdlKGV2ZW50OiBNZWRpYVF1ZXJ5TGlzdEV2ZW50KSB7XG4gICAgICBzZXRQcmVmZXJzRGFya01vZGUoZXZlbnQubWF0Y2hlcyk7XG4gICAgfVxuXG4gICAgaWYgKHdpbmRvdyAmJiAnbWF0Y2hNZWRpYScgaW4gd2luZG93KSB7XG4gICAgICBjb25zdCBtcSA9IHdpbmRvdy5tYXRjaE1lZGlhKCcocHJlZmVycy1jb2xvci1zY2hlbWU6IGRhcmspJyk7XG5cbiAgICAgIGlmIChtcSAmJiAnYWRkRXZlbnRMaXN0ZW5lcicgaW4gbXEpIHtcbiAgICAgICAgc2V0UHJlZmVyc0RhcmtNb2RlKG1xLm1hdGNoZXMpO1xuICAgICAgICBtcS5hZGRFdmVudExpc3RlbmVyKCdjaGFuZ2UnLCBvbkNoYW5nZSk7XG5cbiAgICAgICAgcmV0dXJuICgpID0+IG1xLnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2NoYW5nZScsIG9uQ2hhbmdlKTtcbiAgICAgIH1cbiAgICB9XG4gIH0sIFtdKTtcblxuICByZXR1cm4gcHJlZmVyc0RhcmtNb2RlO1xufVxuXG5leHBvcnQgY29uc3QgVmFyaWFibGVQcm92aWRlciA9IHN0eWxlZChcbiAgJ2RpdicsXG4gIHN0eWxlZE9wdGlvbnMoWyd2YXJpYWJsZXMnLCAnYWx3YXlzU2V0VmFyaWFibGVzJ10pXG4pPFxuICBTdHlsZVByb3BzPHR5cGVvZiBwcm92aWRlclByb3BzPiAmIHtcbiAgICB2YXJpYWJsZXM/OiBDU1NPYmplY3Q7XG4gICAgYWx3YXlzU2V0VmFyaWFibGVzPzogYm9vbGVhbjtcbiAgfVxuPigoeyB2YXJpYWJsZXMgfSkgPT4gdmFyaWFibGVzLCBjc3MoeyB0ZXh0Q29sb3I6ICd0ZXh0JyB9KSwgcHJvdmlkZXJQcm9wcyk7XG5cbmV4cG9ydCBjb25zdCBDb2xvck1vZGUgPSBmb3J3YXJkUmVmPFxuICBIVE1MRGl2RWxlbWVudCxcbiAgT21pdDxDb21wb25lbnRQcm9wczx0eXBlb2YgVmFyaWFibGVQcm92aWRlcj4sICdiZyc+ICYgQ29sb3JNb2RlUHJvcHNcbj4oKHsgbW9kZTogcHJlZmVyZW5jZSwgYWx3YXlzU2V0VmFyaWFibGVzLCBiZywgLi4ucmVzdCB9LCByZWYpID0+IHtcbiAgLy8gY2hlY2tzIGlmIHRoZSB1c2VyIGhhcyBzZXQgJ3N5c3RlbScgYXMgdGhlaXIgY29sb3IgbW9kZSBwcmVmZXJlbmNlXG4gIC8vIHRoZW4gc2V0cyB0aGUgY29sb3IgbW9kZVxuICBjb25zdCBwcmVmZXJzRGFya01vZGUgPSB1c2VQcmVmZXJzRGFya01vZGUoKTtcbiAgY29uc3QgbW9kZSA9XG4gICAgcHJlZmVyZW5jZSA9PT0gJ3N5c3RlbScgPyAocHJlZmVyc0RhcmtNb2RlID8gJ2RhcmsnIDogJ2xpZ2h0JykgOiBwcmVmZXJlbmNlO1xuXG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcbiAgY29uc3QgeyBtb2RlcywgbW9kZTogYWN0aXZlLCBjb2xvcnMgfSA9IHRoZW1lO1xuICBjb25zdCBjb250ZXh0QmcgPSBiZyA/ICdiYWNrZ3JvdW5kLWN1cnJlbnQnIDogdW5kZWZpbmVkO1xuXG4gIC8qKiBTZXJpYWxpemUgY29sb3IgdmFyaWFibGVzIGZvciB0aGUgY3VycmVudCBtb2RlXG4gICAqIDEuIElmIGFsbCB2YXJpYWJsZXMgYXJlIHJlcXVpcmVkIGFkZCBhbGwgbW9kZSB2YXJpYWJsZXMgdG8gdGhlIGN1cnJlbnQgY29udGV4dFxuICAgKiAyLiBJZiB0aGUgdXNlciBoYXMgc3BlY2lmaWVkIGEgYmFja2dyb3VuZCBjb2xvciAtIHNldCB0aGF0IGNvbG9yIHRvIHRoZSBjdXJyZW50LWJnXG4gICAqIDMuIElmIG5vdFxuICAgKi9cbiAgY29uc3QgeyB2YXJpYWJsZXMgfSA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIHJldHVybiBzZXJpYWxpemVUb2tlbnMoXG4gICAgICBtYXBWYWx1ZXMobW9kZXNbbW9kZV0sIChjb2xvciwga2V5KSA9PiB7XG4gICAgICAgIGlmIChrZXkgPT09ICdiYWNrZ3JvdW5kLWN1cnJlbnQnICYmIHR5cGVvZiBiZyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgICByZXR1cm4gY29sb3JzW2JnXTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29sb3JzW2NvbG9yXTtcbiAgICAgIH0pLFxuICAgICAgJ2NvbG9yJyxcbiAgICAgIHRoZW1lXG4gICAgKTtcbiAgfSwgW2NvbG9ycywgbW9kZSwgbW9kZXMsIHRoZW1lLCBiZ10pO1xuXG4gIGlmIChhY3RpdmUgPT09IG1vZGUpIHtcbiAgICBjb25zdCB2YXJzID0gYWx3YXlzU2V0VmFyaWFibGVzXG4gICAgICA/IHZhcmlhYmxlc1xuICAgICAgOiBwaWNrKHZhcmlhYmxlcywgWyctLWNvbG9yLWJhY2tncm91bmQtY3VycmVudCddKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8QmFja2dyb3VuZEN1cnJlbnRDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXt7ICdiYWNrZ3JvdW5kLWN1cnJlbnQnOiBiZyB9fT5cbiAgICAgICAgPFZhcmlhYmxlUHJvdmlkZXIgey4uLnJlc3R9IHZhcmlhYmxlcz17dmFyc30gYmc9e2NvbnRleHRCZ30gcmVmPXtyZWZ9IC8+XG4gICAgICA8L0JhY2tncm91bmRDdXJyZW50Q29udGV4dC5Qcm92aWRlcj5cbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8VGhlbWVQcm92aWRlciB0aGVtZT17eyBtb2RlIH19PlxuICAgICAgPFZhcmlhYmxlUHJvdmlkZXJcbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHZhcmlhYmxlcz17dmFyaWFibGVzfVxuICAgICAgICBiZz17Y29udGV4dEJnfVxuICAgICAgICByZWY9e3JlZn1cbiAgICAgIC8+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufSk7XG4iXX0= */");
105
+ }), providerProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ColorMode.tsx"],"names":[],"mappings":"AAmIgC","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 React, {\n  ComponentProps,\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 = React.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\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"]} */");
106
106
  export var ColorMode = /*#__PURE__*/forwardRef(function ColorMode(_ref4, ref) {
107
107
  var preference = _ref4.mode,
108
108
  alwaysSetVariables = _ref4.alwaysSetVariables,
@@ -117,7 +117,10 @@ export var ColorMode = /*#__PURE__*/forwardRef(function ColorMode(_ref4, ref) {
117
117
  var modes = theme.modes,
118
118
  active = theme.mode,
119
119
  colors = theme.colors;
120
- var contextBg = bg ? 'background-current' : undefined;
120
+ var contextBg = bg ? 'background-current' : undefined; // This makes sure the background-current context is always set to the correct color + not the semantic color name.
121
+
122
+ var currentParentBg = useContext(BackgroundCurrentContext);
123
+ var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
121
124
  /** Serialize color variables for the current mode
122
125
  * 1. If all variables are required add all mode variables to the current context
123
126
  * 2. If the user has specified a background color - set that color to the current-bg
@@ -139,7 +142,7 @@ export var ColorMode = /*#__PURE__*/forwardRef(function ColorMode(_ref4, ref) {
139
142
  var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
140
143
  return /*#__PURE__*/React.createElement(BackgroundCurrentContext.Provider, {
141
144
  value: {
142
- 'background-current': bg
145
+ 'background-current': bgCurrent
143
146
  }
144
147
  }, /*#__PURE__*/React.createElement(VariableProvider, _extends({}, rest, {
145
148
  variables: vars,
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@codecademy/gamut-styles",
3
3
  "description": "Styleguide & Component library for codecademy.com",
4
- "version": "14.1.0",
4
+ "version": "14.1.1-alpha.79dadf.0",
5
5
  "author": "Jake Hiller <jake@codecademy.com>",
6
6
  "main": "dist/index.js",
7
7
  "module": "dist/index.js",
@@ -43,5 +43,5 @@
43
43
  "publishConfig": {
44
44
  "access": "public"
45
45
  },
46
- "gitHead": "7e19b74a1c4c59938e4a6714c4b7e6f7ebb1d147"
46
+ "gitHead": "00c5ef23aabfe2e70790f1e4bceff1f3d51e72b9"
47
47
  }