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:
parent
616dbd67f7
commit
71a5ce7f01
|
@ -548,6 +548,12 @@ in
|
||||||
time = "2018-02-02T11:15:00+00:00";
|
time = "2018-02-02T11:15:00+00:00";
|
||||||
message = ''
|
message = ''
|
||||||
A new program configuration is available: 'programs.mercurial'
|
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/random-background.nix
|
||||||
./services/redshift.nix
|
./services/redshift.nix
|
||||||
./services/screen-locker.nix
|
./services/screen-locker.nix
|
||||||
|
./services/stalonetray.nix
|
||||||
./services/syncthing.nix
|
./services/syncthing.nix
|
||||||
./services/taffybar.nix
|
./services/taffybar.nix
|
||||||
./services/tahoe-lafs.nix
|
./services/tahoe-lafs.nix
|
||||||
|
|
97
modules/services/stalonetray.nix
Normal file
97
modules/services/stalonetray.nix
Normal 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;
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
|
@ -52,7 +52,10 @@ with lib;
|
||||||
qsyncthingtray = {
|
qsyncthingtray = {
|
||||||
Unit = {
|
Unit = {
|
||||||
Description = "QSyncthingTray";
|
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" ];
|
PartOf = [ "graphical-session.target" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue