Compare commits

..

No commits in common. "240ab803839589df72ef22bd461e014267d376bb" and "301b57ec06b900033f4866df8be9ee8da8f52169" have entirely different histories.

4 changed files with 67 additions and 185 deletions

View File

@ -16,7 +16,7 @@ $clock: rgba(171, 233, 179, 1.0);
$media: rgba(224, 232, 224, 0.7); $media: rgba(224, 232, 224, 0.7);
$tray_bg: rgba(204, 204, 204, 0.1); $tray_background: rgba(204, 204, 204, 0.1);
$tray: #c9cbff; $tray: #c9cbff;
$keyboard: #f2cdcd; $keyboard: #f2cdcd;
$language: #e8a2af; $language: #e8a2af;
@ -34,18 +34,12 @@ $battery: #b6b2b3;
* { all: unset; } * { all: unset; }
.vbar { .bar {
background-color: transparent; //background-color: transparent;
margin-left: 5px; margin-left: 5px;
font-size: 15px; font-size: 15px;
font-family: monospace; font-family: monospace;
} }
.hbar {
background-color: transparent;
margin-top: 5px;
font-size: 15px;
font-family: monospace;
}
.icon { .icon {
font-size: 20px; font-size: 20px;
@ -111,27 +105,6 @@ box .weather {
color: mix($weather_end, $weather, 100%); color: mix($weather_end, $weather, 100%);
} }
} }
.audio .audio-scale {
color: $audio;
}
scale {
border-radius: 5px;
min-height: 80px;
min-width: 10px;
margin: .3rem 0 .3rem 0;
}
.volume-icon {
margin: 2pt 0 2pt 0;
color: $audio;
}
box .cpu {
color: $cpu;
padding: 6pt;
}
box .memory {
color: $memory;
padding: 6pt;
}
box .clock { box .clock {
background-color: $widget_bg; background-color: $widget_bg;
border-radius: 5; border-radius: 5;
@ -152,11 +125,6 @@ box .clock {
font-family: monospace; font-family: monospace;
} }
.systray {
background-color: $tray_bg;
color: $tray;
}
// Styles on classes (see eww.yuck for more information) // Styles on classes (see eww.yuck for more information)
.status slider { .status slider {
@ -194,3 +162,6 @@ box .clock {
margin-left: 10px; margin-left: 10px;
margin-right: 20px; margin-right: 20px;
} }
.label-ram {
font-size: large;
}

View File

@ -1,6 +1,6 @@
(defvar eww "eww --config $HOME/.config/eww/bar") (defvar eww "eww --config $HOME/.config/eww/bar")
(defwindow vbar (defwindow bar
:exclusive true :exclusive true
:monitor 0 :monitor 0
:windowtype "dock" :windowtype "dock"
@ -12,47 +12,20 @@
:anchor "center left" :anchor "center left"
) )
:reserve (struts :side "left" :distance "20px") :reserve (struts :side "left" :distance "20px")
(centerbox (widget_bar))
:orientation "v" (defwidget widget_bar []
(centerbox :orientation "v"
(box :orientation "v" :space-evenly false :valign "start" (box :orientation "v" :space-evenly false :valign "start"
(box :class "launcher" :valign "start" :width "10px" :height "10px" "☯") (box :class "launcher" :valign "start" "☯")
;(label :class "launcher" :valign "start" :width "20px" :height "20px" :unindent true (widget_workspaces)
; :text "☯")
(widget-workspaces)
)
(widget-media)
;(widget-weather :orientation "v")
(box :orientation "v" :space-evenly false :valign "end"
(widget-tray)
(widget-audio)
(widget-cpu)
(widget-memory)
(widget-clock)
) )
(widget_weather :orientation "v")
(widget_clock)
;(media)
;(widget_status) ;(widget_status)
)) ))
(defwindow hbar
:exclusive true
:monitor 0
:windowtype "dock"
:geometry (geometry
:x "0%"
:y "0%"
:width "90%"
:height "20px"
:anchor "top center"
)
:reserve (struts :side "top" :distance "20px")
(centerbox :orientation "h"
(box :orientation "h")
(box :orientation "h")
(box :orientation "h" :space-evenly false :halign "end"
(widget-cpu)
(widget-memory)
)
))
(defwidget widget-workspaces [] (defwidget widget_workspaces []
(box (box
:class "workspaces" :class "workspaces"
:orientation "v" :orientation "v"
@ -71,7 +44,7 @@
; Weather ; Weather
(defwidget widget-weather [orientation] (defwidget widget_weather [orientation]
(box (box
:class "weather" :class "weather"
:orientation orientation :orientation orientation
@ -82,7 +55,7 @@
(button :onclick "scripts/popup weather" "W") (button :onclick "scripts/popup weather" "W")
)) ))
(defpoll weather-text :initial "" :interval "180s" (defpoll weather_text :initial "" :interval "180s"
"curl --max-time 2 wttr.in") "curl --max-time 2 wttr.in")
(defwindow weather (defwindow weather
@ -90,109 +63,26 @@
:y "50%" :y "50%"
:width "270px" :width "270px"
:height "60px") :height "60px")
(box weather-text)) (box weather_text))
(defwidget widget-media [] (defwindow calendar
(box :geometry (geometry :x "70px"
:class "media" :y "65%"
:orientation "v" :width "270px"
:space-evenly false :height "60px")
:valign "center" (cal))
(circular-progress
:class "media"
:width 20
:height 20
:thickness 4
:tooltip {music_status_listener}
:value {music_position}
:visible {music_listener != ""}
)
(label
:angle 90
:xalign 0.5
:yalign 0.5
:text {music_listener != "" ? "『${music_listener}』" : ""})
))
(deflisten music_listener :initial "" (defwidget widget_clock []
"playerctl --follow metadata --format '{{ artist }} / {{album}} / {{ title }}' || true")
(deflisten music_status_listener :initial ""
"playerctl --follow metadata --format '{{duration(position)}} / {{duration(mpris:length)}}' || true")
(deflisten music_position :initial 0.5
"playerctl --follow metadata --format '{{100.0 * position / mpris:length}}' || true")
(defwidget widget-audio []
(scale
:class "audio"
:orientation "v"
:min 0
:max 100
:value 23
))
(defwidget widget-audio []
(eventbox
:onhover "${eww} update show_audio=true"
:onhoverlost "${eww} update show_audio=false"
(box
:class "audio"
:orientation "v"
:space-evenly "false"
:spacing "2"
(revealer :transition "slideup" :reveal show_audio
(scale
:class "audio-scale"
:value current-volume
:orientation "v"
:flipped true
:tooltip "Volume: ${current-volume}%"
:max 101
:min 0
:onchange "amixer -D pulse sset Master {}%" ))
(button
:onclick "scripts/popup audio"
:class "volume-icon" ""))))
(defpoll current-volume :interval "1s" "amixer -D pulse sget Master | grep 'Left:' | awk -F'[][]' '{ print $2 }' | tr -d '%'")
(defvar show_audio false)
(defwidget widget-cpu []
(circular-progress
:class "cpu"
:width 20
:height 20
:thickness 4
:tooltip {EWW_CPU.cores}
:value {EWW_CPU.avg}
))
(defwidget widget-memory []
(circular-progress
:class "memory"
:width 20
:height 20
:thickness 4
:tooltip "${EWW_RAM.used_mem} / ${EWW_RAM.total_mem}"
:value {EWW_RAM.used_mem_perc}
))
(defwidget widget-tray []
(systray
:class "systray"
:orientation "v"
:space-evenly true
:icon-size 20
:prepend-new true
))
(defwidget widget-clock []
(box (box
:class "clock" :class "clock"
:orientation "v" :orientation "v"
:valign "end" :valign "end"
:spacing 1 :spacing 1
:width 25
(box :class "icon" "")
"${clock.m}" "${clock.d}"
(box :class "icon" "") (box :class "icon" "")
"${clock.H}" "${clock.M}" "${clock.H}" "${clock.M}"
(box :class "icon" "")
"${clock.m}" "${clock.d}"
)) ))
(defpoll clock :initial "{}" :interval "10s" (defpoll clock :initial "{}" :interval "10s"
@ -227,19 +117,38 @@
; Unused widgets ; Unused widgets
;(defwidget widget_status [] (defwidget widget_status []
; (box (box
; :class "status" :class "status"
; :orientation "v" :orientation "v"
; :space-evenly false :space-evenly false
; :valign "end" :valign "end"
; (metric :label "" (metric :label ""
; :value volume :value volume
; :onchange "amixer -D pulse sset Master {}%") :onchange "amixer -D pulse sset Master {}%")
; (metric :label "" (metric :label ""
; :value {EWW_RAM.used_mem_perc} :value {EWW_RAM.used_mem_perc}
; :onchange "") :onchange "")
; (widget_clock))) (widget_clock)))
(defwidget widget_media []
(box :class "media"
:orientation "v"
:space-evenly false
:valign "center"
{music_listener != "" ? "『${music_listener}』" : ""}
(box :class "music_status"
:orientation "h"
:space-evenly false
:halign "center"
{music_listener != "" ? "${music_status_listener}" : ""})
))
(deflisten music_listener :initial ""
"playerctl --follow metadata --format '{{ artist }} / {{album}} / {{ title }}' || true")
(deflisten music_status_listener :initial ""
"playerctl --follow metadata --format '{{duration(position)}}/{{duration(mpris:length)}}' || true")
(defwidget metric [label value onchange] (defwidget metric [label value onchange]

View File

@ -113,9 +113,7 @@ def detect():
Main entry point, detects the type of compositor used Main entry point, detects the type of compositor used
""" """
if signature := os.environ.get("HYPRLAND_INSTANCE_SIGNATURE", None): if signature := os.environ.get("HYPRLAND_INSTANCE_SIGNATURE", None):
# See https://wiki.hyprland.org/IPC/ socket_addr = f"/tmp/hypr/{signature}/.socket2.sock"
xdg_runtime_dir = os.environ["XDG_RUNTIME_DIR"]
socket_addr = f"/{xdg_runtime_dir}/hypr/{signature}/.socket2.sock"
return hypr_listen(socket_addr) return hypr_listen(socket_addr)
if signature := os.environ.get("SWAYSOCK", None): if signature := os.environ.get("SWAYSOCK", None):
return sway_listen() return sway_listen()

View File

@ -11,7 +11,7 @@ monitor=,preferred,auto,auto
# See https://wiki.hyprland.org/Configuring/Keywords/ for more # See https://wiki.hyprland.org/Configuring/Keywords/ for more
# waybar is executed after eww to have the intersection effect at top left # waybar is executed after eww to have the intersection effect at top left
exec-once = hyprpaper & swaync & fcitx5 & eww --config ~/.config/eww/bar open vbar exec-once = hyprpaper & swaync & fcitx5 & eww --config ~/.config/eww/bar open bar & waybar
# Source a file (multi-file configs) # Source a file (multi-file configs)
# source = ~/.config/hypr/myColors.conf # source = ~/.config/hypr/myColors.conf
@ -52,6 +52,10 @@ decoration {
# See https://wiki.hyprland.org/Configuring/Variables/ for more # See https://wiki.hyprland.org/Configuring/Variables/ for more
rounding = 10 rounding = 10
blur = yes
blur_size = 3
blur_passes = 1
blur_new_optimizations = on
drop_shadow = yes drop_shadow = yes
shadow_range = 4 shadow_range = 4