@vpxa/kb 0.1.24 → 0.1.26

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 (209) hide show
  1. package/README.md +3 -3
  2. package/package.json +9 -2
  3. package/packages/analyzers/dist/symbol-analyzer.js +5 -5
  4. package/packages/cli/dist/commands/init/adapters.js +1 -1
  5. package/packages/cli/dist/commands/init/constants.d.ts +4 -1
  6. package/packages/cli/dist/commands/init/constants.js +1 -1
  7. package/packages/cli/dist/commands/init/frontmatter.d.ts +54 -0
  8. package/packages/cli/dist/commands/init/frontmatter.js +2 -0
  9. package/packages/cli/dist/commands/init/index.js +4 -4
  10. package/packages/cli/dist/commands/init/manifest.d.ts +71 -0
  11. package/packages/cli/dist/commands/init/manifest.js +1 -0
  12. package/packages/cli/dist/commands/init/scaffold.d.ts +28 -5
  13. package/packages/cli/dist/commands/init/scaffold.js +1 -1
  14. package/packages/cli/dist/commands/init/templates.js +38 -9
  15. package/packages/cli/dist/commands/init/user.d.ts +3 -3
  16. package/packages/cli/dist/commands/init/user.js +4 -4
  17. package/packages/cli/dist/commands/system.js +2 -2
  18. package/packages/cli/dist/kb-init.js +1 -1
  19. package/packages/core/dist/errors.d.ts +2 -2
  20. package/packages/core/dist/errors.js +1 -1
  21. package/packages/core/dist/logger.d.ts +2 -1
  22. package/packages/core/dist/logger.js +1 -1
  23. package/packages/core/dist/types.d.ts +6 -0
  24. package/packages/dashboard/dist/assets/index-9ysCkze9.js +21 -0
  25. package/packages/dashboard/dist/assets/index-9ysCkze9.js.map +1 -0
  26. package/packages/dashboard/dist/assets/index-CHpVij2M.css +1 -0
  27. package/packages/dashboard/dist/index.html +18 -0
  28. package/packages/elicitation/dist/__tests__/build.test.d.ts +1 -0
  29. package/packages/elicitation/dist/__tests__/build.test.js +35 -0
  30. package/packages/elicitation/dist/__tests__/fields.test.d.ts +1 -0
  31. package/packages/elicitation/dist/__tests__/fields.test.js +81 -0
  32. package/packages/elicitation/dist/__tests__/normalize.test.d.ts +1 -0
  33. package/packages/elicitation/dist/__tests__/normalize.test.js +60 -0
  34. package/packages/elicitation/dist/build.d.ts +13 -0
  35. package/packages/elicitation/dist/build.js +23 -0
  36. package/packages/elicitation/dist/fields.d.ts +41 -0
  37. package/packages/elicitation/dist/fields.js +62 -0
  38. package/packages/elicitation/dist/index.d.ts +10 -0
  39. package/packages/elicitation/dist/index.js +12 -0
  40. package/packages/elicitation/dist/normalize.d.ts +15 -0
  41. package/packages/elicitation/dist/normalize.js +31 -0
  42. package/packages/elicitation/dist/types.d.ts +85 -0
  43. package/packages/elicitation/dist/types.js +8 -0
  44. package/packages/kb-client/dist/direct-client.d.ts +37 -0
  45. package/packages/kb-client/dist/direct-client.js +1 -0
  46. package/packages/kb-client/dist/index.d.ts +5 -0
  47. package/packages/kb-client/dist/index.js +1 -0
  48. package/packages/kb-client/dist/mcp-client.d.ts +19 -0
  49. package/packages/kb-client/dist/mcp-client.js +4 -0
  50. package/packages/kb-client/dist/parsers.d.ts +35 -0
  51. package/packages/kb-client/dist/parsers.js +2 -0
  52. package/packages/kb-client/dist/types.d.ts +62 -0
  53. package/packages/kb-client/dist/types.js +1 -0
  54. package/packages/present/dist/index.html +384 -0
  55. package/packages/server/dist/completions.d.ts +14 -0
  56. package/packages/server/dist/completions.js +1 -0
  57. package/packages/server/dist/dashboard-static.d.ts +27 -0
  58. package/packages/server/dist/dashboard-static.js +1 -0
  59. package/packages/server/dist/elicitor.d.ts +18 -0
  60. package/packages/server/dist/elicitor.js +1 -0
  61. package/packages/server/dist/index.js +1 -1
  62. package/packages/server/dist/mcp-logging.js +1 -1
  63. package/packages/server/dist/output-schemas.d.ts +118 -1
  64. package/packages/server/dist/output-schemas.js +1 -1
  65. package/packages/server/dist/prompts.d.ts +9 -2
  66. package/packages/server/dist/prompts.js +13 -7
  67. package/packages/server/dist/resources/curated-resources.js +1 -1
  68. package/packages/server/dist/resources/resource-notifier.d.ts +45 -0
  69. package/packages/server/dist/resources/resource-notifier.js +1 -0
  70. package/packages/server/dist/sampling.d.ts +41 -0
  71. package/packages/server/dist/sampling.js +2 -0
  72. package/packages/server/dist/server.d.ts +5 -2
  73. package/packages/server/dist/server.js +2 -2
  74. package/packages/server/dist/task-manager.d.ts +40 -0
  75. package/packages/server/dist/task-manager.js +1 -0
  76. package/packages/server/dist/tool-metadata.js +1 -1
  77. package/packages/server/dist/tool-prefix.d.ts +12 -0
  78. package/packages/server/dist/tool-prefix.js +1 -0
  79. package/packages/server/dist/tools/analyze.tools.js +4 -4
  80. package/packages/server/dist/tools/audit.tool.js +1 -1
  81. package/packages/server/dist/tools/brainstorm.tool.d.ts +7 -0
  82. package/packages/server/dist/tools/brainstorm.tool.js +9 -0
  83. package/packages/server/dist/tools/context.tools.js +9 -9
  84. package/packages/server/dist/tools/execution.tools.d.ts +2 -1
  85. package/packages/server/dist/tools/execution.tools.js +4 -4
  86. package/packages/server/dist/tools/forge.tools.js +10 -10
  87. package/packages/server/dist/tools/forget.tool.d.ts +2 -1
  88. package/packages/server/dist/tools/forget.tool.js +1 -1
  89. package/packages/server/dist/tools/graph.tool.js +2 -2
  90. package/packages/server/dist/tools/manipulation.tools.js +4 -4
  91. package/packages/server/dist/tools/onboard.tool.js +2 -2
  92. package/packages/server/dist/tools/present-blocks.d.ts +46 -0
  93. package/packages/server/dist/tools/present-blocks.js +27 -0
  94. package/packages/server/dist/tools/present-charts.d.ts +31 -0
  95. package/packages/server/dist/tools/present-charts.js +34 -0
  96. package/packages/server/dist/tools/present-theme.d.ts +14 -0
  97. package/packages/server/dist/tools/present-theme.js +395 -0
  98. package/packages/server/dist/tools/present-utils.d.ts +11 -0
  99. package/packages/server/dist/tools/present-utils.js +1 -0
  100. package/packages/server/dist/tools/present.tool.d.ts +7 -0
  101. package/packages/server/dist/tools/present.tool.js +113 -0
  102. package/packages/server/dist/tools/produce.tool.js +2 -2
  103. package/packages/server/dist/tools/reindex.tool.d.ts +2 -1
  104. package/packages/server/dist/tools/reindex.tool.js +2 -2
  105. package/packages/server/dist/tools/remember.tool.d.ts +2 -1
  106. package/packages/server/dist/tools/remember.tool.js +2 -2
  107. package/packages/server/dist/tools/replay.tool.js +1 -1
  108. package/packages/server/dist/tools/search.tool.d.ts +2 -1
  109. package/packages/server/dist/tools/search.tool.js +5 -4
  110. package/packages/server/dist/tools/status.tool.js +2 -2
  111. package/packages/server/dist/tools/update.tool.d.ts +2 -1
  112. package/packages/server/dist/tools/update.tool.js +1 -1
  113. package/packages/server/dist/tools/utility.tools.js +1 -1
  114. package/packages/tools/dist/batch.js +1 -1
  115. package/packages/tools/dist/checkpoint.js +1 -1
  116. package/packages/tools/dist/config-extractor.d.ts +9 -0
  117. package/packages/tools/dist/config-extractor.js +7 -0
  118. package/packages/tools/dist/dead-symbols.js +2 -2
  119. package/packages/tools/dist/diagram-builder.d.ts +9 -0
  120. package/packages/tools/dist/diagram-builder.js +9 -0
  121. package/packages/tools/dist/evidence-map.d.ts +12 -1
  122. package/packages/tools/dist/evidence-map.js +2 -2
  123. package/packages/tools/dist/find-examples.js +2 -2
  124. package/packages/tools/dist/forge-classify.d.ts +4 -0
  125. package/packages/tools/dist/forge-classify.js +1 -1
  126. package/packages/tools/dist/git-context.d.ts +1 -0
  127. package/packages/tools/dist/git-context.js +3 -3
  128. package/packages/tools/dist/index.d.ts +3 -2
  129. package/packages/tools/dist/index.js +1 -1
  130. package/packages/tools/dist/onboard-utils.d.ts +12 -0
  131. package/packages/tools/dist/onboard-utils.js +1 -0
  132. package/packages/tools/dist/onboard.js +2 -21
  133. package/packages/tools/dist/regex-utils.d.ts +8 -0
  134. package/packages/tools/dist/regex-utils.js +1 -0
  135. package/packages/tools/dist/rename.js +2 -2
  136. package/packages/tools/dist/replay.d.ts +2 -1
  137. package/packages/tools/dist/replay.js +4 -4
  138. package/packages/tools/dist/symbol.js +3 -3
  139. package/packages/tools/dist/synthesis-engine.d.ts +13 -0
  140. package/packages/tools/dist/synthesis-engine.js +6 -0
  141. package/packages/tools/dist/trace.js +2 -2
  142. package/packages/tui/dist/App-DXY0-tlW.js +2 -0
  143. package/packages/tui/dist/App.d.ts +3 -3
  144. package/packages/tui/dist/App.js +1 -1
  145. package/packages/tui/dist/CuratedPanel-BIamXLNy.js +2 -0
  146. package/packages/tui/dist/LogPanel-D6u6o84n.js +3 -0
  147. package/packages/tui/dist/SearchPanel-CpJGczAc.js +2 -0
  148. package/packages/tui/dist/StatusPanel-BAbUxyqQ.js +2 -0
  149. package/packages/tui/dist/hooks/useKBClient.d.ts +9 -0
  150. package/packages/tui/dist/hooks/useKBClient.js +2 -0
  151. package/packages/tui/dist/hooks/usePolling.d.ts +8 -0
  152. package/packages/tui/dist/hooks/usePolling.js +2 -0
  153. package/packages/tui/dist/index.d.ts +6 -2
  154. package/packages/tui/dist/index.js +1 -1
  155. package/packages/tui/dist/jsx-runtime-y6Gdq5PZ.js +294 -0
  156. package/packages/tui/dist/panels/CuratedPanel.d.ts +1 -7
  157. package/packages/tui/dist/panels/CuratedPanel.js +1 -1
  158. package/packages/tui/dist/panels/LogPanel.js +1 -1
  159. package/packages/tui/dist/panels/SearchPanel.d.ts +1 -10
  160. package/packages/tui/dist/panels/SearchPanel.js +1 -1
  161. package/packages/tui/dist/panels/StatusPanel.d.ts +1 -7
  162. package/packages/tui/dist/panels/StatusPanel.js +1 -1
  163. package/packages/tui/dist/react-D__J1GQe.js +24 -0
  164. package/packages/tui/dist/types-VcTHNV6s.d.ts +64 -0
  165. package/packages/tui/dist/useKBClient-C35iA4uG.js +2 -0
  166. package/packages/tui/dist/usePolling-BbjnRWgx.js +2 -0
  167. package/scaffold/adapters/copilot.mjs +9 -81
  168. package/scaffold/definitions/agents.mjs +12 -0
  169. package/scaffold/definitions/bodies.mjs +39 -14
  170. package/scaffold/definitions/protocols.mjs +149 -0
  171. package/scaffold/definitions/tools.mjs +40 -5
  172. package/scaffold/general/agents/Architect-Reviewer-Alpha.agent.md +1 -1
  173. package/scaffold/general/agents/Architect-Reviewer-Beta.agent.md +1 -1
  174. package/scaffold/general/agents/Code-Reviewer-Alpha.agent.md +1 -1
  175. package/scaffold/general/agents/Code-Reviewer-Beta.agent.md +1 -1
  176. package/scaffold/general/agents/Debugger.agent.md +2 -2
  177. package/scaffold/general/agents/Documenter.agent.md +2 -2
  178. package/scaffold/general/agents/Explorer.agent.md +4 -3
  179. package/scaffold/general/agents/Frontend.agent.md +1 -1
  180. package/scaffold/general/agents/Implementer.agent.md +1 -1
  181. package/scaffold/general/agents/Orchestrator.agent.md +16 -1
  182. package/scaffold/general/agents/Planner.agent.md +11 -4
  183. package/scaffold/general/agents/Refactor.agent.md +1 -1
  184. package/scaffold/general/agents/Researcher-Alpha.agent.md +1 -1
  185. package/scaffold/general/agents/Researcher-Beta.agent.md +1 -1
  186. package/scaffold/general/agents/Researcher-Delta.agent.md +1 -1
  187. package/scaffold/general/agents/Researcher-Gamma.agent.md +1 -1
  188. package/scaffold/general/agents/Security.agent.md +10 -8
  189. package/scaffold/general/agents/_shared/architect-reviewer-base.md +1 -0
  190. package/scaffold/general/agents/_shared/code-agent-base.md +28 -0
  191. package/scaffold/general/agents/_shared/code-reviewer-base.md +1 -0
  192. package/scaffold/general/agents/_shared/forge-protocol.md +44 -0
  193. package/scaffold/general/agents/_shared/researcher-base.md +14 -0
  194. package/scaffold/general/agents/templates/adr-template.md +1 -0
  195. package/scaffold/general/agents/templates/execution-state.md +1 -0
  196. package/skills/knowledge-base/SKILL.md +19 -6
  197. package/skills/present/SKILL.md +153 -0
  198. package/packages/server/dist/tools/toolkit.tools.d.ts +0 -36
  199. package/packages/server/dist/tools/toolkit.tools.js +0 -20
  200. package/packages/tui/dist/App-DE_tdOhs.js +0 -2
  201. package/packages/tui/dist/CuratedPanel-sYdZAICX.js +0 -2
  202. package/packages/tui/dist/LogPanel-Ce3jMQbH.js +0 -3
  203. package/packages/tui/dist/SearchPanel-DREo6zgt.js +0 -2
  204. package/packages/tui/dist/StatusPanel-2ex8fLOO.js +0 -2
  205. package/packages/tui/dist/embedder.interface-IFCBpOlX.d.ts +0 -28
  206. package/packages/tui/dist/index-C8NmOF18.d.ts +0 -13
  207. package/packages/tui/dist/jsx-runtime-Cof-kwFn.js +0 -316
  208. package/packages/tui/dist/store.interface-CnY6SPOH.d.ts +0 -150
  209. /package/packages/tui/dist/{devtools-DUyj952l.js → devtools-DMOZMn70.js} +0 -0
