diff --git a/modules/programs/ags/.gitignore b/modules/programs/ags/.gitignore new file mode 100644 index 0000000..298eb4d --- /dev/null +++ b/modules/programs/ags/.gitignore @@ -0,0 +1,2 @@ +node_modules/ +@girs/ diff --git a/modules/programs/ags/app.ts b/modules/programs/ags/app.ts index e69de29..7e8cc7c 100644 --- a/modules/programs/ags/app.ts +++ b/modules/programs/ags/app.ts @@ -0,0 +1,10 @@ +import { App } from "astal/gtk4" +import style from "./style.scss" +import Bar from "./widget/Bar" + +App.start({ + css: style, + main() { + App.get_monitors().map(Bar) + }, +}) diff --git a/modules/programs/ags/env.d.ts b/modules/programs/ags/env.d.ts new file mode 100644 index 0000000..467c0a4 --- /dev/null +++ b/modules/programs/ags/env.d.ts @@ -0,0 +1,21 @@ +declare const SRC: string + +declare module "inline:*" { + const content: string + export default content +} + +declare module "*.scss" { + const content: string + export default content +} + +declare module "*.blp" { + const content: string + export default content +} + +declare module "*.css" { + const content: string + export default content +} diff --git a/modules/programs/ags/package.json b/modules/programs/ags/package.json new file mode 100644 index 0000000..8647b83 --- /dev/null +++ b/modules/programs/ags/package.json @@ -0,0 +1,6 @@ +{ + "name": "astal-shell", + "dependencies": { + "astal": "/home/rafiq/.local/share/ags" + } +} diff --git a/modules/programs/ags/style.scss b/modules/programs/ags/style.scss new file mode 100644 index 0000000..1d0d3a9 --- /dev/null +++ b/modules/programs/ags/style.scss @@ -0,0 +1,20 @@ +// https://gitlab.gnome.org/GNOME/gtk/-/blob/gtk-3-24/gtk/theme/Adwaita/_colors-public.scss +$fg-color: #{"@theme_fg_color"}; +$bg-color: #{"@theme_bg_color"}; + +window.Bar { + background: transparent; + color: $fg-color; + font-weight: bold; + + >centerbox { + background: $bg-color; + border-radius: 10px; + margin: 8px; + } + + button { + border-radius: 8px; + margin: 2px; + } +} diff --git a/modules/programs/ags/tsconfig.json b/modules/programs/ags/tsconfig.json new file mode 100644 index 0000000..a92bc43 --- /dev/null +++ b/modules/programs/ags/tsconfig.json @@ -0,0 +1,14 @@ +{ + "$schema": "https://json.schemastore.org/tsconfig", + "compilerOptions": { + "experimentalDecorators": true, + "strict": true, + "target": "ES2022", + "module": "ES2022", + "moduleResolution": "Bundler", + // "checkJs": true, + // "allowJs": true, + "jsx": "react-jsx", + "jsxImportSource": "astal/gtk4", + } +} diff --git a/modules/programs/ags/widget/Bar.tsx b/modules/programs/ags/widget/Bar.tsx new file mode 100644 index 0000000..c2db8c5 --- /dev/null +++ b/modules/programs/ags/widget/Bar.tsx @@ -0,0 +1,36 @@ +import { App, Astal, Gtk, Gdk } from "astal/gtk4" +import { Variable } from "astal" + +const time = Variable("").poll(1000, "date") + +export default function Bar(gdkmonitor: Gdk.Monitor) { + const { TOP, LEFT, RIGHT } = Astal.WindowAnchor + + return + + + + + + + +}