Skip to content

Commit

Permalink
Merge pull request #74 from Exabyte-io/chore/SOF-7367
Browse files Browse the repository at this point in the history
SOF-7367: add menuItemProps to dropdown
  • Loading branch information
k0stik authored May 14, 2024
2 parents 501dd93 + 84c2027 commit 7e89fd1
Show file tree
Hide file tree
Showing 6 changed files with 51 additions and 22 deletions.
13 changes: 13 additions & 0 deletions dist/mui/components/dropdown/Dropdown.d.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,15 @@
import { MenuItemProps } from "@mui/material";
import { PopperPlacementType, PopperProps } from "@mui/material/Popper";
import React from "react";
import { DefaultDropdownButtonProps } from "./DefaultDropdownButton";
import { DropdownItemProps } from "./DropdownItem";
/**
* Add data-<something> html attributes
* @see https://github.com/microsoft/TypeScript/issues/28960#issuecomment-903519759
* */
interface HTMLAttributes extends React.HTMLAttributes<any> {
[dataAttribute: `data-${string}`]: any;
}
export interface DropdownAction {
id: DropdownItemProps["id"];
onClick: (action: DropdownAction, event: React.MouseEvent<HTMLLIElement>) => void;
Expand All @@ -15,6 +23,10 @@ export interface DropdownAction {
isShown?: boolean;
isSelected?: boolean;
isDivider?: boolean;
/**
* Pass any MUI MenuItem props here to customize appearance or html properties
*/
menuItemProps?: MenuItemProps & HTMLAttributes;
}
export interface DropdownProps {
id?: string;
Expand All @@ -37,3 +49,4 @@ export interface DropdownProps {
* to dropdown menu items.
*/
export default function Dropdown({ id, actions, buttonContent, popperProps, children, disabled, paperPlacement, className, buttonProps, }: DropdownProps): React.JSX.Element;
export {};
5 changes: 1 addition & 4 deletions dist/mui/components/dropdown/Dropdown.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
/* eslint-disable jsx-a11y/no-static-element-interactions */
/* eslint-disable jsx-a11y/click-events-have-key-events */
/* eslint-disable react/jsx-props-no-spreading */
import Box from "@mui/material/Box";
import ClickAwayListener from "@mui/material/ClickAwayListener";
import Divider from "@mui/material/Divider";
Expand Down Expand Up @@ -62,6 +59,6 @@ export default function Dropdown({ id, actions, buttonContent, popperProps = {
if (action.isDivider) {
return React.createElement(Divider, { key: action.key || action.id });
}
return (React.createElement(DropdownItem, { disabled: action.disabled, icon: action.icon, endIcon: action.endIcon, id: action.id, onClick: onMenuItemClick, showCheckIcon: action.showCheckIcon, content: action.content, key: action.key || action.id }));
return (React.createElement(DropdownItem, { disabled: action.disabled, icon: action.icon, endIcon: action.endIcon, id: action.id, onMenuItemClick: onMenuItemClick, showCheckIcon: action.showCheckIcon, key: action.key || action.id, ...action.menuItemProps }, action.content));
})))))))));
}
8 changes: 4 additions & 4 deletions dist/mui/components/dropdown/DropdownItem.d.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { MenuItemProps } from "@mui/material/MenuItem";
import React from "react";
export interface DropdownItemProps {
export interface DropdownItemProps extends MenuItemProps {
disabled?: boolean;
icon?: React.ReactElement | boolean;
id: string;
onClick: (id: string, event: React.MouseEvent<HTMLLIElement>) => void;
onMenuItemClick: (id: string, event: React.MouseEvent<HTMLLIElement>) => void;
showCheckIcon?: boolean;
content: string | React.ReactElement;
endIcon?: React.ReactElement;
}
export declare function DropdownItem({ disabled, icon, id, onClick, showCheckIcon, endIcon, content, }: DropdownItemProps): React.JSX.Element;
export declare function DropdownItem({ disabled, icon, id, onMenuItemClick, showCheckIcon, endIcon, children, ...otherProps }: DropdownItemProps): React.JSX.Element;
6 changes: 3 additions & 3 deletions dist/mui/components/dropdown/DropdownItem.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ import ListItemText from "@mui/material/ListItemText";
import MenuItem from "@mui/material/MenuItem";
import React from "react";
import IconByName from "../icon/IconByName";
export function DropdownItem({ disabled = false, icon, id, onClick, showCheckIcon = false, endIcon, content, }) {
return (React.createElement(MenuItem, { id: id, disabled: disabled, onClick: (event) => onClick(id, event) },
export function DropdownItem({ disabled = false, icon, id, onMenuItemClick, showCheckIcon = false, endIcon, children, ...otherProps }) {
return (React.createElement(MenuItem, { id: id, disabled: disabled, onClick: (event) => onMenuItemClick(id, event), ...otherProps },
icon !== false ? (React.createElement(ListItemIcon, null, icon || React.createElement(IconByName, { name: "shapes.blurCircular" }))) : null,
React.createElement(ListItemText, { primaryTypographyProps: { variant: "caption", color: "text.primary" }, className: "DropdownItemText" }, content),
React.createElement(ListItemText, { primaryTypographyProps: { variant: "caption", color: "text.primary" }, className: "DropdownItemText" }, children),
showCheckIcon ? (React.createElement(IconByName, { name: "shapes.check", htmlColor: green[500], fontSize: "large" })) : null,
endIcon));
}
20 changes: 17 additions & 3 deletions src/mui/components/dropdown/Dropdown.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/* eslint-disable jsx-a11y/no-static-element-interactions */
/* eslint-disable jsx-a11y/click-events-have-key-events */
/* eslint-disable react/jsx-props-no-spreading */
import { MenuItemProps } from "@mui/material";
import Box from "@mui/material/Box";
import ClickAwayListener from "@mui/material/ClickAwayListener";
import Divider from "@mui/material/Divider";
Expand All @@ -15,6 +16,14 @@ import React, { useCallback, useRef, useState } from "react";
import { DefaultDropdownButton, DefaultDropdownButtonProps } from "./DefaultDropdownButton";
import { DropdownItem, DropdownItemProps } from "./DropdownItem";

/**
* Add data-<something> html attributes
* @see https://github.com/microsoft/TypeScript/issues/28960#issuecomment-903519759
* */
interface HTMLAttributes extends React.HTMLAttributes<any> {
[dataAttribute: `data-${string}`]: any;
}

export interface DropdownAction {
id: DropdownItemProps["id"];
onClick: (action: DropdownAction, event: React.MouseEvent<HTMLLIElement>) => void;
Expand All @@ -28,6 +37,10 @@ export interface DropdownAction {
isShown?: boolean;
isSelected?: boolean;
isDivider?: boolean;
/**
* Pass any MUI MenuItem props here to customize appearance or html properties
*/
menuItemProps?: MenuItemProps & HTMLAttributes;
}

export interface DropdownProps {
Expand Down Expand Up @@ -140,11 +153,12 @@ export default function Dropdown({
icon={action.icon}
endIcon={action.endIcon}
id={action.id}
onClick={onMenuItemClick}
onMenuItemClick={onMenuItemClick}
showCheckIcon={action.showCheckIcon}
content={action.content}
key={action.key || action.id}
/>
{...action.menuItemProps}>
{action.content}
</DropdownItem>
);
})}
</MenuList>
Expand Down
21 changes: 13 additions & 8 deletions src/mui/components/dropdown/DropdownItem.tsx
Original file line number Diff line number Diff line change
@@ -1,39 +1,44 @@
import { green } from "@mui/material/colors";
import ListItemIcon from "@mui/material/ListItemIcon";
import ListItemText from "@mui/material/ListItemText";
import MenuItem from "@mui/material/MenuItem";
import MenuItem, { MenuItemProps } from "@mui/material/MenuItem";
import React from "react";

import IconByName from "../icon/IconByName";

export interface DropdownItemProps {
export interface DropdownItemProps extends MenuItemProps {
disabled?: boolean;
icon?: React.ReactElement | boolean;
id: string;
onClick: (id: string, event: React.MouseEvent<HTMLLIElement>) => void;
onMenuItemClick: (id: string, event: React.MouseEvent<HTMLLIElement>) => void;
showCheckIcon?: boolean;
content: string | React.ReactElement;
endIcon?: React.ReactElement;
}

export function DropdownItem({
disabled = false,
icon,
id,
onClick,
onMenuItemClick,
showCheckIcon = false,
endIcon,
content,
children,
...otherProps
}: DropdownItemProps) {
return (
<MenuItem id={id} disabled={disabled} onClick={(event) => onClick(id, event)}>
<MenuItem
id={id}
disabled={disabled}
onClick={(event) => onMenuItemClick(id, event)}
// eslint-disable-next-line react/jsx-props-no-spreading
{...otherProps}>
{icon !== false ? (
<ListItemIcon>{icon || <IconByName name="shapes.blurCircular" />}</ListItemIcon>
) : null}
<ListItemText
primaryTypographyProps={{ variant: "caption", color: "text.primary" }}
className="DropdownItemText">
{content}
{children}
</ListItemText>
{showCheckIcon ? (
<IconByName name="shapes.check" htmlColor={green[500]} fontSize="large" />
Expand Down

0 comments on commit 7e89fd1

Please sign in to comment.