@primer/react
Version:
An implementation of GitHub's Primer Design System using React
68 lines (61 loc) • 5.7 kB
JavaScript
;
var styled = require('styled-components');
var React = require('react');
var sx = require('../sx.js');
var useIsomorphicLayoutEffect = require('../utils/useIsomorphicLayoutEffect.js');
var CheckboxGroupContext = require('../CheckboxGroup/CheckboxGroupContext.js');
var _getGlobalFocusStyles = require('../_getGlobalFocusStyles.js');
var constants = require('../constants.js');
var _sharedCheckboxAndRadioStyles = require('../_sharedCheckboxAndRadioStyles.js');
var useProvidedRefOrCreate = require('../hooks/useProvidedRefOrCreate.js');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var styled__default = /*#__PURE__*/_interopDefault(styled);
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); }
const StyledCheckbox = styled__default.default.input.withConfig({
displayName: "Checkbox__StyledCheckbox",
componentId: "sc-1ga3qj3-0"
})(["", ";border-radius:", ";transition:background-color,border-color 80ms cubic-bezier(0.33,1,0.68,1);&::before{width:var(--base-size-16,16px);height:var(--base-size-16,16px);visibility:hidden;content:'';background-color:", ";transition:visibility 0s linear 230ms;clip-path:inset(var(--base-size-16,16px) 0 0 0);mask-image:url('');mask-size:75%;mask-repeat:no-repeat;mask-position:center;@media screen and (prefers-reduced-motion:no-preference){animation:checkmarkOut 80ms cubic-bezier(0.65,0,0.35,1) forwards;}}&:checked,&:indeterminate{background:", ";border-color:", ";&::before{@media screen and (prefers-reduced-motion:no-preference){animation:checkmarkIn 80ms cubic-bezier(0.65,0,0.35,1) forwards 80ms;}}}&:checked{transition:background-color,border-color 80ms cubic-bezier(0.32,0,0.67,0) 0ms;&::before{visibility:visible;transition:visibility 0s linear 0s;}&:disabled{cursor:not-allowed;background-color:", ";border-color:", ";opacity:1;&::before{background-color:", ";}}@media (forced-colors:active){background-color:canvastext;border-color:canvastext;}}&:indeterminate{background:", ";&::before{mask-image:url('');visibility:visible;}}", ";", ";@keyframes checkmarkIn{from{clip-path:inset(var(--base-size-16,16px) 0 0 0);}to{clip-path:inset(0 0 0 0);}}@keyframes checkmarkOut{from{clip-path:inset(0 0 0 0);}to{clip-path:inset(var(--base-size-16,16px) 0 0 0);}}"], _sharedCheckboxAndRadioStyles.sharedCheckboxAndRadioStyles, constants.get('radii.1'), constants.get('colors.fg.onEmphasis'), constants.get('colors.accent.fg'), constants.get('colors.accent.fg'), constants.get('colors.fg.muted'), constants.get('colors.fg.muted'), constants.get('colors.fg.onEmphasis'), constants.get('colors.accent.fg'), _getGlobalFocusStyles(), sx.default);
/**
* An accessible, native checkbox component
*/
const Checkbox = /*#__PURE__*/React__default.default.forwardRef(({
checked,
indeterminate,
disabled,
onChange,
sx: sxProp,
required,
validationStatus,
value,
...rest
}, ref) => {
const checkboxRef = useProvidedRefOrCreate.useProvidedRefOrCreate(ref);
const checkboxGroupContext = React.useContext(CheckboxGroupContext.CheckboxGroupContext);
const handleOnChange = e => {
checkboxGroupContext.onChange && checkboxGroupContext.onChange(e);
onChange && onChange(e);
};
useIsomorphicLayoutEffect(() => {
if (checkboxRef.current) {
checkboxRef.current.indeterminate = indeterminate || false;
}
}, [indeterminate, checked, checkboxRef]);
return /*#__PURE__*/React__default.default.createElement(StyledCheckbox, _extends({
type: "checkbox",
disabled: disabled,
ref: ref || checkboxRef,
checked: indeterminate ? false : checked,
"aria-checked": indeterminate ? 'mixed' : checked ? 'true' : 'false',
sx: sxProp,
required: required,
"aria-required": required ? 'true' : 'false',
"aria-invalid": validationStatus === 'error' ? 'true' : 'false',
onChange: handleOnChange,
value: value,
name: value
}, rest));
});
Checkbox.displayName = 'Checkbox';
var Checkbox$1 = Checkbox;
module.exports = Checkbox$1;