2024-01-11 07:13:19 +00:00
|
|
|
import React from "react";
|
2024-01-11 12:12:15 +00:00
|
|
|
import { LiteTextEditorWithRef, ILiteTextEditor } from "@plane/lite-text-editor";
|
2024-01-11 07:13:19 +00:00
|
|
|
|
|
|
|
import { useMention } from "hooks/store";
|
|
|
|
|
|
|
|
import { FileService } from "services/file.service";
|
|
|
|
|
|
|
|
interface EditorHandle {
|
|
|
|
clearEditor: () => void;
|
|
|
|
setEditorValue: (content: string) => void;
|
|
|
|
}
|
|
|
|
|
2024-01-11 12:12:15 +00:00
|
|
|
interface LiteTextEditorWrapperProps
|
2024-01-11 07:13:19 +00:00
|
|
|
extends Omit<
|
2024-01-11 12:12:15 +00:00
|
|
|
ILiteTextEditor,
|
2024-01-11 07:13:19 +00:00
|
|
|
"uploadFile" | "deleteFile" | "restoreFile" | "mentionSuggestions" | "mentionHighlights"
|
|
|
|
> {
|
|
|
|
workspaceSlug: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const fileService = new FileService();
|
|
|
|
|
2024-01-11 12:12:15 +00:00
|
|
|
export const LiteTextEditor = React.forwardRef<EditorHandle, LiteTextEditorWrapperProps>(
|
2024-01-11 07:13:19 +00:00
|
|
|
({ workspaceSlug, ...props }, ref) => {
|
|
|
|
const editorSuggestions = useMention();
|
|
|
|
|
|
|
|
return (
|
2024-01-11 12:12:15 +00:00
|
|
|
<LiteTextEditorWithRef
|
2024-01-11 07:13:19 +00:00
|
|
|
ref={ref}
|
|
|
|
uploadFile={fileService.getUploadFileFunction(workspaceSlug)}
|
|
|
|
deleteFile={fileService.deleteImage}
|
|
|
|
restoreFile={fileService.restoreImage}
|
|
|
|
mentionSuggestions={editorSuggestions.mentionSuggestions}
|
|
|
|
mentionHighlights={editorSuggestions.mentionHighlights}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2024-01-11 12:12:15 +00:00
|
|
|
LiteTextEditor.displayName = "LiteTextEditor";
|