mirror of
https://github.com/zadam/trilium.git
synced 2025-10-24 14:56:14 +08:00
fix(ui): Exclude launcher pane width from Split calculation; Record Split state for multiple windows
This commit is contained in:
parent
c65f0d4249
commit
22b64a0dc4
1 changed files with 22 additions and 8 deletions
|
@ -3,7 +3,11 @@ import Split from "split.js"
|
||||||
|
|
||||||
export const DEFAULT_GUTTER_SIZE = 5;
|
export const DEFAULT_GUTTER_SIZE = 5;
|
||||||
|
|
||||||
|
let leftPaneWidth: number;
|
||||||
|
let reservedPx: number;
|
||||||
|
let layoutOrientation: string;
|
||||||
let leftInstance: ReturnType<typeof Split> | null;
|
let leftInstance: ReturnType<typeof Split> | null;
|
||||||
|
let rightPaneWidth: number;
|
||||||
let rightInstance: ReturnType<typeof Split> | null;
|
let rightInstance: ReturnType<typeof Split> | null;
|
||||||
|
|
||||||
function setupLeftPaneResizer(leftPaneVisible: boolean) {
|
function setupLeftPaneResizer(leftPaneVisible: boolean) {
|
||||||
|
@ -14,27 +18,34 @@ function setupLeftPaneResizer(leftPaneVisible: boolean) {
|
||||||
|
|
||||||
$("#left-pane").toggle(leftPaneVisible);
|
$("#left-pane").toggle(leftPaneVisible);
|
||||||
|
|
||||||
|
layoutOrientation = layoutOrientation ?? options.get("layoutOrientation");
|
||||||
|
reservedPx = reservedPx ?? (layoutOrientation === "vertical" ? ($("#launcher-pane").outerWidth() || 0) : 0);
|
||||||
|
// Window resizing causes `window.innerWidth` to change, so `reservedWidth` needs to be recalculated each time.
|
||||||
|
const reservedWidth = reservedPx / window.innerWidth * 100;
|
||||||
if (!leftPaneVisible) {
|
if (!leftPaneVisible) {
|
||||||
$("#rest-pane").css("width", "100%");
|
$("#rest-pane").css("width", layoutOrientation === "vertical" ? `calc(100% - ${reservedWidth})` : "100%");
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
let leftPaneWidth = options.getInt("leftPaneWidth");
|
leftPaneWidth = leftPaneWidth ?? (options.getInt("leftPaneWidth") ?? 0);
|
||||||
if (!leftPaneWidth || leftPaneWidth < 5) {
|
if (!leftPaneWidth || leftPaneWidth < 5) {
|
||||||
leftPaneWidth = 5;
|
leftPaneWidth = 5;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const restPaneWidth = 100 - leftPaneWidth - reservedWidth;
|
||||||
if (leftPaneVisible) {
|
if (leftPaneVisible) {
|
||||||
// Delayed initialization ensures that all DOM elements are fully rendered and part of the layout,
|
// Delayed initialization ensures that all DOM elements are fully rendered and part of the layout,
|
||||||
// preventing Split.js from retrieving incorrect dimensions due to #left-pane not being rendered yet,
|
// preventing Split.js from retrieving incorrect dimensions due to #left-pane not being rendered yet,
|
||||||
// which would cause the minSize setting to have no effect.
|
// which would cause the minSize setting to have no effect.
|
||||||
requestAnimationFrame(() => {
|
requestAnimationFrame(() => {
|
||||||
leftInstance = Split(["#left-pane", "#rest-pane"], {
|
leftInstance = Split(["#left-pane", "#rest-pane"], {
|
||||||
sizes: [leftPaneWidth, 100 - leftPaneWidth],
|
sizes: [leftPaneWidth, restPaneWidth],
|
||||||
gutterSize: DEFAULT_GUTTER_SIZE,
|
gutterSize: DEFAULT_GUTTER_SIZE,
|
||||||
minSize: [150, 300],
|
minSize: [150, 300],
|
||||||
onDragEnd: (sizes) => options.save("leftPaneWidth", Math.round(sizes[0]))
|
onDragEnd: (sizes) => {
|
||||||
|
leftPaneWidth = Math.round(sizes[0]);
|
||||||
|
options.save("leftPaneWidth", Math.round(sizes[0]));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -54,7 +65,7 @@ function setupRightPaneResizer() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
let rightPaneWidth = options.getInt("rightPaneWidth");
|
rightPaneWidth = rightPaneWidth ?? (options.getInt("rightPaneWidth") ?? 0);
|
||||||
if (!rightPaneWidth || rightPaneWidth < 5) {
|
if (!rightPaneWidth || rightPaneWidth < 5) {
|
||||||
rightPaneWidth = 5;
|
rightPaneWidth = 5;
|
||||||
}
|
}
|
||||||
|
@ -63,8 +74,11 @@ function setupRightPaneResizer() {
|
||||||
rightInstance = Split(["#center-pane", "#right-pane"], {
|
rightInstance = Split(["#center-pane", "#right-pane"], {
|
||||||
sizes: [100 - rightPaneWidth, rightPaneWidth],
|
sizes: [100 - rightPaneWidth, rightPaneWidth],
|
||||||
gutterSize: DEFAULT_GUTTER_SIZE,
|
gutterSize: DEFAULT_GUTTER_SIZE,
|
||||||
minSize: [ 300, 180 ],
|
minSize: [300, 180],
|
||||||
onDragEnd: (sizes) => options.save("rightPaneWidth", Math.round(sizes[1]))
|
onDragEnd: (sizes) => {
|
||||||
|
rightPaneWidth = Math.round(sizes[1]);
|
||||||
|
options.save("rightPaneWidth", Math.round(sizes[1]));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue