import * as React from 'react'; import styles from '@patternfly/react-styles/css/components/Check/check'; import { css } from '@patternfly/react-styles'; import { PickOptional } from '../../helpers/typeUtils'; import { getDefaultOUIAId, getOUIAProps, OUIAProps } from '../../helpers'; import { ASTERISK } from '../../helpers/htmlConstants'; export interface CheckboxProps extends Omit, 'type' | 'onChange' | 'disabled' | 'label'>, OUIAProps { /** Additional classes added to the checkbox. */ className?: string; /** Additional classed added to the radio input */ inputClassName?: string; /** Flag to show if the checkbox selection is valid or invalid. */ isValid?: boolean; /** Flag to show if the checkbox is disabled. */ isDisabled?: boolean; /** Flag to show if the checkbox is required. */ isRequired?: boolean; /** Flag to show if the checkbox is checked. If null, the checkbox will be indeterminate (partially checked). */ isChecked?: boolean | null; checked?: boolean; /** A callback for when the checkbox selection changes. */ onChange?: (event: React.FormEvent, checked: boolean) => void; /** Label text of the checkbox. */ label?: React.ReactNode; /** Id of the checkbox. */ id: string; /** Aria-label of the checkbox. */ 'aria-label'?: string; /** Description text of the checkbox. */ description?: React.ReactNode; /** Body text of the checkbox */ body?: React.ReactNode; /** Sets the input wrapper component to render. Defaults to
*/ component?: React.ElementType; /** Value to overwrite the randomly generated data-ouia-component-id.*/ ouiaId?: number | string; /** Set the value of data-ouia-safe. Only set to true when the component is in a static state, i.e. no animations are occurring. At all other times, this value must be false. */ ouiaSafe?: boolean; } // tslint:disable-next-line:no-empty const defaultOnChange = () => {}; interface CheckboxState { ouiaStateId: string; } class Checkbox extends React.Component { static displayName = 'Checkbox'; static defaultProps: PickOptional = { className: '', isValid: true, isDisabled: false, isRequired: false, isChecked: false, onChange: defaultOnChange, ouiaSafe: true, component: 'div' }; constructor(props: any) { super(props); this.state = { ouiaStateId: getDefaultOUIAId(Checkbox.displayName) }; } private handleChange = (event: React.FormEvent): void => { this.props.onChange(event, event.currentTarget.checked); }; render() { const { 'aria-label': ariaLabel, className, inputClassName, onChange, isValid, isDisabled, isRequired, isChecked, label, checked, defaultChecked, description, body, ouiaId, ouiaSafe, component: Component, ...props } = this.props; if (!props.id) { // eslint-disable-next-line no-console console.error('Checkbox:', 'id is required to make input accessible'); } const checkedProps: { checked?: boolean; defaultChecked?: boolean } = {}; if ([true, false].includes(checked) || isChecked === true) { checkedProps.checked = checked || isChecked; } if (onChange !== defaultOnChange) { checkedProps.checked = isChecked; } if ([false, true].includes(defaultChecked as boolean)) { checkedProps.defaultChecked = defaultChecked as boolean; } checkedProps.checked = checkedProps.checked === null ? false : checkedProps.checked; return ( elem && (elem.indeterminate = isChecked === null)} {...checkedProps} {...getOUIAProps(Checkbox.displayName, ouiaId !== undefined ? ouiaId : this.state.ouiaStateId, ouiaSafe)} /> {label && ( )} {description && {description}} {body && {body}} ); } } export { Checkbox };