mirror of
https://github.com/siyuan-note/siyuan.git
synced 2025-12-29 04:48:48 +01:00
99 lines
3.4 KiB
TypeScript
99 lines
3.4 KiB
TypeScript
import {Constants} from "../constants";
|
||
/// #if !BROWSER
|
||
import {ipcRenderer} from "electron";
|
||
/// #endif
|
||
import {processMessage} from "./processMessage";
|
||
import {kernelError} from "../dialog/processSystem";
|
||
|
||
export const fetchPost = (url: string, data?: any, cb?: (response: IWebSocketData) => void, headers?: IObject) => {
|
||
const init: RequestInit = {
|
||
method: "POST",
|
||
};
|
||
if (data) {
|
||
if (["/api/search/searchRefBlock", "/api/graph/getGraph", "/api/graph/getLocalGraph"].includes(url)) {
|
||
window.siyuan.reqIds[url] = new Date().getTime();
|
||
if (data.type === "local" && url === "/api/graph/getLocalGraph") {
|
||
// 当打开文档A的关系图、关系图、文档A后刷新,由于防止请求重复处理,文档A关系图无法渲染。
|
||
} else {
|
||
data.reqId = window.siyuan.reqIds[url];
|
||
}
|
||
}
|
||
if (data instanceof FormData) {
|
||
init.body = data;
|
||
} else {
|
||
init.body = JSON.stringify(data);
|
||
}
|
||
}
|
||
if (headers) {
|
||
init.headers = headers;
|
||
}
|
||
fetch(url, init).then((response) => {
|
||
if (response.status === 404) {
|
||
return {
|
||
data: null,
|
||
msg: response.statusText,
|
||
code: response.status,
|
||
};
|
||
} else {
|
||
if (response.headers.get("content-type")?.indexOf("application/json") > -1) {
|
||
return response.json();
|
||
} else {
|
||
return response.text();
|
||
}
|
||
}
|
||
}).then((response: IWebSocketData) => {
|
||
if (typeof response === "string") {
|
||
if (cb) {
|
||
cb(response);
|
||
}
|
||
return;
|
||
}
|
||
if (["/api/search/searchRefBlock", "/api/graph/getGraph", "/api/graph/getLocalGraph"].includes(url)) {
|
||
if (response.data.reqId && window.siyuan.reqIds[url] && window.siyuan.reqIds[url] > response.data.reqId) {
|
||
return;
|
||
}
|
||
}
|
||
if (typeof response === "object" && typeof response.msg === "string" && typeof response.code === "number") {
|
||
if (processMessage(response) && cb) {
|
||
cb(response);
|
||
}
|
||
} else if (cb) {
|
||
cb(response);
|
||
}
|
||
}).catch((e) => {
|
||
console.warn("fetch post error", e);
|
||
if (url === "/api/transactions" && (e.message === "Failed to fetch" || e.message === "Unexpected end of JSON input")) {
|
||
kernelError();
|
||
return;
|
||
}
|
||
/// #if !BROWSER
|
||
if (url === "/api/system/exit" || url === "/api/system/setWorkspaceDir" || (
|
||
["/api/system/setUILayout"].includes(url) && data.errorExit // 内核中断,点关闭处理
|
||
)) {
|
||
ipcRenderer.send(Constants.SIYUAN_QUIT, location.port);
|
||
}
|
||
/// #endif
|
||
});
|
||
};
|
||
|
||
export const fetchSyncPost = async (url: string, data?: any) => {
|
||
const init: RequestInit = {
|
||
method: "POST",
|
||
};
|
||
if (data) {
|
||
init.body = JSON.stringify(data);
|
||
}
|
||
const res = await fetch(url, init);
|
||
const res2 = await res.json() as IWebSocketData;
|
||
processMessage(res2);
|
||
return res2;
|
||
};
|
||
|
||
export const fetchGet = (url: string, cb: (response: IWebSocketData | IEmoji[]) => void) => {
|
||
fetch(url).then((response) => {
|
||
return response.json();
|
||
}).then((response: IWebSocketData) => {
|
||
cb(response);
|
||
});
|
||
};
|
||
|