mirror of
https://github.com/nix-community/home-manager
synced 2025-01-11 11:39:49 +01:00
stalonetray: add module
Adds a service for the Stalonetray system tray. Configured through a 'config' attribute set, which writes space separated key value pairs on successive lines to `~/.stalonetrayrc`.
This commit is contained in:
parent
616dbd67f7
commit
91a98f919d
4 changed files with 106 additions and 1 deletions
|
@ -550,6 +550,13 @@ in
|
|||
A new program configuration is available: 'programs.mercurial'
|
||||
'';
|
||||
}
|
||||
|
||||
{
|
||||
time = "2018-02-03T10:00:00+00:00";
|
||||
message = ''
|
||||
A new module is available: 'services.stalonetray'
|
||||
'';
|
||||
}
|
||||
];
|
||||
};
|
||||
}
|
||||
|
|
|
@ -57,6 +57,7 @@ let
|
|||
./services/random-background.nix
|
||||
./services/redshift.nix
|
||||
./services/screen-locker.nix
|
||||
./services/stalonetray.nix
|
||||
./services/syncthing.nix
|
||||
./services/taffybar.nix
|
||||
./services/tahoe-lafs.nix
|
||||
|
|
94
modules/services/stalonetray.nix
Normal file
94
modules/services/stalonetray.nix
Normal file
|
@ -0,0 +1,94 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
|
||||
cfg = config.services.stalonetray;
|
||||
|
||||
in
|
||||
|
||||
{
|
||||
options = {
|
||||
services.stalonetray = {
|
||||
enable = mkEnableOption "Stalonetray system tray";
|
||||
|
||||
package = mkOption {
|
||||
default = pkgs.stalonetray;
|
||||
defaultText = "pkgs.stalonetray";
|
||||
type = types.package;
|
||||
example = literalExample "pkgs.stalonetray";
|
||||
description = "The package to use for the Stalonetray binary.";
|
||||
};
|
||||
|
||||
config = mkOption {
|
||||
type = with types;
|
||||
attrsOf (nullOr (either str (either bool int)));
|
||||
description = ''
|
||||
Stalonetray configuration as a set of attributes.
|
||||
'';
|
||||
default = {};
|
||||
example = {
|
||||
geometry = "3x1-600+0";
|
||||
decorations = null;
|
||||
icon_size = 30;
|
||||
sticky = true;
|
||||
background = "#cccccc";
|
||||
};
|
||||
};
|
||||
|
||||
extraConfig = mkOption {
|
||||
type = types.lines;
|
||||
description = "Additional configuration lines for stalonetrayrc.";
|
||||
default = "";
|
||||
example = ''
|
||||
geometry 3x1-600+0
|
||||
decorations none
|
||||
icon_size 30
|
||||
sticky true
|
||||
background "#cccccc"
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable (mkMerge [
|
||||
{
|
||||
home.packages = [ cfg.package ];
|
||||
|
||||
systemd.user.services.stalonetray = {
|
||||
Unit = {
|
||||
Description = "Stalonetray system tray";
|
||||
After = [ "graphical-session-pre.target" ];
|
||||
PartOf = [ "graphical-session.target" ];
|
||||
};
|
||||
|
||||
Install = {
|
||||
WantedBy = [ "graphical-session.target" ];
|
||||
};
|
||||
|
||||
Service = {
|
||||
ExecStart = "${cfg.package}/bin/stalonetray";
|
||||
Restart = "on-failure";
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
(mkIf (cfg.config != {}) {
|
||||
home.file.".stalonetrayrc".text =
|
||||
let
|
||||
valueToString = v:
|
||||
if isBool v then (if v then "true" else "false")
|
||||
else if (v==null) then "none"
|
||||
else ''"${toString v}"'';
|
||||
in
|
||||
concatStrings (
|
||||
mapAttrsToList (k: v: "${k} ${valueToString v}\n") cfg.config
|
||||
);
|
||||
})
|
||||
|
||||
(mkIf (cfg.extraConfig != "") {
|
||||
home.file.".stalonetrayrc".text = cfg.extraConfig;
|
||||
})
|
||||
]);
|
||||
}
|
|
@ -52,7 +52,10 @@ with lib;
|
|||
qsyncthingtray = {
|
||||
Unit = {
|
||||
Description = "QSyncthingTray";
|
||||
After = [ "graphical-session-pre.target" "polybar.service" "taffybar.service" ];
|
||||
After = [ "graphical-session-pre.target"
|
||||
"polybar.service"
|
||||
"taffybar.service"
|
||||
"stalonetray.service" ];
|
||||
PartOf = [ "graphical-session.target" ];
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue