Compare commits
2 Commits
8341ffcfcd
...
50901f6810
| Author | SHA1 | Date | |
|---|---|---|---|
| 50901f6810 | |||
| b8523d9cc2 |
100
flake.lock
100
flake.lock
|
|
@ -18,6 +18,24 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"flake-utils_2": {
|
||||||
|
"inputs": {
|
||||||
|
"systems": "systems_2"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1731533236,
|
||||||
|
"narHash": "sha256-l0KFg5HjrsfsO/JpG+r7fRrqm12kzFHyUHqHCVpMMbI=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"rev": "11707dc2f618dd54ca8739b309ec4fc024de578b",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"home-manager": {
|
"home-manager": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
|
|
@ -25,11 +43,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1776454077,
|
"lastModified": 1779969295,
|
||||||
"narHash": "sha256-7zSUFWsU0+jlD7WB3YAxQ84Z/iJurA5hKPm8EfEyGJk=",
|
"narHash": "sha256-HwIJ3tOcwSMiV75L7KqJXciXR9UfT+d7rwOZMX7cTnA=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "565e5349208fe7d0831ef959103c9bafbeac0681",
|
"rev": "61e2c9659324181e0f0ed911958c536333b1d4f6",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -38,6 +56,26 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"insomnia": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-utils": "flake-utils_2",
|
||||||
|
"nixpkgs": "nixpkgs"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1780015149,
|
||||||
|
"narHash": "sha256-sEpglWrsVDNHys56LNLY8mvak2A3OkRE865ZYTc9i/w=",
|
||||||
|
"ref": "develop",
|
||||||
|
"rev": "b0c3b79e114502acd375afe78cac34ef2aeef05c",
|
||||||
|
"revCount": 610,
|
||||||
|
"type": "git",
|
||||||
|
"url": "ssh://git@gitea.hareworks.net/Hare/insomnia.git"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"ref": "develop",
|
||||||
|
"type": "git",
|
||||||
|
"url": "ssh://git@gitea.hareworks.net/Hare/insomnia.git"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nix-index-database": {
|
"nix-index-database": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
|
|
@ -45,11 +83,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1775970782,
|
"lastModified": 1779604987,
|
||||||
"narHash": "sha256-7jt9Vpm48Yy5yAWigYpde+HxtYEpEuyzIQJF4VYehhk=",
|
"narHash": "sha256-ZQ5z+fVhxYKtIFwtqGp5O0PD84BM1riASvqDaN5Xs+s=",
|
||||||
"owner": "Mic92",
|
"owner": "Mic92",
|
||||||
"repo": "nix-index-database",
|
"repo": "nix-index-database",
|
||||||
"rev": "bedba5989b04614fc598af9633033b95a937933f",
|
"rev": "8fba98c80b48fa013820e0163c5096922fea4ddd",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -60,11 +98,11 @@
|
||||||
},
|
},
|
||||||
"nixos-hardware": {
|
"nixos-hardware": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1775490113,
|
"lastModified": 1779826373,
|
||||||
"narHash": "sha256-2ZBhDNZZwYkRmefK5XLOusCJHnoeKkoN95hoSGgMxWM=",
|
"narHash": "sha256-3sRzgLX86qV5NlhWUAufLmHwkyP03tmL3VdZIM13dEo=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixos-hardware",
|
"repo": "nixos-hardware",
|
||||||
"rev": "c775c2772ba56e906cbeb4e0b2db19079ef11ff7",
|
"rev": "ef4efb84766a166c906bd55759574676bf91267c",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -75,11 +113,27 @@
|
||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1776169885,
|
"lastModified": 1775036866,
|
||||||
"narHash": "sha256-l/iNYDZ4bGOAFQY2q8y5OAfBBtrDAaPuRQqWaFHVRXM=",
|
"narHash": "sha256-ZojAnPuCdy657PbTq5V0Y+AHKhZAIwSIT2cb8UgAz/U=",
|
||||||
|
"owner": "nixos",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "6201e203d09599479a3b3450ed24fa81537ebc4e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nixos",
|
||||||
|
"ref": "nixos-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"nixpkgs_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1779560665,
|
||||||
|
"narHash": "sha256-tpyBcxPpcQb8ukyNF7DoCwfSY3VPsxHoYwj00Cayv5o=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "4bd9165a9165d7b5e33ae57f3eecbcb28fb231c9",
|
"rev": "64c08a7ca051951c8eae34e3e3cb1e202fe36786",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -89,7 +143,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_2": {
|
"nixpkgs_3": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1727348695,
|
"lastModified": 1727348695,
|
||||||
"narHash": "sha256-J+PeFKSDV+pHL7ukkfpVzCOO7mBSrrpJ3svwBFABbhI=",
|
"narHash": "sha256-J+PeFKSDV+pHL7ukkfpVzCOO7mBSrrpJ3svwBFABbhI=",
|
||||||
|
|
@ -109,9 +163,10 @@
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils",
|
||||||
"home-manager": "home-manager",
|
"home-manager": "home-manager",
|
||||||
|
"insomnia": "insomnia",
|
||||||
"nix-index-database": "nix-index-database",
|
"nix-index-database": "nix-index-database",
|
||||||
"nixos-hardware": "nixos-hardware",
|
"nixos-hardware": "nixos-hardware",
|
||||||
"nixpkgs": "nixpkgs",
|
"nixpkgs": "nixpkgs_2",
|
||||||
"zen-browser": "zen-browser"
|
"zen-browser": "zen-browser"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
@ -130,9 +185,24 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"systems_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1681028828,
|
||||||
|
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"zen-browser": {
|
"zen-browser": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": "nixpkgs_2"
|
"nixpkgs": "nixpkgs_3"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1761859251,
|
"lastModified": 1761859251,
|
||||||
|
|
|
||||||
|
|
@ -10,6 +10,7 @@
|
||||||
flake-utils.url = "github:numtide/flake-utils";
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
||||||
zen-browser.url = "github:xaragon/zen-browser-flake";
|
zen-browser.url = "github:xaragon/zen-browser-flake";
|
||||||
|
insomnia.url = "git+ssh://git@gitea.hareworks.net/Hare/insomnia.git?ref=develop";
|
||||||
|
|
||||||
nix-index-database.url = "github:Mic92/nix-index-database";
|
nix-index-database.url = "github:Mic92/nix-index-database";
|
||||||
nix-index-database.inputs.nixpkgs.follows = "nixpkgs";
|
nix-index-database.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
{
|
{
|
||||||
programs.firefox = {
|
programs.firefox = {
|
||||||
enable = true;
|
enable = true;
|
||||||
};
|
configPath = ".mozilla/firefox";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,8 +5,46 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (lib) mkOption recursiveUpdate types optionals;
|
inherit (lib)
|
||||||
|
mkOption
|
||||||
|
recursiveUpdate
|
||||||
|
types
|
||||||
|
optionals
|
||||||
|
;
|
||||||
rosePineHyprcursor = pkgs.callPackage ./rose-pine-hyprcursor.nix { };
|
rosePineHyprcursor = pkgs.callPackage ./rose-pine-hyprcursor.nix { };
|
||||||
|
mkLua = lib.generators.mkLuaInline;
|
||||||
|
|
||||||
|
mkEnv = name: value: {
|
||||||
|
_args = [
|
||||||
|
name
|
||||||
|
value
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
mkBind = keys: dispatcher: {
|
||||||
|
_args = [
|
||||||
|
keys
|
||||||
|
(mkLua dispatcher)
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
mkMouseBind = keys: dispatcher: {
|
||||||
|
_args = [
|
||||||
|
keys
|
||||||
|
(mkLua dispatcher)
|
||||||
|
{ mouse = true; }
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
mkStartHook = commands: {
|
||||||
|
_args = [
|
||||||
|
"hyprland.start"
|
||||||
|
(mkLua ''
|
||||||
|
function()
|
||||||
|
${lib.concatMapStrings (command: " hl.exec_cmd(${builtins.toJSON command})\n") commands}end
|
||||||
|
'')
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
defaultInput = {
|
defaultInput = {
|
||||||
kb_layout = "us";
|
kb_layout = "us";
|
||||||
|
|
@ -27,35 +65,31 @@ let
|
||||||
|
|
||||||
wallpaperCommand = config.hare.hyprland.wallpaperCommand;
|
wallpaperCommand = config.hare.hyprland.wallpaperCommand;
|
||||||
|
|
||||||
baseSettings = {
|
startupCommands = [
|
||||||
exec-once = [
|
# "/usr/lib/polkit-kde-authentication-agent-1"
|
||||||
# "/usr/lib/polkit-kde-authentication-agent-1"
|
# "dunst"
|
||||||
# "dunst"
|
"awww-daemon"
|
||||||
"awww-daemon"
|
# "copyq --start-server"
|
||||||
# "copyq --start-server"
|
# "wl-paste --type text --watch cliphist store"
|
||||||
# "wl-paste --type text --watch cliphist store"
|
# "wl-paste --type image --watch cliphist store"
|
||||||
# "wl-paste --type image --watch cliphist store"
|
"eww daemon"
|
||||||
"eww daemon"
|
"eww open bar"
|
||||||
"eww open bar"
|
"eww open roundedEdge"
|
||||||
"eww open roundedEdge"
|
];
|
||||||
];
|
|
||||||
exec =
|
reloadCommands =
|
||||||
optionals (wallpaperCommand != null) [
|
optionals (wallpaperCommand != null) [
|
||||||
wallpaperCommand
|
wallpaperCommand
|
||||||
]
|
]
|
||||||
++ [
|
++ [
|
||||||
"dconf write /org/gnome/desktop/interface/gtk-theme 'Adwaita Dark'"
|
"dconf write /org/gnome/desktop/interface/gtk-theme 'Adwaita Dark'"
|
||||||
"dconf write /org/gnome/desktop/interface/icon-theme 'Adwaita Dark'"
|
"dconf write /org/gnome/desktop/interface/icon-theme 'Adwaita Dark'"
|
||||||
"dconf write /org/gnome/desktop/interface/document-font-name 'Noto Sans Medium 11'"
|
"dconf write /org/gnome/desktop/interface/document-font-name 'Noto Sans Medium 11'"
|
||||||
"dconf write /org/gnome/desktop/interface/font-name 'Noto Sans Medium 11'"
|
"dconf write /org/gnome/desktop/interface/font-name 'Noto Sans Medium 11'"
|
||||||
"dconf write /org/gnome/desktop/interface/monospace-font-name 'Noto Sans Mono Medium 11'"
|
"dconf write /org/gnome/desktop/interface/monospace-font-name 'Noto Sans Mono Medium 11'"
|
||||||
];
|
];
|
||||||
env = [
|
|
||||||
"XDG_CURRENT_DESKTOP,Hyprland"
|
|
||||||
"XDG_SESSION_TYPE,wayland"
|
|
||||||
"XDG_SESSION_DESKTOP,Hyprland"
|
|
||||||
];
|
|
||||||
|
|
||||||
|
baseConfig = {
|
||||||
ecosystem.no_update_news = true;
|
ecosystem.no_update_news = true;
|
||||||
|
|
||||||
input = defaultInput;
|
input = defaultInput;
|
||||||
|
|
@ -66,7 +100,6 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
dwindle = {
|
dwindle = {
|
||||||
pseudotile = true;
|
|
||||||
preserve_split = true;
|
preserve_split = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -75,76 +108,124 @@ let
|
||||||
disable_hyprland_logo = true;
|
disable_hyprland_logo = true;
|
||||||
disable_splash_rendering = true;
|
disable_splash_rendering = true;
|
||||||
};
|
};
|
||||||
|
xwayland = {
|
||||||
|
force_zero_scaling = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
windowrule = [
|
baseSettings = {
|
||||||
"animation windowsIn 0, match:title ^(.*wofi.*)$"
|
menu = {
|
||||||
"float on, match:title ^(.*feh.*)$"
|
_var = "uwsm app -- $(tofi-drun)";
|
||||||
"center on, match:title ^(.*feh.*)$"
|
};
|
||||||
"float on, match:title ^(Picture.*)$"
|
terminal = {
|
||||||
"pin on, match:title ^(Picture.*)$"
|
_var = "wezterm";
|
||||||
"immediate on, match:class ^(Terraria)$"
|
};
|
||||||
|
lock = {
|
||||||
|
_var = "hyprlock";
|
||||||
|
};
|
||||||
|
|
||||||
|
env = [
|
||||||
|
(mkEnv "XDG_CURRENT_DESKTOP" "Hyprland")
|
||||||
|
(mkEnv "XDG_SESSION_TYPE" "wayland")
|
||||||
|
(mkEnv "XDG_SESSION_DESKTOP" "Hyprland")
|
||||||
|
# "GDK_SCALE,2"
|
||||||
|
# "XCURSOR_SIZE,32"
|
||||||
];
|
];
|
||||||
|
|
||||||
workspace = [
|
exec_cmd = reloadCommands;
|
||||||
"1, monitor:DP-2, default:true"
|
|
||||||
"r[2-9], monitor:DP-2"
|
on = mkStartHook startupCommands;
|
||||||
"name:sub, monitor:DP-1, default:true"
|
|
||||||
|
window_rule = [
|
||||||
|
{
|
||||||
|
match.title = "^(.*wofi.*)$";
|
||||||
|
animation = "windowsIn 0";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
match.title = "^(.*feh.*)$";
|
||||||
|
float = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
match.title = "^(.*feh.*)$";
|
||||||
|
center = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
match.title = "^(Picture.*)$";
|
||||||
|
float = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
match.title = "^(Picture.*)$";
|
||||||
|
pin = true;
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
"$menu" = "uwsm app -- $(tofi-drun)";
|
workspace_rule = [
|
||||||
"$terminal" = "wezterm";
|
{
|
||||||
"$lock" = "hyprlock";
|
workspace = "r[1-9]";
|
||||||
bindm = [
|
monitor = "DP-1";
|
||||||
# Window Movement & Resizing
|
}
|
||||||
"SUPER, mouse:272, movewindow"
|
{
|
||||||
"SUPER, mouse:273, resizewindow"
|
workspace = "101";
|
||||||
|
monitor = "DP-2";
|
||||||
|
default = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
workspace = "102";
|
||||||
|
monitor = "DP-3";
|
||||||
|
default = true;
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
bind = [
|
bind = [
|
||||||
|
# Window Movement & Resizing
|
||||||
|
(mkMouseBind "SUPER + mouse:272" "hl.dsp.window.drag()")
|
||||||
|
(mkMouseBind "SUPER + mouse:273" "hl.dsp.window.resize()")
|
||||||
|
|
||||||
# basic
|
# basic
|
||||||
"SUPER, return, exec, $menu"
|
(mkBind "SUPER + RETURN" "hl.dsp.exec_cmd(menu)")
|
||||||
"SUPER, E, exec, $terminal"
|
(mkBind "SUPER + E" "hl.dsp.exec_cmd(terminal)")
|
||||||
"SUPER, Q, killactive,"
|
(mkBind "SUPER + Q" "hl.dsp.window.close()")
|
||||||
"SUPER, L, exec, $lock"
|
(mkBind "SUPER + L" "hl.dsp.exec_cmd(lock)")
|
||||||
"SUPER_SHIFT, L, exec, hyprctl dispatch dpms off"
|
(mkBind "SUPER + SHIFT + L" ''hl.dsp.dpms({ action = "off" })'')
|
||||||
"SUPER_SHIFT, M, exec, loginctl terminate-user $USER"
|
(mkBind "SUPER + SHIFT + M" ''hl.dsp.exec_cmd("loginctl terminate-user $USER")'')
|
||||||
|
|
||||||
# prsc
|
# prsc
|
||||||
", Print, exec, hyprshot -m window -m active --clipboard-only"
|
(mkBind "Print" ''hl.dsp.exec_cmd("hyprshot -m window -m active --clipboard-only")'')
|
||||||
|
|
||||||
# Clipboard
|
# Clipboard
|
||||||
"SUPER, C, exec, copyq show"
|
(mkBind "SUPER + C" ''hl.dsp.exec_cmd("copyq show")'')
|
||||||
"SUPER, V, exec, clipman pick -t dmenu"
|
(mkBind "SUPER + V" ''hl.dsp.exec_cmd("clipman pick -t dmenu")'')
|
||||||
|
|
||||||
# Window navigation
|
# Window navigation
|
||||||
"SUPER, F, fullscreen,"
|
(mkBind "SUPER + F" "hl.dsp.window.fullscreen()")
|
||||||
"SUPER, Y, pin"
|
(mkBind "SUPER + Y" "hl.dsp.window.pin()")
|
||||||
"SUPER, I, togglefloating,"
|
(mkBind "SUPER + I" ''hl.dsp.window.float({ action = "toggle" })'')
|
||||||
"SUPER, O, togglesplit," # dwindle
|
(mkBind "SUPER + O" ''hl.dsp.layout("togglesplit")'') # dwindle
|
||||||
"SUPER, P, pseudo," # dwindle
|
(mkBind "SUPER + P" "hl.dsp.window.pseudo()") # dwindle
|
||||||
|
|
||||||
# Window focus
|
# Window focus
|
||||||
"SUPER, mouse_down, cyclenext, next"
|
(mkBind "SUPER + mouse_down" "hl.dsp.window.cycle_next()")
|
||||||
"SUPER, mouse_up, cyclenext, prev"
|
(mkBind "SUPER + mouse_up" "hl.dsp.window.cycle_next({ next = false })")
|
||||||
|
|
||||||
"SUPER, left, movefocus, l"
|
(mkBind "SUPER + left" ''hl.dsp.focus({ direction = "left" })'')
|
||||||
"SUPER, right, movefocus, r"
|
(mkBind "SUPER + right" ''hl.dsp.focus({ direction = "right" })'')
|
||||||
"SUPER, up, movefocus, u"
|
(mkBind "SUPER + up" ''hl.dsp.focus({ direction = "up" })'')
|
||||||
"SUPER, down, movefocus, d"
|
(mkBind "SUPER + down" ''hl.dsp.focus({ direction = "down" })'')
|
||||||
|
|
||||||
"SUPER_SHIFT, left, movewindow, l"
|
(mkBind "SUPER + SHIFT + left" ''hl.dsp.window.move({ direction = "left" })'')
|
||||||
"SUPER_SHIFT, right, movewindow, r"
|
(mkBind "SUPER + SHIFT + right" ''hl.dsp.window.move({ direction = "right" })'')
|
||||||
"SUPER_SHIFT, up, movewindow, u"
|
(mkBind "SUPER + SHIFT + up" ''hl.dsp.window.move({ direction = "up" })'')
|
||||||
"SUPER_SHIFT, down, movewindow, d"
|
(mkBind "SUPER + SHIFT + down" ''hl.dsp.window.move({ direction = "down" })'')
|
||||||
|
|
||||||
# workspaces
|
# workspaces
|
||||||
"SUPER, 1, workspace, 1"
|
(mkBind "SUPER + 1" "hl.dsp.focus({ workspace = 1 })")
|
||||||
"SUPER, 2, workspace, 2"
|
(mkBind "SUPER + 2" "hl.dsp.focus({ workspace = 2 })")
|
||||||
"SUPER, 3, workspace, 3"
|
(mkBind "SUPER + 3" "hl.dsp.focus({ workspace = 3 })")
|
||||||
|
|
||||||
"SUPER_CTRL, left, workspace, m-1"
|
(mkBind "SUPER + CTRL + left" ''hl.dsp.focus({ workspace = "m-1" })'')
|
||||||
"SUPER_CTRL, right, workspace, m+1"
|
(mkBind "SUPER + CTRL + right" ''hl.dsp.focus({ workspace = "m+1" })'')
|
||||||
"SUPER_CTRL_SHIFT, left, workspace, r-1"
|
(mkBind "SUPER + CTRL + SHIFT + left" ''hl.dsp.focus({ workspace = "r-1" })'')
|
||||||
"SUPER_CTRL_SHIFT, right, workspace, r+1"
|
(mkBind "SUPER + CTRL + SHIFT + right" ''hl.dsp.focus({ workspace = "r+1" })'')
|
||||||
]
|
]
|
||||||
++ (
|
++ (
|
||||||
# workspaces
|
# workspaces
|
||||||
|
|
@ -156,8 +237,8 @@ let
|
||||||
ws = i + 1;
|
ws = i + 1;
|
||||||
in
|
in
|
||||||
[
|
[
|
||||||
"SUPER, code:1${toString i}, workspace, ${toString ws}"
|
(mkBind "SUPER + code:1${toString i}" "hl.dsp.focus({ workspace = ${toString ws} })")
|
||||||
"SUPER SHIFT, code:1${toString i}, movetoworkspace, ${toString ws}"
|
(mkBind "SUPER + SHIFT + code:1${toString i}" "hl.dsp.window.move({ workspace = ${toString ws} })")
|
||||||
]
|
]
|
||||||
) 9
|
) 9
|
||||||
)
|
)
|
||||||
|
|
@ -169,8 +250,16 @@ let
|
||||||
gaps_in = 4;
|
gaps_in = 4;
|
||||||
gaps_out = 7;
|
gaps_out = 7;
|
||||||
border_size = 3;
|
border_size = 3;
|
||||||
"col.active_border" = "rgba(6e848cee) rgba(eeeeffee) 90deg";
|
col = {
|
||||||
"col.inactive_border" = "rgba(595959aa)";
|
active_border = {
|
||||||
|
colors = [
|
||||||
|
"rgba(6e848cee)"
|
||||||
|
"rgba(eeeeffee)"
|
||||||
|
];
|
||||||
|
angle = 90;
|
||||||
|
};
|
||||||
|
inactive_border = "rgba(595959aa)";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
decoration = {
|
decoration = {
|
||||||
rounding = 10;
|
rounding = 10;
|
||||||
|
|
@ -195,18 +284,59 @@ let
|
||||||
animations = {
|
animations = {
|
||||||
enabled = true;
|
enabled = true;
|
||||||
animation = [
|
animation = [
|
||||||
"windowsIn, 1, 1, default, popin 90%"
|
{
|
||||||
"windowsOut, 1, 100, default, popin 80%"
|
leaf = "windowsIn";
|
||||||
"windowsMove, 1, 3, default"
|
enabled = true;
|
||||||
"border, 1, 10, default"
|
speed = 1;
|
||||||
"borderangle, 1, 8, default"
|
bezier = "default";
|
||||||
"fade, 1, 7, default"
|
style = "popin 90%";
|
||||||
"workspaces, 1, 5, default, slidefade 10%"
|
}
|
||||||
|
{
|
||||||
|
leaf = "windowsOut";
|
||||||
|
enabled = true;
|
||||||
|
speed = 100;
|
||||||
|
bezier = "default";
|
||||||
|
style = "popin 80%";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "windowsMove";
|
||||||
|
enabled = true;
|
||||||
|
speed = 3;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "border";
|
||||||
|
enabled = true;
|
||||||
|
speed = 10;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "borderangle";
|
||||||
|
enabled = true;
|
||||||
|
speed = 8;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "fade";
|
||||||
|
enabled = true;
|
||||||
|
speed = 7;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "workspaces";
|
||||||
|
enabled = true;
|
||||||
|
speed = 5;
|
||||||
|
bezier = "default";
|
||||||
|
style = "slidefade 10%";
|
||||||
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
styleSettings = recursiveUpdate defaultStyle config.hare.hyprland.style;
|
styleSettings = recursiveUpdate defaultStyle config.hare.hyprland.style;
|
||||||
|
styleConfig = recursiveUpdate (builtins.removeAttrs styleSettings [ "animations" ]) {
|
||||||
|
animations = builtins.removeAttrs styleSettings.animations [ "animation" ];
|
||||||
|
};
|
||||||
inputSettings = recursiveUpdate defaultInput config.hare.hyprland.input;
|
inputSettings = recursiveUpdate defaultInput config.hare.hyprland.input;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
@ -230,9 +360,13 @@ in
|
||||||
config = {
|
config = {
|
||||||
wayland.windowManager.hyprland = {
|
wayland.windowManager.hyprland = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
configType = "lua";
|
||||||
systemd.enable = false;
|
systemd.enable = false;
|
||||||
settings = recursiveUpdate (recursiveUpdate baseSettings styleSettings) {
|
settings = recursiveUpdate baseSettings {
|
||||||
input = inputSettings;
|
config = recursiveUpdate (recursiveUpdate baseConfig styleConfig) {
|
||||||
|
input = inputSettings;
|
||||||
|
};
|
||||||
|
animation = styleSettings.animations.animation;
|
||||||
};
|
};
|
||||||
plugins = [
|
plugins = [
|
||||||
];
|
];
|
||||||
|
|
|
||||||
|
|
@ -4,8 +4,16 @@
|
||||||
gaps_in = 0;
|
gaps_in = 0;
|
||||||
gaps_out = 0;
|
gaps_out = 0;
|
||||||
border_size = 2;
|
border_size = 2;
|
||||||
"col.active_border" = "rgba(6e848cee) rgba(eeeeffee) 90deg";
|
col = {
|
||||||
"col.inactive_border" = "rgba(595959aa)";
|
active_border = {
|
||||||
|
colors = [
|
||||||
|
"rgba(6e848cee)"
|
||||||
|
"rgba(eeeeffee)"
|
||||||
|
];
|
||||||
|
angle = 90;
|
||||||
|
};
|
||||||
|
inactive_border = "rgba(595959aa)";
|
||||||
|
};
|
||||||
layout = "dwindle";
|
layout = "dwindle";
|
||||||
allow_tearing = true;
|
allow_tearing = true;
|
||||||
};
|
};
|
||||||
|
|
@ -31,13 +39,51 @@
|
||||||
animations = lib.mkForce {
|
animations = lib.mkForce {
|
||||||
enabled = true;
|
enabled = true;
|
||||||
animation = [
|
animation = [
|
||||||
"windowsIn, 1, 1, default, popin 90%"
|
{
|
||||||
"windowsOut, 1, 100, default, popin 80%"
|
leaf = "windowsIn";
|
||||||
"windowsMove, 1, 3, default"
|
enabled = true;
|
||||||
"border, 1, 10, default"
|
speed = 1;
|
||||||
"borderangle, 1, 8, default"
|
bezier = "default";
|
||||||
"fade, 1, 7, default"
|
style = "popin 90%";
|
||||||
"workspaces, 1, 5, default, slidefade 10%"
|
}
|
||||||
|
{
|
||||||
|
leaf = "windowsOut";
|
||||||
|
enabled = true;
|
||||||
|
speed = 100;
|
||||||
|
bezier = "default";
|
||||||
|
style = "popin 80%";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "windowsMove";
|
||||||
|
enabled = true;
|
||||||
|
speed = 3;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "border";
|
||||||
|
enabled = true;
|
||||||
|
speed = 10;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "borderangle";
|
||||||
|
enabled = true;
|
||||||
|
speed = 8;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "fade";
|
||||||
|
enabled = true;
|
||||||
|
speed = 7;
|
||||||
|
bezier = "default";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
leaf = "workspaces";
|
||||||
|
enabled = true;
|
||||||
|
speed = 5;
|
||||||
|
bezier = "default";
|
||||||
|
style = "slidefade 10%";
|
||||||
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
home.stateVersion = "25.05";
|
home.stateVersion = "26.05";
|
||||||
imports = [
|
imports = [
|
||||||
inputs.nix-index-database.homeModules.nix-index
|
inputs.nix-index-database.homeModules.nix-index
|
||||||
../../../home-manager/tofi.nix
|
../../../home-manager/tofi.nix
|
||||||
|
|
@ -19,13 +19,30 @@
|
||||||
../../../home-manager/obs-studio.nix
|
../../../home-manager/obs-studio.nix
|
||||||
../../../home-manager/zeditor.nix
|
../../../home-manager/zeditor.nix
|
||||||
../../../home-manager/blender.nix
|
../../../home-manager/blender.nix
|
||||||
../../../home-manager/voicevox.nix
|
# ../../../home-manager/voicevox.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
wayland.windowManager.hyprland.settings.monitor = [
|
wayland.windowManager.hyprland.settings.monitor = [
|
||||||
"DP-1, 5120x2880@60, 0x0, 2"
|
{
|
||||||
"DP-2, 2560x1440@144, 2560x0, 1, transform, 0"
|
output = "DP-1";
|
||||||
"DP-3, 1920x1080@144, -1080x-240, 1, transform, 1"
|
mode = "5120x2880@60";
|
||||||
|
position = "0x0";
|
||||||
|
scale = 2;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
output = "DP-2";
|
||||||
|
mode = "2560x1440@144";
|
||||||
|
position = "2560x0";
|
||||||
|
scale = 1;
|
||||||
|
transform = 0;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
output = "DP-3";
|
||||||
|
mode = "1920x1080@144";
|
||||||
|
position = "-1080x-240";
|
||||||
|
scale = 1;
|
||||||
|
transform = 1;
|
||||||
|
}
|
||||||
];
|
];
|
||||||
hare.hyprland = {
|
hare.hyprland = {
|
||||||
input.sensitivity = -1.0;
|
input.sensitivity = -1.0;
|
||||||
|
|
@ -41,6 +58,7 @@
|
||||||
plemoljp
|
plemoljp
|
||||||
plemoljp-nf
|
plemoljp-nf
|
||||||
prismlauncher
|
prismlauncher
|
||||||
|
nodejs
|
||||||
scrcpy
|
scrcpy
|
||||||
tetrio-desktop
|
tetrio-desktop
|
||||||
kicad
|
kicad
|
||||||
|
|
@ -48,11 +66,9 @@
|
||||||
inkscape
|
inkscape
|
||||||
obsidian
|
obsidian
|
||||||
kdePackages.filelight
|
kdePackages.filelight
|
||||||
inputs.zen-browser.packages."${stdenv.hostPlatform.system}".default
|
|
||||||
(deno.overrideAttrs (oldAttrs: {
|
(deno.overrideAttrs (oldAttrs: {
|
||||||
doCheck = false;
|
doCheck = false;
|
||||||
}))
|
}))
|
||||||
nodejs_24
|
|
||||||
godot
|
godot
|
||||||
unityhub
|
unityhub
|
||||||
nixd
|
nixd
|
||||||
|
|
@ -61,7 +77,8 @@
|
||||||
bambu-studio
|
bambu-studio
|
||||||
orca-slicer
|
orca-slicer
|
||||||
davinci-resolve
|
davinci-resolve
|
||||||
antigravity
|
inputs.zen-browser.packages."${stdenv.hostPlatform.system}".default
|
||||||
|
inputs.insomnia.packages.${stdenv.hostPlatform.system}.default
|
||||||
];
|
];
|
||||||
services.easyeffects = {
|
services.easyeffects = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
@ -71,6 +88,11 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
settings.user.name = "Hare";
|
settings.user.name = "Hare";
|
||||||
settings.user.email = "kei.hiracchi.0928@gmail.com";
|
settings.user.email = "kei.hiracchi.0928@gmail.com";
|
||||||
|
signing = {
|
||||||
|
format = "ssh";
|
||||||
|
key = "~/.ssh/git-sign.pub";
|
||||||
|
signByDefault = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
fonts = {
|
fonts = {
|
||||||
|
|
@ -92,6 +114,7 @@
|
||||||
"x-scheme-handler/https" = "vivaldi-stable.desktop";
|
"x-scheme-handler/https" = "vivaldi-stable.desktop";
|
||||||
"x-scheme-handler/about" = "vivaldi-stable.desktop";
|
"x-scheme-handler/about" = "vivaldi-stable.desktop";
|
||||||
"x-scheme-handler/unknown" = "vivaldi-stable.desktop";
|
"x-scheme-handler/unknown" = "vivaldi-stable.desktop";
|
||||||
|
"x-scheme-handler/vivaldi" = "vivaldi-stable.desktop";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,9 +6,20 @@ in
|
||||||
system.stateVersion = "25.11";
|
system.stateVersion = "25.11";
|
||||||
|
|
||||||
cornflake.greeter.monitors = [
|
cornflake.greeter.monitors = [
|
||||||
"DP-1, 5120x2880@60, 0x0, 2"
|
{
|
||||||
"DP-2, disable"
|
output = "DP-1";
|
||||||
"DP-3, disable"
|
mode = "5120x2880@60";
|
||||||
|
position = "0x0";
|
||||||
|
scale = 2;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
output = "DP-2";
|
||||||
|
disabled = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
output = "DP-3";
|
||||||
|
disabled = true;
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
|
|
@ -54,6 +65,7 @@ in
|
||||||
obexftp
|
obexftp
|
||||||
fzf
|
fzf
|
||||||
ghq
|
ghq
|
||||||
|
gh
|
||||||
];
|
];
|
||||||
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
||||||
|
|
||||||
|
|
@ -69,8 +81,7 @@ in
|
||||||
5173
|
5173
|
||||||
8000
|
8000
|
||||||
9001
|
9001
|
||||||
2222 # crtb server
|
25565
|
||||||
11434
|
|
||||||
];
|
];
|
||||||
networking.firewall.allowedUDPPorts = [ ];
|
networking.firewall.allowedUDPPorts = [ ];
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
home.stateVersion = "25.05";
|
home.stateVersion = "26.05";
|
||||||
imports = [
|
imports = [
|
||||||
../../../home-manager/direnv.nix
|
../../../home-manager/direnv.nix
|
||||||
../../../home-manager/wezterm
|
../../../home-manager/wezterm
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
home.stateVersion = "25.05";
|
home.stateVersion = "26.05";
|
||||||
imports = [
|
imports = [
|
||||||
../../../home-manager/hyprland
|
../../../home-manager/hyprland
|
||||||
../../../home-manager/tofi.nix
|
../../../home-manager/tofi.nix
|
||||||
|
|
@ -18,11 +18,7 @@
|
||||||
hare.hyprland = {
|
hare.hyprland = {
|
||||||
style = import ../../../home-manager/hyprland/styles/thin.nix { inherit lib; };
|
style = import ../../../home-manager/hyprland/styles/thin.nix { inherit lib; };
|
||||||
input.sensitivity = -0.6;
|
input.sensitivity = -0.6;
|
||||||
<<<<<<< Updated upstream
|
|
||||||
wallpaperCommand = "awww img /usr/share/wallpaper/";
|
wallpaperCommand = "awww img /usr/share/wallpaper/";
|
||||||
=======
|
|
||||||
wallpaperCommand = "swww img /usr/share/wallpaper/001.png";
|
|
||||||
>>>>>>> Stashed changes
|
|
||||||
};
|
};
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
vivaldi
|
vivaldi
|
||||||
|
|
|
||||||
|
|
@ -5,4 +5,8 @@
|
||||||
dedicatedServer.openFirewall = true; # Open ports in the firewall for Source Dedicated Server
|
dedicatedServer.openFirewall = true; # Open ports in the firewall for Source Dedicated Server
|
||||||
localNetworkGameTransfers.openFirewall = true; # Open ports in the firewall for Steam Local Network Game Transfers
|
localNetworkGameTransfers.openFirewall = true; # Open ports in the firewall for Steam Local Network Game Transfers
|
||||||
};
|
};
|
||||||
|
|
||||||
|
programs.gamescope = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,39 +1,51 @@
|
||||||
{ config, lib, pkgs, ... }:
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
let
|
let
|
||||||
rosePineHyprcursor = pkgs.callPackage ../../home-manager/hyprland/rose-pine-hyprcursor.nix { };
|
rosePineHyprcursor = pkgs.callPackage ../../home-manager/hyprland/rose-pine-hyprcursor.nix { };
|
||||||
monitorConf = lib.concatMapStrings (m: "monitor = ${m}\n") config.cornflake.greeter.monitors;
|
toLua = lib.generators.toLua { };
|
||||||
hyprGreetConf = pkgs.writeText "hyprland-greetd.conf" ''
|
monitorConf = lib.concatMapStrings (
|
||||||
|
m: "hl.monitor(${toLua m})\n"
|
||||||
|
) config.cornflake.greeter.monitors;
|
||||||
|
hyprGreetConf = pkgs.writeText "hyprland-greetd.lua" ''
|
||||||
${monitorConf}
|
${monitorConf}
|
||||||
env = HYPRCURSOR_THEME,rose-pine-hyprcursor
|
hl.env("HYPRCURSOR_THEME", "rose-pine-hyprcursor")
|
||||||
env = HYPRCURSOR_SIZE,24
|
hl.env("HYPRCURSOR_SIZE", "24")
|
||||||
env = XCURSOR_SIZE,24
|
hl.env("XCURSOR_SIZE", "24")
|
||||||
|
|
||||||
env = XDG_CURRENT_DESKTOP,Hyprland
|
hl.env("XDG_CURRENT_DESKTOP", "Hyprland")
|
||||||
env = XDG_SESSION_TYPE,wayland
|
hl.env("XDG_SESSION_TYPE", "wayland")
|
||||||
env = XDG_SESSION_DESKTOP,Hyprland
|
hl.env("XDG_SESSION_DESKTOP", "Hyprland")
|
||||||
|
|
||||||
general {
|
hl.config({
|
||||||
border_size = 0
|
general = {
|
||||||
}
|
border_size = 0,
|
||||||
|
},
|
||||||
|
animations = {
|
||||||
|
enabled = false,
|
||||||
|
},
|
||||||
|
misc = {
|
||||||
|
force_default_wallpaper = false,
|
||||||
|
disable_hyprland_logo = true,
|
||||||
|
disable_splash_rendering = true,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
animations {
|
hl.on("hyprland.start", function()
|
||||||
enabled = false
|
hl.exec_cmd("${
|
||||||
}
|
config.programs.regreet.package or pkgs.regreet
|
||||||
|
}/bin/regreet; hyprctl dispatch exit")
|
||||||
misc {
|
end)
|
||||||
force_default_wallpaper = false
|
|
||||||
disable_hyprland_logo = true
|
|
||||||
disable_splash_rendering = true
|
|
||||||
}
|
|
||||||
|
|
||||||
exec-once = ${config.programs.regreet.package or pkgs.regreet}/bin/regreet; hyprctl dispatch exit
|
|
||||||
'';
|
'';
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.cornflake.greeter.monitors = lib.mkOption {
|
options.cornflake.greeter.monitors = lib.mkOption {
|
||||||
type = lib.types.listOf lib.types.str;
|
type = lib.types.listOf lib.types.attrs;
|
||||||
default = [ ];
|
default = [ ];
|
||||||
description = "greetd セッション用 Hyprland の monitor 設定";
|
description = "greetd セッション用 Hyprland の Lua monitor 設定";
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user