Compare commits
8 Commits
e9eb8cc17a
...
a680781cc4
Author | SHA1 | Date |
---|---|---|
Nathan McCarty | a680781cc4 | |
Nathan McCarty | d902a12c56 | |
Nathan McCarty | 71adb46aab | |
Nathan McCarty | 0a17179443 | |
Nathan McCarty | aa126bb930 | |
Nathan McCarty | 6a7b831507 | |
Nathan McCarty | bbc3fd250b | |
Nathan McCarty | 5c045618d4 |
66
flake.lock
66
flake.lock
|
@ -176,8 +176,12 @@
|
||||||
},
|
},
|
||||||
"hyprland": {
|
"hyprland": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"hyprland-protocols": "hyprland-protocols",
|
"hyprland-protocols": [
|
||||||
"nixpkgs": "nixpkgs_2",
|
"hyprland-protocols"
|
||||||
|
],
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
"wlroots": "wlroots",
|
"wlroots": "wlroots",
|
||||||
"xdph": "xdph"
|
"xdph": "xdph"
|
||||||
},
|
},
|
||||||
|
@ -197,7 +201,7 @@
|
||||||
},
|
},
|
||||||
"hyprland-contrib": {
|
"hyprland-contrib": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": "nixpkgs_3"
|
"nixpkgs": "nixpkgs_2"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1687033460,
|
"lastModified": 1687033460,
|
||||||
|
@ -216,7 +220,6 @@
|
||||||
"hyprland-protocols": {
|
"hyprland-protocols": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"hyprland",
|
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -480,22 +483,6 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_2": {
|
"nixpkgs_2": {
|
||||||
"locked": {
|
|
||||||
"lastModified": 1688500189,
|
|
||||||
"narHash": "sha256-djYYiY4lzJOlXOnTHytH6BUugrxHDZjuGxTSrU4gt4M=",
|
|
||||||
"owner": "NixOS",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"rev": "78419edadf0fabbe5618643bd850b2f2198ed060",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "NixOS",
|
|
||||||
"ref": "nixos-unstable",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs_3": {
|
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1658161305,
|
"lastModified": 1658161305,
|
||||||
"narHash": "sha256-X/nhnMCa1Wx4YapsspyAs6QYz6T/85FofrI6NpdPDHg=",
|
"narHash": "sha256-X/nhnMCa1Wx4YapsspyAs6QYz6T/85FofrI6NpdPDHg=",
|
||||||
|
@ -511,7 +498,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_4": {
|
"nixpkgs_3": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1688566749,
|
"lastModified": 1688566749,
|
||||||
"narHash": "sha256-3Og5xbNk1qncLWl2zrrL/k80UqRI/nEGPEbzz306Izk=",
|
"narHash": "sha256-3Og5xbNk1qncLWl2zrrL/k80UqRI/nEGPEbzz306Izk=",
|
||||||
|
@ -527,7 +514,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_5": {
|
"nixpkgs_4": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1667292599,
|
"lastModified": 1667292599,
|
||||||
"narHash": "sha256-7ISOUI1aj6UKMPIL+wwthENL22L3+A9V+jS8Is3QsRo=",
|
"narHash": "sha256-7ISOUI1aj6UKMPIL+wwthENL22L3+A9V+jS8Is3QsRo=",
|
||||||
|
@ -543,7 +530,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_6": {
|
"nixpkgs_5": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1667085676,
|
"lastModified": 1667085676,
|
||||||
"narHash": "sha256-jPHYYoSdrV3ypWG4oi9SUeI2MU6dLjxM88+9io5Rrx0=",
|
"narHash": "sha256-jPHYYoSdrV3ypWG4oi9SUeI2MU6dLjxM88+9io5Rrx0=",
|
||||||
|
@ -636,23 +623,25 @@
|
||||||
"home-manager": "home-manager",
|
"home-manager": "home-manager",
|
||||||
"hyprland": "hyprland",
|
"hyprland": "hyprland",
|
||||||
"hyprland-contrib": "hyprland-contrib",
|
"hyprland-contrib": "hyprland-contrib",
|
||||||
|
"hyprland-protocols": "hyprland-protocols",
|
||||||
"idris2": "idris2",
|
"idris2": "idris2",
|
||||||
"java": "java",
|
"java": "java",
|
||||||
"nix-on-droid": "nix-on-droid",
|
"nix-on-droid": "nix-on-droid",
|
||||||
"nixos-generators": "nixos-generators",
|
"nixos-generators": "nixos-generators",
|
||||||
"nixos-hardware": "nixos-hardware",
|
"nixos-hardware": "nixos-hardware",
|
||||||
"nixpkgs": "nixpkgs_4",
|
"nixpkgs": "nixpkgs_3",
|
||||||
"nixpkgs-unstable": "nixpkgs-unstable",
|
"nixpkgs-unstable": "nixpkgs-unstable",
|
||||||
"quilt-server": "quilt-server",
|
"quilt-server": "quilt-server",
|
||||||
"scripts": "scripts",
|
"scripts": "scripts",
|
||||||
"sops-nix": "sops-nix",
|
"sops-nix": "sops-nix",
|
||||||
"wsl": "wsl"
|
"wsl": "wsl",
|
||||||
|
"xdph": "xdph_2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils_4",
|
"flake-utils": "flake-utils_4",
|
||||||
"nixpkgs": "nixpkgs_5",
|
"nixpkgs": "nixpkgs_4",
|
||||||
"swaywm-toggler": "swaywm-toggler"
|
"swaywm-toggler": "swaywm-toggler"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
|
@ -694,7 +683,7 @@
|
||||||
"swaywm-toggler": {
|
"swaywm-toggler": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils_5",
|
"flake-utils": "flake-utils_5",
|
||||||
"nixpkgs": "nixpkgs_6"
|
"nixpkgs": "nixpkgs_5"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1667366374,
|
"lastModified": 1667366374,
|
||||||
|
@ -835,6 +824,29 @@
|
||||||
"repo": "xdg-desktop-portal-hyprland",
|
"repo": "xdg-desktop-portal-hyprland",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"xdph_2": {
|
||||||
|
"inputs": {
|
||||||
|
"hyprland-protocols": [
|
||||||
|
"hyprland-protocols"
|
||||||
|
],
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1685385764,
|
||||||
|
"narHash": "sha256-r+XMyOoRXq+hlfjayb+fyi9kq2JK48TrwuNIAXqlj7U=",
|
||||||
|
"owner": "hyprwm",
|
||||||
|
"repo": "xdg-desktop-portal-hyprland",
|
||||||
|
"rev": "4d9ff0c17716936e0b5ca577a39e263633901ed1",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "hyprwm",
|
||||||
|
"repo": "xdg-desktop-portal-hyprland",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"root": "root",
|
"root": "root",
|
||||||
|
|
15
flake.nix
15
flake.nix
|
@ -9,7 +9,20 @@
|
||||||
url = "github:nix-community/home-manager/release-23.05";
|
url = "github:nix-community/home-manager/release-23.05";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
hyprland.url = "github:hyprwm/Hyprland";
|
hyprland-protocols = {
|
||||||
|
url = "github:hyprwm/hyprland-protocols";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
hyprland = {
|
||||||
|
url = "github:hyprwm/Hyprland";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
inputs.hyprland-protocols.follows = "hyprland-protocols";
|
||||||
|
};
|
||||||
|
xdph = {
|
||||||
|
url = "github:hyprwm/xdg-desktop-portal-hyprland";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
inputs.hyprland-protocols.follows = "hyprland-protocols";
|
||||||
|
};
|
||||||
hyprland-contrib.url = "github:hyprwm/contrib";
|
hyprland-contrib.url = "github:hyprwm/contrib";
|
||||||
nix-on-droid = {
|
nix-on-droid = {
|
||||||
url = "github:t184256/nix-on-droid";
|
url = "github:t184256/nix-on-droid";
|
||||||
|
|
|
@ -6,12 +6,7 @@ let
|
||||||
shortcuts = inputs.self.packages.${pkgs.system}.shortcuts;
|
shortcuts = inputs.self.packages.${pkgs.system}.shortcuts;
|
||||||
in lib.mkMerge [
|
in lib.mkMerge [
|
||||||
# Hyprland specific configuration
|
# Hyprland specific configuration
|
||||||
(lib.mkIf hyprland {
|
(lib.mkIf hyprland { })
|
||||||
wayland.windowManager.hyprland.extraConfig = ''
|
|
||||||
env = QT_QPA_PLATFORMTHEME,qtct
|
|
||||||
env = QT_STYLE_OVERRIDE,kvantum
|
|
||||||
'';
|
|
||||||
})
|
|
||||||
# General configuration
|
# General configuration
|
||||||
(lib.mkIf hyprland {
|
(lib.mkIf hyprland {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
|
|
|
@ -1,5 +1,13 @@
|
||||||
{ config, lib, pkgs, inputs, ... }@args:
|
{ config, lib, pkgs, inputs, ... }@args:
|
||||||
let nathan = config.nathan;
|
let
|
||||||
|
nathan = config.nathan;
|
||||||
|
portal =
|
||||||
|
inputs.xdph.packages.${pkgs.stdenv.hostPlatform.system}.xdg-desktop-portal-hyprland.override {
|
||||||
|
hyprland-share-picker =
|
||||||
|
inputs.xdph.packages.${pkgs.stdenv.hostPlatform.system}.hyprland-share-picker.override {
|
||||||
|
hyprland = config.wayland.windowManager.hyprland.package;
|
||||||
|
};
|
||||||
|
};
|
||||||
in with lib; {
|
in with lib; {
|
||||||
imports = [
|
imports = [
|
||||||
./desktop/waybar.nix
|
./desktop/waybar.nix
|
||||||
|
@ -34,248 +42,276 @@ in with lib; {
|
||||||
recommendedEnvironment = true;
|
recommendedEnvironment = true;
|
||||||
systemdIntegration = false;
|
systemdIntegration = false;
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
# Set environment variables to force wayland
|
# import home manager session variables
|
||||||
env = XCURSOR_SIZE,24
|
${lib.concatStringsSep "\n" (builtins.attrValues
|
||||||
# env = GDK_BACKEND,wayland,x11
|
(builtins.mapAttrs (name: value: "env = ${name},${value}")
|
||||||
# env = QT_QPA_PLATFORM,wayland;xcb
|
config.home.sessionVariables))}
|
||||||
# env = SDL_VIDEODRIVER,wayland
|
|
||||||
# env = CLUTTER_BACKEND,wayland
|
|
||||||
input {
|
|
||||||
kb_layout = us
|
|
||||||
kb_variant =
|
|
||||||
kb_model =
|
|
||||||
kb_options =
|
|
||||||
kb_rules =
|
|
||||||
follow_mouse = 1
|
|
||||||
}
|
|
||||||
|
|
||||||
general {
|
# Setup missing XDG variables
|
||||||
# See https://wiki.hyprland.org/Configuring/Variables/ for more
|
# env = XDG_SESSION_TYPE,wayland
|
||||||
gaps_in = 5
|
# env = XDG_SESSION_DESKTOP,Hyprland
|
||||||
gaps_out = 10
|
|
||||||
border_size = 3
|
|
||||||
col.active_border = rgba(3fc5b7ee) rgba(70b433ee) 45deg
|
|
||||||
col.inactive_border = rgba(252525aa)
|
|
||||||
layout = dwindle
|
|
||||||
}
|
|
||||||
decoration {
|
|
||||||
rounding = 10
|
|
||||||
blur = true
|
|
||||||
blur_size = 3
|
|
||||||
blur_passes = 1
|
|
||||||
blur_new_optimizations = true
|
|
||||||
drop_shadow = true
|
|
||||||
shadow_range = 4
|
|
||||||
shadow_render_power = 3
|
|
||||||
col.shadow = rgba(181818ee)
|
|
||||||
}
|
|
||||||
|
|
||||||
animations {
|
# Make applications respect wayland
|
||||||
enabled = true;
|
env = GDK_BACKEND,wayland,x11
|
||||||
bezier = myBezier, 0.05, 0.9, 0.1, 1.05
|
env = QT_QPA_PLATFORM,wayland;xcb
|
||||||
animation = windows, 1, 7, myBezier
|
env = SDL_VIDEODRIVER,wayland
|
||||||
animation = windowsOut, 1, 7, default, popin 80%
|
env = CLUTTER_BACKEND,wayland
|
||||||
animation = border, 1, 10, default
|
|
||||||
animation = borderangle, 1, 8, default
|
|
||||||
animation = fade, 1, 7, default
|
|
||||||
animation = workspaces, 1, 6, default
|
|
||||||
}
|
|
||||||
|
|
||||||
dwindle {
|
# Make sure only the hyprland desktop portal is available
|
||||||
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
|
env = XDG_DESKTOP_PORTAL_DIR,${portal}/share/xdg-desktop-portal/portals
|
||||||
pseudotile = true # master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
|
|
||||||
preserve_split = true # you probably want this
|
|
||||||
}
|
|
||||||
|
|
||||||
master {
|
input {
|
||||||
new_is_master = false
|
kb_layout = us
|
||||||
}
|
kb_variant =
|
||||||
|
kb_model =
|
||||||
|
kb_options =
|
||||||
|
kb_rules =
|
||||||
|
follow_mouse = 1
|
||||||
|
}
|
||||||
|
|
||||||
gestures {
|
general {
|
||||||
workspace_swipe = false
|
# See https://wiki.hyprland.org/Configuring/Variables/ for more
|
||||||
}
|
gaps_in = 5
|
||||||
|
gaps_out = 10
|
||||||
|
border_size = 3
|
||||||
|
col.active_border = rgba(3fc5b7ee) rgba(70b433ee) 45deg
|
||||||
|
col.inactive_border = rgba(252525aa)
|
||||||
|
layout = dwindle
|
||||||
|
}
|
||||||
|
decoration {
|
||||||
|
rounding = 10
|
||||||
|
blur = true
|
||||||
|
blur_size = 3
|
||||||
|
blur_passes = 1
|
||||||
|
blur_new_optimizations = true
|
||||||
|
drop_shadow = true
|
||||||
|
shadow_range = 4
|
||||||
|
shadow_render_power = 3
|
||||||
|
col.shadow = rgba(181818ee)
|
||||||
|
}
|
||||||
|
|
||||||
bind = SUPER, Q, exec, alacritty
|
animations {
|
||||||
bind = SUPER, C, killactive,
|
enabled = true;
|
||||||
# bind = SUPER, M, exit,
|
bezier = myBezier, 0.05, 0.9, 0.1, 1.05
|
||||||
bind = SUPER, E, exec, dolphin
|
animation = windows, 1, 7, myBezier
|
||||||
bind = SUPER, V, togglefloating,
|
animation = windowsOut, 1, 7, default, popin 80%
|
||||||
bind = SUPER, P, pseudo, # dwindle
|
animation = border, 1, 10, default
|
||||||
bind = SUPER, B, togglesplit, # dwindle
|
animation = borderangle, 1, 8, default
|
||||||
|
animation = fade, 1, 7, default
|
||||||
|
animation = workspaces, 1, 6, default
|
||||||
|
}
|
||||||
|
|
||||||
# Maximize
|
dwindle {
|
||||||
bind = SUPER, A, fullscreen, 1
|
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
|
||||||
bind = SUPER SHIFT, A, fullscreen, 0
|
pseudotile = true # master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
|
||||||
|
preserve_split = true # you probably want this
|
||||||
|
}
|
||||||
|
|
||||||
# Move focus with mainMod + arrow keys
|
master {
|
||||||
bind = SUPER, H, movefocus, l
|
new_is_master = false
|
||||||
bind = SUPER, L, movefocus, r
|
}
|
||||||
bind = SUPER, K, movefocus, u
|
|
||||||
bind = SUPER, K, layoutmsg, focusnext
|
|
||||||
bind = SUPER, J, movefocus, d
|
|
||||||
bind = SUPER, J, layoutmsg, focusprev
|
|
||||||
|
|
||||||
# Move windows with mainMod + arrow keys
|
gestures {
|
||||||
bind = SUPER SHIFT, H, movewindow, l
|
workspace_swipe = false
|
||||||
bind = SUPER SHIFT, L, movewindow, r
|
}
|
||||||
bind = SUPER SHIFT, K, movewindow, u
|
|
||||||
bind = SUPER SHIFT, K, layoutmsg, swapnext
|
|
||||||
bind = SUPER SHIFT, J, movewindow, d
|
|
||||||
bind = SUPER SHIFT, J, layoutmsg, swapprev
|
|
||||||
|
|
||||||
# Switch layouts with a mode
|
bind = SUPER, Q, exec, alacritty
|
||||||
bind = SUPER, S, submap, layout
|
bind = SUPER, C, killactive,
|
||||||
submap=layout
|
# bind = SUPER, M, exit,
|
||||||
# dwindle
|
bind = SUPER, E, exec, dolphin
|
||||||
bind = , A, exec, hyprctl keyword general:layout dwindle
|
bind = SUPER, V, togglefloating,
|
||||||
bind = , A, submap, reset
|
bind = SUPER, P, pseudo, # dwindle
|
||||||
# master
|
bind = SUPER, B, togglesplit, # dwindle
|
||||||
bind = , S, exec, hyprctl keyword general:layout master
|
|
||||||
bind = , S, submap, reset
|
|
||||||
submap = reset
|
|
||||||
|
|
||||||
# Switch workspaces with mainMod + [0-9]
|
# Maximize
|
||||||
bind = SUPER, 1, workspace, 1
|
bind = SUPER, A, fullscreen, 1
|
||||||
bind = SUPER, 2, workspace, 2
|
bind = SUPER SHIFT, A, fullscreen, 0
|
||||||
bind = SUPER, 3, workspace, 3
|
|
||||||
bind = SUPER, 4, workspace, 4
|
|
||||||
bind = SUPER, 5, workspace, 5
|
|
||||||
bind = SUPER, 6, workspace, 6
|
|
||||||
bind = SUPER, 7, workspace, 7
|
|
||||||
bind = SUPER, 8, workspace, 8
|
|
||||||
bind = SUPER, 9, workspace, 9
|
|
||||||
bind = SUPER, 0, workspace, 10
|
|
||||||
|
|
||||||
# Move active window to a workspace with mainMod + SHIFT + [0-9]
|
# Move focus with mainMod + arrow keys
|
||||||
bind = SUPER SHIFT, 1, movetoworkspace, 1
|
bind = SUPER, H, movefocus, l
|
||||||
bind = SUPER SHIFT, 2, movetoworkspace, 2
|
bind = SUPER, L, movefocus, r
|
||||||
bind = SUPER SHIFT, 3, movetoworkspace, 3
|
bind = SUPER, K, movefocus, u
|
||||||
bind = SUPER SHIFT, 4, movetoworkspace, 4
|
bind = SUPER, K, layoutmsg, focusnext
|
||||||
bind = SUPER SHIFT, 5, movetoworkspace, 5
|
bind = SUPER, J, movefocus, d
|
||||||
bind = SUPER SHIFT, 6, movetoworkspace, 6
|
bind = SUPER, J, layoutmsg, focusprev
|
||||||
bind = SUPER SHIFT, 7, movetoworkspace, 7
|
|
||||||
bind = SUPER SHIFT, 8, movetoworkspace, 8
|
|
||||||
bind = SUPER SHIFT, 9, movetoworkspace, 9
|
|
||||||
bind = SUPER SHIFT, 0, movetoworkspace, 10
|
|
||||||
|
|
||||||
# Scroll through existing workspaces with mainMod + scroll
|
# Move windows with mainMod + arrow keys
|
||||||
bind = SUPER, mouse_down, workspace, e+1
|
bind = SUPER SHIFT, H, movewindow, l
|
||||||
bind = SUPER, mouse_up, workspace, e-1
|
bind = SUPER SHIFT, L, movewindow, r
|
||||||
|
bind = SUPER SHIFT, K, movewindow, u
|
||||||
|
bind = SUPER SHIFT, K, layoutmsg, swapnext
|
||||||
|
bind = SUPER SHIFT, J, movewindow, d
|
||||||
|
bind = SUPER SHIFT, J, layoutmsg, swapprev
|
||||||
|
|
||||||
# Move/resize windows with mainMod + LMB/RMB and dragging
|
# Switch layouts with a mode
|
||||||
bindm = SUPER, mouse:272, movewindow
|
bind = SUPER, S, submap, layout
|
||||||
bindm = SUPER, mouse:273, resizewindow
|
submap=layout
|
||||||
|
# dwindle
|
||||||
|
bind = , A, exec, hyprctl keyword general:layout dwindle
|
||||||
|
bind = , A, submap, reset
|
||||||
|
# master
|
||||||
|
bind = , S, exec, hyprctl keyword general:layout master
|
||||||
|
bind = , S, submap, reset
|
||||||
|
submap = reset
|
||||||
|
|
||||||
# Media key binds
|
# Switch workspaces with mainMod + [0-9]
|
||||||
bind = , xf86audioraisevolume, exec, swayosd --output-volume=raise
|
bind = SUPER, 1, workspace, 1
|
||||||
bind = SHIFT, xf86audioraisevolume, exec, swayosd --output-volume=+2
|
bind = SUPER, 2, workspace, 2
|
||||||
bind = , xf86audiolowervolume, exec, swayosd --output-volume=lower
|
bind = SUPER, 3, workspace, 3
|
||||||
bind = SHIFT, xf86audiolowervolume, exec, swayosd --output-volume=-2
|
bind = SUPER, 4, workspace, 4
|
||||||
bind = , xf86audiomute, exec, swayosd --output-volume mute-toggle
|
bind = SUPER, 5, workspace, 5
|
||||||
bind = , xf86audioplay, exec, playerctl play-pause
|
bind = SUPER, 6, workspace, 6
|
||||||
bind = , xf86audionext, exec, playerctl next
|
bind = SUPER, 7, workspace, 7
|
||||||
|
bind = SUPER, 8, workspace, 8
|
||||||
|
bind = SUPER, 9, workspace, 9
|
||||||
|
bind = SUPER, 0, workspace, 10
|
||||||
|
|
||||||
# Screenshots
|
# Move active window to a workspace with mainMod + SHIFT + [0-9]
|
||||||
bind = , print, exec, grimblast --scale 1 copysave area ~/Pictures/Screenshots/$(date -Iseconds).png
|
bind = SUPER SHIFT, 1, movetoworkspace, 1
|
||||||
bind = SHIFT, print, exec, grimblast --scale 1 copysave output ~/Pictures/Screenshots/$(date -Iseconds).png
|
bind = SUPER SHIFT, 2, movetoworkspace, 2
|
||||||
|
bind = SUPER SHIFT, 3, movetoworkspace, 3
|
||||||
|
bind = SUPER SHIFT, 4, movetoworkspace, 4
|
||||||
|
bind = SUPER SHIFT, 5, movetoworkspace, 5
|
||||||
|
bind = SUPER SHIFT, 6, movetoworkspace, 6
|
||||||
|
bind = SUPER SHIFT, 7, movetoworkspace, 7
|
||||||
|
bind = SUPER SHIFT, 8, movetoworkspace, 8
|
||||||
|
bind = SUPER SHIFT, 9, movetoworkspace, 9
|
||||||
|
bind = SUPER SHIFT, 0, movetoworkspace, 10
|
||||||
|
|
||||||
# Caps lock indicator
|
# Scroll through existing workspaces with mainMod + scroll
|
||||||
bindr = CAPS, caps_lock, exec, swayosd --caps-lock
|
bind = SUPER, mouse_down, workspace, e+1
|
||||||
|
bind = SUPER, mouse_up, workspace, e-1
|
||||||
|
|
||||||
# systemd integration
|
# Move/resize windows with mainMod + LMB/RMB and dragging
|
||||||
exec-once=dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY HYPRLAND_INSTANCE_SIGNATURE XDG_CURRENT_DESKTOP && sleep 2 && systemctl --user start hyprland-session.target
|
bindm = SUPER, mouse:272, movewindow
|
||||||
|
bindm = SUPER, mouse:273, resizewindow
|
||||||
|
|
||||||
|
# Media key binds
|
||||||
|
bind = , xf86audioraisevolume, exec, swayosd --output-volume=raise
|
||||||
|
bind = SHIFT, xf86audioraisevolume, exec, swayosd --output-volume=+2
|
||||||
|
bind = , xf86audiolowervolume, exec, swayosd --output-volume=lower
|
||||||
|
bind = SHIFT, xf86audiolowervolume, exec, swayosd --output-volume=-2
|
||||||
|
bind = , xf86audiomute, exec, swayosd --output-volume mute-toggle
|
||||||
|
bind = , xf86audioplay, exec, playerctl play-pause
|
||||||
|
bind = , xf86audionext, exec, playerctl next
|
||||||
|
|
||||||
## Window rules
|
# Screenshots
|
||||||
|
bind = , print, exec, grimblast --scale 1 copysave area ~/Pictures/Screenshots/$(date -Iseconds).png
|
||||||
|
bind = SHIFT, print, exec, grimblast --scale 1 copysave output ~/Pictures/Screenshots/$(date -Iseconds).png
|
||||||
|
|
||||||
# Gamescope - vmware
|
# Caps lock indicator
|
||||||
windowrulev2 = float,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
bindr = CAPS, caps_lock, exec, swayosd --caps-lock
|
||||||
windowrulev2 = noborder,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
|
||||||
windowrulev2 = rounding 0,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
|
||||||
|
|
||||||
# Bluetooth manager
|
# systemd integration
|
||||||
windowrulev2 = float,class:^(.blueman-manager-wrapped)$
|
exec-once=dbus-update-activation-environment --systemd ${
|
||||||
windowrulev2 = center,class:^(.blueman-manager-wrapped)$
|
lib.concatStringsSep " " ([
|
||||||
|
"DISPLAY"
|
||||||
|
"WAYLAND_DISPLAY"
|
||||||
|
"HYPRLAND_INSTANCE_SIGNATURE"
|
||||||
|
"XDG_CURRENT_DESKTOP"
|
||||||
|
"XDG_SESSION_TYPE"
|
||||||
|
"XDG_SESSION_DESKTOP"
|
||||||
|
"XDG_DESKTOP_PORTAL_DIR"
|
||||||
|
"XDG_BACKEND"
|
||||||
|
"GDK_BACKEND"
|
||||||
|
"QT_QPA_PLATFORM"
|
||||||
|
"SDL_VIDEODRIVER"
|
||||||
|
"CLUTTER_BACKEND"
|
||||||
|
] ++ builtins.attrNames config.home.sessionVariables)
|
||||||
|
} && sleep 2 && systemctl --user start hyprland-session.target
|
||||||
|
|
||||||
# firefox Picture-in-Picture
|
## Window rules
|
||||||
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
|
||||||
windowrulev2 = float,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
|
||||||
windowrulev2 = pin,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
|
||||||
|
|
||||||
# firefox bitwarden
|
# Gamescope - vmware
|
||||||
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
windowrulev2 = float,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
||||||
windowrulev2 = float,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
windowrulev2 = noborder,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
||||||
windowrulev2 = pin,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
windowrulev2 = rounding 0,class:^(.gamescope-wrapped)$,title:VMware Workstation
|
||||||
|
|
||||||
# firefox figma micro indicator
|
# Bluetooth manager
|
||||||
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Firefox — Sharing Indicator)$
|
windowrulev2 = float,class:^(.blueman-manager-wrapped)$
|
||||||
windowrulev2 = float,class^(firefox-beta)$,title:^(Firefox — Sharing Indicator)$
|
windowrulev2 = center,class:^(.blueman-manager-wrapped)$
|
||||||
|
|
||||||
# Common modals
|
# firefox Picture-in-Picture
|
||||||
windowrule = float,title:^(Open)$
|
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
||||||
windowrule = center,title:^(Open)$
|
windowrulev2 = float,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
||||||
windowrule = float,title:^(Choose Files)$
|
windowrulev2 = pin,class^(firefox-beta)$,title:^(Picture-in-Picture)$
|
||||||
windowrule = center,title:^(Choose Files)$
|
|
||||||
windowrule = float,title:^(Save As)$
|
|
||||||
windowrule = center,title:^(Save As)$
|
|
||||||
windowrule = float,title:^(Confirm to replace files)$
|
|
||||||
windowrule = center,title:^(Confirm to replace files)$
|
|
||||||
windowrule = float,title:^(File Operation Progress)$
|
|
||||||
windowrule = center,title:^(File Operation Progress)$
|
|
||||||
windowrulev2 = float,class:^(google-chrome)$,title:^(Open Files)$
|
|
||||||
windowrulev2 = center,class:^(google-chrome)$,title:^(Open Files)$
|
|
||||||
windowrulev2 = float,class:^(google-chrome)$,title:^(Open File)$
|
|
||||||
windowrulev2 = center,class:^(google-chrome)$,title:^(Open File)$
|
|
||||||
|
|
||||||
# Pavucontrol
|
# firefox bitwarden
|
||||||
windowrule = center,pavucontrol
|
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
||||||
windowrule = float,pavucontrol
|
windowrulev2 = float,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
||||||
|
windowrulev2 = pin,class^(firefox-beta)$,title:^(Extension: Bitwarden)
|
||||||
|
|
||||||
# Emacs streaming
|
# firefox figma micro indicator
|
||||||
windowrulev2 = float,title:^(emacs-streaming)$
|
windowrulev2 = nofullscreenrequest,class^(firefox-beta)$,title:^(Firefox — Sharing Indicator)$
|
||||||
|
windowrulev2 = float,class^(firefox-beta)$,title:^(Firefox — Sharing Indicator)$
|
||||||
|
|
||||||
## Scratchpads
|
# Common modals
|
||||||
|
windowrule = float,title:^(Open)$
|
||||||
|
windowrule = center,title:^(Open)$
|
||||||
|
windowrule = float,title:^(Choose Files)$
|
||||||
|
windowrule = center,title:^(Choose Files)$
|
||||||
|
windowrule = float,title:^(Save As)$
|
||||||
|
windowrule = center,title:^(Save As)$
|
||||||
|
windowrule = float,title:^(Confirm to replace files)$
|
||||||
|
windowrule = center,title:^(Confirm to replace files)$
|
||||||
|
windowrule = float,title:^(File Operation Progress)$
|
||||||
|
windowrule = center,title:^(File Operation Progress)$
|
||||||
|
windowrulev2 = float,class:^(google-chrome)$,title:^(Open Files)$
|
||||||
|
windowrulev2 = center,class:^(google-chrome)$,title:^(Open Files)$
|
||||||
|
windowrulev2 = float,class:^(google-chrome)$,title:^(Open File)$
|
||||||
|
windowrulev2 = center,class:^(google-chrome)$,title:^(Open File)$
|
||||||
|
|
||||||
# Alacritty
|
# Pavucontrol
|
||||||
bind = SUPER ALT, Q, exec, pypr toggle term
|
windowrule = center,pavucontrol
|
||||||
$dropterm = ^(alacritty-dropterm)$
|
windowrule = float,pavucontrol
|
||||||
windowrule = float,$dropterm
|
|
||||||
windowrule = size 40% 50%,$dropterm
|
|
||||||
windowrule = workspace special silent,$dropterm
|
|
||||||
windowrule = center,$dropterm
|
|
||||||
|
|
||||||
# Emacs
|
# Emacs streaming
|
||||||
bind = SUPER ALT, W, exec, pypr toggle emacs
|
windowrulev2 = float,title:^(emacs-streaming)$
|
||||||
$scratchmacs = title:^(scratchmacs)$
|
|
||||||
windowrulev2 = float,$scratchmacs
|
|
||||||
windowrulev2 = size 40% 50%,$scratchmacs
|
|
||||||
windowrulev2 = workspace special silent,$scratchmacs
|
|
||||||
windowrulev2 = center,$scratchmacs
|
|
||||||
|
|
||||||
# Ario
|
# Looking Glass
|
||||||
bind = SUPER ALT, E, exec, pypr toggle ario
|
|
||||||
$dropario = class:^(ario)$
|
|
||||||
windowrulev2 = float,$dropario
|
|
||||||
windowrulev2 = size 50% 70%,$dropario
|
|
||||||
windowrulev2 = workspace special silent,$dropario
|
|
||||||
windowrulev2 = center,$dropario
|
|
||||||
|
|
||||||
# Spotify
|
## Scratchpads
|
||||||
bind = SUPER ALT, R, exec, pypr toggle spotify
|
|
||||||
$dropspotify = title:^(Spotify)$
|
|
||||||
windowrulev2 = float,$dropspotify
|
|
||||||
windowrulev2 = size 50% 70%,$dropspotify
|
|
||||||
windowrulev2 = workspace special silent,$dropspotify
|
|
||||||
windowrulev2 = center,$dropspotify
|
|
||||||
|
|
||||||
## Global keybinds
|
# Alacritty
|
||||||
|
bind = SUPER ALT, Q, exec, pypr toggle term
|
||||||
|
$dropterm = ^(alacritty-dropterm)$
|
||||||
|
windowrule = float,$dropterm
|
||||||
|
windowrule = size 40% 50%,$dropterm
|
||||||
|
windowrule = workspace special silent,$dropterm
|
||||||
|
windowrule = center,$dropterm
|
||||||
|
|
||||||
# OBS
|
# Emacs
|
||||||
bind = SHIFT, F10, pass,^(com\.obsproject\.Studio)$
|
bind = SUPER ALT, W, exec, pypr toggle emacs
|
||||||
bind = SHIFT, F11, pass,^(com\.obsproject\.Studio)$
|
$scratchmacs = title:^(scratchmacs)$
|
||||||
|
windowrulev2 = float,$scratchmacs
|
||||||
|
windowrulev2 = size 40% 50%,$scratchmacs
|
||||||
|
windowrulev2 = workspace special silent,$scratchmacs
|
||||||
|
windowrulev2 = center,$scratchmacs
|
||||||
|
|
||||||
# Start polkit agent
|
# Ario
|
||||||
exec-once = systemctl --user start plasma-polkit-agent.service
|
bind = SUPER ALT, E, exec, pypr toggle ario
|
||||||
|
$dropario = class:^(ario)$
|
||||||
|
windowrulev2 = float,$dropario
|
||||||
|
windowrulev2 = size 50% 70%,$dropario
|
||||||
|
windowrulev2 = workspace special silent,$dropario
|
||||||
|
windowrulev2 = center,$dropario
|
||||||
|
|
||||||
|
# Spotify
|
||||||
|
bind = SUPER ALT, R, exec, pypr toggle spotify
|
||||||
|
$dropspotify = title:^(Spotify)$
|
||||||
|
windowrulev2 = float,$dropspotify
|
||||||
|
windowrulev2 = size 50% 70%,$dropspotify
|
||||||
|
windowrulev2 = workspace special silent,$dropspotify
|
||||||
|
windowrulev2 = center,$dropspotify
|
||||||
|
|
||||||
|
## Global keybinds
|
||||||
|
|
||||||
|
# OBS
|
||||||
|
bind = SHIFT, F10, pass,^(com\.obsproject\.Studio)$
|
||||||
|
bind = SHIFT, F11, pass,^(com\.obsproject\.Studio)$
|
||||||
|
|
||||||
|
# Start polkit agent
|
||||||
|
exec-once = systemctl --user start plasma-polkit-agent.service
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -98,6 +98,7 @@ in {
|
||||||
# ZFS
|
# ZFS
|
||||||
boot.supportedFilesystems = [ "zfs" ];
|
boot.supportedFilesystems = [ "zfs" ];
|
||||||
boot.zfs.forceImportRoot = false;
|
boot.zfs.forceImportRoot = false;
|
||||||
|
boot.zfs.extraPools = [ "bigssd" ];
|
||||||
# Generated with head -c4 /dev/urandom | od -A none -t x4
|
# Generated with head -c4 /dev/urandom | od -A none -t x4
|
||||||
networking.hostId = "bc94e9d3";
|
networking.hostId = "bc94e9d3";
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,4 +90,18 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Looking glass
|
||||||
|
xdg.configFile."looking-glass/client.ini" = {
|
||||||
|
text = ''
|
||||||
|
[input]
|
||||||
|
rawMouse=yes
|
||||||
|
[audio]
|
||||||
|
periodSize=512
|
||||||
|
bufferLatency=7
|
||||||
|
micDefault=allow
|
||||||
|
[egl]
|
||||||
|
scale = 1
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,15 @@ let
|
||||||
"10de:1ad9" # Usb ????
|
"10de:1ad9" # Usb ????
|
||||||
];
|
];
|
||||||
in {
|
in {
|
||||||
|
##
|
||||||
|
## Packages
|
||||||
|
##
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
# Looking glass, avoids the need for another monitor
|
||||||
|
looking-glass-client
|
||||||
|
# For samba
|
||||||
|
cifs-utils
|
||||||
|
];
|
||||||
##
|
##
|
||||||
## Kernel configuration
|
## Kernel configuration
|
||||||
##
|
##
|
||||||
|
@ -25,7 +34,6 @@ in {
|
||||||
##
|
##
|
||||||
## Virtualization setup
|
## Virtualization setup
|
||||||
##
|
##
|
||||||
environment.systemPackages = with pkgs; [ looking-glass-client ];
|
|
||||||
virtualisation.spiceUSBRedirection.enable = true;
|
virtualisation.spiceUSBRedirection.enable = true;
|
||||||
virtualisation.libvirtd = {
|
virtualisation.libvirtd = {
|
||||||
qemu = {
|
qemu = {
|
||||||
|
@ -55,4 +63,25 @@ in {
|
||||||
};
|
};
|
||||||
networking.defaultGateway = "10.0.4.1";
|
networking.defaultGateway = "10.0.4.1";
|
||||||
networking.nameservers = [ "10.0.0.10" ];
|
networking.nameservers = [ "10.0.0.10" ];
|
||||||
|
|
||||||
|
##
|
||||||
|
## Samba share
|
||||||
|
##
|
||||||
|
services.samba = {
|
||||||
|
enable = true;
|
||||||
|
openFirewall = true;
|
||||||
|
extraConfig = ''
|
||||||
|
browseable = yes
|
||||||
|
smb encrypt = required
|
||||||
|
'';
|
||||||
|
shares = {
|
||||||
|
# You will still need to set up the user accounts to begin with:
|
||||||
|
# $ sudo smbpasswd -a yourusername
|
||||||
|
homes = {
|
||||||
|
browseable = "no";
|
||||||
|
"read only" = "no";
|
||||||
|
"guest ok" = "no";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
hyprctl dispatch exec -- "[float;size 1829 1029] gamescope --scaler integer \
|
gamescope --scaler integer \
|
||||||
--force-windows-fullscreen -f --rt -- vmware"
|
--force-windows-fullscreen -f --rt -- vmware
|
||||||
|
|
||||||
wait
|
wait
|
||||||
|
|
Loading…
Reference in New Issue