2023-01-27 05:20:00 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
cfg = config.programs.papis;
|
|
|
|
|
|
|
|
defaultLibraries = remove null
|
|
|
|
(mapAttrsToList (n: v: if v.isDefault then n else null) cfg.libraries);
|
|
|
|
|
|
|
|
settingsIni = (lib.mapAttrs (n: v: v.settings) cfg.libraries) // {
|
|
|
|
settings = cfg.settings // { "default-library" = head defaultLibraries; };
|
|
|
|
};
|
|
|
|
|
|
|
|
in {
|
2023-06-22 10:16:28 +02:00
|
|
|
meta.maintainers = [ ];
|
2023-01-27 05:20:00 +01:00
|
|
|
|
|
|
|
options.programs.papis = {
|
2023-07-01 01:30:13 +02:00
|
|
|
enable = mkEnableOption (lib.mdDoc "papis");
|
2023-01-27 05:20:00 +01:00
|
|
|
|
|
|
|
settings = mkOption {
|
|
|
|
type = with types; attrsOf (oneOf [ bool int str ]);
|
|
|
|
default = { };
|
|
|
|
example = literalExpression ''
|
|
|
|
{
|
|
|
|
editor = "nvim";
|
|
|
|
file-browser = "ranger"
|
|
|
|
add-edit = true;
|
|
|
|
}
|
|
|
|
'';
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2023-01-27 05:20:00 +01:00
|
|
|
Configuration written to
|
2023-07-01 01:30:13 +02:00
|
|
|
{file}`$XDG_CONFIG_HOME/papis/config`. See
|
|
|
|
<https://papis.readthedocs.io/en/latest/configuration.html>
|
2023-01-27 05:20:00 +01:00
|
|
|
for supported values.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
libraries = mkOption {
|
|
|
|
type = types.attrsOf (types.submodule ({ config, name, ... }: {
|
|
|
|
options = {
|
|
|
|
name = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = name;
|
|
|
|
readOnly = true;
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "This library's name.";
|
2023-01-27 05:20:00 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
isDefault = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
example = true;
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2023-01-27 05:20:00 +01:00
|
|
|
Whether this is a default library. There must be exactly one
|
|
|
|
default library.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
settings = mkOption {
|
|
|
|
type = with types; attrsOf (oneOf [ bool int str ]);
|
|
|
|
default = { };
|
|
|
|
example = literalExpression ''
|
|
|
|
{
|
|
|
|
dir = "~/papers/";
|
|
|
|
}
|
|
|
|
'';
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2023-01-27 05:20:00 +01:00
|
|
|
Configuration for this library.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}));
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "Attribute set of papis libraries.";
|
2023-01-27 05:20:00 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
assertions = [{
|
|
|
|
assertion = cfg.libraries == { } || length defaultLibraries == 1;
|
|
|
|
message = "Must have exactly one default papis library, but found "
|
|
|
|
+ toString (length defaultLibraries)
|
|
|
|
+ optionalString (length defaultLibraries > 1)
|
|
|
|
(", namely " + concatStringsSep "," defaultLibraries);
|
|
|
|
}];
|
|
|
|
|
|
|
|
home.packages = [ pkgs.papis ];
|
|
|
|
|
|
|
|
xdg.configFile."papis/config" =
|
|
|
|
mkIf (cfg.libraries != { }) { text = generators.toINI { } settingsIni; };
|
|
|
|
};
|
|
|
|
}
|