Window State
Save window positions and sizes and restore them when the app is reopened.
Supported Platforms
- Windows
- Linux
- macOS
Setup
This plugin requires a Rust version of at least 1.75
Install the window-state plugin to get started.
Use your project’s package manager to add the dependency:
npm run tauri add window-stateyarn run tauri add window-statepnpm tauri add window-statecargo tauri add window-state- 
Install the Core plugin by adding the following to your Cargo.tomlfile:src-tauri/Cargo.toml [dependencies]tauri-plugin-window-state = "2.0.0-beta"# alternatively with Git:tauri-plugin-window-state = { git = "https://github.com/tauri-apps/plugins-workspace", branch = "v2" }
- 
Modify lib.rsto initialize the plugin:src-tauri/src/lib.rs fn run() {tauri::Builder::default().plugin(tauri_plugin_window_state::Builder::default().build()).run(tauri::generate_context!()).expect("error while running tauri application");}
- 
Install the JavaScript Guest bindings using your preferred JavaScript package manager: npm install @tauri-apps/plugin-window-stateyarn add @tauri-apps/plugin-window-statepnpm add @tauri-apps/plugin-window-state
Usage
After adding the all windows will remember their state when the app is being closed and will restore to their previous state on the next launch.
You can also access the window-state plugin in both JavaScript and Rust.
JavaScript
You can use saveWindowState to manually save the window state:
import { saveWindowState, StateFlags } from '@tauri-apps/plugin-window-state';
saveWindowState(StateFlags.ALL);Similarly you can manually restore a window’s state from disk:
import {  restoreStateCurrent,  StateFlags,} from '@tauri-apps/plugin-window-state';
restoreStateCurrent(StateFlags.ALL);Rust
You can use the save_window_state() method exposed by the AppHandleExt trait:
use tauri_plugin_window_state::{AppHandleExt, StateFlags};
// `tauri::AppHandle` now has the following additional methodapp.save_window_state(StateFlags::all()); // will save the state of all open windows to diskSimilarly you can manually restore a window’s state from disk using the restore_state() method exposed by the WindowExt trait:
use tauri_plugin_window_state::{WindowExt, StateFlags};
// all `Window` types now have the following additional methodwindow.restore_state(StateFlags::all()); // will restore the window's state from diskPermissions
By default all plugin commands are blocked and cannot be accessed.
You must define a list of permissions in your capabilities configuration.
See Permissions Overview for more information.
{  "permissions": [    ...,    "window-state:allow-restore-state",    "window-state:allow-save-window-state",  ]}| Permission | Description | 
|---|---|
| window-state:allow-restore-state | Enables the restore_state command without any pre-configured scope. | 
| window-state:deny-restore-state | Denies the restore_state command without any pre-configured scope. | 
| window-state:allow-save-window-state | Enables the save_window_state command without any pre-configured scope. | 
| window-state:deny-save-window-state | Denies the save_window_state command without any pre-configured scope. | 
© 2024 Tauri Contributors. CC-BY / MIT