@@ 0,0 1,269 @@
+/* Taken from https://github.com/djpohly/dwl/issues/466 */
+#define COLOR(hex) { ((hex >> 24) & 0xFF) / 255.0f, \
+ ((hex >> 16) & 0xFF) / 255.0f, \
+ ((hex >> 8) & 0xFF) / 255.0f, \
+ (hex & 0xFF) / 255.0f }
+/* appearance */
+static const int sloppyfocus = 0; /* focus follows mouse */
+static const int bypass_surface_visibility = 0; /* 1 means idle inhibitors will disable idle tracking even if it's surface isn't visible */
+static const unsigned int borderpx = 1; /* border pixel of windows */
+static const float rootcolor[] = COLOR(0x222222ff);
+static const float bordercolor[] = COLOR(0x444444ff);
+static const float focuscolor[] = COLOR(0x005577ff);
+static const float urgentcolor[] = COLOR(0xff0000ff);
+/* This conforms to the xdg-protocol. Set the alpha to zero to restore the old behavior */
+static const float fullscreen_bg[] = {0.1f, 0.1f, 0.1f, 1.0f}; /* You can also use glsl colors */
+
+enum {
+ PROGRAM_LAUNCHER,
+ SCRATCHPADS
+};
+const char *modes_labels[] = {
+ "launcher",
+ "scratchpads"
+};
+
+/* tagging - TAGCOUNT must be no greater than 31 */
+#define TAGCOUNT (9)
+
+/* logging */
+static int log_level = WLR_ERROR;
+
+static const Rule rules[] = {
+ /* app_id title tags mask isfloating isterm noswallow monitor scratchkey */
+ { "Alacritty", NULL, 0, 0, 1, 1, -1, 0 },
+ { "Alacritty", "scratchpad",0, 1, 0, 0, -1, 'a' },
+ { "kitty", NULL, 0, 0, 1, 1, -1, 0 },
+ { "foot", NULL, 0, 0, 1, 1, -1, 0 },
+ { "Spotify", NULL, 0, 1, 0, 0, -1, 's' },
+};
+
+/* layout(s) */
+static const Layout layouts[] = {
+ /* symbol arrange function */
+ { "[]=", tile },
+ { "><>", NULL }, /* no layout function means floating behavior */
+ { "[M]", monocle },
+ { "TTT", bstack },
+ { "|M|", centeredmaster }
+};
+
+/* monitors */
+/* NOTE: ALWAYS add a fallback rule, even if you are completely sure it won't be used */
+static const MonitorRule monrules[] = {
+ /* name scale rotate/reflect x y */
+ /* defaults */
+ { NULL, 1, WL_OUTPUT_TRANSFORM_NORMAL, -1, -1 },
+};
+
+static const TagRule tagrules[] = {
+ /* tag mfact nmaster layout */
+ { 9, 0.55, 1, &layouts[2] },
+ /* defaults */
+ { 0, 0.55, 1, &layouts[0] }
+};
+
+/* keyboard */
+/* static const struct xkb_rule_names xkb_rules = { */
+/* /\* can specify fields: rules, model, layout, variant, options *\/ */
+/* /\* example: */
+/* .options = "ctrl:nocaps", */
+/* *\/ */
+
+/* { */
+/* .layout = "us", */
+/* .options = "compose:ralt ctrl:nocaps grp:alt_shift_toggle" */
+/* }, */
+/* { */
+/* .layout = "cz", */
+/* .variant = "qwerty", */
+/* .options = "compose:ralt ctrl:nocaps grp:alt_shift_toggle" */
+/* }, */
+/* }; */
+
+static const struct xkb_rule_names xkb_rules = {
+ .layout = "us,cz",
+ .variant = ",qwerty",
+ .options = "compose:ralt,ctrl:nocaps,grp:alt_shift_toggle",
+};
+
+static const int repeat_rate = 25;
+static const int repeat_delay = 600;
+
+/* Trackpad */
+static const int tap_to_click = 1;
+static const int tap_and_drag = 1;
+static const int drag_lock = 1;
+static const int natural_scrolling = 1;
+static const int disable_while_typing = 1;
+static const int left_handed = 0;
+static const int middle_button_emulation = 0;
+/* You can choose between:
+LIBINPUT_CONFIG_SCROLL_NO_SCROLL
+LIBINPUT_CONFIG_SCROLL_2FG
+LIBINPUT_CONFIG_SCROLL_EDGE
+LIBINPUT_CONFIG_SCROLL_ON_BUTTON_DOWN
+*/
+static const enum libinput_config_scroll_method scroll_method = LIBINPUT_CONFIG_SCROLL_2FG;
+
+/* You can choose between:
+LIBINPUT_CONFIG_CLICK_METHOD_NONE
+LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS
+LIBINPUT_CONFIG_CLICK_METHOD_CLICKFINGER
+*/
+static const enum libinput_config_click_method click_method = LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS;
+
+/* You can choose between:
+LIBINPUT_CONFIG_SEND_EVENTS_ENABLED
+LIBINPUT_CONFIG_SEND_EVENTS_DISABLED
+LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE
+*/
+static const uint32_t send_events_mode = LIBINPUT_CONFIG_SEND_EVENTS_ENABLED;
+
+/* You can choose between:
+LIBINPUT_CONFIG_ACCEL_PROFILE_FLAT
+LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE
+*/
+static const enum libinput_config_accel_profile accel_profile = LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE;
+static const double accel_speed = 0.0;
+
+/* You can choose between:
+LIBINPUT_CONFIG_TAP_MAP_LRM -- 1/2/3 finger tap maps to left/right/middle
+LIBINPUT_CONFIG_TAP_MAP_LMR -- 1/2/3 finger tap maps to left/middle/right
+*/
+static const enum libinput_config_tap_button_map button_map = LIBINPUT_CONFIG_TAP_MAP_LRM;
+
+/* If you want to use the windows key for MODKEY, use WLR_MODIFIER_LOGO */
+#define MODKEY WLR_MODIFIER_LOGO
+
+#define TAGKEYS(KEY,TAG) \
+ { MODKEY, KEY, view, {.ui = 1 << TAG} }, \
+ { MODKEY|WLR_MODIFIER_CTRL, KEY, toggleview, {.ui = 1 << TAG} }, \
+ { MODKEY|WLR_MODIFIER_SHIFT, KEY, tag, {.ui = 1 << TAG} }, \
+ { MODKEY|WLR_MODIFIER_CTRL|WLR_MODIFIER_SHIFT,KEY,toggletag, {.ui = 1 << TAG} }
+
+/* helper for spawning shell commands in the pre dwm-5.0 fashion */
+#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
+
+/* commands */
+static const char *termcmd[] = { "alacritty", NULL };
+static const char *menucmd[] = { "rofi", "-show", "drun", NULL };
+
+/* named scratchpads - First arg only serves to match against key in rules*/
+static const char *scratchpadcmd_spotify[] = {
+ "s", "spotify", NULL,
+};
+
+static const char *scratchpadcmd_alacritty[] = {
+ "a", "alacritty", "-t", "scratchpad", NULL,
+};
+
+/* static const char *scratchpadcmd_notes[] = { */
+/* "a", "alacritty", "-t", "scratchpad", NULL, */
+/* }; */
+
+// BEWARE! Change the hardcoded nix store path!
+#define SEQUENCE_DETECTOR "sequence_detector -c $HOME/.config/dwl/sequence-detector.config.json "
+
+static const int monitor_order[] = { 3, 2, 1, 0 };
+#include "keys.h"
+static const Key keys[] = {
+ /* modifier key function argument */
+ { MODKEY, Key_semicolon, spawn, {.v = menucmd} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_Return, spawn, {.v = termcmd} },
+
+ { MODKEY, Key_j, focusstack, {.i = +1} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_j, movestack, {.i = +1} },
+ { MODKEY, Key_k, focusstack, {.i = -1} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_k, movestack, {.i = -1} },
+ { MODKEY, Key_comma, focusnthclient, {0} },
+ { MODKEY, Key_h, setmfact, {.f = -0.05f} },
+ { MODKEY, Key_l, setmfact, {.f = +0.05f} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_comma, incnmaster, {.i = +1} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_period, incnmaster, {.i = -1} },
+
+ { MODKEY, Key_Return, zoom, {0} },
+ { MODKEY, Key_Tab, view, {0} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_c, killclient, {0} },
+
+ { MODKEY, Key_t, setlayout, {.v = &layouts[0]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_t, setlayout, {.v = &layouts[3]} },
+ { MODKEY, Key_f, setlayout, {.v = &layouts[1]} },
+ { MODKEY, Key_m, setlayout, {.v = &layouts[2]} },
+ { MODKEY, Key_i, setlayout, {.v = &layouts[4]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_m, togglefullscreen, {0} },
+
+ { MODKEY, Key_space, setlayout, {0} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_space, togglefloating, {0} },
+
+ { MODKEY, Key_0, view, {.ui = ~0} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_0, tag, {.ui = ~0} },
+
+ { MODKEY, Key_q, focusnthmon, {.i = monitor_order[0]} },
+ { MODKEY, Key_w, focusnthmon, {.i = monitor_order[1]} },
+ { MODKEY, Key_e, focusnthmon, {.i = monitor_order[2]} },
+ { MODKEY, Key_r, focusnthmon, {.i = monitor_order[3]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_q, tagnthmon, {.i = monitor_order[0]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_w, tagnthmon, {.i = monitor_order[1]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_e, tagnthmon, {.i = monitor_order[2]} },
+ { MODKEY|WLR_MODIFIER_SHIFT, Key_r, tagnthmon, {.i = monitor_order[3]} },
+
+
+ TAGKEYS( Key_1, 0),
+ TAGKEYS( Key_2, 1),
+ TAGKEYS( Key_3, 2),
+ TAGKEYS( Key_4, 3),
+ TAGKEYS( Key_5, 4),
+ TAGKEYS( Key_6, 5),
+ TAGKEYS( Key_7, 6),
+ TAGKEYS( Key_8, 7),
+ TAGKEYS( Key_9, 8),
+
+ { 0, Key_XF86AudioStop, spawn, SHCMD(SEQUENCE_DETECTOR "-g mpris stop") },
+ { 0, Key_XF86AudioPause, spawn, SHCMD(SEQUENCE_DETECTOR "-g mpris pause") },
+ { 0, Key_XF86AudioPlay, spawn, SHCMD(SEQUENCE_DETECTOR "-g mpris play") },
+ { 0, Key_XF86AudioNext, spawn, SHCMD(SEQUENCE_DETECTOR "-g mpris next") },
+ { 0, Key_XF86AudioPrev, spawn, SHCMD(SEQUENCE_DETECTOR "-g mpris prev") },
+ { 0, Key_XF86MonBrightnessUp, spawn, SHCMD("$HOME/.config/dwl/scripts/brightness.sh up") },
+ { 0, Key_XF86MonBrightnessDown, spawn, SHCMD("$HOME/.config/dwl/scripts/brightness.sh down") },
+ { 0, Key_Print, spawn, SHCMD("$HOME/.config/dwl/scripts/print.sh -s") },
+
+ { MODKEY, Key_c, togglesticky, {0} },
+ { MODKEY, Key_s, entermode, {.i = SCRATCHPADS} },
+ { MODKEY, Key_a, entermode, {.i = PROGRAM_LAUNCHER} },
+
+ /* Ctrl-Alt-Backspace and Ctrl-Alt-Fx used to be handled by X server */
+ { MODKEY|WLR_MODIFIER_ALT, Key_q, quit, {0} },
+ /* Ctrl-Alt-Fx is used to switch to another VT, if you don't know what a VT is
+ * do not remove them.
+ */
+#define CHVT(KEY,n) { WLR_MODIFIER_CTRL|WLR_MODIFIER_ALT, KEY, chvt, {.ui = (n)} }
+ CHVT(Key_F1, 1), CHVT(Key_F2, 2), CHVT(Key_F3, 3), CHVT(Key_F4, 4),
+ CHVT(Key_F5, 5), CHVT(Key_F6, 6), CHVT(Key_F7, 7), CHVT(Key_F8, 8),
+ CHVT(Key_F9, 9), CHVT(Key_F10, 10), CHVT(Key_F11, 11), CHVT(Key_F12, 12),
+};
+
+#define EMACS(cmd) SHCMD("emacsclient -nc " cmd)
+static const Modekey modekeys[] = {
+ /* mode modifier key function argument */
+ { SCRATCHPADS, { 0, Key_s, focusortogglematchingscratch, {.v = scratchpadcmd_spotify} } },
+ { SCRATCHPADS, { 0, Key_s, entermode, {.i = NORMAL} } },
+ { SCRATCHPADS, { 0, Key_t, focusortogglematchingscratch, {.v = scratchpadcmd_alacritty} } },
+ { SCRATCHPADS, { 0, Key_t, entermode, {.i = NORMAL} } },
+ { SCRATCHPADS, { 0, Key_Escape, entermode, {.i = NORMAL} } },
+
+ { PROGRAM_LAUNCHER, { 0, Key_e, spawn, EMACS("")} },
+ { PROGRAM_LAUNCHER, { 0, Key_e, entermode, {.i = NORMAL} } },
+ { PROGRAM_LAUNCHER, { 0, Key_d, spawn, EMACS("--eval \"'(dired nil)\"")} },
+ { PROGRAM_LAUNCHER, { 0, Key_d, entermode, {.i = NORMAL} } },
+ { PROGRAM_LAUNCHER, { 0, Key_t, spawn, EMACS("--eval \"'(vterm)\"")} },
+ { PROGRAM_LAUNCHER, { 0, Key_t, entermode, {.i = NORMAL} } },
+
+ { PROGRAM_LAUNCHER, { 0, Key_Escape, entermode, {.i = NORMAL} } },
+};
+
+static const Button buttons[] = {
+ { MODKEY, BTN_LEFT, moveresize, {.ui = CurMove} },
+ { MODKEY, BTN_MIDDLE, togglefloating, {0} },
+ { MODKEY, BTN_RIGHT, moveresize, {.ui = CurResize} },
+};
@@ 0,0 1,237 @@
+// -*- mode: jsonc -*-
+[
+{
+ "ipc": true,
+ // "layer": "top", // Waybar at top layer
+ // "position": "bottom", // Waybar position (top|bottom|left|right)
+ "height": 20, // Waybar height (to be removed for auto height)
+ // "width": 1280, // Waybar width
+ "spacing": 4, // Gaps between modules (4px)
+ // Choose the order of the modules
+ "modules-left": [
+ "dwl/tags"
+ ],
+ "modules-center": [
+ "dwl/window"
+ ],
+ "modules-right": [
+ "mpd",
+ "idle_inhibitor",
+ //"pulseaudio",
+ "network",
+ "power-profiles-daemon",
+ "cpu",
+ "memory",
+ "temperature",
+ "backlight",
+ "keyboard-state",
+ "sway/language",
+ "battery",
+ "clock",
+ "tray"
+ ],
+ "dwl/tags": {
+ "num-tags": 9
+ },
+ "dwl/window": {
+ "format": "{title}",
+ "max-length": 50,
+ "rewrite": {
+ "(.*) - Mozilla Firefox": "🌎 $1",
+ "(.*) — Mozilla Firefox": "🌎 $1"
+ }
+ },
+ // Modules configuration
+ // "sway/workspaces": {
+ // "disable-scroll": true,
+ // "all-outputs": true,
+ // "warp-on-scroll": false,
+ // "format": "{name}: {icon}",
+ // "format-icons": {
+ // "1": "",
+ // "2": "",
+ // "3": "",
+ // "4": "",
+ // "5": "",
+ // "urgent": "",
+ // "focused": "",
+ // "default": ""
+ // }
+ // },
+ "keyboard-state": {
+ "numlock": true,
+ "capslock": true,
+ "format": "{name} {icon}",
+ "format-icons": {
+ "locked": "",
+ "unlocked": ""
+ }
+ },
+ "sway/mode": {
+ "format": "<span style=\"italic\">{}</span>"
+ },
+ "sway/scratchpad": {
+ "format": "{icon} {count}",
+ "show-empty": false,
+ "format-icons": ["", ""],
+ "tooltip": true,
+ "tooltip-format": "{app}: {title}"
+ },
+ "mpd": {
+ "format": "{stateIcon} {consumeIcon}{randomIcon}{repeatIcon}{singleIcon}{artist} - {album} - {title} ({elapsedTime:%M:%S}/{totalTime:%M:%S}) ⸨{songPosition}|{queueLength}⸩ {volume}% ",
+ "format-disconnected": "Disconnected ",
+ "format-stopped": "{consumeIcon}{randomIcon}{repeatIcon}{singleIcon}Stopped ",
+ "unknown-tag": "N/A",
+ "interval": 5,
+ "consume-icons": {
+ "on": " "
+ },
+ "random-icons": {
+ "off": "<span color=\"#f53c3c\"></span> ",
+ "on": " "
+ },
+ "repeat-icons": {
+ "on": " "
+ },
+ "single-icons": {
+ "on": "1 "
+ },
+ "state-icons": {
+ "paused": "",
+ "playing": ""
+ },
+ "tooltip-format": "MPD (connected)",
+ "tooltip-format-disconnected": "MPD (disconnected)"
+ },
+ "idle_inhibitor": {
+ "format": "{icon}",
+ "format-icons": {
+ "activated": "",
+ "deactivated": ""
+ }
+ },
+ "tray": {
+ // "icon-size": 21,
+ "spacing": 10
+ },
+ "clock": {
+ // "timezone": "America/New_York",
+ "interval": 1,
+ "tooltip-format": "<big>{:%Y %B}</big>\n<tt><small>{calendar}</small></tt>",
+ "format-alt": "{:%Y-%m-%d}",
+ "format": "{:%Y-%m-%d %H:%M:%S}"
+ },
+ "cpu": {
+ "format": "{usage}% ",
+ "tooltip": false
+ },
+ "memory": {
+ "format": "{}% "
+ },
+ "temperature": {
+ // "thermal-zone": 2,
+ // "hwmon-path": "/sys/class/hwmon/hwmon2/temp1_input",
+ "critical-threshold": 80,
+ // "format-critical": "{temperatureC}°C {icon}",
+ "format": "{temperatureC}°C {icon}",
+ "format-icons": ["", "", ""]
+ },
+ "backlight": {
+ // "device": "acpi_video1",
+ "format": "{percent}% {icon}",
+ "format-icons": ["", "", "", "", "", "", "", "", ""]
+ },
+ "battery": {
+ "states": {
+ // "good": 95,
+ "warning": 30,
+ "critical": 15
+ },
+ "format": "{capacity}% {icon}",
+ "format-full": "{capacity}% {icon}",
+ "format-charging": "{capacity}% ",
+ "format-plugged": "{capacity}% ",
+ "format-alt": "{time} {icon}",
+ // "format-good": "", // An empty format will hide the module
+ // "format-full": "",
+ "format-icons": ["", "", "", "", ""]
+ },
+ "battery#bat2": {
+ "bat": "BAT2"
+ },
+ "power-profiles-daemon": {
+ "format": "{icon}",
+ "tooltip-format": "Power profile: {profile}\nDriver: {driver}",
+ "tooltip": true,
+ "format-icons": {
+ "default": "",
+ "performance": "",
+ "balanced": "",
+ "power-saver": ""
+ }
+ },
+ "network": {
+ // "interface": "wlp2*", // (Optional) To force the use of this interface
+ "format-wifi": "{essid} ({signalStrength}%) ",
+ "format-ethernet": "{ipaddr}/{cidr} ",
+ "tooltip-format": "{ifname} via {gwaddr} ",
+ "format-linked": "{ifname} (No IP) ",
+ "format-disconnected": "Disconnected ⚠",
+ "format-alt": "{ifname}: {ipaddr}/{cidr}"
+ },
+ "pulseaudio": {
+ // "scroll-step": 1, // %, can be a float
+ "format": "{volume}% {icon} {format_source}",
+ "format-bluetooth": "{volume}% {icon} {format_source}",
+ "format-bluetooth-muted": " {icon} {format_source}",
+ "format-muted": " {format_source}",
+ "format-source": "{volume}% ",
+ "format-source-muted": "",
+ "format-icons": {
+ "headphone": "",
+ "hands-free": "",
+ "headset": "",
+ "phone": "",
+ "portable": "",
+ "car": "",
+ "default": ["", "", ""]
+ },
+ "on-click": "pavucontrol"
+ },
+ "custom/media": {
+ "format": "{icon} {}",
+ "return-type": "json",
+ "max-length": 40,
+ "format-icons": {
+ "spotify": "",
+ "default": "🎜"
+ },
+ "escape": true,
+ "exec": "$HOME/.config/waybar/mediaplayer.py 2> /dev/null" // Script in resources folder
+ // "exec": "$HOME/.config/waybar/mediaplayer.py --player spotify 2> /dev/null" // Filter player based on name
+ }
+}//,
+//{
+// "position": "bottom",
+// "modules-left": [
+// "wlr/taskbar"
+// ],
+// "wlr/taskbar": {
+// "format": "{icon}",
+// "icon-size": 14,
+// "icon-theme": "Numix-Circle",
+// "tooltip-format": "{title}",
+// "on-click": "activate",
+// "on-click-middle": "close",
+// "ignore-list": [
+// ],
+// "app_ids-mapping": {
+// "firefoxdeveloperedition": "firefox-developer-edition"
+// },
+// "rewrite": {
+// "Firefox Web Browser": "Firefox",
+// "Foot Server": "Terminal"
+// }
+// }
+// }
+]