@primer/react
Version:
An implementation of GitHub's Primer Design System using React
63 lines (57 loc) • 2.21 kB
JavaScript
;
var React = require('react');
var styled = require('styled-components');
var Caret = require('../Caret.js');
var constants = require('../constants.js');
var Box = require('../Box/Box.js');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefault(React);
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); }
function PointerBox(props) {
// don't destructure these, just grab them
const themeContext = React__default.default.useContext(styled.ThemeContext);
const {
bg,
border,
borderColor,
theme: themeProp,
sx
} = props;
const {
caret,
children,
...boxProps
} = props;
const {
bg: sxBg,
backgroundColor,
...sxRest
} = sx || {};
const theme = themeProp || themeContext;
const customBackground = bg || sxBg || backgroundColor;
const caretProps = {
bg: bg || (sx === null || sx === void 0 ? void 0 : sx.bg) || (sx === null || sx === void 0 ? void 0 : sx.backgroundColor),
borderColor: borderColor || (sx === null || sx === void 0 ? void 0 : sx.borderColor),
borderWidth: border,
location: caret,
theme
};
const defaultBoxProps = {
borderWidth: '1px',
borderStyle: 'solid',
borderColor: 'border.default',
borderRadius: 2
};
return /*#__PURE__*/React__default.default.createElement(Box, _extends({}, defaultBoxProps, boxProps, {
sx: {
...sxRest,
'--custom-bg': constants.get(`colors.${customBackground}`)({
theme
}),
backgroundImage: customBackground ? `linear-gradient(var(--custom-bg), var(--custom-bg)), linear-gradient(${theme.colors.canvas.default}, ${theme.colors.canvas.default})` : undefined,
position: 'relative'
}
}), children, /*#__PURE__*/React__default.default.createElement(Caret, caretProps));
}
PointerBox.displayName = "PointerBox";
module.exports = PointerBox;