@infinilabs/ai-chat 0.0.0 → 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/README.md +301 -56
  2. package/dist/_baseUniq-BQcAhV7E.js +152 -0
  3. package/dist/arc-2jwvQ2TN.js +131 -0
  4. package/dist/architecture-U656AL7Q-WuSilpZW.js +5 -0
  5. package/dist/architectureDiagram-VXUJARFQ-D6SKNy5z.js +8681 -0
  6. package/dist/blockDiagram-VD42YOAC-Ct2DD8jj.js +3606 -0
  7. package/dist/c4Diagram-YG6GDRKO-B7wBU4mz.js +2481 -0
  8. package/dist/channel-BRREX19f.js +7 -0
  9. package/dist/chunk-4BX2VUAB-BnghU1_v.js +16 -0
  10. package/dist/chunk-55IACEB6-Dduk-DEL.js +13 -0
  11. package/dist/chunk-B4BG7PRW-DeHw-z-x.js +1826 -0
  12. package/dist/chunk-DI55MBZ5-GTHMAr0M.js +1915 -0
  13. package/dist/chunk-FMBD7UC4-Bchh4_3W.js +19 -0
  14. package/dist/chunk-QN33PNHL-H6S-NYp0.js +24 -0
  15. package/dist/chunk-QZHKN3VN-DdcyNnvM.js +17 -0
  16. package/dist/chunk-TZMSLE5B-C7te_j4V.js +108 -0
  17. package/dist/classDiagram-2ON5EDUG-CNkHY_Y7.js +19 -0
  18. package/dist/classDiagram-v2-WZHVMYZB-CNkHY_Y7.js +19 -0
  19. package/dist/clone-DnOD7gQ4.js +8 -0
  20. package/dist/cose-bilkent-S5V4N54A-2EKtTYth.js +4942 -0
  21. package/dist/cytoscape.esm-BfvZ3QT_.js +30239 -0
  22. package/dist/dagre-6UL2VRFP-oJLNDO4O.js +693 -0
  23. package/dist/defaultLocale-DVr69WTU.js +206 -0
  24. package/dist/diagram-PSM6KHXK-DhMgmu9h.js +845 -0
  25. package/dist/diagram-QEK2KX5R-pB1vUeno.js +300 -0
  26. package/dist/diagram-S2PKOQOG-HTooIr24.js +210 -0
  27. package/dist/erDiagram-Q2GNP2WA-CCaN2EHf.js +1158 -0
  28. package/dist/flowDiagram-NV44I4VS-CG0erQtl.js +2331 -0
  29. package/dist/ganttDiagram-JELNMOA3-D3rSLJec.js +3679 -0
  30. package/dist/gitGraph-F6HP7TQM-BDWdXs6A.js +5 -0
  31. package/dist/gitGraphDiagram-NY62KEGX-Ip-PiLDb.js +1203 -0
  32. package/dist/graph-wCViE1vL.js +596 -0
  33. package/dist/index-BQvQI7yA.js +117302 -0
  34. package/dist/index.css +1834 -82
  35. package/dist/index.js +5 -19966
  36. package/dist/info-NVLQJR56-pJlVBPs6.js +5 -0
  37. package/dist/infoDiagram-WHAUD3N6-BbVs4x8y.js +31 -0
  38. package/dist/init-ZxktEp_H.js +16 -0
  39. package/dist/journeyDiagram-XKPGCS4Q-Cz9ox9GA.js +1254 -0
  40. package/dist/kanban-definition-3W4ZIXB7-ChdUHO5f.js +1047 -0
  41. package/dist/katex-ei8sH3Uy.js +14524 -0
  42. package/dist/layout-BaZPdTGN.js +2183 -0
  43. package/dist/linear-D_RX7hM-.js +340 -0
  44. package/dist/mermaid-parser.core-_sn6A3wB.js +18704 -0
  45. package/dist/min-BxeM4Drj.js +41 -0
  46. package/dist/mindmap-definition-VGOIOE7T-BkjJibdi.js +1126 -0
  47. package/dist/ordinal-CxptdPJm.js +76 -0
  48. package/dist/packet-BFZMPI3H-D3RtU0mc.js +5 -0
  49. package/dist/pie-7BOR55EZ-xH--CiaM.js +5 -0
  50. package/dist/pieDiagram-ADFJNKIX-2Yr1gkth.js +237 -0
  51. package/dist/quadrantDiagram-AYHSOK5B-CjicpXRv.js +1335 -0
  52. package/dist/radar-NHE76QYJ-CL0tHnUP.js +5 -0
  53. package/dist/requirementDiagram-UZGBJVZJ-DBnhlfjR.js +1161 -0
  54. package/dist/sankeyDiagram-TZEHDZUN-B2FErKCa.js +1193 -0
  55. package/dist/sequenceDiagram-WL72ISMW-BkNTlRlB.js +3874 -0
  56. package/dist/stateDiagram-FKZM4ZOC-CAAFQtS9.js +447 -0
  57. package/dist/stateDiagram-v2-4FDKWEC3-lF6kUebI.js +19 -0
  58. package/dist/timeline-definition-IT6M3QCI-CQgMFEPA.js +1222 -0
  59. package/dist/treemap-KMMF4GRG-B0Mc-u8X.js +5 -0
  60. package/dist/xychartDiagram-PRI3JC2R-Cee7LdLr.js +1886 -0
  61. package/package.json +6 -7
