UNPKG

@primer/react

Version:

An implementation of GitHub's Primer Design System using React

55 lines (47 loc) 2.67 kB
'use strict'; var React = require('react'); var styled = require('styled-components'); var constants = require('./constants.js'); var ThemeProvider = require('./ThemeProvider.js'); require('focus-visible'); function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; } var React__default = /*#__PURE__*/_interopDefault(React); var styled__default = /*#__PURE__*/_interopDefault(styled); 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); } const GlobalStyle = styled.createGlobalStyle(["*{box-sizing:border-box;}body{margin:0;}table{border-collapse:collapse;}input{color-scheme:", ";}[role=\"button\"]:focus:not(:focus-visible):not(.focus-visible),[role=\"tabpanel\"][tabindex=\"0\"]:focus:not(:focus-visible):not(.focus-visible),button:focus:not(:focus-visible):not(.focus-visible),summary:focus:not(:focus-visible):not(.focus-visible),a:focus:not(:focus-visible):not(.focus-visible){outline:none;box-shadow:none;}[tabindex=\"0\"]:focus:not(:focus-visible):not(.focus-visible),details-dialog:focus:not(:focus-visible):not(.focus-visible){outline:none;}"], props => props.colorScheme); const Base = styled__default.default.div.withConfig({ displayName: "BaseStyles__Base", componentId: "sc-nfjs56-0" })(["", ";", ";"], constants.TYPOGRAPHY, constants.COMMON); function BaseStyles(props) { const { children, color = 'fg.default', fontFamily = 'normal', lineHeight = 'default', ...rest } = props; const { colorScheme, dayScheme, nightScheme } = ThemeProvider.useTheme(); /** * We need to map valid primer/react color modes onto valid color modes for primer/primitives * valid color modes for primer/primitives: auto | light | dark * valid color modes for primer/primer: auto | day | night | light | dark */ return /*#__PURE__*/React__default.default.createElement(Base, _extends({}, rest, { color: color, fontFamily: fontFamily, lineHeight: lineHeight, "data-portal-root": true, "data-color-mode": colorScheme !== null && colorScheme !== void 0 && colorScheme.includes('dark') ? 'dark' : 'light', "data-light-theme": dayScheme, "data-dark-theme": nightScheme }), /*#__PURE__*/React__default.default.createElement(GlobalStyle, { colorScheme: colorScheme !== null && colorScheme !== void 0 && colorScheme.includes('dark') ? 'dark' : 'light' }), children); } BaseStyles.displayName = "BaseStyles"; module.exports = BaseStyles;