mirror of
https://github.com/zephrynis/nix-flake.git
synced 2026-02-19 04:21:55 +00:00
- Add complete colorshell v2.0.3 configuration to home/ags-config/ - Disable runner plugin and NightLight tile (incompatible with NixOS) - Customize SCSS with full opacity (no transparency) - Add dark pale blue color scheme in home/pywal-colors/ - Configure Papirus-Dark icon theme via home-manager - Make ~/.config/ags/ immutable and managed by Nix store - Auto-deploy pywal colors to ~/.cache/wal/colors.json All AGS configuration is now reproducible and version controlled.
101 lines
2.7 KiB
TypeScript
101 lines
2.7 KiB
TypeScript
import GObject, { getter, gtype, register } from "ags/gobject";
|
|
import { Gtk } from "ags/gtk4";
|
|
import { Page } from "../Page";
|
|
|
|
import GLib from "gi://GLib?version=2.0";
|
|
|
|
|
|
@register({ GTypeName: "Pages" })
|
|
export class Pages extends Gtk.Box {
|
|
#timeouts: Array<[GLib.Source, (() => void)|undefined]> = [];
|
|
#page: Page|undefined;
|
|
#transDuration: number;
|
|
#transType: Gtk.RevealerTransitionType = Gtk.RevealerTransitionType.SLIDE_DOWN;
|
|
|
|
@getter(Boolean)
|
|
get isOpen() { return Boolean(this.#page); }
|
|
|
|
@getter(gtype<Page|undefined>(Page))
|
|
get page() { return this.#page; }
|
|
|
|
constructor(props?: {
|
|
initialPage?: Page;
|
|
transitionDuration?: number;
|
|
}) {
|
|
super({
|
|
orientation: Gtk.Orientation.VERTICAL,
|
|
cssName: "pages",
|
|
name: "pages"
|
|
});
|
|
|
|
this.add_css_class("pages");
|
|
|
|
this.#transDuration = props?.transitionDuration ?? 280;
|
|
|
|
if(props?.initialPage)
|
|
this.open(props.initialPage);
|
|
|
|
|
|
const destroyId = this.connect("destroy", () => {
|
|
GObject.signal_handler_is_connected(this, destroyId) &&
|
|
this.disconnect(destroyId);
|
|
|
|
this.#timeouts.forEach((tmout) => {
|
|
tmout[0].destroy();
|
|
(async () => tmout[1]?.())().catch((err: Error) => {
|
|
console.error(`${err.message}\n${err.stack}`);
|
|
});
|
|
});
|
|
});
|
|
}
|
|
|
|
toggle(newPage?: Page, onToggled?: () => void): void {
|
|
if(!newPage || (this.#page?.id === newPage.id)) {
|
|
this.close(onToggled);
|
|
return;
|
|
}
|
|
|
|
if(!this.isOpen) {
|
|
newPage && this.open(newPage, onToggled);
|
|
return;
|
|
}
|
|
|
|
if(this.#page?.id !== newPage.id) {
|
|
this.close();
|
|
this.open(newPage, onToggled);
|
|
}
|
|
}
|
|
|
|
open(newPage: Page, onOpen?: () => void) {
|
|
this.#page = newPage;
|
|
|
|
this.prepend(
|
|
<Gtk.Revealer revealChild={false} transitionType={this.#transType}
|
|
transitionDuration={this.#transDuration}>
|
|
|
|
{newPage.create()}
|
|
</Gtk.Revealer> as Gtk.Revealer
|
|
);
|
|
|
|
(this.get_first_child() as Gtk.Revealer)?.set_reveal_child(true);
|
|
onOpen?.();
|
|
}
|
|
|
|
close(onClosed?: () => void): void {
|
|
const page = this.get_first_child() as Gtk.Revealer|null;
|
|
if(!page) return;
|
|
|
|
this.#page?.actionClosed?.();
|
|
this.#page = undefined;
|
|
|
|
page.set_reveal_child(false);
|
|
this.#timeouts.push([
|
|
setTimeout(() => {
|
|
this.remove(page);
|
|
onClosed?.();
|
|
}, page.transitionDuration),
|
|
onClosed
|
|
]);
|
|
}
|
|
}
|