agent-scope 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/README.md +128 -205
  2. package/dist/cli.js +58 -26
  3. package/dist/cli.js.map +1 -1
  4. package/dist/core/logParser.js +9 -2
  5. package/dist/core/logParser.js.map +1 -1
  6. package/dist/core/queueParser.d.ts +8 -1
  7. package/dist/core/queueParser.d.ts.map +1 -1
  8. package/dist/core/queueParser.js +67 -6
  9. package/dist/core/queueParser.js.map +1 -1
  10. package/dist/core/stateEngine.js +5 -1
  11. package/dist/core/stateEngine.js.map +1 -1
  12. package/dist/core/todoReader.d.ts +11 -0
  13. package/dist/core/todoReader.d.ts.map +1 -0
  14. package/dist/core/todoReader.js +120 -0
  15. package/dist/core/todoReader.js.map +1 -0
  16. package/dist/core/types.d.ts +18 -1
  17. package/dist/core/types.d.ts.map +1 -1
  18. package/dist/public/404/index.html +1 -1
  19. package/dist/public/404.html +1 -1
  20. package/dist/public/_next/static/EjG9asgaOWf0-7fNJq_Sd/_buildManifest.js +1 -0
  21. package/dist/public/_next/static/chunks/46-3b308c2fb194eb7d.js +1 -0
  22. package/dist/public/_next/static/chunks/app/page-525816f75fc4208f.js +1 -0
  23. package/dist/public/_next/static/chunks/main-bfc57b0f3d63ff2c.js +1 -0
  24. package/dist/public/_next/static/css/9056dd3cc8c03e80.css +5 -0
  25. package/dist/public/index.html +1 -1
  26. package/dist/public/index.txt +2 -2
  27. package/dist/server/server.d.ts +6 -1
  28. package/dist/server/server.d.ts.map +1 -1
  29. package/dist/server/server.js +111 -32
  30. package/dist/server/server.js.map +1 -1
  31. package/dist/server/watcher.d.ts +19 -0
  32. package/dist/server/watcher.d.ts.map +1 -0
  33. package/dist/server/watcher.js +76 -0
  34. package/dist/server/watcher.js.map +1 -0
  35. package/package.json +3 -2
  36. package/dist/public/_next/static/chunks/app/page-72fc8cefe60ad1d7.js +0 -1
  37. package/dist/public/_next/static/chunks/main-7be9b0d6fba5e000.js +0 -1
  38. package/dist/public/_next/static/css/14aedabfb1f06bdb.css +0 -3
  39. package/dist/public/_next/static/uP1Ux3UC4o-JCDXNPB44Y/_buildManifest.js +0 -1
  40. /package/dist/public/_next/static/{uP1Ux3UC4o-JCDXNPB44Y → EjG9asgaOWf0-7fNJq_Sd}/_ssgManifest.js +0 -0
  41. /package/dist/public/_next/static/chunks/{117-373243894bd7fac6.js → 117-c710cb30aa7ed4f8.js} +0 -0
  42. /package/dist/public/_next/static/chunks/app/_not-found/{page-4b9eb8aab41bf6df.js → page-c8219ab21dbb5ed7.js} +0 -0
  43. /package/dist/public/_next/static/chunks/{fd9d1056-9f91b5e418130764.js → fd9d1056-9e191f0896c1d560.js} +0 -0
