feat(ags bar): disappear on fullscreen

This commit is contained in:
matt1432 2023-10-07 20:41:24 -04:00
parent 71b6939bfb
commit a7fdacd252
2 changed files with 88 additions and 4 deletions

View file

@ -0,0 +1,81 @@
import { Widget, Hyprland, Utils, Variable } from '../../imports.js';
const { Box, EventBox } = Widget;
const Revealed = Variable(true);
const Hovering = Variable(false);
import { Gesture } from './gesture.js';
export const Revealer = params => Box({
style: 'min-height: 1px',
vertical: true,
children: [
Widget.Revealer({
transition: 'slide_down',
setup: self => self.revealChild = true,
properties: [
['timeouts', []],
],
connections: [[Hyprland, self => {
Utils.execAsync('hyprctl activewindow -j')
.then(result => {
let client = JSON.parse(result);
if (client.fullscreen === Revealed.value) return;
Revealed.value = client.fullscreen;
if (Revealed.value) {
setTimeout(() => {
if (Revealed.value)
self.revealChild = false
}, 2000);
}
else {
self.revealChild = true;
}
}).catch(print);
}]],
child: Gesture({
onHover: () => Hovering.value = true,
onHoverLost: self => {
Hovering.value = false;
if (Revealed.value) {
setTimeout(() => {
if (!Hovering.value) {
self.get_parent().get_parent().children[1].revealChild = true;
self.get_parent().revealChild = false;
}
}, 2000);
}
},
...params,
}),
}),
Widget.Revealer({
connections: [[Revealed, self => {
if (Revealed.value) {
setTimeout(() => {
if (Revealed.value)
self.revealChild = true;
}, 2000);
}
else {
self.revealChild = false;
}
}]],
child: EventBox({
onHover: self => {
Hovering.value = true;
self.get_parent().get_parent().children[0].revealChild = true;
self.get_parent().revealChild = false;
},
child: Box({
style: 'min-height: 50px;',
}),
}),
}),
],
});

View file

@ -13,7 +13,7 @@ import { SysTray } from './systray.js';
import { BatteryIndicator } from './battery.js'; import { BatteryIndicator } from './battery.js';
import { Brightness } from './brightness.js'; import { Brightness } from './brightness.js';
import { AudioIndicator } from './audio.js'; import { AudioIndicator } from './audio.js';
import { Gesture } from './gesture.js'; import { Revealer } from './fullscreen.js';
export const Bar = Window({ export const Bar = Window({
@ -21,8 +21,7 @@ export const Bar = Window({
layer: 'overlay', layer: 'overlay',
anchor: 'top left right', anchor: 'top left right',
exclusive: true, exclusive: true,
child: Revealer({
child: Gesture({
child: CenterBox({ child: CenterBox({
className: 'transparent', className: 'transparent',
halign: 'fill', halign: 'fill',
@ -56,7 +55,11 @@ export const Bar = Window({
], ],
}), }),
centerWidget: CurrentWindow, centerWidget: Box({
children: [
CurrentWindow,
],
}),
endWidget: Box({ endWidget: Box({
halign: 'end', halign: 'end',