UNPKG

@primer/react

Version:

An implementation of GitHub's Primer Design System using React

68 lines (61 loc) 5.7 kB
'use strict'; 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;