treewide: cleanup config with enable options
This commit is contained in:
parent
d469c5fa79
commit
0a387960a2
32
flake.nix
32
flake.nix
|
@ -102,17 +102,25 @@
|
||||||
inputs.agenix.nixosModules.default
|
inputs.agenix.nixosModules.default
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
inputs.disko.nixosModules.disko
|
inputs.disko.nixosModules.disko
|
||||||
{
|
(
|
||||||
home-manager.useGlobalPkgs = true;
|
{ config, ... }:
|
||||||
home-manager.useUserPackages = true;
|
{
|
||||||
home-manager.users.lelgenio = import ./user/home.nix;
|
home-manager.useGlobalPkgs = true;
|
||||||
home-manager.backupFileExtension = "bkp";
|
home-manager.useUserPackages = true;
|
||||||
# Optionally, use home-manager.extraSpecialArgs to pass
|
home-manager.users.lelgenio = {
|
||||||
# arguments to home.nix
|
my = config.my;
|
||||||
home-manager.extraSpecialArgs = {
|
imports = [
|
||||||
inherit inputs;
|
./user/home.nix
|
||||||
};
|
];
|
||||||
}
|
};
|
||||||
|
home-manager.backupFileExtension = "bkp";
|
||||||
|
# Optionally, use home-manager.extraSpecialArgs to pass
|
||||||
|
# arguments to home.nix
|
||||||
|
home-manager.extraSpecialArgs = {
|
||||||
|
inherit inputs;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
]
|
]
|
||||||
++ lib.optional (desktop == "gnome") ./system/gnome.nix
|
++ lib.optional (desktop == "gnome") ./system/gnome.nix
|
||||||
++ lib.optional (desktop == "kde") ./system/kde.nix;
|
++ lib.optional (desktop == "kde") ./system/kde.nix;
|
||||||
|
@ -133,7 +141,6 @@
|
||||||
./system/monolith-gitlab-runner.nix
|
./system/monolith-gitlab-runner.nix
|
||||||
./system/monolith-forgejo-runner.nix
|
./system/monolith-forgejo-runner.nix
|
||||||
./system/nix-serve.nix
|
./system/nix-serve.nix
|
||||||
./system/steam.nix
|
|
||||||
] ++ common_modules;
|
] ++ common_modules;
|
||||||
};
|
};
|
||||||
double-rainbow = lib.nixosSystem {
|
double-rainbow = lib.nixosSystem {
|
||||||
|
@ -151,7 +158,6 @@
|
||||||
++ [
|
++ [
|
||||||
{
|
{
|
||||||
packages.media-packages.enable = lib.mkOverride 0 false;
|
packages.media-packages.enable = lib.mkOverride 0 false;
|
||||||
programs.steam.enable = lib.mkOverride 0 false;
|
|
||||||
services.flatpak.enable = lib.mkOverride 0 false;
|
services.flatpak.enable = lib.mkOverride 0 false;
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
|
@ -41,6 +41,8 @@ in
|
||||||
package = pkgs.unstable.opentabletdriver;
|
package = pkgs.unstable.opentabletdriver;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
my.gaming.enable = true;
|
||||||
|
|
||||||
boot.extraModulePackages = with config.boot.kernelPackages; [ zenpower ];
|
boot.extraModulePackages = with config.boot.kernelPackages; [ zenpower ];
|
||||||
|
|
||||||
boot.initrd.kernelModules = [ "amdgpu" ];
|
boot.initrd.kernelModules = [ "amdgpu" ];
|
||||||
|
|
|
@ -1,6 +1,18 @@
|
||||||
{ lib, ... }:
|
{ lib, ... }:
|
||||||
{
|
{
|
||||||
options = {
|
options = {
|
||||||
my = lib.mkOption { };
|
my = {
|
||||||
|
themes = lib.mkOption { };
|
||||||
|
key = lib.mkOption { };
|
||||||
|
theme = lib.mkOption { };
|
||||||
|
accent = lib.mkOption { };
|
||||||
|
font = lib.mkOption { };
|
||||||
|
username = lib.mkOption { type = lib.types.str; };
|
||||||
|
mail = lib.mkOption { };
|
||||||
|
dmenu = lib.mkOption { type = lib.types.str; };
|
||||||
|
desktop = lib.mkOption { type = lib.types.str; };
|
||||||
|
browser = lib.mkOption { type = lib.types.str; };
|
||||||
|
editor = lib.mkOption { type = lib.types.str; };
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
17
system/android.nix
Normal file
17
system/android.nix
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
options.my.android.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf config.my.android.enable {
|
||||||
|
# Open kde connect ports
|
||||||
|
programs.kdeconnect.enable = true;
|
||||||
|
|
||||||
|
programs.adb.enable = true;
|
||||||
|
services.udev.packages = [ pkgs.android-udev-rules ];
|
||||||
|
};
|
||||||
|
}
|
|
@ -2,7 +2,6 @@
|
||||||
config,
|
config,
|
||||||
pkgs,
|
pkgs,
|
||||||
lib,
|
lib,
|
||||||
inputs,
|
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,15 +1,11 @@
|
||||||
# Edit this configuration file to define what should be installed on
|
# Edit this configuration file to define what should be installed on
|
||||||
# your system. Help is available in the configuration.nix(5) man page
|
# your system. Help is available in the configuration.nix(5) man page
|
||||||
# and in the NixOS manual (accessible by running ‘nixos-help’).
|
# and in the NixOS manual (accessible by running ‘nixos-help’).
|
||||||
{
|
{ pkgs, ... }:
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
inputs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./gamemode.nix
|
./android.nix
|
||||||
|
./gaming.nix
|
||||||
./media-packages.nix
|
./media-packages.nix
|
||||||
./boot.nix
|
./boot.nix
|
||||||
./thunar.nix
|
./thunar.nix
|
||||||
|
@ -25,39 +21,27 @@
|
||||||
../settings
|
../settings
|
||||||
];
|
];
|
||||||
|
|
||||||
my = import ../user/variables.nix;
|
my = import ../user/variables.nix // {
|
||||||
|
android.enable = true;
|
||||||
|
media-packages.enable = true;
|
||||||
|
containers.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
zramSwap.enable = true;
|
zramSwap.enable = true;
|
||||||
|
|
||||||
programs.adb.enable = true;
|
|
||||||
services.udev.packages = [ pkgs.android-udev-rules ];
|
|
||||||
|
|
||||||
# Enable touchpad support (enabled default in most desktopManager).
|
# Enable touchpad support (enabled default in most desktopManager).
|
||||||
services.libinput.enable = true;
|
services.libinput.enable = true;
|
||||||
|
|
||||||
packages.media-packages.enable = true;
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
pavucontrol
|
pavucontrol
|
||||||
|
|
||||||
glib # gsettings
|
glib # gsettings
|
||||||
usbutils
|
usbutils
|
||||||
# dracula-theme # gtk theme
|
|
||||||
adwaita-icon-theme # default gnome cursors
|
adwaita-icon-theme # default gnome cursors
|
||||||
|
|
||||||
nix-output-monitor
|
|
||||||
];
|
];
|
||||||
|
|
||||||
services.geoclue2.enable = true;
|
services.geoclue2.enable = true;
|
||||||
|
|
||||||
# Workaround for nm-wait-online hanging??
|
|
||||||
# Ref: https://github.com/NixOS/nixpkgs/issues/180175
|
|
||||||
systemd.services.NetworkManager-wait-online = {
|
|
||||||
serviceConfig.ExecStart = [
|
|
||||||
""
|
|
||||||
"${pkgs.networkmanager}/bin/nm-online -q"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
systemd.extraConfig = ''
|
systemd.extraConfig = ''
|
||||||
DefaultTimeoutStopSec=10s
|
DefaultTimeoutStopSec=10s
|
||||||
'';
|
'';
|
||||||
|
|
|
@ -1,30 +1,39 @@
|
||||||
{ pkgs, lib, ... }:
|
|
||||||
{
|
{
|
||||||
services.flatpak.enable = true;
|
pkgs,
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
options.my.containers.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
virtualisation.docker = {
|
config = lib.mkIf config.my.containers.enable {
|
||||||
enable = true;
|
services.flatpak.enable = true;
|
||||||
autoPrune = {
|
|
||||||
|
virtualisation.docker = {
|
||||||
enable = true;
|
enable = true;
|
||||||
dates = "monthly";
|
autoPrune = {
|
||||||
flags = [
|
enable = true;
|
||||||
"--all"
|
dates = "monthly";
|
||||||
"--volumes"
|
flags = [
|
||||||
];
|
"--all"
|
||||||
};
|
"--volumes"
|
||||||
daemon.settings = {
|
];
|
||||||
# needed by bitbucket runner ???
|
};
|
||||||
log-driver = "json-file";
|
daemon.settings = {
|
||||||
log-opts = {
|
# needed by bitbucket runner ???
|
||||||
max-size = "10m";
|
log-driver = "json-file";
|
||||||
max-file = "3";
|
log-opts = {
|
||||||
|
max-size = "10m";
|
||||||
|
max-file = "3";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
networking.firewall.extraCommands = lib.getExe pkgs._docker-block-external-connections;
|
||||||
|
|
||||||
|
programs.extra-container.enable = true;
|
||||||
|
|
||||||
|
programs.firejail.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.firewall.extraCommands = lib.getExe pkgs._docker-block-external-connections;
|
|
||||||
|
|
||||||
programs.extra-container.enable = true;
|
|
||||||
|
|
||||||
programs.firejail.enable = true;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,27 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
inputs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
{
|
|
||||||
programs.gamemode.enable = true;
|
|
||||||
programs.gamemode.enableRenice = true;
|
|
||||||
programs.gamemode.settings = {
|
|
||||||
general = {
|
|
||||||
renice = 10;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Warning: GPU optimisations have the potential to damage hardware
|
|
||||||
gpu = {
|
|
||||||
apply_gpu_optimisations = "accept-responsibility";
|
|
||||||
gpu_device = 0;
|
|
||||||
amd_performance_level = "high";
|
|
||||||
};
|
|
||||||
|
|
||||||
custom = {
|
|
||||||
start = "${pkgs.libnotify}/bin/notify-send 'GameMode started'";
|
|
||||||
end = "${pkgs.libnotify}/bin/notify-send 'GameMode ended'";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
63
system/gaming.nix
Normal file
63
system/gaming.nix
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
options.my.gaming.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf config.my.gaming.enable {
|
||||||
|
programs.steam.enable = true;
|
||||||
|
programs.steam.extraPackages =
|
||||||
|
config.fonts.packages
|
||||||
|
++ (with pkgs; [
|
||||||
|
capitaine-cursors
|
||||||
|
bibata-cursors
|
||||||
|
mangohud
|
||||||
|
xdg-user-dirs
|
||||||
|
gamescope
|
||||||
|
|
||||||
|
# gamescope compatibility??
|
||||||
|
xorg.libXcursor
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libXinerama
|
||||||
|
xorg.libXScrnSaver
|
||||||
|
libpng
|
||||||
|
libpulseaudio
|
||||||
|
libvorbis
|
||||||
|
stdenv.cc.cc.lib
|
||||||
|
libkrb5
|
||||||
|
keyutils
|
||||||
|
]);
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
protontricks
|
||||||
|
bottles
|
||||||
|
inputs.dzgui-nix.packages.${pkgs.system}.default
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.gamemode = {
|
||||||
|
enable = true;
|
||||||
|
enableRenice = true;
|
||||||
|
settings = {
|
||||||
|
general = {
|
||||||
|
renice = 10;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Warning: GPU optimisations have the potential to damage hardware
|
||||||
|
gpu = {
|
||||||
|
apply_gpu_optimisations = "accept-responsibility";
|
||||||
|
gpu_device = 0;
|
||||||
|
amd_performance_level = "high";
|
||||||
|
};
|
||||||
|
|
||||||
|
custom = {
|
||||||
|
start = "${pkgs.libnotify}/bin/notify-send 'GameMode started'";
|
||||||
|
end = "${pkgs.libnotify}/bin/notify-send 'GameMode ended'";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -5,10 +5,10 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.packages.media-packages;
|
cfg = config.my.media-packages;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.packages.media-packages = {
|
options.my.media-packages = {
|
||||||
enable = lib.mkEnableOption "media packages";
|
enable = lib.mkEnableOption "media packages";
|
||||||
};
|
};
|
||||||
config = lib.mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
|
|
|
@ -6,8 +6,6 @@
|
||||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
|
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
|
||||||
# Enable networking
|
# Enable networking
|
||||||
networking.networkmanager.enable = true;
|
networking.networkmanager.enable = true;
|
||||||
# Open kde connect ports
|
|
||||||
programs.kdeconnect.enable = true;
|
|
||||||
|
|
||||||
networking.firewall = {
|
networking.firewall = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -15,7 +13,7 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
# Enable CUPS to print documents.
|
# Enable CUPS to print documents.
|
||||||
# services.printing.enable = true;
|
services.printing.enable = true;
|
||||||
|
|
||||||
security.rtkit.enable = true;
|
security.rtkit.enable = true;
|
||||||
services.openssh = {
|
services.openssh = {
|
||||||
|
@ -27,4 +25,13 @@
|
||||||
KbdInteractiveAuthentication = false;
|
KbdInteractiveAuthentication = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Workaround for nm-wait-online hanging??
|
||||||
|
# Ref: https://github.com/NixOS/nixpkgs/issues/180175
|
||||||
|
systemd.services.NetworkManager-wait-online = {
|
||||||
|
serviceConfig.ExecStart = [
|
||||||
|
""
|
||||||
|
"${pkgs.networkmanager}/bin/nm-online -q"
|
||||||
|
];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,36 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
inputs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
{
|
|
||||||
programs.steam.enable = true;
|
|
||||||
programs.steam.extraPackages =
|
|
||||||
config.fonts.packages
|
|
||||||
++ (with pkgs; [
|
|
||||||
capitaine-cursors
|
|
||||||
bibata-cursors
|
|
||||||
mangohud
|
|
||||||
xdg-user-dirs
|
|
||||||
gamescope
|
|
||||||
|
|
||||||
# gamescope compatibility??
|
|
||||||
xorg.libXcursor
|
|
||||||
xorg.libXi
|
|
||||||
xorg.libXinerama
|
|
||||||
xorg.libXScrnSaver
|
|
||||||
libpng
|
|
||||||
libpulseaudio
|
|
||||||
libvorbis
|
|
||||||
stdenv.cc.cc.lib
|
|
||||||
libkrb5
|
|
||||||
keyutils
|
|
||||||
]);
|
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
protontricks
|
|
||||||
bottles
|
|
||||||
inputs.dzgui-nix.packages.${pkgs.system}.default
|
|
||||||
];
|
|
||||||
}
|
|
8
user/dummy.nix
Normal file
8
user/dummy.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{ lib, ... }:
|
||||||
|
{
|
||||||
|
options.my = {
|
||||||
|
android.enable = lib.mkEnableOption { };
|
||||||
|
media-packages.enable = lib.mkEnableOption { };
|
||||||
|
containers.enable = lib.mkEnableOption { };
|
||||||
|
};
|
||||||
|
}
|
|
@ -6,9 +6,12 @@
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (config.my) accent editor desktop;
|
inherit (config.my) accent editor desktop;
|
||||||
|
cfg = config.my.fish;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.fish.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
programs.fish = {
|
programs.fish = {
|
||||||
enable = true;
|
enable = true;
|
||||||
shellInit = ''
|
shellInit = ''
|
||||||
|
|
|
@ -2,16 +2,10 @@
|
||||||
config,
|
config,
|
||||||
pkgs,
|
pkgs,
|
||||||
lib,
|
lib,
|
||||||
inputs,
|
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
inherit (config.my) theme accent;
|
||||||
key
|
|
||||||
theme
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
;
|
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
colors = {
|
colors = {
|
||||||
|
|
24
user/gaming.nix
Normal file
24
user/gaming.nix
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
cfg = config.my.gaming;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.my.gaming.enable = lib.mkEnableOption { };
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
|
my.mangohud.enable = true;
|
||||||
|
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
# lutris-unwrapped
|
||||||
|
# steam # It's enabled in the system config
|
||||||
|
tlauncher
|
||||||
|
gamescope
|
||||||
|
glxinfo
|
||||||
|
vulkan-tools
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
|
@ -7,9 +7,13 @@
|
||||||
let
|
let
|
||||||
inherit (config.my) accent theme editor;
|
inherit (config.my) accent theme editor;
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.helix;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.helix.enable = lib.mkEnableOption "Enable helix config";
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
programs.helix = {
|
programs.helix = {
|
||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
./dummy.nix
|
||||||
./waybar
|
./waybar
|
||||||
./helix.nix
|
./helix.nix
|
||||||
./kakoune
|
./kakoune
|
||||||
|
@ -21,6 +22,7 @@
|
||||||
./rofi.nix
|
./rofi.nix
|
||||||
./mpv.nix
|
./mpv.nix
|
||||||
./mangohud.nix
|
./mangohud.nix
|
||||||
|
./gaming.nix
|
||||||
./pipewire.nix
|
./pipewire.nix
|
||||||
./mimeapps.nix
|
./mimeapps.nix
|
||||||
./desktop-entries.nix
|
./desktop-entries.nix
|
||||||
|
@ -44,7 +46,11 @@
|
||||||
./powerplay-led-idle.nix
|
./powerplay-led-idle.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
my = import ./variables.nix;
|
my = import ./variables.nix // {
|
||||||
|
sway.enable = true;
|
||||||
|
pass.enable = true;
|
||||||
|
fish.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
# Home Manager needs a bit of information about you and the
|
# Home Manager needs a bit of information about you and the
|
||||||
# paths it should manage.
|
# paths it should manage.
|
||||||
|
@ -91,14 +97,6 @@
|
||||||
mate.engrampa
|
mate.engrampa
|
||||||
# gnome.nautilus
|
# gnome.nautilus
|
||||||
|
|
||||||
## games
|
|
||||||
# lutris-unwrapped
|
|
||||||
# steam # It's enabled in the system config
|
|
||||||
tlauncher
|
|
||||||
gamescope
|
|
||||||
glxinfo
|
|
||||||
vulkan-tools
|
|
||||||
|
|
||||||
## Theming
|
## Theming
|
||||||
orchis_theme_compact
|
orchis_theme_compact
|
||||||
papirus_red
|
papirus_red
|
||||||
|
@ -130,6 +128,8 @@
|
||||||
|
|
||||||
unstable.blade-formatter
|
unstable.blade-formatter
|
||||||
nixfmt-rfc-style
|
nixfmt-rfc-style
|
||||||
|
|
||||||
|
nix-output-monitor
|
||||||
];
|
];
|
||||||
|
|
||||||
fonts.fontconfig.enable = true;
|
fonts.fontconfig.enable = true;
|
||||||
|
|
|
@ -1,80 +1,68 @@
|
||||||
{
|
{ config, lib, ... }:
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib,
|
|
||||||
font,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
cfg = config.my.mangohud;
|
||||||
key
|
|
||||||
theme
|
|
||||||
color
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
;
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.mangohud.enable = lib.mkEnableOption { };
|
||||||
programs.mangohud = {
|
|
||||||
enable = true;
|
|
||||||
enableSessionWide = true;
|
|
||||||
settings = {
|
|
||||||
full = true;
|
|
||||||
# histogram = true;
|
|
||||||
no_display = true;
|
|
||||||
fps_limit = "0,30,60,72,90,120,144,240,288,320";
|
|
||||||
toggle_fps_limit = "Shift_R+F10";
|
|
||||||
toggle_preset = "Control_R+F9";
|
|
||||||
fps_metrics = "Control_R+F8";
|
|
||||||
|
|
||||||
# legacy_layout = "false";
|
config.programs.mangohud = lib.mkIf cfg.enable {
|
||||||
# gpu_stats = true;
|
enable = true;
|
||||||
# gpu_temp = true;
|
enableSessionWide = true;
|
||||||
# gpu_core_clock = true;
|
settings = {
|
||||||
# gpu_mem_clock = true;
|
full = true;
|
||||||
# gpu_power = true;
|
# histogram = true;
|
||||||
# gpu_load_change = true;
|
no_display = true;
|
||||||
# gpu_load_value = "50,90";
|
fps_limit = "0,30,60,72,90,120,144,240,288,320";
|
||||||
gpu_load_color = "FFFFFF,FFAA7F,CC0000";
|
toggle_fps_limit = "Shift_R+F10";
|
||||||
# gpu_text = "GPU";
|
toggle_preset = "Control_R+F9";
|
||||||
# cpu_stats = true;
|
fps_metrics = "Control_R+F8";
|
||||||
# cpu_temp = true;
|
|
||||||
# cpu_power = true;
|
|
||||||
# cpu_mhz = true;
|
|
||||||
# cpu_load_change = true;
|
|
||||||
# core_load_change = true;
|
|
||||||
# cpu_load_value = "50,90";
|
|
||||||
cpu_load_color = "FFFFFF,FFAA7F,CC0000";
|
|
||||||
cpu_color = "2e97cb";
|
|
||||||
# cpu_text = "CPU";
|
|
||||||
# io_stats = true;
|
|
||||||
# io_read = true;
|
|
||||||
# io_write = true;
|
|
||||||
io_color = "a491d3";
|
|
||||||
# swap = true;
|
|
||||||
# vram = true;
|
|
||||||
vram_color = "ad64c1";
|
|
||||||
# ram = true;
|
|
||||||
ram_color = "c26693";
|
|
||||||
# fps = true;
|
|
||||||
engine_color = "eb5b5b";
|
|
||||||
gpu_color = "2e9762";
|
|
||||||
wine_color = "eb5b5b";
|
|
||||||
# frame_timing = "1";
|
|
||||||
frametime_color = "00ff00";
|
|
||||||
media_player_color = "ffffff";
|
|
||||||
background_alpha = "0.8";
|
|
||||||
font_size = "24";
|
|
||||||
|
|
||||||
background_color = "020202";
|
# legacy_layout = "false";
|
||||||
position = "top-left";
|
# gpu_stats = true;
|
||||||
# text_color = "ffffff";
|
# gpu_temp = true;
|
||||||
round_corners = "10";
|
# gpu_core_clock = true;
|
||||||
toggle_hud = "Shift_R+F12";
|
# gpu_mem_clock = true;
|
||||||
# toggle_logging = "Shift_L+F12";
|
# gpu_power = true;
|
||||||
# output_folder = "/home/lelgenio";
|
# gpu_load_change = true;
|
||||||
};
|
# gpu_load_value = "50,90";
|
||||||
|
gpu_load_color = "FFFFFF,FFAA7F,CC0000";
|
||||||
|
# gpu_text = "GPU";
|
||||||
|
# cpu_stats = true;
|
||||||
|
# cpu_temp = true;
|
||||||
|
# cpu_power = true;
|
||||||
|
# cpu_mhz = true;
|
||||||
|
# cpu_load_change = true;
|
||||||
|
# core_load_change = true;
|
||||||
|
# cpu_load_value = "50,90";
|
||||||
|
cpu_load_color = "FFFFFF,FFAA7F,CC0000";
|
||||||
|
cpu_color = "2e97cb";
|
||||||
|
# cpu_text = "CPU";
|
||||||
|
# io_stats = true;
|
||||||
|
# io_read = true;
|
||||||
|
# io_write = true;
|
||||||
|
io_color = "a491d3";
|
||||||
|
# swap = true;
|
||||||
|
# vram = true;
|
||||||
|
vram_color = "ad64c1";
|
||||||
|
# ram = true;
|
||||||
|
ram_color = "c26693";
|
||||||
|
# fps = true;
|
||||||
|
engine_color = "eb5b5b";
|
||||||
|
gpu_color = "2e9762";
|
||||||
|
wine_color = "eb5b5b";
|
||||||
|
# frame_timing = "1";
|
||||||
|
frametime_color = "00ff00";
|
||||||
|
media_player_color = "ffffff";
|
||||||
|
background_alpha = "0.8";
|
||||||
|
font_size = "24";
|
||||||
|
|
||||||
|
background_color = "020202";
|
||||||
|
position = "top-left";
|
||||||
|
# text_color = "ffffff";
|
||||||
|
round_corners = "10";
|
||||||
|
toggle_hud = "Shift_R+F12";
|
||||||
|
# toggle_logging = "Shift_L+F12";
|
||||||
|
# output_folder = "/home/lelgenio";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,8 +4,13 @@
|
||||||
config,
|
config,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
|
let
|
||||||
|
cfg = config.my.mpd;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
config = lib.mkIf (config.my.desktop != "gnome") {
|
options.my.mpd.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
services.mpd = {
|
services.mpd = {
|
||||||
enable = true;
|
enable = true;
|
||||||
musicDirectory = config.home.homeDirectory + "/Música";
|
musicDirectory = config.home.homeDirectory + "/Música";
|
||||||
|
|
|
@ -2,11 +2,15 @@
|
||||||
config,
|
config,
|
||||||
pkgs,
|
pkgs,
|
||||||
lib,
|
lib,
|
||||||
inputs,
|
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
|
let
|
||||||
|
cfg = config.my.pass;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.pass.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
programs.password-store = {
|
programs.password-store = {
|
||||||
enable = true;
|
enable = true;
|
||||||
package = pkgs.pass.withExtensions (
|
package = pkgs.pass.withExtensions (
|
||||||
|
|
|
@ -5,13 +5,10 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
inherit (config.my) accent font theme;
|
||||||
key
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
theme
|
|
||||||
;
|
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.sway;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
@ -24,10 +21,17 @@ in
|
||||||
./swaylock.nix
|
./swaylock.nix
|
||||||
./theme.nix
|
./theme.nix
|
||||||
];
|
];
|
||||||
config = lib.mkIf (config.my.desktop == "sway") {
|
|
||||||
services.mako.enable = true;
|
options.my.sway.enable = lib.mkEnableOption { };
|
||||||
services.swayidle.enable = true;
|
|
||||||
services.kanshi.enable = true;
|
config = lib.mkIf cfg.enable {
|
||||||
|
my.mako.enable = true;
|
||||||
|
my.kanshi.enable = true;
|
||||||
|
my.swayidle.enable = true;
|
||||||
|
my.swaylock.enable = true;
|
||||||
|
my.mpd.enable = true;
|
||||||
|
my.zathura.enable = true;
|
||||||
|
my.waybar.enable = true;
|
||||||
|
|
||||||
wayland.windowManager.sway = {
|
wayland.windowManager.sway = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -36,7 +40,7 @@ in
|
||||||
bars = [ ];
|
bars = [ ];
|
||||||
|
|
||||||
floating.modifier = "Mod4";
|
floating.modifier = "Mod4";
|
||||||
terminal = pkgs.alacritty.executable;
|
terminal = lib.getExe pkgs.alacritty;
|
||||||
|
|
||||||
window.titlebar = false;
|
window.titlebar = false;
|
||||||
gaps = {
|
gaps = {
|
||||||
|
@ -69,7 +73,7 @@ in
|
||||||
};
|
};
|
||||||
output = {
|
output = {
|
||||||
"*" = {
|
"*" = {
|
||||||
adaptive_sync = "off";
|
adaptive_sync = "on";
|
||||||
bg = "${theme.background} fill";
|
bg = "${theme.background} fill";
|
||||||
mode = "1920x1080@144.000Hz";
|
mode = "1920x1080@144.000Hz";
|
||||||
};
|
};
|
||||||
|
@ -132,7 +136,6 @@ in
|
||||||
swaylock
|
swaylock
|
||||||
wdisplays
|
wdisplays
|
||||||
|
|
||||||
waybar
|
|
||||||
dhist
|
dhist
|
||||||
demoji
|
demoji
|
||||||
bmenu
|
bmenu
|
||||||
|
|
|
@ -1,20 +1,12 @@
|
||||||
{
|
{ config, lib, ... }:
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
cfg = config.my.kanshi;
|
||||||
key
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
theme
|
|
||||||
;
|
|
||||||
inherit (theme) color;
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
services.kanshi = {
|
options.my.kanshi.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config.services.kanshi = lib.mkIf cfg.enable {
|
||||||
|
enable = true;
|
||||||
settings = [
|
settings = [
|
||||||
{
|
{
|
||||||
profile = {
|
profile = {
|
||||||
|
|
|
@ -6,60 +6,66 @@
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
inherit (config.my)
|
||||||
key
|
|
||||||
accent
|
accent
|
||||||
font
|
font
|
||||||
theme
|
theme
|
||||||
;
|
;
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.mako;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
services.mako = {
|
options.my.mako.enable = lib.mkEnableOption { };
|
||||||
borderSize = 2;
|
|
||||||
padding = "5";
|
|
||||||
margin = "15";
|
|
||||||
layer = "overlay";
|
|
||||||
|
|
||||||
font = "${font.interface} ${toString font.size.small}";
|
config = lib.mkIf cfg.enable {
|
||||||
textColor = color.txt;
|
services.mako = {
|
||||||
|
enable = true;
|
||||||
|
borderSize = 2;
|
||||||
|
padding = "5";
|
||||||
|
margin = "15";
|
||||||
|
layer = "overlay";
|
||||||
|
|
||||||
backgroundColor = color.bg;
|
font = "${font.interface} ${toString font.size.small}";
|
||||||
borderColor = accent.color;
|
textColor = color.txt;
|
||||||
progressColor = "over ${accent.color}88";
|
|
||||||
|
|
||||||
defaultTimeout = 10000;
|
backgroundColor = color.bg;
|
||||||
|
borderColor = accent.color;
|
||||||
|
progressColor = "over ${accent.color}88";
|
||||||
|
|
||||||
extraConfig = ''
|
defaultTimeout = 10000;
|
||||||
[app-name=volumesh]
|
|
||||||
default-timeout=5000
|
|
||||||
group-by=app-name
|
|
||||||
format=<b>%s</b>\n%b
|
|
||||||
'';
|
|
||||||
|
|
||||||
# # {{@@ header() @@}}
|
extraConfig = ''
|
||||||
# # text
|
[app-name=volumesh]
|
||||||
|
default-timeout=5000
|
||||||
|
group-by=app-name
|
||||||
|
format=<b>%s</b>\n%b
|
||||||
|
'';
|
||||||
|
|
||||||
# # features
|
# # {{@@ header() @@}}
|
||||||
# icons=1
|
# # text
|
||||||
# markup=1
|
|
||||||
# actions=1
|
|
||||||
# default-timeout=10000
|
|
||||||
|
|
||||||
# # position
|
# # features
|
||||||
# layer=overlay
|
# icons=1
|
||||||
};
|
# markup=1
|
||||||
systemd.user.services.mako = lib.mkIf (config.services.mako.enable) {
|
# actions=1
|
||||||
Unit = {
|
# default-timeout=10000
|
||||||
Description = "Notification daemon";
|
|
||||||
PartOf = [ "graphical-session.target" ];
|
# # position
|
||||||
After = [ "graphical-session.target" ];
|
# layer=overlay
|
||||||
};
|
};
|
||||||
Service = {
|
systemd.user.services.mako = lib.mkIf (config.services.mako.enable) {
|
||||||
ExecStart = "${pkgs.mako}/bin/mako";
|
Unit = {
|
||||||
Restart = "on-failure";
|
Description = "Notification daemon";
|
||||||
};
|
PartOf = [ "graphical-session.target" ];
|
||||||
Install = {
|
After = [ "graphical-session.target" ];
|
||||||
WantedBy = [ "sway-session.target" ];
|
};
|
||||||
|
Service = {
|
||||||
|
ExecStart = "${pkgs.mako}/bin/mako";
|
||||||
|
Restart = "on-failure";
|
||||||
|
};
|
||||||
|
Install = {
|
||||||
|
WantedBy = [ "sway-session.target" ];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,18 +5,15 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
|
||||||
key
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
theme
|
|
||||||
;
|
|
||||||
inherit (theme) color;
|
|
||||||
|
|
||||||
asScript = filename: text: toString (pkgs.writeShellScript filename text);
|
asScript = filename: text: toString (pkgs.writeShellScript filename text);
|
||||||
|
|
||||||
|
cfg = config.my.swayidle;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
services.swayidle = {
|
options.my.swayidle.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config.services.swayidle = {
|
||||||
|
enable = cfg.enable;
|
||||||
timeouts = [
|
timeouts = [
|
||||||
{
|
{
|
||||||
timeout = 360;
|
timeout = 360;
|
||||||
|
|
|
@ -1,20 +1,14 @@
|
||||||
{
|
{ config, lib, ... }:
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
inherit (config.my) accent font theme;
|
||||||
key
|
|
||||||
accent
|
|
||||||
font
|
|
||||||
theme
|
|
||||||
;
|
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.swaylock;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
programs.swaylock.settings = {
|
options.my.swaylock.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config.programs.swaylock.settings = lib.mkIf cfg.enable {
|
||||||
image = toString theme.background;
|
image = toString theme.background;
|
||||||
font = font.interface;
|
font = font.interface;
|
||||||
font-size = font.size.medium;
|
font-size = font.size.medium;
|
||||||
|
|
|
@ -14,9 +14,13 @@ let
|
||||||
font
|
font
|
||||||
;
|
;
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.waybar;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.waybar.enable = lib.mkEnableOption { };
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
programs.waybar = {
|
programs.waybar = {
|
||||||
enable = true;
|
enable = true;
|
||||||
systemd.enable = true;
|
systemd.enable = true;
|
||||||
|
|
|
@ -1,10 +1,4 @@
|
||||||
{
|
{ config, lib, ... }:
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib,
|
|
||||||
font,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
inherit (config.my)
|
inherit (config.my)
|
||||||
key
|
key
|
||||||
|
@ -13,56 +7,62 @@ let
|
||||||
theme
|
theme
|
||||||
;
|
;
|
||||||
inherit (theme) color;
|
inherit (theme) color;
|
||||||
|
|
||||||
|
cfg = config.my.zathura;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config = {
|
options.my.zathura.enable = lib.mkEnableOption { };
|
||||||
programs.zathura.enable = true;
|
|
||||||
programs.zathura.options = {
|
|
||||||
font = "${font.mono} ${toString font.size.small}";
|
|
||||||
guioptions = "s";
|
|
||||||
|
|
||||||
selection-clipboard = "clipboard";
|
config = lib.mkIf cfg.enable {
|
||||||
|
programs.zathura = {
|
||||||
|
enable = true;
|
||||||
|
options = {
|
||||||
|
font = "${font.mono} ${toString font.size.small}";
|
||||||
|
guioptions = "s";
|
||||||
|
|
||||||
recolor = true;
|
selection-clipboard = "clipboard";
|
||||||
# Turn images grayscale, so they don't look weird
|
|
||||||
recolor-keephue = false;
|
|
||||||
recolor-lightcolor = "rgba(0,0,0,0)";
|
|
||||||
recolor-darkcolor = color.txt;
|
|
||||||
|
|
||||||
default-bg = color.bg_dark;
|
recolor = true;
|
||||||
|
# Turn images grayscale, so they don't look weird
|
||||||
|
recolor-keephue = false;
|
||||||
|
recolor-lightcolor = "rgba(0,0,0,0)";
|
||||||
|
recolor-darkcolor = color.txt;
|
||||||
|
|
||||||
inputbar-bg = color.bg_dark;
|
default-bg = color.bg_dark;
|
||||||
inputbar-fg = color.txt;
|
|
||||||
|
|
||||||
statusbar-bg = color.bg;
|
inputbar-bg = color.bg_dark;
|
||||||
statusbar-fg = color.txt;
|
inputbar-fg = color.txt;
|
||||||
|
|
||||||
completion-bg = color.bg;
|
statusbar-bg = color.bg;
|
||||||
completion-fg = color.txt;
|
statusbar-fg = color.txt;
|
||||||
|
|
||||||
completion-group-bg = color.bg_dark;
|
completion-bg = color.bg;
|
||||||
completion-group-fg = color.txt;
|
completion-fg = color.txt;
|
||||||
|
|
||||||
completion-highlight-bg = accent.color;
|
completion-group-bg = color.bg_dark;
|
||||||
completion-highlight-fg = accent.fg;
|
completion-group-fg = color.txt;
|
||||||
|
|
||||||
index-active-bg = accent.color;
|
completion-highlight-bg = accent.color;
|
||||||
index-active-fg = accent.fg;
|
completion-highlight-fg = accent.fg;
|
||||||
};
|
|
||||||
programs.zathura.mappings = {
|
index-active-bg = accent.color;
|
||||||
"<C-b>" = "toggle_statusbar";
|
index-active-fg = accent.fg;
|
||||||
${key.left} = "scroll left";
|
};
|
||||||
${key.down} = "scroll down";
|
mappings = {
|
||||||
${key.up} = "scroll up";
|
"<C-b>" = "toggle_statusbar";
|
||||||
${key.right} = "scroll right";
|
${key.left} = "scroll left";
|
||||||
"[index] ${key.left}" = "navigate_index collapse";
|
${key.down} = "scroll down";
|
||||||
"[index] ${key.down}" = "navigate_index down";
|
${key.up} = "scroll up";
|
||||||
"[index] ${key.up}" = "navigate_index up";
|
${key.right} = "scroll right";
|
||||||
"[index] ${key.right}" = "navigate_index expand";
|
"[index] ${key.left}" = "navigate_index collapse";
|
||||||
${lib.toUpper key.down} = "navigate next";
|
"[index] ${key.down}" = "navigate_index down";
|
||||||
${lib.toUpper key.up} = "navigate previous";
|
"[index] ${key.up}" = "navigate_index up";
|
||||||
${key.next} = "search forward";
|
"[index] ${key.right}" = "navigate_index expand";
|
||||||
${lib.toUpper key.next} = "search backward";
|
${lib.toUpper key.down} = "navigate next";
|
||||||
|
${lib.toUpper key.up} = "navigate previous";
|
||||||
|
${key.next} = "search forward";
|
||||||
|
${lib.toUpper key.next} = "search backward";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue