2019-12-02 14:59:12 +00:00
|
|
|
;==========================================================
|
|
|
|
;
|
|
|
|
;
|
|
|
|
; ██████╗ ██████╗ ██╗ ██╗ ██╗██████╗ █████╗ ██████╗
|
|
|
|
; ██╔══██╗██╔═══██╗██║ ╚██╗ ██╔╝██╔══██╗██╔══██╗██╔══██╗
|
|
|
|
; ██████╔╝██║ ██║██║ ╚████╔╝ ██████╔╝███████║██████╔╝
|
|
|
|
; ██╔═══╝ ██║ ██║██║ ╚██╔╝ ██╔══██╗██╔══██║██╔══██╗
|
|
|
|
; ██║ ╚██████╔╝███████╗██║ ██████╔╝██║ ██║██║ ██║
|
|
|
|
; ╚═╝ ╚═════╝ ╚══════╝╚═╝ ╚═════╝ ╚═╝ ╚═╝╚═╝ ╚═╝
|
|
|
|
;
|
|
|
|
;
|
|
|
|
; To learn more about how to configure Polybar
|
|
|
|
; go to https://github.com/polybar/polybar
|
|
|
|
;
|
|
|
|
; The README contains a lot of information
|
|
|
|
;
|
|
|
|
;==========================================================
|
|
|
|
|
|
|
|
[colors]
|
2020-01-31 00:22:47 +00:00
|
|
|
background = ${xrdb:background}
|
|
|
|
background-alt = ${xrdb:color8}
|
|
|
|
foreground = ${xrdb:foreground}
|
|
|
|
foreground-alt = ${xrdb:color3}
|
|
|
|
primary = ${xrdb:color1}
|
|
|
|
secondary = ${xrdb:color4}
|
|
|
|
alert = ${xrdb:color2}
|
2019-12-02 14:59:12 +00:00
|
|
|
|
|
|
|
[settings]
|
|
|
|
; The throttle settings lets the eventloop swallow up til X events
|
|
|
|
; if they happen within Y millisecond after first event was received.
|
|
|
|
; This is done to prevent flood of update event.
|
|
|
|
;
|
|
|
|
; For example if 5 modules emit an update event at the same time, we really
|
|
|
|
; just care about the last one. But if we wait too long for events to swallow
|
|
|
|
; the bar would appear sluggish so we continue if timeout
|
|
|
|
; expires or limit is reached.
|
|
|
|
throttle-output = 5
|
|
|
|
throttle-output-for = 10
|
|
|
|
; Time in milliseconds that the input handler will wait between processing events
|
|
|
|
throttle-input-for = 30
|
|
|
|
|
|
|
|
[global/wm]
|
|
|
|
margin-top = 0
|
|
|
|
margin-bottom = 0
|
|
|
|
|
2019-12-02 19:58:36 +00:00
|
|
|
[bar/simple-top]
|
2020-05-16 17:05:09 +00:00
|
|
|
; enable inter process communication, so that we can send messages
|
|
|
|
; to polybar via polybar-msg command
|
|
|
|
enable-ipc = true
|
|
|
|
|
2019-12-02 14:59:12 +00:00
|
|
|
; Put the bar at the bottom of the screen
|
|
|
|
bottom=false
|
|
|
|
|
|
|
|
width = 100%
|
|
|
|
height = 25
|
2019-12-02 18:01:58 +00:00
|
|
|
padding-left = 0
|
|
|
|
padding-right = 0
|
2019-12-02 14:59:12 +00:00
|
|
|
module-margin-left = 2
|
|
|
|
|
2020-05-26 11:09:45 +00:00
|
|
|
modules-left = workspaces sxhkdmode pomo
|
2020-05-16 17:05:09 +00:00
|
|
|
modules-center = music date papersdue
|
2019-12-20 12:01:50 +00:00
|
|
|
modules-right = networkspeed archupdates cpu temp backlight volume battery
|
2019-12-02 20:38:40 +00:00
|
|
|
; do not use offsets for the bar, would only work with override-redirect
|
|
|
|
; and will mess up tray https://github.com/polybar/polybar/issues/1355
|
2019-12-02 14:59:12 +00:00
|
|
|
tray-position = right
|
|
|
|
|
2019-12-02 18:01:58 +00:00
|
|
|
; Basic Colors, defined further up
|
2019-12-02 14:59:12 +00:00
|
|
|
background = ${colors.background}
|
|
|
|
foreground = ${colors.foreground}
|
|
|
|
line-size = 2
|
|
|
|
line-color = ${colors.primary}
|
|
|
|
|
|
|
|
; Prefer fixed center position for the `modules-center` block.
|
|
|
|
; The center block will stay in the middle of the bar whenever
|
|
|
|
; possible. It can still be pushed around if other blocks need
|
|
|
|
; more space.
|
|
|
|
; When false, the center block is centered in the space between
|
|
|
|
; the left and right block.
|
|
|
|
fixed-center = true
|
|
|
|
|
|
|
|
; Fonts are defined using <font-name>;<vertical-offset>
|
|
|
|
; Font names are specified using a fontconfig pattern.
|
|
|
|
; font-0 = NotoSans-Regular:size=8;2
|
|
|
|
; font-1 = MaterialIcons:size=10
|
|
|
|
; font-2 = Termsynu:size=8;-1
|
|
|
|
; font-3 = FontAwesome:size=10
|
|
|
|
; See the Fonts wiki page for more details
|
2019-12-03 09:33:30 +00:00
|
|
|
font-0 = Comic Neue
|
|
|
|
font-1 = NotoSans
|
2020-05-16 17:05:09 +00:00
|
|
|
font-2 = Iosevka:size=18;1
|
2019-12-02 14:59:12 +00:00
|
|
|
|
2019-12-02 20:38:40 +00:00
|
|
|
cursor-click = pointer
|
|
|
|
|
2020-05-26 11:09:45 +00:00
|
|
|
[module/sxhkdmode]
|
|
|
|
type = custom/script
|
|
|
|
exec = sxhkd-chain-labels
|
|
|
|
exec-if = type sxhkd-chain-labels
|
|
|
|
tail = true
|
|
|
|
format = <label>
|
|
|
|
format-padding = 5
|
|
|
|
format-prefix = "狀 "
|
|
|
|
format-background = ${colors.primary}
|
|
|
|
format-foreground = ${colors.background}
|
|
|
|
|
2019-12-02 14:59:12 +00:00
|
|
|
[module/workspaces]
|
|
|
|
; module type
|
|
|
|
type = internal/i3
|
|
|
|
; default formatting
|
2019-12-02 20:21:15 +00:00
|
|
|
format = <label-mode><label-state>
|
2019-12-02 14:59:12 +00:00
|
|
|
; removes numbers for workspaces which have distinct names / icons
|
|
|
|
strip-wsnumbers = true
|
|
|
|
|
2019-12-02 20:14:39 +00:00
|
|
|
ws-icon-0 = 1;
|
|
|
|
ws-icon-1 = 2;
|
2019-12-03 09:33:30 +00:00
|
|
|
ws-icon-2 = 3;
|
2019-12-02 20:14:39 +00:00
|
|
|
ws-icon-3 = 4;4
|
|
|
|
ws-icon-4 = 5;5
|
|
|
|
ws-icon-5 = 6;6
|
|
|
|
ws-icon-6 = 7;7
|
|
|
|
ws-icon-7 = 8;8
|
|
|
|
ws-icon-8 = 9;
|
|
|
|
ws-icon-9 = 10;
|
|
|
|
ws-icon-default = ♟
|
|
|
|
|
2019-12-02 14:59:12 +00:00
|
|
|
; Available tokens:
|
|
|
|
; %name%
|
|
|
|
; %icon%
|
|
|
|
; %index%
|
|
|
|
; %output%
|
|
|
|
; Default: %icon% %name%
|
|
|
|
; unfocused = Inactive workspace on any monitor
|
2019-12-02 20:14:39 +00:00
|
|
|
label-unfocused = %icon%
|
2019-12-02 14:59:12 +00:00
|
|
|
label-unfocused-padding = 4
|
|
|
|
label-unfocused-underline = ${colors.background-alt}
|
|
|
|
; focused = Active workspace on focused monitor
|
2019-12-02 20:14:39 +00:00
|
|
|
label-focused = %icon%
|
2019-12-02 14:59:12 +00:00
|
|
|
label-focused-foreground = ${colors.foreground}
|
|
|
|
label-focused-background = ${colors.background-alt}
|
|
|
|
label-focused-underline = ${colors.primary}
|
|
|
|
label-focused-padding = ${self.label-unfocused-padding}
|
|
|
|
; visible = Active workspace on unfocused monitor
|
2019-12-02 20:14:39 +00:00
|
|
|
label-visible = %icon%
|
2019-12-02 14:59:12 +00:00
|
|
|
label-visible-background = ${self.label-focused-background}
|
|
|
|
label-visible-underline = ${self.label-focused-underline}
|
|
|
|
label-visible-padding = ${self.label-unfocused-padding}
|
|
|
|
; urgent = Workspace with urgency hint set
|
2019-12-02 20:14:39 +00:00
|
|
|
label-urgent = %icon%
|
2019-12-02 14:59:12 +00:00
|
|
|
label-urgent-background = ${colors.alert}
|
|
|
|
label-urgent-padding = ${self.label-unfocused-padding}
|
2019-12-02 20:21:15 +00:00
|
|
|
; formatting of the mode display
|
|
|
|
label-mode = %mode%
|
|
|
|
label-mode-padding = ${self.label-unfocused-padding}
|
|
|
|
label-mode-foreground = ${colors.background}
|
|
|
|
label-mode-background = ${colors.primary}
|
2019-12-02 14:59:12 +00:00
|
|
|
|
|
|
|
[module/cpu]
|
|
|
|
; module type
|
|
|
|
type = internal/cpu
|
|
|
|
; Seconds to sleep between updates
|
|
|
|
interval = 1.0
|
|
|
|
; Available tags:
|
|
|
|
; <label> (default)
|
|
|
|
; <bar-load>
|
|
|
|
; <ramp-load>
|
|
|
|
; <ramp-coreload>
|
|
|
|
format = <ramp-load>
|
|
|
|
; Available tokens:
|
|
|
|
; %percentage% (default) - total cpu load averaged over all cores
|
|
|
|
; %percentage-sum% - Cumulative load on all cores
|
|
|
|
; %percentage-cores% - load percentage for each core
|
|
|
|
; %percentage-core[1-9]% - load percentage for specific core
|
|
|
|
label =
|
|
|
|
; enable large icon font
|
|
|
|
label-font = 2
|
|
|
|
; Spacing between individual per-core ramps
|
|
|
|
ramp-load-0 = ▁
|
|
|
|
ramp-load-1 = %{F#ffe5e5}▂%{F-}
|
|
|
|
ramp-load-2 = %{F#ffcccc}▃%{F-}
|
|
|
|
ramp-load-3 = %{F#ffb2b2}▄%{F-}
|
|
|
|
ramp-load-4 = %{F#ff9999}▅%{F-}
|
|
|
|
ramp-load-5 = %{F#ff6666}▆%{F-}
|
|
|
|
ramp-load-6 = %{F#ff3232}▇%{F-}
|
|
|
|
ramp-load-7 = %{F#ff0000}█%{F-}
|
|
|
|
|
|
|
|
[module/temp]
|
|
|
|
type = internal/temperature
|
|
|
|
; Seconds to sleep between updates
|
|
|
|
interval = 1.0
|
|
|
|
; Thermal zone to use
|
|
|
|
; To list all the zone types, run
|
|
|
|
; $ for i in /sys/class/thermal/thermal_zone*; do echo "$i: $(<$i/type)"; done
|
|
|
|
; Default: 0
|
2020-05-16 17:05:09 +00:00
|
|
|
thermal-zone = 2
|
2019-12-02 14:59:12 +00:00
|
|
|
; Use `sensors` to find preferred temperature source, then run
|
|
|
|
; $ for i in /sys/class/hwmon/hwmon*/temp*_input; do echo "$(<$(dirname $i)/name): $(cat ${i%_*}_label 2>/dev/null || echo $(basename ${i%_*})) $(readlink -f $i)"; done
|
|
|
|
; hwmon-path = /sys/devices/platform/coretemp.0/hwmon/hwmon0/temp1_input
|
|
|
|
; Base temperature for where to start the ramp (in degrees celsius)
|
2020-05-16 17:05:09 +00:00
|
|
|
base-temperature = 50
|
2019-12-02 14:59:12 +00:00
|
|
|
; Threshold temperature to display warning label (in degrees celsius)
|
|
|
|
warn-temperature = 70
|
|
|
|
units = true
|
|
|
|
format = <ramp>
|
|
|
|
format-warn = <ramp> <label-warn>
|
|
|
|
label-warn = %temperature-c%
|
|
|
|
label-warn-foreground = ${colors.alert}
|
|
|
|
ramp-0 =
|
|
|
|
ramp-1 = %{F#ff9999}ﲲﲲ%{F-}
|
|
|
|
ramp-2 = %{F#ff0000}ﲲﲲﲲ%{F-}
|
|
|
|
|
|
|
|
[module/date]
|
|
|
|
type = internal/date
|
|
|
|
; Seconds to sleep between updates
|
|
|
|
interval = 1.0
|
|
|
|
; See "http://en.cppreference.com/w/cpp/io/manip/put_time" for details on how to format the date string
|
|
|
|
; NOTE: if you want to use syntax tags here you need to use %%{...}
|
|
|
|
date = %d/%m
|
|
|
|
; Optional time format
|
|
|
|
time = %H:%M
|
|
|
|
; if `date-alt` or `time-alt` is defined, clicking
|
|
|
|
; the module will toggle between formats
|
2019-12-20 13:08:32 +00:00
|
|
|
date-alt = %A, %d %B %Y (W %V)
|
2019-12-02 14:59:12 +00:00
|
|
|
time-alt = %H:%M
|
2019-12-20 12:01:50 +00:00
|
|
|
label = %date% %{T2} %{T-}%time%
|
2019-12-02 14:59:12 +00:00
|
|
|
|
2020-05-16 17:05:09 +00:00
|
|
|
; display information on currently playing track, allows simple track manipulation
|
2020-05-25 15:25:45 +00:00
|
|
|
; TODO: add album art display (on click?) - retrieved by playerctl metadata mpris:artUrl
|
2020-05-16 17:05:09 +00:00
|
|
|
[module/music]
|
|
|
|
type = custom/script
|
|
|
|
exec = $XDG_CONFIG_HOME/polybar/scripts/poly-mprisdisplay
|
|
|
|
exec-if = type $XDG_CONFIG_HOME/polybar/scripts/poly-mprisdisplay
|
|
|
|
tail = true
|
|
|
|
click-left = kill -USR1 %pid%
|
|
|
|
click-right = kill -USR2 %pid%
|
|
|
|
|
|
|
|
; display information on remaining papers to read for the upcoming week
|
|
|
|
[module/papersdue]
|
|
|
|
type = custom/script
|
|
|
|
exec = $XDG_CONFIG_HOME/polybar/scripts/poly-papersdue
|
|
|
|
exec-if = type bib-due
|
|
|
|
tail = true
|
2020-05-25 15:25:45 +00:00
|
|
|
; show list with high prio
|
2020-05-16 17:05:09 +00:00
|
|
|
click-left = exist rofi-bib-due normal "opening due papers" && rofi-bib-due -p1 -u $(date --date='fri this week' +%Y-%m-%d)
|
2020-05-25 15:25:45 +00:00
|
|
|
; show list with all
|
|
|
|
click-right = exist rofi-bib-due normal "opening due papers" && rofi-bib-due -p3 -u $(date --date='fri this week' +%Y-%m-%d)
|
2020-05-16 17:05:09 +00:00
|
|
|
format-prefix = " "
|
|
|
|
interval = 120
|
|
|
|
|
2020-05-25 15:25:45 +00:00
|
|
|
; displays a small pomodoro timer
|
|
|
|
[module/pomo]
|
|
|
|
type = custom/script
|
|
|
|
exec = $XDG_CONFIG_HOME/polybar/scripts/poly-pomo
|
|
|
|
exec-if = exist pomo normal "pomodoro timer"
|
|
|
|
; pause timer
|
|
|
|
click-left = $XDG_CONFIG_HOME/polybar/scripts/poly-pomo toggle
|
|
|
|
; restart timer
|
|
|
|
click-right = $XDG_CONFIG_HOME/polybar/scripts/poly-pomo restart
|
|
|
|
tail = true
|
|
|
|
|
2020-05-16 17:05:09 +00:00
|
|
|
; display unified available packages for update on arch from repos/aur
|
|
|
|
; uses pacman-contrib/checkupdates if available to avoid partial arch upgrades
|
2019-12-02 15:23:22 +00:00
|
|
|
[module/archupdates]
|
|
|
|
type = custom/script
|
2019-12-02 19:33:37 +00:00
|
|
|
exec = $XDG_CONFIG_HOME/polybar/scripts/poly-archupdates
|
2020-05-16 17:05:09 +00:00
|
|
|
exec-if = type $XDG_CONFIG_HOME/polybar/scripts/poly-archupdates
|
2019-12-02 15:23:22 +00:00
|
|
|
interval = 600
|
|
|
|
format = <label>
|
2020-05-16 17:05:09 +00:00
|
|
|
format-padding = 2
|
|
|
|
format-prefix = " "
|
|
|
|
; format-foreground = ${colors.primary}
|
2019-12-02 15:23:22 +00:00
|
|
|
|
2019-12-02 15:44:21 +00:00
|
|
|
[module/networkspeed]
|
|
|
|
type = custom/script
|
2019-12-02 19:33:37 +00:00
|
|
|
exec = $XDG_CONFIG_HOME/polybar/scripts/poly-networkspeed
|
2019-12-02 15:44:21 +00:00
|
|
|
tail = true
|
2019-12-02 15:23:22 +00:00
|
|
|
|
2019-12-02 21:14:26 +00:00
|
|
|
[module/volume]
|
|
|
|
type = internal/pulseaudio
|
|
|
|
; Available tags:
|
|
|
|
; <label-volume> (default)
|
|
|
|
; <ramp-volume>
|
|
|
|
; <bar-volume>
|
|
|
|
format-volume = <ramp-volume>
|
|
|
|
|
|
|
|
; Use PA_VOLUME_UI_MAX (~153%) if true, or PA_VOLUME_NORM (100%) if false
|
|
|
|
use-ui-max = false
|
|
|
|
|
|
|
|
label-muted = ﱝ
|
|
|
|
label-muted-foreground = ${colors.foreground-alt}
|
|
|
|
|
|
|
|
; Only applies if <ramp-volume> is used
|
|
|
|
ramp-volume-0 =
|
|
|
|
ramp-volume-1 =
|
|
|
|
ramp-volume-2 =
|
|
|
|
ramp-volume-3 = 墳
|
|
|
|
|
2019-12-03 09:33:09 +00:00
|
|
|
[module/backlight]
|
|
|
|
type = internal/xbacklight
|
2019-12-20 12:01:50 +00:00
|
|
|
format = <ramp><label>
|
|
|
|
ramp-0 =
|
|
|
|
ramp-1 =
|
|
|
|
ramp-2 =
|
|
|
|
ramp-3 =
|
|
|
|
ramp-4 =
|
2019-12-02 21:14:26 +00:00
|
|
|
|
2019-12-20 12:01:50 +00:00
|
|
|
[module/battery]
|
|
|
|
type = internal/battery
|
|
|
|
battery = BAT0
|
|
|
|
adapter = AC
|
|
|
|
label-charging = %percentage%%
|
|
|
|
label-discharging = %percentage%%
|
|
|
|
format-discharging = <ramp-capacity> <label-discharging>
|
|
|
|
format-charging = <label-charging>
|
|
|
|
ramp-capacity-0 =
|
|
|
|
ramp-capacity-1 =
|
|
|
|
ramp-capacity-2 =
|
|
|
|
ramp-capacity-3 =
|
|
|
|
ramp-capacity-4 =
|
2019-12-02 14:59:12 +00:00
|
|
|
; vim:ft=dosini
|