ags: updates
All checks were successful
flake check / check (push) Successful in 9m47s
fmt check / check (push) Successful in 1m14s
All checks were successful
flake check / check (push) Successful in 9m47s
fmt check / check (push) Successful in 1m14s
This commit is contained in:
parent
e192ba705e
commit
a9626cfd89
15 changed files with 117 additions and 35 deletions
|
@ -7,6 +7,7 @@ import Audio from "resource:///com/github/Aylur/ags/service/audio.js";
|
|||
import Hyprland from "resource:///com/github/Aylur/ags/service/hyprland.js";
|
||||
import Network from "resource:///com/github/Aylur/ags/service/network.js";
|
||||
import SystemTray from "resource:///com/github/Aylur/ags/service/systemtray.js";
|
||||
import Mpris from 'resource:///com/github/Aylur/ags/service/mpris.js';
|
||||
|
||||
export {
|
||||
App,
|
||||
|
@ -18,4 +19,5 @@ export {
|
|||
Utils,
|
||||
Variable,
|
||||
Widget,
|
||||
Mpris,
|
||||
};
|
|
@ -1,26 +1,31 @@
|
|||
import { Widget } from '../import.js';
|
||||
import { Time } from './widgets/time.js'
|
||||
import { nixosLogo } from './widgets/image.js';
|
||||
import { nixosLogo } from './widgets/images/image.js';
|
||||
import { Media } from './widgets/music.js';
|
||||
import { Workspaces } from './widgets/hyprland.js';
|
||||
|
||||
const Start = () => Widget.Box({
|
||||
hpack: "start",
|
||||
children: [
|
||||
nixosLogo()
|
||||
nixosLogo(),
|
||||
Workspaces(),
|
||||
]
|
||||
})
|
||||
});
|
||||
const Center = () => Widget.Box({
|
||||
children: []
|
||||
})
|
||||
children: [
|
||||
Media(),
|
||||
]
|
||||
});
|
||||
const End = () => Widget.Box({
|
||||
hpack: "end",
|
||||
children: [
|
||||
Time()
|
||||
Time(),
|
||||
]
|
||||
})
|
||||
});
|
||||
|
||||
const Bar = (monitor) => Widget.Window({
|
||||
monitor,
|
||||
name: `bar-${monitor}`,
|
||||
name: `bar`,
|
||||
anchor: ['top', 'left', 'right'],
|
||||
exclusivity: 'exclusive',
|
||||
child: Widget.CenterBox({
|
||||
|
@ -28,8 +33,8 @@ const Bar = (monitor) => Widget.Window({
|
|||
centerWidget: Center(),
|
||||
endWidget: End(),
|
||||
}),
|
||||
})
|
||||
});
|
||||
|
||||
export {
|
||||
Bar
|
||||
}
|
||||
}
|
||||
|
|
17
home/ags/config/js/widgets/hyprland.js
Normal file
17
home/ags/config/js/widgets/hyprland.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
import { Hyprland, Widget } from "../../import.js";
|
||||
|
||||
const Workspaces = () => Widget.Box({
|
||||
class_name: 'workspaces',
|
||||
children: Hyprland.bind('workspaces').transform(ws => {
|
||||
return ws.map(({ id }) => Widget.Button({
|
||||
on_clicked: () => Hyprland.sendMessage(`dispatch workspace ${id}`),
|
||||
child: Widget.Label(`${id}`),
|
||||
class_name: Hyprland.active.workspace.bind('id')
|
||||
.transform(i => `${i === id ? 'focused' : ''}`),
|
||||
}));
|
||||
}),
|
||||
});
|
||||
|
||||
export {
|
||||
Workspaces
|
||||
}
|
|
@ -1,9 +0,0 @@
|
|||
import { Widget } from '../../import.js';
|
||||
|
||||
const nixosLogo = () => Widget.Icon({
|
||||
icon: '/home/notoh/Pictures/icons/nixos.png'
|
||||
});
|
||||
|
||||
export {
|
||||
nixosLogo
|
||||
}
|
9
home/ags/config/js/widgets/images/image.js
Normal file
9
home/ags/config/js/widgets/images/image.js
Normal file
|
@ -0,0 +1,9 @@
|
|||
import { Widget } from '../../../import.js';
|
||||
|
||||
const nixosLogo = () => Widget.Icon({
|
||||
icon: '/home/notoh/snowflake/home/ags/config/js/widgets/images/static/nixos.png'
|
||||
});
|
||||
|
||||
export {
|
||||
nixosLogo
|
||||
}
|
BIN
home/ags/config/js/widgets/images/static/nixos.png
Normal file
BIN
home/ags/config/js/widgets/images/static/nixos.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 28 KiB |
17
home/ags/config/js/widgets/music.js
Normal file
17
home/ags/config/js/widgets/music.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
import { Widget, Mpris } from "../../import.js";
|
||||
|
||||
const Media = () => Widget.Box({
|
||||
class_name: 'media',
|
||||
child: Widget.Label('-').hook(Mpris, self => {
|
||||
if (Mpris.players[0]) {
|
||||
const { track_artists, track_title } = Mpris.players[0];
|
||||
self.label = `${track_artists.join(', ')} - ${track_title}`;
|
||||
} else {
|
||||
self.label = 'Nothing is playing';
|
||||
}
|
||||
}, 'player-changed'),
|
||||
});
|
||||
|
||||
export {
|
||||
Media
|
||||
}
|
0
home/ags/config/js/widgets/system.js
Normal file
0
home/ags/config/js/widgets/system.js
Normal file
|
@ -1,7 +1,7 @@
|
|||
import { Widget, Utils } from '../../import.js';
|
||||
|
||||
|
||||
const Time = () => Widget.EventBox({
|
||||
const Time = () => Widget.Box({
|
||||
child: Widget.Label({
|
||||
className: "date"
|
||||
}).poll(
|
||||
|
|
|
@ -1,2 +1,9 @@
|
|||
@import 'scss/bar.scss';
|
||||
@import 'scss/general.scss';
|
||||
@import 'scss/general.scss';
|
||||
@import 'scss/widgets.scss';
|
||||
|
||||
* {
|
||||
all: unset;
|
||||
margin: 3px;
|
||||
font-family: 'Monaspace Krypton';
|
||||
}
|
|
@ -1,9 +1,5 @@
|
|||
* {
|
||||
all: unset;
|
||||
margin: 3px;
|
||||
font-family: 'Monaspace Krypton';
|
||||
}
|
||||
@import 'colors.scss';
|
||||
|
||||
window {
|
||||
background-color: black;
|
||||
background-color: $background;
|
||||
}
|
24
home/ags/config/scss/colors.scss
Normal file
24
home/ags/config/scss/colors.scss
Normal file
|
@ -0,0 +1,24 @@
|
|||
/* tokyonight */
|
||||
|
||||
$red: #f7768e;
|
||||
$orange: #ff9e64;
|
||||
$yellow: #e0af68;
|
||||
$light-green: #9ece6a;
|
||||
$green: #73daca;
|
||||
$turquoise: #89ddff;
|
||||
$light-cyan: #b4f9f8;
|
||||
$teal: #2ac3de;
|
||||
$cyan: #7dcfff;
|
||||
$blue: #7aa2f7;
|
||||
$magenta: #bb9af7;
|
||||
$white: #c0caf5;
|
||||
$light-gray: #9aa5ce;
|
||||
$parameters: #cfc9c2;
|
||||
$comment: #565f89;
|
||||
$black: #414868;
|
||||
$foreground: #a9b1d6;
|
||||
$foreground-highlight: #c0caf5;
|
||||
$foreground-gutter: #363b54;
|
||||
$background: #1a1b26;
|
||||
$background-highlight: #30374b;
|
||||
$background-menu: #16161e;
|
|
@ -1,7 +0,0 @@
|
|||
.date {
|
||||
color: #ffffff;
|
||||
}
|
||||
|
||||
image {
|
||||
font-size: 24px;
|
||||
}
|
21
home/ags/config/scss/widgets.scss
Normal file
21
home/ags/config/scss/widgets.scss
Normal file
|
@ -0,0 +1,21 @@
|
|||
@import 'colors.scss';
|
||||
|
||||
@mixin widget {
|
||||
color: $white
|
||||
};
|
||||
|
||||
.date {
|
||||
@include widget();
|
||||
}
|
||||
|
||||
.workspaces {
|
||||
@include widget();
|
||||
};
|
||||
|
||||
.media {
|
||||
@include widget();
|
||||
}
|
||||
|
||||
image {
|
||||
font-size: 24px;
|
||||
}
|
|
@ -7,7 +7,7 @@
|
|||
in {
|
||||
programs.ags = {
|
||||
enable = true;
|
||||
extraPackages = with pkgs; [libsoup_3];
|
||||
extraPackages = with pkgs; [libsoup_3 libdbusmenu-gtk3];
|
||||
};
|
||||
home.packages = with pkgs; [dart-sass];
|
||||
xdg.configFile = {
|
||||
|
|
Loading…
Reference in a new issue