feat(sway): major appearance upgrades
This commit is contained in:
parent
9c9eff2a2d
commit
1923c320f5
@ -4,5 +4,4 @@ gaps outer 10
|
|||||||
default_border pixel 2
|
default_border pixel 2
|
||||||
default_floating_border pixel 2
|
default_floating_border pixel 2
|
||||||
|
|
||||||
set $wallpapers_path $HOME/.local/share/wallpapers
|
output * bg ~/.local/share/wallpapers/TokyoNight.jpg fill
|
||||||
output * bg $wallpapers_path/Industrial-Shaded.png fill
|
|
||||||
|
@ -9,13 +9,12 @@
|
|||||||
"battery",
|
"battery",
|
||||||
"disk",
|
"disk",
|
||||||
"pulseaudio",
|
"pulseaudio",
|
||||||
"custom/cap-left"
|
"custom/media",
|
||||||
],
|
],
|
||||||
"modules-center": [
|
"modules-center": [
|
||||||
"sway/workspaces"
|
"sway/workspaces"
|
||||||
],
|
],
|
||||||
"modules-right": [
|
"modules-right": [
|
||||||
"custom/cap-right",
|
|
||||||
"custom/weather",
|
"custom/weather",
|
||||||
"network",
|
"network",
|
||||||
"clock",
|
"clock",
|
||||||
@ -25,7 +24,7 @@
|
|||||||
"custom/weather": {
|
"custom/weather": {
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"min-length": 5,
|
"min-length": 5,
|
||||||
"exec": "curl 'https://wttr.in/Melbourne?m&format='%t''",
|
"exec": "curl 'https://wttr.in/?format='%t''",
|
||||||
"interval": 3600
|
"interval": 3600
|
||||||
},
|
},
|
||||||
"battery": {
|
"battery": {
|
||||||
@ -54,7 +53,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"clock": {
|
"clock": {
|
||||||
"format": " {:%a %b %d %H:%M}",
|
"format": " {:%a %b %d %I:%M %p}",
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"min-length": 18
|
"min-length": 18
|
||||||
},
|
},
|
||||||
@ -110,9 +109,10 @@
|
|||||||
"temperature": {
|
"temperature": {
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"min-length": 6,
|
"min-length": 6,
|
||||||
|
"thermal-zone": 1,
|
||||||
"critical-threshold": 90,
|
"critical-threshold": 90,
|
||||||
"format": "{icon} {temperatureC}°C",
|
"format": "{icon} {temperatureF}°F",
|
||||||
"format-critical": "{icon} {temperatureC}°C",
|
"format-critical": "{icon} {temperatureF}°F",
|
||||||
"format-icons": {
|
"format-icons": {
|
||||||
"default": [
|
"default": [
|
||||||
"",
|
"",
|
||||||
@ -143,14 +143,20 @@
|
|||||||
},
|
},
|
||||||
"sway/workspaces": {
|
"sway/workspaces": {
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"disable-scroll": true
|
"disable-scroll": true,
|
||||||
},
|
"persistent_workspaces": {
|
||||||
"custom/cap-left": {
|
"1": [],
|
||||||
"tooltip": false,
|
"2": [],
|
||||||
"format": ""
|
"3": [],
|
||||||
},
|
"4": [],
|
||||||
"custom/cap-right": {
|
"5": [],
|
||||||
"tooltip": false,
|
"6": []
|
||||||
"format": ""
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"custom/media": {
|
||||||
|
"interval": 1,
|
||||||
|
"return-type": "json",
|
||||||
|
"exec": "~/.config/waybar/scripts/get-media.bash",
|
||||||
|
"escape": true
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
21
dots/.config/waybar/scripts/get-media.bash
Executable file
21
dots/.config/waybar/scripts/get-media.bash
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
main() {
|
||||||
|
local class
|
||||||
|
local text=""
|
||||||
|
class="$(playerctl metadata --format '{{lc(status)}}')"
|
||||||
|
|
||||||
|
local player_ctl_info="$(playerctl metadata --format '{{ artist }} | {{ title }} | {{ album }}')"
|
||||||
|
|
||||||
|
if [[ "${class}" == "playing" ]]; then
|
||||||
|
text="▶ ${player_ctl_info}"
|
||||||
|
|
||||||
|
elif [[ "${class}" == "paused" ]]; then
|
||||||
|
text="⏸︎ ${player_ctl_info}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf '{"class": "%s", "text": "%s"}\n' "${class}" "${text}"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
main
|
@ -1,127 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
from gi.repository import Playerctl, GLib
|
|
||||||
import argparse
|
|
||||||
import logging
|
|
||||||
import sys
|
|
||||||
import signal
|
|
||||||
import gi
|
|
||||||
import json
|
|
||||||
gi.require_version('Playerctl', '2.0')
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
|
|
||||||
def write_output(text, player):
|
|
||||||
logger.info('Writing output')
|
|
||||||
|
|
||||||
output = {'text': text,
|
|
||||||
'class': 'custom-' + player.props.player_name,
|
|
||||||
'alt': player.props.player_name}
|
|
||||||
|
|
||||||
sys.stdout.write(json.dumps(output) + '\n')
|
|
||||||
sys.stdout.flush()
|
|
||||||
|
|
||||||
|
|
||||||
def on_play(player, status, manager):
|
|
||||||
logger.info('Received new playback status')
|
|
||||||
on_metadata(player, player.props.metadata, manager)
|
|
||||||
|
|
||||||
|
|
||||||
def on_metadata(player, metadata, manager):
|
|
||||||
logger.info('Received new metadata')
|
|
||||||
track_info = ''
|
|
||||||
|
|
||||||
if player.props.player_name == 'spotify' and \
|
|
||||||
'mpris:trackid' in metadata.keys() and \
|
|
||||||
':ad:' in player.props.metadata['mpris:trackid']:
|
|
||||||
track_info = 'AD PLAYING'
|
|
||||||
elif player.get_artist() != '' and player.get_title() != '':
|
|
||||||
track_info = '{artist} - {title}'.format(artist=player.get_artist(),
|
|
||||||
title=player.get_title())
|
|
||||||
else:
|
|
||||||
track_info = player.get_title()
|
|
||||||
|
|
||||||
if player.props.status != 'Playing' and track_info:
|
|
||||||
track_info = ' ' + track_info
|
|
||||||
write_output(track_info, player)
|
|
||||||
|
|
||||||
|
|
||||||
def on_player_appeared(manager, player, selected_player=None):
|
|
||||||
if player is not None and (selected_player is None or player.name == selected_player):
|
|
||||||
init_player(manager, player)
|
|
||||||
else:
|
|
||||||
logger.debug("New player appeared, but it's not the selected player, skipping")
|
|
||||||
|
|
||||||
|
|
||||||
def on_player_vanished(manager, player):
|
|
||||||
logger.info('Player has vanished')
|
|
||||||
sys.stdout.write('\n')
|
|
||||||
sys.stdout.flush()
|
|
||||||
|
|
||||||
|
|
||||||
def init_player(manager, name):
|
|
||||||
logger.debug('Initialize player: {player}'.format(player=name.name))
|
|
||||||
player = Playerctl.Player.new_from_name(name)
|
|
||||||
player.connect('playback-status', on_play, manager)
|
|
||||||
player.connect('metadata', on_metadata, manager)
|
|
||||||
manager.manage_player(player)
|
|
||||||
on_metadata(player, player.props.metadata, manager)
|
|
||||||
|
|
||||||
|
|
||||||
def signal_handler(sig, frame):
|
|
||||||
logger.debug('Received signal to stop, exiting')
|
|
||||||
sys.stdout.write('\n')
|
|
||||||
sys.stdout.flush()
|
|
||||||
# loop.quit()
|
|
||||||
sys.exit(0)
|
|
||||||
|
|
||||||
|
|
||||||
def parse_arguments():
|
|
||||||
parser = argparse.ArgumentParser()
|
|
||||||
|
|
||||||
# Increase verbosity with every occurrence of -v
|
|
||||||
parser.add_argument('-v', '--verbose', action='count', default=0)
|
|
||||||
|
|
||||||
# Define for which player we're listening
|
|
||||||
parser.add_argument('--player')
|
|
||||||
|
|
||||||
return parser.parse_args()
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
arguments = parse_arguments()
|
|
||||||
|
|
||||||
# Initialize logging
|
|
||||||
logging.basicConfig(stream=sys.stderr, level=logging.DEBUG,
|
|
||||||
format='%(name)s %(levelname)s %(message)s')
|
|
||||||
|
|
||||||
# Logging is set by default to WARN and higher.
|
|
||||||
# With every occurrence of -v it's lowered by one
|
|
||||||
logger.setLevel(max((3 - arguments.verbose) * 10, 0))
|
|
||||||
|
|
||||||
# Log the sent command line arguments
|
|
||||||
logger.debug('Arguments received {}'.format(vars(arguments)))
|
|
||||||
|
|
||||||
manager = Playerctl.PlayerManager()
|
|
||||||
loop = GLib.MainLoop()
|
|
||||||
|
|
||||||
manager.connect('name-appeared', lambda *args: on_player_appeared(*args, arguments.player))
|
|
||||||
manager.connect('player-vanished', on_player_vanished)
|
|
||||||
|
|
||||||
signal.signal(signal.SIGINT, signal_handler)
|
|
||||||
signal.signal(signal.SIGTERM, signal_handler)
|
|
||||||
|
|
||||||
for player in manager.props.player_names:
|
|
||||||
if arguments.player is not None and arguments.player != player.name:
|
|
||||||
logger.debug('{player} is not the filtered player, skipping it'
|
|
||||||
.format(player=player.name)
|
|
||||||
)
|
|
||||||
continue
|
|
||||||
|
|
||||||
init_player(manager, player)
|
|
||||||
|
|
||||||
loop.run()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
@ -1,140 +1,150 @@
|
|||||||
/* --fujiWhite: #DCD7BA */
|
@define-color fujiWhite #DCD7BA;
|
||||||
/* --oldWhite: #C8C093 */
|
@define-color oldWhite #C8C093;
|
||||||
/* --sumiInk0: #16161D */
|
@define-color sumiInk0 #16161D;
|
||||||
/* --sumiInk1: #1F1F28 */
|
@define-color sumiInk1 #1F1F28;
|
||||||
/* --sumiInk2: #2A2A37 */
|
@define-color sumiInk2 #2A2A37;
|
||||||
/* --sumiInk3: #363646 */
|
@define-color sumiInk3 #363646;
|
||||||
/* --sumiInk4: #54546D */
|
@define-color sumiInk4 #54546D;
|
||||||
/* --waveBlue1: #223249 */
|
@define-color waveBlue1 #223249;
|
||||||
/* --waveBlue2: #2D4F67 */
|
@define-color waveBlue2 #2D4F67;
|
||||||
/* --winterGreen: #2B3328 */
|
@define-color winterGreen #2B3328;
|
||||||
/* --winterYellow: #49443C */
|
@define-color winterYellow #49443C;
|
||||||
/* --winterRed: #43242B */
|
@define-color winterRed #43242B;
|
||||||
/* --winterBlue: #252535 */
|
@define-color winterBlue #252535;
|
||||||
/* --autumnGreen: #76946A */
|
@define-color autumnGreen #76946A;
|
||||||
/* --autumnRed: #C34043 */
|
@define-color autumnRed #C34043;
|
||||||
/* --autumnYellow: #DCA561 */
|
@define-color autumnYellow #DCA561;
|
||||||
/* --samuraiRed: #E82424 */
|
@define-color samuraiRed #E82424;
|
||||||
/* --roninYellow: #FF9E3B */
|
@define-color roninYellow #FF9E3B;
|
||||||
/* --waveAqua1: #6A9589 */
|
@define-color waveAqua1 #6A9589;
|
||||||
/* --dragonBlue: #658594 */
|
@define-color dragonBlue #658594;
|
||||||
/* --fujiGray: #727169 */
|
@define-color fujiGray #727169;
|
||||||
/* --springViolet1: #938AA9 */
|
@define-color springViolet1 #938AA9;
|
||||||
/* --oniViolet: #957FB8 */
|
@define-color oniViolet #957FB8;
|
||||||
/* --crystalBlue: #7E9CD8 */
|
@define-color crystalBlue #7E9CD8;
|
||||||
/* --springViolet2: #9CABCA */
|
@define-color springViolet2 #9CABCA;
|
||||||
/* --springBlue: #7FB4CA */
|
@define-color springBlue #7FB4CA;
|
||||||
/* --lightBlue: #A3D4D5 */
|
@define-color lightBlue #A3D4D5;
|
||||||
/* --waveAqua2: #7AA89F */
|
@define-color waveAqua2 #7AA89F;
|
||||||
/* --springGreen: #98BB6C */
|
@define-color springGreen #98BB6C;
|
||||||
/* --boatYellow1: #938056 */
|
@define-color boatYellow1 #938056;
|
||||||
/* --boatYellow2: #C0A36E */
|
@define-color boatYellow2 #C0A36E;
|
||||||
/* --carpYellow: #E6C384 */
|
@define-color carpYellow #E6C384;
|
||||||
/* --sakuraPink: #D27E99 */
|
@define-color sakuraPink #D27E99;
|
||||||
/* --waveRed: #E46876 */
|
@define-color waveRed #E46876;
|
||||||
/* --peachRed: #FF5D62 */
|
@define-color peachRed #FF5D62;
|
||||||
/* --surimiOrange: #FFA066 */
|
@define-color surimiOrange #FFA066;
|
||||||
|
|
||||||
/* waybar style.css */
|
|
||||||
@define-color bgcolor #16161D; /* background color */
|
|
||||||
@define-color fgcolor #DCD7BA; /* foreground color */
|
|
||||||
@define-color charging #07fb05; /* battery charging color */
|
|
||||||
@define-color plugged #acfcad; /* ac plugged color */
|
|
||||||
@define-color critical #ff0000; /* critical color */
|
|
||||||
@define-color warning #f3f809; /* warning color */
|
|
||||||
@define-color hover #94a6e3; /* mouse hover over workspace color */
|
|
||||||
|
|
||||||
/* Reset all styles */
|
|
||||||
* {
|
* {
|
||||||
border: none;
|
|
||||||
border-radius: 0;
|
|
||||||
min-height: 0;
|
min-height: 0;
|
||||||
margin: 0;
|
padding: 3px;
|
||||||
padding: 0;
|
margin: 3px;
|
||||||
|
border-radius: 20px;
|
||||||
|
padding-left: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#waybar {
|
#waybar {
|
||||||
background: transparent;
|
background: transparent;
|
||||||
font-family: JetBrainsMono;
|
font-family: JetBrainsMono;
|
||||||
font-size: medium;
|
font-size: medium;
|
||||||
color: @fgcolor;
|
color: @fujiWhite;
|
||||||
|
}
|
||||||
|
|
||||||
|
#custom-media {
|
||||||
|
background: @sumiInk0;
|
||||||
|
border-top: 2px solid @oniViolet;
|
||||||
|
border-left: 2px solid @oniViolet;
|
||||||
|
}
|
||||||
|
|
||||||
|
#workspaces {
|
||||||
|
background: @sumiInk0;
|
||||||
|
transition: none;
|
||||||
|
border-top: 2px solid @oniViolet;
|
||||||
|
border-left: 2px solid @oniViolet;
|
||||||
|
border-right: 2px solid @oniViolet;
|
||||||
}
|
}
|
||||||
|
|
||||||
#workspaces button {
|
#workspaces button {
|
||||||
padding-left: 10px;
|
transition: none;
|
||||||
padding-right: 10px;
|
margin: 0px;
|
||||||
color: @bgcolor;
|
color: @oniViolet;
|
||||||
|
background: transparent;
|
||||||
|
border-bottom: 2px solid @oniViolet;
|
||||||
|
border-radius: 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#workspaces button.focused {
|
#workspaces button.focused {
|
||||||
background: @bgcolor;
|
color: @springGreen;
|
||||||
color: @fgcolor;
|
border-bottom: 2px solid @springGreen;
|
||||||
|
border-radius: 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#workspaces button:hover {
|
#workspaces button:hover {
|
||||||
background: @hover;
|
|
||||||
color: @fgcolor;
|
|
||||||
transition: none;
|
transition: none;
|
||||||
box-shadow: inherit;
|
box-shadow: inherit;
|
||||||
text-shadow: inherit;
|
text-shadow: inherit;
|
||||||
}
|
border-top: 0px;
|
||||||
|
border-bottom: 2px solid @peachRed;
|
||||||
#custom-cap-left,
|
color: @sakuraPink;
|
||||||
#custom-cap-right {
|
border-right: 0px;
|
||||||
color: @bgcolor;
|
border-left: 0px;
|
||||||
font-size: 24px;
|
border-radius: 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#idle_inhibitor {
|
#idle_inhibitor {
|
||||||
background: @bgcolor;
|
margin-left: 0px;
|
||||||
padding-left: 20px;
|
background: @sumiInk0;
|
||||||
padding-right: 10px;
|
border-top: 2px solid @oniViolet;
|
||||||
}
|
border-left: 2px solid @oniViolet;
|
||||||
|
|
||||||
#custom-offswitch {
|
|
||||||
background: @bgcolor;
|
|
||||||
padding-right: 20px;
|
|
||||||
padding-left: 10px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#network,
|
||||||
#custom-weather,
|
#custom-weather,
|
||||||
|
#clock,
|
||||||
|
#custom-offswitch {
|
||||||
|
background: @sumiInk0;
|
||||||
|
border-top: 2px solid @oniViolet;
|
||||||
|
border-right: 2px solid @oniViolet;
|
||||||
|
}
|
||||||
|
|
||||||
#cpu,
|
#cpu,
|
||||||
#temperature,
|
|
||||||
#memory,
|
#memory,
|
||||||
#pulseaudio,
|
#pulseaudio,
|
||||||
#disk,
|
#disk,
|
||||||
#battery,
|
#temperature,
|
||||||
#clock,
|
#battery {
|
||||||
#network {
|
background: @sumiInk0;
|
||||||
background: @bgcolor;
|
|
||||||
padding-left: 10px;
|
padding-left: 10px;
|
||||||
padding-right: 10px;
|
padding-right: 10px;
|
||||||
|
border-top: 2px solid @oniViolet;
|
||||||
|
border-left: 2px solid @oniViolet;
|
||||||
}
|
}
|
||||||
|
|
||||||
#disk.critical {
|
#disk.critical {
|
||||||
color: @critical;
|
color: @samuraiRed;
|
||||||
}
|
}
|
||||||
|
|
||||||
#temperature.critical {
|
#temperature.critical {
|
||||||
color: @critical;
|
color: @samuraiRed;
|
||||||
}
|
}
|
||||||
|
|
||||||
#cpu.critical {
|
#cpu.critical {
|
||||||
color: @critical;
|
color: @samuraiRed;
|
||||||
}
|
}
|
||||||
|
|
||||||
#memory.critical {
|
#memory.critical {
|
||||||
color: @critical;
|
color: @samuraiRed;
|
||||||
}
|
}
|
||||||
|
|
||||||
@keyframes blink1 {
|
@keyframes blink1 {
|
||||||
to {
|
to {
|
||||||
color: @plugged;
|
color: @springGreen;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#battery.plugged {
|
#battery.plugged {
|
||||||
background-color: @bgcolor;
|
background-color: @sumiInk0;
|
||||||
animation-name: blink1;
|
animation-name: blink1;
|
||||||
animation-duration: 0.5s;
|
animation-duration: 0.5s;
|
||||||
animation-timing-function: linear;
|
animation-timing-function: linear;
|
||||||
@ -144,12 +154,12 @@
|
|||||||
|
|
||||||
@keyframes blink2 {
|
@keyframes blink2 {
|
||||||
to {
|
to {
|
||||||
background-color: @charging;
|
background-color: @carpYellow;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#battery.charging {
|
#battery.charging {
|
||||||
/* background-color: @bgcolor; */
|
/* background-color: @sumiInk0; */
|
||||||
animation-name: blink2;
|
animation-name: blink2;
|
||||||
animation-duration: 2s;
|
animation-duration: 2s;
|
||||||
animation-timing-function: ease-in-out;
|
animation-timing-function: ease-in-out;
|
||||||
@ -159,12 +169,12 @@
|
|||||||
|
|
||||||
@keyframes blink3 {
|
@keyframes blink3 {
|
||||||
to {
|
to {
|
||||||
background-color: @warning;
|
background-color: @roninYellow;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#battery.warning:not(.charging) {
|
#battery.warning:not(.charging) {
|
||||||
/* background-color: @bgcolor; */
|
/* background-color: @sumiInk0; */
|
||||||
animation-name: blink3;
|
animation-name: blink3;
|
||||||
animation-duration: 0.7s;
|
animation-duration: 0.7s;
|
||||||
animation-timing-function: ease-in-out;
|
animation-timing-function: ease-in-out;
|
||||||
@ -174,12 +184,12 @@
|
|||||||
|
|
||||||
@keyframes blink4 {
|
@keyframes blink4 {
|
||||||
to {
|
to {
|
||||||
background-color: @critical;
|
background-color: @samuraiRed;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#battery.critical:not(.charging) {
|
#battery.critical:not(.charging) {
|
||||||
/* background-color: @bgcolor; */
|
/* background-color: @sumiInk0; */
|
||||||
animation-name: blink4;
|
animation-name: blink4;
|
||||||
animation-duration: 0.8s;
|
animation-duration: 0.8s;
|
||||||
animation-timing-function: ease-in-out;
|
animation-timing-function: ease-in-out;
|
||||||
|
BIN
dots/.local/share/wallpapers/Space-Mountains.png
Normal file
BIN
dots/.local/share/wallpapers/Space-Mountains.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.7 MiB |
BIN
dots/.local/share/wallpapers/TokyoNight.jpg
Normal file
BIN
dots/.local/share/wallpapers/TokyoNight.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.2 MiB |
Loading…
x
Reference in New Issue
Block a user