@haibun/web-playwright 1.58.1 → 1.60.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cycles.d.ts +4 -0
- package/build/cycles.d.ts.map +1 -0
- package/build/cycles.js +83 -0
- package/build/cycles.js.map +1 -0
- package/build/interactionSteps.d.ts +221 -0
- package/build/interactionSteps.d.ts.map +1 -0
- package/build/interactionSteps.js +515 -0
- package/build/interactionSteps.js.map +1 -0
- package/build/monitor/LogEntry.d.ts +4 -0
- package/build/monitor/LogEntry.d.ts.map +1 -0
- package/build/monitor/LogEntry.js +4 -0
- package/build/monitor/LogEntry.js.map +1 -0
- package/build/monitor/MonitorHandler.d.ts.map +1 -1
- package/build/monitor/MonitorHandler.js +25 -51
- package/build/monitor/MonitorHandler.js.map +1 -1
- package/build/monitor/artifactDisplayBase.d.ts +2 -0
- package/build/monitor/artifactDisplayBase.d.ts.map +1 -0
- package/build/monitor/artifactDisplayBase.js +2 -0
- package/build/monitor/artifactDisplayBase.js.map +1 -0
- package/build/monitor/artifactDisplays/HtmlArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/HtmlArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/HtmlArtifactDisplay.js +31 -0
- package/build/monitor/artifactDisplays/HtmlArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/ImageArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/ImageArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/ImageArtifactDisplay.js +17 -0
- package/build/monitor/artifactDisplays/ImageArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/JsonArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/JsonArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/JsonArtifactDisplay.js +18 -0
- package/build/monitor/artifactDisplays/JsonArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/JsonArtifactHTTPTrace.d.ts +14 -0
- package/build/monitor/artifactDisplays/JsonArtifactHTTPTrace.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/JsonArtifactHTTPTrace.js +69 -0
- package/build/monitor/artifactDisplays/JsonArtifactHTTPTrace.js.map +1 -0
- package/build/monitor/artifactDisplays/MermaidDiagram.d.ts +22 -0
- package/build/monitor/artifactDisplays/MermaidDiagram.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/MermaidDiagram.js +199 -0
- package/build/monitor/artifactDisplays/MermaidDiagram.js.map +1 -0
- package/build/monitor/artifactDisplays/ResolvedFeaturesArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/ResolvedFeaturesArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/ResolvedFeaturesArtifactDisplay.js +38 -0
- package/build/monitor/artifactDisplays/ResolvedFeaturesArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/SequenceDiagramGenerator.d.ts +32 -0
- package/build/monitor/artifactDisplays/SequenceDiagramGenerator.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/SequenceDiagramGenerator.js +258 -0
- package/build/monitor/artifactDisplays/SequenceDiagramGenerator.js.map +1 -0
- package/build/monitor/artifactDisplays/SpeechArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/SpeechArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/SpeechArtifactDisplay.js +19 -0
- package/build/monitor/artifactDisplays/SpeechArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/VideoArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/VideoArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/VideoArtifactDisplay.js +21 -0
- package/build/monitor/artifactDisplays/VideoArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/VideoStartArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/VideoStartArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/VideoStartArtifactDisplay.js +17 -0
- package/build/monitor/artifactDisplays/VideoStartArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/artifactDisplayBase.d.ts +20 -0
- package/build/monitor/artifactDisplays/artifactDisplayBase.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/artifactDisplayBase.js +40 -0
- package/build/monitor/artifactDisplays/artifactDisplayBase.js.map +1 -0
- package/build/monitor/artifactDisplays/htmlArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/htmlArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/htmlArtifactDisplay.js +31 -0
- package/build/monitor/artifactDisplays/htmlArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/imageArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/imageArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/imageArtifactDisplay.js +17 -0
- package/build/monitor/artifactDisplays/imageArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/jsonArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/jsonArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/jsonArtifactDisplay.js +18 -0
- package/build/monitor/artifactDisplays/jsonArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/jsonArtifactHTTPTrace.d.ts +14 -0
- package/build/monitor/artifactDisplays/jsonArtifactHTTPTrace.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/jsonArtifactHTTPTrace.js +72 -0
- package/build/monitor/artifactDisplays/jsonArtifactHTTPTrace.js.map +1 -0
- package/build/monitor/artifactDisplays/mermaidDiagram.d.ts +22 -0
- package/build/monitor/artifactDisplays/mermaidDiagram.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/mermaidDiagram.js +199 -0
- package/build/monitor/artifactDisplays/mermaidDiagram.js.map +1 -0
- package/build/monitor/artifactDisplays/resolvedFeaturesArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/resolvedFeaturesArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/resolvedFeaturesArtifactDisplay.js +36 -0
- package/build/monitor/artifactDisplays/resolvedFeaturesArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/sequenceDiagramGenerator.d.ts +32 -0
- package/build/monitor/artifactDisplays/sequenceDiagramGenerator.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/sequenceDiagramGenerator.js +299 -0
- package/build/monitor/artifactDisplays/sequenceDiagramGenerator.js.map +1 -0
- package/build/monitor/artifactDisplays/speechArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/speechArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/speechArtifactDisplay.js +38 -0
- package/build/monitor/artifactDisplays/speechArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/videoArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/videoArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/videoArtifactDisplay.js +22 -0
- package/build/monitor/artifactDisplays/videoArtifactDisplay.js.map +1 -0
- package/build/monitor/artifactDisplays/videoStartArtifactDisplay.d.ts +9 -0
- package/build/monitor/artifactDisplays/videoStartArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/artifactDisplays/videoStartArtifactDisplay.js +30 -0
- package/build/monitor/artifactDisplays/videoStartArtifactDisplay.js.map +1 -0
- package/build/monitor/graph/feature-bases.d.ts +5 -0
- package/build/monitor/graph/feature-bases.d.ts.map +1 -0
- package/build/monitor/graph/feature-bases.js +36 -0
- package/build/monitor/graph/feature-bases.js.map +1 -0
- package/build/monitor/graph/generateMermaidGraph.d.ts +4 -0
- package/build/monitor/graph/generateMermaidGraph.d.ts.map +1 -0
- package/build/monitor/graph/generateMermaidGraph.js +142 -0
- package/build/monitor/graph/generateMermaidGraph.js.map +1 -0
- package/build/monitor/graph/graphUtils.d.ts +3 -0
- package/build/monitor/graph/graphUtils.d.ts.map +1 -0
- package/build/monitor/graph/graphUtils.js +16 -0
- package/build/monitor/graph/graphUtils.js.map +1 -0
- package/build/monitor/graph/mermaidGraphLinks.d.ts +3 -0
- package/build/monitor/graph/mermaidGraphLinks.d.ts.map +1 -0
- package/build/monitor/graph/mermaidGraphLinks.js +31 -0
- package/build/monitor/graph/mermaidGraphLinks.js.map +1 -0
- package/build/monitor/htmlArtifactDisplay.d.ts +2 -0
- package/build/monitor/htmlArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/htmlArtifactDisplay.js +2 -0
- package/build/monitor/htmlArtifactDisplay.js.map +1 -0
- package/build/monitor/imageArtifactDisplay.d.ts +2 -0
- package/build/monitor/imageArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/imageArtifactDisplay.js +2 -0
- package/build/monitor/imageArtifactDisplay.js.map +1 -0
- package/build/monitor/jsonArtifactDisplay.d.ts +2 -0
- package/build/monitor/jsonArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/jsonArtifactDisplay.js +2 -0
- package/build/monitor/jsonArtifactDisplay.js.map +1 -0
- package/build/monitor/jsonArtifactHTTPTrace.d.ts +2 -0
- package/build/monitor/jsonArtifactHTTPTrace.d.ts.map +1 -0
- package/build/monitor/jsonArtifactHTTPTrace.js +2 -0
- package/build/monitor/jsonArtifactHTTPTrace.js.map +1 -0
- package/build/monitor/messages.d.ts +9 -21
- package/build/monitor/messages.d.ts.map +1 -1
- package/build/monitor/messages.js +83 -217
- package/build/monitor/messages.js.map +1 -1
- package/build/monitor/monitor.d.ts +9 -4
- package/build/monitor/monitor.d.ts.map +1 -1
- package/build/monitor/monitor.js +8 -18
- package/build/monitor/monitor.js.map +1 -1
- package/build/monitor/resolvedFeaturesArtifactDisplay.d.ts +2 -0
- package/build/monitor/resolvedFeaturesArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/resolvedFeaturesArtifactDisplay.js +2 -0
- package/build/monitor/resolvedFeaturesArtifactDisplay.js.map +1 -0
- package/build/monitor/sequenceDiagramGenerator.d.ts +32 -0
- package/build/monitor/sequenceDiagramGenerator.d.ts.map +1 -0
- package/build/monitor/sequenceDiagramGenerator.js +299 -0
- package/build/monitor/sequenceDiagramGenerator.js.map +1 -0
- package/build/monitor/speechArtifactDisplay.d.ts +2 -0
- package/build/monitor/speechArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/speechArtifactDisplay.js +2 -0
- package/build/monitor/speechArtifactDisplay.js.map +1 -0
- package/build/monitor/test-utils.d.ts +9 -0
- package/build/monitor/test-utils.d.ts.map +1 -0
- package/build/monitor/test-utils.js +70 -0
- package/build/monitor/test-utils.js.map +1 -0
- package/build/monitor/videoArtifactDisplay.d.ts +2 -0
- package/build/monitor/videoArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/videoArtifactDisplay.js +2 -0
- package/build/monitor/videoArtifactDisplay.js.map +1 -0
- package/build/monitor/videoStartArtifactDisplay.d.ts +2 -0
- package/build/monitor/videoStartArtifactDisplay.d.ts.map +1 -0
- package/build/monitor/videoStartArtifactDisplay.js +2 -0
- package/build/monitor/videoStartArtifactDisplay.js.map +1 -0
- package/build/web-playwright.d.ts +78 -77
- package/build/web-playwright.d.ts.map +1 -1
- package/build/web-playwright.js +12 -571
- package/build/web-playwright.js.map +1 -1
- package/package.json +9 -5
- package/web/monitor.html +261 -260
- package/build/monitor/monitorHandler.d.ts +0 -16
- package/build/monitor/monitorHandler.d.ts.map +0 -1
- package/build/monitor/monitorHandler.js +0 -108
- package/build/monitor/monitorHandler.js.map +0 -1
- package/build/monitor/vite.config.d.ts +0 -4
- package/build/monitor/vite.config.d.ts.map +0 -1
- package/build/monitor/vite.config.js +0 -91
- package/build/monitor/vite.config.js.map +0 -1
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { generateMermaidGraphAsMarkdown } from "../graph/generateMermaidGraph.js";
|
|
2
|
+
import { ArtifactDisplay } from "./artifactDisplayBase.js";
|
|
3
|
+
import mermaid from 'mermaid';
|
|
4
|
+
mermaid.initialize({
|
|
5
|
+
maxTextSize: 1000000,
|
|
6
|
+
maxEdges: 10000,
|
|
7
|
+
});
|
|
8
|
+
let instanceCounter = 0;
|
|
9
|
+
export class ResolvedFeaturesArtifactDisplay extends ArtifactDisplay {
|
|
10
|
+
artifact;
|
|
11
|
+
placementTarget = 'details';
|
|
12
|
+
constructor(artifact) {
|
|
13
|
+
super(artifact);
|
|
14
|
+
this.artifact = artifact;
|
|
15
|
+
}
|
|
16
|
+
async render(container) {
|
|
17
|
+
// The artifact is already typed as TArtifactResolvedFeatures due to the constructor
|
|
18
|
+
if (!this.artifact.resolvedFeatures || this.artifact.resolvedFeatures.length === 0) {
|
|
19
|
+
container.innerHTML = '<p>No resolved features to display.</p>';
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const mermaidGraph = await generateMermaidGraphAsMarkdown(this.artifact.resolvedFeatures);
|
|
23
|
+
const graphSvgId = `mermaid-graph-svg-${instanceCounter++}-${Date.now()}`;
|
|
24
|
+
container.innerHTML = ''; // Clear placeholder
|
|
25
|
+
try {
|
|
26
|
+
const { svg, bindFunctions } = await mermaid.render(graphSvgId, mermaidGraph);
|
|
27
|
+
container.innerHTML = svg;
|
|
28
|
+
if (bindFunctions) {
|
|
29
|
+
bindFunctions(container);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
console.error('Error rendering Mermaid graph:', error);
|
|
34
|
+
container.innerHTML = `<p class="haibun-artifact-error">Error rendering graph: ${error.message}</p>`;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=ResolvedFeaturesArtifactDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResolvedFeaturesArtifactDisplay.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/ResolvedFeaturesArtifactDisplay.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,8BAA8B,EAAE,MAAM,kCAAkC,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,CAAC,UAAU,CAAC;IAClB,WAAW,EAAE,OAAO;IACpB,QAAQ,EAAE,KAAK;CACf,CAAC,CAAC;AAEH,IAAI,eAAe,GAAG,CAAC,CAAC;AAExB,MAAM,OAAO,+BAAgC,SAAQ,eAAe;IAG7C;IAFb,eAAe,GAAG,SAAS,CAAC;IAErC,YAAsB,QAAmC;QACxD,KAAK,CAAC,QAAQ,CAAC,CAAC;QADK,aAAQ,GAAR,QAAQ,CAA2B;IAEzD,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,SAAsB;QACzC,oFAAoF;QACpF,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpF,SAAS,CAAC,SAAS,GAAG,yCAAyC,CAAC;YAChE,OAAO;QACR,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,8BAA8B,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC;QAE1F,MAAM,UAAU,GAAG,qBAAqB,eAAe,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAE1E,SAAS,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,oBAAoB;QAE9C,IAAI,CAAC;YACJ,MAAM,EAAE,GAAG,EAAE,aAAa,EAAE,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;YAC9E,SAAS,CAAC,SAAS,GAAG,GAAG,CAAC;YAE1B,IAAI,aAAa,EAAE,CAAC;gBACnB,aAAa,CAAC,SAAS,CAAC,CAAC;YAC1B,CAAC;QACF,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;YACvD,SAAS,CAAC,SAAS,GAAG,2DAA4D,KAAe,CAAC,OAAO,MAAM,CAAC;QACjH,CAAC;IACF,CAAC;CACD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { TArtifactHTTPTrace, THTTPTraceContent } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
export declare class SequenceDiagramGenerator {
|
|
3
|
+
private needsUpdate;
|
|
4
|
+
private diagramLines;
|
|
5
|
+
private pageNames;
|
|
6
|
+
private pageCounter;
|
|
7
|
+
private participantAdded;
|
|
8
|
+
private mermaidContainerId;
|
|
9
|
+
private parentElement;
|
|
10
|
+
private currentDiagramString;
|
|
11
|
+
constructor(id: string, parentElement: HTMLElement);
|
|
12
|
+
private ensureMermaidContainer;
|
|
13
|
+
private addParticipant;
|
|
14
|
+
private resetDiagramState;
|
|
15
|
+
private buildDiagramString;
|
|
16
|
+
generateDiagramFromHistory(): void;
|
|
17
|
+
processSingleEvent(trace: THTTPTraceContent, httpEvent: TArtifactHTTPTrace['httpEvent'], filters?: {
|
|
18
|
+
request: {
|
|
19
|
+
method: string[];
|
|
20
|
+
accept: string[];
|
|
21
|
+
};
|
|
22
|
+
response: {
|
|
23
|
+
type: string[];
|
|
24
|
+
};
|
|
25
|
+
}): void;
|
|
26
|
+
getDiagram(): string;
|
|
27
|
+
getNeedsUpdate(): boolean;
|
|
28
|
+
setNeedsUpdate(value: boolean): void;
|
|
29
|
+
update(): Promise<void>;
|
|
30
|
+
}
|
|
31
|
+
export declare function skipEvent(filters: any, httpEvent: any, serverName: any, { requestingURL, headers }: THTTPTraceContent): boolean;
|
|
32
|
+
//# sourceMappingURL=SequenceDiagramGenerator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceDiagramGenerator.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/SequenceDiagramGenerator.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAsBpG,qBAAa,wBAAwB;IACpC,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,YAAY,CAAiC;IACrD,OAAO,CAAC,SAAS,CAA8B;IAC/C,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,gBAAgB,CAA+B;IACvD,OAAO,CAAC,kBAAkB,CAAS;IACnC,OAAO,CAAC,aAAa,CAAc;IACnC,OAAO,CAAC,oBAAoB,CAAM;gBAEtB,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,WAAW;IAOlD,OAAO,CAAC,sBAAsB;IAU9B,OAAO,CAAC,cAAc;IActB,OAAO,CAAC,iBAAiB;IAQzB,OAAO,CAAC,kBAAkB;IAOnB,0BAA0B,IAAI,IAAI;IA6BlC,kBAAkB,CAAC,KAAK,EAAE,iBAAiB,EAAE,SAAS,EAAE,kBAAkB,CAAC,WAAW,CAAC,EAAE,OAAO;;;;;;;;KAAc,GAAG,IAAI;IAuFrH,UAAU,IAAI,MAAM;IAKpB,cAAc,IAAI,OAAO;IAKzB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAI9B,MAAM;CA2CnB;AACD,wBAAgB,SAAS,CAAC,OAAO,KAAA,EAAE,SAAS,KAAA,EAAE,UAAU,KAAA,EAAE,EAAE,aAAa,EAAE,OAAO,EAAE,EAAE,iBAAiB,WA0BtG"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
import mermaid from 'mermaid';
|
|
2
|
+
import { shortenURI } from '@haibun/core/build/lib/util/index.js';
|
|
3
|
+
const sanitizeMermaidContent = (message) => {
|
|
4
|
+
let sanitized = message.replace(/"/g, "'");
|
|
5
|
+
sanitized = sanitized.replace(/;/g, '#59;');
|
|
6
|
+
sanitized = sanitized.replace(/\(/g, '#40;');
|
|
7
|
+
sanitized = sanitized.replace(/\)/g, '#41;');
|
|
8
|
+
sanitized = sanitized.replace(/,/g, '#44;');
|
|
9
|
+
return sanitized;
|
|
10
|
+
};
|
|
11
|
+
const jsonFilters = {
|
|
12
|
+
request: {
|
|
13
|
+
method: ['GET', 'POST', 'PUT', 'DELETE', 'PATCH'],
|
|
14
|
+
accept: ['application/json'],
|
|
15
|
+
},
|
|
16
|
+
response: {
|
|
17
|
+
type: ['application/json'],
|
|
18
|
+
},
|
|
19
|
+
};
|
|
20
|
+
export class SequenceDiagramGenerator {
|
|
21
|
+
needsUpdate = true; // Start with true, assume an update is needed initially
|
|
22
|
+
diagramLines = ['sequenceDiagram'];
|
|
23
|
+
pageNames = {};
|
|
24
|
+
pageCounter = 1;
|
|
25
|
+
participantAdded = {};
|
|
26
|
+
mermaidContainerId;
|
|
27
|
+
parentElement;
|
|
28
|
+
currentDiagramString = ''; // Store the last successfully rendered/generated diagram
|
|
29
|
+
constructor(id, parentElement) {
|
|
30
|
+
this.mermaidContainerId = `mermaid-container-${id}`;
|
|
31
|
+
this.parentElement = parentElement;
|
|
32
|
+
this.ensureMermaidContainer();
|
|
33
|
+
this.currentDiagramString = this.buildDiagramString(); // Initialize with empty diagram
|
|
34
|
+
}
|
|
35
|
+
ensureMermaidContainer() {
|
|
36
|
+
let container = this.parentElement.querySelector(`#${this.mermaidContainerId}`);
|
|
37
|
+
if (!container) {
|
|
38
|
+
container = document.createElement('div');
|
|
39
|
+
container.id = this.mermaidContainerId;
|
|
40
|
+
container.className = 'mermaid';
|
|
41
|
+
this.parentElement.appendChild(container);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
addParticipant(alias, name) {
|
|
45
|
+
if (!this.participantAdded[alias]) {
|
|
46
|
+
let insertIndex = 1;
|
|
47
|
+
for (let i = this.diagramLines.length - 1; i >= 1; i--) {
|
|
48
|
+
if (this.diagramLines[i].startsWith('participant ')) {
|
|
49
|
+
insertIndex = i + 1;
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
this.diagramLines.splice(insertIndex, 0, `participant ${alias} as ${name}`);
|
|
54
|
+
this.participantAdded[alias] = true;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
resetDiagramState() {
|
|
58
|
+
this.diagramLines = ['sequenceDiagram'];
|
|
59
|
+
this.pageNames = {};
|
|
60
|
+
this.pageCounter = 1;
|
|
61
|
+
this.participantAdded = {};
|
|
62
|
+
// No: this.needsUpdate = true; // Don't set here, compare diagram strings later
|
|
63
|
+
}
|
|
64
|
+
buildDiagramString() {
|
|
65
|
+
if (this.diagramLines.length <= 1) {
|
|
66
|
+
return 'sequenceDiagram'; // Canonical empty diagram
|
|
67
|
+
}
|
|
68
|
+
return this.diagramLines.join("\n");
|
|
69
|
+
}
|
|
70
|
+
generateDiagramFromHistory() {
|
|
71
|
+
this.resetDiagramState();
|
|
72
|
+
if (window.haibunCapturedMessages) {
|
|
73
|
+
const httpTraceEvents = window.haibunCapturedMessages.filter(entry => entry.messageContext?.artifact?.artifactType === 'json/http/trace' &&
|
|
74
|
+
entry.messageContext.artifact.httpEvent !== 'route');
|
|
75
|
+
for (const logEntry of httpTraceEvents) {
|
|
76
|
+
// Ensure messageContext and artifact are defined before trying to cast and access httpEvent
|
|
77
|
+
if (logEntry.messageContext && logEntry.messageContext.artifact) {
|
|
78
|
+
const artifact = logEntry.messageContext.artifact;
|
|
79
|
+
if (artifact && artifact.trace && typeof artifact.trace === 'object') {
|
|
80
|
+
this.processSingleEvent(artifact.trace, artifact.httpEvent);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// processSingleEvent will set it to true if it adds anything.
|
|
86
|
+
// Here, we compare the generated diagram with the *last rendered* one.
|
|
87
|
+
const finalDiagram = this.buildDiagramString();
|
|
88
|
+
if (finalDiagram === this.currentDiagramString) {
|
|
89
|
+
this.needsUpdate = false;
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
this.needsUpdate = true;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
processSingleEvent(trace, httpEvent, filters = jsonFilters) {
|
|
96
|
+
this.needsUpdate = true;
|
|
97
|
+
const { requestingPage, requestingURL, method, status, statusText, headers } = trace;
|
|
98
|
+
let serverAlias = 'UnknownServerAlias';
|
|
99
|
+
let serverName = 'UnknownServer';
|
|
100
|
+
if (requestingURL) {
|
|
101
|
+
try {
|
|
102
|
+
const url = new URL(requestingURL);
|
|
103
|
+
serverName = url.hostname;
|
|
104
|
+
if (url.hostname === 'localhost' && url.port) {
|
|
105
|
+
serverName = `${url.hostname}:${url.port}`;
|
|
106
|
+
}
|
|
107
|
+
if (serverName) {
|
|
108
|
+
serverAlias = serverName.toLowerCase().replace(/[.:-]/g, '');
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
serverAlias = 'sourcealias';
|
|
112
|
+
serverName = 'Source';
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
catch (e) {
|
|
116
|
+
serverAlias = 'invalidurlalias';
|
|
117
|
+
serverName = 'InvalidURL';
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
this.addParticipant(serverAlias, serverName);
|
|
121
|
+
if (skipEvent(filters, httpEvent, serverName, trace)) {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
let pageAlias = 'UnknownPageAlias';
|
|
125
|
+
let pageParticipantName = 'UnknownPage';
|
|
126
|
+
if (requestingPage) {
|
|
127
|
+
const existingAlias = this.pageNames[requestingPage];
|
|
128
|
+
if (!existingAlias) {
|
|
129
|
+
pageAlias = requestingPage.toLowerCase().replace(/[.-]/g, '');
|
|
130
|
+
pageParticipantName = requestingPage;
|
|
131
|
+
if (!pageAlias.trim()) {
|
|
132
|
+
pageAlias = `Page${this.pageCounter}`;
|
|
133
|
+
}
|
|
134
|
+
this.pageNames[requestingPage] = pageAlias;
|
|
135
|
+
this.addParticipant(pageAlias, pageParticipantName);
|
|
136
|
+
this.pageCounter++;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
pageAlias = existingAlias;
|
|
140
|
+
const participantLine = this.diagramLines.find(line => line.startsWith(`participant ${pageAlias} as `));
|
|
141
|
+
if (participantLine) {
|
|
142
|
+
pageParticipantName = participantLine.substring(participantLine.indexOf(' as ') + 4);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
pageParticipantName = pageAlias;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
pageAlias = 'ClientPage';
|
|
151
|
+
pageParticipantName = 'Client Page';
|
|
152
|
+
this.addParticipant(pageAlias, pageParticipantName);
|
|
153
|
+
}
|
|
154
|
+
if (method && requestingURL) {
|
|
155
|
+
const message = sanitizeMermaidContent(`${method} ${shortenURI(requestingURL)}`);
|
|
156
|
+
this.diagramLines.push(`${pageAlias}->>${serverAlias}: ${message}`);
|
|
157
|
+
if (headers) {
|
|
158
|
+
if (headers.referer) {
|
|
159
|
+
const note = shortenURI(sanitizeMermaidContent(`Referer: ${headers.referer}`));
|
|
160
|
+
this.diagramLines.push(`Note right of ${pageAlias}: ${note}`);
|
|
161
|
+
}
|
|
162
|
+
if (headers["accept"]) {
|
|
163
|
+
const note = sanitizeMermaidContent(`Accept: ${headers["accept"]}`);
|
|
164
|
+
this.diagramLines.push(`Note right of ${pageAlias}: ${note}`);
|
|
165
|
+
}
|
|
166
|
+
if (headers["content-type"]) {
|
|
167
|
+
const note = sanitizeMermaidContent(`Content-type: ${headers['content-type']}`);
|
|
168
|
+
this.diagramLines.push(`Note right of ${pageAlias}: ${note}`);
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
if (status) {
|
|
173
|
+
const message = sanitizeMermaidContent(`${status} ${statusText || ''}`);
|
|
174
|
+
this.diagramLines.push(`${serverAlias}-->>${pageAlias}: ${message}`);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
getDiagram() {
|
|
178
|
+
return this.buildDiagramString();
|
|
179
|
+
}
|
|
180
|
+
// Getter for testing purposes
|
|
181
|
+
getNeedsUpdate() {
|
|
182
|
+
return this.needsUpdate;
|
|
183
|
+
}
|
|
184
|
+
// Setter for testing purposes, to simulate rendering having occurred.
|
|
185
|
+
setNeedsUpdate(value) {
|
|
186
|
+
this.needsUpdate = value;
|
|
187
|
+
}
|
|
188
|
+
async update() {
|
|
189
|
+
this.generateDiagramFromHistory();
|
|
190
|
+
const mermaidContainer = this.parentElement.querySelector(`#${this.mermaidContainerId}`);
|
|
191
|
+
if (!mermaidContainer) {
|
|
192
|
+
console.error("Mermaid container not found for ID:", this.mermaidContainerId);
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
if (!this.needsUpdate && mermaidContainer.querySelector('svg')) {
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
const diagramToRender = this.getDiagram();
|
|
199
|
+
try {
|
|
200
|
+
mermaid.initialize({ maxTextSize: 900000, startOnLoad: false });
|
|
201
|
+
mermaidContainer.innerHTML = '';
|
|
202
|
+
const insert = `<pre class="mermaid">${diagramToRender}</pre>`;
|
|
203
|
+
mermaidContainer.insertAdjacentHTML('beforeend', insert);
|
|
204
|
+
const mermaidElement = mermaidContainer.querySelector('.mermaid');
|
|
205
|
+
if (mermaidElement) {
|
|
206
|
+
await mermaid.run({ nodes: [mermaidElement] });
|
|
207
|
+
console.log("Mermaid diagram rendered.");
|
|
208
|
+
this.currentDiagramString = diagramToRender;
|
|
209
|
+
this.needsUpdate = false;
|
|
210
|
+
}
|
|
211
|
+
else {
|
|
212
|
+
console.error("Mermaid pre element not found after insert.");
|
|
213
|
+
mermaidContainer.innerHTML = `<pre>Error: Could not find .mermaid element for rendering.</pre>`;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
catch (e) {
|
|
217
|
+
console.error("Failed Mermaid diagram definition:\n", diagramToRender);
|
|
218
|
+
console.error("Error rendering Mermaid diagram:", e);
|
|
219
|
+
const detailedError = (typeof e === 'object' && e !== null && 'str' in e) ? e.str : null;
|
|
220
|
+
const errorMessage = detailedError || (e instanceof Error ? e.message : String(e));
|
|
221
|
+
mermaidContainer.innerHTML = `<pre>Error rendering Mermaid diagram:\n\n${errorMessage}\n\n--- Diagram Definition ---\n${diagramToRender}</pre>`;
|
|
222
|
+
// Even on error, we consider this "render attempt" complete.
|
|
223
|
+
// Setting currentDiagramString to the one that failed, and needsUpdate to false prevents re-looping on a bad diagram.
|
|
224
|
+
this.currentDiagramString = diagramToRender;
|
|
225
|
+
this.needsUpdate = false;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
export function skipEvent(filters, httpEvent, serverName, { requestingURL, headers }) {
|
|
230
|
+
if (!serverName) {
|
|
231
|
+
return true;
|
|
232
|
+
}
|
|
233
|
+
if (requestingURL === 'about:blank') {
|
|
234
|
+
return true;
|
|
235
|
+
}
|
|
236
|
+
if (httpEvent === 'request') {
|
|
237
|
+
if (headers && headers.accept) {
|
|
238
|
+
const acceptHeader = headers.accept;
|
|
239
|
+
if (!filters.request.accept.some(filterValue => acceptHeader.includes(filterValue))) {
|
|
240
|
+
return true;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
else if (httpEvent === 'response') {
|
|
245
|
+
if (headers && headers['content-type']) {
|
|
246
|
+
const contentTypeHeader = headers['content-type'];
|
|
247
|
+
if (!filters.response.type.some(filterValue => contentTypeHeader.includes(filterValue))) {
|
|
248
|
+
return true;
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
console.warn(`Unknown HTTP event type: ${httpEvent}`);
|
|
254
|
+
return true;
|
|
255
|
+
}
|
|
256
|
+
return false;
|
|
257
|
+
}
|
|
258
|
+
//# sourceMappingURL=SequenceDiagramGenerator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceDiagramGenerator.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/SequenceDiagramGenerator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TArtifactSpeech } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
3
|
+
export declare class SpeechArtifactDisplay extends ArtifactDisplay {
|
|
4
|
+
protected artifact: TArtifactSpeech;
|
|
5
|
+
readonly placementTarget = "details";
|
|
6
|
+
constructor(artifact: TArtifactSpeech);
|
|
7
|
+
render(container: HTMLElement): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=SpeechArtifactDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SpeechArtifactDisplay.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/SpeechArtifactDisplay.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,6CAA6C,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,qBAAa,qBAAsB,SAAQ,eAAe;IAG7C,SAAS,CAAC,QAAQ,EAAE,eAAe;IAF/C,QAAQ,CAAC,eAAe,aAAa;gBAEf,QAAQ,EAAE,eAAe;IAIxC,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,IAAI;CAW3C"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
2
|
+
export class SpeechArtifactDisplay extends ArtifactDisplay {
|
|
3
|
+
artifact;
|
|
4
|
+
placementTarget = 'details';
|
|
5
|
+
constructor(artifact) {
|
|
6
|
+
super(artifact);
|
|
7
|
+
this.artifact = artifact;
|
|
8
|
+
}
|
|
9
|
+
render(container) {
|
|
10
|
+
const typedArtifact = this.artifact;
|
|
11
|
+
container.innerHTML = '';
|
|
12
|
+
const audioElement = document.createElement('audio');
|
|
13
|
+
audioElement.src = typedArtifact.path;
|
|
14
|
+
audioElement.controls = true;
|
|
15
|
+
audioElement.style.width = '320px';
|
|
16
|
+
container.appendChild(audioElement);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=SpeechArtifactDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SpeechArtifactDisplay.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/SpeechArtifactDisplay.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAGnC;IAFb,eAAe,GAAG,SAAS,CAAC;IAErC,YAAsB,QAAyB;QAC9C,KAAK,CAAC,QAAQ,CAAC,CAAC;QADK,aAAQ,GAAR,QAAQ,CAAiB;IAE/C,CAAC;IAEM,MAAM,CAAC,SAAsB;QACnC,MAAM,aAAa,GAAG,IAAI,CAAC,QAA2B,CAAC;QACvD,SAAS,CAAC,SAAS,GAAG,EAAE,CAAC;QAEzB,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACrD,YAAY,CAAC,GAAG,GAAG,aAAa,CAAC,IAAI,CAAC;QACtC,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC7B,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC;QAEnC,SAAS,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;IACrC,CAAC;CACD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TArtifactVideo } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
3
|
+
export declare class VideoArtifactDisplay extends ArtifactDisplay {
|
|
4
|
+
protected artifact: TArtifactVideo;
|
|
5
|
+
readonly placementTarget: 'details' | 'haibun-video';
|
|
6
|
+
constructor(artifact: TArtifactVideo);
|
|
7
|
+
render(container: HTMLElement): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=VideoArtifactDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VideoArtifactDisplay.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/VideoArtifactDisplay.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,qBAAa,oBAAqB,SAAQ,eAAe;IAE5C,SAAS,CAAC,QAAQ,EAAE,cAAc;IAD9C,QAAQ,CAAC,eAAe,EAAE,SAAS,GAAG,cAAc,CAAC;gBAC/B,QAAQ,EAAE,cAAc;IAOvC,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,IAAI;CAO3C"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
2
|
+
export class VideoArtifactDisplay extends ArtifactDisplay {
|
|
3
|
+
artifact;
|
|
4
|
+
placementTarget;
|
|
5
|
+
constructor(artifact) {
|
|
6
|
+
super(artifact);
|
|
7
|
+
this.artifact = artifact;
|
|
8
|
+
this.placementTarget = document.querySelector('#haibun-video') ? 'haibun-video' : 'details';
|
|
9
|
+
if (this.placementTarget === 'details') {
|
|
10
|
+
console.info('Cannot find #haibun-video container; video will be appended to details on toggle.');
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
render(container) {
|
|
14
|
+
const videoElement = document.createElement('video');
|
|
15
|
+
videoElement.controls = true;
|
|
16
|
+
videoElement.style.width = '320px';
|
|
17
|
+
videoElement.src = this.artifact.path;
|
|
18
|
+
container.replaceChildren(videoElement);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=VideoArtifactDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VideoArtifactDisplay.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/VideoArtifactDisplay.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,MAAM,OAAO,oBAAqB,SAAQ,eAAe;IAElC;IADb,eAAe,CAA6B;IACrD,YAAsB,QAAwB;QAC7C,KAAK,CAAC,QAAQ,CAAC,CAAC;QADK,aAAQ,GAAR,QAAQ,CAAgB;QAE7C,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC;QAC5F,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;YACxC,OAAO,CAAC,IAAI,CAAC,mFAAmF,CAAC,CAAC;QACnG,CAAC;IACF,CAAC;IACM,MAAM,CAAC,SAAsB;QACnC,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACrD,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC7B,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC;QACnC,YAAY,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QACtC,SAAS,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;IACzC,CAAC;CACD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TArtifactVideoStart } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
3
|
+
export declare class VideoStartArtifactDisplay extends ArtifactDisplay {
|
|
4
|
+
protected artifact: TArtifactVideoStart;
|
|
5
|
+
readonly placementTarget = "body";
|
|
6
|
+
constructor(artifact: TArtifactVideoStart);
|
|
7
|
+
render(container: HTMLElement): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=VideoStartArtifactDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VideoStartArtifactDisplay.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/VideoStartArtifactDisplay.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6CAA6C,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,qBAAa,yBAA0B,SAAQ,eAAe;IAEjD,SAAS,CAAC,QAAQ,EAAE,mBAAmB;IADnD,QAAQ,CAAC,eAAe,UAAU;gBACZ,QAAQ,EAAE,mBAAmB;IAG5C,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,IAAI;CAO3C"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
2
|
+
export class VideoStartArtifactDisplay extends ArtifactDisplay {
|
|
3
|
+
artifact;
|
|
4
|
+
placementTarget = 'body';
|
|
5
|
+
constructor(artifact) {
|
|
6
|
+
super(artifact);
|
|
7
|
+
this.artifact = artifact;
|
|
8
|
+
}
|
|
9
|
+
render(container) {
|
|
10
|
+
const span = document.createElement('span');
|
|
11
|
+
span.id = 'haibun-video-start';
|
|
12
|
+
span.dataset.start = `${this.artifact.start}`;
|
|
13
|
+
span.textContent = `Video start event: ${this.artifact.start}`;
|
|
14
|
+
container.replaceChildren(span);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=VideoStartArtifactDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VideoStartArtifactDisplay.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/VideoStartArtifactDisplay.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,MAAM,OAAO,yBAA0B,SAAQ,eAAe;IAEvC;IADb,eAAe,GAAG,MAAM,CAAC;IAClC,YAAsB,QAA6B;QAClD,KAAK,CAAC,QAAQ,CAAC,CAAC;QADK,aAAQ,GAAR,QAAQ,CAAqB;IAEnD,CAAC;IACM,MAAM,CAAC,SAAsB;QACnC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,EAAE,GAAG,oBAAoB,CAAC;QAC/B,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAC9C,IAAI,CAAC,WAAW,GAAG,sBAAsB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAC/D,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;CACD"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { TArtifact } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
export declare abstract class LogComponent<T extends HTMLElement = HTMLElement> {
|
|
3
|
+
readonly element: T;
|
|
4
|
+
constructor(tagName: keyof HTMLElementTagNameMap, className?: string | string[]);
|
|
5
|
+
append(child: LogComponent | HTMLElement): void;
|
|
6
|
+
addClass(className: string): void;
|
|
7
|
+
setData(key: string, value: string): void;
|
|
8
|
+
setHtml(html: string): void;
|
|
9
|
+
setText(text: string): void;
|
|
10
|
+
}
|
|
11
|
+
export declare abstract class ArtifactDisplay {
|
|
12
|
+
protected artifact: TArtifact;
|
|
13
|
+
readonly label: string;
|
|
14
|
+
abstract readonly placementTarget: 'details' | 'haibun-video' | 'haibun-sequence-diagram' | 'body' | 'none';
|
|
15
|
+
constructor(artifact: TArtifact);
|
|
16
|
+
deriveLabel(): string;
|
|
17
|
+
abstract render(container: HTMLElement): Promise<void> | void;
|
|
18
|
+
get artifactType(): string;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=artifactDisplayBase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifactDisplayBase.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/artifactDisplayBase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAC;AAExE,8BAAsB,YAAY,CAAC,CAAC,SAAS,WAAW,GAAG,WAAW;IACrE,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;gBAER,OAAO,EAAE,MAAM,qBAAqB,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAQ/E,MAAM,CAAC,KAAK,EAAE,YAAY,GAAG,WAAW,GAAG,IAAI;IAI/C,QAAQ,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAIjC,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAIzC,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAI3B,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;CAG3B;AAED,8BAAsB,eAAe;IAIxB,SAAS,CAAC,QAAQ,EAAE,SAAS;IAHzC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,QAAQ,CAAC,eAAe,EAAE,SAAS,GAAG,cAAc,GAAG,yBAAyB,GAAG,MAAM,GAAG,MAAM,CAAC;gBAEtF,QAAQ,EAAE,SAAS;IAIzC,WAAW,IAAI,MAAM;aAIL,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI;IAEpE,IAAW,YAAY,IAAI,MAAM,CAEhC;CACD"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export class LogComponent {
|
|
2
|
+
element;
|
|
3
|
+
constructor(tagName, className) {
|
|
4
|
+
this.element = document.createElement(tagName);
|
|
5
|
+
if (className) {
|
|
6
|
+
const classes = Array.isArray(className) ? className : [className];
|
|
7
|
+
this.element.classList.add(...classes);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
append(child) {
|
|
11
|
+
this.element.appendChild(child instanceof LogComponent ? child.element : child);
|
|
12
|
+
}
|
|
13
|
+
addClass(className) {
|
|
14
|
+
this.element.classList.add(className);
|
|
15
|
+
}
|
|
16
|
+
setData(key, value) {
|
|
17
|
+
this.element.dataset[key] = value;
|
|
18
|
+
}
|
|
19
|
+
setHtml(html) {
|
|
20
|
+
this.element.innerHTML = html;
|
|
21
|
+
}
|
|
22
|
+
setText(text) {
|
|
23
|
+
this.element.textContent = text;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export class ArtifactDisplay {
|
|
27
|
+
artifact;
|
|
28
|
+
label;
|
|
29
|
+
constructor(artifact) {
|
|
30
|
+
this.artifact = artifact;
|
|
31
|
+
this.label = this.deriveLabel();
|
|
32
|
+
}
|
|
33
|
+
deriveLabel() {
|
|
34
|
+
return this.artifact.artifactType;
|
|
35
|
+
}
|
|
36
|
+
get artifactType() {
|
|
37
|
+
return this.artifact.artifactType;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=artifactDisplayBase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifactDisplayBase.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/artifactDisplayBase.ts"],"names":[],"mappings":"AAEA,MAAM,OAAgB,YAAY;IACxB,OAAO,CAAI;IAEpB,YAAY,OAAoC,EAAE,SAA6B;QAC9E,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAM,CAAC;QACpD,IAAI,SAAS,EAAE,CAAC;YACf,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;YACnE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC;QACxC,CAAC;IACF,CAAC;IAED,MAAM,CAAC,KAAiC;QACvC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,YAAY,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACjF,CAAC;IAED,QAAQ,CAAC,SAAiB;QACzB,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,CAAC,GAAW,EAAE,KAAa;QACjC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACnC,CAAC;IAED,OAAO,CAAC,IAAY;QACnB,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,IAAY;QACnB,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IACjC,CAAC;CACD;AAED,MAAM,OAAgB,eAAe;IAId;IAHb,KAAK,CAAS;IAGvB,YAAsB,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IACjC,CAAC;IAED,WAAW;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC;IACnC,CAAC;IAID,IAAW,YAAY;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC;IACnC,CAAC;CACD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TArtifactHTML } from "@haibun/core/build/lib/interfaces/logger.js";
|
|
2
|
+
import { ArtifactDisplay } from "./artifactDisplayBase.js";
|
|
3
|
+
export declare class HtmlArtifactDisplay extends ArtifactDisplay {
|
|
4
|
+
protected artifact: TArtifactHTML;
|
|
5
|
+
readonly placementTarget = "details";
|
|
6
|
+
constructor(artifact: TArtifactHTML);
|
|
7
|
+
render(container: HTMLElement): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=htmlArtifactDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlArtifactDisplay.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/htmlArtifactDisplay.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAC5E,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,qBAAa,mBAAoB,SAAQ,eAAe;IAE3C,SAAS,CAAC,QAAQ,EAAE,aAAa;IAD7C,QAAQ,CAAC,eAAe,aAAa;gBACf,QAAQ,EAAE,aAAa;IAGtC,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,IAAI;CAoB3C"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ArtifactDisplay } from "./artifactDisplayBase.js";
|
|
2
|
+
export class HtmlArtifactDisplay extends ArtifactDisplay {
|
|
3
|
+
artifact;
|
|
4
|
+
placementTarget = 'details';
|
|
5
|
+
constructor(artifact) {
|
|
6
|
+
super(artifact);
|
|
7
|
+
this.artifact = artifact;
|
|
8
|
+
}
|
|
9
|
+
render(container) {
|
|
10
|
+
container.innerHTML = ''; // Clear placeholder
|
|
11
|
+
const iframe = document.createElement('iframe');
|
|
12
|
+
iframe.style.border = 'none';
|
|
13
|
+
iframe.style.width = '100%';
|
|
14
|
+
iframe.style.height = '80vh';
|
|
15
|
+
// TArtifactHTML is a union, check for the 'html' property for direct content
|
|
16
|
+
if ('html' in this.artifact && typeof this.artifact.html === 'string') {
|
|
17
|
+
iframe.srcdoc = this.artifact.html;
|
|
18
|
+
}
|
|
19
|
+
else if ('path' in this.artifact && typeof this.artifact.path === 'string') {
|
|
20
|
+
// If it has a path, this display class isn't equipped to load it.
|
|
21
|
+
// Log a warning and show an error in the iframe.
|
|
22
|
+
console.warn(`HtmlArtifactDisplay received artifact with path: ${this.artifact.path}. This display expects direct HTML content.`);
|
|
23
|
+
iframe.srcdoc = '<p class="haibun-artifact-error">Error: Artifact is a path, but direct HTML content was expected.</p>';
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
iframe.srcdoc = '<p class="haibun-artifact-error">Error: HTML content not available or in an unexpected format.</p>';
|
|
27
|
+
}
|
|
28
|
+
container.appendChild(iframe);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=htmlArtifactDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htmlArtifactDisplay.js","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/htmlArtifactDisplay.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,MAAM,OAAO,mBAAoB,SAAQ,eAAe;IAEjC;IADb,eAAe,GAAG,SAAS,CAAC;IACrC,YAAsB,QAAuB;QAC5C,KAAK,CAAC,QAAQ,CAAC,CAAC;QADK,aAAQ,GAAR,QAAQ,CAAe;IAE7C,CAAC;IACM,MAAM,CAAC,SAAsB;QACnC,SAAS,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,oBAAoB;QAC9C,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QAC7B,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;QAC5B,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QAE7B,6EAA6E;QAC7E,IAAI,MAAM,IAAI,IAAI,CAAC,QAAQ,IAAI,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACvE,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QACpC,CAAC;aAAM,IAAI,MAAM,IAAI,IAAI,CAAC,QAAQ,IAAI,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC9E,kEAAkE;YAClE,iDAAiD;YACjD,OAAO,CAAC,IAAI,CAAC,oDAAoD,IAAI,CAAC,QAAQ,CAAC,IAAI,6CAA6C,CAAC,CAAC;YACzH,MAAM,CAAC,MAAM,GAAG,uGAAuG,CAAC;QAClI,CAAC;aAAM,CAAC;YACE,MAAM,CAAC,MAAM,GAAG,oGAAoG,CAAC;QACzH,CAAC;QACP,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;CACD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TArtifactImage } from '@haibun/core/build/lib/interfaces/logger.js';
|
|
2
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
3
|
+
export declare class ImageArtifactDisplay extends ArtifactDisplay {
|
|
4
|
+
protected artifact: TArtifactImage;
|
|
5
|
+
readonly placementTarget = "details";
|
|
6
|
+
constructor(artifact: TArtifactImage);
|
|
7
|
+
render(container: HTMLElement): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=imageArtifactDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imageArtifactDisplay.d.ts","sourceRoot":"","sources":["../../../src/monitor/artifactDisplays/imageArtifactDisplay.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,qBAAa,oBAAqB,SAAQ,eAAe;IAEzC,SAAS,CAAC,QAAQ,EAAE,cAAc;IAD9C,QAAQ,CAAC,eAAe,aAAa;gBACf,QAAQ,EAAE,cAAc;IAIvC,MAAM,CAAC,SAAS,EAAE,WAAW,GAAG,IAAI;CAM9C"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ArtifactDisplay } from './artifactDisplayBase.js';
|
|
2
|
+
export class ImageArtifactDisplay extends ArtifactDisplay {
|
|
3
|
+
artifact;
|
|
4
|
+
placementTarget = 'details'; // This artifact is always placed in details
|
|
5
|
+
constructor(artifact) {
|
|
6
|
+
super(artifact); // type is 'image' by default from TArtifactImage
|
|
7
|
+
this.artifact = artifact;
|
|
8
|
+
// Element creation is deferred to render method
|
|
9
|
+
}
|
|
10
|
+
render(container) {
|
|
11
|
+
const imgElement = document.createElement('img');
|
|
12
|
+
imgElement.alt = 'Screen capture artifact'; // Default alt text
|
|
13
|
+
imgElement.src = this.artifact.path;
|
|
14
|
+
container.replaceChildren(imgElement); // Clear placeholder and add image
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=imageArtifactDisplay.js.map
|