1
0
Fork 0
mirror of https://github.com/kou029w/quot.git synced 2025-01-19 00:18:09 +00:00
quot/app/views/pages/page.tsx

85 lines
2.2 KiB
TypeScript

import { createResource } from "solid-js";
import type Pages from "../../protocol/pages";
import Editor from "../components/editor";
import beforeunload from "../helpers/beforeunload";
import throttle from "../helpers/throttle";
const { block, unblock } = beforeunload();
async function updatePage(
id: number,
content: Pages.RequestContentPage
): Promise<boolean> {
const jwt = window.localStorage.getItem("jwt");
const res = await fetch(
`${import.meta.env.QUOT_API_ENDPOINT}/pages?id=eq.${id}`,
{
method: "PUT",
headers: {
...(jwt ? { authorization: `Bearer ${jwt}` } : {}),
"content-type": "application/json",
},
body: JSON.stringify(content),
}
);
return res.ok;
}
async function deletePage(id: number): Promise<boolean> {
const jwt = window.localStorage.getItem("jwt");
const res = await fetch(
`${import.meta.env.QUOT_API_ENDPOINT}/pages?id=eq.${id}`,
{
method: "DELETE",
headers: jwt ? { authorization: `Bearer ${jwt}` } : {},
}
);
return res.ok;
}
async function fetchPage(id: number): Promise<Pages.ResponsePage> {
const jwt = window.localStorage.getItem("jwt");
const res = await fetch(
`${import.meta.env.QUOT_API_ENDPOINT}/pages?id=eq.${id}`,
{ headers: jwt ? { authorization: `Bearer ${jwt}` } : {} }
);
const data = (await res.json()) as Pages.Response;
return data[0]!;
}
export default (props: { id: number }) => {
const [page] = createResource(props.id, fetchPage);
const throttledUpdate = throttle(
async (id: number, content: Pages.RequestContentPage) => {
if (await (content.text ? updatePage(id, content) : deletePage(id))) {
unblock();
window.history.replaceState(
{},
"",
`/${content.text ? id.toString(16) : "new"}`
);
}
}
);
function onUpdatePage(content: Pages.RequestContentPage) {
block();
throttledUpdate(props.id, content);
}
return (
<main>
{() =>
!page.loading && (
<Editor
id={props.id}
title=""
text=""
{...page()}
onUpdatePage={onUpdatePage}
/>
)
}
</main>
);
};