@@ -0,0 +1,300 @@
1
+ import { _ as __name, s as setAccDescription, g as getAccDescription, q as getDiagramTitle, p as setDiagramTitle, a as getAccTitle, b as setAccTitle, H as selectSvgElement, y as clear, D as cleanAndMerge, E as getConfig, F as defaultConfig_default, l as log, K as getThemeVariables3 } from "./index-BQvQI7yA.js";
2
+ import { p as populateCommonDb } from "./chunk-4BX2VUAB-BnghU1_v.js";
3
+ import { p as parse } from "./mermaid-parser.core-_sn6A3wB.js";
4
+ var defaultOptions = {
5
+ showLegend: true,
6
+ ticks: 5,
7
+ max: null,
8
+ min: 0,
9
+ graticule: "circle"
10
+ };
11
+ var defaultRadarData = {
12
+ axes: [],
13
+ curves: [],
14
+ options: defaultOptions
15
+ };
16
+ var data = structuredClone(defaultRadarData);
17
+ var DEFAULT_RADAR_CONFIG = defaultConfig_default.radar;
18
+ var getConfig2 = /* @__PURE__ */ __name(() => {
19
+ const config = cleanAndMerge({
20
+ ...DEFAULT_RADAR_CONFIG,
21
+ ...getConfig().radar
22
+ });
23
+ return config;
24
+ }, "getConfig");
25
+ var getAxes = /* @__PURE__ */ __name(() => data.axes, "getAxes");
26
+ var getCurves = /* @__PURE__ */ __name(() => data.curves, "getCurves");
27
+ var getOptions = /* @__PURE__ */ __name(() => data.options, "getOptions");
28
+ var setAxes = /* @__PURE__ */ __name((axes) => {
29
+ data.axes = axes.map((axis) => {
30
+ return {
31
+ name: axis.name,
32
+ label: axis.label ?? axis.name
33
+ };
34
+ });
35
+ }, "setAxes");
36
+ var setCurves = /* @__PURE__ */ __name((curves) => {
37
+ data.curves = curves.map((curve) => {
38
+ return {
39
+ name: curve.name,
40
+ label: curve.label ?? curve.name,
41
+ entries: computeCurveEntries(curve.entries)
42
+ };
43
+ });
44
+ }, "setCurves");
45
+ var computeCurveEntries = /* @__PURE__ */ __name((entries) => {
46
+ if (entries[0].axis == void 0) {
47
+ return entries.map((entry) => entry.value);
48
+ }
49
+ const axes = getAxes();
50
+ if (axes.length === 0) {
51
+ throw new Error("Axes must be populated before curves for reference entries");
52
+ }
53
+ return axes.map((axis) => {
54
+ const entry = entries.find((entry2) => entry2.axis?.$refText === axis.name);
55
+ if (entry === void 0) {
56
+ throw new Error("Missing entry for axis " + axis.label);
57
+ }
58
+ return entry.value;
59
+ });
60
+ }, "computeCurveEntries");
61
+ var setOptions = /* @__PURE__ */ __name((options) => {
62
+ const optionMap = options.reduce(
63
+ (acc, option) => {
64
+ acc[option.name] = option;
65
+ return acc;
66
+ },
67
+ {}
68
+ );
69
+ data.options = {
70
+ showLegend: optionMap.showLegend?.value ?? defaultOptions.showLegend,
71
+ ticks: optionMap.ticks?.value ?? defaultOptions.ticks,
72
+ max: optionMap.max?.value ?? defaultOptions.max,
73
+ min: optionMap.min?.value ?? defaultOptions.min,
74
+ graticule: optionMap.graticule?.value ?? defaultOptions.graticule
75
+ };
76
+ }, "setOptions");
77
+ var clear2 = /* @__PURE__ */ __name(() => {
78
+ clear();
79
+ data = structuredClone(defaultRadarData);
80
+ }, "clear");
81
+ var db = {
82
+ getAxes,
83
+ getCurves,
84
+ getOptions,
85
+ setAxes,
86
+ setCurves,
87
+ setOptions,
88
+ getConfig: getConfig2,
89
+ clear: clear2,
90
+ setAccTitle,
91
+ getAccTitle,
92
+ setDiagramTitle,
93
+ getDiagramTitle,
94
+ getAccDescription,
95
+ setAccDescription
96
+ };
97
+ var populate = /* @__PURE__ */ __name((ast) => {
98
+ populateCommonDb(ast, db);
99
+ const { axes, curves, options } = ast;
100
+ db.setAxes(axes);
101
+ db.setCurves(curves);
102
+ db.setOptions(options);
103
+ }, "populate");
104
+ var parser = {
105
+ parse: /* @__PURE__ */ __name(async (input) => {
106
+ const ast = await parse("radar", input);
107
+ log.debug(ast);
108
+ populate(ast);
109
+ }, "parse")
110
+ };
111
+ var draw = /* @__PURE__ */ __name((_text, id, _version, diagram2) => {
112
+ const db2 = diagram2.db;
113
+ const axes = db2.getAxes();
114
+ const curves = db2.getCurves();
115
+ const options = db2.getOptions();
116
+ const config = db2.getConfig();
117
+ const title = db2.getDiagramTitle();
118
+ const svg = selectSvgElement(id);
119
+ const g = drawFrame(svg, config);
120
+ const maxValue = options.max ?? Math.max(...curves.map((curve) => Math.max(...curve.entries)));
121
+ const minValue = options.min;
122
+ const radius = Math.min(config.width, config.height) / 2;
123
+ drawGraticule(g, axes, radius, options.ticks, options.graticule);
124
+ drawAxes(g, axes, radius, config);
125
+ drawCurves(g, axes, curves, minValue, maxValue, options.graticule, config);
126
+ drawLegend(g, curves, options.showLegend, config);
127
+ g.append("text").attr("class", "radarTitle").text(title).attr("x", 0).attr("y", -config.height / 2 - config.marginTop);
128
+ }, "draw");
129
+ var drawFrame = /* @__PURE__ */ __name((svg, config) => {
130
+ const totalWidth = config.width + config.marginLeft + config.marginRight;
131
+ const totalHeight = config.height + config.marginTop + config.marginBottom;
132
+ const center = {
133
+ x: config.marginLeft + config.width / 2,
134
+ y: config.marginTop + config.height / 2
135
+ };
136
+ svg.attr("viewbox", `0 0 ${totalWidth} ${totalHeight}`).attr("width", totalWidth).attr("height", totalHeight);
137
+ return svg.append("g").attr("transform", `translate(${center.x}, ${center.y})`);
138
+ }, "drawFrame");
139
+ var drawGraticule = /* @__PURE__ */ __name((g, axes, radius, ticks, graticule) => {
140
+ if (graticule === "circle") {
141
+ for (let i = 0; i < ticks; i++) {
142
+ const r = radius * (i + 1) / ticks;
143
+ g.append("circle").attr("r", r).attr("class", "radarGraticule");
144
+ }
145
+ } else if (graticule === "polygon") {
146
+ const numAxes = axes.length;
147
+ for (let i = 0; i < ticks; i++) {
148
+ const r = radius * (i + 1) / ticks;
149
+ const points = axes.map((_, j) => {
150
+ const angle = 2 * j * Math.PI / numAxes - Math.PI / 2;
151
+ const x = r * Math.cos(angle);
152
+ const y = r * Math.sin(angle);
153
+ return `${x},${y}`;
154
+ }).join(" ");
155
+ g.append("polygon").attr("points", points).attr("class", "radarGraticule");
156
+ }
157
+ }
158
+ }, "drawGraticule");
159
+ var drawAxes = /* @__PURE__ */ __name((g, axes, radius, config) => {
160
+ const numAxes = axes.length;
161
+ for (let i = 0; i < numAxes; i++) {
162
+ const label = axes[i].label;
163
+ const angle = 2 * i * Math.PI / numAxes - Math.PI / 2;
164
+ g.append("line").attr("x1", 0).attr("y1", 0).attr("x2", radius * config.axisScaleFactor * Math.cos(angle)).attr("y2", radius * config.axisScaleFactor * Math.sin(angle)).attr("class", "radarAxisLine");
165
+ g.append("text").text(label).attr("x", radius * config.axisLabelFactor * Math.cos(angle)).attr("y", radius * config.axisLabelFactor * Math.sin(angle)).attr("class", "radarAxisLabel");
166
+ }
167
+ }, "drawAxes");
168
+ function drawCurves(g, axes, curves, minValue, maxValue, graticule, config) {
169
+ const numAxes = axes.length;
170
+ const radius = Math.min(config.width, config.height) / 2;
171
+ curves.forEach((curve, index) => {
172
+ if (curve.entries.length !== numAxes) {
173
+ return;
174
+ }
175
+ const points = curve.entries.map((entry, i) => {
176
+ const angle = 2 * Math.PI * i / numAxes - Math.PI / 2;
177
+ const r = relativeRadius(entry, minValue, maxValue, radius);
178
+ const x = r * Math.cos(angle);
179
+ const y = r * Math.sin(angle);
180
+ return { x, y };
181
+ });
182
+ if (graticule === "circle") {
183
+ g.append("path").attr("d", closedRoundCurve(points, config.curveTension)).attr("class", `radarCurve-${index}`);
184
+ } else if (graticule === "polygon") {
185
+ g.append("polygon").attr("points", points.map((p) => `${p.x},${p.y}`).join(" ")).attr("class", `radarCurve-${index}`);
186
+ }
187
+ });
188
+ }
189
+ __name(drawCurves, "drawCurves");
190
+ function relativeRadius(value, minValue, maxValue, radius) {
191
+ const clippedValue = Math.min(Math.max(value, minValue), maxValue);
192
+ return radius * (clippedValue - minValue) / (maxValue - minValue);
193
+ }
194
+ __name(relativeRadius, "relativeRadius");
195
+ function closedRoundCurve(points, tension) {
196
+ const numPoints = points.length;
197
+ let d = `M${points[0].x},${points[0].y}`;
198
+ for (let i = 0; i < numPoints; i++) {
199
+ const p0 = points[(i - 1 + numPoints) % numPoints];
200
+ const p1 = points[i];
201
+ const p2 = points[(i + 1) % numPoints];
202
+ const p3 = points[(i + 2) % numPoints];
203
+ const cp1 = {
204
+ x: p1.x + (p2.x - p0.x) * tension,
205
+ y: p1.y + (p2.y - p0.y) * tension
206
+ };
207
+ const cp2 = {
208
+ x: p2.x - (p3.x - p1.x) * tension,
209
+ y: p2.y - (p3.y - p1.y) * tension
210
+ };
211
+ d += ` C${cp1.x},${cp1.y} ${cp2.x},${cp2.y} ${p2.x},${p2.y}`;
212
+ }
213
+ return `${d} Z`;
214
+ }
215
+ __name(closedRoundCurve, "closedRoundCurve");
216
+ function drawLegend(g, curves, showLegend, config) {
217
+ if (!showLegend) {
218
+ return;
219
+ }
220
+ const legendX = (config.width / 2 + config.marginRight) * 3 / 4;
221
+ const legendY = -(config.height / 2 + config.marginTop) * 3 / 4;
222
+ const lineHeight = 20;
223
+ curves.forEach((curve, index) => {
224
+ const itemGroup = g.append("g").attr("transform", `translate(${legendX}, ${legendY + index * lineHeight})`);
225
+ itemGroup.append("rect").attr("width", 12).attr("height", 12).attr("class", `radarLegendBox-${index}`);
226
+ itemGroup.append("text").attr("x", 16).attr("y", 0).attr("class", "radarLegendText").text(curve.label);
227
+ });
228
+ }
229
+ __name(drawLegend, "drawLegend");
230
+ var renderer = { draw };
231
+ var genIndexStyles = /* @__PURE__ */ __name((themeVariables, radarOptions) => {
232
+ let sections = "";
233
+ for (let i = 0; i < themeVariables.THEME_COLOR_LIMIT; i++) {
234
+ const indexColor = themeVariables[`cScale${i}`];
235
+ sections += `
236
+ .radarCurve-${i} {
237
+ color: ${indexColor};
238
+ fill: ${indexColor};
239
+ fill-opacity: ${radarOptions.curveOpacity};
240
+ stroke: ${indexColor};
241
+ stroke-width: ${radarOptions.curveStrokeWidth};
242
+ }
243
+ .radarLegendBox-${i} {
244
+ fill: ${indexColor};
245
+ fill-opacity: ${radarOptions.curveOpacity};
246
+ stroke: ${indexColor};
247
+ }
248
+ `;
249
+ }
250
+ return sections;
251
+ }, "genIndexStyles");
252
+ var buildRadarStyleOptions = /* @__PURE__ */ __name((radar) => {
253
+ const defaultThemeVariables = getThemeVariables3();
254
+ const currentConfig = getConfig();
255
+ const themeVariables = cleanAndMerge(defaultThemeVariables, currentConfig.themeVariables);
256
+ const radarOptions = cleanAndMerge(themeVariables.radar, radar);
257
+ return { themeVariables, radarOptions };
258
+ }, "buildRadarStyleOptions");
259
+ var styles = /* @__PURE__ */ __name(({ radar } = {}) => {
260
+ const { themeVariables, radarOptions } = buildRadarStyleOptions(radar);
261
+ return `
262
+ .radarTitle {
263
+ font-size: ${themeVariables.fontSize};
264
+ color: ${themeVariables.titleColor};
265
+ dominant-baseline: hanging;
266
+ text-anchor: middle;
267
+ }
268
+ .radarAxisLine {
269
+ stroke: ${radarOptions.axisColor};
270
+ stroke-width: ${radarOptions.axisStrokeWidth};
271
+ }
272
+ .radarAxisLabel {
273
+ dominant-baseline: middle;
274
+ text-anchor: middle;
275
+ font-size: ${radarOptions.axisLabelFontSize}px;
276
+ color: ${radarOptions.axisColor};
277
+ }
278
+ .radarGraticule {
279
+ fill: ${radarOptions.graticuleColor};
280
+ fill-opacity: ${radarOptions.graticuleOpacity};
281
+ stroke: ${radarOptions.graticuleColor};
282
+ stroke-width: ${radarOptions.graticuleStrokeWidth};
283
+ }
284
+ .radarLegendText {
285
+ text-anchor: start;
286
+ font-size: ${radarOptions.legendFontSize}px;
287
+ dominant-baseline: hanging;
288
+ }
289
+ ${genIndexStyles(themeVariables, radarOptions)}
290
+ `;
291
+ }, "styles");
292
+ var diagram = {
293
+ parser,
294
+ db,
295
+ renderer,
296
+ styles
297
+ };
298
+ export {
299
+ diagram
300
+ };
@@ -0,0 +1,210 @@
1
+ var _a;
2
+ import { _ as __name, D as cleanAndMerge, H as selectSvgElement, e as configureSvgSize, l as log, b as setAccTitle, a as getAccTitle, p as setDiagramTitle, q as getDiagramTitle, g as getAccDescription, s as setAccDescription, E as getConfig, F as defaultConfig_default, y as clear } from "./index-BQvQI7yA.js";
3
+ import { p as populateCommonDb } from "./chunk-4BX2VUAB-BnghU1_v.js";
4
+ import { p as parse } from "./mermaid-parser.core-_sn6A3wB.js";
5
+ var DEFAULT_PACKET_CONFIG = defaultConfig_default.packet;
6
+ var PacketDB = (_a = class {
7
+ constructor() {
8
+ this.packet = [];
9
+ this.setAccTitle = setAccTitle;
10
+ this.getAccTitle = getAccTitle;
11
+ this.setDiagramTitle = setDiagramTitle;
12
+ this.getDiagramTitle = getDiagramTitle;
13
+ this.getAccDescription = getAccDescription;
14
+ this.setAccDescription = setAccDescription;
15
+ }
16
+ getConfig() {
17
+ const config = cleanAndMerge({
18
+ ...DEFAULT_PACKET_CONFIG,
19
+ ...getConfig().packet
20
+ });
21
+ if (config.showBits) {
22
+ config.paddingY += 10;
23
+ }
24
+ return config;
25
+ }
26
+ getPacket() {
27
+ return this.packet;
28
+ }
29
+ pushWord(word) {
30
+ if (word.length > 0) {
31
+ this.packet.push(word);
32
+ }
33
+ }
34
+ clear() {
35
+ clear();
36
+ this.packet = [];
37
+ }
38
+ }, __name(_a, "PacketDB"), _a);
39
+ var maxPacketSize = 1e4;
40
+ var populate = /* @__PURE__ */ __name((ast, db) => {
41
+ populateCommonDb(ast, db);
42
+ let lastBit = -1;
43
+ let word = [];
44
+ let row = 1;
45
+ const { bitsPerRow } = db.getConfig();
46
+ for (let { start, end, bits, label } of ast.blocks) {
47
+ if (start !== void 0 && end !== void 0 && end < start) {
48
+ throw new Error(`Packet block ${start} - ${end} is invalid. End must be greater than start.`);
49
+ }
50
+ start ??= lastBit + 1;
51
+ if (start !== lastBit + 1) {
52
+ throw new Error(
53
+ `Packet block ${start} - ${end ?? start} is not contiguous. It should start from ${lastBit + 1}.`
54
+ );
55
+ }
56
+ if (bits === 0) {
57
+ throw new Error(`Packet block ${start} is invalid. Cannot have a zero bit field.`);
58
+ }
59
+ end ??= start + (bits ?? 1) - 1;
60
+ bits ??= end - start + 1;
61
+ lastBit = end;
62
+ log.debug(`Packet block ${start} - ${lastBit} with label ${label}`);
63
+ while (word.length <= bitsPerRow + 1 && db.getPacket().length < maxPacketSize) {
64
+ const [block, nextBlock] = getNextFittingBlock({ start, end, bits, label }, row, bitsPerRow);
65
+ word.push(block);
66
+ if (block.end + 1 === row * bitsPerRow) {
67
+ db.pushWord(word);
68
+ word = [];
69
+ row++;
70
+ }
71
+ if (!nextBlock) {
72
+ break;
73
+ }
74
+ ({ start, end, bits, label } = nextBlock);
75
+ }
76
+ }
77
+ db.pushWord(word);
78
+ }, "populate");
79
+ var getNextFittingBlock = /* @__PURE__ */ __name((block, row, bitsPerRow) => {
80
+ if (block.start === void 0) {
81
+ throw new Error("start should have been set during first phase");
82
+ }
83
+ if (block.end === void 0) {
84
+ throw new Error("end should have been set during first phase");
85
+ }
86
+ if (block.start > block.end) {
87
+ throw new Error(`Block start ${block.start} is greater than block end ${block.end}.`);
88
+ }
89
+ if (block.end + 1 <= row * bitsPerRow) {
90
+ return [block, void 0];
91
+ }
92
+ const rowEnd = row * bitsPerRow - 1;
93
+ const rowStart = row * bitsPerRow;
94
+ return [
95
+ {
96
+ start: block.start,
97
+ end: rowEnd,
98
+ label: block.label,
99
+ bits: rowEnd - block.start
100
+ },
101
+ {
102
+ start: rowStart,
103
+ end: block.end,
104
+ label: block.label,
105
+ bits: block.end - rowStart
106
+ }
107
+ ];
108
+ }, "getNextFittingBlock");
109
+ var parser = {
110
+ // @ts-expect-error - PacketDB is not assignable to DiagramDB
111
+ parser: { yy: void 0 },
112
+ parse: /* @__PURE__ */ __name(async (input) => {
113
+ const ast = await parse("packet", input);
114
+ const db = parser.parser?.yy;
115
+ if (!(db instanceof PacketDB)) {
116
+ throw new Error(
117
+ "parser.parser?.yy was not a PacketDB. This is due to a bug within Mermaid, please report this issue at https://github.com/mermaid-js/mermaid/issues."
118
+ );
119
+ }
120
+ log.debug(ast);
121
+ populate(ast, db);
122
+ }, "parse")
123
+ };
124
+ var draw = /* @__PURE__ */ __name((_text, id, _version, diagram2) => {
125
+ const db = diagram2.db;
126
+ const config = db.getConfig();
127
+ const { rowHeight, paddingY, bitWidth, bitsPerRow } = config;
128
+ const words = db.getPacket();
129
+ const title = db.getDiagramTitle();
130
+ const totalRowHeight = rowHeight + paddingY;
131
+ const svgHeight = totalRowHeight * (words.length + 1) - (title ? 0 : rowHeight);
132
+ const svgWidth = bitWidth * bitsPerRow + 2;
133
+ const svg = selectSvgElement(id);
134
+ svg.attr("viewbox", `0 0 ${svgWidth} ${svgHeight}`);
135
+ configureSvgSize(svg, svgHeight, svgWidth, config.useMaxWidth);
136
+ for (const [word, packet] of words.entries()) {
137
+ drawWord(svg, packet, word, config);
138
+ }
139
+ svg.append("text").text(title).attr("x", svgWidth / 2).attr("y", svgHeight - totalRowHeight / 2).attr("dominant-baseline", "middle").attr("text-anchor", "middle").attr("class", "packetTitle");
140
+ }, "draw");
141
+ var drawWord = /* @__PURE__ */ __name((svg, word, rowNumber, { rowHeight, paddingX, paddingY, bitWidth, bitsPerRow, showBits }) => {
142
+ const group = svg.append("g");
143
+ const wordY = rowNumber * (rowHeight + paddingY) + paddingY;
144
+ for (const block of word) {
145
+ const blockX = block.start % bitsPerRow * bitWidth + 1;
146
+ const width = (block.end - block.start + 1) * bitWidth - paddingX;
147
+ group.append("rect").attr("x", blockX).attr("y", wordY).attr("width", width).attr("height", rowHeight).attr("class", "packetBlock");
148
+ group.append("text").attr("x", blockX + width / 2).attr("y", wordY + rowHeight / 2).attr("class", "packetLabel").attr("dominant-baseline", "middle").attr("text-anchor", "middle").text(block.label);
149
+ if (!showBits) {
150
+ continue;
151
+ }
152
+ const isSingleBlock = block.end === block.start;
153
+ const bitNumberY = wordY - 2;
154
+ group.append("text").attr("x", blockX + (isSingleBlock ? width / 2 : 0)).attr("y", bitNumberY).attr("class", "packetByte start").attr("dominant-baseline", "auto").attr("text-anchor", isSingleBlock ? "middle" : "start").text(block.start);
155
+ if (!isSingleBlock) {
156
+ group.append("text").attr("x", blockX + width).attr("y", bitNumberY).attr("class", "packetByte end").attr("dominant-baseline", "auto").attr("text-anchor", "end").text(block.end);
157
+ }
158
+ }
159
+ }, "drawWord");
160
+ var renderer = { draw };
161
+ var defaultPacketStyleOptions = {
162
+ byteFontSize: "10px",
163
+ startByteColor: "black",
164
+ endByteColor: "black",
165
+ labelColor: "black",
166
+ labelFontSize: "12px",
167
+ titleColor: "black",
168
+ titleFontSize: "14px",
169
+ blockStrokeColor: "black",
170
+ blockStrokeWidth: "1",
171
+ blockFillColor: "#efefef"
172
+ };
173
+ var styles = /* @__PURE__ */ __name(({ packet } = {}) => {
174
+ const options = cleanAndMerge(defaultPacketStyleOptions, packet);
175
+ return `
176
+ .packetByte {
177
+ font-size: ${options.byteFontSize};
178
+ }
179
+ .packetByte.start {
180
+ fill: ${options.startByteColor};
181
+ }
182
+ .packetByte.end {
183
+ fill: ${options.endByteColor};
184
+ }
185
+ .packetLabel {
186
+ fill: ${options.labelColor};
187
+ font-size: ${options.labelFontSize};
188
+ }
189
+ .packetTitle {
190
+ fill: ${options.titleColor};
191
+ font-size: ${options.titleFontSize};
192
+ }
193
+ .packetBlock {
194
+ stroke: ${options.blockStrokeColor};
195
+ stroke-width: ${options.blockStrokeWidth};
196
+ fill: ${options.blockFillColor};
197
+ }
198
+ `;
199
+ }, "styles");
200
+ var diagram = {
201
+ parser,
202
+ get db() {
203
+ return new PacketDB();
204
+ },
205
+ renderer,
206
+ styles
207
+ };
208
+ export {
209
+ diagram
210
+ };