mirror of
https://github.com/usememos/memos.git
synced 2025-06-05 22:09:59 +02:00
63 lines
1.9 KiB
TypeScript
63 lines
1.9 KiB
TypeScript
import copy from "copy-to-clipboard";
|
|
import React from "react";
|
|
import { toast } from "react-hot-toast";
|
|
import { useTranslate } from "@/utils/i18n";
|
|
import { generateDialog } from "./Dialog";
|
|
import Icon from "./Icon";
|
|
|
|
interface Props extends DialogProps {
|
|
memoId: MemoId;
|
|
}
|
|
|
|
const EmbedMemoDialog: React.FC<Props> = (props: Props) => {
|
|
const t = useTranslate();
|
|
const { memoId, destroy } = props;
|
|
|
|
const memoEmbeddedCode = () => {
|
|
return `<iframe style="width:100%;height:auto;min-width:256px;" src="${window.location.origin}/m/${memoId}/embed" frameBorder="0"></iframe>`;
|
|
};
|
|
|
|
const handleCopyCode = () => {
|
|
copy(memoEmbeddedCode());
|
|
toast.success("Succeed to copy code to clipboard.");
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<div className="dialog-header-container">
|
|
<p className="title-text">{t("embed-memo.title")}</p>
|
|
<button className="btn close-btn" onClick={() => destroy()}>
|
|
<Icon.X />
|
|
</button>
|
|
</div>
|
|
<div className="dialog-content-container !w-80">
|
|
<p className="text-base leading-6 mb-2">{t("embed-memo.text")}</p>
|
|
<pre className="w-full font-mono text-sm p-3 border rounded-lg">
|
|
<code className="w-full break-all whitespace-pre-wrap">{memoEmbeddedCode()}</code>
|
|
</pre>
|
|
<p className="w-full text-sm leading-6 flex flex-row justify-between items-center mt-2">
|
|
<span className="italic opacity-80">{t("embed-memo.only-public-supported")}</span>
|
|
<span className="btn-primary" onClick={handleCopyCode}>
|
|
{t("embed-memo.copy")}
|
|
</span>
|
|
</p>
|
|
</div>
|
|
</>
|
|
);
|
|
};
|
|
|
|
function showEmbedMemoDialog(memoId: MemoId) {
|
|
generateDialog(
|
|
{
|
|
className: "embed-memo-dialog",
|
|
dialogName: "embed-memo-dialog",
|
|
},
|
|
EmbedMemoDialog,
|
|
{
|
|
memoId,
|
|
}
|
|
);
|
|
}
|
|
|
|
export default showEmbedMemoDialog;
|