feature/homepage widgets
This commit is contained in:
@@ -29,7 +29,7 @@ in
|
||||
|
||||
my.homepage.services = [
|
||||
{
|
||||
group = "Home";
|
||||
group = "Services";
|
||||
name = "Home Assistant";
|
||||
description = "Home automation";
|
||||
href = "http://${hostName}:8123";
|
||||
|
||||
@@ -4,8 +4,8 @@
|
||||
{
|
||||
Github = [
|
||||
{
|
||||
abbr = "GH";
|
||||
href = "https://github.com/";
|
||||
abbr = "GitLab - Smoothcloud";
|
||||
href = "https://gitlab.smoothcloud.de/";
|
||||
}
|
||||
];
|
||||
}
|
||||
|
||||
@@ -10,6 +10,7 @@ let
|
||||
dashboardHost = config.networking.hostName;
|
||||
dashboardUrl = "http://${dashboardHost}:${toString dashboardPort}";
|
||||
manualServices = import ./manual-services.nix;
|
||||
manualWidgets = import ./manual-widgets.nix;
|
||||
|
||||
groupedServices =
|
||||
lib.foldl'
|
||||
@@ -79,6 +80,12 @@ in
|
||||
description = "Merged homepage service metadata contributed by repo modules.";
|
||||
};
|
||||
|
||||
options.my.homepage.widgets = with lib; mkOption {
|
||||
type = types.listOf types.attrs;
|
||||
default = [ ];
|
||||
description = "Widget definitions passed directly to services.homepage-dashboard.widgets. Each entry is an attrset like { resources = { cpu = true; memory = true; }; }.";
|
||||
};
|
||||
|
||||
options.my.profiles.homepage = with lib; {
|
||||
enable = mkEnableOption "getHomepage.dev Dashboard";
|
||||
};
|
||||
@@ -90,6 +97,7 @@ in
|
||||
allowedHosts = "${dashboardHost}:${toString dashboardPort},localhost:${toString dashboardPort},127.0.0.1:${toString dashboardPort},jupiter.solar.internal:${toString dashboardPort}";
|
||||
bookmarks = import ./bookmarks.nix;
|
||||
services = homepageServices ++ manualServices;
|
||||
widgets = config.my.homepage.widgets ++ manualWidgets;
|
||||
};
|
||||
|
||||
users.users.finn.packages = with pkgs; [
|
||||
|
||||
@@ -1,14 +1,28 @@
|
||||
[
|
||||
# Example:
|
||||
# {
|
||||
# "Infrastructure" = [
|
||||
# {
|
||||
# "Proxmox" = {
|
||||
# href = "https://proxmox.example.local";
|
||||
# description = "Virtualization host";
|
||||
# icon = "proxmox.png";
|
||||
# };
|
||||
# }
|
||||
# ];
|
||||
# }
|
||||
{
|
||||
"Services" = [
|
||||
{
|
||||
"Tesla - Dashboard" = {
|
||||
href = "https://grafana.smoothcloud.de";
|
||||
description = "Tesla Information";
|
||||
icon = "tesla.png";
|
||||
};
|
||||
}
|
||||
{
|
||||
"GitLab" = {
|
||||
href = "https://gitlab.smoothcloud.de";
|
||||
description = "Selfhosted GitLab";
|
||||
icon = "gitlab.png";
|
||||
};
|
||||
}
|
||||
{
|
||||
"Nextcloud" = {
|
||||
href = "https://next.smoothcloud.de";
|
||||
description = "Selfhosted Cloud Service";
|
||||
icon = "nextcloud.png";
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
||||
]
|
||||
|
||||
@@ -0,0 +1,6 @@
|
||||
[
|
||||
# Example:
|
||||
{ resources = { cpu = true; memory = true; disk = "/"; }; }
|
||||
{ datetime = { text_size = "xl"; format = { timeStyle = "short"; }; }; }
|
||||
{ search = {provider = "google"; focus = true; target = "_blank"; }; }
|
||||
]
|
||||
@@ -35,7 +35,7 @@ in
|
||||
|
||||
my.homepage.services = [
|
||||
{
|
||||
group = "Documents";
|
||||
group = "Services";
|
||||
name = "Paperless";
|
||||
description = "Document management";
|
||||
href = "http://${hostName}:${toString cfg.port}";
|
||||
|
||||
Reference in New Issue
Block a user