@@ -0,0 +1,46 @@
1
+ //#region packages/server/src/tools/present-blocks.d.ts
2
+ /**
3
+ * Present Blocks — New block-type renderers.
4
+ *
5
+ * Each function returns an HTML string that pairs with classes
6
+ * already defined in present-theme.ts.
7
+ */
8
+ interface TimelineItem {
9
+ phase?: string;
10
+ title: string;
11
+ description?: string;
12
+ status?: 'done' | 'active' | 'pending' | 'error';
13
+ }
14
+ interface ChecklistItem {
15
+ label: string;
16
+ checked?: boolean;
17
+ note?: string;
18
+ }
19
+ interface ComparisonColumn {
20
+ title: string;
21
+ items: string[];
22
+ }
23
+ interface StatusItem {
24
+ label: string;
25
+ status: 'success' | 'warning' | 'error' | 'info' | 'pending';
26
+ detail?: string;
27
+ }
28
+ interface PromptValue {
29
+ question: string;
30
+ context?: string;
31
+ placeholder?: string;
32
+ }
33
+ interface ProgressItem {
34
+ label: string;
35
+ value: number;
36
+ max?: number;
37
+ color?: string;
38
+ }
39
+ declare function renderTimelineHtml(value: unknown): string;
40
+ declare function renderChecklistHtml(value: unknown): string;
41
+ declare function renderComparisonHtml(value: unknown): string;
42
+ declare function renderStatusBoardHtml(value: unknown): string;
43
+ declare function renderPromptHtml(value: unknown): string;
44
+ declare function renderProgressHtml(value: unknown): string;
45
+ //#endregion
46
+ export { ChecklistItem, ComparisonColumn, ProgressItem, PromptValue, StatusItem, TimelineItem, renderChecklistHtml, renderComparisonHtml, renderProgressHtml, renderPromptHtml, renderStatusBoardHtml, renderTimelineHtml };
@@ -0,0 +1,27 @@
1
+ import{escHtml as e}from"./present-utils.js";const t=e;function n(e){let n=e;return!n?.items||!Array.isArray(n.items)?``:`<div class="timeline">${n.items.map(e=>{let n=e.status??`pending`,r=e.phase?`<div class="timeline-phase">${t(e.phase)}</div>`:``,i=e.description?`<div class="timeline-desc">${t(e.description)}</div>`:``;return`<div class="timeline-item">
2
+ <div class="timeline-dot ${n}"></div>
3
+ ${r}
4
+ <div class="timeline-title">${t(e.title)}</div>
5
+ ${i}
6
+ </div>`}).join(``)}</div>`}function r(e){let n=e;return!n?.items||!Array.isArray(n.items)?``:`<div class="checklist">${n.items.map(e=>{let n=e.checked?`checked`:``,r=e.checked?`✓`:``,i=e.note?`<div class="checklist-note">${t(e.note)}</div>`:``;return`<div class="checklist-item ${n}">
7
+ <div class="checklist-check ${n}">${r}</div>
8
+ <div>
9
+ <div class="checklist-label">${t(e.label)}</div>
10
+ ${i}
11
+ </div>
12
+ </div>`}).join(``)}</div>`}function i(e){let n=e;if(!n?.columns||!Array.isArray(n.columns)||n.columns.length===0)return``;let r=n.columns.length,i=Math.max(...n.columns.map(e=>e.items?.length??0));return`<div class="comparison-grid" style="grid-template-columns:repeat(${r},1fr)">${n.columns.map(e=>{let n=`<div class="comparison-header">${t(e.title)}</div>`,r=[];for(let n=0;n<i;n++){let i=e.items?.[n]??``;r.push(`<div class="comparison-item">${t(i)}</div>`)}return`<div class="comparison-col">${n}${r.join(``)}</div>`}).join(``)}</div>`}function a(e){let n=e;return!n?.items||!Array.isArray(n.items)?``:`<div class="status-board">${n.items.map(e=>{let n=e.detail?`<span class="status-detail">${t(e.detail)}</span>`:``;return`<div class="status-row">
13
+ <div class="status-indicator ${e.status??`pending`}"></div>
14
+ <span class="status-label">${t(e.label)}</span>
15
+ ${n}
16
+ </div>`}).join(``)}</div>`}function o(e){let n=e;if(!n?.question)return``;let r=n.context?`<div class="prompt-context">${t(n.context)}</div>`:``,i=n.placeholder?`<div class="prompt-placeholder">${t(n.placeholder)}</div>`:``;return`<div class="prompt-block">
17
+ <div class="prompt-question">${t(n.question)}</div>
18
+ ${r}${i}
19
+ </div>`}function s(e){let n=e;if(!n?.items||!Array.isArray(n.items))return``;let r=e=>e>=100?`var(--success)`:e>=60?`var(--primary)`:e>=30?`var(--warning)`:`var(--error)`;return`<div class="progress-list">${n.items.map(e=>{let n=e.max??100,i=n>0?Math.min(100,e.value/n*100):0,a=e.color??r(i);return`<div class="progress-item">
20
+ <div class="progress-header">
21
+ <span class="progress-label">${t(e.label)}</span>
22
+ <span class="progress-value">${e.value}/${n}</span>
23
+ </div>
24
+ <div class="progress-track">
25
+ <div class="progress-fill" style="width:${i.toFixed(1)}%;background:${a}"></div>
26
+ </div>
27
+ </div>`}).join(``)}</div>`}export{r as renderChecklistHtml,i as renderComparisonHtml,s as renderProgressHtml,o as renderPromptHtml,a as renderStatusBoardHtml,n as renderTimelineHtml};
@@ -0,0 +1,31 @@
1
+ //#region packages/server/src/tools/present-charts.d.ts
2
+ /**
3
+ * Present Charts — Pure SVG chart rendering engine.
4
+ *
5
+ * Supports: line, area, bar, horizontal-bar, pie, donut, sparkline, heatmap.
6
+ * Uses CSS custom properties (--chart-1 … --chart-12) from present-theme.ts.
7
+ * Zero external dependencies.
8
+ */
9
+ interface ChartBlock {
10
+ type: 'chart';
11
+ title?: string;
12
+ value: ChartValue;
13
+ }
14
+ interface ChartValue {
15
+ chartType: 'line' | 'area' | 'bar' | 'horizontal-bar' | 'pie' | 'donut' | 'sparkline' | 'heatmap';
16
+ data: Record<string, unknown>[];
17
+ xKey: string;
18
+ yKeys: string[];
19
+ title?: string;
20
+ height?: number;
21
+ showLegend?: boolean;
22
+ showGrid?: boolean;
23
+ config?: Record<string, unknown>;
24
+ }
25
+ /**
26
+ * Render a chart block as an HTML string containing an inline SVG.
27
+ * Returns a wrapping `<div class="chart-container">` with optional title and legend.
28
+ */
29
+ declare function renderChartAsHtml(block: ChartBlock): string;
30
+ //#endregion
31
+ export { ChartBlock, ChartValue, renderChartAsHtml };
@@ -0,0 +1,34 @@
1
+ import{escHtml as e}from"./present-utils.js";const t=e;function n(e){return Math.abs(e)>=1e6?`${(e/1e6).toFixed(1).replace(/\.0$/,``)}M`:Math.abs(e)>=1e3?`${(e/1e3).toFixed(1).replace(/\.0$/,``)}k`:Number.isInteger(e)?String(e):e.toFixed(1)}function r(e){return`var(--chart-${e%12+1})`}let i=0;function a(e){let n=e.value;if(!n?.data?.length||!n.chartType)return`<pre>${t(JSON.stringify(e.value,null,2))}</pre>`;i++;let r=e.title||n.title?`<div class="chart-title">${t(String(e.title||n.title))}</div>`:``,a;switch(n.chartType){case`line`:a=m(n,!1);break;case`area`:a=m(n,!0);break;case`bar`:a=h(n,!1);break;case`horizontal-bar`:a=h(n,!0);break;case`pie`:a=g(n,!1);break;case`donut`:a=g(n,!0);break;case`sparkline`:a=_(n);break;case`heatmap`:a=v(n);break;default:a=`<pre>${t(JSON.stringify(n,null,2))}</pre>`}let s=n.showLegend!==!1&&n.yKeys.length>1&&n.chartType!==`sparkline`?o(n.yKeys):``;return`<div class="chart-container">${r}${a}${s}</div>`}function o(e){return`<div class="chart-legend">${e.map((e,n)=>`<span class="chart-legend-item"><span class="chart-legend-swatch" style="background:${r(n)}"></span>${t(e)}</span>`).join(``)}</div>`}const s={top:20,right:20,bottom:35,left:55};function c(e,t){return e.map(e=>Number(e[t])||0)}function l(e,t){return e.map(e=>String(e[t]??``))}function u(e){let t=1/0,n=-1/0;for(let r of e)r<t&&(t=r),r>n&&(n=r);return t===n&&(t=t===0?0:t*.9,n=n===0?1:n*1.1),[t,n]}function d(e){return e>=0?0:e}function f(e,t,r,i=5){let a=[];for(let o=0;o<=i;o++){let c=o/i,l=s.top+r-c*r,u=e+c*(t-e);a.push(`<line class="chart-grid-line" x1="${s.left}" x2="${600-s.right}" y1="${l}" y2="${l}"/>`),a.push(`<text class="chart-axis-label" x="${s.left-8}" y="${l+4}" text-anchor="end">${n(u)}</text>`)}return a.join(``)}function p(e,n,r,i){let a=Math.floor(n/50),o=Math.max(1,Math.ceil(e.length/a));return e.map((e,n)=>n%o===0?`<text class="chart-axis-label" x="${s.left+n*i+i/2}" y="${s.top+r+18}" text-anchor="middle">${t(e.length>10?`${e.slice(0,9)}…`:e)}</text>`:``).join(``)}function m(e,t){let n=(e.height??300)-s.top-s.bottom,a=600-s.left-s.right,o=l(e.data,e.xKey),m=e.data.length;if(m===0)return``;let h=a/Math.max(m-1,1),g=1/0,_=-1/0;for(let t of e.yKeys){let[n,r]=u(c(e.data,t));n<g&&(g=n),r>_&&(_=r)}g=d(g);let v=_-g||1,y=e=>s.top+n-(e-g)/v*n,b=e=>s.left+e*h,x=``,S=[];for(let a=0;a<e.yKeys.length;a++){let o=c(e.data,e.yKeys[a]),l=r(a),u=`M${o.map((e,t)=>`${b(t).toFixed(1)},${y(e).toFixed(1)}`).join(`L`)}`;if(t){let e=`ag${i}_${a}`;x+=`<linearGradient id="${e}" x1="0" y1="0" x2="0" y2="1">
2
+ <stop offset="0%" stop-color="${l}" stop-opacity="0.3"/>
3
+ <stop offset="100%" stop-color="${l}" stop-opacity="0"/>
4
+ </linearGradient>`;let t=`${u}L${b(m-1).toFixed(1)},${(s.top+n).toFixed(1)}L${b(0).toFixed(1)},${(s.top+n).toFixed(1)}Z`;S.push(`<path d="${t}" fill="url(#${e})" stroke="none"/>`)}S.push(`<path d="${u}" fill="none" stroke="${l}" stroke-width="2" stroke-linejoin="round" stroke-linecap="round"/>`);for(let e=0;e<o.length;e++)S.push(`<circle cx="${b(e).toFixed(1)}" cy="${y(o[e]).toFixed(1)}" r="3" fill="${l}" stroke="var(--card)" stroke-width="1.5"/>`)}let C=e.height??300,w=e.showGrid===!1?``:f(g,_,n),T=p(o,a,n,m>1?h:a);return`<svg class="chart-svg" viewBox="0 0 600 ${C}" preserveAspectRatio="xMidYMid meet">
5
+ ${x?`<defs>${x}</defs>`:``}
6
+ ${w}${T}${S.join(``)}
7
+ </svg>`}function h(e,i){let a=(e.height??300)-s.top-s.bottom,o=600-s.left-s.right,u=l(e.data,e.xKey),d=e.data.length;if(d===0)return``;let m=e.yKeys.length,h=0;for(let t of e.yKeys)for(let n of c(e.data,t))n>h&&(h=n);h===0&&(h=1);let g=e.height??300,_=[];if(i){let i=Math.min(24,(a-(d-1)*4)/(d*m)),c=i*m+4,l=e.showGrid===!1?``:f(0,h,a),p=u.map((e,n)=>{let r=s.top+n*c+c/2,i=e.length>15?`${e.slice(0,14)}…`:e;return`<text class="chart-axis-label" x="${s.left-8}" y="${r+4}" text-anchor="end">${t(i)}</text>`}).join(``);for(let a=0;a<d;a++)for(let l=0;l<m;l++){let u=Number(e.data[a][e.yKeys[l]])||0,d=u/h*o,f=s.top+a*c+l*i;_.push(`<rect x="${s.left}" y="${f}" width="${d.toFixed(1)}" height="${i-2}" rx="3" fill="${r(l)}" opacity="0.85">
8
+ <title>${t(e.yKeys[l])}: ${n(u)}</title>
9
+ </rect>`)}return`<svg class="chart-svg" viewBox="0 0 600 ${Math.max(g,d*c+s.top+s.bottom)}" preserveAspectRatio="xMidYMid meet">
10
+ ${l}${p}${_.join(``)}
11
+ </svg>`}else{let i=o/d,c=Math.min(40,(i-8)/m),l=e.showGrid===!1?``:f(0,h,a),v=p(u,o,a,i);for(let o=0;o<d;o++)for(let l=0;l<m;l++){let u=Number(e.data[o][e.yKeys[l]])||0,d=u/h*a,f=s.left+o*i+(i-c*m)/2+l*c,p=s.top+a-d;_.push(`<rect x="${f.toFixed(1)}" y="${p.toFixed(1)}" width="${(c-2).toFixed(1)}" height="${d.toFixed(1)}" rx="3" fill="${r(l)}" opacity="0.85">
12
+ <title>${t(e.yKeys[l])}: ${n(u)}</title>
13
+ </rect>`)}return`<svg class="chart-svg" viewBox="0 0 600 ${g}" preserveAspectRatio="xMidYMid meet">
14
+ ${l}${v}${_.join(``)}
15
+ </svg>`}}function g(e,i){let a=e.height??300,s=a/2,c=a/2,u=a/2-10,d=i?u*.55:0,f=e.yKeys[0]||`value`,p=e.data.map(e=>Math.max(0,Number(e[f])||0)),m=l(e.data,e.xKey),h=p.reduce((e,t)=>e+t,0);if(h===0)return`<div style="color:var(--muted-foreground);text-align:center;padding:20px">No data</div>`;let g=[],_=-Math.PI/2;for(let e=0;e<p.length;e++){let i=p[e]/h;if(i===0)continue;let a=i*Math.PI*2,o=_,l=_+a,f=s+u*Math.cos(o),v=c+u*Math.sin(o),y=s+u*Math.cos(l),b=c+u*Math.sin(l),x=a>Math.PI?1:0,S;if(d>0){let e=s+d*Math.cos(o),t=c+d*Math.sin(o),n=s+d*Math.cos(l),r=c+d*Math.sin(l);S=`M${f.toFixed(2)},${v.toFixed(2)} A${u},${u} 0 ${x},1 ${y.toFixed(2)},${b.toFixed(2)} L${n.toFixed(2)},${r.toFixed(2)} A${d},${d} 0 ${x},0 ${e.toFixed(2)},${t.toFixed(2)}Z`}else S=`M${s},${c} L${f.toFixed(2)},${v.toFixed(2)} A${u},${u} 0 ${x},1 ${y.toFixed(2)},${b.toFixed(2)}Z`;g.push(`<path d="${S}" fill="${r(e)}" stroke="var(--background)" stroke-width="2" opacity="0.9">
16
+ <title>${t(m[e]||`Item ${e+1}`)}: ${n(p[e])} (${(i*100).toFixed(1)}%)</title>
17
+ </path>`),_=l}let v=i?`<text x="${s}" y="${c-6}" text-anchor="middle" fill="var(--foreground)" font-size="18" font-weight="700">${n(h)}</text>
18
+ <text x="${s}" y="${c+12}" text-anchor="middle" fill="var(--muted-foreground)" font-size="11">Total</text>`:``,y=o(m.filter((e,t)=>p[t]>0));return`<svg class="chart-svg" viewBox="0 0 ${a} ${a}" preserveAspectRatio="xMidYMid meet">
19
+ ${g.join(``)}${v}
20
+ </svg>${y}`}function _(e){let t=e.height??40,n=e.yKeys[0]||`value`,a=c(e.data,n),o=a.length;if(o===0)return``;let[s,l]=u(a),d=l-s||1,f=200/Math.max(o-1,1),p=a.map((e,n)=>`${(n*f).toFixed(1)},${(t-4-(e-s)/d*(t-8)).toFixed(1)}`),m=`spk${i}`,h=r(0);return`<svg class="chart-svg" viewBox="0 0 200 ${t}" preserveAspectRatio="xMidYMid meet" style="max-width:200px;height:${t}px">
21
+ <defs>
22
+ <linearGradient id="${m}" x1="0" y1="0" x2="0" y2="1">
23
+ <stop offset="0%" stop-color="${h}" stop-opacity="0.2"/>
24
+ <stop offset="100%" stop-color="${h}" stop-opacity="0"/>
25
+ </linearGradient>
26
+ </defs>
27
+ <path d="M${p.join(`L`)}L${((o-1)*f).toFixed(1)},${t}L0,${t}Z" fill="url(#${m})" stroke="none"/>
28
+ <polyline points="${p.join(` `)}" fill="none" stroke="${h}" stroke-width="1.5" stroke-linejoin="round"/>
29
+ <circle cx="${((o-1)*f).toFixed(1)}" cy="${p[o-1].split(`,`)[1]}" r="2.5" fill="${h}"/>
30
+ </svg>`}function v(e){let r=l(e.data,e.xKey),i=e.data.length,a=e.yKeys.length;if(i===0||a===0)return``;let o=1/0,u=-1/0;for(let t of e.yKeys)for(let n of c(e.data,t))n<o&&(o=n),n>u&&(u=n);let d=u-o||1,f=Math.min(50,(600-s.left-s.right)/i),p=Math.min(30,200/a),m=s.left+i*f+s.right,h=s.top+a*p+s.bottom,g=[];for(let n=0;n<a;n++){let r=s.top+n*p+p/2+4,i=e.yKeys[n].length>8?`${e.yKeys[n].slice(0,7)}…`:e.yKeys[n];g.push(`<text class="chart-axis-label" x="${s.left-8}" y="${r}" text-anchor="end">${t(i)}</text>`)}let _=Math.floor((m-s.left)/40),v=Math.max(1,Math.ceil(i/_));for(let e=0;e<i;e++){if(e%v!==0)continue;let n=s.left+e*f+f/2,i=r[e].length>6?`${r[e].slice(0,5)}…`:r[e];g.push(`<text class="chart-axis-label" x="${n}" y="${h-8}" text-anchor="middle">${t(i)}</text>`)}for(let c=0;c<i;c++)for(let i=0;i<a;i++){let a=Number(e.data[c][e.yKeys[i]])||0,l=(a-o)/d,u=s.left+c*f,m=s.top+i*p;g.push(`<rect x="${u}" y="${m}" width="${f-1}" height="${p-1}" rx="2" fill="var(--primary)" opacity="${(.1+l*.8).toFixed(2)}">
31
+ <title>${t(r[c])} / ${t(e.yKeys[i])}: ${n(a)}</title>
32
+ </rect>`)}return`<svg class="chart-svg" viewBox="0 0 ${m} ${h}" preserveAspectRatio="xMidYMid meet">
33
+ ${g.join(``)}
34
+ </svg>`}export{a as renderChartAsHtml};
@@ -0,0 +1,14 @@
1
+ //#region packages/server/src/tools/present-theme.d.ts
2
+ /**
3
+ * Present Design System — CSS tokens and component styles.
4
+ *
5
+ * Based on notification-dashboard design tokens.
6
+ * Dark mode by default, professional clean aesthetic.
7
+ * Font: Plus Jakarta Sans via Google Fonts CDN.
8
+ */
9
+ /** Google Fonts <link> tag to inject into <head>. */
10
+ declare const FONT_LINK = "<link href=\"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap\" rel=\"stylesheet\">";
11
+ /** Returns the full design system CSS string for browser-mode HTML pages. */
12
+ declare function getDesignSystemCSS(): string;
13
+ //#endregion
14
+ export { FONT_LINK, getDesignSystemCSS };
@@ -0,0 +1,395 @@
1
+ const e=`<link href="https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap" rel="stylesheet">`;function t(){return`
2
+ /* ── Reset ────────────────────────────────────────────────────────── */
3
+ *{box-sizing:border-box;margin:0;padding:0}
4
+
5
+ /* ── Design Tokens ────────────────────────────────────────────────── */
6
+ :root{
7
+ /* Background hierarchy */
8
+ --background:#0f1419;
9
+ --background-subtle:#141b24;
10
+ --foreground:#e2e8f0;
11
+ --card:#1a2332;
12
+ --card-foreground:#e2e8f0;
13
+
14
+ /* Semantic colors */
15
+ --primary:#818cf8;
16
+ --primary-glow:rgba(129,140,248,.15);
17
+ --primary-foreground:#1e1b4b;
18
+ --secondary:#2a3549;
19
+ --secondary-foreground:#e2e8f0;
20
+ --muted:#2a3549;
21
+ --muted-foreground:#94a3b8;
22
+ --accent:#1e293b;
23
+ --accent-foreground:#a5b4fc;
24
+ --destructive:#f87171;
25
+ --border:rgba(148,163,184,.12);
26
+ --border-subtle:rgba(148,163,184,.06);
27
+ --input:#384766;
28
+ --ring:#6366f1;
29
+
30
+ /* Status colors */
31
+ --success:#10b981;
32
+ --success-light:#34d399;
33
+ --warning:#f59e0b;
34
+ --warning-light:#fbbf24;
35
+ --error:#ef4444;
36
+ --error-light:#f87171;
37
+ --info:#0ea5e9;
38
+ --info-light:#38bdf8;
39
+
40
+ /* Chart palette */
41
+ --chart-1:#818cf8;
42
+ --chart-2:#38bdf8;
43
+ --chart-3:#34d399;
44
+ --chart-4:#fbbf24;
45
+ --chart-5:#f87171;
46
+ --chart-6:#a78bfa;
47
+ --chart-7:#f472b6;
48
+ --chart-8:#2dd4bf;
49
+ --chart-9:#fb923c;
50
+ --chart-10:#22d3ee;
51
+ --chart-11:#c084fc;
52
+ --chart-12:#a3e635;
53
+ --chart-others:#a8a29e;
54
+ --chart-gradient-start:0.3;
55
+ --chart-gradient-end:0;
56
+
57
+ /* Layout */
58
+ --radius:0.625rem;
59
+ --shadow:0 4px 24px rgba(0,0,0,.25);
60
+ --shadow-sm:0 1px 3px rgba(0,0,0,.2);
61
+ }
62
+
63
+ /* ── Base ─────────────────────────────────────────────────────────── */
64
+ body{
65
+ font-family:'Plus Jakarta Sans',ui-sans-serif,system-ui,-apple-system,sans-serif;
66
+ background:var(--background);color:var(--foreground);
67
+ min-height:100vh;padding:0;line-height:1.6;font-size:14px;
68
+ -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
69
+ background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(129,140,248,.08),transparent);
70
+ }
71
+
72
+ /* ── Animations ───────────────────────────────────────────────────── */
73
+ @keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
74
+ @keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
75
+
76
+ /* ── Layout ───────────────────────────────────────────────────────── */
77
+ .dashboard{max-width:1200px;margin:0 auto;padding:40px 28px}
78
+
79
+ /* ── Header ───────────────────────────────────────────────────────── */
80
+ .header{
81
+ padding:28px 0;margin-bottom:32px;
82
+ border-bottom:1px solid var(--border);
83
+ position:relative;
84
+ }
85
+ .header::after{
86
+ content:'';position:absolute;bottom:-1px;left:0;width:120px;height:2px;
87
+ background:linear-gradient(90deg,var(--primary),transparent);
88
+ }
89
+ .header h1{
90
+ font-size:1.75em;font-weight:700;color:var(--foreground);
91
+ letter-spacing:-0.03em;line-height:1.2;
92
+ }
93
+ .header .subtitle{
94
+ color:var(--muted-foreground);font-size:.88em;margin-top:6px;font-weight:400;
95
+ letter-spacing:.01em;
96
+ }
97
+
98
+ /* ── Section headings ─────────────────────────────────────────────── */
99
+ h2{
100
+ font-size:1.1em;margin:32px 0 16px;color:var(--foreground);font-weight:600;
101
+ display:flex;align-items:center;gap:10px;letter-spacing:-0.01em;
102
+ animation:fadeInUp .4s ease both;
103
+ }
104
+ h2::before{
105
+ content:'';width:3px;height:16px;background:linear-gradient(180deg,var(--primary),rgba(129,140,248,.3));border-radius:2px;flex-shrink:0;
106
+ }
107
+ h3{font-size:1em;margin:16px 0 8px;color:var(--foreground);font-weight:600}
108
+
109
+ /* ── Rendered markdown content ────────────────────────────────────── */
110
+ .md-content{line-height:1.7;margin:12px 0}
111
+ .md-content h1{font-size:1.4em;font-weight:700;margin:24px 0 12px;color:var(--foreground);letter-spacing:-0.02em}
112
+ .md-content h2{font-size:1.2em;margin:20px 0 10px;color:var(--foreground);display:block}
113
+ .md-content h2::before{display:none}
114
+ .md-content h3{font-size:1.05em;margin:16px 0 8px;color:var(--foreground)}
115
+ .md-content h4{font-size:.95em;margin:12px 0 6px;color:var(--foreground);font-weight:600}
116
+ .md-content p{margin:8px 0;color:var(--foreground)}
117
+ .md-content strong{color:var(--foreground);font-weight:600}
118
+ .md-content em{color:var(--muted-foreground);font-style:italic}
119
+ .md-content a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}
120
+ .md-content a:hover{color:var(--accent-foreground)}
121
+ .md-content ul,.md-content ol{padding-left:24px;margin:8px 0}
122
+ .md-content li{margin:4px 0;color:var(--foreground)}
123
+ .md-content li::marker{color:var(--muted-foreground)}
124
+ .md-content blockquote{
125
+ border-left:3px solid var(--primary);padding:10px 16px;margin:12px 0;
126
+ color:var(--muted-foreground);background:var(--card);border-radius:0 var(--radius) var(--radius) 0;
127
+ }
128
+ .md-content pre{
129
+ background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
130
+ padding:16px;overflow-x:auto;margin:12px 0;
131
+ }
132
+ .md-content code{font-family:'JetBrains Mono','Cascadia Code','Fira Code',monospace;font-size:.88em}
133
+ .md-content :not(pre)>code{background:var(--accent);padding:2px 6px;border-radius:4px;font-size:.85em;color:var(--accent-foreground)}
134
+ .md-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}
135
+ .md-content th{
136
+ background:var(--accent);padding:10px 14px;text-align:left;font-weight:600;
137
+ color:var(--muted-foreground);border-bottom:2px solid var(--border);font-size:.8em;
138
+ text-transform:uppercase;letter-spacing:.5px;
139
+ }
140
+ .md-content td{padding:8px 14px;border-bottom:1px solid var(--border);color:var(--foreground)}
141
+ .md-content tr:hover td{background:rgba(129,140,248,.04)}
142
+ .md-content hr{border:none;border-top:1px solid var(--border);margin:24px 0}
143
+ .md-content img{max-width:100%;border-radius:var(--radius)}
144
+
145
+ /* ── Metrics grid ─────────────────────────────────────────────────── */
146
+ .metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:14px 0 28px}
147
+ .metric{
148
+ background:linear-gradient(135deg,var(--card),var(--accent));
149
+ border:1px solid var(--border);border-radius:var(--radius);
150
+ padding:22px 18px;text-align:center;transition:all .2s ease;position:relative;overflow:hidden;
151
+ animation:fadeInUp .4s ease both;
152
+ }
153
+ .metric::before{
154
+ content:'';position:absolute;top:0;left:0;right:0;height:2px;
155
+ background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:0;
156
+ transition:opacity .2s ease;
157
+ }
158
+ .metric:hover{border-color:rgba(129,140,248,.3);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.2)}
159
+ .metric:hover::before{opacity:1}
160
+ .metric-value{
161
+ font-size:1.8em;font-weight:700;color:var(--primary);
162
+ font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
163
+ }
164
+ .metric-label{
165
+ font-size:.75em;color:var(--muted-foreground);margin-top:6px;
166
+ text-transform:uppercase;letter-spacing:.6px;font-weight:500;
167
+ }
168
+
169
+ /* ── Cards grid ───────────────────────────────────────────────────── */
170
+ .card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin:14px 0 28px}
171
+ .card{
172
+ background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
173
+ padding:20px;transition:all .2s ease;position:relative;overflow:hidden;
174
+ animation:fadeInUp .4s ease both;
175
+ }
176
+ .card::after{
177
+ content:'';position:absolute;top:0;left:0;width:3px;height:0;
178
+ background:var(--primary);transition:height .2s ease;border-radius:0 0 2px 0;
179
+ }
180
+ .card:hover{border-color:rgba(129,140,248,.2);box-shadow:0 4px 20px rgba(0,0,0,.15);transform:translateY(-1px)}
181
+ .card:hover::after{height:100%}
182
+ .card-title{font-weight:600;font-size:.98em;margin-bottom:8px;color:var(--foreground)}
183
+ .card-body{color:var(--muted-foreground);font-size:.88em;line-height:1.55}
184
+ .badge{
185
+ display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;
186
+ font-size:.75em;font-weight:600;margin-top:10px;
187
+ background:rgba(129,140,248,.1);color:var(--primary);border:1px solid rgba(129,140,248,.15);
188
+ }
189
+
190
+ /* ── Table ─────────────────────────────────────────────────────────── */
191
+ .table-wrap{
192
+ overflow-x:auto;margin:14px 0 28px;border-radius:var(--radius);border:1px solid var(--border);
193
+ background:var(--card);animation:fadeInUp .4s ease both;
194
+ }
195
+ table{width:100%;border-collapse:collapse;font-size:13px}
196
+ thead{position:sticky;top:0;z-index:1}
197
+ th{
198
+ background:var(--accent);padding:12px 16px;text-align:left;font-weight:600;
199
+ color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.5px;font-size:.72em;
200
+ border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap;
201
+ transition:color .15s;
202
+ }
203
+ th:hover{color:var(--primary)}
204
+ td{padding:10px 16px;border-bottom:1px solid var(--border-subtle);color:var(--foreground)}
205
+ tr:hover td{background:rgba(129,140,248,.04)}
206
+ .tool-name{font-family:'JetBrains Mono','Cascadia Code',monospace;font-size:.85em;color:var(--primary);font-weight:500}
207
+ .category-tag{
208
+ display:inline-flex;padding:2px 8px;border-radius:6px;font-size:.8em;font-weight:500;
209
+ background:var(--accent);color:var(--muted-foreground);border:1px solid var(--border);white-space:nowrap;
210
+ }
211
+
212
+ /* ── Code blocks ──────────────────────────────────────────────────── */
213
+ pre{
214
+ background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
215
+ padding:16px;overflow-x:auto;font-size:13px;margin:12px 0;
216
+ }
217
+ code{font-family:'JetBrains Mono','Cascadia Code','Fira Code',monospace;font-size:.9em}
218
+ blockquote{
219
+ border-left:3px solid var(--primary);padding:10px 16px;color:var(--muted-foreground);
220
+ margin:12px 0;background:var(--card);border-radius:0 var(--radius) var(--radius) 0;
221
+ }
222
+ ul,ol{padding-left:24px;margin:8px 0}
223
+ li{margin:4px 0}
224
+ .tree-node{padding:3px 0}
225
+ .tree-key{font-weight:600;color:var(--primary)}
226
+ .tree-children{margin-left:20px;border-left:2px solid var(--border);padding-left:12px}
227
+
228
+ /* ── Mermaid ──────────────────────────────────────────────────────── */
229
+ .mermaid{background:transparent !important;border:none !important}
230
+
231
+ /* ── Charts ───────────────────────────────────────────────────────── */
232
+ .chart-container{
233
+ background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
234
+ padding:24px;margin:14px 0 28px;overflow:hidden;animation:fadeInUp .4s ease both;
235
+ }
236
+ .chart-title{font-size:.95em;font-weight:600;color:var(--foreground);margin-bottom:14px}
237
+ .chart-svg{width:100%;display:block}
238
+ .chart-legend{
239
+ display:flex;flex-wrap:wrap;gap:14px;margin-top:14px;padding-top:12px;
240
+ border-top:1px solid var(--border);
241
+ }
242
+ .chart-legend-item{display:flex;align-items:center;gap:6px;font-size:.8em;color:var(--muted-foreground)}
243
+ .chart-legend-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}
244
+ .chart-tooltip{
245
+ position:absolute;background:var(--card);border:1px solid var(--border);
246
+ border-radius:6px;padding:8px 12px;font-size:.8em;pointer-events:none;
247
+ box-shadow:var(--shadow);z-index:10;display:none;color:var(--foreground);
248
+ }
249
+ .chart-axis-label{font-size:.7em;fill:var(--muted-foreground);font-family:inherit}
250
+ .chart-grid-line{stroke:var(--border);stroke-dasharray:3,3;stroke-width:0.5}
251
+
252
+ /* ── Timeline ─────────────────────────────────────────────────────── */
253
+ .timeline{margin:14px 0 28px;padding-left:28px;border-left:2px solid var(--border);position:relative;animation:fadeInUp .4s ease both}
254
+ .timeline-item{position:relative;padding:0 0 28px 22px}
255
+ .timeline-item:last-child{padding-bottom:0}
256
+ .timeline-dot{
257
+ position:absolute;left:-33px;top:4px;width:12px;height:12px;
258
+ border-radius:50%;border:2px solid var(--border);background:var(--background);
259
+ transition:all .2s ease;
260
+ }
261
+ .timeline-dot.done{background:var(--success);border-color:var(--success);box-shadow:0 0 8px rgba(16,185,129,.3)}
262
+ .timeline-dot.active{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 4px rgba(129,140,248,.15)}
263
+ .timeline-dot.pending{background:var(--muted);border-color:var(--muted-foreground)}
264
+ .timeline-dot.error{background:var(--error);border-color:var(--error);box-shadow:0 0 8px rgba(239,68,68,.3)}
265
+ .timeline-phase{font-size:.7em;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:2px}
266
+ .timeline-title{font-weight:600;color:var(--foreground);font-size:.95em}
267
+ .timeline-desc{color:var(--muted-foreground);font-size:.85em;margin-top:4px;line-height:1.5}
268
+
269
+ /* ── Checklist ────────────────────────────────────────────────────── */
270
+ .checklist{margin:14px 0 28px}
271
+ .checklist-item{
272
+ display:flex;align-items:flex-start;gap:10px;padding:10px 14px;
273
+ border-radius:var(--radius);transition:background .1s;
274
+ }
275
+ .checklist-item:hover{background:var(--accent)}
276
+ .checklist-check{
277
+ width:18px;height:18px;border-radius:4px;border:2px solid var(--border);
278
+ flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;
279
+ font-size:11px;color:transparent;
280
+ }
281
+ .checklist-check.checked{background:var(--success);border-color:var(--success);color:#fff}
282
+ .checklist-label{color:var(--foreground);font-size:.9em;font-weight:500}
283
+ .checklist-item.checked .checklist-label{color:var(--muted-foreground);text-decoration:line-through}
284
+ .checklist-note{font-size:.8em;color:var(--muted-foreground);margin-top:2px}
285
+
286
+ /* ── Comparison grid ──────────────────────────────────────────────── */
287
+ .comparison-grid{
288
+ display:grid;gap:0;margin:14px 0 28px;border:1px solid var(--border);
289
+ border-radius:var(--radius);overflow:hidden;
290
+ }
291
+ .comparison-col{min-width:0}
292
+ .comparison-col:not(:last-child){border-right:1px solid var(--border)}
293
+ .comparison-header{
294
+ padding:14px 16px;font-weight:600;font-size:.9em;color:var(--foreground);
295
+ background:var(--accent);border-bottom:2px solid var(--border);text-align:center;
296
+ }
297
+ .comparison-item{
298
+ padding:10px 16px;border-bottom:1px solid var(--border);font-size:.88em;
299
+ color:var(--foreground);min-height:40px;display:flex;align-items:center;
300
+ }
301
+ .comparison-item:last-child{border-bottom:none}
302
+
303
+ /* ── Status board ─────────────────────────────────────────────────── */
304
+ .status-board{display:flex;flex-direction:column;gap:8px;margin:14px 0 28px}
305
+ .status-row{
306
+ display:flex;align-items:center;gap:12px;padding:10px 14px;
307
+ background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
308
+ }
309
+ .status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}
310
+ .status-indicator.success{background:var(--success)}
311
+ .status-indicator.warning{background:var(--warning)}
312
+ .status-indicator.error{background:var(--error)}
313
+ .status-indicator.info{background:var(--info)}
314
+ .status-indicator.pending{background:var(--muted-foreground)}
315
+ .status-label{font-weight:500;font-size:.9em;color:var(--foreground);flex:1}
316
+ .status-detail{font-size:.8em;color:var(--muted-foreground)}
317
+
318
+ /* ── Progress bars ────────────────────────────────────────────────── */
319
+ .progress-list{display:flex;flex-direction:column;gap:12px;margin:14px 0 28px}
320
+ .progress-item{display:flex;flex-direction:column;gap:4px}
321
+ .progress-header{display:flex;justify-content:space-between;align-items:baseline}
322
+ .progress-label{font-size:.88em;font-weight:500;color:var(--foreground)}
323
+ .progress-value{font-size:.8em;color:var(--muted-foreground);font-variant-numeric:tabular-nums}
324
+ .progress-track{
325
+ height:6px;background:var(--accent);border-radius:3px;overflow:hidden;
326
+ }
327
+ .progress-fill{
328
+ height:100%;border-radius:3px;transition:width .3s ease;
329
+ }
330
+
331
+ /* ── Prompt / Question block ──────────────────────────────────────── */
332
+ .prompt-block{
333
+ background:var(--card);border:1px solid var(--primary);border-radius:var(--radius);
334
+ padding:20px;margin:14px 0 28px;
335
+ }
336
+ .prompt-question{font-size:1.05em;font-weight:600;color:var(--foreground);margin-bottom:8px}
337
+ .prompt-context{font-size:.88em;color:var(--muted-foreground);line-height:1.6;margin-bottom:12px}
338
+ .prompt-placeholder{
339
+ padding:10px 14px;background:var(--accent);border:1px dashed var(--border);
340
+ border-radius:var(--radius);color:var(--muted-foreground);font-size:.85em;font-style:italic;
341
+ }
342
+
343
+ /* ── Actions ──────────────────────────────────────────────────────── */
344
+ .actions-bar{margin:32px 0}
345
+ .actions-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
346
+ .action-group{display:flex;flex-direction:column;gap:6px}
347
+ .action-group label{font-size:.85em;color:var(--muted-foreground);font-weight:500}
348
+ .action-group select{
349
+ padding:9px 14px;background:var(--card);border:1px solid var(--border);
350
+ border-radius:var(--radius);color:var(--foreground);font-size:.9em;cursor:pointer;min-width:200px;
351
+ font-family:inherit;
352
+ }
353
+ .action-group select:hover{border-color:var(--primary)}
354
+ .action-btn{
355
+ padding:10px 22px;border:1px solid var(--border);border-radius:var(--radius);
356
+ font-size:.88em;font-weight:600;cursor:pointer;transition:all .2s ease;
357
+ background:var(--card);color:var(--foreground);font-family:inherit;
358
+ }
359
+ .action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
360
+ .action-primary{background:linear-gradient(135deg,var(--primary),#6366f1);color:var(--primary-foreground);border-color:transparent}
361
+ .action-primary:hover{opacity:.9;box-shadow:0 4px 20px rgba(129,140,248,.3)}
362
+ .action-danger{background:var(--error);color:#fff;border-color:var(--error)}
363
+ .action-danger:hover{opacity:.9}
364
+ .action-default:hover{border-color:var(--primary);color:var(--primary)}
365
+ .action-feedback{
366
+ margin-top:14px;padding:10px 16px;border-radius:var(--radius);
367
+ display:none;font-weight:500;font-size:.9em;
368
+ }
369
+ .action-feedback.sent{
370
+ display:block;background:rgba(16,185,129,.1);color:var(--success);
371
+ border:1px solid rgba(16,185,129,.2);
372
+ }
373
+
374
+ /* ── Footer ───────────────────────────────────────────────────────── */
375
+ .footer{
376
+ text-align:center;padding:24px;color:var(--muted-foreground);font-size:.75em;
377
+ border-top:1px solid var(--border);margin-top:48px;letter-spacing:.02em;
378
+ }
379
+
380
+ /* ── Search filter (injected for tables) ──────────────────────────── */
381
+ .search-bar{display:flex;gap:12px;margin-bottom:14px;align-items:center}
382
+ .search-bar input{
383
+ flex:1;padding:9px 14px;background:var(--card);border:1px solid var(--border);
384
+ border-radius:var(--radius);color:var(--foreground);font-size:.9em;outline:none;
385
+ transition:border-color .15s;font-family:inherit;
386
+ }
387
+ .search-bar input:focus{border-color:var(--primary)}
388
+ .search-bar .count{color:var(--muted-foreground);font-size:.85em;white-space:nowrap}
389
+
390
+ /* ── Scrollbar ────────────────────────────────────────────────────── */
391
+ ::-webkit-scrollbar{width:6px;height:6px}
392
+ ::-webkit-scrollbar-track{background:var(--card)}
393
+ ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
394
+ ::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}
395
+ `}export{e as FONT_LINK,t as getDesignSystemCSS};
@@ -0,0 +1,11 @@
1
+ //#region packages/server/src/tools/present-utils.d.ts
2
+ /**
3
+ * Shared HTML utility functions for the Present tool family.
4
+ *
5
+ * Used by present.tool.ts, present-charts.ts, and present-blocks.ts
6
+ * to avoid duplicating escape logic across modules.
7
+ */
8
+ /** HTML-escape a string for safe insertion into HTML content and attributes. */
9
+ declare function escHtml(s: string): string;
10
+ //#endregion
11
+ export { escHtml };
@@ -0,0 +1 @@
1
+ function e(e){return e.replace(/&/g,`&amp;`).replace(/</g,`&lt;`).replace(/>/g,`&gt;`).replace(/"/g,`&quot;`)}export{e as escHtml};
@@ -0,0 +1,7 @@
1
+ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
2
+ import { Elicitor } from "@kb/elicitation";
3
+
4
+ //#region packages/server/src/tools/present.tool.d.ts
5
+ declare function registerPresentTool(server: McpServer, elicitor?: Elicitor): void;
6
+ //#endregion
7
+ export { registerPresentTool };