forked from Fediversity/fediversity.eu
36 lines
1 KiB
Nix
36 lines
1 KiB
Nix
|
{ config, options, lib, ... }:
|
||
|
let
|
||
|
inherit (lib)
|
||
|
mkOption
|
||
|
types
|
||
|
;
|
||
|
cfg = config;
|
||
|
in
|
||
|
{
|
||
|
content-types. article = { config, collection, ... }: {
|
||
|
imports = [ cfg.content-types.page ];
|
||
|
options = {
|
||
|
collection = mkOption {
|
||
|
description = "Collection this article belongs to";
|
||
|
type = options.collections.type.nestedTypes.elemType;
|
||
|
default = collection;
|
||
|
};
|
||
|
date = mkOption {
|
||
|
description = "Publication date";
|
||
|
type = with types; str;
|
||
|
default = null;
|
||
|
};
|
||
|
author = mkOption {
|
||
|
description = "Page author";
|
||
|
type = with types; either str (nonEmptyListOf str);
|
||
|
default = null;
|
||
|
};
|
||
|
};
|
||
|
config.name = lib.slug config.title;
|
||
|
# TODO: this should be covered by the TBD `link` function instead,
|
||
|
# taking a historical list of collection names into account
|
||
|
config.outPath = "${collection.name}/${lib.head config.locations}";
|
||
|
config.outputs.html = lib.mkForce (cfg.templates.html.article cfg config);
|
||
|
};
|
||
|
}
|