sparkecoder 0.1.55 → 0.1.56

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 (116) hide show
  1. package/dist/agent/index.d.ts +2 -2
  2. package/dist/agent/index.js +15 -12
  3. package/dist/agent/index.js.map +1 -1
  4. package/dist/cli.js +15 -12
  5. package/dist/cli.js.map +1 -1
  6. package/dist/{index-dJv_dqUq.d.ts → index-CqKMYoJv.d.ts} +1 -1
  7. package/dist/index.d.ts +3 -3
  8. package/dist/index.js +15 -12
  9. package/dist/index.js.map +1 -1
  10. package/dist/{search-DrztQ_iP.d.ts → search-CZsTAZ90.d.ts} +1 -1
  11. package/dist/server/index.js +15 -12
  12. package/dist/server/index.js.map +1 -1
  13. package/dist/tools/index.d.ts +2 -2
  14. package/dist/tools/index.js +2 -6
  15. package/dist/tools/index.js.map +1 -1
  16. package/package.json +1 -1
  17. package/web/.next/BUILD_ID +1 -1
  18. package/web/.next/standalone/web/.next/BUILD_ID +1 -1
  19. package/web/.next/standalone/web/.next/build-manifest.json +2 -2
  20. package/web/.next/standalone/web/.next/prerender-manifest.json +3 -3
  21. package/web/.next/standalone/web/.next/server/app/(main)/session/[id]/page.js.nft.json +1 -1
  22. package/web/.next/standalone/web/.next/server/app/(main)/session/[id]/page_client-reference-manifest.js +1 -1
  23. package/web/.next/standalone/web/.next/server/app/_global-error.html +2 -2
  24. package/web/.next/standalone/web/.next/server/app/_global-error.rsc +1 -1
  25. package/web/.next/standalone/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  26. package/web/.next/standalone/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  27. package/web/.next/standalone/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  28. package/web/.next/standalone/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  29. package/web/.next/standalone/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  30. package/web/.next/standalone/web/.next/server/app/_not-found.html +1 -1
  31. package/web/.next/standalone/web/.next/server/app/_not-found.rsc +1 -1
  32. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  33. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  34. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  35. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  36. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  37. package/web/.next/standalone/web/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  38. package/web/.next/standalone/web/.next/server/app/docs/installation.html +2 -2
  39. package/web/.next/standalone/web/.next/server/app/docs/installation.rsc +1 -1
  40. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_full.segment.rsc +1 -1
  41. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_head.segment.rsc +1 -1
  42. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_index.segment.rsc +1 -1
  43. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_tree.segment.rsc +1 -1
  44. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation/__PAGE__.segment.rsc +1 -1
  45. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation.segment.rsc +1 -1
  46. package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs.segment.rsc +1 -1
  47. package/web/.next/standalone/web/.next/server/app/docs/skills.html +2 -2
  48. package/web/.next/standalone/web/.next/server/app/docs/skills.rsc +1 -1
  49. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_full.segment.rsc +1 -1
  50. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_head.segment.rsc +1 -1
  51. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_index.segment.rsc +1 -1
  52. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_tree.segment.rsc +1 -1
  53. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills/__PAGE__.segment.rsc +1 -1
  54. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills.segment.rsc +1 -1
  55. package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs.segment.rsc +1 -1
  56. package/web/.next/standalone/web/.next/server/app/docs/tools.html +2 -2
  57. package/web/.next/standalone/web/.next/server/app/docs/tools.rsc +1 -1
  58. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_full.segment.rsc +1 -1
  59. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_head.segment.rsc +1 -1
  60. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_index.segment.rsc +1 -1
  61. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_tree.segment.rsc +1 -1
  62. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools/__PAGE__.segment.rsc +1 -1
  63. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools.segment.rsc +1 -1
  64. package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs.segment.rsc +1 -1
  65. package/web/.next/standalone/web/.next/server/app/docs.html +2 -2
  66. package/web/.next/standalone/web/.next/server/app/docs.rsc +1 -1
  67. package/web/.next/standalone/web/.next/server/app/docs.segments/_full.segment.rsc +1 -1
  68. package/web/.next/standalone/web/.next/server/app/docs.segments/_head.segment.rsc +1 -1
  69. package/web/.next/standalone/web/.next/server/app/docs.segments/_index.segment.rsc +1 -1
  70. package/web/.next/standalone/web/.next/server/app/docs.segments/_tree.segment.rsc +1 -1
  71. package/web/.next/standalone/web/.next/server/app/docs.segments/docs/__PAGE__.segment.rsc +1 -1
  72. package/web/.next/standalone/web/.next/server/app/docs.segments/docs.segment.rsc +1 -1
  73. package/web/.next/standalone/web/.next/server/app/embed/[id]/page.js.nft.json +1 -1
  74. package/web/.next/standalone/web/.next/server/app/embed/[id]/page_client-reference-manifest.js +1 -1
  75. package/web/.next/standalone/web/.next/server/app/index.html +1 -1
  76. package/web/.next/standalone/web/.next/server/app/index.rsc +1 -1
  77. package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p/__PAGE__.segment.rsc +1 -1
  78. package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p.segment.rsc +1 -1
  79. package/web/.next/standalone/web/.next/server/app/index.segments/_full.segment.rsc +1 -1
  80. package/web/.next/standalone/web/.next/server/app/index.segments/_head.segment.rsc +1 -1
  81. package/web/.next/standalone/web/.next/server/app/index.segments/_index.segment.rsc +1 -1
  82. package/web/.next/standalone/web/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  83. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_c9e3cd7b._.js → 2374f_05c00b91._.js} +1 -1
  84. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_de035f79._.js → 2374f_1fa4a79a._.js} +1 -1
  85. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_273991ba._.js → 2374f_39f76acc._.js} +1 -1
  86. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_8d018190._.js → 2374f_562d2f4f._.js} +1 -1
  87. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_7b421f78._.js → 2374f_6ced4caf._.js} +1 -1
  88. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_ec997752._.js → 2374f_800db4e3._.js} +1 -1
  89. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_2572135b._.js → 2374f_934cb548._.js} +1 -1
  90. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_5ee28d4c._.js → 2374f_aade2a6d._.js} +1 -1
  91. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_460c0d78._.js → 2374f_ac284eb3._.js} +1 -1
  92. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_a7457131._.js → 2374f_c272cbb4._.js} +1 -1
  93. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_06a5ea48._.js → 2374f_d118a207._.js} +1 -1
  94. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_df3c414e._.js → 2374f_e35df3d7._.js} +1 -1
  95. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_88cbeb7b._.js → 2374f_ef435bac._.js} +1 -1
  96. package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_65b86b54._.js → 2374f_f661d73d._.js} +1 -1
  97. package/web/.next/standalone/web/.next/server/chunks/ssr/{[root-of-the-server]__a87e1c27._.js → [root-of-the-server]__8cdc7b0b._.js} +2 -2
  98. package/web/.next/standalone/web/.next/server/chunks/ssr/{[root-of-the-server]__c94aac98._.js → [root-of-the-server]__f44222d9._.js} +2 -2
  99. package/web/.next/standalone/web/.next/server/chunks/ssr/{web_b85931da._.js → web_0a13adb9._.js} +2 -2
  100. package/web/.next/standalone/web/.next/server/pages/404.html +1 -1
  101. package/web/.next/standalone/web/.next/server/pages/500.html +2 -2
  102. package/web/.next/standalone/web/.next/server/server-reference-manifest.js +1 -1
  103. package/web/.next/standalone/web/.next/server/server-reference-manifest.json +1 -1
  104. package/web/.next/standalone/web/.next/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
  105. package/web/.next/standalone/web/.next/static/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
  106. package/web/.next/standalone/web/src/components/ai-elements/search-tool.tsx +7 -9
  107. package/web/.next/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
  108. /package/web/.next/standalone/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → static/yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
  109. /package/web/.next/standalone/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → static/yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
  110. /package/web/.next/standalone/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → static/yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
  111. /package/web/.next/standalone/web/.next/static/{static/NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
  112. /package/web/.next/standalone/web/.next/static/{static/NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
  113. /package/web/.next/standalone/web/.next/static/{static/NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
  114. /package/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
  115. /package/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
  116. /package/web/.next/static/{NvcDNpBzx7zCsiSYYtQ3Z → yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
@@ -215,8 +215,8 @@ interface SearchToolOptions {
215
215
  * Progress is streamed back to the UI so users can see exploration happening.
216
216
  */
217
217
  declare function createSearchTool(options: SearchToolOptions): ai.Tool<{
218
+ context: string;
218
219
  query: string;
219
- context?: string | undefined;
220
220
  }, {
221
221
  success: boolean;
222
222
  error: string;
@@ -4199,14 +4199,10 @@ The Explore agent will explore the codebase and return a summary of findings.
4199
4199
  This is more thorough than a simple grep because it can follow references and understand context.
4200
4200
  It also has access to semantic search to find code by meaning, not just text.
4201
4201
 
4202
- Examples:
4203
- - "Find all React components that use the useState hook"
4204
- - "Where is the authentication logic implemented?"
4205
- - "Find all API routes and their handlers"
4206
- - "Search for usages of the UserService class"`,
4202
+ CRITICAL: The explore agent has ZERO context. It cannot see the conversation, the user's message, devtools data, or any prior context. You MUST pass ALL relevant context via the "context" parameter. If the user selected a component (component name, file path, HTML, component stack) or there is a <devtools-context> block, you MUST copy that information into the "context" field verbatim. Without it the explore agent is searching blind.`,
4207
4203
  inputSchema: z10.object({
4208
4204
  query: z10.string().describe("What to search for. Be specific about what you're looking for."),
4209
- context: z10.string().optional().describe("Optional additional context about why you need this information.")
4205
+ context: z10.string().describe("ALL context the explore agent needs. It has ZERO context on its own - no conversation history, no devtools data, nothing. You MUST include: any selected component info (name, file path, HTML, component stack), any <devtools-context> block (page URL, path, viewport), and any other relevant details from the user message. The explore agent literally only sees the query and this context field.")
4210
4206
  }),
4211
4207
  execute: async ({ query, context }, toolOptions) => {
4212
4208
  const toolCallId = toolOptions.toolCallId || `explore_agent_${Date.now()}`;
@@ -4534,6 +4530,11 @@ Use this proactively after making code changes to catch errors early.
4534
4530
 
4535
4531
  **Choose the right search approach:**
4536
4532
 
4533
+ 0. **Use paths to your advantage \u2014 skip searching if you already have what you need.**
4534
+ - If the user selected a component via devtools and you can see the component name, file path, and/or line number, you ALREADY know where the code is. Just use \`read_file\` to read that file directly \u2014 do NOT call \`explore_agent\` to "find" something you already have the location of.
4535
+ - If you received a **page path** (e.g. \`/dashboard\`, \`/settings/profile\`), map it to the corresponding file in the project structure. In Next.js this means \`app/dashboard/page.tsx\`, \`app/settings/profile/page.tsx\`, etc. In other frameworks, check the routing convention (e.g. \`pages/\`, \`src/routes/\`). Use \`read_file\` on the mapped path directly.
4536
+ - If the file path doesn't exist or \`read_file\` fails, fall back to grep to locate it (e.g. \`rg "ComponentName" --type ts -l\`) since devtools paths can sometimes be slightly off or truncated.
4537
+ - Read up and down component trees when you have the file path or page path to find what you're looking for.
4537
4538
  1. **Use the \`explore_agent\` tool (Explore agent)** for:
4538
4539
  - Semantic/exploratory questions: "How does authentication work?", "Where is user data processed?"
4539
4540
  - Finding code by meaning or concept, not exact text
@@ -4543,11 +4544,12 @@ Use this proactively after making code changes to catch errors early.
4543
4544
 
4544
4545
  The Explore agent is a mini-agent that intelligently explores the codebase, reads relevant files, and returns a summary of what it found. It's best for understanding and discovery.
4545
4546
 
4546
- **IMPORTANT: The Explore agent has NO context on its own.** When you call \`explore_agent\`, you MUST pass along any relevant context the user has given you via the \`context\` parameter. In particular:
4547
- - If the user selected a component via devtools (you'll see component name, file path, HTML, component stack in their message), pass ALL of that to the explore agent's \`context\` field.
4548
- - If there is a \`<devtools-context>\` block with the current page URL, path, and viewport, include that too.
4549
- - If the user references "this page", "this component", "this button", etc., the explore agent needs the component name, file path, and page path to know what to search for.
4550
- - The explore agent cannot see the conversation history. The \`query\` and \`context\` fields are the ONLY information it receives.
4547
+ **MANDATORY \u2014 The Explore agent has ZERO context.** It cannot see the conversation, the user's messages, devtools data, or anything else. The \`query\` and \`context\` fields are the ONLY information it receives. Every time you call \`explore_agent\`, you MUST populate the \`context\` field with ALL relevant information:
4548
+ - Copy the ENTIRE \`<devtools-context>\` block (page URL, path, viewport) if one exists in the user's message.
4549
+ - Copy ALL selected component info (component name, file path, line number, HTML snippet, component stack) if the user selected something via devtools.
4550
+ - Include any file paths, component names, or page names the user mentioned.
4551
+ - If you skip the \`context\` field, the explore agent is searching completely blind and will waste time guessing.
4552
+ - NEVER call \`explore_agent\` with only a \`query\` and no \`context\` when the user's message contains devtools or component information.
4551
4553
 
4552
4554
  2. **Use direct commands (grep/rg, find)** for:
4553
4555
  - Exact string matches: \`rg "functionName"\`, \`rg "class MyClass"\`
@@ -4556,7 +4558,8 @@ Use this proactively after making code changes to catch errors early.
4556
4558
  - Counting occurrences or listing all matches
4557
4559
 
4558
4560
  **Examples:**
4559
- - "Where is the API authentication handled?" \u2192 Use \`explore_agent\` tool
4561
+ - User selected \`<LandingButton>\` at \`src/components/LandingButton.tsx:12\` \u2192 Just \`read_file("src/components/LandingButton.tsx")\`. Do NOT call explore_agent.
4562
+ - "Where is the API authentication handled?" (no file path given) \u2192 Use \`explore_agent\` tool
4560
4563
  - "Find all usages of getUserById" \u2192 Use \`rg "getUserById"\`
4561
4564
  - "How does the payment flow work?" \u2192 Use \`explore_agent\` tool
4562
4565
  - "Find files named config" \u2192 Use \`find . -name "*config*"\`