#tauri-plugin #plugin #desktop #tauri #wallpaper #desktop-plugin #underlay

sys tauri-plugin-desktop-underlay

Tauri plugin for attaching a window to desktop, below icons and above wallpaper

3 unstable releases

new 0.1.1 May 11, 2025
0.1.0 May 11, 2025
0.0.1 Sep 3, 2024

#1321 in GUI

Download history 228/week @ 2025-05-06

228 downloads per month

Custom license

59KB
317 lines

PLUGIN-DESKTOP-UNDERLAY

tauri license npm npm crates.io crates.io docs.rs

Tauri plugin for attaching a window to desktop, below icons and above wallpaper, referred to as a desktop underlay.

  • Linux: Not tested, thus not guaranteed to work.
  • MacOS:
  • Windows:

Examples

Install

Install the desktop underlay plugin by adding the following to your Cargo.toml file:

[dependencies]
tauri-plugin-desktop-underlay = "0.1.1"

You can install the JavaScript guest bindings using your preferred JavaScript package manager:

npm install tauri-plugin-desktop-underlay-api # or
yarn add tauri-plugin-desktop-underlay-api # or
pnpm add tauri-plugin-desktop-underlay-api

Usage

First you need to register the core plugin with Tauri:

tauri::Builder::default()
    // Initialize the desktop-underlay plugin
    .plugin(tauri_plugin_desktop_underlay::init())
    .run(tauri::generate_context!())
    .unwrap();

Afterwards all the plugin's APIs are available through the JavaScript guest bindings:

import {
  setDesktopUnderlay,
  isDesktopUnderlay,
  toggleDesktopUnderlay,
} from "tauri-plugin-desktop-underlay-api";

To operate on the current window:

const isUnderlay = await isDesktopUnderlay();
await setDesktopUnderlay(true);
await setDesktopUnderlay(false);
const nowIsUnderlay = await toggleDesktopUnderlay();

To operate on another window (say, with label wallpaper):

const isUnderlay = await isDesktopUnderlay("wallpaper");
await setDesktopUnderlay(true, "wallpaper");
await setDesktopUnderlay(false, "wallpaper");
const nowIsUnderlay = await toggleDesktopUnderlay("wallpaper");

If you only intend on using the APIs from Rust code, you can import the DesktopUnderlayExt extension on windows and webview windows:

use tauri_plugin_desktop_underlay::DesktopUnderlayExt;

let main_window = app.get_webview_window("main").unwrap();
let is_underlay = main_window.is_desktop_underlay();
let _ = main_window.set_desktop_underlay(true);
let _ = main_window.set_desktop_underlay(false);
let now_is_underlay = main_window.toggle_desktop_underlay();

Permissions

See permissions reference. You do not need to add permissions if you are not using the JavaScript guest bindings.

Build from Source

If you want to try a local build, or you want to try the examples before deciding whether to use this plugin, you may need to build the source code:

git clone https://github.com/Charlie-XIAO/tauri-plugin-desktop-underlay.git
pnpm install
pnpm build

FAQ

See FAQ for the list of frequently asked questions. If these do not answer your question and you cannot find an answer in the issue tracker either, consider submitting a new issue.

Contributing

Feel free to open issues to report bugs or request features and improvements. Since I majorly develop on Windows, there could be many problems on Linux and macOS that I am not aware of. Pull requests are also welcome, though for larger changes it would be generally better to open an issue for discussion first.

License

Copyright (c) 2024-2025 Yao Xiao @Charlie-XIAO; this project is released under the MIT License.

Dependencies

~18–66MB
~1M SLoC