Implemented config changing functionality

This commit is contained in:
Jas Singh
2024-07-15 01:37:41 -07:00
parent abe491e6d0
commit 11785d1a5d
10 changed files with 282 additions and 170 deletions

126
config.js
View File

@@ -1,46 +1,92 @@
import { exec } from "resource:///com/github/Aylur/ags/utils.js";
import { Bar, BarAlt } from "./modules/bar/index.js";
import DirectoryMonitorService from "./directoryMonitorService.js";
import MenuWindows from "./modules/menus/main.js";
import Notifications from "./modules/notifications/index.js";
import GLib from "gi://GLib"
const applyScss = () => {
// Compile scss
exec(`sass ${App.configDir}/scss/main.scss ${App.configDir}/style.css`);
exec(
`sass ${App.configDir}/scss/highlight.scss ${App.configDir}/highlight.css`,
);
console.log("Scss compiled");
const main = "/tmp/ags/hyprpanel/main.js"
const entry = `${App.configDir}/main.ts`
const bundler = GLib.getenv("AGS_BUNDLER") || "bun"
// Apply compiled css
App.resetCss();
App.applyCss(`${App.configDir}/style.css`);
console.log("Compiled css applied");
};
const v = {
ags: pkg.version?.split(".").map(Number) || [],
expect: [1, 8, 1],
}
DirectoryMonitorService.connect("changed", () => applyScss());
try {
switch (bundler) {
case "bun": await Utils.execAsync([
"bun", "build", entry,
"--outfile", main,
"--external", "resource://*",
"--external", "gi://*",
"--external", "file://*",
]); break
applyScss();
case "esbuild": await Utils.execAsync([
"esbuild", "--bundle", entry,
"--format=esm",
`--outfile=${main}`,
"--external:resource://*",
"--external:gi://*",
"--external:file://*",
]); break
const workspaceMonitorMap = {
0: [4, 5],
1: [6, 7],
2: [1, 2, 3, 8, 9, 10],
};
default:
throw `"${bundler}" is not a valid bundler`
}
App.config({
windows: [
...MenuWindows,
Notifications(),
BarAlt(0, workspaceMonitorMap),
BarAlt(1, workspaceMonitorMap),
Bar(2, workspaceMonitorMap),
],
style: `${App.configDir}/style.css`,
closeWindowDelay: {
sideright: 350,
launcher: 350,
bar0: 350,
},
onConfigParsed: () => Utils.execAsync(`python3 ${App.configDir}/services/bluetooth.py`),
});
if (v.ags[1] < v.expect[1] || v.ags[2] < v.expect[2]) {
print(`my config needs at least v${v.expect.join(".")}, yours is v${v.ags.join(".")}`)
App.quit()
}
await import(`file://${main}`)
} catch (error) {
console.error(error)
App.quit()
}
export { }
// import { exec } from "resource:///com/github/Aylur/ags/utils.js";
// import { Bar, BarAlt } from "./modules/bar/index.js";
// import DirectoryMonitorService from "./directoryMonitorService.js";
// import MenuWindows from "./modules/menus/main.js";
// import Notifications from "./modules/notifications/index.js";
//
// const applyScss = () => {
// // Compile scss
// exec(`sass ${App.configDir}/scss/main.scss ${App.configDir}/style.css`);
// exec(
// `sass ${App.configDir}/scss/highlight.scss ${App.configDir}/highlight.css`,
// );
// console.log("Scss compiled");
//
// // Apply compiled css
// App.resetCss();
// App.applyCss(`${App.configDir}/style.css`);
// console.log("Compiled css applied");
// };
//
// DirectoryMonitorService.connect("changed", () => applyScss());
//
// applyScss();
//
// const workspaceMonitorMap = {
// 0: [4, 5],
// 1: [6, 7],
// 2: [1, 2, 3, 8, 9, 10],
// };
//
// App.config({
// windows: [
// ...MenuWindows,
// Notifications(),
// BarAlt(0, workspaceMonitorMap),
// BarAlt(1, workspaceMonitorMap),
// Bar(2, workspaceMonitorMap),
// ],
// style: `${App.configDir}/style.css`,
// closeWindowDelay: {
// sideright: 350,
// launcher: 350,
// bar0: 350,
// },
// onConfigParsed: () => Utils.execAsync(`python3 ${App.configDir}/services/bluetooth.py`),
// });