Skip to content

Commit

Permalink
refactor: Add TypeScript types to inlinecheckbox (carbon-design-syste…
Browse files Browse the repository at this point in the history
…m#17729)

* refactor: rename .js to .tsx

* refactor: changed the jsx to tsx and added interface

* refactor: fixed errored typings

* refactor: adds index.tsx

* chore: removes comment

---------

Co-authored-by: Gururajj77 <[email protected]>
Co-authored-by: Gururaj J <[email protected]>
  • Loading branch information
3 people authored Nov 13, 2024
1 parent 0ee6d40 commit ad23c63
Show file tree
Hide file tree
Showing 3 changed files with 117 additions and 25 deletions.
48 changes: 38 additions & 10 deletions packages/react/src/components/DataTable/TableSelectRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -87,29 +87,57 @@ const TableSelectRow = ({
}: TableSelectRowProps) => {
const prefix = usePrefix();
const uniqueNameId = useId();

const handleRadioChange = onChange
? (
value: string | number | undefined,
name: string | undefined,
event: React.ChangeEvent<HTMLInputElement>
) => {
// Convert the radio value to boolean for consistency
onChange(!!value, name || '', event);
}
: undefined;

const handleCheckboxChange = onChange
? (
checked: boolean,
name: string,
event: React.ChangeEvent<HTMLInputElement>
) => {
onChange(checked, name, event);
}
: undefined;

const selectionInputProps = {
id,
name: name ? name : uniqueNameId,
onClick: onSelect,
onChange,
checked,
disabled,
};
const InlineInputComponent = radio ? RadioButton : InlineCheckbox;

const labelValue = ariaLabel || deprecatedAriaLabel || '';
const tableSelectRowClasses = classNames(`${prefix}--table-column-checkbox`, {
...(className && { [className]: true }),
[`${prefix}--table-column-radio`]: radio,
});
return (
<td className={tableSelectRowClasses} aria-live="off">
<InlineInputComponent
{...selectionInputProps}
{...(radio && {
labelText: ariaLabel || deprecatedAriaLabel,
hideLabel: true,
})}
{...(!radio && { 'aria-label': ariaLabel || deprecatedAriaLabel })}
/>
{radio ? (
<RadioButton
{...selectionInputProps}
labelText={labelValue}
onChange={handleRadioChange}
hideLabel={true}
/>
) : (
<InlineCheckbox
{...selectionInputProps}
aria-label={labelValue}
onChange={handleCheckboxChange}
/>
)}
</td>
);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,78 @@
* This source code is licensed under the Apache-2.0 license found in the
* LICENSE file in the root directory of this source tree.
*/

import PropTypes from 'prop-types';
import React, { useEffect, useRef } from 'react';
import deprecate from '../../prop-types/deprecate';
import { usePrefix } from '../../internal/usePrefix';
import { useMergedRefs } from '../../internal/useMergedRefs';

/** @type any */
const InlineCheckbox = React.forwardRef(
export interface InlineCheckboxProps {
/*
* Specify the label for the control
*/
'aria-label': string;

/**
* Deprecated, please use `aria-label` instead.
* Specify the label for the control
*/
ariaLabel?: string;

/**
* Specify whether the underlying control is checked,
* or not
* @default false
* */
checked?: boolean;

/**
* Specify whether the underlying input control should be disabled
* @default false
*/
disabled?: boolean;

/**
* Provide an `id` for the underlying input control
*/
id: string;

/**
* Specify whether the control is in an indeterminate state
*/
indeterminate?: boolean;

/**
* Provide a `name` for the underlying input control
*/
name: string;

/**
* Provide an optional hook that is called each time the input is updated
*/
onChange?: (
checked: boolean,
id: string,
event: React.ChangeEvent<HTMLInputElement>
) => void;

/**
* Provide a handler that is invoked when a user clicks on the control
*/
onClick?: (event: React.MouseEvent<HTMLInputElement>) => void;

/**
* Provide a handler that is invoked on the key down event for the control
*/
onKeyDown?: (event: React.KeyboardEvent<HTMLInputElement>) => void;

/**
* Provide an optional tooltip for the InlineCheckbox
*/
title?: string;
}

const InlineCheckbox = React.forwardRef<HTMLInputElement, InlineCheckboxProps>(
function InlineCheckbox(props, forwardRef) {
const {
['aria-label']: ariaLabel,
Expand All @@ -28,16 +91,19 @@ const InlineCheckbox = React.forwardRef(
title,
} = props;
const prefix = usePrefix();
const inputRef = useRef(null);
const inputRef = useRef<HTMLInputElement>(null);
const ref = useMergedRefs([inputRef, forwardRef]);
const inputProps = {

const inputProps: React.InputHTMLAttributes<HTMLInputElement> & {
ref: React.Ref<HTMLInputElement>;
} = {
checked,
className: `${prefix}--checkbox`,
disabled,
id,
name,
onClick: onClick ? onClickCheckBoxInput : onClick,
onChange: (evt) => {
onChange: (evt: React.ChangeEvent<HTMLInputElement>) => {
onChange(evt.target.checked, id, evt);
},
onKeyDown,
Expand All @@ -51,16 +117,15 @@ const InlineCheckbox = React.forwardRef(

useEffect(() => {
if (inputRef?.current) {
inputRef.current.indeterminate = indeterminate;
inputRef.current.indeterminate = indeterminate || false;
}
}, [indeterminate]);

function onClickCheckBoxInput(evt) {
// If the previous "indeterminate" is true, change "checked" to false. If it is not undefined, we're working on `TableSelectAll`
function onClickCheckBoxInput(evt: React.MouseEvent<HTMLInputElement>) {
if (indeterminate) {
evt.target.checked = false;
(evt.target as HTMLInputElement).checked = false;
}
onClick(evt);
onClick?.(evt);
}

return (
Expand All @@ -72,7 +137,7 @@ const InlineCheckbox = React.forwardRef(
htmlFor={id}
className={`${prefix}--checkbox-label`}
title={title}
onClick={(evt) => {
onClick={(evt: React.MouseEvent) => {
evt.stopPropagation();
}}>
<span className={`${prefix}--visually-hidden`}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
* LICENSE file in the root directory of this source tree.
*/

import InlineCheckbox from './InlineCheckbox';

import InlineCheckbox, { type InlineCheckboxProps } from './InlineCheckbox';
export default InlineCheckbox;
export { InlineCheckbox };
export { InlineCheckbox, type InlineCheckboxProps };

0 comments on commit ad23c63

Please sign in to comment.