2024-01-31 10:06:55 +00:00
|
|
|
// helpers
|
|
|
|
import { cn } from "helpers/common.helper";
|
|
|
|
// types
|
|
|
|
import { TButtonVariants } from "./types";
|
|
|
|
// constants
|
|
|
|
import { BACKGROUND_BUTTON_VARIANTS, BORDER_BUTTON_VARIANTS } from "./constants";
|
|
|
|
import { Tooltip } from "@plane/ui";
|
|
|
|
|
|
|
|
export type DropdownButtonProps = {
|
|
|
|
children: React.ReactNode;
|
|
|
|
className?: string;
|
|
|
|
isActive: boolean;
|
|
|
|
tooltipContent: string | React.ReactNode;
|
|
|
|
tooltipHeading: string;
|
|
|
|
showTooltip: boolean;
|
|
|
|
variant: TButtonVariants;
|
|
|
|
};
|
|
|
|
|
|
|
|
type ButtonProps = {
|
|
|
|
children: React.ReactNode;
|
|
|
|
className?: string;
|
|
|
|
isActive: boolean;
|
|
|
|
tooltipContent: string | React.ReactNode;
|
|
|
|
tooltipHeading: string;
|
|
|
|
showTooltip: boolean;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const DropdownButton: React.FC<DropdownButtonProps> = (props) => {
|
|
|
|
const { children, className, isActive, tooltipContent, tooltipHeading, showTooltip, variant } = props;
|
|
|
|
|
|
|
|
const ButtonToRender: React.FC<ButtonProps> = BORDER_BUTTON_VARIANTS.includes(variant)
|
|
|
|
? BorderButton
|
|
|
|
: BACKGROUND_BUTTON_VARIANTS.includes(variant)
|
|
|
|
? BackgroundButton
|
|
|
|
: TransparentButton;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<ButtonToRender
|
|
|
|
className={className}
|
|
|
|
isActive={isActive}
|
|
|
|
tooltipContent={tooltipContent}
|
|
|
|
tooltipHeading={tooltipHeading}
|
|
|
|
showTooltip={showTooltip}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</ButtonToRender>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const BorderButton: React.FC<ButtonProps> = (props) => {
|
|
|
|
const { children, className, isActive, tooltipContent, tooltipHeading, showTooltip } = props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Tooltip tooltipHeading={tooltipHeading} tooltipContent={tooltipContent} disabled={!showTooltip}>
|
|
|
|
<div
|
|
|
|
className={cn(
|
2024-02-08 13:51:08 +00:00
|
|
|
"h-full flex items-center gap-1.5 border-[0.5px] border-neutral-border-medium hover:bg-neutral-component-surface-dark rounded text-xs px-2 py-0.5",
|
|
|
|
{ "bg-neutral-component-surface-dark": isActive },
|
2024-01-31 10:06:55 +00:00
|
|
|
className
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const BackgroundButton: React.FC<ButtonProps> = (props) => {
|
|
|
|
const { children, className, tooltipContent, tooltipHeading, showTooltip } = props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Tooltip tooltipHeading={tooltipHeading} tooltipContent={tooltipContent} disabled={!showTooltip}>
|
|
|
|
<div
|
|
|
|
className={cn(
|
2024-02-08 13:51:08 +00:00
|
|
|
"h-full flex items-center gap-1.5 rounded text-xs px-2 py-0.5 bg-neutral-component-surface-dark",
|
2024-01-31 10:06:55 +00:00
|
|
|
className
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const TransparentButton: React.FC<ButtonProps> = (props) => {
|
|
|
|
const { children, className, isActive, tooltipContent, tooltipHeading, showTooltip } = props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Tooltip tooltipHeading={tooltipHeading} tooltipContent={tooltipContent} disabled={!showTooltip}>
|
|
|
|
<div
|
|
|
|
className={cn(
|
2024-02-08 13:51:08 +00:00
|
|
|
"h-full flex items-center gap-1.5 rounded text-xs px-2 py-0.5 hover:bg-neutral-component-surface-dark",
|
|
|
|
{ "bg-neutral-component-surface-dark": isActive },
|
2024-01-31 10:06:55 +00:00
|
|
|
className
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
};
|