From d0af9eca9e07decf3ede93b3ad869daaa04af65c Mon Sep 17 00:00:00 2001 From: Dmitry Voronin Date: Wed, 18 Dec 2024 13:16:41 +0300 Subject: [PATCH] Sway: Rewrite to replaceVars. --- home/file/sway/default.nix | 228 +++++++++++++++++++++--- home/file/sway/module/Display.conf | 9 +- home/file/sway/module/Font.conf | 10 +- home/file/sway/module/Input.conf | 85 +++++---- home/file/sway/module/Keyd.conf | 7 +- home/file/sway/module/Launcher.conf | 15 +- home/file/sway/module/Mod.conf | 11 +- home/file/sway/module/Mouse.conf | 11 +- home/file/sway/module/Navigation.conf | 29 ++- home/file/sway/module/Notification.conf | 13 +- home/file/sway/module/Resize.conf | 17 +- home/file/sway/module/ScratchPad.conf | 95 +++++----- home/file/sway/module/Screenshot.conf | 168 +---------------- home/file/sway/module/Session.conf | 10 -- home/file/sway/module/Sound.conf | 33 ++-- home/file/sway/module/Style.conf | 23 +-- home/file/sway/module/System.conf | 40 ++--- home/file/sway/module/Terminal.conf | 9 +- home/file/sway/module/Tiling.conf | 51 +++--- home/file/sway/module/TitleBar.conf | 18 +- home/file/sway/module/Waybar.conf | 9 +- home/file/sway/module/Workspace.conf | 65 ++++--- 22 files changed, 424 insertions(+), 532 deletions(-) delete mode 100644 home/file/sway/module/Session.conf diff --git a/home/file/sway/default.nix b/home/file/sway/default.nix index d5bac6f..ed816e2 100644 --- a/home/file/sway/default.nix +++ b/home/file/sway/default.nix @@ -1,4 +1,5 @@ { + __findFile, config, lib, pkgs, @@ -6,29 +7,208 @@ ... }: let - swayRcRaw = pkgs.writeText "sway-rc-raw" (util.readFiles [ - ./module/Mod.conf - ./module/Style.conf - ./module/Display.conf - ./module/Input.conf - ./module/Font.conf - ./module/Launcher.conf - ./module/Terminal.conf - ./module/TitleBar.conf - ./module/Navigation.conf - ./module/Notification.conf - ./module/Resize.conf - ./module/ScratchPad.conf - ./module/Screenshot.conf - ./module/Sound.conf - ./module/Tiling.conf - ./module/Workspace.conf - ./module/Session.conf - ./module/Keyd.conf - ./module/Waybar.conf - ./module/System.conf - ./module/Mouse.conf - ]); + fontName = config.module.style.font.sansSerif.name; + keyboardLayouts = config.module.keyboard.layouts; + keyboardOptions = config.module.keyboard.options; + + alpha = config.module.style.opacity.hex; + accent = config.module.style.color.accent + alpha; + border = config.module.style.color.border + alpha; + borderSize = config.module.style.window.border; + fg = config.module.style.color.fg.light; + wallpaper = config.module.wallpaper.path; + windowGap = config.module.style.window.gap; + + codec = "libsvtav1"; + color = config.module.style.color; + container = "mp4"; + format = "%Y-%m-%d_%H-%M-%S"; + framerate = 10; + opacity = "26"; + pixfmt = "yuv420p10le"; + selection = "slurp -d -b ${color.bg.light}${opacity} -c ${color.fg.light} -w 0 -s 00000000"; + + notifyStart = ''swayscript notify_short''; + notifyEnd = ''swayscript notify_long''; + picEdit = ''swappy -f - -o -''; + picFull = ''-o $(swaymsg -t get_outputs | jq -r ".[] | select(.focused) | .name") -''; + picPrepFile = prepFile "\${XDG_PICTURES_DIR[0]}" "png"; + picRefLatestFile = refLatestFile "png"; + picSelected = ''-g "''${scrSelection}" -''; + picToBuffer = ''wl-copy -t image/png''; + picToFile = ''tee "''${scrFile}"''; + screenshot = ''grim''; + updateWaybar = ''{ pkill -RTMIN+4 waybar; } & disown''; # NOTE: Might need to add a delay here if it becomes inconsistent one day. + vidFull = ''-o $(swaymsg -t get_outputs | jq -r ".[] | select(.focused) | .name") -''; + vidPrepFile = prepFile "\${XDG_VIDEOS_DIR[0]}" container; + vidRefLatestFile = refLatestFile container; + vidSelected = ''--geometry "''${scrSelection}"''; + vidStop = ''pkill -SIGINT wf-recorder''; + + prepFile = path: ext: '' + # Focused app id by default. + curWindow=$(parse_snake $(swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | .app_id')) + + # If no id (i.e. xwayland), then use a name (title). + [[ "''${curWindow}" = "null" ]] && curWindow=$(parse_snake $(swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | .name')) + + # If no app in focus, use "unknown" dir. + [[ "''${curWindow}" =~ ^[0-9]+$ ]] && curWindow="unknown" + + # Prepare dir and file path. + scrPath="${path}" + scrDir="${path}/''${curWindow}" + mkdir -p "''${scrDir}" + scrName="$(date +${format}).${ext}" + scrFile="''${scrDir}/''${scrName}" + scrLatestRef="./''${curWindow}/''${scrName}" + ''; + + refLatestFile = ext: '' + scrLatest="''${scrPath}/Latest.${ext}" + rm "''${scrLatest}" + ln -s "''${scrLatestRef}" "''${scrLatest}" + ''; + + getSelection = '' + scrSelection=$(${selection}) + [[ -n "''${scrSelection}" ]] || exit + ''; + + getTransform = '' + scrTransform="$(swaymsg -t get_outputs | jq -r '.[] | select(.focused) | .transform')" + [[ "''${scrTransform}" = "normal" ]] && scrTransform="" + ''; + + vidStart = '' + wf-recorder \ + --no-damage \ + --codec ${codec} \ + --file "''${scrFile}" \ + --framerate ${toString framerate} \ + --pixel-format ${pixfmt} \ + ''; + + vidMuxAudio = '' + ffmpeg \ + -f lavfi \ + -i anullsrc=channel_layout=stereo:sample_rate=44100 \ + -i "''${scrFile}" \ + -c:v copy \ + -c:a libopus \ + -shortest \ + -f ${container} \ + "''${scrFile}_" \ + && mv "''${scrFile}_" "''${scrFile}" \ + || rm "''${scrFile}_" + ''; + + vidTransform = '' + if [[ -n "''${scrTransform}" ]]; then + ffmpeg \ + -display_rotation ''${scrTransform} \ + -i "''${scrFile}" \ + -c copy \ + -f ${container} \ + "''${scrFile}_" \ + && mv "''${scrFile}_" "''${scrFile}" \ + || rm "''${scrFile}_" + fi + ''; + + SelectRecording = pkgs.writeShellScriptBin "SelectRecording" '' + ${vidStop} || { + ${getSelection} + ${getTransform} + ${vidPrepFile} + ${notifyStart} + ${updateWaybar} + ${vidStart} ${vidSelected} + ${notifyEnd} + ${updateWaybar} + ${vidMuxAudio} + ${vidTransform} + ${vidRefLatestFile} + }; + ''; + + FullscreenRecording = pkgs.writeShellScriptBin "FullscreenRecording" '' + ${vidStop} || { + ${getTransform} + ${vidPrepFile} + ${notifyStart} + ${updateWaybar} + ${vidStart} ${vidFull} + ${notifyEnd} + ${updateWaybar} + ${vidMuxAudio} + ${vidTransform} + ${vidRefLatestFile} + }; + ''; + + FullscreenScreenshot = pkgs.writeShellScriptBin "FullscreenScreenshot" '' + ${notifyEnd} + ${picPrepFile} + + ${screenshot} ${picFull} | ${picToFile} | ${picToBuffer} + ${picRefLatestFile} + ''; + + SelectScreenshot = pkgs.writeShellScriptBin "SelectScreenshot" '' + ${getSelection} + ${notifyStart} + ${picPrepFile} + + ${screenshot} ${picSelected} | ${picEdit} | ${picToFile} | ${picToBuffer} + ${notifyEnd} + ${picRefLatestFile} + ''; + + swayRcRaw = pkgs.writeText "sway-rc-raw" ( + util.readFiles [ + ./module/Mod.conf + ./module/Style.conf + ./module/Display.conf + ./module/Input.conf + ./module/Font.conf + ./module/Launcher.conf + ./module/Terminal.conf + ./module/TitleBar.conf + ./module/Navigation.conf + ./module/Notification.conf + ./module/Resize.conf + ./module/ScratchPad.conf + ./module/Screenshot.conf + ./module/Sound.conf + ./module/Tiling.conf + ./module/Workspace.conf + ./module/Keyd.conf + ./module/Waybar.conf + ./module/System.conf + ./module/Mouse.conf + ] + ); + + swayRc = (pkgs.replaceVars swayRcRaw { + inherit + FullscreenRecording + FullscreenScreenshot + SelectRecording + SelectScreenshot + accent + border + borderSize + fg + fontName + keyboardLayouts + keyboardOptions + wallpaper + windowGap + ; + }).overrideAttrs (old: { + doCheck = false; + }); in { text = @@ -36,6 +216,6 @@ in # Read `man 5 sway` for a complete reference. include /etc/sway/config.d/* '' - + swayRc + + builtins.readFile swayRc + lib.concatStringsSep "\n" config.module.sway.extraConfig; } diff --git a/home/file/sway/module/Display.conf b/home/file/sway/module/Display.conf index 94f33b7..501173b 100644 --- a/home/file/sway/module/Display.conf +++ b/home/file/sway/module/Display.conf @@ -1,7 +1,2 @@ -{ ... }: -{ - text = '' - # You can get the names of your outputs by running: swaymsg -t get_outputs - output * scale 1 - ''; -} +# You can get the names of your outputs by running: swaymsg -t get_outputs +output * scale 1 diff --git a/home/file/sway/module/Font.conf b/home/file/sway/module/Font.conf index d8d80a3..bf38d5c 100644 --- a/home/file/sway/module/Font.conf +++ b/home/file/sway/module/Font.conf @@ -1,9 +1 @@ -{ config, ... }: -let - fontName = config.module.style.font.sansSerif.name; -in -{ - text = '' - font "${fontName} Medium 0.01" - ''; -} +font "@fontName@ Medium 0.01" diff --git a/home/file/sway/module/Input.conf b/home/file/sway/module/Input.conf index bb0bd12..98c5bc4 100644 --- a/home/file/sway/module/Input.conf +++ b/home/file/sway/module/Input.conf @@ -1,47 +1,42 @@ -{ config, ... }: -{ - text = '' - ### Input configuration - # - # Example configuration: - # - # input "2:14:SynPS/2_Synaptics_TouchPad" { - # dwt enabled - # tap enabled - # natural_scroll enabled - # middle_emulation enabled - # } - # - # You can get the names of your inputs by running: swaymsg -t get_inputs - # Read `man 5 sway-input` for more information about this section. +### Input configuration +# +# Example configuration: +# +# input "2:14:SynPS/2_Synaptics_TouchPad" { +# dwt enabled +# tap enabled +# natural_scroll enabled +# middle_emulation enabled +# } +# +# You can get the names of your inputs by running: swaymsg -t get_inputs +# Read `man 5 sway-input` for more information about this section. - input type:pointer { - accel_profile flat - pointer_accel 0 - dwt enabled - tap enabled - natural_scroll enabled - middle_emulation enabled - } - - input type:touchpad { - accel_profile flat - pointer_accel 0 - dwt enabled - tap enabled - natural_scroll enabled - middle_emulation enabled - } - - input type:keyboard { - xkb_layout ${config.module.keyboard.layouts} - xkb_options ${config.module.keyboard.options} - } - - # Hide mouse cursor after a period of inactivity. - seat seat0 hide_cursor 5000 - - # Per-window languages. - exec swaykbdd - ''; +input type:pointer { + accel_profile flat + pointer_accel 0 + dwt enabled + tap enabled + natural_scroll enabled + middle_emulation enabled } + +input type:touchpad { + accel_profile flat + pointer_accel 0 + dwt enabled + tap enabled + natural_scroll enabled + middle_emulation enabled +} + +input type:keyboard { + xkb_layout @keyboardLayouts@ + xkb_options @keyboardOptions@ +} + +# Hide mouse cursor after a period of inactivity. +seat seat0 hide_cursor 5000 + +# Per-window languages. +exec swaykbdd diff --git a/home/file/sway/module/Keyd.conf b/home/file/sway/module/Keyd.conf index 7429d2e..0671610 100644 --- a/home/file/sway/module/Keyd.conf +++ b/home/file/sway/module/Keyd.conf @@ -1,6 +1 @@ -{ ... }: -{ - text = '' - exec keyd-application-mapper -d - ''; -} +exec keyd-application-mapper -d diff --git a/home/file/sway/module/Launcher.conf b/home/file/sway/module/Launcher.conf index 82b9949..7a08fda 100644 --- a/home/file/sway/module/Launcher.conf +++ b/home/file/sway/module/Launcher.conf @@ -1,11 +1,6 @@ -{ ... }: -{ - text = '' - # Application launcher. - # Note: pass the final command to swaymsg so that the resulting window can be opened - # on the original workspace that the command was run on. - set $menu fuzzel +# Application launcher. +# Note: pass the final command to swaymsg so that the resulting window can be opened +# on the original workspace that the command was run on. +set $menu fuzzel - bindsym $mod+space exec $menu - ''; -} +bindsym $mod+space exec $menu diff --git a/home/file/sway/module/Mod.conf b/home/file/sway/module/Mod.conf index 9041bf1..0b69a89 100644 --- a/home/file/sway/module/Mod.conf +++ b/home/file/sway/module/Mod.conf @@ -1,8 +1,3 @@ -{ ... }: -{ - text = '' - # Meta key. Use Mod1 for Alt. - set $mod Mod4 - set $sysmod print - ''; -} +# Meta key. Use Mod1 for Alt. +set $mod Mod4 +set $sysmod print diff --git a/home/file/sway/module/Mouse.conf b/home/file/sway/module/Mouse.conf index cb5c66f..95bb60b 100644 --- a/home/file/sway/module/Mouse.conf +++ b/home/file/sway/module/Mouse.conf @@ -1,8 +1,3 @@ -{ ... }: -{ - text = '' - bindsym --whole-window $mod+button2 kill - bindsym --whole-window $mod+button8 floating toggle - bindsym --whole-window $mod+button9 fullscreen - ''; -} +bindsym --whole-window $mod+button2 kill +bindsym --whole-window $mod+button8 floating toggle +bindsym --whole-window $mod+button9 fullscreen diff --git a/home/file/sway/module/Navigation.conf b/home/file/sway/module/Navigation.conf index 361eb27..8af5bed 100644 --- a/home/file/sway/module/Navigation.conf +++ b/home/file/sway/module/Navigation.conf @@ -1,19 +1,14 @@ -{ ... }: -{ - text = '' - # Move focus. - bindsym --to-code $mod+a focus left - bindsym --to-code $mod+d focus right - bindsym --to-code $mod+s focus down - bindsym --to-code $mod+w focus up +# Move focus. +bindsym --to-code $mod+a focus left +bindsym --to-code $mod+d focus right +bindsym --to-code $mod+s focus down +bindsym --to-code $mod+w focus up - # Move the focused window. - bindsym --to-code $mod+Shift+a move left - bindsym --to-code $mod+Shift+d move right - bindsym --to-code $mod+Shift+s move down - bindsym --to-code $mod+Shift+w move up +# Move the focused window. +bindsym --to-code $mod+Shift+a move left +bindsym --to-code $mod+Shift+d move right +bindsym --to-code $mod+Shift+s move down +bindsym --to-code $mod+Shift+w move up - # Focus mouse following. - focus_follows_mouse yes - ''; -} +# Focus mouse following. +focus_follows_mouse yes diff --git a/home/file/sway/module/Notification.conf b/home/file/sway/module/Notification.conf index 928e8fd..159e88f 100644 --- a/home/file/sway/module/Notification.conf +++ b/home/file/sway/module/Notification.conf @@ -1,10 +1,5 @@ -{ ... }: -{ - text = '' - # Show last notification. - bindsym --to-code $mod+shift+n exec makoctl restore +# Show last notification. +bindsym --to-code $mod+shift+n exec makoctl restore - # Hide all notifications. - bindsym --to-code $mod+n exec makoctl dismiss --all - ''; -} +# Hide all notifications. +bindsym --to-code $mod+n exec makoctl dismiss --all diff --git a/home/file/sway/module/Resize.conf b/home/file/sway/module/Resize.conf index d26e8f7..04a74a1 100644 --- a/home/file/sway/module/Resize.conf +++ b/home/file/sway/module/Resize.conf @@ -1,13 +1,4 @@ -{ ... }: -let - stepHorizontal = 10; - stepVertical = 10; -in -{ - text = '' - bindsym --to-code $mod+j resize grow height ${toString stepVertical}px - bindsym --to-code $mod+k resize shrink height ${toString stepVertical}px - bindsym --to-code $mod+h resize shrink width ${toString stepHorizontal}px - bindsym --to-code $mod+l resize grow width ${toString stepHorizontal}px - ''; -} +bindsym --to-code $mod+j resize grow height 10px +bindsym --to-code $mod+k resize shrink height 10px +bindsym --to-code $mod+h resize shrink width 10px +bindsym --to-code $mod+l resize grow width 10px diff --git a/home/file/sway/module/ScratchPad.conf b/home/file/sway/module/ScratchPad.conf index dd4496e..73eb4af 100644 --- a/home/file/sway/module/ScratchPad.conf +++ b/home/file/sway/module/ScratchPad.conf @@ -1,53 +1,48 @@ -{ ... }: -{ - text = '' - # Sway has a "scratchpad", which is a bag of holding for windows. - # You can send windows there and get them back later. - # NOTE: Get id with `swaymsg -t get_tree`. +# Sway has a "scratchpad", which is a bag of holding for windows. +# You can send windows there and get them back later. +# NOTE: Get id with `swaymsg -t get_tree`. - # Show the next scratchpad window or hide the focused scratchpad window. - # If there are multiple scratchpad windows, this command cycles through them. - bindsym --to-code $mod+c scratchpad show - bindsym --to-code $mod+shift+C move scratchpad - bindsym --to-code $mod+shift+X exec swayscript scratchpad_kill +# Show the next scratchpad window or hide the focused scratchpad window. +# If there are multiple scratchpad windows, this command cycles through them. +bindsym --to-code $mod+c scratchpad show +bindsym --to-code $mod+shift+C move scratchpad +bindsym --to-code $mod+shift+X exec swayscript scratchpad_kill - # Fix for a goddamn Firefox WebRTC indicator. - for_window [app_id="firefox" title="Firefox — Sharing Indicator"] { - kill - } - - # NetworkManager. - for_window [app_id="nm-connection-editor"] { - move scratchpad - scratchpad show - } - - # Bluetooth. - for_window [app_id=".blueman-manager-wrapped"] { - move scratchpad - scratchpad show - } - - # Sound. - for_window [app_id="pavucontrol"] { - move scratchpad - scratchpad show - } - - # Android emulator controls. - for_window [title="Emulator" window_type="utility"] { - move scratchpad - } - - # Calculator. - for_window [app_id="org.gnome.Calculator"] { - move scratchpad - scratchpad show - } - - # JamesDsp. - for_window [title="JamesDSP for Linux"] { - move scratchpad - } - ''; +# Fix for a goddamn Firefox WebRTC indicator. +for_window [app_id="firefox" title="Firefox — Sharing Indicator"] { + kill +} + +# NetworkManager. +for_window [app_id="nm-connection-editor"] { + move scratchpad + scratchpad show +} + +# Bluetooth. +for_window [app_id=".blueman-manager-wrapped"] { + move scratchpad + scratchpad show +} + +# Sound. +for_window [app_id="pavucontrol"] { + move scratchpad + scratchpad show +} + +# Android emulator controls. +for_window [title="Emulator" window_type="utility"] { + move scratchpad +} + +# Calculator. +for_window [app_id="org.gnome.Calculator"] { + move scratchpad + scratchpad show +} + +# JamesDsp. +for_window [title="JamesDSP for Linux"] { + move scratchpad } diff --git a/home/file/sway/module/Screenshot.conf b/home/file/sway/module/Screenshot.conf index 984c704..8dd3981 100644 --- a/home/file/sway/module/Screenshot.conf +++ b/home/file/sway/module/Screenshot.conf @@ -1,165 +1,5 @@ -{ - __findFile, - config, - lib, - pkgs, - ... -}: -let - codec = "libsvtav1"; - color = config.module.style.color; - container = "mp4"; - format = "%Y-%m-%d_%H-%M-%S"; - framerate = 10; - opacity = "26"; - pixfmt = "yuv420p10le"; - selection = "slurp -d -b ${color.bg.light}${opacity} -c ${color.fg.light} -w 0 -s 00000000"; -in -{ - text = - let - notifyStart = ''swayscript notify_short''; - notifyEnd = ''swayscript notify_long''; - picEdit = ''swappy -f - -o -''; - picFull = ''-o $(swaymsg -t get_outputs | jq -r ".[] | select(.focused) | .name") -''; - picPrepFile = prepFile "\${XDG_PICTURES_DIR[0]}" "png"; - picRefLatestFile = refLatestFile "png"; - picSelected = ''-g "''${scrSelection}" -''; - picToBuffer = ''wl-copy -t image/png''; - picToFile = ''tee "''${scrFile}"''; - screenshot = ''grim''; - updateWaybar = ''{ pkill -RTMIN+4 waybar; } & disown''; # NOTE: Might need to add a delay here if it becomes inconsistent one day. - vidFull = ''-o $(swaymsg -t get_outputs | jq -r ".[] | select(.focused) | .name") -''; - vidPrepFile = prepFile "\${XDG_VIDEOS_DIR[0]}" container; - vidRefLatestFile = refLatestFile container; - vidSelected = ''--geometry "''${scrSelection}"''; - vidStop = ''pkill -SIGINT wf-recorder''; +bindsym --to-code $mod+y exec @FullscreenScreenshot@/bin/FullscreenScreenshot} +bindsym --to-code $mod+shift+y exec @FullscreenRecording@/bin/FullscreenRecording} - prepFile = path: ext: '' - # Focused app id by default. - curWindow=$(parse_snake $(swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | .app_id')) - - # If no id (i.e. xwayland), then use a name (title). - [[ "''${curWindow}" = "null" ]] && curWindow=$(parse_snake $(swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | .name')) - - # If no app in focus, use "unknown" dir. - [[ "''${curWindow}" =~ ^[0-9]+$ ]] && curWindow="unknown" - - # Prepare dir and file path. - scrPath="${path}" - scrDir="${path}/''${curWindow}" - mkdir -p "''${scrDir}" - scrName="$(date +${format}).${ext}" - scrFile="''${scrDir}/''${scrName}" - scrLatestRef="./''${curWindow}/''${scrName}" - ''; - - refLatestFile = ext: '' - scrLatest="''${scrPath}/Latest.${ext}" - rm "''${scrLatest}" - ln -s "''${scrLatestRef}" "''${scrLatest}" - ''; - - getSelection = '' - scrSelection=$(${selection}) - [[ -n "''${scrSelection}" ]] || exit - ''; - - getTransform = '' - scrTransform="$(swaymsg -t get_outputs | jq -r '.[] | select(.focused) | .transform')" - [[ "''${scrTransform}" = "normal" ]] && scrTransform="" - ''; - - vidStart = '' - wf-recorder \ - --no-damage \ - --codec ${codec} \ - --file "''${scrFile}" \ - --framerate ${toString framerate} \ - --pixel-format ${pixfmt} \ - ''; - - vidMuxAudio = '' - ffmpeg \ - -f lavfi \ - -i anullsrc=channel_layout=stereo:sample_rate=44100 \ - -i "''${scrFile}" \ - -c:v copy \ - -c:a libopus \ - -shortest \ - -f ${container} \ - "''${scrFile}_" \ - && mv "''${scrFile}_" "''${scrFile}" \ - || rm "''${scrFile}_" - ''; - - vidTransform = '' - if [[ -n "''${scrTransform}" ]]; then - ffmpeg \ - -display_rotation ''${scrTransform} \ - -i "''${scrFile}" \ - -c copy \ - -f ${container} \ - "''${scrFile}_" \ - && mv "''${scrFile}_" "''${scrFile}" \ - || rm "''${scrFile}_" - fi - ''; - - SelectRecording = pkgs.writeShellScriptBin "SelectRecording" '' - ${vidStop} || { - ${getSelection} - ${getTransform} - ${vidPrepFile} - ${notifyStart} - ${updateWaybar} - ${vidStart} ${vidSelected} - ${notifyEnd} - ${updateWaybar} - ${vidMuxAudio} - ${vidTransform} - ${vidRefLatestFile} - }; - ''; - - FullscreenRecording = pkgs.writeShellScriptBin "FullscreenRecording" '' - ${vidStop} || { - ${getTransform} - ${vidPrepFile} - ${notifyStart} - ${updateWaybar} - ${vidStart} ${vidFull} - ${notifyEnd} - ${updateWaybar} - ${vidMuxAudio} - ${vidTransform} - ${vidRefLatestFile} - }; - ''; - - FullscreenScreenshot = pkgs.writeShellScriptBin "FullscreenScreenshot" '' - ${notifyEnd} - ${picPrepFile} - - ${screenshot} ${picFull} | ${picToFile} | ${picToBuffer} - ${picRefLatestFile} - ''; - - SelectScreenshot = pkgs.writeShellScriptBin "SelectScreenshot" '' - ${getSelection} - ${notifyStart} - ${picPrepFile} - - ${screenshot} ${picSelected} | ${picEdit} | ${picToFile} | ${picToBuffer} - ${notifyEnd} - ${picRefLatestFile} - ''; - in - '' - bindsym --to-code $mod+y exec ${lib.getExe FullscreenScreenshot} - bindsym --to-code $mod+shift+y exec ${lib.getExe FullscreenRecording} - - bindsym --to-code $mod+v exec ${lib.getExe SelectScreenshot} - bindsym --to-code $mod+shift+v exec ${lib.getExe SelectRecording} - ''; -} +bindsym --to-code $mod+v exec @SelectScreenshot@/bin/SelectScreenshot} +bindsym --to-code $mod+shift+v exec @SelectRecording@/bin/SelectRecording} diff --git a/home/file/sway/module/Session.conf b/home/file/sway/module/Session.conf deleted file mode 100644 index 3f174eb..0000000 --- a/home/file/sway/module/Session.conf +++ /dev/null @@ -1,10 +0,0 @@ -{ config, ... }: -let - lock = "swaylock -f -F -c 000000 -k --font \"${config.module.style.font.serif.name}\" --font-size ${toString config.module.style.font.size.desktop}"; -in -{ - text = '' - bindsym --to-code $mod+z exec '_twice 1 ${lock}' - bindsym --to-code $mod+Shift+Z exec _twice 1 bash -c '${lock}; systemctl suspend -i' - ''; -} diff --git a/home/file/sway/module/Sound.conf b/home/file/sway/module/Sound.conf index 90a6488..36fc144 100644 --- a/home/file/sway/module/Sound.conf +++ b/home/file/sway/module/Sound.conf @@ -1,22 +1,13 @@ -{ ... }: -let - step_music = 10; - step_volume = 5; -in -{ - text = '' - bindsym XF86AudioRaiseVolume exec 'pactl set-sink-volume @DEFAULT_SINK@ +${toString step_volume}%' - bindsym XF86AudioLowerVolume exec 'pactl set-sink-volume @DEFAULT_SINK@ -${toString step_volume}%' - bindsym XF86AudioMute exec 'pactl set-sink-mute @DEFAULT_SINK@ toggle' - bindsym XF86AudioMicMute exec 'pactl set-source-mute @DEFAULT_SOURCE@ toggle' +bindsym XF86AudioRaiseVolume exec 'pactl set-sink-volume @DEFAULT_SINK@ +5%' +bindsym XF86AudioLowerVolume exec 'pactl set-sink-volume @DEFAULT_SINK@ -5%' +bindsym XF86AudioMute exec 'pactl set-sink-mute @DEFAULT_SINK@ toggle' +bindsym XF86AudioMicMute exec 'pactl set-source-mute @DEFAULT_SOURCE@ toggle' - bindsym XF86AudioPlay exec 'playerctl play-pause' - bindsym XF86AudioPause exec 'playerctl pause' - bindsym XF86AudioStop exec 'playerctl stop' - bindsym XF86AudioNext exec 'playerctl next' - bindsym XF86AudioPrev exec 'playerctl previous' - bindsym XF86Forward exec 'playerctl position ${toString step_music}+' - bindsym XF86Back exec 'playerctl position ${toString step_music}-' - bindsym XF86Eject exec 'swayscript sound_output_cycle' - ''; -} +bindsym XF86AudioPlay exec 'playerctl play-pause' +bindsym XF86AudioPause exec 'playerctl pause' +bindsym XF86AudioStop exec 'playerctl stop' +bindsym XF86AudioNext exec 'playerctl next' +bindsym XF86AudioPrev exec 'playerctl previous' +bindsym XF86Forward exec 'playerctl position 10+' +bindsym XF86Back exec 'playerctl position 10-' +bindsym XF86Eject exec 'swayscript sound_output_cycle' diff --git a/home/file/sway/module/Style.conf b/home/file/sway/module/Style.conf index 04e92d8..15a5904 100644 --- a/home/file/sway/module/Style.conf +++ b/home/file/sway/module/Style.conf @@ -1,17 +1,6 @@ -{ config, ... }: -let - accent = config.module.style.color.accent + alpha; - alpha = config.module.style.opacity.hex; - border = config.module.style.color.border + alpha; - fg = config.module.style.color.fg.light; -in -{ - text = '' - output * bg ${config.module.wallpaper.path} fill - client.focused "#${accent}" "#${accent}" "#${fg}" "#${accent}" "#${accent}" - client.focused_inactive "#${border}" "#${border}" "#${fg}" "#${border}" "#${border}" - client.unfocused "#${border}" "#${border}" "#${fg}" "#${border}" "#${border}" - client.urgent "#${border}" "#${border}" "#${fg}" "#${border}" "#${border}" - client.placeholder "#${border}" "#${border}" "#${fg}" "#${border}" "#${border}" - ''; -} +output * bg @wallpaper@ fill +client.focused "#@accent@" "#@accent@" "#@fg@" "#@accent@" "#@accent@" +client.focused_inactive "#@border@" "#@border@" "#@fg@" "#@border@" "#@border@" +client.unfocused "#@border@" "#@border@" "#@fg@" "#@border@" "#@border@" +client.urgent "#@border@" "#@border@" "#@fg@" "#@border@" "#@border@" +client.placeholder "#@border@" "#@border@" "#@fg@" "#@border@" "#@border@" diff --git a/home/file/sway/module/System.conf b/home/file/sway/module/System.conf index e536b8b..d98bd3b 100644 --- a/home/file/sway/module/System.conf +++ b/home/file/sway/module/System.conf @@ -1,25 +1,17 @@ -{ ... }: -let - brstep = 5; -in -{ - text = '' - bindsym $sysmod input * xkb_switch_layout 0 - bindsym --to-code $sysmod+a exec 'swayscript network' - bindsym --to-code $sysmod+c exec 'systemctl reboot -i' - bindsym --to-code $sysmod+d exec 'swayscript dnd' - bindsym --to-code $sysmod+g exec 'swayscript gaming' - bindsym --to-code $sysmod+l exec 'powerlimit toggle' - bindsym --to-code $sysmod+m exec 'swayscript monitor' - bindsym --to-code $sysmod+p exec 'powersave toggle' - bindsym --to-code $sysmod+r exec 'swayscript reload' - bindsym --to-code $sysmod+v exec 'swayscript vpn' - bindsym --to-code $sysmod+x exec 'systemctl poweroff -i' - bindsym --to-code $sysmod+z exec 'systemctl suspend -i' +bindsym $sysmod input * xkb_switch_layout 0 +bindsym --to-code $sysmod+a exec 'swayscript network' +bindsym --to-code $sysmod+c exec 'systemctl reboot -i' +bindsym --to-code $sysmod+d exec 'swayscript dnd' +bindsym --to-code $sysmod+g exec 'swayscript gaming' +bindsym --to-code $sysmod+l exec 'powerlimit toggle' +bindsym --to-code $sysmod+m exec 'swayscript monitor' +bindsym --to-code $sysmod+p exec 'powersave toggle' +bindsym --to-code $sysmod+r exec 'swayscript reload' +bindsym --to-code $sysmod+v exec 'swayscript vpn' +bindsym --to-code $sysmod+x exec 'systemctl poweroff -i' +bindsym --to-code $sysmod+z exec 'systemctl suspend -i' - bindsym --to-code $sysmod+w exec light -A ${toString brstep} - bindsym XF86MonBrightnessUp exec light -A ${toString brstep} - bindsym --to-code $sysmod+s exec light -U ${toString brstep} - bindsym XF86MonBrightnessDown exec light -U ${toString brstep} - ''; -} +bindsym --to-code $sysmod+w exec light -A 5 +bindsym XF86MonBrightnessUp exec light -A 5 +bindsym --to-code $sysmod+s exec light -U 5 +bindsym XF86MonBrightnessDown exec light -U 5 diff --git a/home/file/sway/module/Terminal.conf b/home/file/sway/module/Terminal.conf index c7cd357..47b5775 100644 --- a/home/file/sway/module/Terminal.conf +++ b/home/file/sway/module/Terminal.conf @@ -1,8 +1,3 @@ -{ ... }: -{ - text = '' - set $term foot +set $term foot - bindsym --to-code $mod+Escape exec $term -e bash -i -c "tmux new-session -A -s $USER; bash -i" - ''; -} +bindsym --to-code $mod+Escape exec $term -e bash -i -c "tmux new-session -A -s $USER; bash -i" diff --git a/home/file/sway/module/Tiling.conf b/home/file/sway/module/Tiling.conf index a8f57ac..2f1a150 100644 --- a/home/file/sway/module/Tiling.conf +++ b/home/file/sway/module/Tiling.conf @@ -1,36 +1,31 @@ -{ config, ... }: -{ - text = '' - # Toggle tiling. - bindsym --to-code $mod+shift+f floating toggle +# Toggle tiling. +bindsym --to-code $mod+shift+f floating toggle - # Swap focus between the tiling area and the floating area - bindsym --to-code $mod+r focus mode_toggle +# Swap focus between the tiling area and the floating area +bindsym --to-code $mod+r focus mode_toggle - # Split directions. - bindsym --to-code $mod+backslash splith - bindsym --to-code $mod+minus splitv +# Split directions. +bindsym --to-code $mod+backslash splith +bindsym --to-code $mod+minus splitv - # Switch the current container between different layout styles. - bindsym --to-code $mod+Tab layout toggle split tabbed +# Switch the current container between different layout styles. +bindsym --to-code $mod+Tab layout toggle split tabbed - # Fullscreen. - bindsym --to-code $mod+f fullscreen +# Fullscreen. +bindsym --to-code $mod+f fullscreen - # Drag floating windows by holding down $mod and left mouse button. - # Resize them with right mouse button + $mod. - # Despite the name, also works for non-floating windows. - # Change normal to inverse to use left mouse button for resizing and right - # mouse button for dragging. - floating_modifier $mod normal +# Drag floating windows by holding down $mod and left mouse button. +# Resize them with right mouse button + $mod. +# Despite the name, also works for non-floating windows. +# Change normal to inverse to use left mouse button for resizing and right +# mouse button for dragging. +floating_modifier $mod normal - # Kill focused window. - bindsym --to-code $mod+x kill +# Kill focused window. +bindsym --to-code $mod+x kill - # Add gaps. - gaps inner ${toString config.module.style.window.gap} +# Add gaps. +gaps inner @windowGap@ - # Launch everything tiled. - # for_window [all] floating disable - ''; -} +# Launch everything tiled. +# for_window [all] floating disable diff --git a/home/file/sway/module/TitleBar.conf b/home/file/sway/module/TitleBar.conf index a639738..a61bf32 100644 --- a/home/file/sway/module/TitleBar.conf +++ b/home/file/sway/module/TitleBar.conf @@ -1,13 +1,5 @@ -{ config, ... }: -let - borderSize = toString config.module.style.window.border; -in -{ - text = '' - # Disable title bar. - default_border pixel ${borderSize} - default_floating_border pixel ${borderSize} - titlebar_padding 1 - titlebar_border_thickness 0 - ''; -} +# Disable title bar. +default_border pixel @borderSize@ +default_floating_border pixel @borderSize@ +titlebar_padding 1 +titlebar_border_thickness 0 diff --git a/home/file/sway/module/Waybar.conf b/home/file/sway/module/Waybar.conf index e895e76..3cf4617 100644 --- a/home/file/sway/module/Waybar.conf +++ b/home/file/sway/module/Waybar.conf @@ -1,7 +1,2 @@ -{ ... }: -{ - text = '' - bindsym --to-code $mod+shift+r exec 'pkill waybar || exec waybar' - exec waybar - ''; -} +bindsym --to-code $mod+shift+r exec 'pkill waybar || exec waybar' +exec waybar diff --git a/home/file/sway/module/Workspace.conf b/home/file/sway/module/Workspace.conf index da9e393..9bece5d 100644 --- a/home/file/sway/module/Workspace.conf +++ b/home/file/sway/module/Workspace.conf @@ -1,38 +1,33 @@ -{ ... }: -{ - text = '' - # Switch to workspace. - bindsym --to-code $mod+1 workspace number 1 - bindsym --to-code $mod+2 workspace number 2 - bindsym --to-code $mod+3 workspace number 3 - bindsym --to-code $mod+4 workspace number 4 - bindsym --to-code $mod+5 workspace number 5 - bindsym --to-code $mod+6 workspace number 6 - bindsym --to-code $mod+7 workspace number 7 - bindsym --to-code $mod+8 workspace number 8 - bindsym --to-code $mod+9 workspace number 9 - bindsym --to-code $mod+0 workspace number 10 +# Switch to workspace. +bindsym --to-code $mod+1 workspace number 1 +bindsym --to-code $mod+2 workspace number 2 +bindsym --to-code $mod+3 workspace number 3 +bindsym --to-code $mod+4 workspace number 4 +bindsym --to-code $mod+5 workspace number 5 +bindsym --to-code $mod+6 workspace number 6 +bindsym --to-code $mod+7 workspace number 7 +bindsym --to-code $mod+8 workspace number 8 +bindsym --to-code $mod+9 workspace number 9 +bindsym --to-code $mod+0 workspace number 10 - # Move focused container to workspace. - bindsym --to-code $mod+Shift+1 move container to workspace number 1 - bindsym --to-code $mod+Shift+2 move container to workspace number 2 - bindsym --to-code $mod+Shift+3 move container to workspace number 3 - bindsym --to-code $mod+Shift+4 move container to workspace number 4 - bindsym --to-code $mod+Shift+5 move container to workspace number 5 - bindsym --to-code $mod+Shift+6 move container to workspace number 6 - bindsym --to-code $mod+Shift+7 move container to workspace number 7 - bindsym --to-code $mod+Shift+8 move container to workspace number 8 - bindsym --to-code $mod+Shift+9 move container to workspace number 9 - bindsym --to-code $mod+Shift+0 move container to workspace number 10 - # Note: workspaces can have any name you want, not just numbers. - # We just use 1-10 as the default. +# Move focused container to workspace. +bindsym --to-code $mod+Shift+1 move container to workspace number 1 +bindsym --to-code $mod+Shift+2 move container to workspace number 2 +bindsym --to-code $mod+Shift+3 move container to workspace number 3 +bindsym --to-code $mod+Shift+4 move container to workspace number 4 +bindsym --to-code $mod+Shift+5 move container to workspace number 5 +bindsym --to-code $mod+Shift+6 move container to workspace number 6 +bindsym --to-code $mod+Shift+7 move container to workspace number 7 +bindsym --to-code $mod+Shift+8 move container to workspace number 8 +bindsym --to-code $mod+Shift+9 move container to workspace number 9 +bindsym --to-code $mod+Shift+0 move container to workspace number 10 +# Note: workspaces can have any name you want, not just numbers. +# We just use 1-10 as the default. - # Switch left-right. - bindsym --to-code $mod+e workspace next - bindsym --to-code $mod+q workspace prev +# Switch left-right. +bindsym --to-code $mod+e workspace next +bindsym --to-code $mod+q workspace prev - # Move left-right. - bindsym --to-code $mod+Shift+e move container to workspace next - bindsym --to-code $mod+Shift+q move container to workspace prev - ''; -} +# Move left-right. +bindsym --to-code $mod+Shift+e move container to workspace next +bindsym --to-code $mod+Shift+q move container to workspace prev