Compare commits
No commits in common. "master" and "hyprland" have entirely different histories.
89
flake.lock
89
flake.lock
|
|
@ -10,11 +10,11 @@
|
|||
]
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1775689345,
|
||||
"narHash": "sha256-tM3s7CX+tgxlYW0Sk3nzVThg2MHn08foIuMxABupxIs=",
|
||||
"lastModified": 1764289441,
|
||||
"narHash": "sha256-ak+lgFiYE5PHByN1/BRkO5JP498hno6Ix24C1Qf/vec=",
|
||||
"owner": "aylur",
|
||||
"repo": "ags",
|
||||
"rev": "bbee2f18939f1ec7ff720e717cf305e73635628f",
|
||||
"rev": "e169694390548dfd38ff40f1ef2163d6c3ffe3ea",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -30,11 +30,11 @@
|
|||
]
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1777578913,
|
||||
"narHash": "sha256-2Hzr8T4oUtw2q0ZYxrgDB8kvy85QawlhpiQDk4eGOHQ=",
|
||||
"lastModified": 1769774308,
|
||||
"narHash": "sha256-8Ve6VdUpcYbl8bS5oyDwVnnNobyPxdPmUHGgSDyOazQ=",
|
||||
"owner": "aylur",
|
||||
"repo": "astal",
|
||||
"rev": "67ddc83e0bdbda6de7f6f15e4fbc5d6b9d2d1b18",
|
||||
"rev": "eb235f8813bdea2a4a38ac228f2efc4e2a8a90af",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -132,11 +132,11 @@
|
|||
]
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1778144356,
|
||||
"narHash": "sha256-dGM+QCstz/DyLB68+JK5GWyMx4QSqmOJEVgZmy63d/g=",
|
||||
"lastModified": 1773093840,
|
||||
"narHash": "sha256-u/96NoAyN8BSRuM3ZimGf7vyYgXa3pLx4MYWjokuoH4=",
|
||||
"owner": "nix-community",
|
||||
"repo": "home-manager",
|
||||
"rev": "e4419d3123b780d5f4c0bceeace450424387638c",
|
||||
"rev": "bb014746edb2a98d975abde4dd40fa240de4cf86",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -184,11 +184,11 @@
|
|||
},
|
||||
"nixpkgs_2": {
|
||||
"locked": {
|
||||
"lastModified": 1777954456,
|
||||
"narHash": "sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9+hrDTkDU=",
|
||||
"lastModified": 1772963539,
|
||||
"narHash": "sha256-9jVDGZnvCckTGdYT53d/EfznygLskyLQXYwJLKMPsZs=",
|
||||
"owner": "NixOS",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "549bd84d6279f9852cae6225e372cc67fb91a4c1",
|
||||
"rev": "9dcb002ca1690658be4a04645215baea8b95f31d",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -200,11 +200,11 @@
|
|||
},
|
||||
"nixpkgs_3": {
|
||||
"locked": {
|
||||
"lastModified": 1777954456,
|
||||
"narHash": "sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9+hrDTkDU=",
|
||||
"lastModified": 1772963539,
|
||||
"narHash": "sha256-9jVDGZnvCckTGdYT53d/EfznygLskyLQXYwJLKMPsZs=",
|
||||
"owner": "nixos",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "549bd84d6279f9852cae6225e372cc67fb91a4c1",
|
||||
"rev": "9dcb002ca1690658be4a04645215baea8b95f31d",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -215,6 +215,22 @@
|
|||
}
|
||||
},
|
||||
"nixpkgs_4": {
|
||||
"locked": {
|
||||
"lastModified": 1772542754,
|
||||
"narHash": "sha256-WGV2hy+VIeQsYXpsLjdr4GvHv5eECMISX1zKLTedhdg=",
|
||||
"owner": "NixOS",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "8c809a146a140c5c8806f13399592dbcb1bb5dc4",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "NixOS",
|
||||
"ref": "nixos-unstable",
|
||||
"repo": "nixpkgs",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"nixpkgs_5": {
|
||||
"locked": {
|
||||
"lastModified": 1730200266,
|
||||
"narHash": "sha256-l253w0XMT8nWHGXuXqyiIC/bMvh1VRszGXgdpQlfhvU=",
|
||||
|
|
@ -236,11 +252,11 @@
|
|||
"nixpkgs": "nixpkgs_3"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1778165192,
|
||||
"narHash": "sha256-RgflEUfqht5XBXXFqt/XmC7/wUQgrYw+D34pYWCtCBw=",
|
||||
"lastModified": 1773125003,
|
||||
"narHash": "sha256-EF89LT3zxm8dM2pgoAohUcdQoTVVv1v02Jq+z6j8u+0=",
|
||||
"owner": "nix-community",
|
||||
"repo": "NUR",
|
||||
"rev": "25abd5cb8f57397fa34d49eddcd8d0b23e19efc0",
|
||||
"rev": "eb59c1e77102b9f836cdea9f12568f191a9aff57",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
|
|
@ -258,13 +274,48 @@
|
|||
"nixos-06cb-009a-fingerprint-sensor": "nixos-06cb-009a-fingerprint-sensor",
|
||||
"nixpkgs": "nixpkgs_2",
|
||||
"nur": "nur",
|
||||
"vicinae": "vicinae",
|
||||
"worktimer": "worktimer"
|
||||
}
|
||||
},
|
||||
"systems": {
|
||||
"locked": {
|
||||
"lastModified": 1681028828,
|
||||
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||
"owner": "nix-systems",
|
||||
"repo": "default",
|
||||
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "nix-systems",
|
||||
"repo": "default",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"vicinae": {
|
||||
"inputs": {
|
||||
"nixpkgs": "nixpkgs_4",
|
||||
"systems": "systems"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1773099334,
|
||||
"narHash": "sha256-ciiNQFZ2m2JOEDDg9ZZxOuxykl4Aw/2C1EQsOcq+F+E=",
|
||||
"owner": "vicinaehq",
|
||||
"repo": "vicinae",
|
||||
"rev": "2a427670116461a4ce0207db2c089aee9f40428e",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "vicinaehq",
|
||||
"repo": "vicinae",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"worktimer": {
|
||||
"inputs": {
|
||||
"flake-parts": "flake-parts_3",
|
||||
"nixpkgs": "nixpkgs_4"
|
||||
"nixpkgs": "nixpkgs_5"
|
||||
},
|
||||
"locked": {
|
||||
"lastModified": 1739738223,
|
||||
|
|
|
|||
11
flake.nix
11
flake.nix
|
|
@ -7,6 +7,7 @@
|
|||
};
|
||||
nur.url = "github:nix-community/NUR";
|
||||
fzgo.url = "git+https://git.thomasave.be/thomasave/fzgo.git";
|
||||
vicinae.url = "github:vicinaehq/vicinae";
|
||||
worktimer = {
|
||||
type = "git";
|
||||
url = "https://git.thomasave.be/thomasave/WorkTimer";
|
||||
|
|
@ -37,6 +38,8 @@
|
|||
} @ inputs: let
|
||||
supportedSystems = ["x86_64-linux" "aarch64-linux"];
|
||||
forAllSystems = nixpkgs.lib.genAttrs supportedSystems;
|
||||
system = builtins.currentSystem;
|
||||
pkgs = nixpkgs.legacyPackages.${system};
|
||||
commonModules = host: user: [
|
||||
./hosts/${host}/hardware-configuration.nix
|
||||
{
|
||||
|
|
@ -45,17 +48,19 @@
|
|||
(self: super: {utillinux = super.util-linux;})
|
||||
];
|
||||
}
|
||||
({pkgs, ...}: {
|
||||
{
|
||||
networking.hostName = host;
|
||||
time.timeZone = "Asia/Bangkok";
|
||||
nix.settings = {
|
||||
substituters = [
|
||||
"https://nix-community.cachix.org"
|
||||
"https://cuda-maintainers.cachix.org"
|
||||
"https://vicinae.cachix.org"
|
||||
];
|
||||
trusted-public-keys = [
|
||||
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
|
||||
"cuda-maintainers.cachix.org-1:0dq3bujKpuEPMCX6U4WylrUDZ9JyUG0VpVZa7CNfq5E="
|
||||
"vicinae.cachix.org-1:1kDrfienkGHPYbkpNj1mWTr7Fm1+zcenzgTizIcI3oc="
|
||||
];
|
||||
experimental-features = ["nix-command" "flakes"];
|
||||
trusted-users = ["root" user];
|
||||
|
|
@ -65,7 +70,7 @@
|
|||
};
|
||||
users.users.${user} = {
|
||||
isNormalUser = true;
|
||||
extraGroups = ["wheel" "video"]; # Enable 'sudo' for the user.
|
||||
extraGroups = ["wheel" "video"]; # Enable ‘sudo’ for the user.
|
||||
openssh.authorizedKeys.keys = [
|
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKAa3tMzSCRuprEACrBsKI0F/o73o6J9L1qR3TaZn/N8 user@Kell"
|
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIByLwLAdJbmoDV5sx4hg5NbzKbOh1GmWEhDOUJ1GQBhK user@Riva"
|
||||
|
|
@ -80,7 +85,7 @@
|
|||
shell = pkgs.zsh;
|
||||
};
|
||||
system.stateVersion = "23.11";
|
||||
})
|
||||
}
|
||||
home-manager.nixosModules.home-manager
|
||||
{
|
||||
home-manager = {
|
||||
|
|
|
|||
|
|
@ -15,10 +15,7 @@
|
|||
};
|
||||
in {
|
||||
imports = [
|
||||
(import ./utils/desktop.nix {
|
||||
inherit inputs config pkgs;
|
||||
scale = 1.2;
|
||||
})
|
||||
(import ./utils/desktop.nix {inherit inputs config pkgs;})
|
||||
(import ./utils/fzgo_links.nix {inherit config pkgs fzgo_paths;})
|
||||
];
|
||||
|
||||
|
|
@ -28,7 +25,6 @@ in {
|
|||
jetbrains.pycharm
|
||||
rclone
|
||||
opencode
|
||||
claude-code
|
||||
# zed-editor
|
||||
uv
|
||||
google-cloud-sdk
|
||||
|
|
@ -39,14 +35,26 @@ in {
|
|||
vscode
|
||||
texliveFull
|
||||
gnome-power-manager
|
||||
discord
|
||||
smile
|
||||
podman-compose
|
||||
vesktop
|
||||
];
|
||||
|
||||
wayland.windowManager.hyprland.settings = {
|
||||
monitor = [
|
||||
"eDP-1,2880x1800@120.00Hz,480x0,1.2,vrr,1"
|
||||
"HDMI-A-1,3840x2160@60.00Hz,0x-2160,1"
|
||||
"DP-3,1920x1080,3840x-540,1"
|
||||
"DP-1,1920x1080,3840x-540,1"
|
||||
];
|
||||
bind = [
|
||||
", XF86PowerOff, exec, ${pkgs.rofi}/bin/rofi -show power-menu -modi power-menu:${
|
||||
./hyprland/files/rofi-power-menu.sh
|
||||
}"
|
||||
];
|
||||
general.gaps_out = 1;
|
||||
};
|
||||
|
||||
programs.alacritty.settings.font.size = 13;
|
||||
programs.kitty.font.size = 13;
|
||||
systemd.user.services.vicinae.Service.Environment = [
|
||||
"QT_SCALE_FACTOR=1.5"
|
||||
];
|
||||
}
|
||||
|
|
|
|||
|
|
@ -15,20 +15,13 @@
|
|||
};
|
||||
in {
|
||||
imports = [
|
||||
(import ./utils/desktop.nix {
|
||||
inherit inputs config pkgs;
|
||||
scale = 1.0;
|
||||
})
|
||||
(import ./utils/desktop.nix {inherit inputs config pkgs;})
|
||||
(import ./utils/fzgo_links.nix {inherit config pkgs fzgo_paths;})
|
||||
];
|
||||
|
||||
programs.ssh.matchBlocks."*".identityFile = "/home/user/.secrets/SSH/Arendia/id_ed25519";
|
||||
|
||||
home.packages = with pkgs; [
|
||||
rclone
|
||||
uv
|
||||
claude-code
|
||||
awscli2
|
||||
distrobox
|
||||
gnome-disk-utility
|
||||
moonlight-qt
|
||||
|
|
@ -36,15 +29,33 @@ in {
|
|||
texliveFull
|
||||
gnome-power-manager
|
||||
# jetbrains.pycharm-professional
|
||||
discord
|
||||
smile
|
||||
podman-compose
|
||||
vesktop
|
||||
];
|
||||
|
||||
services.hyprpaper = {
|
||||
settings = {
|
||||
wallpaper = [
|
||||
"HDMI-A-1,${./hyprland/files/wallpaper.png}"
|
||||
"eDP-1,${./hyprland/files/wallpaper.png}"
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
wayland.windowManager.hyprland.settings = {
|
||||
monitor = [
|
||||
"eDP-1,2560x1440@60.01,0x0,1"
|
||||
"HDMI-A-1,1920x1080@60,0x-1080,1"
|
||||
];
|
||||
bind = [
|
||||
", XF86PowerOff, exec, ${pkgs.rofi}/bin/rofi -show power-menu -modi power-menu:${
|
||||
./hyprland/files/rofi-power-menu.sh
|
||||
}"
|
||||
];
|
||||
general.gaps_out = 1;
|
||||
};
|
||||
|
||||
programs.alacritty.settings.font.size = 13;
|
||||
programs.kitty.font.size = 15;
|
||||
programs.foot.settings.main.font = pkgs.lib.mkForce "DejaVu Sans Mono:size=15";
|
||||
systemd.user.services.vicinae.Service.Environment = [
|
||||
"QT_SCALE_FACTOR=1.2"
|
||||
];
|
||||
}
|
||||
|
|
|
|||
|
|
@ -36,8 +36,18 @@ in {
|
|||
moonlight-qt
|
||||
vscode
|
||||
jetbrains.rider
|
||||
discord
|
||||
];
|
||||
|
||||
services.hyprpaper = {
|
||||
settings = {
|
||||
wallpaper = [
|
||||
"DP-1,${./hyprland/files/wallpaper.png}"
|
||||
"DP-2,${./hyprland/files/wallpaper.png}"
|
||||
"HDMI-A-1,${./hyprland/files/wallpaper.png}"
|
||||
];
|
||||
};
|
||||
};
|
||||
wayland.windowManager.hyprland.settings = {
|
||||
monitor = [
|
||||
"DP-2,preferred,0x550,1"
|
||||
|
|
|
|||
|
|
@ -30,6 +30,13 @@ in {
|
|||
jq
|
||||
rclone
|
||||
];
|
||||
services.hyprpaper = {
|
||||
settings = {
|
||||
wallpaper = [
|
||||
"Virtual-1,${./hyprland/files/wallpaper.png}"
|
||||
];
|
||||
};
|
||||
};
|
||||
wayland.windowManager.hyprland.settings = {
|
||||
monitor = [
|
||||
"Virtual-1,2560x1440,0x0,1"
|
||||
|
|
|
|||
|
|
@ -2,9 +2,9 @@ import { Astal, Gdk, Gtk } from "ags/gtk4";
|
|||
import app from "ags/gtk4/app";
|
||||
import { createBinding, createState, For, With, Accessor } from "ags";
|
||||
import { createPoll } from "ags/time";
|
||||
import { subprocess, execAsync } from "ags/process";
|
||||
import Pango from "gi://Pango";
|
||||
import Tray from "gi://AstalTray";
|
||||
import { execAsync } from "ags/process";
|
||||
import Hyprland from "gi://AstalHyprland";
|
||||
import { getIconName } from "./utils";
|
||||
import Wp from "gi://AstalWp";
|
||||
import Battery from "gi://AstalBattery";
|
||||
|
|
@ -16,36 +16,6 @@ const sensorsAvailable = await execAsync(["sensors"])
|
|||
.catch(() => false);
|
||||
const wirePlumber = Wp.get_default();
|
||||
|
||||
// --- NIRI IPC INTEGRATION ---
|
||||
const [workspaces, setWorkspaces] = createState<any[]>([]);
|
||||
const [windows, setWindows] = createState<any[]>([]);
|
||||
|
||||
async function updateNiriState() {
|
||||
try {
|
||||
const wsOut = await execAsync(["niri", "msg", "-j", "workspaces"]);
|
||||
setWorkspaces(JSON.parse(wsOut) || []);
|
||||
|
||||
const winOut = await execAsync(["niri", "msg", "-j", "windows"]);
|
||||
setWindows(JSON.parse(winOut) || []);
|
||||
} catch (e) {
|
||||
console.error("Failed to fetch Niri state:", e);
|
||||
}
|
||||
}
|
||||
|
||||
// Initialize state immediately
|
||||
updateNiriState();
|
||||
|
||||
// Subscribe to Niri's native event stream
|
||||
subprocess(
|
||||
["niri", "msg", "-j", "event-stream"],
|
||||
(line) => {
|
||||
// A state change happened in Niri. Re-fetching guarantees perfect sync
|
||||
updateNiriState();
|
||||
},
|
||||
(err) => console.error("Niri event stream error:", err)
|
||||
);
|
||||
// ----------------------------
|
||||
|
||||
function SysTray(): JSX.Element {
|
||||
const tray = Tray.get_default();
|
||||
let items = createBinding(tray, "items");
|
||||
|
|
@ -82,18 +52,18 @@ function SysTray(): JSX.Element {
|
|||
);
|
||||
}
|
||||
|
||||
function Left({ connector }: { connector: string }): JSX.Element {
|
||||
function Left(): JSX.Element {
|
||||
return (
|
||||
<box hexpand halign={Gtk.Align.START}>
|
||||
<Clients connector={connector} />
|
||||
<Clients />
|
||||
</box>
|
||||
);
|
||||
}
|
||||
|
||||
function Center({ connector }: { connector: string }): JSX.Element {
|
||||
function Center(): JSX.Element {
|
||||
return (
|
||||
<box>
|
||||
<Workspaces connector={connector} />
|
||||
<Workspaces />
|
||||
</box>
|
||||
);
|
||||
}
|
||||
|
|
@ -274,77 +244,91 @@ function Volume(): JSX.Element {
|
|||
);
|
||||
}
|
||||
|
||||
function Workspaces({ connector }: { connector: string }): JSX.Element {
|
||||
function Workspaces(): JSX.Element {
|
||||
const hyprland = Hyprland.get_default();
|
||||
let workspaces = createBinding(hyprland, "workspaces");
|
||||
return (
|
||||
<box class="workspaces">
|
||||
{/* Generate a derived binding by passing a transformation function into the `workspaces` state */}
|
||||
<For each={workspaces((wss: any[]) =>
|
||||
wss.filter((ws) => ws.output === connector)
|
||||
.filter((ws) => ws.is_active || windows().some((w: any) => w.workspace_id === ws.id))
|
||||
.sort((a, b) => a.idx - b.idx)
|
||||
)}>
|
||||
{(ws: any) => (
|
||||
<With value={workspaces}>
|
||||
{(wss: Array<Hyprland.Workspace>) => (
|
||||
<box>
|
||||
<With value={createBinding(hyprland, "focusedMonitor")}>
|
||||
{(fm: Hyprland.Monitor) => {
|
||||
let filtered_wss = new Accessor(() =>
|
||||
wss
|
||||
.sort((a, b) => a.id - b.id)
|
||||
.filter(
|
||||
(ws) =>
|
||||
ws &&
|
||||
ws.get_monitor() &&
|
||||
ws.get_monitor().get_id() === fm.get_id(),
|
||||
),
|
||||
);
|
||||
return (
|
||||
<box>
|
||||
<For each={filtered_wss}>
|
||||
{(ws: Hyprland.Workspace, _index) => (
|
||||
<button
|
||||
class={ws.is_active ? "focused" : ""}
|
||||
onClicked={() => execAsync(["niri", "msg", "action", "focus-workspace", ws.idx.toString()])}
|
||||
class={createBinding(hyprland, "focusedWorkspace").as(
|
||||
(fw) => (ws === fw ? "focused" : ""),
|
||||
)}
|
||||
onClicked={() => ws.focus()}
|
||||
>
|
||||
{ws.name || ws.idx.toString()}
|
||||
{`${ws.id}`.slice(-1)}
|
||||
</button>
|
||||
)}
|
||||
</For>
|
||||
</box>
|
||||
);
|
||||
}}
|
||||
</With>
|
||||
</box>
|
||||
)}
|
||||
</With>
|
||||
</box>
|
||||
);
|
||||
}
|
||||
|
||||
const MAX_TOTAL_CHARS = 120;
|
||||
const MIN_TITLE_CHARS = 10;
|
||||
const OVERHEAD_PER_WINDOW = 5; // icon + padding + margin in character-width equivalents
|
||||
|
||||
function computeTitleBudgets(wins: any[]): any[] {
|
||||
const totalLength = wins.reduce((sum, w) => sum + (w.title || "").length, 0);
|
||||
const count = wins.length;
|
||||
const totalWithOverhead = totalLength + count * OVERHEAD_PER_WINDOW;
|
||||
|
||||
let maxChars: number;
|
||||
if (count === 0 || totalWithOverhead <= MAX_TOTAL_CHARS) {
|
||||
maxChars = -1;
|
||||
} else {
|
||||
const charsAvailable = MAX_TOTAL_CHARS - count * OVERHEAD_PER_WINDOW;
|
||||
maxChars = Math.max(MIN_TITLE_CHARS, Math.floor(charsAvailable / count));
|
||||
}
|
||||
|
||||
return wins.map(w => ({ ...w, maxChars }));
|
||||
function shorten(title: string) {
|
||||
return title.length > 40 ? title.slice(0, 20) + "..." : title;
|
||||
}
|
||||
|
||||
function Clients({ connector }: { connector: string }): JSX.Element {
|
||||
function Clients(): JSX.Element {
|
||||
const hyprland = Hyprland.get_default();
|
||||
let clients = createBinding(hyprland, "clients");
|
||||
return (
|
||||
<box>
|
||||
<With value={createBinding(hyprland, "focusedWorkspace")}>
|
||||
{(fw: Hyprland.Workspace) => (
|
||||
<box class="clients">
|
||||
{/* Use With to react to workspace changes, so we know which WS is active */}
|
||||
<With value={workspaces}>
|
||||
{(wss: any[]) => {
|
||||
let active_ws_for_monitor = wss.find((ws: any) => ws.is_active && ws.output === connector)?.id;
|
||||
<With value={clients}>
|
||||
{(cls: Array<Hyprland.Client>) => {
|
||||
let filtered_clients = new Accessor(() =>
|
||||
cls
|
||||
.sort((a, b) => a.pid - b.pid)
|
||||
.filter((cl) => !cl.title.includes("rofi"))
|
||||
.filter(
|
||||
(cl) => fw && cl.get_workspace().get_id() === fw.get_id(),
|
||||
),
|
||||
);
|
||||
|
||||
return (
|
||||
<box>
|
||||
{/* Generate a derived binding for windows, depending on the active workspace */}
|
||||
<For each={windows((wins: any[]) =>
|
||||
computeTitleBudgets(
|
||||
wins.filter((w: any) => !w.title?.includes("rofi"))
|
||||
.filter((w: any) => w.workspace_id === active_ws_for_monitor)
|
||||
.sort((a: any, b: any) => {
|
||||
const posA = a.layout?.pos_in_scrolling_layout?.[0] ?? 0;
|
||||
const posB = b.layout?.pos_in_scrolling_layout?.[0] ?? 0;
|
||||
return posA - posB;
|
||||
})
|
||||
)
|
||||
)}>
|
||||
{(win: any) => (
|
||||
<box class={win.is_focused ? "focused" : "unfocused"}>
|
||||
<image iconName={getIconName(win.app_id, win.title)} class="app-icon" />
|
||||
<For each={filtered_clients}>
|
||||
{(cl: Hyprland.Client, _index) => (
|
||||
<box
|
||||
class={createBinding(hyprland, "focusedClient").as(
|
||||
(a) =>
|
||||
a && a.address === cl.address
|
||||
? "focused"
|
||||
: "unfocused",
|
||||
)}
|
||||
>
|
||||
<image iconName={getIconName(cl)} class="app-icon" />
|
||||
<label
|
||||
label={win.title || ""}
|
||||
maxWidthChars={win.maxChars}
|
||||
ellipsize={Pango.EllipsizeMode.END}
|
||||
label={createBinding(cl, "title").as((title) =>
|
||||
shorten(title),
|
||||
)}
|
||||
/>
|
||||
</box>
|
||||
)}
|
||||
|
|
@ -354,13 +338,14 @@ function Clients({ connector }: { connector: string }): JSX.Element {
|
|||
}}
|
||||
</With>
|
||||
</box>
|
||||
)}
|
||||
</With>
|
||||
</box>
|
||||
);
|
||||
}
|
||||
|
||||
export default function Bar(gdkmonitor: Gdk.Monitor, scaleFactor: number = 1) {
|
||||
console.log("Creating Bar on monitor:", gdkmonitor.get_connector());
|
||||
const connector = gdkmonitor.get_connector() || "";
|
||||
|
||||
console.log("Creating Bar on monitor:", gdkmonitor);
|
||||
return (
|
||||
<window
|
||||
visible
|
||||
|
|
@ -374,11 +359,11 @@ export default function Bar(gdkmonitor: Gdk.Monitor, scaleFactor: number = 1) {
|
|||
}
|
||||
application={app}
|
||||
class="Bar"
|
||||
name={`top-bar-${connector}`}
|
||||
name="top-bar"
|
||||
>
|
||||
<centerbox class="window-box">
|
||||
<Left $type="start" connector={connector} />
|
||||
<Center $type="center" connector={connector} />
|
||||
<Left $type="start" />
|
||||
<Center $type="center" />
|
||||
<Right $type="end" />
|
||||
</centerbox>
|
||||
</window>
|
||||
|
|
|
|||
|
|
@ -1,19 +1,60 @@
|
|||
import app from "ags/gtk4/app";
|
||||
import { Gdk } from "ags/gtk4";
|
||||
import style from "./style.scss";
|
||||
import Bar from "./Bar";
|
||||
import Hyprland from "gi://AstalHyprland";
|
||||
import NotificationPopups from "./notifications/NotificationPopups";
|
||||
|
||||
function register_windows(monitor: Gdk.Monitor) {
|
||||
let scale = (monitor.get_geometry().width >= 3000) ? 1.2 : 1;
|
||||
Bar(monitor, scale);
|
||||
const hyprland = Hyprland.get_default();
|
||||
|
||||
function find_main_monitor(): Hyprland.Monitor {
|
||||
let monitors = hyprland.get_monitors();
|
||||
for (let j = 0; j < monitors.length; j++) {
|
||||
for (const monitor of ["eDP", "DP", "HDMI-A"]) {
|
||||
for (let i = 0; i < monitors.length; i++) {
|
||||
console.log(
|
||||
"Checking monitor:",
|
||||
monitors[i].get_name(),
|
||||
"against",
|
||||
monitor + "-" + j,
|
||||
);
|
||||
if (monitors[i].get_name() == monitor + "-" + j) {
|
||||
return monitors[i];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return monitors[0];
|
||||
}
|
||||
|
||||
function register_windows(monitor: Hyprland.Monitor) {
|
||||
let gtkMonitor = app.get_monitors()[0];
|
||||
let scale = monitor.get_width() >= 3000 ? 1.2 : 1;
|
||||
Bar(gtkMonitor, scale);
|
||||
NotificationPopups();
|
||||
}
|
||||
|
||||
function switch_to_best_monitor() {
|
||||
let mainMonitor = find_main_monitor();
|
||||
for (var wd of app.get_windows()) {
|
||||
wd.destroy();
|
||||
}
|
||||
register_windows(mainMonitor);
|
||||
}
|
||||
|
||||
hyprland.connect("monitor-added", (_, _monitor: Hyprland.Monitor) => {
|
||||
switch_to_best_monitor();
|
||||
});
|
||||
|
||||
hyprland.connect("monitor-removed", () => {
|
||||
switch_to_best_monitor();
|
||||
});
|
||||
|
||||
console.log("Trying to find the best monitor");
|
||||
|
||||
app.start({
|
||||
css: style,
|
||||
iconTheme: "Papirus",
|
||||
main() {
|
||||
register_windows(app.get_monitors()[0]);
|
||||
switch_to_best_monitor();
|
||||
},
|
||||
});
|
||||
|
|
|
|||
|
|
@ -1,4 +1,5 @@
|
|||
import Apps from "gi://AstalApps";
|
||||
import AstalHyprland from "gi://AstalHyprland";
|
||||
|
||||
const app_icons = new Apps.Apps().list.reduce(
|
||||
(acc, app) => {
|
||||
|
|
@ -15,39 +16,57 @@ const app_icons = new Apps.Apps().list.reduce(
|
|||
{ classOrNames: {} as Record<string, string>, executables: {} as Record<string, string> },
|
||||
);
|
||||
|
||||
export function getIconName(app_id: string | null | undefined, title: string | null | undefined) {
|
||||
if (!app_id && !title) return "";
|
||||
export function getIconName(client: AstalHyprland.Client | null | undefined) {
|
||||
if (!client) return "";
|
||||
|
||||
// try fields matching Niri outputs
|
||||
// try a bunch of fields (snake_case and camelCase variants)
|
||||
const possibleKeys = [
|
||||
app_id,
|
||||
title
|
||||
// common client properties (snake_case)
|
||||
(client as any).wm_class,
|
||||
(client as any).initial_class,
|
||||
(client as any).executable,
|
||||
// camelCase variants (some bindings expose these)
|
||||
(client as any).class,
|
||||
(client as any).initialClass,
|
||||
(client as any).initialTitle,
|
||||
(client as any).title,
|
||||
(client as any).name,
|
||||
].filter(Boolean) as string[];
|
||||
|
||||
// 1) direct exact match
|
||||
for (const k of possibleKeys) {
|
||||
const icon = app_icons.classOrNames[k] ?? app_icons.executables[k];
|
||||
if (icon) {
|
||||
// cache the mapping
|
||||
const cacheKey = app_id ?? title ?? k;
|
||||
// cache the mapping for this client's canonical class (prefer wm_class or class)
|
||||
const cacheKey = (client as any).wm_class ?? (client as any).class ?? (client as any).name ?? k;
|
||||
app_icons.classOrNames[cacheKey] = icon;
|
||||
return icon;
|
||||
}
|
||||
}
|
||||
|
||||
// 2) fuzzy match: see if any stored key includes any of the client strings (title, name, etc.)
|
||||
for (const s of possibleKeys) {
|
||||
const searchStrings = [
|
||||
(client as any).title,
|
||||
(client as any).initialTitle,
|
||||
(client as any).initial_class,
|
||||
(client as any).initialClass,
|
||||
(client as any).wm_class,
|
||||
(client as any).class,
|
||||
(client as any).name,
|
||||
].filter(Boolean) as string[];
|
||||
|
||||
for (const s of searchStrings) {
|
||||
const matchKey = Object.keys(app_icons.classOrNames).find((key) => key.includes(s));
|
||||
if (matchKey) {
|
||||
const icon = app_icons.classOrNames[matchKey];
|
||||
const cacheKey = app_id ?? title ?? s;
|
||||
const cacheKey = (client as any).wm_class ?? (client as any).class ?? (client as any).name ?? s;
|
||||
app_icons.classOrNames[cacheKey] = icon;
|
||||
return icon;
|
||||
}
|
||||
}
|
||||
|
||||
// nothing found — cache empty string so we don't repeat work
|
||||
const cacheKey = app_id ?? title ?? "";
|
||||
const cacheKey = (client as any).wm_class ?? (client as any).class ?? (client as any).name ?? "";
|
||||
if (cacheKey) app_icons.classOrNames[cacheKey] = "";
|
||||
return "";
|
||||
}
|
||||
|
|
|
|||
|
|
@ -21,7 +21,7 @@
|
|||
pkgs.accountsservice
|
||||
|
||||
battery
|
||||
# hyprland
|
||||
hyprland
|
||||
tray
|
||||
powerprofiles
|
||||
wireplumber
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
{pkgs, config, ...}: let
|
||||
{pkgs, ...}: let
|
||||
lock-false = {
|
||||
Value = false;
|
||||
Status = "locked";
|
||||
|
|
@ -6,7 +6,6 @@
|
|||
in {
|
||||
programs.firefox = {
|
||||
enable = true;
|
||||
configPath = "${config.xdg.configHome}/mozilla/firefox";
|
||||
package = pkgs.wrapFirefox pkgs.firefox-unwrapped {
|
||||
pkcs11Modules = [
|
||||
pkgs.eid-mw
|
||||
|
|
|
|||
Binary file not shown.
|
|
@ -2,14 +2,6 @@
|
|||
programs.git = {
|
||||
enable = true;
|
||||
lfs.enable = true;
|
||||
|
||||
# 1. Update the signing configuration
|
||||
signing = {
|
||||
format = "ssh";
|
||||
key = "/home/user/.secrets/SSH/Aloria/id_ed25519";
|
||||
signByDefault = true;
|
||||
};
|
||||
|
||||
settings = {
|
||||
alias = {
|
||||
s = "status";
|
||||
|
|
@ -19,10 +11,6 @@
|
|||
name = "Thomas Avé";
|
||||
email = "email@thomasave.be";
|
||||
};
|
||||
|
||||
# 2. Tell Git where your allowed_signers file is located
|
||||
gpg.ssh.allowedSignersFile = "~/.ssh/allowed_signers";
|
||||
|
||||
credentials.helper = "store";
|
||||
pull.rebase = false;
|
||||
push.autoSetupRemove = true;
|
||||
|
|
@ -36,24 +24,11 @@
|
|||
};
|
||||
rerere.enabled = true;
|
||||
};
|
||||
|
||||
ignores = [
|
||||
"*.direnv/"
|
||||
"*.nix/"
|
||||
"uv.lock"
|
||||
".dmypy.json"
|
||||
".envrc"
|
||||
];
|
||||
};
|
||||
programs.delta = {
|
||||
enable = true;
|
||||
options = {
|
||||
diff-so-fancy = true;
|
||||
file-style = "omit";
|
||||
# hunk-header-style = "omit";
|
||||
};
|
||||
};
|
||||
|
||||
programs.lazygit = {
|
||||
enable = true;
|
||||
settings = {
|
||||
|
|
@ -61,18 +36,6 @@
|
|||
editPreset = "nvim";
|
||||
autoStageResolvedConflicts = false;
|
||||
};
|
||||
git.overrideGpg = true;
|
||||
git.pagers = [
|
||||
{
|
||||
colorArg = "always";
|
||||
pager = "delta --dark --color-only --paging=never";
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
# 3. Declaratively create the allowed_signers file (Assuming Home Manager)
|
||||
home.file.".ssh/allowed_signers".text = ''
|
||||
email@thomasave.be namespaces="git" ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBxMq4kubz4wWr4S8xU3GRkPcn6XRS3y7IP+qylN5QAp user@Aloria
|
||||
'';
|
||||
}
|
||||
|
|
|
|||
|
|
@ -4,11 +4,9 @@
|
|||
pname = "Helium";
|
||||
version = "0.4.7.1";
|
||||
src = pkgs.fetchurl {
|
||||
url = "https://github.com/imputnet/helium-linux/releases/download/0.11.7.1/helium-0.11.7.1-x86_64.AppImage";
|
||||
sha256 = "sha256-qzc135IP5F2btxtOMUGMz+0azJhYL9KI0lcPG2KjcxU=";
|
||||
url = "https://github.com/imputnet/helium-linux/releases/download/0.9.4.1/helium-0.9.4.1-x86_64.AppImage";
|
||||
sha256 = "sha256-N5gdWuxOrIudJx/4nYo4/SKSxakpTFvL4zzByv6Cnug=";
|
||||
};
|
||||
extraPkgs = pkgs: [pkgs.tzdata];
|
||||
profile = "export TZ=Asia/Bangkok";
|
||||
})
|
||||
];
|
||||
xdg.desktopEntries = {
|
||||
|
|
|
|||
|
|
@ -147,6 +147,7 @@ in {
|
|||
"rounding 0, match:float 0, match:workspace f[1]"
|
||||
];
|
||||
|
||||
# UPDATED: New Layer Rule Syntax (0.53.0)
|
||||
# Syntax: effect value, match:namespace regex
|
||||
layerrule = [
|
||||
"no_anim on, match:namespace ags_bar_0"
|
||||
|
|
|
|||
|
|
@ -1,224 +0,0 @@
|
|||
{pkgs, scale ? null, ...}: let
|
||||
terminal = "${pkgs.foot}/bin/footclient";
|
||||
nautilus = "${pkgs.nautilus}/bin/nautilus";
|
||||
playerctl = "${pkgs.playerctl}/bin/playerctl";
|
||||
wpctl = "${pkgs.wireplumber}/bin/wpctl";
|
||||
brightnessctl = "${pkgs.brightnessctl}/bin/brightnessctl";
|
||||
terminal-name = "foot";
|
||||
launch_terminal = pkgs.writeShellScriptBin "launch_terminal" ''
|
||||
function find_leaf_pid(){
|
||||
local PID
|
||||
local RET
|
||||
local NAME
|
||||
PID=$1
|
||||
for CHILD_PID in $(pgrep -P "$PID"); do
|
||||
RET=$(find_leaf_pid "$CHILD_PID")
|
||||
if [ "$RET" != "" ]; then
|
||||
PID="$RET"
|
||||
fi
|
||||
done
|
||||
NAME=$(ps -p "$PID" -o comm=)
|
||||
if [ "$NAME" == "zsh" ]; then
|
||||
echo "$PID"
|
||||
elif [ "$NAME" == "ssh" ]; then
|
||||
echo "$PID"
|
||||
fi
|
||||
}
|
||||
|
||||
LEAF_PID=$(find_leaf_pid "$1")
|
||||
if [ "$(ps -p "$LEAF_PID" -o comm=)" == "ssh" ]; then
|
||||
SSH_COMMAND=$(ps -p "$LEAF_PID" -o args --no-headers)
|
||||
if [[ "$SSH_COMMAND" == *"waypipe"* ]]; then
|
||||
CLIENT=$(echo "$SSH_COMMAND" | awk '{ print $5 }')
|
||||
PREVIOUS_SESSION_ID=$(grep -z "SSH_SESSION_ID" "/proc/$LEAF_PID/environ" | xargs -0 -n 1 | grep -oP "[0-9]*")
|
||||
SSH_SESSION_ID=$RANDOM
|
||||
${terminal} -e zsh -c "SSH_SESSION_ID=$SSH_SESSION_ID waypipe ssh -t \"$CLIENT\" env SSH_SESSION_ID=\"$SSH_SESSION_ID\" PREVIOUS_SESSION_ID=\"$PREVIOUS_SESSION_ID\" \"zsh --login\""
|
||||
else
|
||||
${terminal} -e zsh -c "ssh -t \"$(echo "$SSH_COMMAND" | awk '{ print $2 }')\""
|
||||
fi
|
||||
|
||||
else # Not an ssh session
|
||||
if [ "$(ps -p "$1" -o comm=)" == "${terminal-name}" ]; then
|
||||
CWD=$(readlink -e /proc/"$LEAF_PID"/cwd)
|
||||
if [ "$CWD" != "" ]; then
|
||||
${terminal} --working-directory "$CWD"
|
||||
else
|
||||
${terminal}
|
||||
fi
|
||||
else
|
||||
${terminal}
|
||||
fi
|
||||
fi
|
||||
'';
|
||||
in {
|
||||
# Since native Home Manager doesn't have a programs.niri module yet,
|
||||
# we generate the KDL configuration file directly.
|
||||
programs.hyprlock = {
|
||||
enable = true;
|
||||
settings = {
|
||||
input-field = [
|
||||
{
|
||||
size = "200, 50";
|
||||
position = "0, -80";
|
||||
monitor = "";
|
||||
dots_center = true;
|
||||
fade_on_empty = true;
|
||||
font_color = "rgb(202, 211, 245)";
|
||||
inner_color = "rgb(91, 96, 120)";
|
||||
outer_color = "rgb(24, 25, 38)";
|
||||
outline_thickness = 3;
|
||||
placeholder_text = "<span foreground=\"##cad3f5\">Password...</span>";
|
||||
shadow_passes = 2;
|
||||
}
|
||||
];
|
||||
general = {
|
||||
no_fade_in = false;
|
||||
};
|
||||
background = [
|
||||
{
|
||||
path = "screenshot";
|
||||
blur_passes = 3;
|
||||
blur_size = 8;
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
xdg.configFile."niri/config.kdl".text = ''
|
||||
spawn-at-startup "${pkgs.swaybg}/bin/swaybg" "-i" "${../hyprland/files/wallpaper.png}" "-m" "fill"
|
||||
spawn-at-startup "foot" "--server"
|
||||
spawn-at-startup "ags" "run"
|
||||
spawn-at-startup "${pkgs.mate-polkit}/bin/polkit-mate"
|
||||
prefer-no-csd
|
||||
|
||||
hotkey-overlay {
|
||||
skip-at-startup
|
||||
}
|
||||
|
||||
gestures {
|
||||
hot-corners {
|
||||
off
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
layout {
|
||||
gaps 5
|
||||
border {
|
||||
off
|
||||
}
|
||||
focus-ring {
|
||||
width 4
|
||||
active-color "rgba(0, 47, 95, 238)"
|
||||
inactive-color "rgba(255, 255, 255, 0)"
|
||||
}
|
||||
}
|
||||
|
||||
input {
|
||||
mouse {
|
||||
accel-speed 0.5
|
||||
}
|
||||
touchpad {
|
||||
tap
|
||||
}
|
||||
keyboard {
|
||||
xkb {
|
||||
options "compose:rctrl"
|
||||
}
|
||||
}
|
||||
focus-follows-mouse max-scroll-amount="10%"
|
||||
warp-mouse-to-focus
|
||||
}
|
||||
${if scale != null then ''
|
||||
output "eDP-1" {
|
||||
scale ${toString scale}
|
||||
}
|
||||
'' else ""} window-rule {
|
||||
match app-id="vicinae"
|
||||
open-floating true
|
||||
}
|
||||
|
||||
binds {
|
||||
// General Binds
|
||||
Mod+Return { spawn "sh" "-c" "${launch_terminal}/bin/launch_terminal $(niri msg --json focused-window | ${pkgs.jq}/bin/jq .pid)"; }
|
||||
Mod+Shift+Return { spawn "${terminal}"; }
|
||||
Mod+Q { close-window; }
|
||||
Mod+A { spawn "${nautilus}"; }
|
||||
Mod+B { spawn "Helium"; }
|
||||
Mod+M { maximize-column; }
|
||||
Mod+F {maximize-window-to-edges;}
|
||||
Mod+Tab { toggle-overview; }
|
||||
|
||||
// Vicinae Binds
|
||||
Mod+C { spawn "vicinae" "vicinae://extensions/vicinae/clipboard/history"; }
|
||||
Mod+N { spawn "vicinae" "vicinae://extensions/vicinae/wm/switch-windows"; }
|
||||
Mod+Escape { spawn "vicinae" "open" "-q" "Power Management "; }
|
||||
Mod+Space { spawn "vicinae" "toggle"; }
|
||||
|
||||
Mod+Comma { consume-or-expel-window-left; }
|
||||
Mod+Period { consume-or-expel-window-right; }
|
||||
|
||||
Mod+Alt+H { set-column-width "-5%"; }
|
||||
Mod+Alt+L { set-column-width "+5%"; }
|
||||
Mod+Alt+K { set-window-height "-5%"; }
|
||||
Mod+Alt+J { set-window-height "+5%"; }
|
||||
|
||||
// Movement
|
||||
Mod+H { focus-column-left; }
|
||||
Mod+J { focus-window-down; }
|
||||
Mod+K { focus-window-up; }
|
||||
Mod+L { focus-column-right; }
|
||||
|
||||
Mod+Shift+H { move-column-left; }
|
||||
Mod+Shift+L { move-column-right; }
|
||||
Mod+Shift+J { move-window-down; }
|
||||
Mod+Shift+K { move-window-up; }
|
||||
|
||||
// Workspaces
|
||||
Mod+Shift+U { move-column-to-workspace-down; }
|
||||
Mod+Shift+I { move-column-to-workspace-up; }
|
||||
|
||||
Mod+I { focus-workspace-up; }
|
||||
Mod+U { focus-workspace-down; }
|
||||
Mod+1 { focus-workspace 1; }
|
||||
Mod+2 { focus-workspace 2; }
|
||||
Mod+3 { focus-workspace 3; }
|
||||
Mod+4 { focus-workspace 4; }
|
||||
Mod+5 { focus-workspace 5; }
|
||||
Mod+6 { focus-workspace 6; }
|
||||
Mod+7 { focus-workspace 7; }
|
||||
Mod+8 { focus-workspace 8; }
|
||||
Mod+9 { focus-workspace 9; }
|
||||
|
||||
// Move to workspace
|
||||
Mod+Shift+1 { move-column-to-workspace 1; }
|
||||
Mod+Shift+2 { move-column-to-workspace 2; }
|
||||
Mod+Shift+3 { move-column-to-workspace 3; }
|
||||
Mod+Shift+4 { move-column-to-workspace 4; }
|
||||
Mod+Shift+5 { move-column-to-workspace 5; }
|
||||
Mod+Shift+6 { move-column-to-workspace 6; }
|
||||
Mod+Shift+7 { move-column-to-workspace 7; }
|
||||
Mod+Shift+8 { move-column-to-workspace 8; }
|
||||
Mod+Shift+9 { move-column-to-workspace 9; }
|
||||
|
||||
Print { screenshot; }
|
||||
Ctrl+Alt+L {spawn "${pkgs.hyprlock}/bin/hyprlock"; }
|
||||
|
||||
XF86MonBrightnessUp { spawn "${brightnessctl}" "set" "+10%"; }
|
||||
XF86MonBrightnessDown { spawn "${brightnessctl}" "set" "10%-"; }
|
||||
|
||||
// Volume
|
||||
XF86AudioRaiseVolume { spawn "${wpctl}" "set-volume" "@DEFAULT_AUDIO_SINK@" "10%+" "--limit" "1.0"; }
|
||||
XF86AudioLowerVolume { spawn "${wpctl}" "set-volume" "@DEFAULT_AUDIO_SINK@" "10%-"; }
|
||||
XF86AudioMute { spawn "${wpctl}" "set-mute" "@DEFAULT_AUDIO_SINK@" "toggle"; }
|
||||
XF86AudioMicMute { spawn "${wpctl}" "set-mute" "@DEFAULT_AUDIO_SOURCE@" "toggle"; }
|
||||
|
||||
// Media
|
||||
XF86AudioNext { spawn "${playerctl}" "next"; }
|
||||
XF86AudioPrev { spawn "${playerctl}" "previous"; }
|
||||
Mod+XF86AudioMute { spawn "${playerctl}" "play-pause"; }
|
||||
Mod+XF86AudioRaiseVolume { spawn "${playerctl}" "next"; }
|
||||
Mod+XF86AudioLowerVolume { spawn "${playerctl}" "previous"; }
|
||||
}
|
||||
'';
|
||||
}
|
||||
|
|
@ -2,19 +2,9 @@
|
|||
config,
|
||||
pkgs,
|
||||
...
|
||||
}: let
|
||||
basedpyrightShim = pkgs.symlinkJoin {
|
||||
name = "basedpyright-with-pyright-shim";
|
||||
paths = [pkgs.basedpyright];
|
||||
postBuild = ''
|
||||
ln -s $out/bin/basedpyright-langserver $out/bin/pyright-langserver
|
||||
ln -s $out/bin/basedpyright $out/bin/pyright
|
||||
'';
|
||||
};
|
||||
in {
|
||||
}: {
|
||||
home.packages = with pkgs; [
|
||||
# codeium
|
||||
basedpyrightShim
|
||||
nixd
|
||||
alejandra
|
||||
clang-tools
|
||||
|
|
|
|||
|
|
@ -5,13 +5,12 @@ end
|
|||
return {
|
||||
{
|
||||
'saghen/blink.compat',
|
||||
version = '*',
|
||||
lazy = true,
|
||||
opts = {},
|
||||
},
|
||||
{
|
||||
'saghen/blink.cmp',
|
||||
branch = 'v1',
|
||||
version = "1.*",
|
||||
dependencies = {
|
||||
'rafamadriz/friendly-snippets',
|
||||
'honza/vim-snippets',
|
||||
|
|
@ -23,8 +22,8 @@ return {
|
|||
},
|
||||
build = 'nix run --extra-experimental-features flakes --extra-experimental-features nix-command .#build-plugin',
|
||||
keys = {
|
||||
{ "<leader>n", function() vim.diagnostic.jump({ count = 1 }) end },
|
||||
{ "<leader>p", function() vim.diagnostic.jump({ count = -1 }) end },
|
||||
{ "<leader>n", vim.diagnostic.goto_next },
|
||||
{ "<leader>p", vim.diagnostic.goto_prev },
|
||||
{ "<leader>f", vim.lsp.buf.code_action },
|
||||
{ "gd", vim.lsp.buf.definition },
|
||||
{ "gi", vim.lsp.buf.implementation },
|
||||
|
|
|
|||
|
|
@ -23,7 +23,6 @@
|
|||
htop
|
||||
ghostscript
|
||||
waypipe
|
||||
tree
|
||||
inputs.worktimer.packages.${pkgs.stdenv.hostPlatform.system}.default
|
||||
usbutils
|
||||
gocryptfs
|
||||
|
|
|
|||
|
|
@ -2,14 +2,12 @@
|
|||
inputs,
|
||||
config,
|
||||
pkgs,
|
||||
scale ? null,
|
||||
...
|
||||
}: {
|
||||
imports = [
|
||||
(import ./common.nix {inherit inputs config pkgs;})
|
||||
(import ./python.nix {inherit inputs config pkgs;})
|
||||
# (import ../hyprland {inherit inputs pkgs;})
|
||||
(import ../niri {inherit inputs config pkgs scale;})
|
||||
(import ../hyprland {inherit inputs pkgs;})
|
||||
(import ../ags {inherit inputs pkgs;})
|
||||
../rofi
|
||||
../vicinae
|
||||
|
|
@ -120,5 +118,4 @@
|
|||
};
|
||||
|
||||
fonts.fontconfig.enable = true;
|
||||
gtk.gtk4.theme = config.gtk.theme; # Silence warning
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,9 +1,17 @@
|
|||
{...}: {
|
||||
programs.vicinae = {
|
||||
{inputs, ...}:
|
||||
# Add inputs here
|
||||
{
|
||||
# Import the module definition here
|
||||
imports = [inputs.vicinae.homeManagerModules.default];
|
||||
|
||||
services.vicinae = {
|
||||
enable = true;
|
||||
systemd = {
|
||||
enable = true;
|
||||
autoStart = true;
|
||||
environment = {
|
||||
QT_SCALE_FACTOR = "1.5";
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -5,12 +5,12 @@
|
|||
config,
|
||||
...
|
||||
}: let
|
||||
# serverIP = "10.0.0.1";
|
||||
serverIP = "10.0.0.1";
|
||||
in {
|
||||
imports = [
|
||||
(import ../Common/default.nix {inherit inputs pkgs config;})
|
||||
(import ../Common/desktop.nix {inherit inputs pkgs config;})
|
||||
# (import ../Common/nfs.nix {inherit pkgs serverIP;})
|
||||
(import ../Common/nfs.nix {inherit pkgs serverIP;})
|
||||
(import ../Common/zfs.nix {inherit inputs pkgs config;})
|
||||
];
|
||||
|
||||
|
|
@ -150,6 +150,21 @@ in {
|
|||
}
|
||||
];
|
||||
};
|
||||
GCP = {
|
||||
address = ["10.5.0.5/24"];
|
||||
privateKeyFile = "/home/user/.secrets/Wireguard/GCP.key";
|
||||
listenPort = 51820;
|
||||
autostart = false;
|
||||
postUp = "resolvectl dns GCP 1.1.1.1;resolvectl dns wlan0 1.1.1.1;";
|
||||
peers = [
|
||||
{
|
||||
publicKey = "NEBNE4Czf2MkZF2X5aVhmofENH1uXjDpvXjIMJvfMFA=";
|
||||
allowedIPs = ["0.0.0.0/0"];
|
||||
endpoint = "35.201.231.151:443";
|
||||
persistentKeepalive = 25;
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
systemd.services."wg-quick-OPNsense" = {
|
||||
serviceConfig = {
|
||||
|
|
@ -158,13 +173,6 @@ in {
|
|||
};
|
||||
unitConfig.StartLimitIntervalSec = 0;
|
||||
};
|
||||
services.tailscale = {
|
||||
enable = true;
|
||||
extraUpFlags = [
|
||||
"--login-server=https://headscale.thomasave.be"
|
||||
];
|
||||
authKeyFile = "/home/user/.secrets/Tailscale/Aloria/authkey";
|
||||
};
|
||||
services.usbmuxd.enable = true;
|
||||
environment.systemPackages = with pkgs; [
|
||||
libcamera
|
||||
|
|
|
|||
|
|
@ -56,8 +56,7 @@
|
|||
nixpkgs.config.packageOverrides = pkgs: {
|
||||
zfs = pkgs.zfs_unstable;
|
||||
};
|
||||
boot.kernelPackages = pkgs.linuxPackages;
|
||||
boot.zfs.forceImportRoot = false;
|
||||
boot.kernelPackages = pkgs.linuxPackages_latest;
|
||||
hardware.firmware = with pkgs; [
|
||||
ipu6-camera-bins
|
||||
ivsc-firmware
|
||||
|
|
|
|||
|
|
@ -11,6 +11,7 @@ in {
|
|||
imports = [
|
||||
(import ../Common/default.nix {inherit inputs pkgs config;})
|
||||
(import ../Common/desktop.nix {inherit inputs pkgs config;})
|
||||
(import ../Common/nfs.nix {inherit pkgs serverIP;})
|
||||
(import ../Common/zfs.nix {inherit inputs pkgs config;})
|
||||
];
|
||||
|
||||
|
|
|
|||
|
|
@ -12,7 +12,6 @@
|
|||
boot.initrd.kernelModules = [];
|
||||
boot.kernelModules = ["kvm-intel"];
|
||||
boot.extraModulePackages = [];
|
||||
boot.zfs.forceImportRoot = false;
|
||||
|
||||
fileSystems."/" = {
|
||||
device = "rpool/root";
|
||||
|
|
|
|||
|
|
@ -15,17 +15,15 @@
|
|||
vulkan-extension-layer
|
||||
];
|
||||
};
|
||||
# programs.hyprland = {
|
||||
# enable = true;
|
||||
# withUWSM = true;
|
||||
# };
|
||||
programs.niri.enable = true;
|
||||
programs.hyprland = {
|
||||
enable = true;
|
||||
withUWSM = true;
|
||||
};
|
||||
services.greetd = {
|
||||
enable = pkgs.lib.mkDefault true;
|
||||
settings = rec {
|
||||
initial_session = {
|
||||
# command = "uwsm start hyprland-uwsm.desktop";
|
||||
command = "niri-session";
|
||||
command = "uwsm start hyprland-uwsm.desktop";
|
||||
user = "user";
|
||||
};
|
||||
default_session = initial_session;
|
||||
|
|
|
|||
|
|
@ -12,6 +12,7 @@ in {
|
|||
# (import ../Common/nvidia.nix { inherit inputs pkgs config; })
|
||||
(import ../Common/desktop.nix {inherit inputs pkgs config;})
|
||||
(import ../Common/nfs.nix {inherit pkgs serverIP;})
|
||||
(import ../Common/android.nix {inherit pkgs;})
|
||||
];
|
||||
|
||||
# Kernel
|
||||
|
|
@ -39,6 +40,7 @@ in {
|
|||
nixpkgs.config.rocmSupport = true;
|
||||
services.ollama = {
|
||||
enable = true;
|
||||
acceleration = "rocm";
|
||||
};
|
||||
# nixpkgs.config.cudaSupport = true;
|
||||
services.logind.settings.Login = {
|
||||
|
|
|
|||
Loading…
Reference in New Issue