forked from github/plane
e1ae0d3b56
* remirror instances commented out to avoid prosemirror conflicts * styles migrated for remirror to tiptap transition * added bubblemenu support with extensions * fixed css for task lists and code with syntax highlighting * added support for slash command * fixed bubble menu to match styles and added better seperation in UI * saving with debounce logic added and it's stored in backend * added migration support by updating to html * Image uploads done * improved file structure and delete image function implemented * Integrated tiptap with Issue Modal * added additional props and Tiptap Integration with Comments * added tiptap integration with user activity feeds * added ref control support and bubble menu support for readonly editor * added tiptap support for plane pages * added tiptap support to gpt assistant modal (yet to be tested) * removed remirror instances and cleaned up code * improved code structure for extracting props in Tiptap * fixing ts errors for next build * fixing node ts error for Horizontal Rule * added ts fix for node types * temp fix * temp fix * added min height for issue description in modal * added resolutions to prosemirror-model version * trying pnpm overrides * explicitly added prosemirror deps * bugfixes * removed extra gap at the top and moved saved indicator to the bottom * fix: slash command scroll position * chore: update custom css variables * matched theme colours * fixed gpt-assistant modal * updated yarn lock * added debounced updates for the title and removed saved state after timeout * added css animations for saved state * build fixes and remove remirror instances * minor commenting fixes --------- Co-authored-by: Palanikannan1437 <73993394+Palanikannan1437@users.noreply.github.com> Co-authored-by: Aaryan Khandelwal <aaryankhandu123@gmail.com>
74 lines
2.6 KiB
TypeScript
74 lines
2.6 KiB
TypeScript
import { Editor } from "@tiptap/core";
|
|
import { Check, Trash } from "lucide-react";
|
|
import { Dispatch, FC, SetStateAction, useEffect, useRef } from "react";
|
|
import { cn } from "../utils";
|
|
|
|
interface LinkSelectorProps {
|
|
editor: Editor;
|
|
isOpen: boolean;
|
|
setIsOpen: Dispatch<SetStateAction<boolean>>;
|
|
}
|
|
|
|
export const LinkSelector: FC<LinkSelectorProps> = ({ editor, isOpen, setIsOpen }) => {
|
|
const inputRef = useRef<HTMLInputElement>(null);
|
|
|
|
useEffect(() => {
|
|
inputRef.current && inputRef.current?.focus();
|
|
});
|
|
|
|
return (
|
|
<div className="relative">
|
|
<button
|
|
className={cn("flex h-full items-center space-x-2 px-3 py-1.5 text-sm font-medium text-custom-text-300 hover:bg-custom-background-100 active:bg-custom-background-100", { "bg-custom-background-100": isOpen })}
|
|
onClick={() => {
|
|
setIsOpen(!isOpen);
|
|
}}
|
|
>
|
|
<p className="text-base">↗</p>
|
|
<p
|
|
className={cn("underline underline-offset-4", {
|
|
"text-custom-text-100": editor.isActive("link"),
|
|
})}
|
|
>
|
|
Link
|
|
</p>
|
|
</button>
|
|
{isOpen && (
|
|
<form
|
|
onSubmit={(e) => {
|
|
e.preventDefault();
|
|
const form = e.target as HTMLFormElement;
|
|
const input = form.elements[0] as HTMLInputElement;
|
|
editor.chain().focus().setLink({ href: input.value }).run();
|
|
setIsOpen(false);
|
|
}}
|
|
className="fixed top-full z-[99999] mt-1 flex w-60 overflow-hidden rounded border border-custom-border-300 bg-custom-background-100 dow-xl animate-in fade-in slide-in-from-top-1"
|
|
>
|
|
<input
|
|
ref={inputRef}
|
|
type="url"
|
|
placeholder="Paste a link"
|
|
className="flex-1 bg-custom-background-100 border border-custom-primary-300 p-1 text-sm outline-none placeholder:text-custom-text-400"
|
|
defaultValue={editor.getAttributes("link").href || ""}
|
|
/>
|
|
{editor.getAttributes("link").href ? (
|
|
<button
|
|
className="flex items-center rounded-sm p-1 text-red-600 transition-all hover:bg-red-100 dark:hover:bg-red-800"
|
|
onClick={() => {
|
|
editor.chain().focus().unsetLink().run();
|
|
setIsOpen(false);
|
|
}}
|
|
>
|
|
<Trash className="h-4 w-4" />
|
|
</button>
|
|
) : (
|
|
<button className="flex items-center rounded-sm p-1 text-custom-text-300 transition-all hover:bg-custom-background-90">
|
|
<Check className="h-4 w-4" />
|
|
</button>
|
|
)}
|
|
</form>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|