@@ -0,0 +1,5 @@
1
+ @import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap");*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
2
+
3
+ /*
4
+ ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
5
+ */*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--font-size:16px;--background:#fff;--foreground:#0a0a0a;--card:#fff;--card-foreground:#0a0a0a;--popover:#fff;--popover-foreground:#0a0a0a;--primary:#030213;--primary-foreground:#fff;--secondary:#f0f0f3;--secondary-foreground:#030213;--muted:#ececf0;--muted-foreground:#717182;--accent:#e9ebef;--accent-foreground:#030213;--destructive:#d4183d;--destructive-foreground:#fff;--border:rgba(0,0,0,.1);--input:transparent;--input-background:#f3f3f5;--ring:#b0b0b0;--radius:0.625rem;--chart-1:#e06030;--chart-2:#2aa08a;--chart-3:#3a6080;--chart-4:#d0a030;--chart-5:#c09030;--sidebar:#f8f8f8;--sidebar-foreground:#0a0a0a;--sidebar-primary:#030213;--sidebar-primary-foreground:#f8f8f8;--sidebar-accent:#f0f0f0;--sidebar-accent-foreground:#1a1a1a;--sidebar-border:#e0e0e0;--sidebar-ring:#b0b0b0}.dark{--background:#1a1a1a;--foreground:#f5f5f5;--card:#1a1a1a;--card-foreground:#f5f5f5;--popover:#1a1a1a;--popover-foreground:#f5f5f5;--primary:#f5f5f5;--primary-foreground:#1a1a1a;--secondary:#2a2a2a;--secondary-foreground:#f5f5f5;--muted:#2a2a2a;--muted-foreground:#a0a0a0;--accent:#2a2a2a;--accent-foreground:#f5f5f5;--destructive:#7f1d1d;--destructive-foreground:#ef4444;--border:#2a2a2a;--input:#2a2a2a;--ring:#555;--chart-1:#3b82f6;--chart-2:#22c55e;--chart-3:#f59e0b;--chart-4:#a855f7;--chart-5:#ef4444;--sidebar:#1e1e1e;--sidebar-foreground:#f5f5f5;--sidebar-primary:#3b82f6;--sidebar-primary-foreground:#f5f5f5;--sidebar-accent:#2a2a2a;--sidebar-accent-foreground:#f5f5f5;--sidebar-border:#2a2a2a;--sidebar-ring:#555}*{border-color:var(--border)}html{font-size:var(--font-size)}body{font-family:JetBrains Mono,monospace;color:var(--foreground);background:var(--background);font-feature-settings:"rlig" 1,"calt" 1}.absolute{position:absolute}.relative{position:relative}.left-3{left:.75rem}.top-1\/2{top:50%}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.size-12{width:3rem;height:3rem}.size-2{width:.5rem;height:.5rem}.size-2\.5{width:.625rem;height:.625rem}.size-3{width:.75rem;height:.75rem}.size-3\.5{width:.875rem;height:.875rem}.size-4{width:1rem;height:1rem}.size-full{width:100%;height:100%}.h-1\.5{height:.375rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-full{height:100%}.h-screen{height:100vh}.w-1\/2{width:50%}.w-2\.5{width:.625rem}.w-48{width:12rem}.w-\[220px\]{width:220px}.w-\[25\%\]{width:25%}.w-\[350px\]{width:350px}.w-full{width:100%}.min-w-0{min-width:0}.min-w-\[250px\]{min-width:250px}.min-w-\[280px\]{min-width:280px}.max-w-4xl{max-width:56rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.\!overflow-y-auto{overflow-y:auto!important}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-border{border-color:var(--border)}.border-destructive{border-color:var(--destructive)}.border-ring{border-color:var(--ring)}.border-sidebar-border{border-color:var(--sidebar-border)}.border-transparent{border-color:transparent}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-accent{background-color:var(--accent)}.bg-background{background-color:var(--background)}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-chart-1{background-color:var(--chart-1)}.bg-chart-2{background-color:var(--chart-2)}.bg-chart-3{background-color:var(--chart-3)}.bg-chart-4{background-color:var(--chart-4)}.bg-chart-5{background-color:var(--chart-5)}.bg-muted{background-color:var(--muted)}.bg-muted-foreground{background-color:var(--muted-foreground)}.bg-sidebar{background-color:var(--sidebar)}.p-0\.5{padding:.125rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-px{padding:1px}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-3{padding-right:.75rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.tracking-wide{letter-spacing:.025em}.text-chart-1{color:var(--chart-1)}.text-chart-2{color:var(--chart-2)}.text-chart-3{color:var(--chart-3)}.text-chart-4{color:var(--chart-4)}.text-chart-5{color:var(--chart-5)}.text-destructive-foreground{color:var(--destructive-foreground)}.text-foreground{color:var(--foreground)}.text-muted-foreground{color:var(--muted-foreground)}.placeholder-muted-foreground::-moz-placeholder{color:var(--muted-foreground)}.placeholder-muted-foreground::placeholder{color:var(--muted-foreground)}.opacity-75{opacity:.75}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-\[color\2c box-shadow\]{transition-property:color,box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--sidebar)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-sidebar-accent:hover{background-color:var(--sidebar-accent)}.hover\:text-foreground:hover{color:var(--foreground)}.focus\:border-ring:focus{border-color:var(--ring)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus-visible\:outline-1:focus-visible{outline-width:1px}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.\[\&\>div\]\:\!block>div{display:block!important}
@@ -1 +1 @@
1
- <!DOCTYPE html><html lang="en" class="dark"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="/_next/static/css/14aedabfb1f06bdb.css" data-precedence="next"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/webpack-8658fdbc42bfbbae.js"/><script src="/_next/static/chunks/fd9d1056-9f91b5e418130764.js" async=""></script><script src="/_next/static/chunks/117-373243894bd7fac6.js" async=""></script><script src="/_next/static/chunks/main-app-feb0e3b0cc6fb4c7.js" async=""></script><script src="/_next/static/chunks/app/page-72fc8cefe60ad1d7.js" async=""></script><title>agent-scope</title><meta name="description" content="Execution observer for AI agent workflows"/><script src="/_next/static/chunks/polyfills-42372ed130431b0a.js" noModule=""></script></head><body><div class="min-h-screen bg-gray-950 flex items-center justify-center"><div class="text-gray-400">Loading...</div></div><script src="/_next/static/chunks/webpack-8658fdbc42bfbbae.js" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0]);self.__next_f.push([2,null])</script><script>self.__next_f.push([1,"1:HL[\"/_next/static/css/14aedabfb1f06bdb.css\",\"style\"]\n"])</script><script>self.__next_f.push([1,"2:I[2846,[],\"\"]\n4:I[9107,[],\"ClientPageRoot\"]\n5:I[6117,[\"931\",\"static/chunks/app/page-72fc8cefe60ad1d7.js\"],\"default\",1]\n6:I[4707,[],\"\"]\n7:I[6423,[],\"\"]\n9:I[1060,[],\"\"]\na:[]\n0:[\"$\",\"$L2\",null,{\"buildId\":\"uP1Ux3UC4o-JCDXNPB44Y\",\"assetPrefix\":\"\",\"urlParts\":[\"\",\"\"],\"initialTree\":[\"\",{\"children\":[\"__PAGE__\",{}]},\"$undefined\",\"$undefined\",true],\"initialSeedData\":[\"\",{\"children\":[\"__PAGE__\",{},[[\"$L3\",[\"$\",\"$L4\",null,{\"props\":{\"params\":{},\"searchParams\":{}},\"Component\":\"$5\"}],null],null],null]},[[[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/css/14aedabfb1f06bdb.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"className\":\"dark\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L6\",null,{\"parallelRouterKey\":\"children\",\"segmentPath\":[\"children\"],\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L7\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":\"404\"}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"children\":\"This page could not be found.\"}]}]]"])</script><script>self.__next_f.push([1,"}]}]],\"notFoundStyles\":[]}]}]}]],null],null],\"couldBeIntercepted\":false,\"initialHead\":[null,\"$L8\"],\"globalErrorComponent\":\"$9\",\"missingSlots\":\"$Wa\"}]\n"])</script><script>self.__next_f.push([1,"8:[[\"$\",\"meta\",\"0\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}],[\"$\",\"meta\",\"1\",{\"charSet\":\"utf-8\"}],[\"$\",\"title\",\"2\",{\"children\":\"agent-scope\"}],[\"$\",\"meta\",\"3\",{\"name\":\"description\",\"content\":\"Execution observer for AI agent workflows\"}]]\n3:null\n"])</script></body></html>
1
+ <!DOCTYPE html><html lang="en" class="dark"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="/_next/static/css/9056dd3cc8c03e80.css" data-precedence="next"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/webpack-8658fdbc42bfbbae.js"/><script src="/_next/static/chunks/fd9d1056-9e191f0896c1d560.js" async=""></script><script src="/_next/static/chunks/117-c710cb30aa7ed4f8.js" async=""></script><script src="/_next/static/chunks/main-app-feb0e3b0cc6fb4c7.js" async=""></script><script src="/_next/static/chunks/46-3b308c2fb194eb7d.js" async=""></script><script src="/_next/static/chunks/app/page-525816f75fc4208f.js" async=""></script><title>agent-scope</title><meta name="description" content="Execution observer for AI agent workflows"/><script src="/_next/static/chunks/polyfills-42372ed130431b0a.js" noModule=""></script></head><body><div class="h-screen bg-background flex items-center justify-center"><div class="text-muted-foreground">Loading...</div></div><script src="/_next/static/chunks/webpack-8658fdbc42bfbbae.js" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0]);self.__next_f.push([2,null])</script><script>self.__next_f.push([1,"1:HL[\"/_next/static/css/9056dd3cc8c03e80.css\",\"style\"]\n"])</script><script>self.__next_f.push([1,"2:I[2846,[],\"\"]\n4:I[9107,[],\"ClientPageRoot\"]\n5:I[8205,[\"46\",\"static/chunks/46-3b308c2fb194eb7d.js\",\"931\",\"static/chunks/app/page-525816f75fc4208f.js\"],\"default\",1]\n6:I[4707,[],\"\"]\n7:I[6423,[],\"\"]\n9:I[1060,[],\"\"]\na:[]\n0:[\"$\",\"$L2\",null,{\"buildId\":\"EjG9asgaOWf0-7fNJq_Sd\",\"assetPrefix\":\"\",\"urlParts\":[\"\",\"\"],\"initialTree\":[\"\",{\"children\":[\"__PAGE__\",{}]},\"$undefined\",\"$undefined\",true],\"initialSeedData\":[\"\",{\"children\":[\"__PAGE__\",{},[[\"$L3\",[\"$\",\"$L4\",null,{\"props\":{\"params\":{},\"searchParams\":{}},\"Component\":\"$5\"}],null],null],null]},[[[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/css/9056dd3cc8c03e80.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"className\":\"dark\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L6\",null,{\"parallelRouterKey\":\"children\",\"segmentPath\":[\"children\"],\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L7\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":\"404\"}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"ch"])</script><script>self.__next_f.push([1,"ildren\":\"This page could not be found.\"}]}]]}]}]],\"notFoundStyles\":[]}]}]}]],null],null],\"couldBeIntercepted\":false,\"initialHead\":[null,\"$L8\"],\"globalErrorComponent\":\"$9\",\"missingSlots\":\"$Wa\"}]\n"])</script><script>self.__next_f.push([1,"8:[[\"$\",\"meta\",\"0\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}],[\"$\",\"meta\",\"1\",{\"charSet\":\"utf-8\"}],[\"$\",\"title\",\"2\",{\"children\":\"agent-scope\"}],[\"$\",\"meta\",\"3\",{\"name\":\"description\",\"content\":\"Execution observer for AI agent workflows\"}]]\n3:null\n"])</script></body></html>
@@ -1,7 +1,7 @@
1
1
  2:I[9107,[],"ClientPageRoot"]
