mirror of
https://github.com/empayre/fleet.git
synced 2024-11-07 09:18:59 +00:00
8fa009a93e
* Delete multiple hosts with delete host modal * Free tier admin/maintainers access to select checkboxes and bulk delete
98 lines
3.0 KiB
TypeScript
98 lines
3.0 KiB
TypeScript
import React, { useCallback } from "react";
|
|
import { kebabCase } from "lodash";
|
|
|
|
// ignore TS error for now until these are rewritten in ts.
|
|
// @ts-ignore
|
|
import { ButtonVariant } from "components/buttons/Button/Button";
|
|
import Button from "../../../buttons/Button";
|
|
import CloseIcon from "../../../../../assets/images/icon-close-vibrant-blue-16x16@2x.png";
|
|
import DeleteIcon from "../../../../../assets/images/icon-delete-vibrant-blue-12x14@2x.png";
|
|
import CheckIcon from "../../../../../assets/images/icon-action-check-16x15@2x.png";
|
|
import DisableIcon from "../../../../../assets/images/icon-action-disable-14x14@2x.png";
|
|
import TransferIcon from "../../../../../assets/images/icon-action-transfer-16x16@2x.png";
|
|
|
|
const baseClass = "action-button";
|
|
export interface IActionButtonProps {
|
|
name: string;
|
|
buttonText: string;
|
|
onActionButtonClick: (ids: number[]) => void | undefined;
|
|
targetIds?: number[]; // TODO figure out undefined case
|
|
variant?: ButtonVariant;
|
|
hideButton?: boolean | ((targetIds: number[]) => boolean);
|
|
icon?: string;
|
|
iconPosition?: string;
|
|
}
|
|
|
|
function useActionCallback(
|
|
callbackFn: (targetIds: number[]) => void | undefined
|
|
) {
|
|
return useCallback(
|
|
(targetIds) => {
|
|
callbackFn(targetIds);
|
|
},
|
|
[callbackFn]
|
|
);
|
|
}
|
|
|
|
const ActionButton = (buttonProps: IActionButtonProps): JSX.Element | null => {
|
|
const {
|
|
name,
|
|
buttonText,
|
|
onActionButtonClick,
|
|
targetIds = [],
|
|
variant = "brand",
|
|
hideButton,
|
|
icon,
|
|
iconPosition,
|
|
} = buttonProps;
|
|
const onButtonClick = useActionCallback(onActionButtonClick);
|
|
|
|
const iconLink = ((iconProp) => {
|
|
// check if using pre-defined short-hand otherwise otherwise return the prop
|
|
switch (iconProp) {
|
|
case "close":
|
|
return CloseIcon;
|
|
case "remove":
|
|
return CloseIcon;
|
|
case "delete":
|
|
return DeleteIcon;
|
|
case "check":
|
|
return CheckIcon;
|
|
case "disable":
|
|
return DisableIcon;
|
|
case "transfer":
|
|
return TransferIcon;
|
|
default:
|
|
return null;
|
|
}
|
|
})(icon);
|
|
// hideButton is intended to provide a flexible way to specify show/hide conditions via a boolean or a function that evaluates to a boolean
|
|
// currently it is typed to accept an array of targetIds but this typing could easily be expanded to include other use cases
|
|
const isHidden = (
|
|
hideButtonProp: boolean | ((ids: number[]) => boolean) | undefined
|
|
) => {
|
|
if (typeof hideButtonProp === "function") {
|
|
return hideButtonProp(targetIds);
|
|
}
|
|
return Boolean(hideButtonProp);
|
|
};
|
|
|
|
return !isHidden(hideButton) ? (
|
|
<div className={`${baseClass} ${baseClass}__${kebabCase(name)}`}>
|
|
<Button onClick={() => onButtonClick(targetIds)} variant={variant}>
|
|
<>
|
|
{iconPosition === "left" && iconLink && (
|
|
<img alt={`${name} icon`} src={iconLink} />
|
|
)}
|
|
{buttonText}
|
|
{iconPosition !== "left" && iconLink && (
|
|
<img alt={`${name} icon`} src={iconLink} />
|
|
)}
|
|
</>
|
|
</Button>
|
|
</div>
|
|
) : null;
|
|
};
|
|
|
|
export default ActionButton;
|