Skip to main content

Persistent Layouts

Examples of persisting layouts across page loads.

Local Storage

The PaneGroup component has an autoSaveId prop that can be used to uniquely identify the layout of the panes within the group. When provided, the layout of the panes will be saved to local storage and restored when the page is reloaded.

Left
Right

Anatomy

Here's the high-level structure of the example above:

+page.svelte
		<script lang="ts">
	import { PaneGroup, Pane, PaneResizer } from "paneforge";
</script>
 
<PaneGroup direction="horizontal" autoSaveId="someGroupId">
	<Pane defaultSize={50} />
	<PaneResizer />
	<Pane defaultSize={50} />
</PaneGroup>
	

Cookies (SSR-friendly)

Local storage is not available on the server, so you can use cookies to persist the layout of the panes across page loads, ensuring no layout flicker when the page is first loaded.

Left
Right

Anatomy

Here's the high-level structure of the example above:

+page.server.ts
		import type { PageServerLoad } from "./$types";
 
export const load: PageServerLoad = async (event) => {
	let layout = event.cookies.get("PaneForge:layout");
	if (layout) {
		layout = JSON.parse(layout);
	}
 
	return {
		layout,
	};
};
	
MyPaneGroup.svelte
		<script lang="ts">
	import { PaneGroup, Pane, PaneResizer } from "paneforge";
 
	let { layout }: { layout?: number[] } = $props();
 
	function onLayoutChange(sizes: number[]) {
		document.cookie = `PaneForge:layout=${JSON.stringify(sizes)}`;
	}
</script>
 
<PaneGroup direction="horizontal" {onLayoutChange}>
	<Pane defaultSize={layout ? layout[0] : 50} />
	<PaneResizer />
	<Pane defaultSize={layout ? layout[1] : 50} />
</PaneGroup>