feat(ags bar): disappear on fullscreen
This commit is contained in:
parent
71b6939bfb
commit
a7fdacd252
2 changed files with 88 additions and 4 deletions
81
config/ags/js/bar/fullscreen.js
Normal file
81
config/ags/js/bar/fullscreen.js
Normal 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;',
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
});
|
|
@ -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',
|
||||||
|
|
Loading…
Reference in a new issue