import { useState } from "react"; import { observer } from "mobx-react"; import { ArchiveRestoreIcon, ExternalLink, Link, Lock, Trash2, UsersRound } from "lucide-react"; import { ArchiveIcon, ContextMenu, CustomMenu, TContextMenuItem, TOAST_TYPE, setToast } from "@plane/ui"; // components import { DeletePageModal } from "@/components/pages"; // constants import { E_PAGES, PAGE_ARCHIVED, PAGE_RESTORED, PAGE_UPDATED } from "@/constants/event-tracker"; // helpers import { copyUrlToClipboard } from "@/helpers/string.helper"; // hooks import { useEventTracker, usePage } from "@/hooks/store"; type Props = { pageId: string; parentRef: React.RefObject; projectId: string; workspaceSlug: string; }; export const PageQuickActions: React.FC = observer((props) => { const { pageId, parentRef, projectId, workspaceSlug } = props; // states const [deletePageModal, setDeletePageModal] = useState(false); // store hooks const { access, archive, archived_at, makePublic, makePrivate, restore, canCurrentUserArchivePage, canCurrentUserChangeAccess, canCurrentUserDeletePage, } = usePage(pageId); const { setTrackElement, captureEvent } = useEventTracker(); const pageLink = `${workspaceSlug}/projects/${projectId}/pages/${pageId}`; const handleCopyText = () => copyUrlToClipboard(pageLink).then(() => { setToast({ type: TOAST_TYPE.SUCCESS, title: "Link Copied!", message: "Page link copied to clipboard.", }); }); const handleOpenInNewTab = () => window.open(`/${pageLink}`, "_blank"); const MENU_ITEMS: TContextMenuItem[] = [ { key: "make-public-private", action: () => { { access === 0 ? makePrivate() : makePublic(); captureEvent(PAGE_UPDATED, { page_id: pageId, changed_property: "access", change_details: access === 0 ? "private" : "public", element: E_PAGES, }); } }, title: access === 0 ? "Make private" : "Make public", icon: access === 0 ? Lock : UsersRound, shouldRender: canCurrentUserChangeAccess && !archived_at, }, { key: "open-new-tab", action: handleOpenInNewTab, title: "Open in new tab", icon: ExternalLink, shouldRender: true, }, { key: "copy-link", action: handleCopyText, title: "Copy link", icon: Link, shouldRender: true, }, { key: "archive-restore", action: () => { archived_at ? restore() : archive(); captureEvent(archived_at ? PAGE_RESTORED : PAGE_ARCHIVED, { page_id: pageId, element: E_PAGES, }); }, title: archived_at ? "Restore" : "Archive", icon: archived_at ? ArchiveRestoreIcon : ArchiveIcon, shouldRender: canCurrentUserArchivePage, }, { key: "delete", action: () => { setTrackElement(E_PAGES); setDeletePageModal(true); }, title: "Delete", icon: Trash2, shouldRender: canCurrentUserDeletePage && !!archived_at, }, ]; return ( <> setDeletePageModal(false)} pageId={pageId} projectId={projectId} /> {MENU_ITEMS.map((item) => { if (!item.shouldRender) return null; return ( { e.preventDefault(); e.stopPropagation(); item.action(); }} className="flex items-center gap-2" > {item.icon && } {item.title} ); })} ); });