AnoPaper/src/pages/pubNoteSafe.jsx

74 lines
2.2 KiB
React
Raw Normal View History

2023-04-01 20:57:46 +03:00
import RenderMarkdown from "../components/markdown";
import { useState } from "react";
import { useParams } from "react-router-dom";
import printDate from "../components/utils";
import { ChevronDoubleLeftIcon } from "@heroicons/react/24/outline";
2023-02-09 17:15:34 +03:00
import { Button, IconWithText } from "../components/button";
import { CopyToClipboard } from "../components/copytocb";
2023-04-03 15:23:41 +03:00
import Note from "../components/note";
function PubNoteSafe() {
let params = useParams();
let [note, setNote] = useState(false);
if (note === false)
fetch(`/get-note/safe/${params.id}`)
.then((data) => {
data
.json()
.then((data) => {
data.code = 1;
setNote(data);
})
.catch(() => {
setNote({
text: "Такой публичной заметки не сущуествует",
name: "Меня не существует",
time: Date.now(),
code: 0,
});
});
})
.catch(() => {
setNote({
text: "Такой публичной заметки не сущуествует",
name: "Меня не существует",
time: Date.now(),
code: 0,
});
});
return (
<div className="">
<Button className="mb-4" href="/">
2023-02-09 17:15:34 +03:00
<IconWithText
icon={
<ChevronDoubleLeftIcon className="transform translate-z-0 h-7 w-7" />
}
>
Писать
2023-02-09 17:15:34 +03:00
</IconWithText>
</Button>
{note?.code === 1 && (
<div className="p-4 mb-2">
<div className="grid grid-cols-1 lg:grid-cols-2">
<h2 className="font-medium text-center lg:text-left p-2">
Ссылка для отправки публичной заметки. При переходе на эту ссылку,
2023-04-02 11:46:41 +03:00
заметка исчезнет с сервера и будет сохранена локально.
</h2>
<CopyToClipboard
text={`${window.location.origin}/pubNotes/${params.id}`}
></CopyToClipboard>
</div>
</div>
)}
2023-04-03 15:23:41 +03:00
<Note note={note} />
</div>
);
}
export default PubNoteSafe;