diff options
| author | Caroline Larimore <caroline@larimo.re> | 2024-09-17 21:37:33 -0700 |
|---|---|---|
| committer | Caroline Larimore <caroline@larimo.re> | 2024-09-17 21:37:33 -0700 |
| commit | 6bc6e37af5b21b0356d0e008f83eee5378fc8b43 (patch) | |
| tree | 0fd4e2fdf9ddd1937b3a02de57d11e4ff1ade6fc /roles/home/desktop/eww/panels | |
| parent | 485dc4b641f6b07def1bfa28c7c3ab83e764f29e (diff) | |
home: desktop: update eww widgets
Diffstat (limited to 'roles/home/desktop/eww/panels')
| -rw-r--r-- | roles/home/desktop/eww/panels/bar.css | 39 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/bar.yuck | 102 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/cpu.yuck | 45 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/default.css | 4 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/default.yuck | 7 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/fs.css | 13 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/fs.yuck | 74 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/launcher.css | 7 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/launcher.yuck | 27 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/memory.yuck | 28 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/music.css | 38 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/music.yuck | 102 | ||||
| -rw-r--r-- | roles/home/desktop/eww/panels/volume.yuck | 40 |
13 files changed, 526 insertions, 0 deletions
diff --git a/roles/home/desktop/eww/panels/bar.css b/roles/home/desktop/eww/panels/bar.css new file mode 100644 index 0000000..a07c3b1 --- /dev/null +++ b/roles/home/desktop/eww/panels/bar.css @@ -0,0 +1,39 @@ +.bar .shutdown { + color: @brightRed; +} + +.bar .restart { + color: @brightGreen; +} + +.bar .sleep { + color: @brightYellow; +} + +.bar .dismiss { + color: @red; +} + +.bar .ws { + font-family: 'Symbols Nerd Font Mono'; + font-size: 18; + + color: @bg2; +} + +.bar .ws.active { + color: @fg4; +} + +.bar .ws.visible { + color: @fg; +} + +.bar .ws.focused { + background: @bg1; + color: @fg0; +} + +.bar .ws.urgent { + background: @red; +} diff --git a/roles/home/desktop/eww/panels/bar.yuck b/roles/home/desktop/eww/panels/bar.yuck new file mode 100644 index 0000000..6dc4771 --- /dev/null +++ b/roles/home/desktop/eww/panels/bar.yuck @@ -0,0 +1,102 @@ +(defwidget bar [] + (centerbox :class "bar" + :orientation "h" + + (box + :orientation "h" + :spacing 8 + :space-evenly false + + (tooltip :class "panel" + {EWW_TIME} + {formattime(EWW_TIME, "%T", "America/Los_Angeles")} + ) + + (tooltip :class "panel" + {formattime(EWW_TIME, "%F", "America/Los_Angeles")} + {formattime(EWW_TIME, "%A, %B %d, %Y", "America/Los_Angeles")} + ) + ) + + (box + :orientation "h" + :spacing 8 + :space-evenly false + + ;(label :class "panel" + ; :text "i have no idea what to put here :3" + ;) + + (box :class "unpadded panel" + (ws :num 0 :icon "" :name "Main") + (ws :num 1 :icon "" :name "Terminal") + (ws :num 2 :icon "" :name "Browser") + (ws :num 3 :icon "" :name "Chat") + (ws :num 4 :icon "" :name "Gaming") + (ws :num 5 :icon "" :name "5") + (ws :num 6 :icon "" :name "6") + (ws :num 7 :icon "" :name "7") + (ws :num 8 :icon "" :name "Meow") + (ws :num 9 :icon "" :name "Music") + (ws :num 10 :icon "" :name "Misc") + ) + ) + + (box + :orientation "h" + :spacing 8 + :space-evenly false + :halign "end" + + (box :class "unpadded panel" + :space-evenly false + (button :class "sleep icon" + :width 31 + "" + ) + + (button :class "restart icon" + :width 33 + "" + ) + + (button :class "shutdown icon" + :width 31 + "" + ) + ) + + (box :class "unpadded panel" + (button :class "dismiss icon" + :width 29 + :onclick `${EWW_CMD} close sys` + "" + ) + ) + ) + ) +) + +(defwidget ws [num icon name] + (tooltip {name} + (button :class {"ws" + + (ws-status[num].active ? " active" : "") + + (ws-status[num].visible ? " visible" : "") + + (ws-status[num].focused ? " focused" : "") + + (ws-status[num].urgent ? " urgent" : "") + } + :width { + num == 0 ? 31 : + num == 10 ? 31 : + 33 + } + + {icon} + ) + ) +) + +(defpoll ws-status + :interval "0.1s" + `i3-msg -t get_workspaces | jq -caM 'map({"ws-\\(.num)": {visible, focused, urgent, active: true}}) | add as $orig | [range(0;11)] | [.[] as $i | $orig."ws-\\($i)" // {visible: false, focused: false, urgent: false, active: false}]'` +) diff --git a/roles/home/desktop/eww/panels/cpu.yuck b/roles/home/desktop/eww/panels/cpu.yuck new file mode 100644 index 0000000..ef57fa6 --- /dev/null +++ b/roles/home/desktop/eww/panels/cpu.yuck @@ -0,0 +1,45 @@ +(defwidget cpu [] + (box :class "panel" + :orientation "h" + :spacing 8 + :space-evenly false + + (tooltip :class "cutout" + {round(EWW_CPU.avg, 2) + "%"} + (graph + :value {EWW_CPU.avg} + :time-range "30s" + :width 76 + :height 76 + :hexpand true + ) + ) + + (box :orientation "v" + :spacing 8 + :space-evenly false + :hexpand true + + (label :halign "start" :markup {"<b>" + cpu-name + "</b>"}) + + (stat :key "Temperature" :value {round(EWW_TEMPS.K10TEMP_TCTL, 2) + "°C"}) + (stat :key "Frequency" :value {round(cpu-max-freq * cpu-freq/100, 0) + " MHz"}) + (stat :key "Usage" :value {round(EWW_CPU.avg, 2) + "%"}) + ) + ) +) + +(defpoll cpu-freq + :interval "2s" + `lscpu | sed -n '/CPU(s) scaling MHz/ s/.*:\\s*\\(.*\\)%/\\1/p'` +) + +(defpoll cpu-max-freq + :interval "9999s" + `lscpu | sed -n '/CPU max MHz/ s/.*:\\s*\\(.*\\)/\\1/p'` +) + +(defpoll cpu-name + :interval "9999s" + `lscpu | sed -n '/Model name/ s/.*:\\s*\\(.*\\)/\\1/p'` +) diff --git a/roles/home/desktop/eww/panels/default.css b/roles/home/desktop/eww/panels/default.css new file mode 100644 index 0000000..8cd39a3 --- /dev/null +++ b/roles/home/desktop/eww/panels/default.css @@ -0,0 +1,4 @@ +@import "bar.css"; +@import "fs.css"; +@import "launcher.css"; +@import "music.css"; diff --git a/roles/home/desktop/eww/panels/default.yuck b/roles/home/desktop/eww/panels/default.yuck new file mode 100644 index 0000000..3c20c4b --- /dev/null +++ b/roles/home/desktop/eww/panels/default.yuck @@ -0,0 +1,7 @@ +(include "./panels/bar.yuck") +(include "./panels/cpu.yuck") +(include "./panels/fs.yuck") +(include "./panels/launcher.yuck") +(include "./panels/memory.yuck") +(include "./panels/music.yuck") +(include "./panels/volume.yuck") diff --git a/roles/home/desktop/eww/panels/fs.css b/roles/home/desktop/eww/panels/fs.css new file mode 100644 index 0000000..8ca2dd2 --- /dev/null +++ b/roles/home/desktop/eww/panels/fs.css @@ -0,0 +1,13 @@ +.disks .meter.almost-full .progress { + color: @orange; + background: rgba(0, 0, 0, 0); +} + +.disks .meter.full .progress { + color: @red; + background: rgba(0, 0, 0, 0); +} + +.zfs .total { + font-weight: bold; +} diff --git a/roles/home/desktop/eww/panels/fs.yuck b/roles/home/desktop/eww/panels/fs.yuck new file mode 100644 index 0000000..54bbd46 --- /dev/null +++ b/roles/home/desktop/eww/panels/fs.yuck @@ -0,0 +1,74 @@ +(defwidget disks [] + (box :class "panel disks" + :orientation "h" + :spacing 8 + :space-evenly false + :height {100+16} + + (disk :mount "total" + :zfs true + :name "zpool" + ) + + (disk :mount "/mnt/4tb" + :name "4tb" + ) + (disk :mount "/mnt/ssd" + :name "ssd" + ) + ) +) + +(defwidget zfs [] + (box :class "panel zfs" + :orientation "v" + :spacing 8 + :space-evenly false + :hexpand true + + (label :halign "start" :markup "<b>ZFS Volumes</b>") + + (zvol :mount "/nix") + (zvol :mount "/persist") + + (zvol :class "faint" + :mount "/home" + ) + + (zvol :class "faint" + :mount "/" + ) + + (zvol :class "total" + :mount "total" + :name "Total" + ) + ) +) + +(defwidget disk [mount ?name ?zfs] + (meter + :value { + (zfs == true ? zpool : disks)[mount].used / ((zfs == true ? zpool : disks)[mount].used + (zfs == true ? zpool : disks)[mount].free) * 100} + :label {name != "" ? name : mount} + + {round((zfs == true ? zpool : disks)[mount].used/1024/1024, 0) + " GiB"} + ) +) + +(defwidget zvol [mount ?name ?class] + (stat :class {class} + :key {name != "" ? name : mount} + :value {round(zpool[mount].used/1024/1024, 2) + " GiB"} + ) +) + +(defpoll disks + :interval "10s" + `df -x fuse -x tmpfs -x efivarfs -x devtmpfs -x zfs | tail -n +2 | awk '{ printf "%s free %d\\n%s used %d\\n", $6, $4, $6, $3 }' | xargs printf '{"%s": {"%s": %d}}\\n' | jq -scaM 'map(to_entries) | flatten | group_by(.key) | map({"\\(.[0].key)": map(.value | to_entries) | flatten | from_entries}) | add'` +) + +(defpoll zpool + :interval "10s" + `df -t zfs --total | tail -n +2 | awk '{ printf "%s free %d\\n%s used %d\\n", $6, $4, $6, $3 }' | xargs printf '{"%s": {"%s": %d}}\\n' | jq -scaM 'map(to_entries) | flatten | group_by(.key) | map({"\\(.[0].key)": map(.value | to_entries) | flatten | from_entries}) | add | .total = ."-" | del(."-") | .total.free = ."/zpool".free'` +) diff --git a/roles/home/desktop/eww/panels/launcher.css b/roles/home/desktop/eww/panels/launcher.css new file mode 100644 index 0000000..5055191 --- /dev/null +++ b/roles/home/desktop/eww/panels/launcher.css @@ -0,0 +1,7 @@ +.launcher entry { + border-radius: 0; +} + +.launcher entry:focus { + box-shadow: 0 0 0 2px @accent inset; +} diff --git a/roles/home/desktop/eww/panels/launcher.yuck b/roles/home/desktop/eww/panels/launcher.yuck new file mode 100644 index 0000000..a568346 --- /dev/null +++ b/roles/home/desktop/eww/panels/launcher.yuck @@ -0,0 +1,27 @@ +(defwidget launcher [] + (box :class "launcher panel" + :orientation "v" + :spacing 8 + :space-evenly false + :height {556 - ((128 + 16 + 4) + 8)} + :width 768 + + (input + :valign "start" + ) + + (scroll + :vscroll true + :hscroll false + :vexpand true + + (literal :content {lunch}) + ) + ) +) + +(defpoll lunch + :interval "60s" + ;`~/lunch.sh` + `~/code/lunch/zig-out/bin/lunch` +) diff --git a/roles/home/desktop/eww/panels/memory.yuck b/roles/home/desktop/eww/panels/memory.yuck new file mode 100644 index 0000000..4f6633a --- /dev/null +++ b/roles/home/desktop/eww/panels/memory.yuck @@ -0,0 +1,28 @@ +(defwidget memory [] + (box :class "panel" + :orientation "v" + :spacing 8 + :space-evenly false + + (box + (label :markup "<b>Memory</b>" + :halign "start" + ) + + (label :markup {round(EWW_RAM.used_mem/1024/1024/1024, 2) + " GiB / " + round(EWW_RAM.total_mem/1024/1024/1024, 2) + " GiB"} + :halign "end" + ) + ) + + (tooltip :class "cutout" + {round(EWW_RAM.used_mem_perc, 2) + "%"} + (graph + :hexpand true + :value {EWW_RAM.used_mem} + :max {EWW_RAM.total_mem} + :time-range "30s" + :height 100 + ) + ) + ) +) diff --git a/roles/home/desktop/eww/panels/music.css b/roles/home/desktop/eww/panels/music.css new file mode 100644 index 0000000..e5bbc60 --- /dev/null +++ b/roles/home/desktop/eww/panels/music.css @@ -0,0 +1,38 @@ +.music { + padding: 8px; + opacity: 1.0; +} + +.music .right { + margin-top: 8px; +} + +.music .song-title { + font-size: 17px; + font-weight: bold; +} + +.music .song-album { + color: @fg2; +} + +.music .song-artist { + color: @fg2; +} + +.music scale trough { + background: @bg2; + min-height: 4px; +} + +.music scale highlight { + background: @accent; +} + +.music scale slider { + box-shadow: none; + background: @accent; + margin: -6px; + min-height: 0; + min-width: 0; +} diff --git a/roles/home/desktop/eww/panels/music.yuck b/roles/home/desktop/eww/panels/music.yuck new file mode 100644 index 0000000..757efd5 --- /dev/null +++ b/roles/home/desktop/eww/panels/music.yuck @@ -0,0 +1,102 @@ + +(defwidget music [] + (box :class "panel music" + :orientation "h" + :spacing 8 + :space-evenly false + :height {128 + 16 + 4} + + (image + :path song-cover + :image-width 128 + :image-height 128 + ) + + (box :class "right" + :orientation "v" + :spacing 0 + :space-evenly true + :hexpand true + + (box :class "info" + :orientation "v" + :space-evenly false + :valign "center" + + (tooltip {song.title} + (label :class "song-title" + :text {song.title} + :halign "start" + :truncate true + ) + ) + (tooltip {song.album} + (label :class "song-album" + :text {song.album} + :halign "start" + :truncate true + ) + ) + (tooltip {song.artist} + (label :class "song-artist" + :text {song.artist} + :halign "start" + :truncate true + ) + ) + ) + + (box + :valign "end" + :space-evenly false + + (box :class "control" + :space-evenly false + + (button :class "icon" + :width 36 + :onclick `playerctl --player=cmus,firefox,%any previous` + + "" + ) + (button :class "icon" + :onclick `playerctl --player=cmus,firefox,%any play-pause` + :width 36 + + { song.status == "Playing" ? "" : "" } + ) + (button :class "icon" + :width 36 + :onclick `playerctl --player=cmus,firefox,%any next` + + "" + ) + ) + + (scale + :hexpand true + :value {song-position} + :max {song.length/1000/1000} + ;:onchange `/home/c/seek.sh {}` + ) + + {formattime(round(song-position, 0), "%M:%S") + " / " + formattime(round(song.length/1000/1000, 0), "%M:%S")} + + (box :width 16) + ) + ) + ) +) + +(deflisten song-cover + `playerctl --player=cmus,firefox,%any -F metadata title | get-album-art` +) + +(deflisten song + `playerctl --player=cmus,firefox,%any -F metadata --format='{"title": "{{title}}", "album": "{{album}}", "artist": "{{artist}}", "status": "{{status}}", "length": "{{mpris:length}}"}'` +) + +(defpoll song-position + :interval "0.2s" + `playerctl --player=cmus,firefox,%any position` +)
\ No newline at end of file diff --git a/roles/home/desktop/eww/panels/volume.yuck b/roles/home/desktop/eww/panels/volume.yuck new file mode 100644 index 0000000..0c342c3 --- /dev/null +++ b/roles/home/desktop/eww/panels/volume.yuck @@ -0,0 +1,40 @@ +(defwidget volume [] + (box :class "volume panel" + :orientation "v" + :space-evenly false + + (label :markup "<b>Volume</b>") + + (box + :orientation "h" + :vexpand true + + (box + :orientation "v" + :space-evenly false + :vexpand true + + (scale + :orientation "v" + :flipped true + :value {sink-volume} + :max 101 + :onchange `pactl set-sink-volume @DEFAULT_SINK@ {}%` + :vexpand true + ) + + {sink-volume + "%"} + ) + ) + ) +) + +(defpoll sink-volume + :interval "0.2s" + `pactl get-sink-volume @DEFAULT_SINK@ | head -n1 | awk '{print substr($5, 1, length($5)-1)}'` +) + +;(defpoll source-volume +; :interval "0.2s" +; `pactl get-source-volume @DEFAULT_SOURCE@ | head -n1 | awk '{print substr($5, 1, length($5)-1)}'` +;) |