#window-manager #hyprland #scratchpad #desktop #wayland #linux #scratchpads

app hyprscratch

Improved scratchpad functionality for Hyprland

29 releases

0.5.0 Nov 9, 2024
0.4.3 Aug 31, 2024
0.4.2 Jul 21, 2024
0.2.10 Mar 22, 2024
0.1.3 Jul 8, 2023

#114 in GUI

Download history 191/week @ 2024-08-30 9/week @ 2024-09-06 22/week @ 2024-09-13 41/week @ 2024-09-20 33/week @ 2024-09-27 3/week @ 2024-10-04 155/week @ 2024-10-11 28/week @ 2024-10-18 3/week @ 2024-11-01 111/week @ 2024-11-08 13/week @ 2024-11-15 5/week @ 2024-11-22 3/week @ 2024-11-29

133 downloads per month

MIT and GPL-3.0-or-later

67KB
1.5K SLoC

Hyprscratch

A small tool for Qtile-like scratchpads in Hyprland or simplifying usage of the built-in functionality, configured entirely inside of hyprland.conf.

Installation

Cargo:

cargo install hyprscratch

AUR:

paru -S hyprscratch

Usage

In hyprland.conf:

#start the hyprscratch daemon
exec-once = hyprscratch [DAEMON_OPTIONS]

#configure scratchpads
bind = $MOD, $KEY, exec, hyprscratch $CLIENT_TITLE "$HYPRLAND_EXEC_COMMAND" [SCRATCHPAD_OPTIONS]

Example scratchpad:

bind = $mainMod, b, exec, hyprscratch btop "[float;size 70% 80%;center] alacritty --title btop -e btop" onstart

Daemon options:

  • clean [spotless]: automatically hides all scratchpads on workspace change. The spotless option also hides them on losing focus to non-floating cients.

  • no-auto-reload: does not reload the configuration when the configuration file is updated.

Scratchpad options:

  • persist: makes it so that the scratchpad doesn't get replaced when a new one is summoned.

  • cover: makes it so that the scratchpad doesn't replace another one if one is already present.

  • sticky: makes it so that the scratchpad isn't hidden by clean.

  • shiny: makes it so that the scratchpad isn't hidden only by clean spotless.

  • eager: spawns the scratchpad hidden when the daemon is started.

  • summon: only creates or brings up the scratchpad.

  • hide: only hides the scratchpad.

  • poly: toggle all scratchpads with the same title

  • special: uses the special workspace. Ignores most other scratchpad options and is ignored by clean spotless and cycle.

Extra hyprscratch commands:

  • cycle [normal|special]: cycles between scratchpads (optionally only normal or special ones) in the order they are defined in the configuration file.

  • previous: summon the last used scratchpad that is not currently active.

  • hide-all: hides all scratchpads, useful mostly when stacking multiple of them.

  • kill-all: closes all scratchpad clients that are open

  • reload: re-parses the configuration file without restarting the daemon.

  • get-config: prints out the parsed configuration.

  • kill: kills the hyprsctatch daemon

  • logs: show logs

Other Relevant information

To find the title needed for a scratchpad, run hyprctl clients and check the initialTitle field. An incorrect title results in the scratchpad not being hidden and a new one being spawned instead.

To group multiple scratchpads together, bind them to the same key and use stack on all of them.

Terminal applications often all use the title of the terminal emulator. Usually the title can be set with the --title flag to differentiate them.

If there are multiple scratchpads with the same initial title, this program just grabs the first one it finds.

Scratchpads don't have to be floating. This can also be used to just spawn a specific client, where the binding also hides it or grabs it from another workspace. Non-floating scratchpads are ignored by clean.

Dependencies

~6–15MB
~177K SLoC