Improve ewwbar
This commit is contained in:
@ -1,9 +1,9 @@
|
||||
//$text: wheat;
|
||||
$text: #f6daa8;
|
||||
$highlight1: #4e8172;
|
||||
$highlight2: #679a8b;
|
||||
$background: #1d2021;
|
||||
$background: #23231b;
|
||||
$lowlight1: black;
|
||||
$lowlight2: #1d1f21;
|
||||
|
||||
*{
|
||||
all: unset;
|
||||
@ -20,7 +20,7 @@ window {
|
||||
font-size: 18px;
|
||||
font-weight: 300;
|
||||
border: solid $highlight1 1px;
|
||||
background: black;
|
||||
background: $lowlight1;
|
||||
border-radius: 30px;
|
||||
padding-top: 3px;
|
||||
padding-bottom: 5px;
|
||||
@ -32,9 +32,7 @@ window {
|
||||
}
|
||||
|
||||
.workspace.active {
|
||||
font-weight: 600;
|
||||
background: $text;
|
||||
color: black;
|
||||
border: solid $highlight2 2px;
|
||||
}
|
||||
|
||||
.workspaces {
|
||||
@ -47,11 +45,11 @@ window {
|
||||
border-top: solid $highlight1 1px;
|
||||
border-bottom: dotted $highlight1 6px;
|
||||
color: $highlight1;
|
||||
background: black;
|
||||
background: $lowlight1;
|
||||
border-radius: 30px;
|
||||
padding-top: 0.5em;
|
||||
padding-bottom: 0.3em;
|
||||
box-shadow: 0 0px 5px 1px #06060b;
|
||||
margin-top: 20px;
|
||||
}
|
||||
|
||||
scale trough {
|
||||
@ -64,6 +62,14 @@ scale trough {
|
||||
margin: 0px 0px 0px 0px;
|
||||
}
|
||||
|
||||
.volbox {
|
||||
transition: all 0.5s;
|
||||
}
|
||||
|
||||
.volbox.active {
|
||||
background-color: $lowlight2;
|
||||
}
|
||||
|
||||
.volume {
|
||||
min-height: 150px;
|
||||
}
|
||||
@ -84,8 +90,7 @@ scale trough {
|
||||
border-color: green;
|
||||
margin: 2px;
|
||||
margin-top: 20px;
|
||||
transition: border-color 1s;
|
||||
transition: all 1s;
|
||||
transition: all 0.2s;
|
||||
}
|
||||
|
||||
.vpn label {
|
||||
@ -94,7 +99,11 @@ scale trough {
|
||||
}
|
||||
|
||||
.vpn:hover {
|
||||
border-top: dotted 6px;
|
||||
background-color: $lowlight2;
|
||||
}
|
||||
|
||||
.vpn:active {
|
||||
background-color: $highlight1;
|
||||
}
|
||||
|
||||
.vpn.connecting {
|
||||
@ -105,6 +114,10 @@ scale trough {
|
||||
border-color: red;
|
||||
}
|
||||
|
||||
.calendar {
|
||||
background: $lowlight2;
|
||||
}
|
||||
|
||||
.clock {
|
||||
font-size: 30px;
|
||||
font-weight: 400;
|
||||
|
||||
@ -7,8 +7,9 @@
|
||||
:anchor "center left")
|
||||
:stacking "fg"
|
||||
:exclusive true
|
||||
(box :orientation "v"
|
||||
(centerbox :orientation "v"
|
||||
(workspaces)
|
||||
(middle)
|
||||
(bottom)
|
||||
))
|
||||
|
||||
@ -21,18 +22,27 @@
|
||||
:anchor "center left")
|
||||
:stacking "fg"
|
||||
:exclusive true
|
||||
(box :orientation "v"
|
||||
(box :orientation "v" :space-evenly: false
|
||||
(workspaces)
|
||||
(bottom)
|
||||
))
|
||||
|
||||
(defwidget middle []
|
||||
(box :orientation "v"
|
||||
:space-evenly false
|
||||
:valign "center"
|
||||
))
|
||||
|
||||
(defwidget bottom []
|
||||
(box :orientation "v"
|
||||
:space-evenly false
|
||||
:valign "end"
|
||||
(speaker)
|
||||
(vpn)
|
||||
(speaker)
|
||||
(temperature)
|
||||
(battery)
|
||||
(box :class "boxed" (systray :orientation "v"))
|
||||
(date)
|
||||
(clock)
|
||||
))
|
||||
|
||||
@ -40,37 +50,69 @@
|
||||
(box :orientation "v"
|
||||
:valign "start"
|
||||
:class "workspaces"
|
||||
:space-evenly: false
|
||||
(for workspace in workspaces_json
|
||||
(label :class 'workspace ${workspace.class}' :text '${workspace.id}')
|
||||
(button :class 'workspace ${workspace.class}' (label :text '${workspace.id}'))
|
||||
)))
|
||||
|
||||
(defwidget speaker []
|
||||
(box :class "volume"
|
||||
:orientation "v"
|
||||
:valign "end"
|
||||
(eventbox
|
||||
:onhover "${EWW_CMD} update show_volume=true"
|
||||
:onhoverlost "${EWW_CMD} update show_volume=false"
|
||||
(box :orientation "v"
|
||||
:class "boxed volbox ${show_volume ? "active" : ""}"
|
||||
:space-evenly false
|
||||
(revealer :transition "slidedown"
|
||||
:reveal show_volume
|
||||
(scale :orientation "v"
|
||||
:class "volume"
|
||||
:flipped true
|
||||
:min 0
|
||||
:max 100
|
||||
:value volume_out
|
||||
:onchange "pamixer --set-volume {} && volshow")
|
||||
:onchange "pamixer --set-volume {} && volshow"
|
||||
))
|
||||
(label :text "VOL")
|
||||
(revealer :transition "slideup"
|
||||
:reveal {!show_volume}
|
||||
(label :text volume_out)
|
||||
)
|
||||
)))
|
||||
|
||||
(defwidget vpn []
|
||||
(button :valign "end"
|
||||
:class "vpn boxed ${vpn_status.class}"
|
||||
:onclick "${vpn_status.on_click}"
|
||||
:tooltip "${vpn_status.tooltip}"
|
||||
(label :text "${vpn_status.icon}")
|
||||
))
|
||||
|
||||
(defwidget temperature []
|
||||
(box :orientation "v"
|
||||
:valign "end"
|
||||
:class "battery boxed"
|
||||
(label :text "TMP")
|
||||
(label :text "99C")
|
||||
))
|
||||
|
||||
(defwidget battery []
|
||||
(box :orientation "v"
|
||||
:valign "end"
|
||||
:class "battery boxed"
|
||||
:visible {current_battery != ""}
|
||||
(label :text "BAT")
|
||||
(label :text "${current_battery}%")
|
||||
))
|
||||
|
||||
(defwidget date []
|
||||
(tooltip :class "boxed date" :halign "fill"
|
||||
(calendar :class "calendar")
|
||||
|
||||
(box :orientation "v" :hexpand true
|
||||
(label :text current_month)
|
||||
(label :text current_day)
|
||||
)))
|
||||
|
||||
(defwidget clock []
|
||||
(box :orientation "v"
|
||||
:valign "end"
|
||||
@ -79,6 +121,7 @@
|
||||
(label :text current_minute)
|
||||
))
|
||||
|
||||
(defvar show_volume false)
|
||||
(defpoll workspaces_json :interval "1s" "eww-workspaces")
|
||||
(defpoll volume_out :interval "1s" "pamixer --get-volume")
|
||||
(defpoll vpn_status :interval "1s" "mullvad-status")
|
||||
|
||||
Reference in New Issue
Block a user