@shumoku/core 0.1.1 → 0.2.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.
Files changed (157) hide show
  1. package/dist/constants.d.ts +23 -0
  2. package/dist/constants.d.ts.map +1 -0
  3. package/dist/constants.js +25 -0
  4. package/dist/constants.js.map +1 -0
  5. package/dist/index.d.ts +1 -0
  6. package/dist/index.d.ts.map +1 -1
  7. package/dist/index.js +2 -0
  8. package/dist/index.js.map +1 -1
  9. package/dist/layout/hierarchical.d.ts +12 -39
  10. package/dist/layout/hierarchical.d.ts.map +1 -1
  11. package/dist/layout/hierarchical.js +697 -1015
  12. package/dist/layout/hierarchical.js.map +1 -1
  13. package/dist/models/types.d.ts +30 -0
  14. package/dist/models/types.d.ts.map +1 -1
  15. package/dist/models/types.js.map +1 -1
  16. package/dist/renderer/svg.d.ts +31 -5
  17. package/dist/renderer/svg.d.ts.map +1 -1
  18. package/dist/renderer/svg.js +312 -85
  19. package/dist/renderer/svg.js.map +1 -1
  20. package/package.json +1 -1
  21. package/src/constants.ts +35 -0
  22. package/src/index.ts +3 -0
  23. package/src/layout/hierarchical.ts +805 -1127
  24. package/src/models/types.ts +37 -0
  25. package/src/renderer/svg.ts +368 -88
  26. package/dist/renderer/components/index.d.ts +0 -8
  27. package/dist/renderer/components/index.d.ts.map +0 -1
  28. package/dist/renderer/components/index.js +0 -8
  29. package/dist/renderer/components/index.js.map +0 -1
  30. package/dist/renderer/components/link-renderer.d.ts +0 -11
  31. package/dist/renderer/components/link-renderer.d.ts.map +0 -1
  32. package/dist/renderer/components/link-renderer.js +0 -340
  33. package/dist/renderer/components/link-renderer.js.map +0 -1
  34. package/dist/renderer/components/node-renderer.d.ts +0 -14
  35. package/dist/renderer/components/node-renderer.d.ts.map +0 -1
  36. package/dist/renderer/components/node-renderer.js +0 -242
  37. package/dist/renderer/components/node-renderer.js.map +0 -1
  38. package/dist/renderer/components/port-renderer.d.ts +0 -8
  39. package/dist/renderer/components/port-renderer.d.ts.map +0 -1
  40. package/dist/renderer/components/port-renderer.js +0 -85
  41. package/dist/renderer/components/port-renderer.js.map +0 -1
  42. package/dist/renderer/components/subgraph-renderer.d.ts +0 -13
  43. package/dist/renderer/components/subgraph-renderer.d.ts.map +0 -1
  44. package/dist/renderer/components/subgraph-renderer.js +0 -85
  45. package/dist/renderer/components/subgraph-renderer.js.map +0 -1
  46. package/dist/renderer/icon-registry/index.d.ts +0 -6
  47. package/dist/renderer/icon-registry/index.d.ts.map +0 -1
  48. package/dist/renderer/icon-registry/index.js +0 -5
  49. package/dist/renderer/icon-registry/index.js.map +0 -1
  50. package/dist/renderer/icon-registry/registry.d.ts +0 -25
  51. package/dist/renderer/icon-registry/registry.d.ts.map +0 -1
  52. package/dist/renderer/icon-registry/registry.js +0 -85
  53. package/dist/renderer/icon-registry/registry.js.map +0 -1
  54. package/dist/renderer/icon-registry/types.d.ts +0 -44
  55. package/dist/renderer/icon-registry/types.d.ts.map +0 -1
  56. package/dist/renderer/icon-registry/types.js +0 -5
  57. package/dist/renderer/icon-registry/types.js.map +0 -1
  58. package/dist/renderer/render-model/builder.d.ts +0 -43
  59. package/dist/renderer/render-model/builder.d.ts.map +0 -1
  60. package/dist/renderer/render-model/builder.js +0 -646
  61. package/dist/renderer/render-model/builder.js.map +0 -1
  62. package/dist/renderer/render-model/index.d.ts +0 -6
  63. package/dist/renderer/render-model/index.d.ts.map +0 -1
  64. package/dist/renderer/render-model/index.js +0 -5
  65. package/dist/renderer/render-model/index.js.map +0 -1
  66. package/dist/renderer/render-model/types.d.ts +0 -216
  67. package/dist/renderer/render-model/types.d.ts.map +0 -1
  68. package/dist/renderer/render-model/types.js +0 -6
  69. package/dist/renderer/render-model/types.js.map +0 -1
  70. package/dist/renderer/renderer-types.d.ts +0 -55
  71. package/dist/renderer/renderer-types.d.ts.map +0 -1
  72. package/dist/renderer/renderer-types.js +0 -5
  73. package/dist/renderer/renderer-types.js.map +0 -1
  74. package/dist/renderer/svg-builder.d.ts +0 -152
  75. package/dist/renderer/svg-builder.d.ts.map +0 -1
  76. package/dist/renderer/svg-builder.js +0 -176
  77. package/dist/renderer/svg-builder.js.map +0 -1
  78. package/dist/renderer/svg-dom/builders/defs.d.ts +0 -10
  79. package/dist/renderer/svg-dom/builders/defs.d.ts.map +0 -1
  80. package/dist/renderer/svg-dom/builders/defs.js +0 -82
  81. package/dist/renderer/svg-dom/builders/defs.js.map +0 -1
  82. package/dist/renderer/svg-dom/builders/index.d.ts +0 -9
  83. package/dist/renderer/svg-dom/builders/index.d.ts.map +0 -1
  84. package/dist/renderer/svg-dom/builders/index.js +0 -9
  85. package/dist/renderer/svg-dom/builders/index.js.map +0 -1
  86. package/dist/renderer/svg-dom/builders/link.d.ts +0 -18
  87. package/dist/renderer/svg-dom/builders/link.d.ts.map +0 -1
  88. package/dist/renderer/svg-dom/builders/link.js +0 -188
  89. package/dist/renderer/svg-dom/builders/link.js.map +0 -1
  90. package/dist/renderer/svg-dom/builders/node.d.ts +0 -15
  91. package/dist/renderer/svg-dom/builders/node.d.ts.map +0 -1
  92. package/dist/renderer/svg-dom/builders/node.js +0 -262
  93. package/dist/renderer/svg-dom/builders/node.js.map +0 -1
  94. package/dist/renderer/svg-dom/builders/subgraph.d.ts +0 -14
  95. package/dist/renderer/svg-dom/builders/subgraph.d.ts.map +0 -1
  96. package/dist/renderer/svg-dom/builders/subgraph.js +0 -63
  97. package/dist/renderer/svg-dom/builders/subgraph.js.map +0 -1
  98. package/dist/renderer/svg-dom/builders/utils.d.ts +0 -40
  99. package/dist/renderer/svg-dom/builders/utils.d.ts.map +0 -1
  100. package/dist/renderer/svg-dom/builders/utils.js +0 -79
  101. package/dist/renderer/svg-dom/builders/utils.js.map +0 -1
  102. package/dist/renderer/svg-dom/index.d.ts +0 -9
  103. package/dist/renderer/svg-dom/index.d.ts.map +0 -1
  104. package/dist/renderer/svg-dom/index.js +0 -7
  105. package/dist/renderer/svg-dom/index.js.map +0 -1
  106. package/dist/renderer/svg-dom/interaction.d.ts +0 -69
  107. package/dist/renderer/svg-dom/interaction.d.ts.map +0 -1
  108. package/dist/renderer/svg-dom/interaction.js +0 -296
  109. package/dist/renderer/svg-dom/interaction.js.map +0 -1
  110. package/dist/renderer/svg-dom/renderer.d.ts +0 -47
  111. package/dist/renderer/svg-dom/renderer.d.ts.map +0 -1
  112. package/dist/renderer/svg-dom/renderer.js +0 -188
  113. package/dist/renderer/svg-dom/renderer.js.map +0 -1
  114. package/dist/renderer/svg-string/builders/defs.d.ts +0 -10
  115. package/dist/renderer/svg-string/builders/defs.d.ts.map +0 -1
  116. package/dist/renderer/svg-string/builders/defs.js +0 -43
  117. package/dist/renderer/svg-string/builders/defs.js.map +0 -1
  118. package/dist/renderer/svg-string/builders/link.d.ts +0 -10
  119. package/dist/renderer/svg-string/builders/link.d.ts.map +0 -1
  120. package/dist/renderer/svg-string/builders/link.js +0 -149
  121. package/dist/renderer/svg-string/builders/link.js.map +0 -1
  122. package/dist/renderer/svg-string/builders/node.d.ts +0 -10
  123. package/dist/renderer/svg-string/builders/node.d.ts.map +0 -1
  124. package/dist/renderer/svg-string/builders/node.js +0 -134
  125. package/dist/renderer/svg-string/builders/node.js.map +0 -1
  126. package/dist/renderer/svg-string/builders/subgraph.d.ts +0 -10
  127. package/dist/renderer/svg-string/builders/subgraph.d.ts.map +0 -1
  128. package/dist/renderer/svg-string/builders/subgraph.js +0 -59
  129. package/dist/renderer/svg-string/builders/subgraph.js.map +0 -1
  130. package/dist/renderer/svg-string/index.d.ts +0 -5
  131. package/dist/renderer/svg-string/index.d.ts.map +0 -1
  132. package/dist/renderer/svg-string/index.js +0 -5
  133. package/dist/renderer/svg-string/index.js.map +0 -1
  134. package/dist/renderer/svg-string/renderer.d.ts +0 -17
  135. package/dist/renderer/svg-string/renderer.d.ts.map +0 -1
  136. package/dist/renderer/svg-string/renderer.js +0 -53
  137. package/dist/renderer/svg-string/renderer.js.map +0 -1
  138. package/dist/renderer/text-measurer/browser-measurer.d.ts +0 -25
  139. package/dist/renderer/text-measurer/browser-measurer.d.ts.map +0 -1
  140. package/dist/renderer/text-measurer/browser-measurer.js +0 -85
  141. package/dist/renderer/text-measurer/browser-measurer.js.map +0 -1
  142. package/dist/renderer/text-measurer/fallback-measurer.d.ts +0 -22
  143. package/dist/renderer/text-measurer/fallback-measurer.d.ts.map +0 -1
  144. package/dist/renderer/text-measurer/fallback-measurer.js +0 -113
  145. package/dist/renderer/text-measurer/fallback-measurer.js.map +0 -1
  146. package/dist/renderer/text-measurer/index.d.ts +0 -13
  147. package/dist/renderer/text-measurer/index.d.ts.map +0 -1
  148. package/dist/renderer/text-measurer/index.js +0 -35
  149. package/dist/renderer/text-measurer/index.js.map +0 -1
  150. package/dist/renderer/text-measurer/types.d.ts +0 -30
  151. package/dist/renderer/text-measurer/types.d.ts.map +0 -1
  152. package/dist/renderer/text-measurer/types.js +0 -5
  153. package/dist/renderer/text-measurer/types.js.map +0 -1
  154. package/dist/renderer/theme.d.ts +0 -29
  155. package/dist/renderer/theme.d.ts.map +0 -1
  156. package/dist/renderer/theme.js +0 -80
  157. package/dist/renderer/theme.js.map +0 -1
