mirror of
https://github.com/Shadowfita/docmost.git
synced 2025-11-14 00:31:12 +10:00
* update tiptap version * excalidraw init * cleanup * better file handling and other fixes * use different modal to fix excalidraw cursor position issue * see https://github.com/excalidraw/excalidraw/issues/7312 * fix websocket in vite dev mode * WIP * add align attribute * fix table * menu icons * Render image in excalidraw html * add size to custom SVG components * rewrite undefined font urls
101 lines
2.6 KiB
TypeScript
101 lines
2.6 KiB
TypeScript
import api from "@/lib/api-client";
|
|
import {
|
|
IExportPageParams,
|
|
IMovePage,
|
|
IPage,
|
|
IPageInput,
|
|
SidebarPagesParams,
|
|
} from "@/features/page/types/page.types";
|
|
import { IAttachment, IPagination } from "@/lib/types.ts";
|
|
import { saveAs } from "file-saver";
|
|
|
|
export async function createPage(data: Partial<IPage>): Promise<IPage> {
|
|
const req = await api.post<IPage>("/pages/create", data);
|
|
return req.data;
|
|
}
|
|
|
|
export async function getPageById(
|
|
pageInput: Partial<IPageInput>,
|
|
): Promise<IPage> {
|
|
const req = await api.post<IPage>("/pages/info", pageInput);
|
|
return req.data;
|
|
}
|
|
|
|
export async function updatePage(data: Partial<IPageInput>): Promise<IPage> {
|
|
const req = await api.post<IPage>("/pages/update", data);
|
|
return req.data;
|
|
}
|
|
|
|
export async function deletePage(pageId: string): Promise<void> {
|
|
await api.post("/pages/delete", { pageId });
|
|
}
|
|
|
|
export async function movePage(data: IMovePage): Promise<void> {
|
|
await api.post<void>("/pages/move", data);
|
|
}
|
|
|
|
export async function getSidebarPages(
|
|
params: SidebarPagesParams,
|
|
): Promise<IPagination<IPage>> {
|
|
const req = await api.post("/pages/sidebar-pages", params);
|
|
return req.data;
|
|
}
|
|
|
|
export async function getPageBreadcrumbs(
|
|
pageId: string,
|
|
): Promise<Partial<IPage[]>> {
|
|
const req = await api.post("/pages/breadcrumbs", { pageId });
|
|
return req.data;
|
|
}
|
|
|
|
export async function getRecentChanges(
|
|
spaceId?: string,
|
|
): Promise<IPagination<IPage>> {
|
|
const req = await api.post("/pages/recent", { spaceId });
|
|
return req.data;
|
|
}
|
|
|
|
export async function exportPage(data: IExportPageParams): Promise<void> {
|
|
const req = await api.post("/pages/export", data, {
|
|
responseType: "blob",
|
|
});
|
|
|
|
const fileName = req?.headers["content-disposition"]
|
|
.split("filename=")[1]
|
|
.replace(/"/g, "");
|
|
|
|
saveAs(req.data, fileName);
|
|
}
|
|
|
|
export async function importPage(file: File, spaceId: string) {
|
|
const formData = new FormData();
|
|
formData.append("spaceId", spaceId);
|
|
formData.append("file", file);
|
|
|
|
const req = await api.post<IPage>("/pages/import", formData, {
|
|
headers: {
|
|
"Content-Type": "multipart/form-data",
|
|
},
|
|
});
|
|
|
|
return req.data;
|
|
}
|
|
|
|
export async function uploadFile(file: File, pageId: string, attachmentId?: string): Promise<IAttachment> {
|
|
const formData = new FormData();
|
|
if(attachmentId){
|
|
formData.append("attachmentId", attachmentId);
|
|
}
|
|
formData.append("pageId", pageId);
|
|
formData.append("file", file);
|
|
|
|
|
|
const req = await api.post<IAttachment>("/files/upload", formData, {
|
|
headers: {
|
|
"Content-Type": "multipart/form-data",
|
|
},
|
|
});
|
|
|
|
return req as unknown as IAttachment;
|
|
}
|