hyprland
This commit is contained in:
@@ -31,14 +31,24 @@ in
|
|||||||
programs.hyprland = {
|
programs.hyprland = {
|
||||||
enable = true;
|
enable = true;
|
||||||
primaryDisplay = "eDP-1";
|
primaryDisplay = "eDP-1";
|
||||||
display1 = display;
|
|
||||||
|
|
||||||
wallpaper = [
|
monitorv2 = [
|
||||||
"${display.input}, /run/wallpaper.jpg"
|
{
|
||||||
|
name = display.input;
|
||||||
|
mode = "${display.resolution}@${display.refreshRate}";
|
||||||
|
position = "0x0";
|
||||||
|
scale = 1.25;
|
||||||
|
extra = [
|
||||||
|
"bitdepth"
|
||||||
|
"10"
|
||||||
|
"cm"
|
||||||
|
"hdr"
|
||||||
|
"sdrbrightness"
|
||||||
|
"1.2"
|
||||||
|
"sdrsaturation"
|
||||||
|
"0.98"
|
||||||
];
|
];
|
||||||
|
}
|
||||||
monitor = [
|
|
||||||
"${display.input},${display.resolution}@${display.refreshRate},0x0,1.25,bitdepth,10,cm,hdr,sdrbrightness,1.2,sdrsaturation,0.98"
|
|
||||||
];
|
];
|
||||||
|
|
||||||
workspace = [
|
workspace = [
|
||||||
@@ -50,6 +60,17 @@ in
|
|||||||
windowRule = [
|
windowRule = [
|
||||||
"size 2160 3356, tag:horizonrdp"
|
"size 2160 3356, tag:horizonrdp"
|
||||||
];
|
];
|
||||||
|
|
||||||
|
hyprpaper = {
|
||||||
|
wallpaperPath = "/run/wallpaper.jpg";
|
||||||
|
};
|
||||||
|
|
||||||
|
keybinds = {
|
||||||
|
bind = [
|
||||||
|
"$mod, A, exec, chromium --app=\"https://music.apple.com\""
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
defaultApps = {
|
defaultApps = {
|
||||||
browser = pkgs.firefox;
|
browser = pkgs.firefox;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -33,14 +33,39 @@ in
|
|||||||
enable = true;
|
enable = true;
|
||||||
primaryDisplay = "DP-1";
|
primaryDisplay = "DP-1";
|
||||||
|
|
||||||
wallpaper = [
|
monitorv2 = [
|
||||||
"${displayLeft.input}, /run/wallpaper.jpg"
|
{
|
||||||
"${displayRight.input}, /run/wallpaper.jpg"
|
name = displayLeft.input;
|
||||||
|
mode = "${displayLeft.resolution}@${displayLeft.refreshRate}";
|
||||||
|
position = "0x0";
|
||||||
|
scale = 1.0;
|
||||||
|
extra = [
|
||||||
|
"bitdepth"
|
||||||
|
"10"
|
||||||
|
"cm"
|
||||||
|
"hdr"
|
||||||
|
"sdrbrightness"
|
||||||
|
"1.2"
|
||||||
|
"sdrsaturation"
|
||||||
|
"0.98"
|
||||||
];
|
];
|
||||||
|
}
|
||||||
monitor = [
|
{
|
||||||
"${displayLeft.input},${displayLeft.resolution}@${displayLeft.refreshRate},0x0,1,bitdepth,10,cm,hdr,sdrbrightness,1.2,sdrsaturation,0.98"
|
name = displayRight.input;
|
||||||
"${displayRight.input},${displayRight.resolution}@${displayRight.refreshRate},3840x0,1,bitdepth,10,cm,hdr,sdrbrightness,1.5,sdrsaturation,0.98"
|
mode = "${displayRight.resolution}@${displayRight.refreshRate}";
|
||||||
|
position = "3840x0";
|
||||||
|
scale = 1.0;
|
||||||
|
extra = [
|
||||||
|
"bitdepth"
|
||||||
|
"10"
|
||||||
|
"cm"
|
||||||
|
"hdr"
|
||||||
|
"sdrbrightness"
|
||||||
|
"1.5"
|
||||||
|
"sdrsaturation"
|
||||||
|
"0.98"
|
||||||
|
];
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
workspace = [
|
workspace = [
|
||||||
@@ -53,12 +78,24 @@ in
|
|||||||
"size 2160 7680, tag:horizonrdp"
|
"size 2160 7680, tag:horizonrdp"
|
||||||
];
|
];
|
||||||
|
|
||||||
extraConfig = ''
|
autostartCommands = [
|
||||||
exec-once = [silent] firefox
|
"[silent] firefox"
|
||||||
exec-once = [silent] vesktop
|
"[silent] vesktop"
|
||||||
exec-once = [silent] chromium --app="https://music.apple.com"
|
"[silent] chromium --app=\"https://music.apple.com\""
|
||||||
exec-once = [silent] steam
|
"[silent] steam"
|
||||||
'';
|
];
|
||||||
|
|
||||||
|
hyprpaper = {
|
||||||
|
wallpaperPath = "/run/wallpaper.jpg";
|
||||||
|
};
|
||||||
|
|
||||||
|
keybinds = {
|
||||||
|
bind = [
|
||||||
|
"$mod, A, exec, chromium --app=\"https://music.apple.com\""
|
||||||
|
"$mod, C, exec, vesktop"
|
||||||
|
"$mod, G, exec, steam"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
defaultApps = {
|
defaultApps = {
|
||||||
browser = pkgs.firefox;
|
browser = pkgs.firefox;
|
||||||
|
|||||||
@@ -17,11 +17,13 @@ in
|
|||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
# Home packages
|
# Home packages
|
||||||
home.packages = with pkgs; [
|
home.packages =
|
||||||
|
with pkgs;
|
||||||
|
(
|
||||||
|
[
|
||||||
box64
|
box64
|
||||||
brightnessctl
|
brightnessctl
|
||||||
ddcutil
|
ddcutil
|
||||||
dunst
|
|
||||||
egl-wayland
|
egl-wayland
|
||||||
file-roller
|
file-roller
|
||||||
glib
|
glib
|
||||||
@@ -44,7 +46,6 @@ in
|
|||||||
kdePackages.qtmultimedia
|
kdePackages.qtmultimedia
|
||||||
libnotify
|
libnotify
|
||||||
libz
|
libz
|
||||||
mako
|
|
||||||
meson
|
meson
|
||||||
nautilus
|
nautilus
|
||||||
nomacs
|
nomacs
|
||||||
@@ -53,11 +54,8 @@ in
|
|||||||
pamixer
|
pamixer
|
||||||
pavucontrol
|
pavucontrol
|
||||||
playerctl
|
playerctl
|
||||||
polkit
|
|
||||||
polkit_gnome
|
|
||||||
qt5.qtwayland
|
qt5.qtwayland
|
||||||
qt6.qtwayland
|
qt6.qtwayland
|
||||||
rofi
|
|
||||||
waybar
|
waybar
|
||||||
wayland-protocols
|
wayland-protocols
|
||||||
wayland-utils
|
wayland-utils
|
||||||
@@ -66,15 +64,15 @@ in
|
|||||||
wl-clipboard
|
wl-clipboard
|
||||||
wlogout
|
wlogout
|
||||||
wlroots
|
wlroots
|
||||||
xdg-desktop-portal-hyprland
|
|
||||||
xdg-desktop-portal-gtk
|
|
||||||
xdg-desktop-portal-wlr
|
|
||||||
xorg.xhost
|
xorg.xhost
|
||||||
xsettingsd
|
xsettingsd
|
||||||
xwayland
|
xwayland
|
||||||
|
|
||||||
pkgs.mjallen.pipewire-python
|
pkgs.mjallen.pipewire-python
|
||||||
];
|
]
|
||||||
|
++ (if cfg.notificationDaemon == "mako" then [ mako ] else [ dunst ])
|
||||||
|
++ (if cfg.launcher == "wofi" then [ wofi ] else [ rofi ])
|
||||||
|
);
|
||||||
|
|
||||||
# Session variables
|
# Session variables
|
||||||
home.sessionVariables = {
|
home.sessionVariables = {
|
||||||
@@ -114,11 +112,23 @@ in
|
|||||||
hyprpaper = {
|
hyprpaper = {
|
||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
preload = [ "/run/wallpaper.jpg" ];
|
preload = [ cfg.hyprpaper.wallpaperPath ];
|
||||||
wallpaper = [
|
wallpaper =
|
||||||
"${cfg.display1.input}, /run/wallpaper.jpg"
|
let
|
||||||
"${cfg.display2.input}, /run/wallpaper.jpg"
|
useMonitorV2 = (lib.versionAtLeast pkgs.hyprland.version "0.40.0") && (cfg.monitorv2 != [ ]);
|
||||||
|
names =
|
||||||
|
if useMonitorV2 then
|
||||||
|
map (m: m.name) cfg.monitorv2
|
||||||
|
else
|
||||||
|
[
|
||||||
|
cfg.display1.input
|
||||||
|
cfg.display2.input
|
||||||
];
|
];
|
||||||
|
in
|
||||||
|
if cfg.hyprpaper.usePerMonitor then
|
||||||
|
map (n: "${n}, ${cfg.hyprpaper.wallpaperPath}") names
|
||||||
|
else
|
||||||
|
[ ", ${cfg.hyprpaper.wallpaperPath}" ];
|
||||||
splash = false;
|
splash = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@@ -139,16 +149,16 @@ in
|
|||||||
# on-resume = "brightnessctl -r"; # monitor backlight restore.
|
# on-resume = "brightnessctl -r"; # monitor backlight restore.
|
||||||
# }
|
# }
|
||||||
{
|
{
|
||||||
timeout = 900; # 15 min
|
timeout = cfg.hyprIdle.lockScreenTimer;
|
||||||
on-timeout = "loginctl lock-session"; # lock screen when timeout has passed
|
on-timeout = "loginctl lock-session"; # lock screen when timeout has passed
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
timeout = 930; # 15.5 min
|
timeout = cfg.hyprIdle.screenOffTimer;
|
||||||
on-timeout = "hyprctl dispatch dpms off"; # screen off when timeout has passed
|
on-timeout = "hyprctl dispatch dpms off"; # screen off when timeout has passed
|
||||||
on-resume = "hyprctl dispatch dpms on"; # screen on when activity is detected after timeout has fired.
|
on-resume = "hyprctl dispatch dpms on"; # screen on when activity is detected after timeout has fired.
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
timeout = 3600; # 1hr
|
timeout = cfg.hyprIdle.suspendTimer;
|
||||||
on-timeout = "systemctl suspend"; # suspend pc
|
on-timeout = "systemctl suspend"; # suspend pc
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
@@ -212,8 +222,22 @@ in
|
|||||||
# hyprgrass
|
# hyprgrass
|
||||||
];
|
];
|
||||||
|
|
||||||
settings = {
|
settings =
|
||||||
"$mod" = "SUPER";
|
let
|
||||||
|
useMonitorV2 = (lib.versionAtLeast pkgs.hyprland.version "0.40.0") && (cfg.monitorv2 != [ ]);
|
||||||
|
names =
|
||||||
|
if useMonitorV2 then
|
||||||
|
map (m: m.name) cfg.monitorv2
|
||||||
|
else
|
||||||
|
[
|
||||||
|
cfg.display1.input
|
||||||
|
cfg.display2.input
|
||||||
|
];
|
||||||
|
firstMonitor = builtins.elemAt names 0;
|
||||||
|
secondMonitor = if builtins.length names > 1 then builtins.elemAt names 1 else firstMonitor;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
"$mod" = cfg.modKey;
|
||||||
|
|
||||||
# Mouse
|
# Mouse
|
||||||
# mouse_[up|down] - scroll wheel
|
# mouse_[up|down] - scroll wheel
|
||||||
@@ -237,8 +261,8 @@ in
|
|||||||
|
|
||||||
bind = [
|
bind = [
|
||||||
"$mod, Return, exec, ${cfg.defaultApps.terminal.pname}"
|
"$mod, Return, exec, ${cfg.defaultApps.terminal.pname}"
|
||||||
"$mod, SPACE, exec, wofi --show drun"
|
"$mod, SPACE, exec, ${if cfg.launcher == "wofi" then "wofi --show drun" else "rofi -show drun"}"
|
||||||
", xf86Search, exec, wofi --show drun"
|
", xf86Search, exec, ${if cfg.launcher == "wofi" then "wofi --show drun" else "rofi -show drun"}"
|
||||||
"$mod, Q, killactive, "
|
"$mod, Q, killactive, "
|
||||||
"$mod, M, exec, wlogout --protocol layer-shell"
|
"$mod, M, exec, wlogout --protocol layer-shell"
|
||||||
"$mod, E, exec, ${cfg.defaultApps.fileExplorer.pname}"
|
"$mod, E, exec, ${cfg.defaultApps.fileExplorer.pname}"
|
||||||
@@ -252,8 +276,8 @@ in
|
|||||||
"$mod SHIFT, F, fullscreen, 0"
|
"$mod SHIFT, F, fullscreen, 0"
|
||||||
"$mod SHIFT, E, exec, smile"
|
"$mod SHIFT, E, exec, smile"
|
||||||
|
|
||||||
"$mod, mouse:276, movecurrentworkspacetomonitor, ${cfg.display1.input}"
|
"$mod, mouse:276, movecurrentworkspacetomonitor, ${firstMonitor}"
|
||||||
"$mod, mouse:275, movecurrentworkspacetomonitor, ${cfg.display2.input}"
|
"$mod, mouse:275, movecurrentworkspacetomonitor, ${secondMonitor}"
|
||||||
|
|
||||||
# alt-tab between workspaces on active monitor
|
# alt-tab between workspaces on active monitor
|
||||||
"$mod, Tab, workspace, m+1"
|
"$mod, Tab, workspace, m+1"
|
||||||
@@ -297,7 +321,8 @@ in
|
|||||||
"$mod SHIFT, j, movewindow, d"
|
"$mod SHIFT, j, movewindow, d"
|
||||||
|
|
||||||
"$mod, b, exec, ${cfg.defaultApps.browser.pname}"
|
"$mod, b, exec, ${cfg.defaultApps.browser.pname}"
|
||||||
];
|
]
|
||||||
|
++ cfg.keybinds.bind;
|
||||||
|
|
||||||
bindm = [
|
bindm = [
|
||||||
# Move/resize windows with mod + LMB/RMB and dragging
|
# Move/resize windows with mod + LMB/RMB and dragging
|
||||||
@@ -305,12 +330,14 @@ in
|
|||||||
"$mod, mouse:273, resizewindow"
|
"$mod, mouse:273, resizewindow"
|
||||||
# middle mouse will grab a window, mod + middle mouse will close it
|
# middle mouse will grab a window, mod + middle mouse will close it
|
||||||
"$mod SHIFT, mouse:274, movewindow"
|
"$mod SHIFT, mouse:274, movewindow"
|
||||||
];
|
]
|
||||||
|
++ cfg.keybinds.bindm;
|
||||||
|
|
||||||
bindel = [
|
bindel = [
|
||||||
", XF86AudioRaiseVolume, exec, wpctl set-volume -l 1.5 @DEFAULT_AUDIO_SINK@ 5%+"
|
", XF86AudioRaiseVolume, exec, wpctl set-volume -l 1.5 @DEFAULT_AUDIO_SINK@ 5%+"
|
||||||
", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"
|
", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"
|
||||||
];
|
]
|
||||||
|
++ cfg.keybinds.bindel;
|
||||||
|
|
||||||
bindl = [
|
bindl = [
|
||||||
", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"
|
", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"
|
||||||
@@ -324,17 +351,40 @@ in
|
|||||||
|
|
||||||
"$mod, XF86MonBrightnessUp, exec, brightnessctl -d kbd_backlight set +10%"
|
"$mod, XF86MonBrightnessUp, exec, brightnessctl -d kbd_backlight set +10%"
|
||||||
"$mod, XF86MonBrightnessDown, exec, brightnessctl -d kbd_backlight set 10%-"
|
"$mod, XF86MonBrightnessDown, exec, brightnessctl -d kbd_backlight set 10%-"
|
||||||
];
|
]
|
||||||
|
++ cfg.keybinds.bindl;
|
||||||
|
|
||||||
monitor = cfg.monitor;
|
monitor = cfg.monitor;
|
||||||
monitorv2 = cfg.monitorv2 or { };
|
monitorv2 = map (
|
||||||
|
m:
|
||||||
|
if m.disabled then
|
||||||
|
"${m.name}, disable"
|
||||||
|
else if m.mirrorOf != null then
|
||||||
|
"${m.name}, mirror, ${m.mirrorOf}"
|
||||||
|
else
|
||||||
|
let
|
||||||
|
mode = if m.mode == null then "preferred" else m.mode;
|
||||||
|
position = if m.position == null then "auto" else m.position;
|
||||||
|
scale = if m.scale == null then "1" else (toString m.scale);
|
||||||
|
transform = if m.transform == null then "auto" else m.transform;
|
||||||
|
base = [
|
||||||
|
m.name
|
||||||
|
mode
|
||||||
|
position
|
||||||
|
scale
|
||||||
|
transform
|
||||||
|
];
|
||||||
|
line = builtins.concatStringsSep ", " (base ++ m.extra);
|
||||||
|
in
|
||||||
|
line
|
||||||
|
) cfg.monitorv2;
|
||||||
|
|
||||||
render = {
|
render = {
|
||||||
cm_fs_passthrough = 1;
|
cm_fs_passthrough = 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
misc = {
|
misc = {
|
||||||
vrr = 1;
|
vrr = if cfg.enableVRR then 1 else 0;
|
||||||
force_default_wallpaper = 0;
|
force_default_wallpaper = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -345,7 +395,7 @@ in
|
|||||||
"col.active_border" = "rgb(8aadf4) rgb(24273A) rgb(24273A) rgb(8aadf4) 45deg";
|
"col.active_border" = "rgb(8aadf4) rgb(24273A) rgb(24273A) rgb(8aadf4) 45deg";
|
||||||
"col.inactive_border" = "rgb(24273A) rgb(24273A) rgb(24273A) rgb(24273A) 45deg";
|
"col.inactive_border" = "rgb(24273A) rgb(24273A) rgb(24273A) rgb(24273A) 45deg";
|
||||||
layout = "dwindle";
|
layout = "dwindle";
|
||||||
allow_tearing = true;
|
allow_tearing = cfg.allowTearing;
|
||||||
};
|
};
|
||||||
|
|
||||||
decoration = {
|
decoration = {
|
||||||
@@ -558,21 +608,24 @@ in
|
|||||||
};
|
};
|
||||||
|
|
||||||
debug = {
|
debug = {
|
||||||
full_cm_proto = true;
|
full_cm_proto = cfg.debug.fullCmProto;
|
||||||
disable_logs = true;
|
disable_logs = cfg.debug.disableLogs;
|
||||||
disable_scale_checks = true;
|
disable_scale_checks = cfg.debug.disableScaleChecks;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
extraConfig = ''
|
extraConfig =
|
||||||
|
let
|
||||||
|
autostarts = builtins.concatStringsSep "\n" (map (cmd: "exec-once = ${cmd}") cfg.autostartCommands);
|
||||||
|
in
|
||||||
|
''
|
||||||
exec-once = dbus-update-activation-environment --systemd --all
|
exec-once = dbus-update-activation-environment --systemd --all
|
||||||
exec-once = systemctl --user import-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP
|
exec-once = systemctl --user import-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP
|
||||||
exec-once = /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
|
|
||||||
exec-once = xhost +SI:localuser:root
|
exec-once = xhost +SI:localuser:root
|
||||||
exec-once = nwg-look -a
|
|
||||||
exec-once = nwg-dock-hyprland -d
|
|
||||||
''
|
''
|
||||||
+ cfg.extraConfig or '''';
|
+ autostarts
|
||||||
|
+ "\n"
|
||||||
|
+ (cfg.extraConfig or "");
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,19 +14,19 @@ with lib;
|
|||||||
input = mkOption {
|
input = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "DP-1";
|
default = "DP-1";
|
||||||
description = "First display identifier";
|
description = "First display identifier (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
|
|
||||||
resolution = mkOption {
|
resolution = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "3840x2160";
|
default = "3840x2160";
|
||||||
description = "First display resolution";
|
description = "First display resolution (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
|
|
||||||
refreshRate = mkOption {
|
refreshRate = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "240.00000";
|
default = "240.00000";
|
||||||
description = "First display refresh rate";
|
description = "First display refresh rate (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -34,38 +34,104 @@ with lib;
|
|||||||
input = mkOption {
|
input = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "DP-1";
|
default = "DP-1";
|
||||||
description = "Second display identifier";
|
description = "Second display identifier (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
|
|
||||||
resolution = mkOption {
|
resolution = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "3840x2160";
|
default = "3840x2160";
|
||||||
description = "Second display resolution";
|
description = "Second display resolution (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
|
|
||||||
refreshRate = mkOption {
|
refreshRate = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
default = "240.00000";
|
default = "240.00000";
|
||||||
description = "Second display refresh rate";
|
description = "Second display refresh rate (Deprecated: prefer monitorv2)";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Deprecated: prefer hyprpaper.* options
|
||||||
wallpaper = mkOption {
|
wallpaper = mkOption {
|
||||||
type = with types; listOf str;
|
type = with types; listOf str;
|
||||||
default = [ ];
|
default = [ ];
|
||||||
description = "List of hyprland wallpaper configs";
|
description = "Deprecated: no longer used; prefer hyprpaper.wallpaperPath and hyprpaper.usePerMonitor.";
|
||||||
|
};
|
||||||
|
|
||||||
|
hyprpaper = mkOption {
|
||||||
|
type = types.submodule {
|
||||||
|
options = {
|
||||||
|
wallpaperPath = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "/run/wallpaper.jpg";
|
||||||
|
description = "Path to the wallpaper used by hyprpaper.";
|
||||||
|
};
|
||||||
|
usePerMonitor = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = "If true, generate one wallpaper entry per monitor (monitorv2 preferred, falls back to display1/display2).";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
default = { };
|
||||||
|
description = "Hyprpaper configuration.";
|
||||||
};
|
};
|
||||||
|
|
||||||
monitor = mkOption {
|
monitor = mkOption {
|
||||||
type = with types; listOf str;
|
type = with types; listOf str;
|
||||||
default = [ ];
|
default = [ ];
|
||||||
description = "List of hyprland monitor configs";
|
description = "List of Hyprland monitor configs (legacy). Example: [ \"eDP-1, 1920x1080@60, 0x0, 1\" ]";
|
||||||
};
|
};
|
||||||
|
|
||||||
monitorv2 = mkOption {
|
monitorv2 = mkOption {
|
||||||
|
type =
|
||||||
|
with types;
|
||||||
|
listOf (
|
||||||
|
types.submodule {
|
||||||
|
options = {
|
||||||
|
name = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = "Monitor name (e.g., DP-1, eDP-1).";
|
||||||
|
};
|
||||||
|
mode = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description = "Resolution@Hz or keyword (e.g., \"3840x2160@144\" or \"preferred\").";
|
||||||
|
};
|
||||||
|
position = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description = "Position like \"0x0\" or \"auto\".";
|
||||||
|
};
|
||||||
|
scale = mkOption {
|
||||||
|
type = types.nullOr types.float;
|
||||||
|
default = null;
|
||||||
|
description = "Scale factor (e.g., 1.0).";
|
||||||
|
};
|
||||||
|
transform = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description = "Rotation/transform (e.g., \"normal\", \"90\", \"180\", \"270\", \"flipped\").";
|
||||||
|
};
|
||||||
|
disabled = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = "Disable this monitor.";
|
||||||
|
};
|
||||||
|
mirrorOf = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description = "Mirror another monitor by name.";
|
||||||
|
};
|
||||||
|
extra = mkOption {
|
||||||
type = with types; listOf str;
|
type = with types; listOf str;
|
||||||
default = [ ];
|
default = [ ];
|
||||||
description = "List of hyprland monitorv2 configs";
|
description = "Additional monitorv2 flags appended as-is.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland monitorv2 entries as structured options; rendered to lines like \"name, mode, position, scale, transform, ...\".";
|
||||||
};
|
};
|
||||||
|
|
||||||
workspace = mkOption {
|
workspace = mkOption {
|
||||||
@@ -146,6 +212,110 @@ with lib;
|
|||||||
description = "Default applications used across the system";
|
description = "Default applications used across the system";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
autostartCommands = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [
|
||||||
|
"nwg-look -a"
|
||||||
|
"nwg-dock-hyprland -d"
|
||||||
|
];
|
||||||
|
description = "Commands to run via Hyprland exec-once";
|
||||||
|
};
|
||||||
|
|
||||||
|
launcher = mkOption {
|
||||||
|
type = types.enum [
|
||||||
|
"wofi"
|
||||||
|
"rofi"
|
||||||
|
];
|
||||||
|
default = "wofi";
|
||||||
|
description = "Application launcher to use in keybinds and packages.";
|
||||||
|
};
|
||||||
|
|
||||||
|
notificationDaemon = mkOption {
|
||||||
|
type = types.enum [
|
||||||
|
"mako"
|
||||||
|
"dunst"
|
||||||
|
];
|
||||||
|
default = "mako";
|
||||||
|
description = "Notification daemon to install.";
|
||||||
|
};
|
||||||
|
|
||||||
|
modKey = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
default = "SUPER";
|
||||||
|
description = "Modifier key used for Hyprland binds (e.g., SUPER, ALT).";
|
||||||
|
};
|
||||||
|
|
||||||
|
enableVRR = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = "Enable variable refresh rate (maps to Hyprland misc.vrr).";
|
||||||
|
};
|
||||||
|
|
||||||
|
allowTearing = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = "Allow tearing (maps to Hyprland general.allow_tearing).";
|
||||||
|
};
|
||||||
|
|
||||||
|
debug = mkOption {
|
||||||
|
type = types.submodule {
|
||||||
|
options = {
|
||||||
|
disableLogs = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = "Set Hyprland debug.disable_logs.";
|
||||||
|
};
|
||||||
|
fullCmProto = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = "Set Hyprland debug.full_cm_proto.";
|
||||||
|
};
|
||||||
|
disableScaleChecks = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = "Set Hyprland debug.disable_scale_checks.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
default = { };
|
||||||
|
description = "Hyprland debug flags.";
|
||||||
|
};
|
||||||
|
|
||||||
|
keybinds = mkOption {
|
||||||
|
type = types.submodule {
|
||||||
|
options = {
|
||||||
|
bind = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland bind entries.";
|
||||||
|
};
|
||||||
|
bindm = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland bindm entries.";
|
||||||
|
};
|
||||||
|
bindel = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland bindel entries.";
|
||||||
|
};
|
||||||
|
bindl = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland bindl entries.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
default = { };
|
||||||
|
description = "Keybinding lists for Hyprland; useful for host-level overrides.";
|
||||||
|
};
|
||||||
|
|
||||||
|
gestures = mkOption {
|
||||||
|
type = with types; listOf str;
|
||||||
|
default = [ ];
|
||||||
|
description = "Hyprland gesture entries.";
|
||||||
|
};
|
||||||
|
|
||||||
hyprIdle = {
|
hyprIdle = {
|
||||||
lockScreenTimer = mkOption {
|
lockScreenTimer = mkOption {
|
||||||
type = with types; int;
|
type = with types; int;
|
||||||
|
|||||||
@@ -83,10 +83,5 @@ in
|
|||||||
dns_enabled = true;
|
dns_enabled = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Common development programs
|
|
||||||
programs = {
|
|
||||||
nix-ld.enable = lib.mkDefault true;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,10 @@
|
|||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
isArm = ("aarch64-linux" == system) || ("aarch64-darwin" == system);
|
isArm = ("aarch64-linux" == system) || ("aarch64-darwin" == system);
|
||||||
hasDestopEnvironment = config.${namespace}.desktop.cosmic.enable || config.${namespace}.desktop.gnome.enable || config.${namespace}.desktop.hyprland.enable;
|
hasDestopEnvironment =
|
||||||
|
config.${namespace}.desktop.cosmic.enable
|
||||||
|
|| config.${namespace}.desktop.gnome.enable
|
||||||
|
|| config.${namespace}.desktop.hyprland.enable;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|||||||
@@ -61,6 +61,12 @@ in
|
|||||||
"/var/lib/systemd/coredump"
|
"/var/lib/systemd/coredump"
|
||||||
"/etc/NetworkManager/system-connections"
|
"/etc/NetworkManager/system-connections"
|
||||||
"/var/lib/tailscale"
|
"/var/lib/tailscale"
|
||||||
|
{
|
||||||
|
directory = "/var/lib/wallpapers";
|
||||||
|
user = "nobody";
|
||||||
|
group = "nobody";
|
||||||
|
mode = "u=rwx,g=rwx,o=rx";
|
||||||
|
}
|
||||||
{
|
{
|
||||||
directory = "/etc/nix";
|
directory = "/etc/nix";
|
||||||
user = "root";
|
user = "root";
|
||||||
|
|||||||
@@ -1,6 +1,15 @@
|
|||||||
{ config, pkgs, lib, namespace, ... }:
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
namespace,
|
||||||
|
...
|
||||||
|
}:
|
||||||
let
|
let
|
||||||
hasDestopEnvironment = config.${namespace}.desktop.cosmic.enable || config.${namespace}.desktop.gnome.enable || config.${namespace}.desktop.hyprland.enable;
|
hasDestopEnvironment =
|
||||||
|
config.${namespace}.desktop.cosmic.enable
|
||||||
|
|| config.${namespace}.desktop.gnome.enable
|
||||||
|
|| config.${namespace}.desktop.hyprland.enable;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
programs = {
|
programs = {
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
pkgs,
|
|
||||||
lib,
|
lib,
|
||||||
namespace,
|
namespace,
|
||||||
...
|
...
|
||||||
|
|||||||
@@ -6,10 +6,8 @@
|
|||||||
}:
|
}:
|
||||||
with lib;
|
with lib;
|
||||||
let
|
let
|
||||||
inherit (lib.${namespace}) mkOpt mkReverseProxyOpt;
|
inherit (lib.${namespace}) mkOpt;
|
||||||
cfg = config.${namespace}.services.jellyseerr;
|
cfg = config.${namespace}.services.jellyseerr;
|
||||||
|
|
||||||
jellyseerrPort = 5055;
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.${namespace}.services.jellyseerr = {
|
options.${namespace}.services.jellyseerr = {
|
||||||
|
|||||||
@@ -8,8 +8,6 @@ let
|
|||||||
inherit (lib.${namespace}) mkOpt mkReverseProxyOpt;
|
inherit (lib.${namespace}) mkOpt mkReverseProxyOpt;
|
||||||
cfg = config.${namespace}.services.ntfy;
|
cfg = config.${namespace}.services.ntfy;
|
||||||
|
|
||||||
ntfyEnvFile = config.sops.secrets."jallen-nas/ntfy/auth-users".path;
|
|
||||||
|
|
||||||
ntfyConfig = {
|
ntfyConfig = {
|
||||||
services = {
|
services = {
|
||||||
ntfy-sh = {
|
ntfy-sh = {
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
pkgs,
|
|
||||||
lib,
|
lib,
|
||||||
namespace,
|
namespace,
|
||||||
...
|
...
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{ inputs, ... }:
|
{ inputs, ... }:
|
||||||
final: prev: {
|
_final: prev: {
|
||||||
rcon = inputs.nixpkgs-stable.legacyPackages.${prev.system}.rcon;
|
rcon = inputs.nixpkgs-stable.legacyPackages.${prev.system}.rcon;
|
||||||
open-webui = inputs.nixpkgs-stable.legacyPackages.${prev.system}.open-webui;
|
open-webui = inputs.nixpkgs-stable.legacyPackages.${prev.system}.open-webui;
|
||||||
nextcloud-client = inputs.nixpkgs-stable.legacyPackages.${prev.system}.nextcloud-client;
|
nextcloud-client = inputs.nixpkgs-stable.legacyPackages.${prev.system}.nextcloud-client;
|
||||||
|
|||||||
@@ -2,7 +2,6 @@
|
|||||||
buildHomeAssistantComponent,
|
buildHomeAssistantComponent,
|
||||||
python3Packages,
|
python3Packages,
|
||||||
fetchFromGitHub,
|
fetchFromGitHub,
|
||||||
lib,
|
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
buildHomeAssistantComponent rec {
|
buildHomeAssistantComponent rec {
|
||||||
|
|||||||
@@ -25,7 +25,10 @@
|
|||||||
package = pkgs.postgresql_16;
|
package = pkgs.postgresql_16;
|
||||||
enableTCPIP = true;
|
enableTCPIP = true;
|
||||||
dataDir = "/media/nas/main/nix-app-data/postgresql";
|
dataDir = "/media/nas/main/nix-app-data/postgresql";
|
||||||
ensureDatabases = [ "authentik" "homeassistant" ];
|
ensureDatabases = [
|
||||||
|
"authentik"
|
||||||
|
"homeassistant"
|
||||||
|
];
|
||||||
ensureUsers = [
|
ensureUsers = [
|
||||||
{
|
{
|
||||||
name = "authentik";
|
name = "authentik";
|
||||||
|
|||||||
Reference in New Issue
Block a user