@codecademy/gamut-styles 16.1.4-alpha.cd6532.0 → 16.1.4
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/AssetProvider.js +16 -14
- package/dist/Background.js +45 -28
- package/dist/ColorMode.js +76 -69
- package/dist/GamutProvider.js +19 -19
- package/dist/cache/createEmotionCache.js +26 -11
- package/dist/cache/stylisPlugins/focusVisible.js +4 -4
- package/dist/globals/Reboot.js +6 -4
- package/dist/globals/Typography.js +20 -18
- package/dist/globals/Variables.js +19 -11
- package/dist/remoteAssets/fonts.js +8 -8
- package/dist/styles/boxShadow.js +20 -10
- package/dist/styles/fontSmoothing.js +7 -5
- package/dist/styles/noSelect.js +1 -1
- package/dist/styles/pxRem.js +3 -3
- package/dist/styles/responsive.js +6 -4
- package/dist/styles/screenReaderOnly.js +2 -2
- package/dist/styles/transitionConcat.js +4 -4
- package/dist/themes/admin.js +1 -1
- package/dist/themes/core.js +11 -13
- package/dist/themes/platform.js +1 -1
- package/dist/utilities/themed.js +2 -4
- package/dist/variables/colors.js +18 -19
- package/dist/variables/deprecated-colors.js +16 -17
- package/dist/variables/elements.js +1 -1
- package/dist/variables/responsive.js +6 -4
- package/dist/variables/spacing.js +1 -1
- package/dist/variables/timing.js +5 -5
- package/dist/variables/typography.js +8 -14
- package/dist/variance/config.js +31 -47
- package/dist/variance/index.js +2 -1
- package/dist/variance/props.js +15 -15
- package/dist/variance/utils.js +14 -6
- package/package.json +3 -3
package/dist/AssetProvider.js
CHANGED
|
@@ -1,20 +1,22 @@
|
|
|
1
1
|
import { webFonts } from './remoteAssets/fonts';
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
3
|
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
4
|
-
export
|
|
5
|
-
|
|
6
|
-
filePath,
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
});
|
|
17
|
-
|
|
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() {
|
|
18
20
|
return /*#__PURE__*/_jsx(_Fragment, {
|
|
19
21
|
children: createFontLinks()
|
|
20
22
|
});
|
package/dist/Background.js
CHANGED
|
@@ -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
|
-
|
|
19
|
+
var isColorAlias = function isColorAlias(mode, color) {
|
|
6
20
|
return Object.keys(mode).includes(color);
|
|
7
21
|
};
|
|
8
|
-
export
|
|
9
|
-
|
|
10
|
-
bg
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
37
|
-
|
|
38
|
-
[active]
|
|
39
|
-
|
|
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
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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
|
});
|
package/dist/ColorMode.js
CHANGED
|
@@ -1,4 +1,18 @@
|
|
|
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";
|
|
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); }
|
|
2
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';
|
|
@@ -7,31 +21,26 @@ import { createContext, forwardRef, useContext, useEffect, useMemo, useState } f
|
|
|
7
21
|
import { background, border, color, css, flex, grid, layout, positioning, space } from './variance/props';
|
|
8
22
|
import { styledOptions } from './variance/utils';
|
|
9
23
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
-
export
|
|
11
|
-
export
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
} = theme;
|
|
20
|
-
return serializeTokens(mapValues(theme?.modes[mode], color => colors[color]), 'color', theme).variables;
|
|
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;
|
|
21
33
|
};
|
|
22
|
-
|
|
34
|
+
var BackgroundCurrentContext = /*#__PURE__*/createContext({
|
|
23
35
|
'background-current': undefined
|
|
24
36
|
});
|
|
25
37
|
export function useColorModes() {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
mode,
|
|
29
|
-
modes,
|
|
30
|
-
_getColorValue
|
|
31
|
-
|
|
32
|
-
const modesCopy = {
|
|
33
|
-
...modes
|
|
34
|
-
};
|
|
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);
|
|
35
44
|
if (bgCurrent['background-current'] && modesCopy[mode]['background-current'] !== bgCurrent['background-current']) {
|
|
36
45
|
/* sets the color to the copy of our modes object, and casts the type as the default color values for background-current.
|
|
37
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.
|
|
@@ -39,100 +48,98 @@ export function useColorModes() {
|
|
|
39
48
|
|
|
40
49
|
modesCopy[mode]['background-current'] = bgCurrent['background-current'];
|
|
41
50
|
}
|
|
42
|
-
return [mode, modesCopy
|
|
51
|
+
return [mode, modesCopy === null || modesCopy === void 0 ? void 0 : modesCopy[mode], modes, getColorValue];
|
|
43
52
|
}
|
|
44
53
|
export function useCurrentMode(mode) {
|
|
45
|
-
|
|
46
|
-
|
|
54
|
+
var _useColorModes = useColorModes(),
|
|
55
|
+
_useColorModes2 = _slicedToArray(_useColorModes, 1),
|
|
56
|
+
activeMode = _useColorModes2[0];
|
|
57
|
+
return mode !== null && mode !== void 0 ? mode : activeMode;
|
|
47
58
|
}
|
|
48
59
|
export function usePrefersDarkMode() {
|
|
49
|
-
|
|
50
|
-
|
|
60
|
+
var _useState = useState(false),
|
|
61
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
62
|
+
prefersDarkMode = _useState2[0],
|
|
63
|
+
setPrefersDarkMode = _useState2[1];
|
|
64
|
+
useEffect(function () {
|
|
51
65
|
function onChange(event) {
|
|
52
66
|
setPrefersDarkMode(event.matches);
|
|
53
67
|
}
|
|
54
68
|
if (window && 'matchMedia' in window) {
|
|
55
|
-
|
|
69
|
+
var mq = window.matchMedia('(prefers-color-scheme: dark)');
|
|
56
70
|
if (mq && 'addEventListener' in mq) {
|
|
57
71
|
setPrefersDarkMode(mq.matches);
|
|
58
72
|
mq.addEventListener('change', onChange);
|
|
59
|
-
return ()
|
|
73
|
+
return function () {
|
|
74
|
+
return mq.removeEventListener('change', onChange);
|
|
75
|
+
};
|
|
60
76
|
}
|
|
61
77
|
}
|
|
62
78
|
}, []);
|
|
63
79
|
return prefersDarkMode;
|
|
64
80
|
}
|
|
65
|
-
export
|
|
81
|
+
export var VariableProvider = /*#__PURE__*/_styled('div', _extends({}, {
|
|
66
82
|
target: "e1skjn880",
|
|
67
83
|
label: "VariableProvider"
|
|
68
|
-
}, styledOptions(['variables', 'alwaysSetVariables'])))(
|
|
69
|
-
|
|
70
|
-
variables
|
|
71
|
-
} = _ref2;
|
|
84
|
+
}, styledOptions(['variables', 'alwaysSetVariables'])))(function (_ref3) {
|
|
85
|
+
var variables = _ref3.variables;
|
|
72
86
|
return variables;
|
|
73
87
|
}, css({
|
|
74
88
|
textColor: 'text'
|
|
75
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"]} */");
|
|
76
|
-
export
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
bg
|
|
81
|
-
...rest
|
|
82
|
-
} = _ref3;
|
|
90
|
+
export var ColorMode = /*#__PURE__*/forwardRef(function (_ref4, ref) {
|
|
91
|
+
var preference = _ref4.mode,
|
|
92
|
+
alwaysSetVariables = _ref4.alwaysSetVariables,
|
|
93
|
+
bg = _ref4.bg,
|
|
94
|
+
rest = _objectWithoutProperties(_ref4, ["mode", "alwaysSetVariables", "bg"]);
|
|
83
95
|
// checks if the user has set 'system' as their color mode preference
|
|
84
96
|
// then sets the color mode
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
} = theme;
|
|
93
|
-
const contextBg = bg ? 'background-current' : undefined;
|
|
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;
|
|
94
104
|
// This makes sure the background-current context is always set to the correct color + not the semantic color name.
|
|
95
|
-
|
|
96
|
-
|
|
105
|
+
var currentParentBg = useContext(BackgroundCurrentContext);
|
|
106
|
+
var bgCurrent = bg === 'background-current' ? currentParentBg['background-current'] ? currentParentBg['background-current'] : modes[active]['background-current'] : bg;
|
|
97
107
|
|
|
98
108
|
/** Serialize color variables for the current mode
|
|
99
109
|
* 1. If all variables are required add all mode variables to the current context
|
|
100
110
|
* 2. If the user has specified a background color - set that color to the current-bg
|
|
101
111
|
* 3. If not
|
|
102
112
|
*/
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
return colors[
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
}, [colors, mode, modes, theme, bg]);
|
|
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;
|
|
113
122
|
if (active === mode) {
|
|
114
|
-
|
|
123
|
+
var vars = alwaysSetVariables ? variables : pick(variables, ['--color-background-current']);
|
|
115
124
|
return /*#__PURE__*/_jsx(BackgroundCurrentContext.Provider, {
|
|
116
125
|
value: {
|
|
117
126
|
'background-current': bgCurrent
|
|
118
127
|
},
|
|
119
|
-
children: /*#__PURE__*/_jsx(VariableProvider, {
|
|
120
|
-
...rest,
|
|
128
|
+
children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
|
|
121
129
|
variables: vars,
|
|
122
130
|
bg: contextBg,
|
|
123
131
|
ref: ref
|
|
124
|
-
})
|
|
132
|
+
}))
|
|
125
133
|
});
|
|
126
134
|
}
|
|
127
135
|
return /*#__PURE__*/_jsx(ThemeProvider, {
|
|
128
136
|
theme: {
|
|
129
|
-
mode
|
|
137
|
+
mode: mode
|
|
130
138
|
},
|
|
131
|
-
children: /*#__PURE__*/_jsx(VariableProvider, {
|
|
132
|
-
...rest,
|
|
139
|
+
children: /*#__PURE__*/_jsx(VariableProvider, _objectSpread(_objectSpread({}, rest), {}, {
|
|
133
140
|
variables: variables,
|
|
134
141
|
bg: contextBg,
|
|
135
142
|
ref: ref
|
|
136
|
-
})
|
|
143
|
+
}))
|
|
137
144
|
});
|
|
138
145
|
});
|
package/dist/GamutProvider.js
CHANGED
|
@@ -8,34 +8,34 @@ import { coreTheme } from './themes/core';
|
|
|
8
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
9
|
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
10
10
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
-
export
|
|
11
|
+
export var GamutContext = /*#__PURE__*/React.createContext({
|
|
12
12
|
hasGlobals: false,
|
|
13
13
|
hasCache: false
|
|
14
14
|
});
|
|
15
15
|
GamutContext.displayName = 'GamutContext';
|
|
16
|
-
export
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
theme = coreTheme,
|
|
21
|
-
variables,
|
|
22
|
-
useGlobals =
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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
31
|
|
|
32
32
|
// Do not initialize a new cache if one has been provided as props
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
var activeCache = useRef(shouldCreateCache && (cache !== null && cache !== void 0 ? cache : createEmotionCache()));
|
|
34
|
+
var contextValue = {
|
|
35
35
|
hasGlobals: shouldInsertGlobals,
|
|
36
36
|
hasCache: shouldCreateCache
|
|
37
37
|
};
|
|
38
|
-
|
|
38
|
+
var globals = shouldInsertGlobals && /*#__PURE__*/_jsxs(_Fragment, {
|
|
39
39
|
children: [/*#__PURE__*/_jsx(Typography, {}), /*#__PURE__*/_jsx(Reboot, {}), /*#__PURE__*/_jsx(Variables, {
|
|
40
40
|
variables: theme._variables
|
|
41
41
|
}), variables && /*#__PURE__*/_jsx(Variables, {
|
|
@@ -1,13 +1,25 @@
|
|
|
1
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
2
|
+
function _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); }
|
|
1
13
|
import createCache from '@emotion/cache';
|
|
2
14
|
import { prefixer } from 'stylis';
|
|
3
15
|
import { focusVisible } from './stylisPlugins';
|
|
4
|
-
export
|
|
5
|
-
export
|
|
6
|
-
|
|
16
|
+
export var EMOTION_KEY = 'gamut';
|
|
17
|
+
export var EMOTION_CONTAINER = 'emotion-styles';
|
|
18
|
+
var getEmotionNode = function getEmotionNode() {
|
|
7
19
|
if (typeof document === 'undefined') {
|
|
8
20
|
return;
|
|
9
21
|
}
|
|
10
|
-
|
|
22
|
+
var node = document.getElementById(EMOTION_CONTAINER);
|
|
11
23
|
if (node) return node;
|
|
12
24
|
node = document.createElement('div');
|
|
13
25
|
node.setAttribute('id', EMOTION_CONTAINER);
|
|
@@ -16,10 +28,13 @@ const getEmotionNode = () => {
|
|
|
16
28
|
document.getElementsByTagName('body')[0].prepend(node);
|
|
17
29
|
return node;
|
|
18
30
|
};
|
|
19
|
-
export
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
})
|
|
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,9 +1,9 @@
|
|
|
1
|
-
export
|
|
1
|
+
export var focusVisible = function focusVisible(element) {
|
|
2
2
|
if (element.type === 'rule' && element.value.includes(':focus-visible')) {
|
|
3
3
|
if (typeof element.props === 'string') element.props = [element.props];
|
|
4
|
-
element.props = element.props.map(prop
|
|
5
|
-
|
|
6
|
-
return
|
|
4
|
+
element.props = element.props.map(function (prop) {
|
|
5
|
+
var poly = prop.replace(/:focus-visible/g, '[data-focus-visible-added]');
|
|
6
|
+
return "".concat(prop, ", ").concat(poly);
|
|
7
7
|
});
|
|
8
8
|
}
|
|
9
9
|
return undefined;
|
package/dist/globals/Reboot.js
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { css, Global } from '@emotion/react';
|
|
2
2
|
import { coreTheme as theme } from '../themes';
|
|
3
3
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
4
|
-
const rebootStyles = /*#__PURE__*/css("/**\n * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n * Reboot\n * Normalization of HTML elements, manually forked from Normalize.css to remove\n * styles targeting irrelevant browsers while applying new styles.\n * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n * Document\n * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n * 2 Change the default font family in all browsers.\n * 3 Correct the line height in all browsers.\n * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n * we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n * 6 Change the default tap highlight to be completely transparent in iOS.\n*/*,*::before,*::after{box-sizing:border-box;}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0, 0, 0, 0);}article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block;}body{margin:0;font-family:", theme.fontFamily.base, ";font-weight:", theme.fontWeight.base, ";line-height:", theme.lineHeight.base, ";color:", theme.colors.text, ";text-align:left;background-color:", theme.colors.background, ";}[tabindex='-1']:focus{outline:0!important;}hr{box-sizing:content-box;height:0;overflow:visible;}h1,h2,h3,h4,h5,h6{margin-top:0;}p{margin-top:0;margin-bottom:", theme.spacing[16], ";}abbr[title],abbr[data-original-title]{text-decoration:underline;text-decoration:underline dotted;cursor:help;border-bottom:0;}address{margin-bottom:1rem;font-style:normal;line-height:inherit;}ol,ul,dl{margin-top:0;margin-bottom:1rem;}ol ol,ul ul,ol ul,ul ol{margin-bottom:0;}dt{font-weight:", theme.fontWeight.title, ";}dd{margin-bottom:0.5rem;margin-left:0;}blockquote{margin:0 0 1rem;}dfn{font-style:italic;}b,strong{font-weight:", theme.fontWeight.title, ";}small{font-size:", theme.fontSize[14], ";}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline;}sub{bottom:-0.25em;}sup{top:-0.5em;}a{color:", theme.colors.primary, ";text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects;&:hover{text-decoration:underline;}}a:not([href]):not([tabindex]){color:inherit;text-decoration:none;&:hover,&:focus{color:inherit;text-decoration:none;}&:focus{outline:0;}}pre,code,kbd,samp{font-family:monospace,monospace;font-size:1em;}pre{margin-top:0;margin-bottom:1rem;overflow:auto;/* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */-ms-overflow-style:scrollbar;}figure{margin:0 0 1rem;}img{vertical-align:middle;border-style:none;}svg:not(:root){overflow:hidden;}table{border-collapse:collapse;}caption{padding-top:", theme.spacing[16], ";padding-bottom:", theme.spacing[16], ";color:", theme.spacing[16], ";text-align:left;caption-side:bottom;}th{text-align:inherit;}label{display:inline-block;margin-bottom:0;}button{border-radius:0;}button:focus-visible{outline:1px dotted;outline:5px auto -webkit-focus-ring-color;}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit;}button,input{overflow:visible;}button,select{text-transform:none;}button,html [type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;}input[type='radio'],input[type='checkbox']{box-sizing:border-box;padding:0;}input[type='date'],input[type='time'],input[type='datetime-local'],input[type='month']{-webkit-appearance:listbox;}textarea{overflow:auto;resize:vertical;}fieldset{min-width:0;padding:0;margin:0;border:0;}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:0.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal;}progress{vertical-align:baseline;}[type='number']::-webkit-inner-spin-button,[type='number']::-webkit-outer-spin-button{height:auto;}[type='search']{outline-offset:-2px;-webkit-appearance:none;}[type='search']::-webkit-search-cancel-button,[type='search']::-webkit-search-decoration{-webkit-appearance:none;}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button;}output{display:inline-block;}summary{display:list-item;cursor:pointer;}template{display:none;}[hidden]{display:none!important;};label:rebootStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/globals/Reboot.tsx"],"names":[],"mappings":"AAIwB","file":"../../src/globals/Reboot.tsx","sourcesContent":["import { css, Global } from '@emotion/react';\n\nimport { coreTheme as theme } from '../themes';\n\nconst rebootStyles = css`\n  /**\n  * https://raw.githubusercontent.com/twbs/bootstrap/v4-dev/scss/_reboot.scss\n  * Reboot\n  * Normalization of HTML elements, manually forked from Normalize.css to remove\n  * styles targeting irrelevant browsers while applying new styles.\n  * Normalize is licensed MIT. https://github.com/necolas/normalize.css\n  * Document\n  * 1 Change from 'box-sizing: content-box' so that 'width' is affected by 'padding' and 'border'.\n  * 2 Change the default font family in all browsers.\n  * 3 Correct the line height in all browsers.\n  * 4 Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.\n  * 5 Setting @viewport causes scrollbars to overlap content in IE11 and Edge, so\n  *    we force a non-overlapping, non-auto-hiding scrollbar to counteract.\n  * 6 Change the default tap highlight to be completely transparent in iOS.\n*/\n\n  *,\n  *::before,\n  *::after {\n    /* This is changed from content-box to border-box as all of our css relies on it */\n    box-sizing: border-box; /** 1 */\n  }\n\n  html {\n    font-family: sans-serif; /** 2 */\n    line-height: 1.15; /** 3 */\n    -webkit-text-size-adjust: 100%; /** 4 */\n    -ms-text-size-adjust: 100%; /** 4 */\n    -ms-overflow-style: scrollbar; /** 5 */\n    -webkit-tap-highlight-color: rgba(0, 0, 0, 0); /** 6 */\n  }\n\n  /**Shim for \"new\" HTML5 structural elements to display correctly (IE10, older browsers) */\n\n  article,\n  aside,\n  dialog,\n  figcaption,\n  figure,\n  footer,\n  header,\n  hgroup,\n  main,\n  nav,\n  section {\n    display: block;\n  }\n  /** Body\n   1. Remove the margin in all browsers.\n   2. As a best practice, apply a default \\`background-color\\`.\n   3. Set an explicit initial text-align value so that we can later use the\n      the \\`inherit\\` value on things like \\`<th>\\` elements.\n   */\n\n  body {\n    margin: 0;\n    font-family: ${theme.fontFamily.base};\n    font-weight: ${theme.fontWeight.base};\n    line-height: ${theme.lineHeight.base};\n    color: ${theme.colors.text};\n    text-align: left;\n    background-color: ${theme.colors.background};\n  }\n\n  /* Suppress the focus outline on elements that cannot be accessed via keyboard.\n  This prevents an unwanted focus outline from appearing around elements that\n  might still respond to pointer events.\n Credit: https://github.com/suitcss/base */\n\n  [tabindex='-1']:focus {\n    outline: 0 !important;\n  }\n\n  /*\n  Content grouping\n 1. Add the correct box sizing in Firefox.\n  2. Show the overflow in Edge and IE.\n*/\n\n  hr {\n    box-sizing: content-box;\n    /* 1 */\n    height: 0;\n    /* 2 */\n    overflow: visible;\n  }\n  /* Typography */\n  /*\n  Remove top margins from headings\n   By default, \\`<h1>\\`-\\`<h6>\\` all receive top and bottom margins. We nuke the top\n  margin for easier control within type scales as it avoids margin collapsing.\n*/\n\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6 {\n    margin-top: 0;\n  }\n\n  /*\n  Reset margins on paragraphs\n  Similarly, the top margin on \\`<p>\\`s get reset. However, we also reset the\n  bottom margin to use \\`rem\\` units instead of \\`em\\`.\n  */\n\n  p {\n    margin-top: 0;\n    margin-bottom: ${theme.spacing[16]};\n  }\n\n  /*\n  Abbreviations\n  1. Remove the bottom border in Firefox 39-.\n  2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n  3. Add explicit cursor to indicate changed behavior.\n  4. Duplicate behavior to the data-* attribute for our tooltip plugin\n  */\n\n  abbr[title],\n  abbr[data-original-title] {\n    /* 4 */\n    text-decoration: underline;\n    text-decoration: underline dotted;\n    cursor: help;\n    border-bottom: 0;\n  }\n\n  address {\n    margin-bottom: 1rem;\n    font-style: normal;\n    line-height: inherit;\n  }\n\n  ol,\n  ul,\n  dl {\n    margin-top: 0;\n    margin-bottom: 1rem;\n  }\n\n  ol ol,\n  ul ul,\n  ol ul,\n  ul ol {\n    margin-bottom: 0;\n  }\n\n  dt {\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  dd {\n    /* Undo browser default */\n    margin-bottom: 0.5rem;\n    margin-left: 0;\n  }\n\n  blockquote {\n    margin: 0 0 1rem;\n  }\n\n  dfn {\n    /* Add the correct font style in Android 4.3- */\n    font-style: italic;\n  }\n\n  b,\n  strong {\n    /* Add the correct font weight in Chrome, Edge, and Safari */\n    font-weight: ${theme.fontWeight.title};\n  }\n\n  small {\n    /* Add the correct font size in all browsers */\n    font-size: ${theme.fontSize[14]};\n  }\n\n  /*\n Prevent \\`sub\\` and \\`sup\\` elements from affecting the line height in\n  all browsers.\n*/\n  sub,\n  sup {\n    position: relative;\n    font-size: 75%;\n    line-height: 0;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n  sup {\n    top: -0.5em;\n  }\n\n  /*\n Links\n  Remove the gray background on active links in IE 10.\n  Remove gaps in links underline in iOS 8+ and Safari 8+.\n*/\n\n  a {\n    color: ${theme.colors.primary};\n    text-decoration: none;\n\n    background-color: transparent;\n    -webkit-text-decoration-skip: objects;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n\n  /*\n  And undo these styles for placeholder links/named anchors (without href)\n  which have not been made explicitly keyboard-focusable (without tabindex).\n  It would be more straightforward to just use a[href] in previous block, but that\n  causes specificity issues in many other styles that are too complex to fix.\n  */\n\n  a:not([href]):not([tabindex]) {\n    color: inherit;\n    text-decoration: none;\n\n    &:hover,\n    &:focus {\n      color: inherit;\n      text-decoration: none;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n  }\n\n  /* Code */\n\n  pre,\n  code,\n  kbd,\n  samp {\n    /* Correct the inheritance and scaling of font size in all browsers. */\n    font-family: monospace, monospace;\n    /* Correct the odd \\`em\\` font sizing in all browsers.*/\n    font-size: 1em;\n  }\n  /* stylelint-enable font-family-no-duplicate-names */\n\n  pre {\n    /* Remove browser default top margin */\n    margin-top: 0;\n    /* Reset browser default of \\`1em\\` to use \\`rem\\`s */\n    margin-bottom: 1rem;\n    /* Don't allow content to break outside */\n    overflow: auto;\n    /* We have @viewport set which causes scrollbars to overlap content in IE11 and Edge, so */\n    /* we force a non-overlapping, non-auto-hiding scrollbar to counteract. */\n    -ms-overflow-style: scrollbar;\n  }\n\n  /*\nFigures\n*/\n  figure {\n    /* Apply a consistent margin strategy (matches our type styles). */\n    margin: 0 0 1rem;\n  }\n\n  /* Images and content */\n  img {\n    vertical-align: middle;\n    /* Remove the border on images inside links in IE 10-. */\n    border-style: none;\n  }\n\n  svg:not(:root) {\n    /* Hide the overflow in IE */\n    overflow: hidden;\n  }\n\n  /* Tables  */\n  table {\n    /* *  Prevent double borders */\n    border-collapse: collapse;\n  }\n\n  caption {\n    padding-top: ${theme.spacing[16]};\n    padding-bottom: ${theme.spacing[16]};\n    color: ${theme.spacing[16]};\n    text-align: left;\n    caption-side: bottom;\n  }\n\n  th {\n    /*  Matches default \\`<td>\\` alignment by inheriting from the \\`<body>\\`, or the\n  closest parent with a set \\`text-align\\`. */\n    text-align: inherit;\n  }\n\n  /* Forms */\n\n  label {\n    /* Allow labels to use \\`margin\\` for spacing. */\n    display: inline-block;\n    margin-bottom: 0;\n  }\n\n  /* Remove the default \\`border-radius\\` that macOS Chrome adds.\n Details at https://github.com/twbs/bootstrap/issues/24093     */\n\n  button {\n    border-radius: 0;\n  }\n\n  /*\n  Work around a Firefox/IE bug where the transparent \\`button\\` background\n  results in a loss of the default \\`button\\` focus styles.\n  Credit: https://github.com/suitcss/base/\n  */\n\n  button:focus-visible {\n    outline: 1px dotted;\n    outline: 5px auto -webkit-focus-ring-color;\n  }\n\n  input,\n  button,\n  select,\n  optgroup,\n  textarea {\n    /* Remove the margin in Firefox and Safari */\n    margin: 0;\n    font-family: inherit;\n    font-size: inherit;\n    line-height: inherit;\n  }\n\n  button,\n  input {\n    /* Show the overflow in Edge */\n    overflow: visible;\n  }\n\n  button,\n  select {\n    /* Remove the inheritance of text transform in Firefox */\n    text-transform: none;\n  }\n\n  /*\n  1. Prevent a WebKit bug where (2) destroys native \\`audio\\` and \\`video\\`\n    controls in Android 4.\n  2. Correct the inability to style clickable types in iOS and Safari.\n  */\n  button,\n  html [type='button'],\n  [type='reset'],\n  [type='submit'] {\n    /* 2 */\n    -webkit-appearance: button;\n  }\n\n  input[type='radio'],\n  input[type='checkbox'] {\n    /*  1. Add the correct box sizing in IE 10- */\n    box-sizing: border-box;\n    /* 2. Remove the padding in IE 10- */\n    padding: 0;\n  }\n\n  input[type='date'],\n  input[type='time'],\n  input[type='datetime-local'],\n  input[type='month'] {\n    /* Remove the default appearance of temporal inputs to avoid a Mobile Safari\n    bug where setting a custom line-height prevents text from being vertically\n    centered within the input.\n    See https://bugs.webkit.org/show_bug.cgi?id=139848\n    and https://github.com/twbs/bootstrap/issues/11266 */\n    -webkit-appearance: listbox;\n  }\n\n  textarea {\n    /* Remove the default vertical scrollbar in IE. */\n    overflow: auto;\n    /* Textareas should really only resize vertically so they don't break their (horizontal) containers. */\n    resize: vertical;\n  }\n\n  fieldset {\n    /* Browsers set a default \\`min-width: min-content;\\` on fieldsets,\n  unlike e.g. \\`<div>\\`s, which have \\`min-width: 0;\\` by default.\n  So we reset that to ensure fieldsets behave more like a standard block element.\n  See https://github.com/twbs/bootstrap/issues/12359\n  and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements */\n    min-width: 0;\n    /* Reset the default outline behavior of fieldsets so they don't affect page layout.*/\n    padding: 0;\n    margin: 0;\n    border: 0;\n  }\n\n  /* 1. Correct the text wrapping in Edge and IE. */\n  /* 2. Correct the color inheritance from \\`fieldset\\` elements in IE. */\n  legend {\n    display: block;\n    width: 100%;\n    /* 1 */\n    max-width: 100%;\n    padding: 0;\n    margin-bottom: 0.5rem;\n    font-size: 1.5rem;\n    line-height: inherit;\n    /* 2 */\n    color: inherit;\n    /* 1 */\n    white-space: normal;\n  }\n\n  progress {\n    /* Add the correct vertical alignment in Chrome, Firefox, and Opera. */\n    vertical-align: baseline;\n  }\n\n  /* Correct the cursor style of increment and decrement buttons in Chrome. */\n  [type='number']::-webkit-inner-spin-button,\n  [type='number']::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  [type='search'] {\n    /*\n    This overrides the extra rounded corners on search inputs in iOS so that our\n    \\`.form-control\\` class can properly style them. Note that this cannot simply\n    be added to \\`.form-control\\` as it's not specific enough. For details, see\n    https://github.com/twbs/bootstrap/issues/11586.\n    */\n    /* 2. Correct the outline style in Safari. */\n    outline-offset: -2px;\n    -webkit-appearance: none;\n  }\n\n  /* Remove the inner padding and cancel buttons in Chrome and Safari on macOS. */\n\n  [type='search']::-webkit-search-cancel-button,\n  [type='search']::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  /*\n  1. Correct the inability to style clickable types in iOS and Safari.\n  2. Change font properties to \\`inherit\\` in Safari.\n  */\n  ::-webkit-file-upload-button {\n    /* 2 */\n    font: inherit;\n    /* 1 */\n    -webkit-appearance: button;\n  }\n\n  /* Correct element displays */\n\n  output {\n    display: inline-block;\n  }\n\n  summary {\n    /* Add the correct display in all browsers */\n    display: list-item;\n    cursor: pointer;\n  }\n\n  template {\n    /* Add the correct display in IE */\n    display: none;\n  }\n\n  /*\n  Always hide an element with the \\`hidden\\` HTML attribute (from PureCSS).\n  Needed for proper display in IE 10-.\n  */\n  [hidden] {\n    display: none !important;\n  }\n`;\n\nexport const Reboot = () => <Global styles={rebootStyles} />;\n"]} */"));
|
|
5
|
-
export
|
|
6
|
-
|
|
7
|
-
|
|
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
|
+
};
|