Skip to content

Commit

Permalink
tooltip
Browse files Browse the repository at this point in the history
  • Loading branch information
aditya-supare committed Dec 22, 2024
1 parent 1070fca commit 09cf96e
Show file tree
Hide file tree
Showing 4 changed files with 153 additions and 19 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
"@radix-ui/react-slot": "^1.1.0",
"@radix-ui/react-tabs": "^1.1.2",
"@radix-ui/react-toast": "^1.2.2",
"@radix-ui/react-tooltip": "^1.1.6",
"@t3-oss/env-nextjs": "^0.10.1",
"@tanstack/react-query": "^5.50.0",
"@tinymce/tinymce-react": "^5.1.1",
Expand Down
100 changes: 92 additions & 8 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

39 changes: 28 additions & 11 deletions src/components/editor/TextEditorMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
import { type Editor } from "@tiptap/react";
import { AiOutlineRedo, AiOutlineUndo } from "react-icons/ai";
import { BsTypeUnderline } from "react-icons/bs";
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from "../ui/tooltip";


const Button = ({
Expand Down Expand Up @@ -42,56 +43,72 @@ import {
icon: <RiBold className="size-5" />,
onClick: () => editor.chain().focus().toggleBold().run(),
isActive: editor.isActive("bold"),
tooltip: "Bold"
},
{
icon: <BsTypeUnderline className="size-5" />,
onClick: () => editor.chain().focus().toggleUnderline().run(),
isActive: editor.isActive("underline"),
tooltip: "Underline"
},
{
icon: <RiItalic className="size-5" />,
onClick: () => editor.chain().focus().toggleItalic().run(),
isActive: editor.isActive("italic"),
disabled: !editor.can().chain().focus().toggleItalic().run(),
tooltip: "Italic"
},
{
icon: <RiStrikethrough className="size-5" />,
onClick: () => editor.chain().focus().toggleStrike().run(),
isActive: editor.isActive("strike"),
disabled: !editor.can().chain().focus().toggleStrike().run(),
tooltip: "Strikethrough"
},
{
icon: <RiCodeSSlashLine className="size-5" />,
onClick: () => editor.chain().focus().toggleCode().run(),
isActive: editor.isActive("code"),
disabled: !editor.can().chain().focus().toggleCode().run(),
tooltip: "Code"
},
{
icon: <AiOutlineUndo className="size-5" />,
onClick: () => editor.chain().focus().undo().run(),
isActive: editor.isActive("undo"),
disabled: !editor.can().chain().focus().undo().run(),
tooltip: "Undo"
},
{
icon: <AiOutlineRedo className="size-5" />,
onClick: () => editor.chain().focus().redo().run(),
isActive: editor.isActive("redo"),
disabled: !editor.can().chain().focus().redo().run(),
tooltip: "Redo"
},
];

return (
<div className="mb-2 flex space-x-2">
{buttons.map(({ icon, onClick, isActive, disabled }, index) => (
<Button
key={index}
onClick={onClick}
isActive={isActive}
disabled={disabled}
>
{icon}
</Button>
))}
<div className="mb-2 mt-2 flex space-x-2">
{buttons.map(({ icon, onClick, isActive, disabled, tooltip }, index) => (
<TooltipProvider key={index}>
<Tooltip delayDuration={0}>
<TooltipTrigger>
<Button
key={index}
onClick={onClick}
isActive={isActive}
disabled={disabled}
>
{icon}
</Button>
</TooltipTrigger>
<TooltipContent>
<span>{tooltip}</span>
</TooltipContent>
</Tooltip>
</TooltipProvider>
))}
</div>
);
}
Expand Down
32 changes: 32 additions & 0 deletions src/components/ui/tooltip.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
"use client"

import * as React from "react"
import * as TooltipPrimitive from "@radix-ui/react-tooltip"

import { cn } from "@/lib/utils"

const TooltipProvider = TooltipPrimitive.Provider

const Tooltip = TooltipPrimitive.Root

const TooltipTrigger = TooltipPrimitive.Trigger

const TooltipContent = React.forwardRef<
React.ElementRef<typeof TooltipPrimitive.Content>,
React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>
>(({ className, sideOffset = 4, ...props }, ref) => (
<TooltipPrimitive.Portal>
<TooltipPrimitive.Content
ref={ref}
sideOffset={sideOffset}
className={cn(
"z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
className
)}
{...props}
/>
</TooltipPrimitive.Portal>
))
TooltipContent.displayName = TooltipPrimitive.Content.displayName

export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }

0 comments on commit 09cf96e

Please sign in to comment.