mirror of
https://github.com/alyraffauf/nixcfg.git
synced 2024-11-25 02:31:54 -05:00
randomWallpaper: make bin PATH and move script to separate file
This commit is contained in:
parent
0a2131cb75
commit
8c791a1773
|
@ -4,86 +4,7 @@
|
|||
pkgs,
|
||||
...
|
||||
}: let
|
||||
wallpaperD = pkgs.writers.writeRuby "randomWallpaperD" {} ''
|
||||
require 'fileutils'
|
||||
|
||||
directory = "${config.xdg.dataHome}/backgrounds/"
|
||||
current_pids = {}
|
||||
known_monitors = {}
|
||||
last_update_time = {}
|
||||
|
||||
update_interval = 900 # 15 minutes in seconds
|
||||
|
||||
xdg_runtime_dir = ENV['XDG_RUNTIME_DIR']
|
||||
hyprland_instance_signature = ENV['HYPRLAND_INSTANCE_SIGNATURE']
|
||||
sway_sock = ENV['SWAYSOCK']
|
||||
|
||||
hyprland_lock_path = nil
|
||||
|
||||
unless hyprland_instance_signature.nil?
|
||||
hyprland_lock_path = File.join(xdg_runtime_dir, 'hypr', hyprland_instance_signature, 'hyprland.lock')
|
||||
end
|
||||
|
||||
def wm_dead? (hyprland_lock_path, sway_sock)
|
||||
sway_running = system("pidof sway > /dev/null")
|
||||
hypr_running = system("pidof Hyprland > /dev/null")
|
||||
(hyprland_lock_path.nil? || !File.exist?(hyprland_lock_path) || !hypr_running) && (sway_sock.nil? || !File.exist?(sway_sock) || !sway_running)
|
||||
end
|
||||
|
||||
def get_outputs
|
||||
hyprctl = IO.popen(["${lib.getExe' config.wayland.windowManager.hyprland.package "hyprctl"}", 'monitors']).read
|
||||
swaymsg = IO.popen(["${lib.getExe' config.wayland.windowManager.sway.package "swaymsg"}", '-t', 'get_outputs', '-p']).readlines
|
||||
|
||||
hypr_outputs = hyprctl.each_line.map { |line| line.split[1] if line.include?('Monitor') }.compact
|
||||
sway_outputs = swaymsg.select { |line| line.include?('Output') }.map { |line| line.split[1] }
|
||||
|
||||
return (sway_outputs | hypr_outputs)
|
||||
end
|
||||
|
||||
sleep 1
|
||||
|
||||
loop do
|
||||
active_monitors = get_outputs
|
||||
|
||||
break if wm_dead? hyprland_lock_path, sway_sock
|
||||
next if active_monitors.empty?
|
||||
|
||||
added_monitors = active_monitors - known_monitors.keys
|
||||
removed_monitors = known_monitors.keys - active_monitors
|
||||
|
||||
# Handle newly added monitors
|
||||
added_monitors.each do |monitor|
|
||||
random_background = Dir.glob(File.join(directory, '*.{png,jpg}')).sample
|
||||
pid = spawn("${lib.getExe pkgs.swaybg}", '-o', monitor, '-i', random_background, '-m', 'fill')
|
||||
current_pids[monitor] = pid
|
||||
last_update_time[monitor] = Time.now
|
||||
known_monitors[monitor] = random_background
|
||||
end
|
||||
|
||||
# Remove wallpapers from removed monitors
|
||||
removed_monitors.each do |monitor|
|
||||
Process.kill('TERM', current_pids[monitor]) if current_pids[monitor]
|
||||
current_pids.delete(monitor)
|
||||
last_update_time.delete(monitor)
|
||||
known_monitors.delete(monitor)
|
||||
end
|
||||
|
||||
# Update wallpapers after the set interval
|
||||
active_monitors.each do |monitor|
|
||||
if Time.now - last_update_time[monitor] >= update_interval
|
||||
random_background = Dir.glob(File.join(directory, '*.{png,jpg}')).sample
|
||||
pid = spawn("${lib.getExe pkgs.swaybg}", '-o', monitor, '-i', random_background, '-m', 'fill')
|
||||
sleep 1
|
||||
Process.kill('TERM', current_pids[monitor]) if current_pids[monitor]
|
||||
current_pids[monitor] = pid
|
||||
last_update_time[monitor] = Time.now
|
||||
known_monitors[monitor] = random_background
|
||||
end
|
||||
end
|
||||
|
||||
sleep 3
|
||||
end
|
||||
'';
|
||||
wallpaperD = pkgs.writers.writeRuby "randomWallpaperD" {} (builtins.readFile ./script.rb);
|
||||
in {
|
||||
config = lib.mkIf config.ar.home.services.randomWallpaper.enable {
|
||||
services.hyprpaper.enable = lib.mkForce false;
|
||||
|
@ -99,8 +20,20 @@ in {
|
|||
};
|
||||
|
||||
Service = {
|
||||
Environment = [
|
||||
"PATH=${
|
||||
lib.makeBinPath [
|
||||
config.wayland.windowManager.hyprland.package
|
||||
config.wayland.windowManager.sway.package
|
||||
pkgs.procps
|
||||
pkgs.swaybg
|
||||
]
|
||||
}"
|
||||
];
|
||||
|
||||
ExecStart = "${wallpaperD}";
|
||||
Restart = "no";
|
||||
TasksMax = "infinity";
|
||||
};
|
||||
|
||||
Install.WantedBy = lib.optional (config.ar.home.desktop.hyprland.enable) "hyprland-session.target" ++ lib.optional (config.ar.home.desktop.sway.enable) "sway-session.target";
|
||||
|
|
82
homeManagerModules/services/randomWallpaper/script.rb
Normal file
82
homeManagerModules/services/randomWallpaper/script.rb
Normal file
|
@ -0,0 +1,82 @@
|
|||
#!/usr/bin/env ruby
|
||||
|
||||
require "fileutils"
|
||||
|
||||
# Set the wallpaper directory to the first argument if it exists, else use the default value
|
||||
directory = ARGV[0] || File.expand_path("~/.local/share/backgrounds")
|
||||
|
||||
current_pids = {}
|
||||
known_monitors = {}
|
||||
last_update_time = {}
|
||||
|
||||
update_interval = 900 # 15 minutes in seconds
|
||||
|
||||
xdg_runtime_dir = ENV["XDG_RUNTIME_DIR"]
|
||||
hyprland_instance_signature = ENV["HYPRLAND_INSTANCE_SIGNATURE"]
|
||||
sway_sock = ENV["SWAYSOCK"]
|
||||
|
||||
hyprland_lock_path = nil
|
||||
|
||||
unless hyprland_instance_signature.nil?
|
||||
hyprland_lock_path = File.join(xdg_runtime_dir, "hypr", hyprland_instance_signature, "hyprland.lock")
|
||||
end
|
||||
|
||||
def wm_dead?(hyprland_lock_path, sway_sock)
|
||||
sway_running = system("pidof sway > /dev/null")
|
||||
hypr_running = system("pidof Hyprland > /dev/null")
|
||||
(hyprland_lock_path.nil? || !File.exist?(hyprland_lock_path) || !hypr_running) && (sway_sock.nil? || !File.exist?(sway_sock) || !sway_running)
|
||||
end
|
||||
|
||||
def get_outputs
|
||||
hyprctl = IO.popen(["hyprctl", "monitors"]).read
|
||||
swaymsg = IO.popen(["swaymsg", "-t", "get_outputs", "-p"]).readlines
|
||||
|
||||
hypr_outputs = hyprctl.each_line.map { |line| line.split[1] if line.include?("Monitor") }.compact
|
||||
sway_outputs = swaymsg.select { |line| line.include?("Output") }.map { |line| line.split[1] }
|
||||
|
||||
return (sway_outputs | hypr_outputs)
|
||||
end
|
||||
|
||||
sleep 1
|
||||
|
||||
loop do
|
||||
active_monitors = get_outputs
|
||||
|
||||
break if wm_dead? hyprland_lock_path, sway_sock
|
||||
next if active_monitors.empty?
|
||||
|
||||
added_monitors = active_monitors - known_monitors.keys
|
||||
removed_monitors = known_monitors.keys - active_monitors
|
||||
|
||||
# Handle newly added monitors
|
||||
added_monitors.each do |monitor|
|
||||
random_background = Dir.glob(File.join(directory, "*.{png,jpg}")).sample
|
||||
pid = spawn("swaybg", "-o", monitor, "-i", random_background, "-m", "fill")
|
||||
current_pids[monitor] = pid
|
||||
last_update_time[monitor] = Time.now
|
||||
known_monitors[monitor] = random_background
|
||||
end
|
||||
|
||||
# Remove wallpapers from removed monitors
|
||||
removed_monitors.each do |monitor|
|
||||
Process.kill("TERM", current_pids[monitor]) if current_pids[monitor]
|
||||
current_pids.delete(monitor)
|
||||
last_update_time.delete(monitor)
|
||||
known_monitors.delete(monitor)
|
||||
end
|
||||
|
||||
# Update wallpapers after the set interval
|
||||
active_monitors.each do |monitor|
|
||||
if Time.now - last_update_time[monitor] >= update_interval
|
||||
random_background = Dir.glob(File.join(directory, "*.{png,jpg}")).sample
|
||||
pid = spawn("swaybg", "-o", monitor, "-i", random_background, "-m", "fill")
|
||||
sleep 1
|
||||
Process.kill("TERM", current_pids[monitor]) if current_pids[monitor]
|
||||
current_pids[monitor] = pid
|
||||
last_update_time[monitor] = Time.now
|
||||
known_monitors[monitor] = random_background
|
||||
end
|
||||
end
|
||||
|
||||
sleep 3
|
||||
end
|
|
@ -62,7 +62,7 @@ in {
|
|||
Service = {
|
||||
Environment = lib.mkForce [
|
||||
"PATH=${
|
||||
pkgs.lib.makeBinPath ((with pkgs; [
|
||||
lib.makeBinPath ((with pkgs; [
|
||||
bash
|
||||
brightnessctl
|
||||
coreutils
|
||||
|
|
Loading…
Reference in a new issue