calcite: switch to niri
This commit is contained in:
parent
62ca7ce8af
commit
3b393a74f5
10 changed files with 473 additions and 123 deletions
|
@ -1,4 +1,7 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
|
let
|
||||||
|
homeDirectory = "/home/xin";
|
||||||
|
in
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./common
|
./common
|
||||||
|
@ -6,9 +9,11 @@
|
||||||
|
|
||||||
programs.nix-index-database.comma.enable = true;
|
programs.nix-index-database.comma.enable = true;
|
||||||
|
|
||||||
home.username = "xin";
|
home = {
|
||||||
home.homeDirectory = "/home/xin";
|
inherit homeDirectory;
|
||||||
home.stateVersion = "23.05";
|
username = "xin";
|
||||||
|
stateVersion = "23.05";
|
||||||
|
};
|
||||||
|
|
||||||
# Let Home Manager install and manage itself.
|
# Let Home Manager install and manage itself.
|
||||||
programs.home-manager.enable = true;
|
programs.home-manager.enable = true;
|
||||||
|
@ -79,22 +84,30 @@
|
||||||
zellij = {
|
zellij = {
|
||||||
enable = true;
|
enable = true;
|
||||||
};
|
};
|
||||||
|
gui = {
|
||||||
|
niri.enable = true;
|
||||||
|
waybar.enable = true;
|
||||||
|
fuzzel.enable = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.gnome-shell.enable = true;
|
xdg.systemDirs.data = [
|
||||||
|
"/usr/share"
|
||||||
|
"/var/lib/flatpak/exports/share"
|
||||||
|
"${homeDirectory}/.local/share/flatpak/exports/share"
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.man.generateCaches = false;
|
||||||
|
|
||||||
programs.atuin = {
|
programs.atuin = {
|
||||||
enable = true;
|
enable = true;
|
||||||
flags = [ "--disable-up-arrow" ];
|
flags = [ "--disable-up-arrow" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.firefox.enable = true;
|
programs.firefox = {
|
||||||
|
enable = true;
|
||||||
programs.firefox.policies = {
|
policies.DefaultDownloadDirectory = "/media/data/Downloads";
|
||||||
DefaultDownloadDirectory = "/media/data/Downloads";
|
profiles.default = {
|
||||||
};
|
|
||||||
|
|
||||||
programs.firefox.profiles.default = {
|
|
||||||
isDefault = true;
|
isDefault = true;
|
||||||
userChrome = ''
|
userChrome = ''
|
||||||
#titlebar {
|
#titlebar {
|
||||||
|
@ -174,4 +187,6 @@
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,6 +51,8 @@
|
||||||
|
|
||||||
networking.hostName = "calcite";
|
networking.hostName = "calcite";
|
||||||
|
|
||||||
|
services.blueman.enable = true;
|
||||||
|
|
||||||
programs.steam = {
|
programs.steam = {
|
||||||
enable = true;
|
enable = true;
|
||||||
gamescopeSession = {
|
gamescopeSession = {
|
||||||
|
@ -96,18 +98,15 @@
|
||||||
LC_TIME = "en_US.utf8";
|
LC_TIME = "en_US.utf8";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Enable the X11 windowing system.
|
services.displayManager = {
|
||||||
services.xserver.enable = true;
|
enable = true;
|
||||||
|
defaultSession = "niri";
|
||||||
# Enable the GNOME Desktop Environment.
|
|
||||||
services.xserver.displayManager.gdm.enable = true;
|
|
||||||
services.xserver.desktopManager.gnome.enable = true;
|
|
||||||
|
|
||||||
# Configure keymap in X11
|
|
||||||
services.xserver = {
|
|
||||||
xkb.layout = "us";
|
|
||||||
xkb.variant = "";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
programs.niri.enable = true;
|
||||||
|
|
||||||
|
services.xserver.displayManager.gdm.enable = true;
|
||||||
|
|
||||||
# Keyboard mapping on internal keyboard
|
# Keyboard mapping on internal keyboard
|
||||||
services.keyd = {
|
services.keyd = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -163,17 +162,9 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Enable automatic login for the user.
|
|
||||||
services.displayManager.autoLogin.enable = true;
|
|
||||||
services.displayManager.autoLogin.user = "xin";
|
|
||||||
|
|
||||||
# Smart services
|
# Smart services
|
||||||
services.smartd.enable = true;
|
services.smartd.enable = true;
|
||||||
|
|
||||||
# Workaround for GNOME autologin: https://github.com/NixOS/nixpkgs/issues/103746#issuecomment-945091229
|
|
||||||
systemd.services."getty@tty1".enable = false;
|
|
||||||
systemd.services."autovt@tty1".enable = false;
|
|
||||||
|
|
||||||
# Allow unfree packages
|
# Allow unfree packages
|
||||||
nixpkgs.config.allowUnfree = true;
|
nixpkgs.config.allowUnfree = true;
|
||||||
nixpkgs.config.permittedInsecurePackages = [
|
nixpkgs.config.permittedInsecurePackages = [
|
||||||
|
@ -227,14 +218,6 @@
|
||||||
|
|
||||||
eudic
|
eudic
|
||||||
|
|
||||||
# Gnome tweaks
|
|
||||||
gnomeExtensions.paperwm
|
|
||||||
gnomeExtensions.search-light
|
|
||||||
gnomeExtensions.appindicator
|
|
||||||
gnomeExtensions.pano
|
|
||||||
gnome-tweaks
|
|
||||||
gnome-themes-extra
|
|
||||||
gnome-remote-desktop
|
|
||||||
bibata-cursors
|
bibata-cursors
|
||||||
gthumb
|
gthumb
|
||||||
oculante
|
oculante
|
||||||
|
@ -247,8 +230,6 @@
|
||||||
element-desktop
|
element-desktop
|
||||||
tdesktop
|
tdesktop
|
||||||
qq
|
qq
|
||||||
wechat-uos
|
|
||||||
feishu
|
|
||||||
|
|
||||||
# Password manager
|
# Password manager
|
||||||
bitwarden
|
bitwarden
|
||||||
|
@ -304,15 +285,22 @@
|
||||||
custom.restic.repositoryFile = config.sops.secrets.restic_repo_calcite.path;
|
custom.restic.repositoryFile = config.sops.secrets.restic_repo_calcite.path;
|
||||||
custom.restic.passwordFile = config.sops.secrets.restic_repo_calcite_password.path;
|
custom.restic.passwordFile = config.sops.secrets.restic_repo_calcite_password.path;
|
||||||
|
|
||||||
custom.forgejo-actions-runner.enable = false;
|
custom.forgejo-actions-runner = {
|
||||||
custom.forgejo-actions-runner.tokenFile = config.sops.secrets."gitea/envfile".path;
|
enable = false;
|
||||||
|
tokenFile = config.sops.secrets."gitea/envfile".path;
|
||||||
|
settings = {
|
||||||
|
runner.capacity = 2;
|
||||||
|
runner.fetch_timeout = "120s";
|
||||||
|
runner.fetch_interval = "30s";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
custom.prometheus = {
|
custom.prometheus = {
|
||||||
enable = true;
|
enable = true;
|
||||||
exporters.blackbox.enable = true;
|
exporters.blackbox.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
custom.stylix.enable = true;
|
custom.stylix.enable = false;
|
||||||
|
|
||||||
services.ollama = {
|
services.ollama = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -322,6 +310,9 @@
|
||||||
# MTP support
|
# MTP support
|
||||||
services.gvfs.enable = true;
|
services.gvfs.enable = true;
|
||||||
|
|
||||||
|
services.flatpak.enable = true;
|
||||||
|
xdg.portal.enable = true;
|
||||||
|
|
||||||
# Fonts
|
# Fonts
|
||||||
fonts = {
|
fonts = {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
|
@ -330,6 +321,8 @@
|
||||||
"FiraCode"
|
"FiraCode"
|
||||||
"FiraMono"
|
"FiraMono"
|
||||||
"JetBrainsMono"
|
"JetBrainsMono"
|
||||||
|
"RobotoMono"
|
||||||
|
"Ubuntu"
|
||||||
];
|
];
|
||||||
})
|
})
|
||||||
noto-fonts
|
noto-fonts
|
||||||
|
|
|
@ -79,4 +79,6 @@
|
||||||
dynamicBoost.enable = lib.mkForce false;
|
dynamicBoost.enable = lib.mkForce false;
|
||||||
open = true;
|
open = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
hardware.bluetooth.enable = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ restic_repo_calcite_password: ENC[AES256_GCM,data:9ALTQULAMyLY4FIxuVztf9r3,iv:fO
|
||||||
restic_repo_calcite: ENC[AES256_GCM,data:ELvSvoBfulbsoMvRMt2bVo9KiNQAuHomblZcAwJ+g0tHELkq65kaaGwMsNy1AttBfiD7RrQsKifX/YTUGmuz1mDg0WqkV/Mv,iv:HKz96YgVahxh+t3AEqe09mTE01uT+VrUYt04H6zyS9g=,tag:llFeeN7ryTZI9gLlYIRhCg==,type:str]
|
restic_repo_calcite: ENC[AES256_GCM,data:ELvSvoBfulbsoMvRMt2bVo9KiNQAuHomblZcAwJ+g0tHELkq65kaaGwMsNy1AttBfiD7RrQsKifX/YTUGmuz1mDg0WqkV/Mv,iv:HKz96YgVahxh+t3AEqe09mTE01uT+VrUYt04H6zyS9g=,tag:llFeeN7ryTZI9gLlYIRhCg==,type:str]
|
||||||
sing_box_url: ENC[AES256_GCM,data:2z2bDKdn51o1eaqhgE0pTg4FWcO8wcLNlnBZ69Q3Jm5GCxkXxsxN7DgqQvRVeakOHvaenQotF+nc6tlhKPsyzdQeG0yl3YYhGb9o3DkmpUjC6lalMSoiw1rSMVyBg4KYCWxmhR9iRurun62+5INGZwwHVqAjgWJhy/9+pdIFtgKyd/t0JhSU,iv:gIGbvRd88vZu3cVW7e4emZmmNO8QcubLrxS1sCwi4Co=,tag:AzLLtcA9jAbeuo6eWU6ilw==,type:str]
|
sing_box_url: ENC[AES256_GCM,data:2z2bDKdn51o1eaqhgE0pTg4FWcO8wcLNlnBZ69Q3Jm5GCxkXxsxN7DgqQvRVeakOHvaenQotF+nc6tlhKPsyzdQeG0yl3YYhGb9o3DkmpUjC6lalMSoiw1rSMVyBg4KYCWxmhR9iRurun62+5INGZwwHVqAjgWJhy/9+pdIFtgKyd/t0JhSU,iv:gIGbvRd88vZu3cVW7e4emZmmNO8QcubLrxS1sCwi4Co=,tag:AzLLtcA9jAbeuo6eWU6ilw==,type:str]
|
||||||
gitea:
|
gitea:
|
||||||
envfile: ENC[AES256_GCM,data:bO1aMYm0kPTBbyPD5cweVRzNjiDK2WlWDsxz52L3faFg5HSVmBoi5DZC17XBXYw=,iv:lo9XEcwY4FPD/rRbnuiUviioMIiiphS26UgPro56DIU=,tag:0eKfsS0pYw+FPW+Y5dgisg==,type:str]
|
envfile: ENC[AES256_GCM,data:CK+JNELuzjKgWnImuV4Euif3f3nNOACOrvc4NiIXs+q/F7QWrtpb3TK8/FrLNQk=,iv:QSDrlKJCBld2gDx/y1sT8anh37GhqSS2QZd2JJi5Yis=,tag:x5T6h59LBXhEyVwSr2dnuQ==,type:str]
|
||||||
sops:
|
sops:
|
||||||
kms: []
|
kms: []
|
||||||
gcp_kms: []
|
gcp_kms: []
|
||||||
|
@ -27,8 +27,8 @@ sops:
|
||||||
WGlLdXVoZlp3bEFXZjlMdG1VOUZDNUkKQ2NNTE3OsNUr2pOI7qeNFSCVkUIVRS+g
|
WGlLdXVoZlp3bEFXZjlMdG1VOUZDNUkKQ2NNTE3OsNUr2pOI7qeNFSCVkUIVRS+g
|
||||||
FG5FbJJcFihXqr+Qo0nZkq+xq07vIia7mKoqyoIfkKwweiVzDKyrkQ==
|
FG5FbJJcFihXqr+Qo0nZkq+xq07vIia7mKoqyoIfkKwweiVzDKyrkQ==
|
||||||
-----END AGE ENCRYPTED FILE-----
|
-----END AGE ENCRYPTED FILE-----
|
||||||
lastmodified: "2024-09-12T16:48:39Z"
|
lastmodified: "2024-11-09T06:41:02Z"
|
||||||
mac: ENC[AES256_GCM,data:sYY8N0HZ05sUV7m/w5L1pFWJb2V8wZNukyUXHH0V9LMO1JlJMwCUH2XuseLGz5kz0yggAF+fty/x16PBvI5ARcpaZ23pLmNFYHtpx2tWhWcyYg/yMAqjUf19o17IZ50GpLVkmRHQbowwZF9dcHr8mEicrftZbeORzg2eKVkx8+w=,iv:0fyqOrs2XQ363uX5Dr8zuoUzkHdtsQ/v3SZidFBeSr4=,tag:1Kw1jrruxfn9lxgtL0XEMA==,type:str]
|
mac: ENC[AES256_GCM,data:Hf8QYvRWxfs/JDOIAVnX5M0kv9Ktncfzq+Zf7i32TTsa94ShrgbUYVxQbRviOFDbjLfzswGKikLQ2EHLlH1KOFs7+mKKz5PKVAWJZnkAPa2oFXs41BcXLIg8sf4dhFxjzzhakeUX9Q0z4evJ1vMX06/VnnpHVSMhsnenSfBhWIA=,iv:uXKf2oYSb+0IWp6Ch0XuoFUIaUBiAW7Z8R9Z7LSdLvY=,tag:0VAcFakwCrHGZW5I8jmydA==,type:str]
|
||||||
pgp: []
|
pgp: []
|
||||||
unencrypted_suffix: _unencrypted
|
unencrypted_suffix: _unencrypted
|
||||||
version: 3.9.0
|
version: 3.9.1
|
||||||
|
|
|
@ -9,5 +9,6 @@
|
||||||
./vim.nix
|
./vim.nix
|
||||||
./vscode.nix
|
./vscode.nix
|
||||||
./zellij.nix
|
./zellij.nix
|
||||||
|
./gui
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
7
modules/home-manager/gui/default.nix
Normal file
7
modules/home-manager/gui/default.nix
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
./niri.nix
|
||||||
|
./fuzzel.nix
|
||||||
|
./waybar.nix
|
||||||
|
];
|
||||||
|
}
|
14
modules/home-manager/gui/fuzzel.nix
Normal file
14
modules/home-manager/gui/fuzzel.nix
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
let
|
||||||
|
inherit (lib) mkIf mkEnableOption;
|
||||||
|
cfg = config.custom-hm.gui.fuzzel;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.custom-hm.gui.fuzzel = {
|
||||||
|
enable = mkEnableOption "fuzzel";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
programs.fuzzel.enable = true;
|
||||||
|
};
|
||||||
|
}
|
88
modules/home-manager/gui/niri.nix
Normal file
88
modules/home-manager/gui/niri.nix
Normal file
|
@ -0,0 +1,88 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (lib) mkIf mkEnableOption;
|
||||||
|
cfg = config.custom-hm.gui.niri;
|
||||||
|
wallpaper = pkgs.fetchurl {
|
||||||
|
url = "https://github.com/NixOS/nixos-artwork/blob/master/wallpapers/nixos-wallpaper-catppuccin-mocha.png?raw=true";
|
||||||
|
hash = "sha256-fmKFYw2gYAYFjOv4lr8IkXPtZfE1+88yKQ4vjEcax1s=";
|
||||||
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.custom-hm.gui.niri = {
|
||||||
|
enable = mkEnableOption "niri";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
xwayland-satellite
|
||||||
|
cosmic-files
|
||||||
|
];
|
||||||
|
home.pointerCursor = {
|
||||||
|
name = "Bibata-Modern-Ice";
|
||||||
|
size = 24;
|
||||||
|
package = pkgs.bibata-cursors;
|
||||||
|
gtk.enable = true;
|
||||||
|
};
|
||||||
|
gtk = {
|
||||||
|
enable = true;
|
||||||
|
theme = {
|
||||||
|
name = "Catppuccin-GTK-Dark";
|
||||||
|
package = pkgs.magnetic-catppuccin-gtk;
|
||||||
|
};
|
||||||
|
gtk2.configLocation = "${config.xdg.configHome}/gtk-2.0/gtkrc";
|
||||||
|
};
|
||||||
|
services.network-manager-applet.enable = true;
|
||||||
|
|
||||||
|
systemd.user.services.swaybg = {
|
||||||
|
Install = {
|
||||||
|
WantedBy = [ "graphical-session.target" ];
|
||||||
|
};
|
||||||
|
Unit = {
|
||||||
|
PartOf = [ "graphical-session.target" ];
|
||||||
|
After = [ "graphical-session.target" ];
|
||||||
|
};
|
||||||
|
Service = {
|
||||||
|
ExecStart = "${lib.getExe pkgs.swaybg} -i ${wallpaper} -m fill";
|
||||||
|
Restart = "on-failure";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.swaylock = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
show-failed-attempts = true;
|
||||||
|
daemonize = true;
|
||||||
|
scaling = "fill";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.user.services.swayidle.Unit.After = [ "graphical-session.target" ];
|
||||||
|
|
||||||
|
services = {
|
||||||
|
swayidle = {
|
||||||
|
enable = true;
|
||||||
|
timeouts = [
|
||||||
|
{
|
||||||
|
timeout = 900;
|
||||||
|
command = "/run/current-system/systemd/bin/systemctl suspend";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
events = [
|
||||||
|
{
|
||||||
|
event = "lock";
|
||||||
|
command = "${pkgs.swaylock}/bin/swaylock";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
event = "before-sleep";
|
||||||
|
command = "/run/current-system/systemd/bin/loginctl lock-session";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
57
modules/home-manager/gui/waybar.css
Normal file
57
modules/home-manager/gui/waybar.css
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
* {
|
||||||
|
font-family: Ubuntu Nerd Font, Noto Sans CJK SC;
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: bold;
|
||||||
|
min-height: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
window#waybar {
|
||||||
|
color: @text;
|
||||||
|
opacity: 0.95;
|
||||||
|
background-color: @crust;
|
||||||
|
padding: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#custom-nixos {
|
||||||
|
background-color: #24273a;
|
||||||
|
padding-left: 15px;
|
||||||
|
padding-right: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#custom-separator {
|
||||||
|
margin: 0 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#workspaces {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
#workspaces button {
|
||||||
|
padding: 0 10px;
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
#workspaces button.focused,
|
||||||
|
#workspaces button.active {
|
||||||
|
border-bottom: 4px solid #8aadf4;
|
||||||
|
}
|
||||||
|
#workspaces button.empty {
|
||||||
|
font-size: 0;
|
||||||
|
min-width: 0;
|
||||||
|
min-height: 0;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: 0;
|
||||||
|
opacity: 0;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
#cpu,
|
||||||
|
#memory,
|
||||||
|
#pulseaudio,
|
||||||
|
#network,
|
||||||
|
#backlight,
|
||||||
|
#battery,
|
||||||
|
#tray {
|
||||||
|
margin-right: 15px;
|
||||||
|
}
|
||||||
|
#clock {
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
173
modules/home-manager/gui/waybar.nix
Normal file
173
modules/home-manager/gui/waybar.nix
Normal file
|
@ -0,0 +1,173 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (lib) mkIf mkEnableOption readFile;
|
||||||
|
cfg = config.custom-hm.gui.waybar;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.custom-hm.gui.waybar = {
|
||||||
|
enable = mkEnableOption "waybar";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
programs.waybar = {
|
||||||
|
enable = true;
|
||||||
|
style = readFile ./waybar.css;
|
||||||
|
settings = {
|
||||||
|
main = {
|
||||||
|
margin = "2px 3px 2 3px";
|
||||||
|
height = 30;
|
||||||
|
layer = "top";
|
||||||
|
"custom/nixos" = {
|
||||||
|
format = "";
|
||||||
|
interval = "once";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
"custom/separator" = {
|
||||||
|
format = " ";
|
||||||
|
interval = "once";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
modules-left = [
|
||||||
|
"custom/nixos"
|
||||||
|
"niri/workspaces"
|
||||||
|
"custom/separator"
|
||||||
|
"niri/window"
|
||||||
|
];
|
||||||
|
modules-center = [
|
||||||
|
"clock"
|
||||||
|
];
|
||||||
|
modules-right = [
|
||||||
|
"network#speed"
|
||||||
|
"custom/separator"
|
||||||
|
"network#if"
|
||||||
|
"custom/separator"
|
||||||
|
"pulseaudio"
|
||||||
|
"custom/separator"
|
||||||
|
"memory"
|
||||||
|
"custom/separator"
|
||||||
|
"cpu"
|
||||||
|
"custom/separator"
|
||||||
|
"backlight"
|
||||||
|
"custom/separator"
|
||||||
|
"battery"
|
||||||
|
"custom/separator"
|
||||||
|
"tray"
|
||||||
|
];
|
||||||
|
"niri/workspaces" = {
|
||||||
|
all-outputs = true;
|
||||||
|
format = "{icon}";
|
||||||
|
format-icons = {
|
||||||
|
"terminal" = "";
|
||||||
|
"browser" = "";
|
||||||
|
"chat" = "";
|
||||||
|
"mail" = "";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
"niri/window" = {
|
||||||
|
max-length = 50;
|
||||||
|
};
|
||||||
|
pulseaudio = {
|
||||||
|
format = "{icon} {volume}% {format_source}";
|
||||||
|
format-bluetooth = "{icon} {volume}% {format_source}";
|
||||||
|
format-bluetooth-muted = " {icon} {format_source}";
|
||||||
|
format-icons = {
|
||||||
|
car = "";
|
||||||
|
default = [
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
];
|
||||||
|
hands-free = "";
|
||||||
|
headphone = "";
|
||||||
|
headset = "";
|
||||||
|
phone = "";
|
||||||
|
portable = "";
|
||||||
|
};
|
||||||
|
format-muted = " {format_source}";
|
||||||
|
format-source = " {volume}%";
|
||||||
|
format-source-muted = "";
|
||||||
|
on-click = "${pkgs.pavucontrol}/bin/pavucontrol";
|
||||||
|
};
|
||||||
|
backlight = {
|
||||||
|
format = " {percent}%";
|
||||||
|
on-scroll-down = "${pkgs.brightnessctl}/bin/brightnessctl set 1%-";
|
||||||
|
on-scroll-up = "${pkgs.brightnessctl}/bin/brightnessctl set +1%";
|
||||||
|
};
|
||||||
|
battery = {
|
||||||
|
interval = 10;
|
||||||
|
format = "{icon} {capacity}%";
|
||||||
|
format-charging = "{icon} {capacity}% ";
|
||||||
|
format-plugged = "{icon} {capacity}% ";
|
||||||
|
format-icons = [
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
];
|
||||||
|
};
|
||||||
|
clock = {
|
||||||
|
format = "{:%a %b %d %H:%M}";
|
||||||
|
tooltip-format = "<big>{:%Y %B}</big>\n<tt><small>{calendar}</small></tt>";
|
||||||
|
};
|
||||||
|
memory = {
|
||||||
|
format = " {percentage}%";
|
||||||
|
};
|
||||||
|
|
||||||
|
"network#if" = {
|
||||||
|
format = "{ifname}";
|
||||||
|
format-disconnected = "";
|
||||||
|
format-ethernet = "";
|
||||||
|
format-linked = "{ifname} (No IP) ";
|
||||||
|
format-wifi = "{icon}";
|
||||||
|
format-icons = [
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
""
|
||||||
|
];
|
||||||
|
interval = 10;
|
||||||
|
};
|
||||||
|
|
||||||
|
"network#speed" = {
|
||||||
|
format = "{ifname}";
|
||||||
|
format-disconnected = "";
|
||||||
|
format-ethernet = " {bandwidthDownBytes} {bandwidthUpBytes}";
|
||||||
|
format-linked = "";
|
||||||
|
format-wifi = " {bandwidthDownBytes} {bandwidthUpBytes}";
|
||||||
|
interval = 5;
|
||||||
|
max-length = 30;
|
||||||
|
tooltip-format = "{ipaddr}";
|
||||||
|
tooltip-format-disconnected = " Disconnected";
|
||||||
|
tooltip-format-ethernet = "{ifname} ";
|
||||||
|
tooltip-format-wifi = "{essid} {icon} {signalStrength}%";
|
||||||
|
};
|
||||||
|
|
||||||
|
cpu = {
|
||||||
|
format = " {usage}%";
|
||||||
|
interval = 5;
|
||||||
|
};
|
||||||
|
|
||||||
|
tray = {
|
||||||
|
icon-size = 18;
|
||||||
|
spacing = 14;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
systemd.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.user.targets.tray = {
|
||||||
|
Unit = {
|
||||||
|
Description = "Home Manager System Tray";
|
||||||
|
Requires = [ "graphical-session-pre.target" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue