Skip to content

Commit

Permalink
feat: Adding with Label element prop to Checkbox (#1014)
Browse files Browse the repository at this point in the history
Co-authored-by: JonnCh <[email protected]>
  • Loading branch information
JonnCharpentier and JonnCh authored Apr 8, 2024
1 parent 4f9a03d commit 2360d68
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 4 deletions.
5 changes: 5 additions & 0 deletions src/inputs/Checkbox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,11 @@ import { CheckboxBase } from "src/inputs/CheckboxBase";

export interface CheckboxProps {
label: string;
/** If false this will be wrap in a div element instead of the label
* Expects implementer to wrap within a label element to work properly
* @default true
*/
withLabelElement?: boolean;
checkboxOnly?: boolean;
selected: boolean | "indeterminate";
/** Handler that is called when the element's selection state changes. */
Expand Down
14 changes: 10 additions & 4 deletions src/inputs/CheckboxBase.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,11 @@ export interface CheckboxBaseProps extends BeamFocusableProps {
checkboxOnly?: boolean;
errorMsg?: string;
helperText?: string | ReactNode;
/** If false this will be wrap in a div element instead of the label
* Expects implementer to wrap within a label element to work properly
* @default true
*/
withLabelElement?: boolean;
}

export function CheckboxBase(props: CheckboxBaseProps) {
Expand All @@ -34,20 +39,21 @@ export function CheckboxBase(props: CheckboxBaseProps) {
description,
isDisabled = false,
isIndeterminate = false,
isSelected,
inputProps,
label,
errorMsg,
helperText,
checkboxOnly = false,
withLabelElement = true,
} = props;
const ref = useRef(null);
const { isFocusVisible, focusProps } = useFocusRing(ariaProps);
const { hoverProps, isHovered } = useHover({ isDisabled });
const tid = useTestIds(props, defaultTestId(label));

const Tag = withLabelElement ? "label" : "div";

return (
<label
<Tag
css={
Css.df.cursorPointer.relative
// Prevents accidental checkbox clicks due to label width being longer
Expand All @@ -74,7 +80,7 @@ export function CheckboxBase(props: CheckboxBaseProps) {
{helperText && <HelperText helperText={helperText} {...tid.helperText} />}
</div>
)}
</label>
</Tag>
);
}

Expand Down

0 comments on commit 2360d68

Please sign in to comment.