feat(astal): add basic working config
All checks were successful
Discord / discord commits (push) Has been skipped
All checks were successful
Discord / discord commits (push) Has been skipped
This commit is contained in:
parent
3a54b5f005
commit
e056756246
7 changed files with 357 additions and 10 deletions
47
modules/ags/astal/js/utils.js
Normal file
47
modules/ags/astal/js/utils.js
Normal file
|
@ -0,0 +1,47 @@
|
|||
const { execAsync, monitorFile } = Utils;
|
||||
|
||||
|
||||
/** @param {string} host */
|
||||
const watchAndCompileSass = (host) => {
|
||||
const reloadCss = () => {
|
||||
const scss = `${App.configDir}/scss/${host}.scss`;
|
||||
const css = `/tmp/astal-${host}/style.css`;
|
||||
|
||||
execAsync(`sass ${scss} ${css}`).then(() => {
|
||||
App.resetCss();
|
||||
App.applyCss(css);
|
||||
}).catch(print);
|
||||
};
|
||||
|
||||
monitorFile(
|
||||
`${App.configDir}/scss`,
|
||||
reloadCss,
|
||||
);
|
||||
reloadCss();
|
||||
};
|
||||
|
||||
/** @param {string} host */
|
||||
export const transpileTypeScript = async(host) => {
|
||||
const outPath = `/tmp/astal-${host}/index.js`;
|
||||
|
||||
await execAsync([
|
||||
'bash', '-c',
|
||||
// Create the dir if it doesn't exist
|
||||
`mkdir -p /tmp/astal-${host}; ` +
|
||||
|
||||
`bun build ${App.configDir}/${host}.ts ` +
|
||||
'--external resource:///* ' +
|
||||
'--external gi://* ' +
|
||||
'--external cairo ' +
|
||||
'--external */fzf.es.js ' +
|
||||
|
||||
// Since bun wants to right in cwd, we just redirect stdin instead
|
||||
`> ${outPath}`,
|
||||
]).catch(print);
|
||||
|
||||
if (host !== 'greeter') {
|
||||
watchAndCompileSass(host);
|
||||
}
|
||||
|
||||
return await import(`file://${outPath}`);
|
||||
};
|
237
modules/ags/astal/package-lock.json
generated
Normal file
237
modules/ags/astal/package-lock.json
generated
Normal file
|
@ -0,0 +1,237 @@
|
|||
{
|
||||
"name": "astal",
|
||||
"lockfileVersion": 3,
|
||||
"requires": true,
|
||||
"packages": {
|
||||
"": {
|
||||
"devDependencies": {
|
||||
"@girs/adw-1": "^1.4.3-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/adw-1": {
|
||||
"version": "1.4.3-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/adw-1/-/adw-1-1.4.3-3.2.9.tgz",
|
||||
"integrity": "sha512-FJPtFRLJHXHZl5WEPjXmyKXaoIgBWurZMroSxNxpRGFVlbxx7wq4Q1k1iKKVxcKbe69z66GQsHV2BgaeQK0aXg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gdk-4.0": "^4.0.0-3.2.9",
|
||||
"@girs/gdkpixbuf-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gmodule-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/graphene-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/gsk-4.0": "^4.0.0-3.2.9",
|
||||
"@girs/gtk-4.0": "^4.12.5-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9",
|
||||
"@girs/pango-1.0": "^1.51.0-3.2.9",
|
||||
"@girs/pangocairo-1.0": "^1.0.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/cairo-1.0": {
|
||||
"version": "1.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/cairo-1.0/-/cairo-1.0-1.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-yeBoeyniCKU3IcgpoKUywlviBx2kEVeYjglFw4v5eGGvaBugPWvlShqePxfNmfh2A4cjFzzdLXRN6brQEHgQEA==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/freetype2-2.0": {
|
||||
"version": "2.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/freetype2-2.0/-/freetype2-2.0-2.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-Og9CTSl2QYnuCtX2L6rYa9WVUetYbaD1Y7BwEe3kOSG2OkDB+hunnF82x1Ctg1iKRRBXgWxadKb28bm2wKx/Jw==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gdk-4.0": {
|
||||
"version": "4.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gdk-4.0/-/gdk-4.0-4.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-86+32kDXaSqzicqMCx35O8ZkCrG5Qyyozaq1NQdWhBNUopGNiTLtVkf90aIP0y8ZccIeJKidCWEO3IYiRmmHkg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gdkpixbuf-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gmodule-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9",
|
||||
"@girs/pango-1.0": "^1.51.0-3.2.9",
|
||||
"@girs/pangocairo-1.0": "^1.0.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gdkpixbuf-2.0": {
|
||||
"version": "2.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gdkpixbuf-2.0/-/gdkpixbuf-2.0-2.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-7guULwcaulcOvqvAB8pd6Xr9B2YmK1sQK6CYm5bHZQw9N18LnZkm9ATOAXjXLieaUSeERA6LnBPmtkLUZdeTzA==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gmodule-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gio-2.0": {
|
||||
"version": "2.78.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gio-2.0/-/gio-2.0-2.78.0-3.2.9.tgz",
|
||||
"integrity": "sha512-A3F1AkBPF8Up6bSfH9zbAUsQqv4dB0jvfUIo5b+SJs6Mt9FhpqNEUMyqeCFTDKDA9n2sK6JxAJviwsW9dxViJA==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gjs": {
|
||||
"version": "3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gjs/-/gjs-3.2.9.tgz",
|
||||
"integrity": "sha512-dJfCNdtt4OLRywlhKOc+h27l5KoOiDhbhkuuG/WaV/jn9KaQ1BMAyVWdBEZu6WzPJlsiWYujis0fe5ZJnrgoDA==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/glib-2.0": {
|
||||
"version": "2.78.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/glib-2.0/-/glib-2.0-2.78.0-3.2.9.tgz",
|
||||
"integrity": "sha512-wcbnSojav6jc4//PYsAJPwXizFlz35/F+AHyFbvutOSdNz4xzzUUZqUhhH2lmoyR8WDvkVWBcQitCmYmPNe6Xg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gmodule-2.0": {
|
||||
"version": "2.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gmodule-2.0/-/gmodule-2.0-2.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-10JS6N7VkPxcom5I3hzD65NmZzQ63ZFmN+2KXZPwTDU6K2A2QrxZB2/3Q3j6KKNc+e/d9GhStL9ISUPLErHoNg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gobject-2.0": {
|
||||
"version": "2.78.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gobject-2.0/-/gobject-2.0-2.78.0-3.2.9.tgz",
|
||||
"integrity": "sha512-zszoqx7/z7KseQnc7WUXz1jgs3oYskT748cMKLQ7n4pRtL6klrTzlPbM42Szs+Uk6wOKJ+o+MMdcpb8znflDBg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/graphene-1.0": {
|
||||
"version": "1.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/graphene-1.0/-/graphene-1.0-1.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-2iTdpt7XTJAH/K5GiKoF2r0BHe1JghpV+rh81WYtFqM/r9CLs5GipESuraVQvZeK2vyrZcGRjVmoDoiKiA3BlQ==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gsk-4.0": {
|
||||
"version": "4.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gsk-4.0/-/gsk-4.0-4.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-LtGbMKBVYPburnI1JGt2d3uKzHgk4A2QtO4n/kP0T99Rmnxr+D2xwR+VdqcdgkLXoTzdlvodfK1b7W/eILB7CQ==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gdk-4.0": "^4.0.0-3.2.9",
|
||||
"@girs/gdkpixbuf-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gmodule-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/graphene-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9",
|
||||
"@girs/pango-1.0": "^1.51.0-3.2.9",
|
||||
"@girs/pangocairo-1.0": "^1.0.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/gtk-4.0": {
|
||||
"version": "4.12.5-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/gtk-4.0/-/gtk-4.0-4.12.5-3.2.9.tgz",
|
||||
"integrity": "sha512-TweLlhryVS8DnDQouLdJtGv3AeJ9Dv/nKFatPSDlcwUFYCSDa9+R5gA5L7GNh3NobPIa6ZMAT4oAv2fJS7zYFw==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gdk-4.0": "^4.0.0-3.2.9",
|
||||
"@girs/gdkpixbuf-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gmodule-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/graphene-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/gsk-4.0": "^4.0.0-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9",
|
||||
"@girs/pango-1.0": "^1.51.0-3.2.9",
|
||||
"@girs/pangocairo-1.0": "^1.0.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/harfbuzz-0.0": {
|
||||
"version": "8.2.1-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/harfbuzz-0.0/-/harfbuzz-0.0-8.2.1-3.2.9.tgz",
|
||||
"integrity": "sha512-5o4Ow44ndt9Jnyp5vw6tWYSFESY/inH/3nNoWk1bWpG5TFxOwvW05RiSpdKXb4nTXaDWPBXLZF4Its9Q/GrW2w==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/pango-1.0": {
|
||||
"version": "1.51.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/pango-1.0/-/pango-1.0-1.51.0-3.2.9.tgz",
|
||||
"integrity": "sha512-dWIvPJoFnpgWQcflTyGhXN5TmlmW0OvTG6kjBFwVJLwT2H6vugUKk9665MvEQDywaeGZzdfrJqQo/oFplhVSBg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9"
|
||||
}
|
||||
},
|
||||
"node_modules/@girs/pangocairo-1.0": {
|
||||
"version": "1.0.0-3.2.9",
|
||||
"resolved": "https://registry.npmjs.org/@girs/pangocairo-1.0/-/pangocairo-1.0-1.0.0-3.2.9.tgz",
|
||||
"integrity": "sha512-9tpiYEwdx9829p0oQFrC5Y38USGeap2Y+yNeD8Klf1Pb9pGC/lVjAjrqmGC/nSAyLHz3SlK1kTDP1fBsqoCEng==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@girs/cairo-1.0": "^1.0.0-3.2.9",
|
||||
"@girs/freetype2-2.0": "^2.0.0-3.2.9",
|
||||
"@girs/gio-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gjs": "^3.2.9",
|
||||
"@girs/glib-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/gobject-2.0": "^2.78.0-3.2.9",
|
||||
"@girs/harfbuzz-0.0": "^8.2.1-3.2.9",
|
||||
"@girs/pango-1.0": "^1.51.0-3.2.9"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
5
modules/ags/astal/package.json
Normal file
5
modules/ags/astal/package.json
Normal file
|
@ -0,0 +1,5 @@
|
|||
{
|
||||
"devDependencies": {
|
||||
"@girs/adw-1": "^1.4.3-3.2.9"
|
||||
}
|
||||
}
|
10
modules/ags/astal/scss/wim.scss
Normal file
10
modules/ags/astal/scss/wim.scss
Normal file
|
@ -0,0 +1,10 @@
|
|||
window {
|
||||
all: unset;
|
||||
}
|
||||
|
||||
|
||||
.base {
|
||||
background-color: #{"@window_bg_color"};
|
||||
border: 1px solid #{"@accent_bg_color"};
|
||||
padding: 5px;
|
||||
}
|
23
modules/ags/astal/tsconfig.json
Normal file
23
modules/ags/astal/tsconfig.json
Normal file
|
@ -0,0 +1,23 @@
|
|||
{
|
||||
"compilerOptions": {
|
||||
"target": "ES2022",
|
||||
"module": "ES2022",
|
||||
"lib": [
|
||||
"ES2022"
|
||||
],
|
||||
"allowJs": true,
|
||||
"checkJs": true,
|
||||
"strict": true,
|
||||
"noImplicitAny": false,
|
||||
"baseUrl": ".",
|
||||
"paths": {
|
||||
"gi://Adw": ["./node_modules/@girs/adw-1/adw-1.d.ts"],
|
||||
"gi://Adw?version=1": ["./node_modules/@girs/adw-1/adw-1.d.ts"]
|
||||
},
|
||||
"typeRoots": [
|
||||
"./types",
|
||||
"./node_modules"
|
||||
],
|
||||
"skipLibCheck": true
|
||||
},
|
||||
}
|
20
modules/ags/astal/wim.ts
Normal file
20
modules/ags/astal/wim.ts
Normal file
|
@ -0,0 +1,20 @@
|
|||
import Adw from 'gi://Adw';
|
||||
|
||||
|
||||
App.config({
|
||||
windows: () => [
|
||||
Widget.Window({
|
||||
name: 'test',
|
||||
|
||||
child: Widget.Box({
|
||||
setup: (self) => {
|
||||
self.toggleCssClass('base');
|
||||
},
|
||||
|
||||
child: new Adw.SplitButton({
|
||||
label: 'test',
|
||||
}),
|
||||
}),
|
||||
}),
|
||||
],
|
||||
});
|
|
@ -28,10 +28,21 @@ in {
|
|||
inherit (lib) optionals;
|
||||
|
||||
astalTypes = config.home.file.".local/share/io.Aylur.Astal/types";
|
||||
astalConfigDir = ".nix/modules/ags/astal";
|
||||
|
||||
# https://github.com/Aylur/ags/blob/e1f2d311ceb496a69ef6daa6aebb46ce511b2f22/nix/hm-module.nix#L69
|
||||
agsTypes = config.home.file.".local//share/com.github.Aylur.ags/types";
|
||||
agsConfigDir = ".nix/modules/ags/config";
|
||||
|
||||
configJs =
|
||||
/*
|
||||
javascript
|
||||
*/
|
||||
''
|
||||
import { transpileTypeScript } from './js/utils.js';
|
||||
|
||||
export default (await transpileTypeScript('${hostName}')).default;
|
||||
'';
|
||||
in {
|
||||
# Experimental Gtk4 ags
|
||||
programs.astal = {
|
||||
|
@ -46,19 +57,13 @@ in {
|
|||
home = {
|
||||
file =
|
||||
{
|
||||
".config/astal/types".source = astalTypes.source;
|
||||
".config/astal".source = symlink /home/${mainUser}/.nix/modules/ags/astal;
|
||||
"${astalConfigDir}/types".source = astalTypes.source;
|
||||
"${astalConfigDir}/config.js".text = configJs;
|
||||
|
||||
".config/ags".source = symlink /home/${mainUser}/.nix/modules/ags/config;
|
||||
"${agsConfigDir}/types".source = agsTypes.source;
|
||||
"${agsConfigDir}/config.js".text =
|
||||
/*
|
||||
javascript
|
||||
*/
|
||||
''
|
||||
import { transpileTypeScript } from './js/utils.js';
|
||||
|
||||
export default (await transpileTypeScript('${hostName}')).default;
|
||||
'';
|
||||
"${agsConfigDir}/config.js".text = configJs;
|
||||
}
|
||||
// (import ./icons.nix {inherit pkgs agsConfigDir;});
|
||||
|
||||
|
|
Loading…
Reference in a new issue