import copy from "copy-to-clipboard"; import React from "react"; import toast from "react-hot-toast"; import { useTranslate } from "@/utils/i18n"; import { useResourceStore } from "@/store/module"; import { getResourceUrl } from "@/utils/resource"; import Dropdown from "./kit/Dropdown"; import Icon from "./Icon"; import { showCommonDialog } from "./Dialog/CommonDialog"; import showChangeResourceFilenameDialog from "./ChangeResourceFilenameDialog"; import showPreviewImageDialog from "./PreviewImageDialog"; interface Props { resource: Resource; } const ResourceItemDropdown = ({ resource }: Props) => { const t = useTranslate(); const resourceStore = useResourceStore(); const handlePreviewBtnClick = (resource: Resource) => { const resourceUrl = getResourceUrl(resource); if (resource.type.startsWith("image")) { showPreviewImageDialog([getResourceUrl(resource)], 0); } else { window.open(resourceUrl); } }; const handleCopyResourceLinkBtnClick = (resource: Resource) => { const url = getResourceUrl(resource); copy(url); toast.success(t("message.succeed-copy-resource-link")); }; const handleRenameBtnClick = (resource: Resource) => { showChangeResourceFilenameDialog(resource.id, resource.filename); }; const handleDeleteResourceBtnClick = (resource: Resource) => { let warningText = t("resource.warning-text"); if (resource.linkedMemoAmount > 0) { warningText = warningText + `\n${t("resource.linked-amount")}: ${resource.linkedMemoAmount}`; } showCommonDialog({ title: t("resource.delete-resource"), content: warningText, style: "warning", dialogName: "delete-resource-dialog", onConfirm: async () => { await resourceStore.deleteResourceById(resource.id); }, }); }; return ( } actions={ <> } /> ); }; export default React.memo(ResourceItemDropdown);