Compare commits
2 commits
1029f738b8
...
e5d1ba38d4
| Author | SHA1 | Date | |
|---|---|---|---|
| e5d1ba38d4 | |||
| 5b4944696e |
5 changed files with 13 additions and 76 deletions
|
|
@ -135,36 +135,31 @@ config.keys = {
|
|||
action = wezterm.action.SplitHorizontal({ domain = "CurrentPaneDomain" }),
|
||||
},
|
||||
|
||||
{ -- Dynamic pane management: Creates development layout or toggles focus between editor and terminal
|
||||
{ -- Dynamic pane management
|
||||
key = "`",
|
||||
mods = "LEADER",
|
||||
action = wezterm.action_callback(function(_, pane)
|
||||
local tab = pane:tab()
|
||||
local panes = tab:panes_with_info()
|
||||
|
||||
-- Case 1: Single pane - Create a 3-pane development layout
|
||||
if #panes == 1 then
|
||||
-- First split: Create bottom terminal pane (30% height)
|
||||
pane:split({
|
||||
direction = "Bottom",
|
||||
size = 0.30,
|
||||
})
|
||||
-- Second split: Create left sidebar for Claude Code (25% width)
|
||||
pane:split({
|
||||
direction = "Left",
|
||||
size = 0.25,
|
||||
args = { "claude" } -- Launch Claude Code in the sidebar
|
||||
size = 0.26,
|
||||
args = { "claude" }
|
||||
})
|
||||
|
||||
-- Case 2: Multiple panes exist, pane 2 (editor) is not zoomed - Focus and zoom editor
|
||||
elseif not panes[2].is_zoomed then
|
||||
panes[2].pane:activate() -- Switch to editor pane (typically Neovim)
|
||||
tab:set_zoomed(true) -- Zoom to hide other panes for focused editing
|
||||
panes[2].pane:activate()
|
||||
tab:set_zoomed(true)
|
||||
|
||||
-- Case 3: Pane 2 (editor) is currently zoomed - Unzoom and return to terminal
|
||||
elseif panes[2].is_zoomed then
|
||||
tab:set_zoomed(false) -- Restore multi-pane layout
|
||||
panes[3].pane:activate() -- Focus the terminal pane for quick commands
|
||||
tab:set_zoomed(false)
|
||||
panes[3].pane:activate()
|
||||
end
|
||||
end),
|
||||
},
|
||||
|
|
|
|||
|
|
@ -3,7 +3,6 @@
|
|||
./amdgpu-clocks
|
||||
./flatpak
|
||||
./libinput
|
||||
./ollama
|
||||
./pipewire
|
||||
./printing
|
||||
./udev
|
||||
|
|
|
|||
|
|
@ -1,50 +0,0 @@
|
|||
{...}: {
|
||||
# Get up and running with large language models locally.
|
||||
services.ollama = {
|
||||
enable = true;
|
||||
|
||||
# User and group under which to run ollama
|
||||
user = "ollama";
|
||||
group = "ollama";
|
||||
|
||||
# AMD GPU Support
|
||||
acceleration = "rocm";
|
||||
# 5700xt Support
|
||||
rocmOverrideGfx = "10.1.0";
|
||||
|
||||
# Language models to install
|
||||
loadModels = [
|
||||
"deepseek-r1:8b"
|
||||
"gemma3:4b"
|
||||
"qwen3:8b"
|
||||
"llama3:8b"
|
||||
|
||||
# Coding models
|
||||
"qwen2.5-coder:7b"
|
||||
];
|
||||
|
||||
# Location to store models
|
||||
models = "/srv/ollama/models";
|
||||
|
||||
# Increase context window
|
||||
environmentVariables = {
|
||||
OLLAMA_CONTEXT_LENGTH = "8192";
|
||||
};
|
||||
};
|
||||
|
||||
# Enable the Open-WebUI server
|
||||
services.open-webui = {
|
||||
enable = true;
|
||||
host = "fuchsia.home.arpa";
|
||||
openFirewall = true;
|
||||
};
|
||||
|
||||
# Mount our subvolume for storage of models
|
||||
fileSystems = {
|
||||
"/srv/ollama" = {
|
||||
device = "/dev/disk/by-label/data";
|
||||
fsType = "btrfs";
|
||||
options = ["subvol=srv-ollama" "compress=zstd"];
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
@ -7,13 +7,5 @@
|
|||
];
|
||||
service = "api@internal";
|
||||
};
|
||||
|
||||
open-webui = {
|
||||
rule = "Host(`ollama.home.arpa`)";
|
||||
entryPoints = [
|
||||
"websecure"
|
||||
];
|
||||
service = "open-webui";
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,7 +1,8 @@
|
|||
{...}: {
|
||||
services.traefik.dynamicConfigOptions.http.services = {
|
||||
open-webui.loadBalancer.servers = [
|
||||
{url = "http://fuchsia.home.arpa:8080";}
|
||||
];
|
||||
};
|
||||
# # Example
|
||||
# services.traefik.dynamicConfigOptions.http.services = {
|
||||
# open-webui.loadBalancer.servers = [
|
||||
# {url = "http://fuchsia.home.arpa:8080";}
|
||||
# ];
|
||||
# };
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue