@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.
- package/README.md +3 -3
- package/package.json +9 -2
- package/packages/analyzers/dist/symbol-analyzer.js +5 -5
- package/packages/cli/dist/commands/init/adapters.js +1 -1
- package/packages/cli/dist/commands/init/constants.d.ts +4 -1
- package/packages/cli/dist/commands/init/constants.js +1 -1
- package/packages/cli/dist/commands/init/frontmatter.d.ts +54 -0
- package/packages/cli/dist/commands/init/frontmatter.js +2 -0
- package/packages/cli/dist/commands/init/index.js +4 -4
- package/packages/cli/dist/commands/init/manifest.d.ts +71 -0
- package/packages/cli/dist/commands/init/manifest.js +1 -0
- package/packages/cli/dist/commands/init/scaffold.d.ts +28 -5
- package/packages/cli/dist/commands/init/scaffold.js +1 -1
- package/packages/cli/dist/commands/init/templates.js +38 -9
- package/packages/cli/dist/commands/init/user.d.ts +3 -3
- package/packages/cli/dist/commands/init/user.js +4 -4
- package/packages/cli/dist/commands/system.js +2 -2
- package/packages/cli/dist/kb-init.js +1 -1
- package/packages/core/dist/errors.d.ts +2 -2
- package/packages/core/dist/errors.js +1 -1
- package/packages/core/dist/logger.d.ts +2 -1
- package/packages/core/dist/logger.js +1 -1
- package/packages/core/dist/types.d.ts +6 -0
- package/packages/dashboard/dist/assets/index-9ysCkze9.js +21 -0
- package/packages/dashboard/dist/assets/index-9ysCkze9.js.map +1 -0
- package/packages/dashboard/dist/assets/index-CHpVij2M.css +1 -0
- package/packages/dashboard/dist/index.html +18 -0
- package/packages/elicitation/dist/__tests__/build.test.d.ts +1 -0
- package/packages/elicitation/dist/__tests__/build.test.js +35 -0
- package/packages/elicitation/dist/__tests__/fields.test.d.ts +1 -0
- package/packages/elicitation/dist/__tests__/fields.test.js +81 -0
- package/packages/elicitation/dist/__tests__/normalize.test.d.ts +1 -0
- package/packages/elicitation/dist/__tests__/normalize.test.js +60 -0
- package/packages/elicitation/dist/build.d.ts +13 -0
- package/packages/elicitation/dist/build.js +23 -0
- package/packages/elicitation/dist/fields.d.ts +41 -0
- package/packages/elicitation/dist/fields.js +62 -0
- package/packages/elicitation/dist/index.d.ts +10 -0
- package/packages/elicitation/dist/index.js +12 -0
- package/packages/elicitation/dist/normalize.d.ts +15 -0
- package/packages/elicitation/dist/normalize.js +31 -0
- package/packages/elicitation/dist/types.d.ts +85 -0
- package/packages/elicitation/dist/types.js +8 -0
- package/packages/kb-client/dist/direct-client.d.ts +37 -0
- package/packages/kb-client/dist/direct-client.js +1 -0
- package/packages/kb-client/dist/index.d.ts +5 -0
- package/packages/kb-client/dist/index.js +1 -0
- package/packages/kb-client/dist/mcp-client.d.ts +19 -0
- package/packages/kb-client/dist/mcp-client.js +4 -0
- package/packages/kb-client/dist/parsers.d.ts +35 -0
- package/packages/kb-client/dist/parsers.js +2 -0
- package/packages/kb-client/dist/types.d.ts +62 -0
- package/packages/kb-client/dist/types.js +1 -0
- package/packages/present/dist/index.html +384 -0
- package/packages/server/dist/completions.d.ts +14 -0
- package/packages/server/dist/completions.js +1 -0
- package/packages/server/dist/dashboard-static.d.ts +27 -0
- package/packages/server/dist/dashboard-static.js +1 -0
- package/packages/server/dist/elicitor.d.ts +18 -0
- package/packages/server/dist/elicitor.js +1 -0
- package/packages/server/dist/index.js +1 -1
- package/packages/server/dist/mcp-logging.js +1 -1
- package/packages/server/dist/output-schemas.d.ts +118 -1
- package/packages/server/dist/output-schemas.js +1 -1
- package/packages/server/dist/prompts.d.ts +9 -2
- package/packages/server/dist/prompts.js +13 -7
- package/packages/server/dist/resources/curated-resources.js +1 -1
- package/packages/server/dist/resources/resource-notifier.d.ts +45 -0
- package/packages/server/dist/resources/resource-notifier.js +1 -0
- package/packages/server/dist/sampling.d.ts +41 -0
- package/packages/server/dist/sampling.js +2 -0
- package/packages/server/dist/server.d.ts +5 -2
- package/packages/server/dist/server.js +2 -2
- package/packages/server/dist/task-manager.d.ts +40 -0
- package/packages/server/dist/task-manager.js +1 -0
- package/packages/server/dist/tool-metadata.js +1 -1
- package/packages/server/dist/tool-prefix.d.ts +12 -0
- package/packages/server/dist/tool-prefix.js +1 -0
- package/packages/server/dist/tools/analyze.tools.js +4 -4
- package/packages/server/dist/tools/audit.tool.js +1 -1
- package/packages/server/dist/tools/brainstorm.tool.d.ts +7 -0
- package/packages/server/dist/tools/brainstorm.tool.js +9 -0
- package/packages/server/dist/tools/context.tools.js +9 -9
- package/packages/server/dist/tools/execution.tools.d.ts +2 -1
- package/packages/server/dist/tools/execution.tools.js +4 -4
- package/packages/server/dist/tools/forge.tools.js +10 -10
- package/packages/server/dist/tools/forget.tool.d.ts +2 -1
- package/packages/server/dist/tools/forget.tool.js +1 -1
- package/packages/server/dist/tools/graph.tool.js +2 -2
- package/packages/server/dist/tools/manipulation.tools.js +4 -4
- package/packages/server/dist/tools/onboard.tool.js +2 -2
- package/packages/server/dist/tools/present-blocks.d.ts +46 -0
- package/packages/server/dist/tools/present-blocks.js +27 -0
- package/packages/server/dist/tools/present-charts.d.ts +31 -0
- package/packages/server/dist/tools/present-charts.js +34 -0
- package/packages/server/dist/tools/present-theme.d.ts +14 -0
- package/packages/server/dist/tools/present-theme.js +395 -0
- package/packages/server/dist/tools/present-utils.d.ts +11 -0
- package/packages/server/dist/tools/present-utils.js +1 -0
- package/packages/server/dist/tools/present.tool.d.ts +7 -0
- package/packages/server/dist/tools/present.tool.js +113 -0
- package/packages/server/dist/tools/produce.tool.js +2 -2
- package/packages/server/dist/tools/reindex.tool.d.ts +2 -1
- package/packages/server/dist/tools/reindex.tool.js +2 -2
- package/packages/server/dist/tools/remember.tool.d.ts +2 -1
- package/packages/server/dist/tools/remember.tool.js +2 -2
- package/packages/server/dist/tools/replay.tool.js +1 -1
- package/packages/server/dist/tools/search.tool.d.ts +2 -1
- package/packages/server/dist/tools/search.tool.js +5 -4
- package/packages/server/dist/tools/status.tool.js +2 -2
- package/packages/server/dist/tools/update.tool.d.ts +2 -1
- package/packages/server/dist/tools/update.tool.js +1 -1
- package/packages/server/dist/tools/utility.tools.js +1 -1
- package/packages/tools/dist/batch.js +1 -1
- package/packages/tools/dist/checkpoint.js +1 -1
- package/packages/tools/dist/config-extractor.d.ts +9 -0
- package/packages/tools/dist/config-extractor.js +7 -0
- package/packages/tools/dist/dead-symbols.js +2 -2
- package/packages/tools/dist/diagram-builder.d.ts +9 -0
- package/packages/tools/dist/diagram-builder.js +9 -0
- package/packages/tools/dist/evidence-map.d.ts +12 -1
- package/packages/tools/dist/evidence-map.js +2 -2
- package/packages/tools/dist/find-examples.js +2 -2
- package/packages/tools/dist/forge-classify.d.ts +4 -0
- package/packages/tools/dist/forge-classify.js +1 -1
- package/packages/tools/dist/git-context.d.ts +1 -0
- package/packages/tools/dist/git-context.js +3 -3
- package/packages/tools/dist/index.d.ts +3 -2
- package/packages/tools/dist/index.js +1 -1
- package/packages/tools/dist/onboard-utils.d.ts +12 -0
- package/packages/tools/dist/onboard-utils.js +1 -0
- package/packages/tools/dist/onboard.js +2 -21
- package/packages/tools/dist/regex-utils.d.ts +8 -0
- package/packages/tools/dist/regex-utils.js +1 -0
- package/packages/tools/dist/rename.js +2 -2
- package/packages/tools/dist/replay.d.ts +2 -1
- package/packages/tools/dist/replay.js +4 -4
- package/packages/tools/dist/symbol.js +3 -3
- package/packages/tools/dist/synthesis-engine.d.ts +13 -0
- package/packages/tools/dist/synthesis-engine.js +6 -0
- package/packages/tools/dist/trace.js +2 -2
- package/packages/tui/dist/App-DXY0-tlW.js +2 -0
- package/packages/tui/dist/App.d.ts +3 -3
- package/packages/tui/dist/App.js +1 -1
- package/packages/tui/dist/CuratedPanel-BIamXLNy.js +2 -0
- package/packages/tui/dist/LogPanel-D6u6o84n.js +3 -0
- package/packages/tui/dist/SearchPanel-CpJGczAc.js +2 -0
- package/packages/tui/dist/StatusPanel-BAbUxyqQ.js +2 -0
- package/packages/tui/dist/hooks/useKBClient.d.ts +9 -0
- package/packages/tui/dist/hooks/useKBClient.js +2 -0
- package/packages/tui/dist/hooks/usePolling.d.ts +8 -0
- package/packages/tui/dist/hooks/usePolling.js +2 -0
- package/packages/tui/dist/index.d.ts +6 -2
- package/packages/tui/dist/index.js +1 -1
- package/packages/tui/dist/jsx-runtime-y6Gdq5PZ.js +294 -0
- package/packages/tui/dist/panels/CuratedPanel.d.ts +1 -7
- package/packages/tui/dist/panels/CuratedPanel.js +1 -1
- package/packages/tui/dist/panels/LogPanel.js +1 -1
- package/packages/tui/dist/panels/SearchPanel.d.ts +1 -10
- package/packages/tui/dist/panels/SearchPanel.js +1 -1
- package/packages/tui/dist/panels/StatusPanel.d.ts +1 -7
- package/packages/tui/dist/panels/StatusPanel.js +1 -1
- package/packages/tui/dist/react-D__J1GQe.js +24 -0
- package/packages/tui/dist/types-VcTHNV6s.d.ts +64 -0
- package/packages/tui/dist/useKBClient-C35iA4uG.js +2 -0
- package/packages/tui/dist/usePolling-BbjnRWgx.js +2 -0
- package/scaffold/adapters/copilot.mjs +9 -81
- package/scaffold/definitions/agents.mjs +12 -0
- package/scaffold/definitions/bodies.mjs +39 -14
- package/scaffold/definitions/protocols.mjs +149 -0
- package/scaffold/definitions/tools.mjs +40 -5
- package/scaffold/general/agents/Architect-Reviewer-Alpha.agent.md +1 -1
- package/scaffold/general/agents/Architect-Reviewer-Beta.agent.md +1 -1
- package/scaffold/general/agents/Code-Reviewer-Alpha.agent.md +1 -1
- package/scaffold/general/agents/Code-Reviewer-Beta.agent.md +1 -1
- package/scaffold/general/agents/Debugger.agent.md +2 -2
- package/scaffold/general/agents/Documenter.agent.md +2 -2
- package/scaffold/general/agents/Explorer.agent.md +4 -3
- package/scaffold/general/agents/Frontend.agent.md +1 -1
- package/scaffold/general/agents/Implementer.agent.md +1 -1
- package/scaffold/general/agents/Orchestrator.agent.md +16 -1
- package/scaffold/general/agents/Planner.agent.md +11 -4
- package/scaffold/general/agents/Refactor.agent.md +1 -1
- package/scaffold/general/agents/Researcher-Alpha.agent.md +1 -1
- package/scaffold/general/agents/Researcher-Beta.agent.md +1 -1
- package/scaffold/general/agents/Researcher-Delta.agent.md +1 -1
- package/scaffold/general/agents/Researcher-Gamma.agent.md +1 -1
- package/scaffold/general/agents/Security.agent.md +10 -8
- package/scaffold/general/agents/_shared/architect-reviewer-base.md +1 -0
- package/scaffold/general/agents/_shared/code-agent-base.md +28 -0
- package/scaffold/general/agents/_shared/code-reviewer-base.md +1 -0
- package/scaffold/general/agents/_shared/forge-protocol.md +44 -0
- package/scaffold/general/agents/_shared/researcher-base.md +14 -0
- package/scaffold/general/agents/templates/adr-template.md +1 -0
- package/scaffold/general/agents/templates/execution-state.md +1 -0
- package/skills/knowledge-base/SKILL.md +19 -6
- package/skills/present/SKILL.md +153 -0
- package/packages/server/dist/tools/toolkit.tools.d.ts +0 -36
- package/packages/server/dist/tools/toolkit.tools.js +0 -20
- package/packages/tui/dist/App-DE_tdOhs.js +0 -2
- package/packages/tui/dist/CuratedPanel-sYdZAICX.js +0 -2
- package/packages/tui/dist/LogPanel-Ce3jMQbH.js +0 -3
- package/packages/tui/dist/SearchPanel-DREo6zgt.js +0 -2
- package/packages/tui/dist/StatusPanel-2ex8fLOO.js +0 -2
- package/packages/tui/dist/embedder.interface-IFCBpOlX.d.ts +0 -28
- package/packages/tui/dist/index-C8NmOF18.d.ts +0 -13
- package/packages/tui/dist/jsx-runtime-Cof-kwFn.js +0 -316
- package/packages/tui/dist/store.interface-CnY6SPOH.d.ts +0 -150
- /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,`&`).replace(/</g,`<`).replace(/>/g,`>`).replace(/"/g,`"`)}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 };
|