feat: use derivation to transpile scss to css
This commit is contained in:
parent
65965e5859
commit
0f1f2f70ad
5 changed files with 188 additions and 174 deletions
|
@ -1,7 +1,14 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
|
let
|
||||||
|
toCSS = import ./tocss.nix;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
programs.waybar = {
|
programs.waybar = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
style = toCSS {
|
||||||
|
inherit pkgs;
|
||||||
|
file = ./style.scss;
|
||||||
|
};
|
||||||
settings = {
|
settings = {
|
||||||
main = import ./config.nix;
|
main = import ./config.nix;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,172 +0,0 @@
|
||||||
''
|
|
||||||
* {
|
|
||||||
font-family: "DejaVuSansMNerdFont-Regular";
|
|
||||||
border: none;
|
|
||||||
opacity: 50;
|
|
||||||
border-radius: 10px;
|
|
||||||
font-size: 13px; }
|
|
||||||
|
|
||||||
window#waybar {
|
|
||||||
background: transparent; }
|
|
||||||
|
|
||||||
window#waybar.hidden {
|
|
||||||
opacity: 0.2; }
|
|
||||||
|
|
||||||
#window {
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
border-radius: 10px;
|
|
||||||
transition: none;
|
|
||||||
color: transparent;
|
|
||||||
background: transparent; }
|
|
||||||
|
|
||||||
.modules-center {
|
|
||||||
margin: 3px 0 0 0; }
|
|
||||||
|
|
||||||
.modules-right {
|
|
||||||
margin: 3px 8px 0 0; }
|
|
||||||
|
|
||||||
.modules-left {
|
|
||||||
margin: 3px 0 0 8px; }
|
|
||||||
|
|
||||||
#workspaces {
|
|
||||||
background-color: rgba(13, 214, 250, 0.4); }
|
|
||||||
#workspaces button {
|
|
||||||
padding: 1px 5px; }
|
|
||||||
#workspaces button:hover {
|
|
||||||
background-color: rgba(159, 255, 255, 0.9); }
|
|
||||||
#workspaces button.focused {
|
|
||||||
background-color: rgba(50, 194, 219, 0.7); }
|
|
||||||
|
|
||||||
#network {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #bd93f9; }
|
|
||||||
|
|
||||||
#pulseaudio {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
min-width: 23px;
|
|
||||||
color: #1a1826;
|
|
||||||
background: #fae3b0; }
|
|
||||||
|
|
||||||
#backlight {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #f8bd96; }
|
|
||||||
|
|
||||||
#clock {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #abe9b3; }
|
|
||||||
|
|
||||||
#memory {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #ddb6f2; }
|
|
||||||
|
|
||||||
#privacy {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #ddb6f2; }
|
|
||||||
|
|
||||||
#cpu {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #96cdfb; }
|
|
||||||
|
|
||||||
#tray {
|
|
||||||
padding-left: 10px;
|
|
||||||
margin-right: 4px;
|
|
||||||
padding-right: 10px;
|
|
||||||
border-radius: 10px;
|
|
||||||
color: #b5e8e0;
|
|
||||||
background: #161320; }
|
|
||||||
|
|
||||||
#idle_inhibitor {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
font-size: 20px;
|
|
||||||
color: #161320;
|
|
||||||
background: #f28fad; }
|
|
||||||
|
|
||||||
#group-power {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
font-size: 20px;
|
|
||||||
transition: none;
|
|
||||||
color: #161320;
|
|
||||||
background: #f28fad; }
|
|
||||||
|
|
||||||
#custom-notification {
|
|
||||||
margin-left: 4px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
border-radius: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #f2cdcd;
|
|
||||||
font-family: "NotoSansMono Nerd Font"; }
|
|
||||||
|
|
||||||
#mode {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #ddb6f2; }
|
|
||||||
|
|
||||||
@keyframes blink {
|
|
||||||
to {
|
|
||||||
background-color: #bf616a;
|
|
||||||
color: #b5e8e0; } }
|
|
||||||
|
|
||||||
#battery {
|
|
||||||
margin-left: 4px;
|
|
||||||
margin-right: 4px;
|
|
||||||
border-radius: 10px;
|
|
||||||
padding-left: 10px;
|
|
||||||
padding-right: 10px;
|
|
||||||
color: #161320;
|
|
||||||
background: #b5e8e0; }
|
|
||||||
#battery .critical:not(.charging) {
|
|
||||||
animation-name: blink;
|
|
||||||
animation-duration: 0.5s;
|
|
||||||
animation-timing-function: linear;
|
|
||||||
animation-iteration-count: infinite;
|
|
||||||
animation-direction: alternate; }
|
|
||||||
|
|
||||||
''
|
|
173
home/sway/waybar/style.scss
Normal file
173
home/sway/waybar/style.scss
Normal file
|
@ -0,0 +1,173 @@
|
||||||
|
@mixin border {
|
||||||
|
margin-left: 4px;
|
||||||
|
margin-right: 4px;
|
||||||
|
border-radius: 10px;
|
||||||
|
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin border-left {
|
||||||
|
padding-left: 10px;
|
||||||
|
margin-right: 4px;
|
||||||
|
padding-right: 10px;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin border-right {
|
||||||
|
margin-left: 4px;
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
* {
|
||||||
|
font-family: "DejaVuSansMNerdFont-Regular";
|
||||||
|
border: none;
|
||||||
|
opacity: 50;
|
||||||
|
border-radius: 10px;
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
window#waybar {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
window#waybar.hidden {
|
||||||
|
opacity: 0.2;
|
||||||
|
}
|
||||||
|
|
||||||
|
#window {
|
||||||
|
padding-left: 10px;
|
||||||
|
padding-right: 10px;
|
||||||
|
border-radius: 10px;
|
||||||
|
transition: none;
|
||||||
|
color: transparent;
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.modules-center {
|
||||||
|
margin: 3px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.modules-right {
|
||||||
|
margin: 3px 8px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.modules-left {
|
||||||
|
margin: 3px 0 0 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#workspaces {
|
||||||
|
background-color: rgba(13, 214, 250, 0.4);
|
||||||
|
|
||||||
|
button {
|
||||||
|
padding: 1px 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
button:hover {
|
||||||
|
background-color: rgba(159, 255, 255, 0.9);
|
||||||
|
}
|
||||||
|
|
||||||
|
button.focused {
|
||||||
|
background-color: rgba(50, 194, 219, 0.7);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#network {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #bd93f9;
|
||||||
|
}
|
||||||
|
|
||||||
|
#pulseaudio {
|
||||||
|
@include border();
|
||||||
|
min-width: 23px;
|
||||||
|
color: #1a1826;
|
||||||
|
background: #fae3b0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#backlight {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #f8bd96;
|
||||||
|
}
|
||||||
|
|
||||||
|
#clock {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #abe9b3;
|
||||||
|
}
|
||||||
|
|
||||||
|
#memory {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #ddb6f2;
|
||||||
|
}
|
||||||
|
|
||||||
|
#privacy {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #ddb6f2;
|
||||||
|
}
|
||||||
|
|
||||||
|
#cpu {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #96cdfb;
|
||||||
|
}
|
||||||
|
|
||||||
|
#tray {
|
||||||
|
@include border-left();
|
||||||
|
color: #b5e8e0;
|
||||||
|
background: #161320;
|
||||||
|
}
|
||||||
|
|
||||||
|
#idle_inhibitor {
|
||||||
|
@include border();
|
||||||
|
font-size: 20px;
|
||||||
|
color: #161320;
|
||||||
|
background: #f28fad;
|
||||||
|
}
|
||||||
|
|
||||||
|
#group-power {
|
||||||
|
@include border();
|
||||||
|
font-size: 20px;
|
||||||
|
transition: none;
|
||||||
|
color: #161320;
|
||||||
|
background: #f28fad;
|
||||||
|
}
|
||||||
|
|
||||||
|
#custom-notification {
|
||||||
|
@include border-right();
|
||||||
|
color: #161320;
|
||||||
|
background: #f2cdcd;
|
||||||
|
font-family: "NotoSansMono Nerd Font";
|
||||||
|
}
|
||||||
|
|
||||||
|
#mode {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #ddb6f2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes blink {
|
||||||
|
to {
|
||||||
|
background-color: #bf616a;
|
||||||
|
color: #b5e8e0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#battery {
|
||||||
|
@include border();
|
||||||
|
color: #161320;
|
||||||
|
background: #b5e8e0;
|
||||||
|
|
||||||
|
.critical:not(.charging) {
|
||||||
|
animation-name: blink;
|
||||||
|
animation-duration: 0.5s;
|
||||||
|
animation-timing-function: linear;
|
||||||
|
animation-iteration-count: infinite;
|
||||||
|
animation-direction: alternate;
|
||||||
|
}
|
||||||
|
}
|
7
home/sway/waybar/tocss.nix
Normal file
7
home/sway/waybar/tocss.nix
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{ pkgs, file, ... }:
|
||||||
|
pkgs.stdenv.mkDerivation {
|
||||||
|
name = "toCSS";
|
||||||
|
buildCommand = ''
|
||||||
|
${pkgs.sass}/bin/scss ${file} $out
|
||||||
|
'';
|
||||||
|
}
|
|
@ -218,7 +218,6 @@ in
|
||||||
bat
|
bat
|
||||||
kdeconnect
|
kdeconnect
|
||||||
dotter
|
dotter
|
||||||
sassc
|
|
||||||
glib
|
glib
|
||||||
pamixer
|
pamixer
|
||||||
wireguard-tools
|
wireguard-tools
|
||||||
|
@ -231,8 +230,8 @@ in
|
||||||
fonts = with pkgs; {
|
fonts = with pkgs; {
|
||||||
packages = [
|
packages = [
|
||||||
(nerdfonts.override { fonts = [ "Noto" ]; })
|
(nerdfonts.override { fonts = [ "Noto" ]; })
|
||||||
jigmo
|
|
||||||
d2coding
|
d2coding
|
||||||
|
jigmo
|
||||||
last-resort
|
last-resort
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Reference in a new issue