stalonetray: add modulue

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`.

Have also taken the liberty of adding "stalonetray.service" to the list
of system tray services in `services.syncthing`. However, I've been unable
to test this.
This commit is contained in:
Alistair Potts 2018-02-02 15:25:51 +00:00
parent 616dbd67f7
commit 71a5ce7f01
4 changed files with 108 additions and 1 deletions

View file

@ -548,6 +548,12 @@ in
time = "2018-02-02T11:15:00+00:00";
message = ''
A new program configuration is available: 'programs.mercurial'
}
{
time = "2018-02-03T10:00:00+00:00";
message = ''
A new module is available: 'services.stalonetray'
'';
}
];

View file

@ -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

View file

@ -0,0 +1,97 @@
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.stalonetray;
package = pkgs.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 = [ pkgs.stalonetray ];
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 = "${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;
})
]);
}

View file

@ -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" ];
};