Merge remote-tracking branch 'origin/nixos' into nixos

This commit is contained in:
Moritz Böhme 2023-06-10 21:54:36 +02:00
commit 21bba2e8fd
Signed by: moritz
GPG key ID: 970C6E89EB0547A9
10 changed files with 73 additions and 60 deletions

View file

@ -33,6 +33,7 @@ in
gpg.enable = mkDefault true; gpg.enable = mkDefault true;
hyprland.enable = mkDefault true; hyprland.enable = mkDefault true;
logseq.enable = mkDefault true; logseq.enable = mkDefault true;
nix-edit.enable = mkDefault true;
nvim.enable = mkDefault true; nvim.enable = mkDefault true;
python.versions."311".enable = mkDefault true; python.versions."311".enable = mkDefault true;
spotify.enable = mkDefault true; spotify.enable = mkDefault true;
@ -53,6 +54,7 @@ in
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [
anki anki
calibre calibre
fd
keepassxc keepassxc
nixpkgs-review nixpkgs-review
pavucontrol pavucontrol

View file

@ -31,8 +31,7 @@ in
"browser.urlbar.suggest.searches" = true; "browser.urlbar.suggest.searches" = true;
# startup page # startup page
"browser.startup.homepage" = "https://searxng.moritzboeh.me/"; "browser.startup.page" = 0;
"browser.startup.page" = 1;
# drm # drm
"media.eme.enabled" = true; "media.eme.enabled" = true;

View file

@ -221,4 +221,6 @@ in
# Move/resize windows with mainMod + LMB/RMB and dragging # Move/resize windows with mainMod + LMB/RMB and dragging
bindm = $mainMod, mouse:272, movewindow bindm = $mainMod, mouse:272, movewindow
bindm = $mainMod, mouse:273, resizewindow bindm = $mainMod, mouse:273, resizewindow
exec-once=${getExe config.my.programs.wallpaper.package} -r
'' ''

View file

@ -58,7 +58,16 @@ in
enable = true; enable = true;
# use package with hyprland support for switching workspaces # use package with hyprland support for switching workspaces
package = pkgs.waybar-hyprland; package = pkgs.symlinkJoin {
name = "waybar-hyprland";
paths = [ pkgs.waybar-hyprland ];
nativeBuildInputs = [ pkgs.makeWrapper ];
postBuild = ''
wrapProgram $out/bin/waybar \
--prefix PATH ":" "${hyprland}/bin"
'';
};
# start using systemd service # start using systemd service
systemd = { systemd = {
@ -70,7 +79,7 @@ in
mainBar = { mainBar = {
layer = "top"; layer = "top";
position = "top"; position = "top";
height = 30; height = 20;
modules-left = [ "wlr/workspaces" ]; modules-left = [ "wlr/workspaces" ];
modules-center = [ "hyprland/window" ]; modules-center = [ "hyprland/window" ];
modules-right = [ "network" "memory" "cpu" "battery" "clock" ]; modules-right = [ "network" "memory" "cpu" "battery" "clock" ];
@ -83,7 +92,6 @@ in
}; };
}; };
# lock screen after timeout # lock screen after timeout
home-manager.users.moritz = { home-manager.users.moritz = {
services.swayidle = { services.swayidle = {
@ -129,40 +137,6 @@ in
# adds pam module for swaylock # adds pam module for swaylock
security.pam.services.swaylock = { }; security.pam.services.swaylock = { };
# start hyprpaper daemon using systemd unit (to set wallpaper)
systemd.user.services.hyprpaper =
let
wallpaper = "/home/moritz/.config/wallpapers/a_short_walk.png";
config = pkgs.writeTextFile {
name = "hyprpaper.conf";
text = ''
preload = ${wallpaper}
wallpaper = ,${wallpaper}
'';
};
in
{
wantedBy = [ "graphical-session.target" ];
serviceConfig = {
ExecStartPre = "${pkgs.coreutils}/bin/sleep 0.5";
ExecStart = "${getExe pkgs.hyprpaper} -c ${config}";
RestartSec = "500ms";
Restart = "on-failure";
};
};
systemd.user.services.random-wallpaper = {
wantedBy = [ "graphical-session.target" ];
requires = [ "hyprpaper.service" ];
serviceConfig = {
ExecStartPre = "${pkgs.coreutils}/bin/sleep 0.5";
ExecStart = "${getExe config.my.programs.wallpaper.package} -r";
RestartSec = "500ms";
Restart = "on-failure";
};
};
# only consider graphical-session.target started when hyprland-sesstion.target is reached # only consider graphical-session.target started when hyprland-sesstion.target is reached
systemd.user.targets.hyprland-session = { systemd.user.targets.hyprland-session = {
partOf = [ "graphical-session.target" ]; partOf = [ "graphical-session.target" ];

View file

@ -0,0 +1,26 @@
{ lib
, config
, pkgs
, ...
}:
with lib;
let
cfg = config.my.programs.nix-edit;
in
{
options.my.programs.nix-edit.enable = mkEnableOption "nix-edit";
config = mkIf cfg.enable {
environment.systemPackages =
let
nix-edit = pkgs.writeShellApplication {
name = "nix-edit";
runtimeInputs = with pkgs; [ nix gnugrep ];
text = builtins.readFile ./nix-edit.sh;
};
in
[ nix-edit ];
};
}

View file

@ -0,0 +1,15 @@
#!/usr/bin/env bash
input=$(
echo ":lf nixpkgs"
echo "pkgs = legacyPackages.\${builtins.currentSystem}"
echo ":doc $1"
echo ":e $1"
)
echo "$input" | nix repl --quiet 2> >(grep -v "ioctl" |
grep -v "^error: value does not have documentation$" |
grep -vP "error: .* has no source location information" |
grep -vP "Welcome to Nix \d+\.\d+\.\d+\." |
grep -vP "Added \d+ variables." |
grep -v -e '^[[:space:]]*$'
)

View file

@ -8,7 +8,7 @@ let
script = pkgs.writeShellApplication { script = pkgs.writeShellApplication {
name = "wallpaper"; name = "wallpaper";
runtimeInputs = with pkgs; [ findutils coreutils feh hyprland jq fzf viu ]; runtimeInputs = with pkgs; [ findutils coreutils feh swaybg fzf viu ];
text = builtins.readFile ./wallpaper.sh; text = builtins.readFile ./wallpaper.sh;
}; };
in in

25
modules/programs/wallpaper/wallpaper.sh Normal file → Executable file
View file

@ -14,20 +14,23 @@ function help() {
} }
function randomWallpaper() { function randomWallpaper() {
find ~/.config/wallpapers/ -type f,l | shuf -n 1 echo "$WALLPAPERS" | shuf -n 1
}
function setWallpaperX {
feh --bg-fill "$1"
}
function setWallpaperWayland {
swaybg --mode fill -i "$1" 2>/dev/null &
} }
function setWallpaper() { function setWallpaper() {
case "${XDG_CURRENT_DESKTOP,,}" in if [[ -z ${WAYLAND_DISPLAY+x} ]]; then
hyprland) setWallpaperX "$1"
hyprctl hyprpaper preload "$1" &>/dev/null else
hyprctl monitors -j | jq '.[].name' | xargs -I{} -P 0 hyprctl hyprpaper wallpaper '{}',"$1" &>/dev/null setWallpaperWayland "$1"
hyprctl hyprpaper unload all &>/dev/null fi
;;
*)
feh --bg-fill "$1" &>/dev/null
;;
esac
} }
# Parse arguments # Parse arguments

View file

@ -19,7 +19,7 @@ in
users.users.moritz = { users.users.moritz = {
extraGroups = [ "libvirtd" ]; extraGroups = [ "libvirtd" ];
packages = with pkgs; [ virt-manager ]; packages = with pkgs; [ virt-manager virt-viewer ];
}; };
}; };
} }

View file

@ -22,12 +22,4 @@ final: prev: {
--add-flags "--socket=wayland --enable-features=UseOzonePlatform --ozone-platform=wayland" --add-flags "--socket=wayland --enable-features=UseOzonePlatform --ozone-platform=wayland"
''; '';
}; };
waybar-hyprland = prev.waybar.overrideAttrs (old: {
pname = "${old.pname}-hyprland";
postPatch = old.postPatch or "" + ''
sed -i 's,zext_workspace_handle_v1_activate(workspace_handle_);,const std::string command = "${final.hyprland}/bin/hyprctl dispatch workspace " + name_;\n\tsystem(command.c_str());,g' src/modules/wlr/workspace_manager.cpp
'';
mesonFlags = old.mesonFlags or [ ] ++ [ "-Dexperimental=true" ];
});
} }