2
- 3:I[6117,["931","static/chunks/app/page-72fc8cefe60ad1d7.js"],"default",1]
2
+ 3:I[8205,["46","static/chunks/46-3b308c2fb194eb7d.js","931","static/chunks/app/page-525816f75fc4208f.js"],"default",1]
3
3
  4:I[4707,[],""]
4
4
  5:I[6423,[],""]
5
- 0:["uP1Ux3UC4o-JCDXNPB44Y",[[["",{"children":["__PAGE__",{}]},"$undefined","$undefined",true],["",{"children":["__PAGE__",{},[["$L1",["$","$L2",null,{"props":{"params":{},"searchParams":{}},"Component":"$3"}],null],null],null]},[[[["$","link","0",{"rel":"stylesheet","href":"/_next/static/css/14aedabfb1f06bdb.css","precedence":"next","crossOrigin":"$undefined"}]],["$","html",null,{"lang":"en","className":"dark","children":["$","body",null,{"children":["$","$L4",null,{"parallelRouterKey":"children","segmentPath":["children"],"error":"$undefined","errorStyles":"$undefined","errorScripts":"$undefined","template":["$","$L5",null,{}],"templateStyles":"$undefined","templateScripts":"$undefined","notFound":[["$","title",null,{"children":"404: This page could not be found."}],["$","div",null,{"style":{"fontFamily":"system-ui,\"Segoe UI\",Roboto,Helvetica,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\"","height":"100vh","textAlign":"center","display":"flex","flexDirection":"column","alignItems":"center","justifyContent":"center"},"children":["$","div",null,{"children":[["$","style",null,{"dangerouslySetInnerHTML":{"__html":"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}"}}],["$","h1",null,{"className":"next-error-h1","style":{"display":"inline-block","margin":"0 20px 0 0","padding":"0 23px 0 0","fontSize":24,"fontWeight":500,"verticalAlign":"top","lineHeight":"49px"},"children":"404"}],["$","div",null,{"style":{"display":"inline-block"},"children":["$","h2",null,{"style":{"fontSize":14,"fontWeight":400,"lineHeight":"49px","margin":0},"children":"This page could not be found."}]}]]}]}]],"notFoundStyles":[]}]}]}]],null],null],["$L6",null]]]]
5
+ 0:["EjG9asgaOWf0-7fNJq_Sd",[[["",{"children":["__PAGE__",{}]},"$undefined","$undefined",true],["",{"children":["__PAGE__",{},[["$L1",["$","$L2",null,{"props":{"params":{},"searchParams":{}},"Component":"$3"}],null],null],null]},[[[["$","link","0",{"rel":"stylesheet","href":"/_next/static/css/9056dd3cc8c03e80.css","precedence":"next","crossOrigin":"$undefined"}]],["$","html",null,{"lang":"en","className":"dark","children":["$","body",null,{"children":["$","$L4",null,{"parallelRouterKey":"children","segmentPath":["children"],"error":"$undefined","errorStyles":"$undefined","errorScripts":"$undefined","template":["$","$L5",null,{}],"templateStyles":"$undefined","templateScripts":"$undefined","notFound":[["$","title",null,{"children":"404: This page could not be found."}],["$","div",null,{"style":{"fontFamily":"system-ui,\"Segoe UI\",Roboto,Helvetica,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\"","height":"100vh","textAlign":"center","display":"flex","flexDirection":"column","alignItems":"center","justifyContent":"center"},"children":["$","div",null,{"children":[["$","style",null,{"dangerouslySetInnerHTML":{"__html":"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}"}}],["$","h1",null,{"className":"next-error-h1","style":{"display":"inline-block","margin":"0 20px 0 0","padding":"0 23px 0 0","fontSize":24,"fontWeight":500,"verticalAlign":"top","lineHeight":"49px"},"children":"404"}],["$","div",null,{"style":{"display":"inline-block"},"children":["$","h2",null,{"style":{"fontSize":14,"fontWeight":400,"lineHeight":"49px","margin":0},"children":"This page could not be found."}]}]]}]}]],"notFoundStyles":[]}]}]}]],null],null],["$L6",null]]]]
6
6
  6:[["$","meta","0",{"name":"viewport","content":"width=device-width, initial-scale=1"}],["$","meta","1",{"charSet":"utf-8"}],["$","title","2",{"children":"agent-scope"}],["$","meta","3",{"name":"description","content":"Execution observer for AI agent workflows"}]]
