Skip to content

Commit

Permalink
Fix #7368: Unique key prop added to CHips and icons
Browse files Browse the repository at this point in the history
  • Loading branch information
melloware committed Dec 6, 2024
1 parent 4994928 commit a427add
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 8 deletions.
10 changes: 7 additions & 3 deletions components/lib/chip/Chip.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ export const Chip = React.memo(
ptm('image')
);

content.push(<img alt={props.imageAlt} {...imageProps} />);
content.push(<img alt={props.imageAlt} {...imageProps} key={UniqueComponentId('image')} />);
} else if (props.icon) {
const chipIconProps = mergeProps(
{
Expand All @@ -82,7 +82,7 @@ export const Chip = React.memo(
);

content.push(
<span {...labelProps} key="label">
<span {...labelProps} key={UniqueComponentId('label')}>
{props.label}
</span>
);
Expand All @@ -109,7 +109,11 @@ export const Chip = React.memo(
ptm('root')
);

return <div {...rootProps}>{content}</div>;
return (
<div {...rootProps} key={UniqueComponentId('chip')}>
{content}
</div>
);
};

React.useImperativeHandle(ref, () => ({
Expand Down
12 changes: 9 additions & 3 deletions components/lib/chips/Chips.js
Original file line number Diff line number Diff line change
Expand Up @@ -328,7 +328,7 @@ export const Chips = React.memo(
},
ptm('removeTokenIcon')
);
const icon = props.removeIcon || <TimesCircleIcon {...iconProps} />;
const icon = props.removeIcon || <TimesCircleIcon {...iconProps} key={`${index}_icon`} />;
const removeIcon = IconUtils.getJSXIcon(icon, { ...iconProps }, { props });

return removeIcon;
Expand All @@ -345,7 +345,11 @@ export const Chips = React.memo(
},
ptm('label')
);
const label = <span {...labelProps}>{content}</span>;
const label = (
<span {...labelProps} key={`${index}_${value}_span`}>
{content}
</span>
);
const icon = createRemoveIcon(value, index);
const tokenProps = mergeProps(
{
Expand Down Expand Up @@ -456,7 +460,9 @@ export const Chips = React.memo(

return (
<>
<div {...rootProps}>{list}</div>
<div {...rootProps} key="chips">
{list}
</div>
{hasTooltip && <Tooltip target={inputRef} content={props.tooltip} pt={ptm('tooltip')} {...props.tooltipOptions} />}
</>
);
Expand Down
4 changes: 2 additions & 2 deletions components/lib/utils/IconUtils.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as React from 'react';
import { classNames } from './ClassNames';
import ObjectUtils from './ObjectUtils';
import UniqueComponentId from './UniqueComponentId';

export default class IconUtils {
static getJSXIcon(icon, iconProps = {}, options = {}) {
Expand All @@ -10,7 +10,7 @@ export default class IconUtils {
const iconType = typeof icon;
const className = classNames(iconProps.className, iconType === 'string' && icon);

content = <span {...iconProps} className={className} />;
content = <span {...iconProps} className={className} key={UniqueComponentId('icon')} />;

if (iconType !== 'string') {
const defaultContentOptions = {
Expand Down

0 comments on commit a427add

Please sign in to comment.