From b58787cfec0bd07abc316c66dc9be6c10b8113c6 Mon Sep 17 00:00:00 2001 From: Claude Agent Date: Wed, 25 Mar 2026 05:17:35 +0000 Subject: feat: add Claudomator stories as atom source in Doot tasks tab Co-Authored-By: Claude Sonnet 4.6 --- internal/handlers/atoms.go | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) (limited to 'internal/handlers/atoms.go') diff --git a/internal/handlers/atoms.go b/internal/handlers/atoms.go index e99c879..6086a5b 100644 --- a/internal/handlers/atoms.go +++ b/internal/handlers/atoms.go @@ -1,15 +1,17 @@ package handlers import ( + "context" "log" "sort" + "task-dashboard/internal/api" "task-dashboard/internal/models" "task-dashboard/internal/store" ) // BuildUnifiedAtomList creates a list of atoms from tasks, cards, and google tasks -func BuildUnifiedAtomList(s *store.Store) ([]models.Atom, []models.Board, error) { +func BuildUnifiedAtomList(s *store.Store, claudomator api.ClaudomatorClient) ([]models.Atom, []models.Board, error) { tasks, err := s.GetTasks() if err != nil { return nil, nil, err @@ -51,6 +53,17 @@ func BuildUnifiedAtomList(s *store.Store) ([]models.Atom, []models.Board, error) } } + if claudomator != nil { + stories, err := claudomator.GetActiveStories(context.Background()) + if err != nil { + log.Printf("Warning: failed to fetch Claudomator stories: %v", err) + } else { + for _, s := range stories { + atoms = append(atoms, models.StoryToAtom(s)) + } + } + } + // Compute UI fields for all atoms for i := range atoms { atoms[i].ComputeUIFields() -- cgit v1.2.3