Skip to content

Commit

Permalink
refactor: convert options menu item to a function component
Browse files Browse the repository at this point in the history
  • Loading branch information
anastasialanz committed Oct 1, 2024
1 parent d147b85 commit 991f913
Showing 1 changed file with 37 additions and 31 deletions.
68 changes: 37 additions & 31 deletions packages/react/src/components/OptionsMenu/OptionsMenuItem.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React from 'react';
import React, { forwardRef } from 'react';

export interface OptionsMenuItemProps
extends Pick<
Expand All @@ -11,39 +11,45 @@ export interface OptionsMenuItemProps
onSelect: (e: React.MouseEvent<HTMLElement>) => void;
}

class OptionsMenuItemComponent extends React.Component<OptionsMenuItemProps> {
static defaultProps = {
// eslint-disable-next-line @typescript-eslint/no-empty-function
onSelect: () => {}
};

handleClick = (event: React.MouseEvent<HTMLElement>) => {
const { disabled, onSelect } = this.props;
function OptionsMenuItemComponent({
disabled,
className,
menuItemRef,
onSelect = () => {}, // eslint-disable-line @typescript-eslint/no-empty-function
...other
}: OptionsMenuItemProps) {
function handleClick(event: React.MouseEvent<HTMLElement>) {
if (!disabled) {
onSelect(event);
}
};

render() {
const { handleClick, props } = this;
const { menuItemRef, disabled, onSelect, ...other } = props;
return (
// keydown happens in OptionsMenu which proxies to click
// eslint-disable-next-line jsx-a11y/click-events-have-key-events
<li
role="menuitem"
ref={menuItemRef}
aria-disabled={disabled}
onClick={handleClick}
{...other}
/>
);
}

return (
// keydown happens in OptionsMenu which proxies to click
// eslint-disable-next-line jsx-a11y/click-events-have-key-events
<li
role="menuitem"
ref={menuItemRef}
aria-disabled={disabled}
onClick={handleClick}
className={className}
{...other}
/>
);
}

export default React.forwardRef(function OptionsMenuItem(
props: OptionsMenuItemProps,
ref: React.Ref<HTMLLIElement>
) {
return <OptionsMenuItemComponent menuItemRef={ref} {...props} />;
});
const OptionsMenuItem = forwardRef<HTMLLIElement, OptionsMenuItemProps>(
({ disabled, className, onSelect, ...other }, ref) => (
<OptionsMenuItemComponent
className={className}
menuItemRef={ref}
disabled={disabled}
onSelect={onSelect}
{...other}
/>
)
);

OptionsMenuItem.displayName = 'OptionsMenuItem';

export default OptionsMenuItem;

0 comments on commit 991f913

Please sign in to comment.