2022-03-10 21:52:12 +01:00
|
|
|
{
|
|
|
|
|
pkgs,
|
|
|
|
|
wirelessInterface,
|
|
|
|
|
colours,
|
|
|
|
|
batteryName,
|
|
|
|
|
}: let
|
2020-09-24 19:16:51 +02:00
|
|
|
inherit (pkgs) lib;
|
|
|
|
|
|
2020-06-10 17:37:25 +02:00
|
|
|
setsid = script:
|
|
|
|
|
pkgs.writers.writeDash "setsid-command" ''
|
|
|
|
|
${pkgs.utillinux}/bin/setsid ${script}
|
|
|
|
|
'';
|
2020-08-17 16:03:21 +02:00
|
|
|
coronaBlock = {
|
|
|
|
|
block = "custom";
|
|
|
|
|
interval = 60 * 2; # every two minutes
|
|
|
|
|
command = pkgs.writers.writeDash "corona" ''
|
|
|
|
|
${pkgs.curl}/bin/curl https://corona-stats.online/germany \
|
|
|
|
|
| ${pkgs.gnugrep}/bin/grep Germany \
|
|
|
|
|
| ${pkgs.gnused}/bin/sed 's/\s*//g' \
|
|
|
|
|
| ${pkgs.ansifilter}/bin/ansifilter \
|
|
|
|
|
| ${pkgs.gawk}/bin/awk -F'│' '{print "🤒 " $8 " 💀 " $5}'
|
|
|
|
|
'';
|
|
|
|
|
};
|
2020-06-10 17:37:25 +02:00
|
|
|
in {
|
2019-11-05 21:59:51 +01:00
|
|
|
theme = {
|
|
|
|
|
name = "plain";
|
|
|
|
|
overrides = {
|
|
|
|
|
critical_fg = colours.red.bright;
|
|
|
|
|
good_fg = colours.green.bright;
|
|
|
|
|
idle_fg = colours.foreground;
|
2022-08-19 11:26:27 +02:00
|
|
|
info_fg = colours.cyan.bright;
|
2019-11-05 21:59:51 +01:00
|
|
|
warning_fg = colours.yellow.bright;
|
2020-05-31 18:25:39 +02:00
|
|
|
warning_bg = colours.background;
|
2019-11-05 21:59:51 +01:00
|
|
|
alternating_tint_bg = colours.background;
|
|
|
|
|
alternating_tint_fg = colours.background;
|
|
|
|
|
critical_bg = colours.background;
|
|
|
|
|
good_bg = colours.background;
|
|
|
|
|
idle_bg = colours.background;
|
|
|
|
|
info_bg = colours.background;
|
2022-08-18 18:47:12 +02:00
|
|
|
separator = "";
|
2020-05-31 18:25:39 +02:00
|
|
|
separator_bg = "auto";
|
2020-09-03 19:16:49 +02:00
|
|
|
separator_fg = colours.black.bright;
|
2019-11-05 21:59:51 +01:00
|
|
|
};
|
|
|
|
|
};
|
2020-04-13 11:02:37 +02:00
|
|
|
icons = {
|
|
|
|
|
name = "none";
|
|
|
|
|
overrides = {
|
|
|
|
|
bat = "🔋";
|
|
|
|
|
bat_charging = "🔌";
|
|
|
|
|
bat_discharging = "🔋";
|
2020-08-26 11:33:16 +02:00
|
|
|
bat_empty = " ";
|
|
|
|
|
bat_full = " ";
|
|
|
|
|
bat_half = " ";
|
|
|
|
|
bat_quarter = " ";
|
|
|
|
|
bat_three_quarters = " ";
|
|
|
|
|
cogs = "🚦 ";
|
|
|
|
|
cpu = "🖥 ";
|
2021-06-01 19:14:00 +02:00
|
|
|
disk_drive = "💽";
|
2020-08-26 11:33:16 +02:00
|
|
|
mail = "📧 ";
|
|
|
|
|
memory_mem = "🧠 ";
|
|
|
|
|
music = "🎵";
|
|
|
|
|
music_next = "⏭";
|
|
|
|
|
music_pause = "";
|
|
|
|
|
music_play = "▶";
|
|
|
|
|
music_prev = "⏮";
|
2020-04-23 13:15:34 +02:00
|
|
|
net_down = "❎";
|
2020-08-26 11:33:16 +02:00
|
|
|
net_up = "🌐";
|
2020-04-22 17:42:45 +02:00
|
|
|
net_vpn = "🛡 ";
|
2020-08-26 11:33:16 +02:00
|
|
|
net_wired = "🌐";
|
|
|
|
|
net_wireless = "📶";
|
|
|
|
|
pomodoro = "🍅 ";
|
2022-08-19 11:27:17 +02:00
|
|
|
tasks = "✅";
|
2020-08-26 11:33:16 +02:00
|
|
|
time = "📅 ";
|
2020-04-23 13:15:34 +02:00
|
|
|
toggle_off = "👎";
|
|
|
|
|
toggle_on = "👍";
|
2022-08-19 11:26:56 +02:00
|
|
|
update = "🆕";
|
2020-08-26 11:33:16 +02:00
|
|
|
volume_empty = "🔈 ";
|
2020-04-22 17:42:45 +02:00
|
|
|
volume_full = "🔊 ";
|
|
|
|
|
volume_half = "🔉 ";
|
2020-08-26 11:33:16 +02:00
|
|
|
volume_muted = "🔇";
|
2021-04-04 11:12:17 +02:00
|
|
|
weather_clouds = "🌥";
|
2021-06-01 19:14:00 +02:00
|
|
|
weather_default = "🌡";
|
2021-04-04 11:12:17 +02:00
|
|
|
weather_rain = "🌧";
|
|
|
|
|
weather_snow = "🌨";
|
2021-06-01 19:14:00 +02:00
|
|
|
weather_sun = "🌣";
|
2021-04-04 11:12:17 +02:00
|
|
|
weather_thunder = "🌩";
|
2020-04-13 11:02:37 +02:00
|
|
|
};
|
|
|
|
|
};
|
2019-11-05 21:59:51 +01:00
|
|
|
block = [
|
2021-04-04 11:12:17 +02:00
|
|
|
{
|
|
|
|
|
block = "weather";
|
2021-04-05 10:08:01 +02:00
|
|
|
autolocate = true;
|
2021-06-01 19:14:00 +02:00
|
|
|
format = "{location}: {temp}C";
|
2021-04-04 11:12:17 +02:00
|
|
|
service = {
|
|
|
|
|
name = "openweathermap";
|
|
|
|
|
api_key = lib.strings.fileContents <secrets/openweathermap.key>;
|
|
|
|
|
city_id = "2950159";
|
|
|
|
|
units = "metric";
|
|
|
|
|
};
|
|
|
|
|
}
|
2021-10-19 17:59:14 +02:00
|
|
|
{
|
|
|
|
|
block = "custom";
|
2021-11-24 18:19:46 +01:00
|
|
|
interval = 60 * 5;
|
2022-03-10 21:52:12 +01:00
|
|
|
command = let
|
|
|
|
|
spacetime = import <niveum/configs/spacetime.nix>;
|
|
|
|
|
in
|
|
|
|
|
pkgs.writers.writePython3 "sun.py" {
|
|
|
|
|
libraries = [pkgs.python3Packages.astral];
|
|
|
|
|
flakeIgnore = ["E121" "E501"];
|
2021-11-13 23:39:01 +01:00
|
|
|
}
|
2022-03-10 21:52:12 +01:00
|
|
|
''
|
|
|
|
|
import astral
|
|
|
|
|
import astral.moon
|
|
|
|
|
import astral.sun
|
2021-11-13 23:39:01 +01:00
|
|
|
|
2022-03-10 21:52:12 +01:00
|
|
|
moon_phases = {
|
|
|
|
|
0: "🌑",
|
|
|
|
|
3.5: "🌒",
|
|
|
|
|
7: "🌓",
|
|
|
|
|
10.5: "🌔",
|
|
|
|
|
14: "🌕",
|
|
|
|
|
17.5: "🌖",
|
|
|
|
|
21: "🌗",
|
|
|
|
|
24.5: "🌘",
|
|
|
|
|
28: "🌑",
|
|
|
|
|
}
|
|
|
|
|
current_phase = astral.moon.phase()
|
|
|
|
|
closest_phase = min(moon_phases.keys(), key=lambda x: abs(current_phase - x))
|
2021-10-24 18:22:55 +02:00
|
|
|
|
2022-03-10 21:52:12 +01:00
|
|
|
city = astral.LocationInfo("Berlin", "Germany", "${spacetime.time.timeZone}", ${toString spacetime.location.latitude}, ${toString spacetime.location.longitude})
|
|
|
|
|
sun = astral.sun.sun(city.observer, date=astral.today(), tzinfo=city.timezone)
|
|
|
|
|
|
|
|
|
|
print("🌅 {} 🌇 {} {} {}".format(sun["sunrise"].strftime("%R"), sun["sunset"].strftime("%R"), moon_phases[closest_phase], round(current_phase, 1)))
|
|
|
|
|
'';
|
2021-10-19 17:59:14 +02:00
|
|
|
}
|
2022-08-19 11:48:58 +02:00
|
|
|
{
|
|
|
|
|
block = "custom";
|
|
|
|
|
interval = 10;
|
|
|
|
|
command = "newsboat-unread-count";
|
|
|
|
|
json = true;
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
block = "custom";
|
|
|
|
|
interval = 10;
|
|
|
|
|
command = pkgs.writers.writeDash "todo" ''
|
|
|
|
|
${pkgs.todoman}/bin/todo --porcelain | ${pkgs.jq}/bin/jq -r '
|
|
|
|
|
map(select(.due != null))
|
|
|
|
|
| (map(select(.due < now)) | length) as $overdue
|
|
|
|
|
| (map(select(.due >= now and .due < now + (60 * 60 * 24))) | length) as $dueToday
|
|
|
|
|
| {
|
|
|
|
|
icon: "tasks",
|
|
|
|
|
text: "\($overdue)+\($dueToday)",
|
|
|
|
|
state: (
|
|
|
|
|
if $overdue > 0 then
|
|
|
|
|
"Critical"
|
2022-08-19 14:22:17 +02:00
|
|
|
elif $dueToday > 0 then
|
|
|
|
|
"Warning"
|
2022-08-19 11:48:58 +02:00
|
|
|
else
|
2022-08-19 14:22:17 +02:00
|
|
|
"Idle"
|
2022-08-19 11:48:58 +02:00
|
|
|
end
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
'
|
|
|
|
|
'';
|
|
|
|
|
json = true;
|
|
|
|
|
}
|
2022-01-27 16:25:10 +01:00
|
|
|
{
|
2021-05-18 20:38:26 +02:00
|
|
|
block = "custom";
|
|
|
|
|
interval = 5;
|
2022-01-27 16:25:10 +01:00
|
|
|
command = pkgs.writers.writeDash "hu-berlin-vpn" ''
|
2022-03-10 21:52:12 +01:00
|
|
|
PATH=${lib.makeBinPath [pkgs.systemd]}
|
2022-08-19 11:27:28 +02:00
|
|
|
(systemctl is-active --quiet openvpn-hu-berlin.service && echo "OVPN") \
|
|
|
|
|
|| (systemctl is-active --quiet hu-vpn.service && echo "PPP-VPN") \
|
|
|
|
|
|| :
|
2021-05-18 20:38:26 +02:00
|
|
|
'';
|
2022-01-27 16:25:10 +01:00
|
|
|
}
|
2019-11-05 21:59:51 +01:00
|
|
|
{
|
|
|
|
|
block = "net";
|
2020-10-30 11:05:26 +01:00
|
|
|
device = wirelessInterface;
|
2021-06-01 19:14:00 +02:00
|
|
|
format = "{ssid} {signal_strength}";
|
2019-11-05 21:59:51 +01:00
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
block = "battery";
|
2020-10-30 11:05:26 +01:00
|
|
|
device = batteryName;
|
2019-11-05 21:59:51 +01:00
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
block = "sound";
|
2020-01-24 10:09:04 +01:00
|
|
|
on_click = "pavucontrol";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
block = "disk_space";
|
2021-06-01 19:14:00 +02:00
|
|
|
format = "{icon} {available}";
|
2019-11-05 21:59:51 +01:00
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
block = "memory";
|
|
|
|
|
display_type = "memory";
|
2021-06-01 19:14:00 +02:00
|
|
|
format_mem = "{mem_used;G}";
|
2019-11-05 21:59:51 +01:00
|
|
|
clickable = false;
|
|
|
|
|
}
|
2022-03-10 21:52:12 +01:00
|
|
|
{block = "load";}
|
2019-11-05 21:59:51 +01:00
|
|
|
{
|
2022-08-19 11:27:43 +02:00
|
|
|
block = "custom";
|
|
|
|
|
interval = 10;
|
|
|
|
|
json = true;
|
|
|
|
|
command = pkgs.writers.writeDash "time" ''
|
|
|
|
|
${pkgs.jq}/bin/jq -n \
|
|
|
|
|
--arg now "$(${pkgs.coreutils}/bin/date +'%Y-%m-%d (%W %a) %H:%M')" \
|
|
|
|
|
--argjson nextEvent "$(
|
|
|
|
|
${pkgs.khal}/bin/khal list --format "{start}" --day-format "" $(${pkgs.coreutils}/bin/date +'%Y-%m-%d %H:%M') 2>/dev/null \
|
|
|
|
|
| ${pkgs.gnugrep}/bin/grep -E '[0-9]{2}:[0-9]{2}' \
|
|
|
|
|
| ${pkgs.coreutils}/bin/head -1 \
|
|
|
|
|
| ${pkgs.coreutils}/bin/date --date="$(cat)" +%s
|
|
|
|
|
)" \
|
2022-08-19 11:29:42 +02:00
|
|
|
'{
|
2022-08-19 11:27:43 +02:00
|
|
|
text: $now,
|
|
|
|
|
icon: "time",
|
|
|
|
|
state: (
|
2022-08-19 11:29:42 +02:00
|
|
|
($nextEvent - now) as $deltaT
|
|
|
|
|
| if $deltaT < (5 * 60) then
|
2022-08-19 11:27:43 +02:00
|
|
|
"Critical"
|
|
|
|
|
elif $deltaT < (15 * 60) then
|
|
|
|
|
"Warning"
|
|
|
|
|
elif $deltaT < (60 * 60) then
|
|
|
|
|
"Info"
|
|
|
|
|
else
|
|
|
|
|
"Idle"
|
|
|
|
|
end
|
|
|
|
|
)
|
|
|
|
|
}'
|
|
|
|
|
'';
|
2019-11-05 21:59:51 +01:00
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
}
|