2023-07-29 18:19:35 +08:00
|
|
|
import { Client } from "./client.ts";
|
2023-07-29 23:06:32 +08:00
|
|
|
import { EditorSelection } from "./deps.ts";
|
2023-07-14 19:58:16 +08:00
|
|
|
|
|
|
|
class PageState {
|
|
|
|
constructor(
|
|
|
|
readonly scrollTop: number,
|
|
|
|
readonly selection: EditorSelection,
|
|
|
|
) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
export class OpenPages {
|
|
|
|
openPages = new Map<string, PageState>();
|
|
|
|
|
2023-07-29 18:19:35 +08:00
|
|
|
constructor(private client: Client) {}
|
2023-07-14 19:58:16 +08:00
|
|
|
|
|
|
|
restoreState(pageName: string): boolean {
|
|
|
|
const pageState = this.openPages.get(pageName);
|
2023-07-29 18:19:35 +08:00
|
|
|
const editorView = this.client.editorView;
|
2023-07-14 19:58:16 +08:00
|
|
|
if (pageState) {
|
|
|
|
// Restore state
|
|
|
|
try {
|
|
|
|
editorView.dispatch({
|
|
|
|
selection: pageState.selection,
|
2023-07-27 21:25:25 +08:00
|
|
|
// scrollIntoView: true,
|
2023-07-14 19:58:16 +08:00
|
|
|
});
|
|
|
|
} catch {
|
|
|
|
// This is fine, just go to the top
|
|
|
|
editorView.dispatch({
|
|
|
|
selection: { anchor: 0 },
|
|
|
|
scrollIntoView: true,
|
|
|
|
});
|
|
|
|
}
|
2023-07-27 21:25:25 +08:00
|
|
|
setTimeout(() => {
|
|
|
|
// Next tick, to allow the editor to process the render
|
|
|
|
editorView.scrollDOM.scrollTop = pageState.scrollTop;
|
|
|
|
});
|
2023-07-14 19:58:16 +08:00
|
|
|
} else {
|
|
|
|
editorView.scrollDOM.scrollTop = 0;
|
|
|
|
editorView.dispatch({
|
|
|
|
selection: { anchor: 0 },
|
|
|
|
scrollIntoView: true,
|
|
|
|
});
|
|
|
|
}
|
2023-07-29 18:19:35 +08:00
|
|
|
this.client.focus();
|
2023-07-14 19:58:16 +08:00
|
|
|
return !!pageState;
|
|
|
|
}
|
|
|
|
|
|
|
|
saveState(currentPage: string) {
|
|
|
|
this.openPages.set(
|
|
|
|
currentPage,
|
|
|
|
new PageState(
|
2023-07-29 18:19:35 +08:00
|
|
|
this.client.editorView.scrollDOM.scrollTop,
|
|
|
|
this.client.editorView.state.selection,
|
2023-07-14 19:58:16 +08:00
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|