mika kuns
1a10e6fa09
feat(worker): expose RestoreDefaultAgents hub method
2026-04-23 12:18:49 +02:00
mika kuns
df57c2bc05
feat(worker): seed default agents on startup
2026-04-23 12:15:28 +02:00
mika kuns
990be09bd7
feat(worker): add DefaultAgentSeeder for first-launch agent seeding
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-23 12:12:55 +02:00
mika kuns
e275f67a5e
build(worker): ship DefaultAgents folder in build output
2026-04-23 12:09:13 +02:00
mika kuns
ff3de1d100
feat(worker): add bundled default agent definitions
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-23 12:08:16 +02:00
Mika Kuns
a4e313dbad
improve Frontend
2026-04-22 17:09:00 +02:00
Mika Kuns
7de5510735
fix(ui): session terminal scrolls to end after layout so last line is fully visible
2026-04-22 15:42:02 +02:00
Mika Kuns
5e54275842
fix(ui): pin AgentStrip above metadata footer, terminal sits above it
2026-04-22 15:38:34 +02:00
Mika Kuns
6ac88235a7
fix(ui): session terminal auto-sizes to output, caps at 420px before scrolling
2026-04-22 15:34:47 +02:00
Mika Kuns
c599fdcb8c
refactor(ui): single scrollable DetailsIsland body with agent-settings gear flyout, remove Notes
2026-04-22 15:16:40 +02:00
Mika Kuns
b0b15e474e
feat(ui): always-visible Steps section at top of DetailsIsland with add-step input
2026-04-22 15:08:07 +02:00
Mika Kuns
839f862b7d
fix(ui): move agent-settings expander out of capped scroller so it expands properly
2026-04-22 13:50:35 +02:00
Mika Kuns
2901a769d8
fix(ui): use PlaceholderText instead of obsolete Watermark in ListSettingsModalView
2026-04-22 13:33:49 +02:00
Mika Kuns
e74e7eecf4
docs: refresh CLAUDE.md files for agent settings UI
2026-04-22 13:31:28 +02:00
Mika Kuns
bba577888b
feat(ui): per-task agent settings in DetailsIsland
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 13:29:57 +02:00
Mika Kuns
5784dbee94
feat(ui): open ListSettingsModal via context menu and gear button
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 13:27:05 +02:00
Mika Kuns
5348220e60
feat(ui): add ListSettingsModalView
2026-04-22 13:22:39 +02:00
Mika Kuns
cd0b95ef9a
feat(ui): add ListSettingsModalViewModel
2026-04-22 13:20:42 +02:00
Mika Kuns
fc1cfe59ec
feat(ui): WorkerClient supports list/task agent settings + ListUpdated event
2026-04-22 13:18:16 +02:00
Mika Kuns
7c312161bb
feat(worker): add hub methods for list and task agent settings
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 13:16:46 +02:00
Mika Kuns
480eb0817a
feat(data): add TaskRepository.UpdateAgentSettingsAsync
2026-04-22 13:10:21 +02:00
Mika Kuns
1b94fa5c44
feat(data): add ListRepository.DeleteConfigAsync
2026-04-22 13:09:03 +02:00
Mika Kuns
02464b7f89
docs(plans): agent settings UI implementation plan
2026-04-22 12:06:31 +02:00
Mika Kuns
68f461d0e1
docs(specs): agent settings per list and per task UI reimplementation
2026-04-22 12:01:20 +02:00
Mika Kuns
cfb410dd4d
Merge task: Improve the Readme
2026-04-22 11:34:13 +02:00
Mika Kuns
b378fbf550
chore(settings): allow context-mode MCP tools locally
2026-04-22 11:03:43 +02:00
Mika Kuns
cb43bcdd10
docs(plans): add 2026-04-21 open-items consolidation
2026-04-22 11:03:40 +02:00
Mika Kuns
31420574db
feat(ui): show status messages and real diff-stats in DiffModal
...
- Count additions/deletions per file as lines are parsed.
- Surface load failures and empty-diff states via StatusMessage.
- Pass the worktree base commit so diffs render against the branch
base, not just the working-tree HEAD.
2026-04-22 11:03:37 +02:00
Mika Kuns
07dee31847
fix(data): use UTF-8 encoding for git process stdio
...
Ensures non-ASCII git output (branch names, paths, commit messages) is
read and written without locale-dependent corruption.
2026-04-22 11:03:24 +02:00
Mika Kuns
4debd5ce09
fix(ui): disable Merge button after worktree is no longer Active
...
Add WorktreeStateLabel observable property populated from
entity.Worktree?.State.ToString() in both BindAsync and
RefreshWorktreeAsync. CanMerge now requires WorktreeStateLabel == "Active"
so the button disables after a successful merge with removeWorktree:false.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 10:36:09 +02:00
Mika Kuns
1495c63e3d
fix(worker): return Blocked when MergeAbortAsync fails to avoid stuck repo
...
If git merge --abort throws, the repo is left mid-merge. Previously the
code logged a warning and returned a conflict result, giving the UI a
stale file list. Now it returns Blocked with an explicit message so the
caller knows manual resolution is required.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 10:30:44 +02:00
Mika Kuns
953d93179d
fix(worker): honour targetBranch in MergeAsync by checking out before merge
...
Add GitService.CheckoutBranchAsync; compare targetBranch to current HEAD
before MergeNoFfAsync and switch when they differ. Returns Blocked if the
branch does not exist. Add three new tests (two service, one GitService).
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-22 10:25:35 +02:00
Mika Kuns
1bc7fcc609
feat(ui): add Merge button to DiffModal
2026-04-22 09:53:11 +02:00
Mika Kuns
c911717a3b
feat(ui): add Merge command to DiffModal
2026-04-22 09:53:07 +02:00
Mika Kuns
949911f6c8
feat(ui): attach MergeModal to DetailsIsland
2026-04-22 09:53:03 +02:00
Mika Kuns
f3a58a6515
feat(ui): wire DetailsIsland ApproveMerge through MergeModal
2026-04-22 09:52:59 +02:00
Mika Kuns
ee4cd706ef
chore(app): register MergeModalViewModel
2026-04-22 09:47:19 +02:00
Mika Kuns
e11b01951e
feat(ui): add MergeModalView
2026-04-22 09:46:33 +02:00
Mika Kuns
3d0cc4ffed
feat(ui): add MergeModalViewModel
2026-04-22 09:46:20 +02:00
Mika Kuns
4585b20f80
feat(ui): add MergeTaskAsync and GetMergeTargetsAsync to WorkerClient
2026-04-22 09:44:48 +02:00
Mika Kuns
c53b5878cf
feat(worker): expose MergeTask and GetMergeTargets on WorkerHub
2026-04-22 09:44:22 +02:00
Mika Kuns
c13ae437f7
chore(worker): register TaskMergeService
2026-04-22 09:43:34 +02:00
Mika Kuns
5780879629
test(worker): cover GetTargetsAsync and dirty-tree block
2026-04-22 09:41:31 +02:00
Mika Kuns
2bcd5ef9bd
test(worker): cover merge conflict auto-abort
2026-04-22 09:41:31 +02:00
Mika Kuns
63eb860e40
test(worker): cover diverged non-conflicting merge
2026-04-22 09:41:30 +02:00
Mika Kuns
e80ac7de49
test(worker): cover TaskMergeService removeWorktree path
2026-04-22 09:41:30 +02:00
Mika Kuns
3331c24898
feat(worker): implement TaskMergeService happy path
2026-04-22 09:37:35 +02:00
Mika Kuns
1c20d8f846
feat(worker): scaffold TaskMergeService with pre-flight checks
2026-04-22 09:36:16 +02:00
Mika Kuns
77a1460e3a
feat(git): add ListConflictedFilesAsync
2026-04-22 09:31:36 +02:00
Mika Kuns
21a1870fd7
feat(git): add MergeAbortAsync
2026-04-22 09:29:24 +02:00