AnoPaper/src/pages/pubNoteSafe.jsx

69 lines
2 KiB
React
Raw Normal View History

import { useState } from "react";
import { useParams } from "react-router-dom";
import { ChevronDoubleLeftIcon } from "@heroicons/react/24/outline";
2023-04-03 17:03:01 +03:00
import { ButtonWithIcon } 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="">
2023-04-03 17:03:01 +03:00
<ButtonWithIcon
className="mb-4"
href="/"
text="Писать"
icon={ChevronDoubleLeftIcon}
/>
{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;