fix page-reload

This commit is contained in:
Rizky 2023-10-16 14:27:34 +00:00
parent c1a82b2a9f
commit 820e9b1e46
2 changed files with 58 additions and 15 deletions

View File

@ -0,0 +1,52 @@
import { compress } from "lz-string";
import { syncronize } from "y-pojo";
import * as Y from "yjs";
import { MPage } from "../../web/src/utils/types/general";
import { WS_MSG_SET_PAGE, WS_MSG_SV_LOCAL } from "../../web/src/utils/types/ws";
import { eg } from "../ws/edit/edit-global";
import { loadPage } from "../ws/edit/tools/load-page";
export const _ = {
url: "/page-reload/:page_id",
async api(page_id: string) {
if (eg.edit.page[page_id]) {
const rawPage = await loadPage(page_id);
if (rawPage) {
const ydoc = new Y.Doc() as MPage;
let root = ydoc.getMap("map");
syncronize(root as any, rawPage);
const um = new Y.UndoManager(root, { ignoreRemoteMapChanges: true });
const broadcast = () => {
const sv_local = compress(
Y.encodeStateVector(ydoc as any).toString()
);
const broadcast: WS_MSG_SV_LOCAL = {
type: "sv_local",
sv_local,
mode: "page",
id: page_id,
};
eg.edit.page[page_id].ws.forEach((w) =>
w.send(JSON.stringify(broadcast))
);
};
um.on("stack-item-added", broadcast);
um.on("stack-item-updated", broadcast);
eg.edit.page[page_id].doc = ydoc;
eg.edit.page[page_id].undoManager = um;
eg.edit.page[page_id].ws.forEach((w) => {
const sent: WS_MSG_SET_PAGE = {
type: "set_page",
changes: compress(Y.encodeStateAsUpdate(ydoc as any).toString()),
};
w.send(JSON.stringify(sent));
});
}
}
return "ok";
},
};

View File

@ -20,22 +20,13 @@ export const routeEditor = (p: PG, page_id: string) => {
p.render();
if (!p.mpage || p.mpage.getMap("map").get("id") !== page_id) {
if (!loadingCounter[page_id]) {
loadingCounter[page_id] = 1;
} else {
loadingCounter[page_id]++;
}
if (loadingCounter[page_id] > 2) {
p.status = "reload";
p.status = "reload";
await api.page_reload(page_id);
p.mpageLoaded = () => {
p.status = "ready";
p.render();
p.mpageLoaded = () => {
p.status = "ready";
p.render();
};
await api.page_reload(page_id);
}
};
p.render();
}
});
}