aboutsummaryrefslogtreecommitdiffstats
path: root/apps/web/components/ui/action-button.tsx
diff options
context:
space:
mode:
authorMohamedBassem <me@mbassem.com>2024-04-15 18:39:59 +0100
committerMohamedBassem <me@mbassem.com>2024-04-15 18:55:34 +0100
commit81e0b2849d837649da9adbc5d077b8c819fe7bee (patch)
tree003bb21413372825dc19c07a87bdbe6692e384a9 /apps/web/components/ui/action-button.tsx
parent5c9acb1cb3bfe341378b91bbed344dd7202a00d7 (diff)
downloadkarakeep-81e0b2849d837649da9adbc5d077b8c819fe7bee.tar.zst
feature: Add title to bookmarks and allow editing them. Fixes #27
Diffstat (limited to 'apps/web/components/ui/action-button.tsx')
-rw-r--r--apps/web/components/ui/action-button.tsx40
1 files changed, 31 insertions, 9 deletions
diff --git a/apps/web/components/ui/action-button.tsx b/apps/web/components/ui/action-button.tsx
index e9cdc3c9..2ac361f5 100644
--- a/apps/web/components/ui/action-button.tsx
+++ b/apps/web/components/ui/action-button.tsx
@@ -4,15 +4,20 @@ import { useClientConfig } from "@/lib/clientConfig";
import type { ButtonProps } from "./button";
import { Button } from "./button";
import LoadingSpinner from "./spinner";
+import {
+ Tooltip,
+ TooltipContent,
+ TooltipPortal,
+ TooltipTrigger,
+} from "./tooltip";
-const ActionButton = React.forwardRef<
- HTMLButtonElement,
- ButtonProps & {
- loading: boolean;
- spinner?: React.ReactNode;
- ignoreDemoMode?: boolean;
- }
->(
+interface ActionButtonProps extends ButtonProps {
+ loading: boolean;
+ spinner?: React.ReactNode;
+ ignoreDemoMode?: boolean;
+}
+
+const ActionButton = React.forwardRef<HTMLButtonElement, ActionButtonProps>(
(
{ children, loading, spinner, disabled, ignoreDemoMode = false, ...props },
ref,
@@ -35,4 +40,21 @@ const ActionButton = React.forwardRef<
);
ActionButton.displayName = "ActionButton";
-export { ActionButton };
+const ActionButtonWithTooltip = React.forwardRef<
+ HTMLButtonElement,
+ ActionButtonProps & { tooltip: string; delayDuration?: number }
+>(({ tooltip, delayDuration, ...props }, ref) => {
+ return (
+ <Tooltip delayDuration={delayDuration}>
+ <TooltipTrigger>
+ <ActionButton ref={ref} {...props} />
+ </TooltipTrigger>
+ <TooltipPortal>
+ <TooltipContent>{tooltip}</TooltipContent>
+ </TooltipPortal>
+ </Tooltip>
+ );
+});
+ActionButtonWithTooltip.displayName = "ActionButtonWithTooltip";
+
+export { ActionButton, ActionButtonWithTooltip };