@@ -1,8 +0,0 @@
1
- /**
2
- * Renderer Components
3
- */
4
- export { renderNode } from './node-renderer.js';
5
- export { renderLink } from './link-renderer.js';
6
- export { renderPorts } from './port-renderer.js';
7
- export { renderSubgraph } from './subgraph-renderer.js';
8
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/renderer/components/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,UAAU,EAA4B,MAAM,oBAAoB,CAAA;AACzE,OAAO,EAAE,UAAU,EAA4B,MAAM,oBAAoB,CAAA;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAgC,MAAM,wBAAwB,CAAA"}
@@ -1,11 +0,0 @@
1
- /**
2
- * Link Renderer Component
3
- */
4
- import type { LayoutLink, LayoutNode } from '../../models/index.js';
5
- import type { ThemeColors } from '../theme.js';
6
- import { type SVGElement } from '../svg-builder.js';
7
- export interface LinkRendererContext {
8
- theme: ThemeColors;
9
- }
10
- export declare function renderLink(layoutLink: LayoutLink, nodes: Map<string, LayoutNode>, ctx: LinkRendererContext): SVGElement;
11
- //# sourceMappingURL=link-renderer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"link-renderer.d.ts","sourceRoot":"","sources":["../../../src/renderer/components/link-renderer.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAA0B,MAAM,uBAAuB,CAAA;AAC3F,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAE9C,OAAO,EAGL,KAAK,UAAU,EAChB,MAAM,mBAAmB,CAAA;AAM1B,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,WAAW,CAAA;CACnB;AAED,wBAAgB,UAAU,CACxB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,EAC9B,GAAG,EAAE,mBAAmB,GACvB,UAAU,CAgFZ"}
@@ -1,340 +0,0 @@
1
- /**
2
- * Link Renderer Component
3
- */
4
- import { getVlanColor } from '../theme.js';
5
- import { g, path, text, rect, pathBuilder, escapeXml, bezierMidpoint, } from '../svg-builder.js';
6
- export function renderLink(layoutLink, nodes, ctx) {
7
- const { id, points, link, fromEndpoint, toEndpoint } = layoutLink;
8
- const label = link.label;
9
- // Auto-apply styles based on redundancy type
10
- const type = link.type || getDefaultLinkType(link.redundancy);
11
- const arrow = link.arrow ?? getDefaultArrowType(link.redundancy);
12
- const stroke = link.style?.stroke || getVlanColor(link.vlan) || ctx.theme.defaultLinkStroke;
13
- const dasharray = getLinkDasharray(type);
14
- const markerEnd = arrow !== 'none' ? 'url(#arrow)' : '';
15
- // Bandwidth config
16
- const bandwidthConfig = getBandwidthConfig(link.bandwidth);
17
- const strokeWidth = link.style?.strokeWidth || bandwidthConfig.strokeWidth || getLinkStrokeWidth(type);
18
- const group = g({ class: 'link-group' });
19
- // Render link lines
20
- const linkLines = renderBandwidthLines(id, points, stroke, strokeWidth, dasharray, markerEnd, bandwidthConfig, type);
21
- for (const linkLine of linkLines) {
22
- group.child(linkLine);
23
- }
24
- // Center label and VLANs
25
- const midPoint = getMidPoint(points);
26
- let labelYOffset = -8;
27
- if (label) {
28
- const labelText = Array.isArray(label) ? label.join(' / ') : label;
29
- group.child(text({
30
- x: midPoint.x,
31
- y: midPoint.y + labelYOffset,
32
- class: 'link-label',
33
- 'text-anchor': 'middle',
34
- }, escapeXml(labelText)));
35
- labelYOffset += 12;
36
- }
37
- // VLANs
38
- if (link.vlan && link.vlan.length > 0) {
39
- const vlanText = link.vlan.length === 1
40
- ? `VLAN ${link.vlan[0]}`
41
- : `VLAN ${link.vlan.join(', ')}`;
42
- group.child(text({
43
- x: midPoint.x,
44
- y: midPoint.y + labelYOffset,
45
- class: 'link-label',
46
- 'text-anchor': 'middle',
47
- }, escapeXml(vlanText)));
48
- }
49
- // Endpoint labels
50
- const fromNode = nodes.get(fromEndpoint.node);
51
- const toNode = nodes.get(toEndpoint.node);
52
- const fromNodeCenterX = fromNode ? fromNode.position.x : points[0].x;
53
- const toNodeCenterX = toNode ? toNode.position.x : points[points.length - 1].x;
54
- const fromLabels = formatEndpointLabels(fromEndpoint);
55
- const toLabels = formatEndpointLabels(toEndpoint);
56
- if (fromLabels.length > 0 && points.length > 1) {
57
- const portName = fromEndpoint.port || '';
58
- const labelPos = getEndpointLabelPosition(points, 'start', fromNodeCenterX, portName);
59
- const endpointElements = renderEndpointLabels(fromLabels, labelPos.x, labelPos.y, labelPos.anchor, ctx.theme);
60
- for (const el of endpointElements) {
61
- group.child(el);
62
- }
63
- }
64
- if (toLabels.length > 0 && points.length > 1) {
65
- const portName = toEndpoint.port || '';
66
- const labelPos = getEndpointLabelPosition(points, 'end', toNodeCenterX, portName);
67
- const endpointElements = renderEndpointLabels(toLabels, labelPos.x, labelPos.y, labelPos.anchor, ctx.theme);
68
- for (const el of endpointElements) {
69
- group.child(el);
70
- }
71
- }
72
- return group;
73
- }
74
- // ============================================
75
- // Link Line Rendering
76
- // ============================================
77
- function renderBandwidthLines(id, points, stroke, strokeWidth, dasharray, markerEnd, config, type) {
78
- const { lineCount } = config;
79
- const lineSpacing = 3;
80
- if (lineCount === 1) {
81
- const pathD = generatePath(points);
82
- const elements = [];
83
- // Double line effect for redundancy
84
- if (type === 'double') {
85
- elements.push(path({
86
- class: 'link-double-outer',
87
- d: pathD,
88
- fill: 'none',
89
- stroke,
90
- 'stroke-width': strokeWidth + 2,
91
- }));
92
- elements.push(path({
93
- class: 'link-double-inner',
94
- d: pathD,
95
- fill: 'none',
96
- stroke: 'white',
97
- 'stroke-width': strokeWidth - 1,
98
- }));
99
- }
100
- elements.push(path({
101
- class: 'link',
102
- 'data-id': id,
103
- d: pathD,
104
- fill: 'none',
105
- stroke,
106
- 'stroke-width': strokeWidth,
107
- 'stroke-dasharray': dasharray || undefined,
108
- 'marker-end': markerEnd || undefined,
109
- }));
110
- return elements;
111
- }
112
- // Multiple parallel lines
113
- const offsets = calculateLineOffsets(lineCount, lineSpacing);
114
- return offsets.map(offset => {
115
- const offsetPoints = offsetPointsPerp(points, offset);
116
- return path({
117
- class: 'link',
118
- 'data-id': id,
119
- d: generatePath(offsetPoints),
120
- fill: 'none',
121
- stroke,
122
- 'stroke-width': strokeWidth,
123
- 'stroke-dasharray': dasharray || undefined,
124
- });
125
- });
126
- }
127
- function generatePath(points) {
128
- if (points.length === 4) {
129
- return pathBuilder()
130
- .moveTo(points[0].x, points[0].y)
131
- .curveTo(points[1].x, points[1].y, points[2].x, points[2].y, points[3].x, points[3].y)
132
- .toString();
133
- }
134
- else if (points.length === 2) {
135
- return pathBuilder()
136
- .moveTo(points[0].x, points[0].y)
137
- .lineTo(points[1].x, points[1].y)
138
- .toString();
139
- }
140
- else {
141
- const pb = pathBuilder().moveTo(points[0].x, points[0].y);
142
- for (let i = 1; i < points.length; i++) {
143
- pb.lineTo(points[i].x, points[i].y);
144
- }
145
- return pb.toString();
146
- }
147
- }
148
- function calculateLineOffsets(lineCount, spacing) {
149
- const offsets = [];
150
- const totalWidth = (lineCount - 1) * spacing;
151
- const startOffset = -totalWidth / 2;
152
- for (let i = 0; i < lineCount; i++) {
153
- offsets.push(startOffset + i * spacing);
154
- }
155
- return offsets;
156
- }
157
- function offsetPointsPerp(points, offset) {
158
- if (points.length < 2)
159
- return points;
160
- const dx = points[points.length - 1].x - points[0].x;
161
- const dy = points[points.length - 1].y - points[0].y;
162
- const len = Math.sqrt(dx * dx + dy * dy);
163
- if (len === 0)
164
- return points;
165
- const perpX = -dy / len;
166
- const perpY = dx / len;
167
- return points.map(p => ({
168
- x: p.x + perpX * offset,
169
- y: p.y + perpY * offset,
170
- }));
171
- }
172
- // ============================================
173
- // Endpoint Labels
174
- // ============================================
175
- function formatEndpointLabels(endpoint) {
176
- const parts = [];
177
- if (endpoint.ip)
178
- parts.push(endpoint.ip);
179
- return parts;
180
- }
181
- function getEndpointLabelPosition(points, which, nodeCenterX, portName) {
182
- const endpointIdx = which === 'start' ? 0 : points.length - 1;
183
- const endpoint = points[endpointIdx];
184
- const nextIdx = which === 'start' ? 1 : points.length - 2;
185
- const nextPoint = points[nextIdx];
186
- const dx = nextPoint.x - endpoint.x;
187
- const dy = nextPoint.y - endpoint.y;
188
- const len = Math.sqrt(dx * dx + dy * dy);
189
- const nx = len > 0 ? dx / len : 0;
190
- const ny = len > 0 ? dy / len : 1;
191
- const perpX = -ny;
192
- const perpY = nx;
193
- const isVertical = Math.abs(dy) > Math.abs(dx);
194
- const portHash = hashString(portName);
195
- const hashDirection = portHash % 2 === 0 ? 1 : -1;
196
- const portOffsetFromCenter = endpoint.x - nodeCenterX;
197
- let sideMultiplier;
198
- if (isVertical) {
199
- if (Math.abs(portOffsetFromCenter) > 5) {
200
- sideMultiplier = portOffsetFromCenter > 0 ? 1 : -1;
201
- }
202
- else {
203
- sideMultiplier = hashDirection * 0.2;
204
- }
205
- }
206
- else {
207
- sideMultiplier = which === 'start' ? -1 : 1;
208
- }
209
- const offsetDist = 30;
210
- const perpDist = 20;
211
- let x;
212
- let y;
213
- if (isVertical) {
214
- x = endpoint.x + perpDist * sideMultiplier;
215
- y = endpoint.y + ny * offsetDist;
216
- }
217
- else {
218
- x = endpoint.x + nx * offsetDist + perpX * perpDist * sideMultiplier;
219
- y = endpoint.y + ny * offsetDist + perpY * perpDist * sideMultiplier;
220
- }
221
- let anchor = 'middle';
222
- const labelDx = x - endpoint.x;
223
- if (Math.abs(labelDx) > 8) {
224
- anchor = labelDx > 0 ? 'start' : 'end';
225
- }
226
- return { x, y, anchor };
227
- }
228
- function renderEndpointLabels(lines, x, y, anchor, theme) {
229
- if (lines.length === 0)
230
- return [];
231
- const lineHeight = 11;
232
- const paddingX = 2;
233
- const paddingY = 2;
234
- const charWidth = 4.8;
235
- const maxLen = Math.max(...lines.map(l => l.length));
236
- const rectWidth = maxLen * charWidth + paddingX * 2;
237
- const rectHeight = lines.length * lineHeight + paddingY * 2;
238
- let rectX = x - paddingX;
239
- if (anchor === 'middle') {
240
- rectX = x - rectWidth / 2;
241
- }
242
- else if (anchor === 'end') {
243
- rectX = x - rectWidth + paddingX;
244
- }
245
- const rectY = y - lineHeight + paddingY;
246
- const elements = [];
247
- elements.push(rect({
248
- x: rectX,
249
- y: rectY,
250
- width: rectWidth,
251
- height: rectHeight,
252
- rx: 2,
253
- fill: theme.endpointLabelBg,
254
- stroke: theme.endpointLabelStroke,
255
- 'stroke-width': 0.5,
256
- }));
257
- lines.forEach((line, i) => {
258
- elements.push(text({
259
- x,
260
- y: y + i * lineHeight,
261
- class: 'endpoint-label',
262
- 'text-anchor': anchor,
263
- }, escapeXml(line)));
264
- });
265
- return elements;
266
- }
267
- // ============================================
268
- // Utilities
269
- // ============================================
270
- function getDefaultLinkType(redundancy) {
271
- switch (redundancy) {
272
- case 'ha':
273
- case 'vc':
274
- case 'vss':
275
- case 'vpc':
276
- case 'mlag':
277
- return 'double';
278
- case 'stack':
279
- return 'thick';
280
- default:
281
- return 'solid';
282
- }
283
- }
284
- function getDefaultArrowType(_redundancy) {
285
- return 'none';
286
- }
287
- function getLinkDasharray(type) {
288
- switch (type) {
289
- case 'dashed': return '5 3';
290
- case 'invisible': return '0';
291
- default: return '';
292
- }
293
- }
294
- function getLinkStrokeWidth(type) {
295
- switch (type) {
296
- case 'thick': return 3;
297
- case 'double': return 2;
298
- default: return 1.5;
299
- }
300
- }
301
- function getBandwidthConfig(bandwidth) {
302
- const strokeWidth = 1.5;
303
- switch (bandwidth) {
304
- case '1G': return { lineCount: 1, strokeWidth };
305
- case '10G': return { lineCount: 2, strokeWidth };
306
- case '25G': return { lineCount: 3, strokeWidth };
307
- case '40G': return { lineCount: 4, strokeWidth };
308
- case '100G': return { lineCount: 5, strokeWidth };
309
- default: return { lineCount: 1, strokeWidth };
310
- }
311
- }
312
- function getMidPoint(points) {
313
- if (points.length === 4) {
314
- return bezierMidpoint(points[0], points[1], points[2], points[3]);
315
- }
316
- if (points.length === 2) {
317
- return {
318
- x: (points[0].x + points[1].x) / 2,
319
- y: (points[0].y + points[1].y) / 2,
320
- };
321
- }
322
- const midIndex = Math.floor(points.length / 2);
323
- if (midIndex > 0 && midIndex < points.length) {
324
- return {
325
- x: (points[midIndex - 1].x + points[midIndex].x) / 2,
326
- y: (points[midIndex - 1].y + points[midIndex].y) / 2,
327
- };
328
- }
329
- return points[midIndex] || points[0];
330
- }
331
- function hashString(str) {
332
- let hash = 0;
333
- for (let i = 0; i < str.length; i++) {
334
- const char = str.charCodeAt(i);
335
- hash = ((hash << 5) - hash) + char;
336
- hash = hash & hash;
337
- }
338
- return Math.abs(hash);
339
- }
340
- //# sourceMappingURL=link-renderer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"link-renderer.js","sourceRoot":"","sources":["../../../src/renderer/components/link-renderer.ts"],"names":[],"mappings":"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"}
@@ -1,14 +0,0 @@
1
- /**
2
- * Node Renderer Component
3
- */
4
- import type { LayoutNode } from '../../models/index.js';
5
- import type { ThemeColors } from '../theme.js';
6
- import type { IconThemeVariant } from '../../icons/index.js';
7
- import { type SVGElement } from '../svg-builder.js';
8
- export interface NodeRendererContext {
9
- theme: ThemeColors;
10
- iconTheme: IconThemeVariant;
11
- fontFamily: string;
12
- }
13
- export declare function renderNode(layoutNode: LayoutNode, ctx: NodeRendererContext): SVGElement;
14
- //# sourceMappingURL=node-renderer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"node-renderer.d.ts","sourceRoot":"","sources":["../../../src/renderer/components/node-renderer.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAmB,MAAM,uBAAuB,CAAA;AACxE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAC9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AAE5D,OAAO,EAGL,KAAK,UAAU,EAChB,MAAM,mBAAmB,CAAA;AAO1B,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,WAAW,CAAA;IAClB,SAAS,EAAE,gBAAgB,CAAA;IAC3B,UAAU,EAAE,MAAM,CAAA;CACnB;AAED,wBAAgB,UAAU,CACxB,UAAU,EAAE,UAAU,EACtB,GAAG,EAAE,mBAAmB,GACvB,UAAU,CAuCZ"}
@@ -1,242 +0,0 @@
1
- /**
2
- * Node Renderer Component
3
- */
4
- import { getDeviceIcon, getVendorIconEntry } from '../../icons/index.js';
5
- import { g, rect, circle, polygon, ellipse, line, text, escapeXml, points, } from '../svg-builder.js';
6
- import { renderPorts } from './port-renderer.js';
7
- export function renderNode(layoutNode, ctx) {
8
- const { id, position, size, node, ports } = layoutNode;
9
- const x = position.x;
10
- const y = position.y;
11
- const w = size.width;
12
- const h = size.height;
13
- const style = node.style || {};
14
- const fill = style.fill || ctx.theme.defaultNodeFill;
15
- const stroke = style.stroke || ctx.theme.defaultNodeStroke;
16
- const strokeWidth = style.strokeWidth || 1;
17
- const strokeDasharray = style.strokeDasharray || '';
18
- const group = g({ class: 'node', 'data-id': id });
19
- // Shape
20
- const shape = renderNodeShape(node.shape, x, y, w, h, fill, stroke, strokeWidth, strokeDasharray);
21
- group.child(shape);
22
- // Icon
23
- const icon = renderNodeIcon(node, x, y, h, ctx.iconTheme);
24
- if (icon) {
25
- group.child(icon);
26
- }
27
- // Label
28
- const hasIcon = !!icon;
29
- const labels = renderNodeLabel(node, x, y, h, hasIcon, ctx);
30
- for (const label of labels) {
31
- group.child(label);
32
- }
33
- // Ports
34
- const portsElements = renderPorts(x, y, ports, ctx.theme);
35
- for (const port of portsElements) {
36
- group.child(port);
37
- }
38
- return group;
39
- }
40
- // ============================================
41
- // Shape Rendering
42
- // ============================================
43
- function renderNodeShape(shape, x, y, w, h, fill, stroke, strokeWidth, strokeDasharray) {
44
- const halfW = w / 2;
45
- const halfH = h / 2;
46
- const baseAttrs = {
47
- fill,
48
- stroke,
49
- 'stroke-width': strokeWidth,
50
- 'stroke-dasharray': strokeDasharray || undefined,
51
- filter: 'url(#shadow)',
52
- };
53
- switch (shape) {
54
- case 'rect':
55
- return rect({
56
- x: x - halfW,
57
- y: y - halfH,
58
- width: w,
59
- height: h,
60
- ...baseAttrs,
61
- });
62
- case 'rounded':
63
- return rect({
64
- x: x - halfW,
65
- y: y - halfH,
66
- width: w,
67
- height: h,
68
- rx: 8,
69
- ry: 8,
70
- ...baseAttrs,
71
- });
72
- case 'circle': {
73
- const r = Math.min(halfW, halfH);
74
- return circle({
75
- cx: x,
76
- cy: y,
77
- r,
78
- ...baseAttrs,
79
- });
80
- }
81
- case 'diamond':
82
- return polygon({
83
- points: points([x, y - halfH], [x + halfW, y], [x, y + halfH], [x - halfW, y]),
84
- ...baseAttrs,
85
- });
86
- case 'hexagon': {
87
- const hx = halfW * 0.866;
88
- return polygon({
89
- points: points([x - halfW, y], [x - hx, y - halfH], [x + hx, y - halfH], [x + halfW, y], [x + hx, y + halfH], [x - hx, y + halfH]),
90
- ...baseAttrs,
91
- });
92
- }
93
- case 'cylinder': {
94
- const ellipseH = h * 0.15;
95
- const group = g();
96
- group.child(ellipse({
97
- cx: x,
98
- cy: y + halfH - ellipseH,
99
- rx: halfW,
100
- ry: ellipseH,
101
- fill,
102
- stroke,
103
- 'stroke-width': strokeWidth,
104
- 'stroke-dasharray': strokeDasharray || undefined,
105
- }));
106
- group.child(rect({
107
- x: x - halfW,
108
- y: y - halfH + ellipseH,
109
- width: w,
110
- height: h - ellipseH * 2,
111
- fill,
112
- }));
113
- group.child(line({
114
- x1: x - halfW,
115
- y1: y - halfH + ellipseH,
116
- x2: x - halfW,
117
- y2: y + halfH - ellipseH,
118
- stroke,
119
- 'stroke-width': strokeWidth,
120
- }));
121
- group.child(line({
122
- x1: x + halfW,
123
- y1: y - halfH + ellipseH,
124
- x2: x + halfW,
125
- y2: y + halfH - ellipseH,
126
- stroke,
127
- 'stroke-width': strokeWidth,
128
- }));
129
- group.child(ellipse({
130
- cx: x,
131
- cy: y - halfH + ellipseH,
132
- rx: halfW,
133
- ry: ellipseH,
134
- fill,
135
- stroke,
136
- 'stroke-width': strokeWidth,
137
- 'stroke-dasharray': strokeDasharray || undefined,
138
- filter: 'url(#shadow)',
139
- }));
140
- return group;
141
- }
142
- case 'stadium':
143
- return rect({
144
- x: x - halfW,
145
- y: y - halfH,
146
- width: w,
147
- height: h,
148
- rx: halfH,
149
- ry: halfH,
150
- ...baseAttrs,
151
- });
152
- case 'trapezoid': {
153
- const indent = w * 0.15;
154
- return polygon({
155
- points: points([x - halfW + indent, y - halfH], [x + halfW - indent, y - halfH], [x + halfW, y + halfH], [x - halfW, y + halfH]),
156
- ...baseAttrs,
157
- });
158
- }
159
- default:
160
- return rect({
161
- x: x - halfW,
162
- y: y - halfH,
163
- width: w,
164
- height: h,
165
- rx: 4,
166
- ry: 4,
167
- ...baseAttrs,
168
- });
169
- }
170
- }
171
- // ============================================
172
- // Icon Rendering
173
- // ============================================
174
- function renderNodeIcon(node, x, y, h, iconTheme) {
175
- const iconSize = 40;
176
- const iconY = y - h / 2 + 12;
177
- // Try vendor-specific icon first
178
- const iconKey = node.service || node.model;
179
- if (node.vendor && iconKey) {
180
- const iconEntry = getVendorIconEntry(node.vendor, iconKey, node.resource);
181
- if (iconEntry) {
182
- const vendorIcon = iconEntry[iconTheme] || iconEntry.default;
183
- const viewBox = iconEntry.viewBox || '0 0 48 48';
184
- // Check if icon is a nested SVG
185
- if (vendorIcon.startsWith('<svg')) {
186
- const viewBoxMatch = vendorIcon.match(/viewBox="0 0 (\d+) (\d+)"/);
187
- if (viewBoxMatch) {
188
- const vbWidth = parseInt(viewBoxMatch[1]);
189
- const vbHeight = parseInt(viewBoxMatch[2]);
190
- const aspectRatio = vbWidth / vbHeight;
191
- const iconWidth = Math.round(iconSize * aspectRatio);
192
- const innerSvg = vendorIcon.replace(/<svg[^>]*>/, '').replace(/<\/svg>$/, '');
193
- return g({ class: 'node-icon', transform: `translate(${x - iconWidth / 2}, ${iconY})` })
194
- .child(`<svg width="${iconWidth}" height="${iconSize}" viewBox="0 0 ${vbWidth} ${vbHeight}">${innerSvg}</svg>`);
195
- }
196
- }
197
- // Parse viewBox for aspect ratio
198
- const vbMatch = viewBox.match(/(\d+)\s+(\d+)\s+(\d+)\s+(\d+)/);
199
- if (vbMatch) {
200
- const vbWidth = parseInt(vbMatch[3]);
201
- const vbHeight = parseInt(vbMatch[4]);
202
- const aspectRatio = vbWidth / vbHeight;
203
- const iconWidth = Math.abs(aspectRatio - 1) < 0.01 ? iconSize : Math.round(iconSize * aspectRatio);
204
- return g({ class: 'node-icon', transform: `translate(${x - iconWidth / 2}, ${iconY})` })
205
- .child(`<svg width="${iconWidth}" height="${iconSize}" viewBox="${viewBox}">${vendorIcon}</svg>`);
206
- }
207
- return g({ class: 'node-icon', transform: `translate(${x - iconSize / 2}, ${iconY})` })
208
- .child(`<svg width="${iconSize}" height="${iconSize}" viewBox="${viewBox}">${vendorIcon}</svg>`);
209
- }
210
- }
211
- // Fall back to device type icon
212
- const iconPath = getDeviceIcon(node.type);
213
- if (!iconPath)
214
- return null;
215
- return g({ class: 'node-icon', transform: `translate(${x - iconSize / 2}, ${iconY})` })
216
- .child(`<svg width="${iconSize}" height="${iconSize}" viewBox="0 0 24 24" fill="currentColor">${iconPath}</svg>`);
217
- }
218
- // ============================================
219
- // Label Rendering
220
- // ============================================
221
- function renderNodeLabel(node, x, y, _h, hasIcon, ctx) {
222
- const labels = Array.isArray(node.label) ? node.label : [node.label];
223
- const lineHeight = 16;
224
- const totalHeight = labels.length * lineHeight;
225
- const iconOffset = hasIcon ? 28 : 0;
226
- const startY = y - totalHeight / 2 + lineHeight / 2 + 4 + iconOffset;
227
- return labels.map((labelText, i) => {
228
- const isBold = labelText.includes('<b>') || labelText.includes('<strong>');
229
- const cleanLine = labelText.replace(/<\/?b>|<\/?strong>|<br\s*\/?>/gi, '');
230
- const className = isBold ? 'node-label node-label-bold' : 'node-label';
231
- return text({
232
- x,
233
- y: startY + i * lineHeight,
234
- class: className,
235
- 'text-anchor': 'middle',
236
- 'font-family': ctx.fontFamily,
237
- 'font-size': 12,
238
- fill: ctx.theme.labelColor,
239
- }, escapeXml(cleanLine));
240
- });
241
- }
242
- //# sourceMappingURL=node-renderer.js.map