7
7
  1:null
@@ -1,2 +1,7 @@
1
- export declare function startServer(agentScopeDir: string, port?: number): Promise<void>;
1
+ export interface ServerOptions {
2
+ agentScopeDir?: string;
3
+ claudeDir: string;
4
+ port: number;
5
+ }
6
+ export declare function startServer(options: ServerOptions): Promise<void>;
2
7
  //# sourceMappingURL=server.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"AAcA,wBAAsB,WAAW,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,GAAE,MAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAoG3F"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,aAAa;IAC5B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,wBAAsB,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAkMvE"}
@@ -7,61 +7,129 @@ import { fileURLToPath } from 'url';
7
7
  import { parseQueue } from '../core/queueParser.js';
8
8
  import { parseLog } from '../core/logParser.js';
9
9
  import { computeSnapshot } from '../core/stateEngine.js';
10
+ import { readSessions } from '../core/todoReader.js';
11
+ import { createWatcher } from './watcher.js';
10
12
  const __filename = fileURLToPath(import.meta.url);
11
13
  const __dirname = dirname(__filename);
12
- export async function startServer(agentScopeDir, port = 4317) {
14
+ export async function startServer(options) {
15
+ const { claudeDir, port, agentScopeDir } = options;
13
16
  const fastify = Fastify({
14
- logger: false
17
+ logger: false,
18
+ ignoreTrailingSlash: true
15
19
  });
16
20
  // Enable CORS
17
21
  await fastify.register(cors, {
18
22
  origin: true
19
23
  });
20
- // Serve static files (dashboard UI)
21
- const publicPath = join(__dirname, '../public');
22
- if (existsSync(publicPath)) {
23
- await fastify.register(staticPlugin, {
24
- root: publicPath,
25
- prefix: '/'
26
- });
27
- }
24
+ // Setup file watcher
25
+ const { watcher, emitter } = createWatcher({
26
+ claudeDir,
27
+ agentScopeDir
28
+ });
29
+ // Track SSE clients
30
+ const sseClients = new Set();
31
+ emitter.on('change', (event) => {
32
+ for (const send of sseClients) {
33
+ send(event);
34
+ }
35
+ });
36
+ // Cleanup on server close
37
+ fastify.addHook('onClose', async () => {
38
+ await watcher.close();
39
+ });
28
40
  // Health check endpoint
29
41
  fastify.get('/health', async () => {
30
- return { status: 'ok' };
42
+ const hasLive = existsSync(join(claudeDir, 'tasks'));
43
+ const hasPlan = agentScopeDir ? existsSync(join(agentScopeDir, 'queue.md')) : false;
44
+ return { status: 'ok', modes: { live: hasLive, plan: hasPlan } };
45
+ });
46
+ // SSE endpoint for real-time updates
47
+ fastify.get('/events', async (_request, reply) => {
48
+ reply.raw.writeHead(200, {
49
+ 'Content-Type': 'text/event-stream',
50
+ 'Cache-Control': 'no-cache',
51
+ 'Connection': 'keep-alive',
52
+ 'Access-Control-Allow-Origin': '*'
53
+ });
54
+ // Send initial connection event
55
+ reply.raw.write(`data: ${JSON.stringify({ type: 'connected', timestamp: new Date().toISOString() })}\n\n`);
56
+ const send = (event) => {
57
+ reply.raw.write(`data: ${JSON.stringify(event)}\n\n`);
58
+ };
59
+ sseClients.add(send);
60
+ // Keep-alive ping every 30s
61
+ const pingInterval = setInterval(() => {
62
+ reply.raw.write(`: ping\n\n`);
63
+ }, 30000);
64
+ _request.raw.on('close', () => {
65
+ sseClients.delete(send);
66
+ clearInterval(pingInterval);
67
+ });
68
+ // Don't end the response - keep it open for SSE
69
+ await new Promise(() => { }); // never resolves
31
70
  });
32
- // Snapshot endpoint
71
+ // Live mode: List all sessions
72
+ fastify.get('/sessions', async () => {
73
+ const sessions = readSessions(claudeDir);
74
+ return { sessions };
75
+ });
76
+ // Live mode: Get tasks for a specific session
77
+ fastify.get('/sessions/:id', async (request) => {
78
+ const sessions = readSessions(claudeDir);
79
+ const session = sessions.find(s => s.id === request.params.id);
80
+ if (!session) {
81
+ return { session: null, error: 'Session not found' };
82
+ }
83
+ return { session };
84
+ });
85
+ // Plan mode: Snapshot endpoint (existing functionality)
33
86
  fastify.get('/snapshot', async () => {
87
+ if (!agentScopeDir) {
88
+ return {
89
+ snapshot: null,
90
+ queueErrors: ['Plan mode not configured. Run "agent-scope init" first.'],
91
+ logErrors: [],
92
+ meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
93
+ };
94
+ }
34
95
  const queuePath = join(agentScopeDir, 'queue.md');
35
96
  const logPath = join(agentScopeDir, 'execution.log');
36
- // Check if files exist
37
97
  if (!existsSync(queuePath)) {
38
98
  return {
39
99
  snapshot: null,
40
100
  queueErrors: ['queue.md not found'],
41
101
  logErrors: [],
42
- meta: {
43
- generatedAt: new Date().toISOString(),
44
- totalTasks: 0
45
- }
102
+ meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
46
103
  };
47
104
  }
105
+ // Read config for queue parse patterns
106
+ const configPath = join(agentScopeDir, 'config.json');
107
+ let queueParseConfig;
108
+ if (existsSync(configPath)) {
109
+ try {
110
+ const configData = JSON.parse(readFileSync(configPath, 'utf-8'));
111
+ if (configData.taskModel) {
112
+ queueParseConfig = {
113
+ id: configData.taskModel.id,
114
+ headings: configData.taskModel.headings
115
+ };
116
+ }
117
+ }
118
+ catch { /* use defaults */ }
119
+ }
48
120
  // Read and parse queue
49
121
  const queueContent = readFileSync(queuePath, 'utf-8');
50
- const queueResult = parseQueue(queueContent);
51
- // If queue has errors, don't compute snapshot
122
+ const queueResult = parseQueue(queueContent, queueParseConfig);
52
123
  if (queueResult.errors.length > 0) {
53
124
  return {
54
125
  snapshot: null,
55
126
  queueErrors: queueResult.errors,
56
127
  logErrors: [],
57
- meta: {
58
- generatedAt: new Date().toISOString(),
59
- totalTasks: 0
60
- }
128
+ meta: { generatedAt: new Date().toISOString(), totalTasks: 0 }
61
129
  };
62
130
  }
63
131
  // Read and parse log
64
- let logResult = parseLog(''); // Default to empty result
132
+ let logResult = parseLog('');
65
133
  if (existsSync(logPath)) {
66
134
  const logContent = readFileSync(logPath, 'utf-8');
67
135
  logResult = parseLog(logContent);
@@ -76,22 +144,33 @@ export async function startServer(agentScopeDir, port = 4317) {
76
144
  snapshot: null,
77
145
  queueErrors: [`Failed to compute snapshot: ${error}`],
78
146
  logErrors: logResult.errors,
79
- meta: {
80
- generatedAt: new Date().toISOString(),
81
- totalTasks: queueResult.tasks.length
82
- }
147
+ meta: { generatedAt: new Date().toISOString(), totalTasks: queueResult.tasks.length }
83
148
  };
84
149
  }
85
150
  return {
86
151
  snapshot,
87
152
  queueErrors: [],
88
153
  logErrors: logResult.errors,
89
- meta: {
90
- generatedAt: new Date().toISOString(),
91
- totalTasks: queueResult.tasks.length
92
- }
154
+ meta: { generatedAt: new Date().toISOString(), totalTasks: queueResult.tasks.length }
93
155
  };
94
156
  });
157
+ // Serve static files and SPA
158
+ const publicPath = join(__dirname, '../public');
159
+ if (existsSync(publicPath)) {
160
+ await fastify.register(staticPlugin, {
161
+ root: publicPath,
162
+ prefix: '/'
163
+ });
164
+ fastify.get('/', async (_request, reply) => {
165
+ return reply.sendFile('index.html');
166
+ });
167
+ fastify.setNotFoundHandler(async (_request, reply) => {
168
+ if (_request.url.startsWith('/api/') || _request.url.match(/\.\w+$/)) {
169
+ return reply.code(404).send({ error: 'Not found' });
170
+ }
171
+ return reply.sendFile('index.html');
172
+ });
173
+ }
95
174
  // Start server
96
175
  try {
97
176
  await fastify.listen({ port, host: '0.0.0.0' });
@@ -1 +1 @@
1
- {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { type FSWatcher } from 'chokidar';
2
+ import { EventEmitter } from 'events';
3
+ export interface WatcherOptions {
4
+ claudeDir: string;
5
+ agentScopeDir?: string;
6
+ }
7
+ export interface WatchEvent {
8
+ type: 'sessions' | 'plan';
9
+ timestamp: string;
10
+ }
11
+ /**
12
+ * Creates a file watcher that emits events when task files change.
13
+ * Watches ~/.claude/tasks/ for Live mode and .agent-scope/ for Plan mode.
14
+ */
15
+ export declare function createWatcher(options: WatcherOptions): {
16
+ watcher: FSWatcher;
17
+ emitter: EventEmitter;
18
+ };
19
+ //# sourceMappingURL=watcher.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"watcher.d.ts","sourceRoot":"","sources":["../../src/server/watcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,KAAK,SAAS,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAItC,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,UAAU,GAAG,MAAM,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,cAAc,GAAG;IAAE,OAAO,EAAE,SAAS,CAAC;IAAC,OAAO,EAAE,YAAY,CAAA;CAAE,CA0EpG"}
@@ -0,0 +1,76 @@
1
+ import { watch } from 'chokidar';
2
+ import { EventEmitter } from 'events';
3
+ import { existsSync } from 'fs';
4
+ import { join } from 'path';
5
+ /**
6
+ * Creates a file watcher that emits events when task files change.
7
+ * Watches ~/.claude/tasks/ for Live mode and .agent-scope/ for Plan mode.
8
+ */
9
+ export function createWatcher(options) {
10
+ const emitter = new EventEmitter();
11
+ const watchPaths = [];
12
+ // Watch Claude tasks directory
13
+ const claudeTasksDir = join(options.claudeDir, 'tasks');
14
+ if (existsSync(claudeTasksDir)) {
15
+ watchPaths.push(join(claudeTasksDir, '**/*.json'));
16
+ }
17
+ // Watch agent-scope files if configured
18
+ if (options.agentScopeDir && existsSync(options.agentScopeDir)) {
19
+ const queuePath = join(options.agentScopeDir, 'queue.md');
20
+ const logPath = join(options.agentScopeDir, 'execution.log');
21
+ if (existsSync(queuePath))
22
+ watchPaths.push(queuePath);
23
+ if (existsSync(logPath))
24
+ watchPaths.push(logPath);
25
+ }
26
+ if (watchPaths.length === 0) {
27
+ // Nothing to watch, return a no-op watcher
28
+ const noopWatcher = watch([], { persistent: false });
29
+ return { watcher: noopWatcher, emitter };
30
+ }
31
+ let debounceTimer = null;
32
+ let pendingEventType = null;
33
+ const watcher = watch(watchPaths, {
34
+ persistent: true,
35
+ ignoreInitial: true,
36
+ awaitWriteFinish: {
37
+ stabilityThreshold: 100,
38
+ pollInterval: 50
39
+ }
40
+ });
41
+ const emitDebounced = (eventType) => {
42
+ // If we already have a pending event, merge (prefer 'sessions' if mixed)
43
+ if (pendingEventType && pendingEventType !== eventType) {
44
+ pendingEventType = 'sessions'; // both changed, prioritize sessions
45
+ }
46
+ else {
47
+ pendingEventType = eventType;
48
+ }
49
+ if (debounceTimer)
50
+ clearTimeout(debounceTimer);
51
+ debounceTimer = setTimeout(() => {
52
+ if (pendingEventType) {
53
+ const event = {
54
+ type: pendingEventType,
55
+ timestamp: new Date().toISOString()
56
+ };
57
+ emitter.emit('change', event);
58
+ pendingEventType = null;
59
+ }
60
+ }, 100);
61
+ };
62
+ watcher.on('change', (path) => {
63
+ const eventType = path.includes('.agent-scope') ? 'plan' : 'sessions';
64
+ emitDebounced(eventType);
65
+ });
66
+ watcher.on('add', (path) => {
67
+ const eventType = path.includes('.agent-scope') ? 'plan' : 'sessions';
68
+ emitDebounced(eventType);
69
+ });
70
+ watcher.on('unlink', (path) => {
71
+ const eventType = path.includes('.agent-scope') ? 'plan' : 'sessions';
72
+ emitDebounced(eventType);
73
+ });
74
+ return { watcher, emitter };
75
+ }
76
+ //# sourceMappingURL=watcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"watcher.js","sourceRoot":"","sources":["../../src/server/watcher.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agent-scope",
3
- "version": "0.1.0",
3
+ "version": "0.2.0",
4
4
  "description": "Deterministic, local, passive execution observer for AI agent workflows",
5
5
  "type": "module",
6
6
  "bin": {
@@ -16,7 +16,7 @@
16
16
  "build": "tsc && cd dashboard && npm run build",
17
17
  "build:core": "tsc",
18
18
  "build:dashboard": "cd dashboard && npm run build",
19
- "test": "vitest",
19
+ "test": "vitest --run",
20
20
  "test:coverage": "vitest --coverage",
21
21
  "prepublishOnly": "npm run build && npm test"
22
22
  },
@@ -44,6 +44,7 @@
44
44
  "dependencies": {
45
45
  "@fastify/cors": "^9.0.1",
46
46
  "@fastify/static": "^7.0.4",
47
+ "chokidar": "^5.0.0",
47
48
  "commander": "^12.0.0",
48
49
  "fastify": "^4.26.0"
49
50
  },
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[931],{315:function(e,s,t){Promise.resolve().then(t.bind(t,6117))},6117:function(e,s,t){"use strict";t.r(s),t.d(s,{default:function(){return a}});var r=t(7437),l=t(2265);function a(){let[e,s]=(0,l.useState)(null),[t,a]=(0,l.useState)(!0),[d,n]=(0,l.useState)(null),[i,c]=(0,l.useState)(null),[x,o]=(0,l.useState)("all"),m=async()=>{a(!0),n(null);try{let e=await fetch("/snapshot");if(!e.ok)throw Error("Failed to fetch snapshot");let t=await e.json();s(t)}catch(e){n(e instanceof Error?e.message:"Unknown error")}finally{a(!1)}};if((0,l.useEffect)(()=>{m()},[]),t&&!e)return(0,r.jsx)("div",{className:"min-h-screen bg-gray-950 flex items-center justify-center",children:(0,r.jsx)("div",{className:"text-gray-400",children:"Loading..."})});if(d)return(0,r.jsx)("div",{className:"min-h-screen bg-gray-950 flex items-center justify-center",children:(0,r.jsxs)("div",{className:"text-red-500",children:["Error: ",d]})});if(!e)return null;if(e.queueErrors.length>0)return(0,r.jsx)("div",{className:"min-h-screen bg-gray-950 p-8",children:(0,r.jsx)("div",{className:"max-w-4xl mx-auto",children:(0,r.jsxs)("div",{className:"bg-red-950 border border-red-800 rounded-lg p-6",children:[(0,r.jsx)("h2",{className:"text-xl font-bold text-red-300 mb-4",children:"Queue Parse Errors"}),(0,r.jsx)("div",{className:"space-y-2",children:e.queueErrors.map((e,s)=>(0,r.jsx)("div",{className:"text-red-200 font-mono text-sm",children:e},s))})]})})});let h=e.snapshot,g="all"===x?h.tasks:h.tasks.filter(e=>e.status===x),u=e=>{switch(e){case"DONE":return"text-green-400 bg-green-950 border-green-800";case"FAILED":return"text-red-400 bg-red-950 border-red-800";case"BLOCKED":return"text-yellow-400 bg-yellow-950 border-yellow-800";case"READY":return"text-blue-400 bg-blue-950 border-blue-800";default:return"text-gray-400 bg-gray-950 border-gray-800"}},b=e=>h.tasks.filter(s=>s.dependsOn.includes(e)).map(e=>e.id);return(0,r.jsxs)("div",{className:"min-h-screen bg-gray-950 text-gray-100",children:[(0,r.jsx)("div",{className:"border-b border-gray-800 bg-gray-900 sticky top-0 z-10",children:(0,r.jsxs)("div",{className:"max-w-7xl mx-auto px-6 py-4 flex items-center justify-between",children:[(0,r.jsxs)("div",{children:[(0,r.jsx)("h1",{className:"text-2xl font-bold",children:"agent-scope"}),(0,r.jsxs)("p",{className:"text-sm text-gray-400",children:["Last updated: ",new Date(e.meta.generatedAt).toLocaleString()]})]}),(0,r.jsx)("button",{onClick:m,disabled:t,className:"px-4 py-2 bg-blue-600 hover:bg-blue-700 disabled:bg-gray-700 disabled:cursor-not-allowed rounded-lg font-medium transition",children:t?"Refreshing...":"Refresh"})]})}),(0,r.jsxs)("div",{className:"max-w-7xl mx-auto px-6 py-8 space-y-8",children:[e.logErrors.length>0&&(0,r.jsxs)("div",{className:"bg-yellow-950 border border-yellow-800 rounded-lg p-4",children:[(0,r.jsx)("h3",{className:"font-bold text-yellow-300 mb-2",children:"Log Parse Warnings"}),(0,r.jsx)("div",{className:"text-sm text-yellow-200 space-y-1",children:e.logErrors.map((e,s)=>(0,r.jsx)("div",{className:"font-mono",children:e},s))})]}),(0,r.jsxs)("div",{className:"grid grid-cols-2 md:grid-cols-3 lg:grid-cols-6 gap-4",children:[(0,r.jsxs)("div",{className:"bg-gray-900 border border-gray-800 rounded-lg p-4",children:[(0,r.jsx)("div",{className:"text-3xl font-bold",children:h.summary.total}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Total Tasks"})]}),(0,r.jsxs)("div",{className:"bg-gray-900 border border-green-800 rounded-lg p-4",children:[(0,r.jsx)("div",{className:"text-3xl font-bold text-green-400",children:h.summary.done}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Done"})]}),(0,r.jsxs)("div",{className:"bg-gray-900 border border-red-800 rounded-lg p-4",children:[(0,r.jsx)("div",{className:"text-3xl font-bold text-red-400",children:h.summary.failed}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Failed"})]}),(0,r.jsxs)("div",{className:"bg-gray-900 border border-yellow-800 rounded-lg p-4",children:[(0,r.jsx)("div",{className:"text-3xl font-bold text-yellow-400",children:h.summary.blocked}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Blocked"})]}),(0,r.jsxs)("div",{className:"bg-gray-900 border border-blue-800 rounded-lg p-4",children:[(0,r.jsx)("div",{className:"text-3xl font-bold text-blue-400",children:h.summary.ready}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Ready"})]}),(0,r.jsxs)("div",{className:"bg-gray-900 border border-gray-800 rounded-lg p-4",children:[(0,r.jsxs)("div",{className:"text-3xl font-bold",children:[Math.round(100*h.summary.successRate),"%"]}),(0,r.jsx)("div",{className:"text-sm text-gray-400",children:"Success Rate"})]})]}),(0,r.jsxs)("div",{className:"space-y-3",children:[(0,r.jsx)("h2",{className:"text-xl font-bold",children:"Slice Progress"}),Object.entries(h.slices).map(e=>{let[s,t]=e;return(0,r.jsxs)("div",{className:"bg-gray-900 border border-gray-800 rounded-lg p-4",children:[(0,r.jsxs)("div",{className:"flex justify-between mb-2",children:[(0,r.jsx)("span",{className:"font-bold",children:s}),(0,r.jsxs)("span",{className:"text-gray-400",children:[t.done,"/",t.total," (",t.progress,"%)"]})]}),(0,r.jsx)("div",{className:"w-full bg-gray-800 rounded-full h-2",children:(0,r.jsx)("div",{className:"bg-green-500 h-2 rounded-full transition-all",style:{width:"".concat(t.progress,"%")}})})]},s)})]}),(0,r.jsxs)("div",{children:[(0,r.jsxs)("div",{className:"flex justify-between items-center mb-4",children:[(0,r.jsx)("h2",{className:"text-xl font-bold",children:"Tasks"}),(0,r.jsxs)("select",{value:x,onChange:e=>o(e.target.value),className:"px-3 py-2 bg-gray-900 border border-gray-800 rounded-lg",children:[(0,r.jsx)("option",{value:"all",children:"All"}),(0,r.jsx)("option",{value:"READY",children:"Ready"}),(0,r.jsx)("option",{value:"BLOCKED",children:"Blocked"}),(0,r.jsx)("option",{value:"DONE",children:"Done"}),(0,r.jsx)("option",{value:"FAILED",children:"Failed"})]})]}),(0,r.jsx)("div",{className:"bg-gray-900 border border-gray-800 rounded-lg overflow-hidden",children:(0,r.jsxs)("table",{className:"w-full",children:[(0,r.jsx)("thead",{className:"bg-gray-800",children:(0,r.jsxs)("tr",{children:[(0,r.jsx)("th",{className:"px-4 py-3 text-left text-sm font-medium",children:"ID"}),(0,r.jsx)("th",{className:"px-4 py-3 text-left text-sm font-medium",children:"Area"}),(0,r.jsx)("th",{className:"px-4 py-3 text-left text-sm font-medium",children:"Description"}),(0,r.jsx)("th",{className:"px-4 py-3 text-left text-sm font-medium",children:"Status"}),(0,r.jsx)("th",{className:"px-4 py-3 text-left text-sm font-medium",children:"Dependencies"})]})}),(0,r.jsx)("tbody",{className:"divide-y divide-gray-800",children:g.map(e=>(0,r.jsxs)("tr",{onClick:()=>c(e),className:"hover:bg-gray-850 cursor-pointer transition",children:[(0,r.jsx)("td",{className:"px-4 py-3 font-mono text-sm",children:e.id}),(0,r.jsx)("td",{className:"px-4 py-3 text-sm",children:e.area}),(0,r.jsx)("td",{className:"px-4 py-3 text-sm",children:e.description}),(0,r.jsx)("td",{className:"px-4 py-3",children:(0,r.jsx)("span",{className:"px-2 py-1 rounded text-xs font-medium border ".concat(u(e.status)),children:e.status})}),(0,r.jsx)("td",{className:"px-4 py-3 text-sm text-gray-400",children:e.dependsOn.length>0?e.dependsOn.join(", "):"-"})]},e.id))})]})})]})]}),i&&(0,r.jsx)("div",{className:"fixed inset-0 bg-black bg-opacity-50 z-50 flex items-center justify-center",onClick:()=>c(null),children:(0,r.jsx)("div",{className:"bg-gray-900 border border-gray-800 rounded-lg max-w-2xl w-full mx-4 max-h-[90vh] overflow-y-auto",onClick:e=>e.stopPropagation(),children:(0,r.jsxs)("div",{className:"p-6 space-y-4",children:[(0,r.jsxs)("div",{className:"flex justify-between items-start",children:[(0,r.jsxs)("div",{children:[(0,r.jsx)("h2",{className:"text-2xl font-bold",children:i.id}),(0,r.jsx)("span",{className:"inline-block mt-2 px-3 py-1 rounded text-sm font-medium border ".concat(u(i.status)),children:i.status})]}),(0,r.jsx)("button",{onClick:()=>c(null),className:"text-gray-400 hover:text-gray-200",children:"✕"})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Area"}),(0,r.jsx)("p",{children:i.area})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Description"}),(0,r.jsx)("p",{children:i.description})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Acceptance Criteria"}),(0,r.jsx)("p",{children:i.acceptanceCriteria})]}),i.dependsOn.length>0&&(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Dependencies"}),(0,r.jsx)("div",{className:"space-y-1",children:i.dependsOn.map(e=>{let s=h.tasks.find(s=>s.id===e);return(0,r.jsxs)("div",{className:"flex items-center gap-2",children:[(0,r.jsx)("span",{className:"font-mono text-sm",children:e}),s&&(0,r.jsx)("span",{className:"px-2 py-0.5 rounded text-xs border ".concat(u(s.status)),children:s.status})]},e)})})]}),b(i.id).length>0&&(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Blocks These Tasks"}),(0,r.jsx)("div",{className:"space-y-1",children:b(i.id).map(e=>(0,r.jsx)("div",{className:"font-mono text-sm",children:e},e))})]}),i.lastEvent&&(0,r.jsxs)("div",{children:[(0,r.jsx)("h3",{className:"text-sm font-bold text-gray-400 mb-1",children:"Last Event"}),(0,r.jsxs)("div",{className:"bg-gray-800 rounded p-3 text-sm font-mono",children:[(0,r.jsxs)("div",{children:["Agent: ",i.lastEvent.agent]}),(0,r.jsxs)("div",{children:["Time: ",new Date(i.lastEvent.timestamp).toLocaleString()]}),i.lastEvent.meta&&(0,r.jsxs)("div",{children:["Meta: ",JSON.stringify(i.lastEvent.meta)]})]})]})]})})})]})}}},function(e){e.O(0,[971,117,744],function(){return e(e.s=315)}),_N_E=e.O()}]);