@primer/react
Version:
An implementation of GitHub's Primer Design System using React
104 lines (96 loc) • 4.76 kB
JavaScript
'use strict';
var React = require('react');
var octiconsReact = require('@primer/octicons-react');
var Group = require('./Group.js');
var shared = require('./shared.js');
var Visuals = require('./Visuals.js');
var Box = require('../Box/Box.js');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefault(React);
const Selection = ({
selected
}) => {
const {
selectionVariant: listSelectionVariant,
role: listRole
} = React__default.default.useContext(shared.ListContext);
const {
selectionVariant: groupSelectionVariant
} = React__default.default.useContext(Group.GroupContext);
/** selectionVariant in Group can override the selectionVariant in List root */
/** fallback to selectionVariant from container menu if any (ActionMenu, SelectPanel ) */
let selectionVariant;
if (typeof groupSelectionVariant !== 'undefined') selectionVariant = groupSelectionVariant;else selectionVariant = listSelectionVariant;
if (!selectionVariant) {
// if selectionVariant is not set on List, but Item is selected
// fail loudly instead of silently ignoring
if (selected) {
throw new Error('For Item to be selected, ActionList or ActionList.Group needs to have a selectionVariant defined');
} else {
return null;
}
}
if (selectionVariant === 'single' || listRole === 'menu') {
return /*#__PURE__*/React__default.default.createElement(Visuals.LeadingVisualContainer, {
"data-component": "ActionList.Selection"
}, selected && /*#__PURE__*/React__default.default.createElement(octiconsReact.CheckIcon, null));
}
/**
* selectionVariant is multiple
* we use a styled div instead of an input because there should not
* be an interactive element inside an option
*/
const checkmarkIn = {
from: {
clipPath: 'inset(var(--base-size-16, 16px) 0 0 0)'
},
to: {
clipPath: 'inset(0 0 0 0)'
}
};
const checkmarkOut = {
from: {
clipPath: 'inset(0 0 0 0)'
},
to: {
clipPath: 'inset(var(--base-size-16, 16px) 0 0 0)'
}
};
return /*#__PURE__*/React__default.default.createElement(Visuals.LeadingVisualContainer, {
"data-component": "ActionList.Selection"
}, /*#__PURE__*/React__default.default.createElement(Box, {
sx: {
borderColor: selected ? 'accent.fg' : 'neutral.emphasis',
borderStyle: 'solid',
borderWidth: '1',
borderRadius: '1',
cursor: 'pointer',
display: 'grid',
height: 'var(--base-size-16, 16px)',
margin: '0',
placeContent: 'center',
width: 'var(--base-size-16, 16px)',
backgroundColor: selected ? 'accent.fg' : 'canvas.default',
transition: selected ? 'background-color, border-color 80ms cubic-bezier(0.33, 1, 0.68, 1)' : 'background-color, border-color 80ms cubic-bezier(0.32, 0, 0.67, 0) 0ms',
'::before': {
width: 'var(--base-size-16, 16px)',
height: 'var(--base-size-16, 16px)',
visibility: selected ? 'visible' : 'hidden',
content: '""',
backgroundColor: 'fg.onEmphasis',
transition: selected ? 'visibility 0s linear 0s' : 'visibility 0s linear 230ms',
clipPath: 'inset(var(--base-size-16, 16px) 0 0 0)',
maskImage: "url('')",
maskSize: '75%',
maskRepeat: 'no-repeat',
maskPosition: 'center',
animation: selected ? 'checkmarkIn 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards 80ms' : 'checkmarkOut 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards',
'@keyframes checkmarkIn': checkmarkIn,
'@keyframes checkmarkOut': checkmarkOut
}
},
"data-component": "ActionList.Checkbox"
}));
};
Selection.displayName = "Selection";
exports.Selection = Selection;