snice 4.8.0 → 4.9.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 (315) hide show
  1. package/adapters/react/camera-annotate.d.ts +27 -0
  2. package/adapters/react/camera-annotate.d.ts.map +1 -0
  3. package/adapters/react/camera-annotate.js +24 -0
  4. package/adapters/react/camera-annotate.js.map +1 -0
  5. package/adapters/react/camera-annotate.tsx +35 -0
  6. package/adapters/react/candlestick.d.ts +34 -0
  7. package/adapters/react/candlestick.d.ts.map +1 -0
  8. package/adapters/react/candlestick.js +24 -0
  9. package/adapters/react/candlestick.js.map +1 -0
  10. package/adapters/react/candlestick.tsx +42 -0
  11. package/adapters/react/components.d.ts +14 -0
  12. package/adapters/react/components.d.ts.map +1 -1
  13. package/adapters/react/components.js +7 -0
  14. package/adapters/react/components.js.map +1 -1
  15. package/adapters/react/components.ts +14 -0
  16. package/adapters/react/funnel.d.ts +31 -0
  17. package/adapters/react/funnel.d.ts.map +1 -0
  18. package/adapters/react/funnel.js +24 -0
  19. package/adapters/react/funnel.js.map +1 -0
  20. package/adapters/react/funnel.tsx +39 -0
  21. package/adapters/react/network-graph.d.ts +32 -0
  22. package/adapters/react/network-graph.d.ts.map +1 -0
  23. package/adapters/react/network-graph.js +24 -0
  24. package/adapters/react/network-graph.js.map +1 -0
  25. package/adapters/react/network-graph.tsx +40 -0
  26. package/adapters/react/sankey.d.ts +31 -0
  27. package/adapters/react/sankey.d.ts.map +1 -0
  28. package/adapters/react/sankey.js +24 -0
  29. package/adapters/react/sankey.js.map +1 -0
  30. package/adapters/react/sankey.tsx +39 -0
  31. package/adapters/react/time-range-picker.d.ts +33 -0
  32. package/adapters/react/time-range-picker.d.ts.map +1 -0
  33. package/adapters/react/time-range-picker.js +24 -0
  34. package/adapters/react/time-range-picker.js.map +1 -0
  35. package/adapters/react/time-range-picker.tsx +41 -0
  36. package/adapters/react/treemap.d.ts +30 -0
  37. package/adapters/react/treemap.d.ts.map +1 -0
  38. package/adapters/react/treemap.js +24 -0
  39. package/adapters/react/treemap.js.map +1 -0
  40. package/adapters/react/treemap.tsx +38 -0
  41. package/adapters/react/virtual-scroller.d.ts +1 -0
  42. package/adapters/react/virtual-scroller.d.ts.map +1 -1
  43. package/adapters/react/virtual-scroller.js +1 -1
  44. package/adapters/react/virtual-scroller.js.map +1 -1
  45. package/adapters/react/virtual-scroller.tsx +2 -1
  46. package/dist/cdn/accordion/snice-accordion.js +1 -1
  47. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  48. package/dist/cdn/alert/snice-alert.js +1 -1
  49. package/dist/cdn/alert/snice-alert.min.js +1 -1
  50. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  51. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  52. package/dist/cdn/avatar/snice-avatar.js +1 -1
  53. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  54. package/dist/cdn/badge/snice-badge.js +1 -1
  55. package/dist/cdn/badge/snice-badge.min.js +1 -1
  56. package/dist/cdn/banner/snice-banner.js +1 -1
  57. package/dist/cdn/banner/snice-banner.min.js +1 -1
  58. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +2 -2
  59. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js.map +1 -1
  60. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +13 -13
  61. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js.map +1 -1
  62. package/dist/cdn/button/snice-button.js +1 -1
  63. package/dist/cdn/button/snice-button.min.js +1 -1
  64. package/dist/cdn/calendar/snice-calendar.js +1 -1
  65. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  66. package/dist/cdn/camera/snice-camera.js +1 -1
  67. package/dist/cdn/camera/snice-camera.min.js +1 -1
  68. package/dist/cdn/camera-annotate/README.md +27 -0
  69. package/dist/cdn/camera-annotate/snice-camera-annotate.js +730 -0
  70. package/dist/cdn/camera-annotate/snice-camera-annotate.js.map +1 -0
  71. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +144 -0
  72. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js.map +1 -0
  73. package/dist/cdn/candlestick/README.md +27 -0
  74. package/dist/cdn/candlestick/snice-candlestick.js +717 -0
  75. package/dist/cdn/candlestick/snice-candlestick.js.map +1 -0
  76. package/dist/cdn/candlestick/snice-candlestick.min.js +22 -0
  77. package/dist/cdn/candlestick/snice-candlestick.min.js.map +1 -0
  78. package/dist/cdn/card/snice-card.js +1 -1
  79. package/dist/cdn/card/snice-card.min.js +1 -1
  80. package/dist/cdn/carousel/snice-carousel.js +1 -1
  81. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  82. package/dist/cdn/chart/snice-chart.js +1 -1
  83. package/dist/cdn/chart/snice-chart.min.js +1 -1
  84. package/dist/cdn/chat/snice-chat.js +1 -1
  85. package/dist/cdn/chat/snice-chat.min.js +1 -1
  86. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  87. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  88. package/dist/cdn/chip/snice-chip.js +1 -1
  89. package/dist/cdn/chip/snice-chip.min.js +1 -1
  90. package/dist/cdn/code-block/snice-code-block.js +1 -1
  91. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  92. package/dist/cdn/color-display/snice-color-display.js +1 -1
  93. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  94. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  95. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  96. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  97. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  98. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  99. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  100. package/dist/cdn/divider/snice-divider.js +1 -1
  101. package/dist/cdn/divider/snice-divider.min.js +1 -1
  102. package/dist/cdn/doc/snice-doc.js +1 -1
  103. package/dist/cdn/doc/snice-doc.min.js +1 -1
  104. package/dist/cdn/draw/snice-draw.js +1 -1
  105. package/dist/cdn/draw/snice-draw.min.js +1 -1
  106. package/dist/cdn/drawer/snice-drawer.js +1 -1
  107. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  108. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  109. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  110. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  111. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  112. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  113. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  114. package/dist/cdn/funnel/README.md +27 -0
  115. package/dist/cdn/funnel/snice-funnel.js +424 -0
  116. package/dist/cdn/funnel/snice-funnel.js.map +1 -0
  117. package/dist/cdn/funnel/snice-funnel.min.js +20 -0
  118. package/dist/cdn/funnel/snice-funnel.min.js.map +1 -0
  119. package/dist/cdn/gauge/snice-gauge.js +1 -1
  120. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  121. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  122. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  123. package/dist/cdn/image/snice-image.js +1 -1
  124. package/dist/cdn/image/snice-image.min.js +1 -1
  125. package/dist/cdn/input/snice-input.js +1 -1
  126. package/dist/cdn/input/snice-input.min.js +1 -1
  127. package/dist/cdn/kanban/snice-kanban.js +1 -1
  128. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  129. package/dist/cdn/kpi/snice-kpi.js +1 -1
  130. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  131. package/dist/cdn/layout/README.md +2 -2
  132. package/dist/cdn/layout/snice-layout.js +23 -6
  133. package/dist/cdn/layout/snice-layout.js.map +1 -1
  134. package/dist/cdn/layout/snice-layout.min.js +2 -2
  135. package/dist/cdn/layout/snice-layout.min.js.map +1 -1
  136. package/dist/cdn/link/snice-link.js +1 -1
  137. package/dist/cdn/link/snice-link.min.js +1 -1
  138. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  139. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  140. package/dist/cdn/list/README.md +6 -2
  141. package/dist/cdn/list/snice-list.js +87 -10
  142. package/dist/cdn/list/snice-list.js.map +1 -1
  143. package/dist/cdn/list/snice-list.min.js +20 -6
  144. package/dist/cdn/list/snice-list.min.js.map +1 -1
  145. package/dist/cdn/location/snice-location.js +1 -1
  146. package/dist/cdn/location/snice-location.min.js +1 -1
  147. package/dist/cdn/login/snice-login.js +1 -1
  148. package/dist/cdn/login/snice-login.min.js +1 -1
  149. package/dist/cdn/masonry/snice-masonry.js +1 -1
  150. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  151. package/dist/cdn/menu/snice-menu.js +1 -1
  152. package/dist/cdn/menu/snice-menu.min.js +1 -1
  153. package/dist/cdn/modal/snice-modal.js +1 -1
  154. package/dist/cdn/modal/snice-modal.min.js +1 -1
  155. package/dist/cdn/music-player/snice-music-player.js +1 -1
  156. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  157. package/dist/cdn/nav/README.md +2 -2
  158. package/dist/cdn/nav/snice-nav.js +23 -6
  159. package/dist/cdn/nav/snice-nav.js.map +1 -1
  160. package/dist/cdn/nav/snice-nav.min.js +2 -2
  161. package/dist/cdn/nav/snice-nav.min.js.map +1 -1
  162. package/dist/cdn/network-graph/README.md +27 -0
  163. package/dist/cdn/network-graph/snice-network-graph.js +788 -0
  164. package/dist/cdn/network-graph/snice-network-graph.js.map +1 -0
  165. package/dist/cdn/network-graph/snice-network-graph.min.js +13 -0
  166. package/dist/cdn/network-graph/snice-network-graph.min.js.map +1 -0
  167. package/dist/cdn/pagination/README.md +2 -2
  168. package/dist/cdn/pagination/snice-pagination.js +13 -13
  169. package/dist/cdn/pagination/snice-pagination.js.map +1 -1
  170. package/dist/cdn/pagination/snice-pagination.min.js +14 -14
  171. package/dist/cdn/pagination/snice-pagination.min.js.map +1 -1
  172. package/dist/cdn/paint/snice-paint.js +1 -1
  173. package/dist/cdn/paint/snice-paint.min.js +1 -1
  174. package/dist/cdn/progress/snice-progress.js +1 -1
  175. package/dist/cdn/progress/snice-progress.min.js +1 -1
  176. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  177. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  178. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  179. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  180. package/dist/cdn/radio/snice-radio.js +1 -1
  181. package/dist/cdn/radio/snice-radio.min.js +1 -1
  182. package/dist/cdn/runtime/snice-runtime.esm.js +3 -3
  183. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  184. package/dist/cdn/runtime/snice-runtime.esm.min.js +3 -3
  185. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  186. package/dist/cdn/runtime/snice-runtime.js +3 -3
  187. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  188. package/dist/cdn/runtime/snice-runtime.min.js +3 -3
  189. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  190. package/dist/cdn/sankey/README.md +27 -0
  191. package/dist/cdn/sankey/snice-sankey.js +679 -0
  192. package/dist/cdn/sankey/snice-sankey.js.map +1 -0
  193. package/dist/cdn/sankey/snice-sankey.min.js +21 -0
  194. package/dist/cdn/sankey/snice-sankey.min.js.map +1 -0
  195. package/dist/cdn/select/snice-select.js +1 -1
  196. package/dist/cdn/select/snice-select.min.js +1 -1
  197. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  198. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  199. package/dist/cdn/slider/snice-slider.js +1 -1
  200. package/dist/cdn/slider/snice-slider.min.js +1 -1
  201. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  202. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  203. package/dist/cdn/spinner/snice-spinner.js +1 -1
  204. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  205. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  206. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  207. package/dist/cdn/stepper/README.md +6 -2
  208. package/dist/cdn/stepper/snice-stepper.js +77 -10
  209. package/dist/cdn/stepper/snice-stepper.js.map +1 -1
  210. package/dist/cdn/stepper/snice-stepper.min.js +13 -9
  211. package/dist/cdn/stepper/snice-stepper.min.js.map +1 -1
  212. package/dist/cdn/switch/snice-switch.js +1 -1
  213. package/dist/cdn/switch/snice-switch.min.js +1 -1
  214. package/dist/cdn/table/snice-table.js +1 -1
  215. package/dist/cdn/table/snice-table.min.js +1 -1
  216. package/dist/cdn/tabs/snice-tabs.js +1 -1
  217. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  218. package/dist/cdn/terminal/snice-terminal.js +1 -1
  219. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  220. package/dist/cdn/textarea/snice-textarea.js +1 -1
  221. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  222. package/dist/cdn/time-range-picker/README.md +27 -0
  223. package/dist/cdn/time-range-picker/snice-time-range-picker.js +635 -0
  224. package/dist/cdn/time-range-picker/snice-time-range-picker.js.map +1 -0
  225. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +34 -0
  226. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js.map +1 -0
  227. package/dist/cdn/timeline/snice-timeline.js +1 -1
  228. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  229. package/dist/cdn/timer/snice-timer.js +1 -1
  230. package/dist/cdn/timer/snice-timer.min.js +1 -1
  231. package/dist/cdn/toast/snice-toast.js +1 -1
  232. package/dist/cdn/toast/snice-toast.min.js +1 -1
  233. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  234. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  235. package/dist/cdn/tree/README.md +5 -1
  236. package/dist/cdn/tree/snice-tree.js +4 -8
  237. package/dist/cdn/tree/snice-tree.js.map +1 -1
  238. package/dist/cdn/tree/snice-tree.min.js +5 -5
  239. package/dist/cdn/tree/snice-tree.min.js.map +1 -1
  240. package/dist/cdn/treemap/README.md +27 -0
  241. package/dist/cdn/treemap/snice-treemap.js +522 -0
  242. package/dist/cdn/treemap/snice-treemap.js.map +1 -0
  243. package/dist/cdn/treemap/snice-treemap.min.js +14 -0
  244. package/dist/cdn/treemap/snice-treemap.min.js.map +1 -0
  245. package/dist/cdn/virtual-scroller/README.md +2 -2
  246. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +47 -16
  247. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js.map +1 -1
  248. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +9 -9
  249. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js.map +1 -1
  250. package/dist/components/breadcrumbs/snice-breadcrumbs.js +1 -1
  251. package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -1
  252. package/dist/components/camera-annotate/snice-camera-annotate.d.ts +68 -0
  253. package/dist/components/camera-annotate/snice-camera-annotate.js +663 -0
  254. package/dist/components/camera-annotate/snice-camera-annotate.js.map +1 -0
  255. package/dist/components/camera-annotate/snice-camera-annotate.types.d.ts +50 -0
  256. package/dist/components/candlestick/snice-candlestick.d.ts +78 -0
  257. package/dist/components/candlestick/snice-candlestick.js +650 -0
  258. package/dist/components/candlestick/snice-candlestick.js.map +1 -0
  259. package/dist/components/candlestick/snice-candlestick.types.d.ts +40 -0
  260. package/dist/components/funnel/snice-funnel.d.ts +37 -0
  261. package/dist/components/funnel/snice-funnel.js +357 -0
  262. package/dist/components/funnel/snice-funnel.js.map +1 -0
  263. package/dist/components/funnel/snice-funnel.types.d.ts +28 -0
  264. package/dist/components/list/snice-list-item.d.ts +2 -0
  265. package/dist/components/list/snice-list-item.js +20 -2
  266. package/dist/components/list/snice-list-item.js.map +1 -1
  267. package/dist/components/nav/snice-nav.js +22 -5
  268. package/dist/components/nav/snice-nav.js.map +1 -1
  269. package/dist/components/network-graph/snice-network-graph.d.ts +80 -0
  270. package/dist/components/network-graph/snice-network-graph.js +721 -0
  271. package/dist/components/network-graph/snice-network-graph.js.map +1 -0
  272. package/dist/components/network-graph/snice-network-graph.types.d.ts +49 -0
  273. package/dist/components/pagination/snice-pagination.js +12 -12
  274. package/dist/components/sankey/snice-sankey.d.ts +46 -0
  275. package/dist/components/sankey/snice-sankey.js +612 -0
  276. package/dist/components/sankey/snice-sankey.js.map +1 -0
  277. package/dist/components/sankey/snice-sankey.types.d.ts +59 -0
  278. package/dist/components/stepper/snice-stepper.js +9 -3
  279. package/dist/components/stepper/snice-stepper.js.map +1 -1
  280. package/dist/components/time-range-picker/snice-time-range-picker.d.ts +67 -0
  281. package/dist/components/time-range-picker/snice-time-range-picker.js +568 -0
  282. package/dist/components/time-range-picker/snice-time-range-picker.js.map +1 -0
  283. package/dist/components/time-range-picker/snice-time-range-picker.types.d.ts +39 -0
  284. package/dist/components/treemap/snice-treemap.d.ts +49 -0
  285. package/dist/components/treemap/snice-treemap.js +455 -0
  286. package/dist/components/treemap/snice-treemap.js.map +1 -0
  287. package/dist/components/treemap/snice-treemap.types.d.ts +42 -0
  288. package/dist/components/virtual-scroller/snice-virtual-scroller.d.ts +5 -0
  289. package/dist/components/virtual-scroller/snice-virtual-scroller.js +47 -16
  290. package/dist/components/virtual-scroller/snice-virtual-scroller.js.map +1 -1
  291. package/dist/index.cjs +1 -1
  292. package/dist/index.cjs.map +1 -1
  293. package/dist/index.esm.js +1 -1
  294. package/dist/index.esm.js.map +1 -1
  295. package/dist/index.iife.js +1 -1
  296. package/dist/index.iife.js.map +1 -1
  297. package/dist/symbols.cjs +1 -1
  298. package/dist/symbols.esm.js +1 -1
  299. package/dist/transitions.cjs +1 -1
  300. package/dist/transitions.esm.js +1 -1
  301. package/docs/ai/components/camera-annotate.md +82 -0
  302. package/docs/ai/components/candlestick.md +79 -0
  303. package/docs/ai/components/funnel.md +86 -0
  304. package/docs/ai/components/network-graph.md +87 -0
  305. package/docs/ai/components/sankey.md +63 -0
  306. package/docs/ai/components/time-range-picker.md +78 -0
  307. package/docs/ai/components/treemap.md +78 -0
  308. package/docs/components/camera-annotate.md +186 -0
  309. package/docs/components/candlestick.md +196 -0
  310. package/docs/components/funnel.md +191 -0
  311. package/docs/components/network-graph.md +215 -0
  312. package/docs/components/sankey.md +201 -0
  313. package/docs/components/time-range-picker.md +213 -0
  314. package/docs/components/treemap.md +198 -0
  315. package/package.json +1 -1
@@ -0,0 +1,788 @@
1
+ /*!
2
+ * snice v4.8.0
3
+ * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
+ * (c) 2024
5
+ * Released under the MIT License.
6
+ */
7
+ if(typeof globalThis.Snice==="undefined"){console.warn("[snice] snice-runtime.min.js must be loaded before snice-network-graph.min.js");}
8
+ var SniceNetworkGraph = (function (exports, snice) {
9
+ 'use strict';
10
+
11
+ /******************************************************************************
12
+ Copyright (c) Microsoft Corporation.
13
+
14
+ Permission to use, copy, modify, and/or distribute this software for any
15
+ purpose with or without fee is hereby granted.
16
+
17
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
18
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
19
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
20
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
21
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
22
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
23
+ PERFORMANCE OF THIS SOFTWARE.
24
+ ***************************************************************************** */
25
+ /* global Reflect, Promise, SuppressedError, Symbol, Iterator */
26
+
27
+
28
+ function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
29
+ function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
30
+ var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
31
+ var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
32
+ var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
33
+ var _, done = false;
34
+ for (var i = decorators.length - 1; i >= 0; i--) {
35
+ var context = {};
36
+ for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
37
+ for (var p in contextIn.access) context.access[p] = contextIn.access[p];
38
+ context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
39
+ var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
40
+ if (kind === "accessor") {
41
+ if (result === void 0) continue;
42
+ if (result === null || typeof result !== "object") throw new TypeError("Object expected");
43
+ if (_ = accept(result.get)) descriptor.get = _;
44
+ if (_ = accept(result.set)) descriptor.set = _;
45
+ if (_ = accept(result.init)) initializers.unshift(_);
46
+ }
47
+ else if (_ = accept(result)) {
48
+ if (kind === "field") initializers.unshift(_);
49
+ else descriptor[key] = _;
50
+ }
51
+ }
52
+ if (target) Object.defineProperty(target, contextIn.name, descriptor);
53
+ done = true;
54
+ }
55
+ function __runInitializers(thisArg, initializers, value) {
56
+ var useValue = arguments.length > 2;
57
+ for (var i = 0; i < initializers.length; i++) {
58
+ value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
59
+ }
60
+ return useValue ? value : void 0;
61
+ }
62
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
63
+ var e = new Error(message);
64
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
65
+ };
66
+
67
+ var cssContent = ":host{display:block;font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif);contain:layout style paint;width:100%}.network-graph{position:relative;width:100%;height:100%;min-height:18.75rem;overflow:hidden;background:var(--snice-color-background,rgb(255 255 255));border:1px solid var(--snice-color-border,rgb(226 226 226));border-radius:4px}.network-graph__svg{display:block;width:100%;height:100%;cursor:grab}.network-graph__svg:active{cursor:grabbing}.network-graph__edge{stroke:var(--snice-color-border,rgb(226 226 226));stroke-width:1px;fill:none;transition:stroke var(--snice-transition-fast, 150ms) ease,stroke-opacity var(--snice-transition-fast, 150ms) ease}.network-graph__edge--highlighted{stroke-width:2px}.network-graph__edge--dimmed{stroke-opacity:0.15}.network-graph__edge-label{font-size:.625rem;fill:var(--snice-color-text-tertiary,rgb(115 115 115));text-anchor:middle;pointer-events:none;dominant-baseline:central}.network-graph__edge-label--dimmed{opacity:.15}.network-graph__node{cursor:pointer;transition:opacity var(--snice-transition-fast, 150ms) ease}.network-graph__node--dimmed{opacity:.15}.network-graph__node--dragging{cursor:grabbing}.network-graph__node-circle{stroke:var(--snice-color-background,rgb(255 255 255));stroke-width:2px;transition:r var(--snice-transition-fast, 150ms) ease}.network-graph__node-label{font-size:.6875rem;fill:var(--snice-color-text,rgb(23 23 23));text-anchor:middle;pointer-events:none;dominant-baseline:central;font-weight:var(--snice-font-weight-medium,500)}.network-graph__node-label--dimmed{opacity:.15}.network-graph__tooltip{position:absolute;padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-xs,.5rem);background:var(--snice-color-text,rgb(23 23 23));color:var(--snice-color-text-inverse,rgb(250 250 250));font-size:.75rem;border-radius:4px;pointer-events:none;white-space:nowrap;z-index:10;box-shadow:var(--snice-shadow-md,0 4px 6px -1px rgb(0 0 0 / .1),0 2px 4px -2px rgb(0 0 0 / .1));transform:translate(-50%,-100%);margin-top:-.5rem;opacity:0;transition:opacity var(--snice-transition-fast, 150ms) ease}.network-graph__tooltip--visible{opacity:1}";
68
+
69
+ const DEFAULT_COLORS = [
70
+ 'rgb(37 99 235)', // blue
71
+ 'rgb(22 163 74)', // green
72
+ 'rgb(234 88 12)', // orange
73
+ 'rgb(220 38 38)', // red
74
+ 'rgb(147 51 234)', // purple
75
+ 'rgb(6 182 212)', // cyan
76
+ 'rgb(236 72 153)', // pink
77
+ 'rgb(245 158 11)', // amber
78
+ 'rgb(20 184 166)', // teal
79
+ 'rgb(99 102 241)', // indigo
80
+ ];
81
+ let SniceNetworkGraph = (() => {
82
+ let _classDecorators = [snice.element('snice-network-graph')];
83
+ let _classDescriptor;
84
+ let _classExtraInitializers = [];
85
+ let _classThis;
86
+ let _classSuper = HTMLElement;
87
+ let _instanceExtraInitializers = [];
88
+ let _data_decorators;
89
+ let _data_initializers = [];
90
+ let _data_extraInitializers = [];
91
+ let _layout_decorators;
92
+ let _layout_initializers = [];
93
+ let _layout_extraInitializers = [];
94
+ let _chargeStrength_decorators;
95
+ let _chargeStrength_initializers = [];
96
+ let _chargeStrength_extraInitializers = [];
97
+ let _linkDistance_decorators;
98
+ let _linkDistance_initializers = [];
99
+ let _linkDistance_extraInitializers = [];
100
+ let _zoomEnabled_decorators;
101
+ let _zoomEnabled_initializers = [];
102
+ let _zoomEnabled_extraInitializers = [];
103
+ let _dragEnabled_decorators;
104
+ let _dragEnabled_initializers = [];
105
+ let _dragEnabled_extraInitializers = [];
106
+ let _showLabels_decorators;
107
+ let _showLabels_initializers = [];
108
+ let _showLabels_extraInitializers = [];
109
+ let _animation_decorators;
110
+ let _animation_initializers = [];
111
+ let _animation_extraInitializers = [];
112
+ let _svgElement_decorators;
113
+ let _svgElement_initializers = [];
114
+ let _svgElement_extraInitializers = [];
115
+ let _tooltipEl_decorators;
116
+ let _tooltipEl_initializers = [];
117
+ let _tooltipEl_extraInitializers = [];
118
+ let _emitNodeClick_decorators;
119
+ let _emitEdgeClick_decorators;
120
+ let _emitNodeDrag_decorators;
121
+ let _emitGraphZoom_decorators;
122
+ let _init_decorators;
123
+ let _onDataChange_decorators;
124
+ let _onLayoutChange_decorators;
125
+ let _onDisplayChange_decorators;
126
+ let _cleanup_decorators;
127
+ let _renderContent_decorators;
128
+ let _componentStyles_decorators;
129
+ (class extends _classSuper {
130
+ static { _classThis = this; }
131
+ constructor() {
132
+ super(...arguments);
133
+ this.data = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _data_initializers, { nodes: [], edges: [] }));
134
+ this.layout = (__runInitializers(this, _data_extraInitializers), __runInitializers(this, _layout_initializers, 'force'));
135
+ this.chargeStrength = (__runInitializers(this, _layout_extraInitializers), __runInitializers(this, _chargeStrength_initializers, -300));
136
+ this.linkDistance = (__runInitializers(this, _chargeStrength_extraInitializers), __runInitializers(this, _linkDistance_initializers, 80));
137
+ this.zoomEnabled = (__runInitializers(this, _linkDistance_extraInitializers), __runInitializers(this, _zoomEnabled_initializers, true));
138
+ this.dragEnabled = (__runInitializers(this, _zoomEnabled_extraInitializers), __runInitializers(this, _dragEnabled_initializers, true));
139
+ this.showLabels = (__runInitializers(this, _dragEnabled_extraInitializers), __runInitializers(this, _showLabels_initializers, true));
140
+ this.animation = (__runInitializers(this, _showLabels_extraInitializers), __runInitializers(this, _animation_initializers, true));
141
+ this.svgElement = (__runInitializers(this, _animation_extraInitializers), __runInitializers(this, _svgElement_initializers, void 0));
142
+ this.tooltipEl = (__runInitializers(this, _svgElement_extraInitializers), __runInitializers(this, _tooltipEl_initializers, void 0));
143
+ // Manually created SVG-namespace groups (template engine can't create nested SVG children)
144
+ this.transformGroupEl = __runInitializers(this, _tooltipEl_extraInitializers);
145
+ this.simNodes = [];
146
+ this.simEdges = [];
147
+ this.animFrameId = 0;
148
+ this.simAlpha = 1;
149
+ this.simRunning = false;
150
+ this.simInitialized = false;
151
+ // Zoom/pan state
152
+ this.zoomScale = 1;
153
+ this.panX = 0;
154
+ this.panY = 0;
155
+ // Drag state
156
+ this.dragNode = null;
157
+ this.dragStartX = 0;
158
+ this.dragStartY = 0;
159
+ // Pan state
160
+ this.isPanning = false;
161
+ this.panStartX = 0;
162
+ this.panStartY = 0;
163
+ this.panStartPanX = 0;
164
+ this.panStartPanY = 0;
165
+ // Hover state
166
+ this.hoveredNodeId = '';
167
+ // Bound handlers for cleanup
168
+ this.boundMouseMove = this.handleMouseMove.bind(this);
169
+ this.boundMouseUp = this.handleMouseUp.bind(this);
170
+ // ResizeObserver
171
+ this.resizeObserver = null;
172
+ this.containerWidth = 600;
173
+ this.containerHeight = 400;
174
+ }
175
+ static {
176
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
177
+ _data_decorators = [snice.property({ type: Object, attribute: false })];
178
+ _layout_decorators = [snice.property({ attribute: 'layout' })];
179
+ _chargeStrength_decorators = [snice.property({ type: Number, attribute: 'charge-strength' })];
180
+ _linkDistance_decorators = [snice.property({ type: Number, attribute: 'link-distance' })];
181
+ _zoomEnabled_decorators = [snice.property({ type: Boolean, attribute: 'zoom-enabled' })];
182
+ _dragEnabled_decorators = [snice.property({ type: Boolean, attribute: 'drag-enabled' })];
183
+ _showLabels_decorators = [snice.property({ type: Boolean, attribute: 'show-labels' })];
184
+ _animation_decorators = [snice.property({ type: Boolean })];
185
+ _svgElement_decorators = [snice.query('.network-graph__svg')];
186
+ _tooltipEl_decorators = [snice.query('.network-graph__tooltip')];
187
+ _emitNodeClick_decorators = [snice.dispatch('node-click', { bubbles: true, composed: true })];
188
+ _emitEdgeClick_decorators = [snice.dispatch('edge-click', { bubbles: true, composed: true })];
189
+ _emitNodeDrag_decorators = [snice.dispatch('node-drag', { bubbles: true, composed: true })];
190
+ _emitGraphZoom_decorators = [snice.dispatch('graph-zoom', { bubbles: true, composed: true })];
191
+ _init_decorators = [snice.ready()];
192
+ _onDataChange_decorators = [snice.watch('data')];
193
+ _onLayoutChange_decorators = [snice.watch('layout')];
194
+ _onDisplayChange_decorators = [snice.watch('showLabels')];
195
+ _cleanup_decorators = [snice.dispose()];
196
+ _renderContent_decorators = [snice.render({ once: true })];
197
+ _componentStyles_decorators = [snice.styles()];
198
+ __esDecorate(this, null, _emitNodeClick_decorators, { kind: "method", name: "emitNodeClick", static: false, private: false, access: { has: obj => "emitNodeClick" in obj, get: obj => obj.emitNodeClick }, metadata: _metadata }, null, _instanceExtraInitializers);
199
+ __esDecorate(this, null, _emitEdgeClick_decorators, { kind: "method", name: "emitEdgeClick", static: false, private: false, access: { has: obj => "emitEdgeClick" in obj, get: obj => obj.emitEdgeClick }, metadata: _metadata }, null, _instanceExtraInitializers);
200
+ __esDecorate(this, null, _emitNodeDrag_decorators, { kind: "method", name: "emitNodeDrag", static: false, private: false, access: { has: obj => "emitNodeDrag" in obj, get: obj => obj.emitNodeDrag }, metadata: _metadata }, null, _instanceExtraInitializers);
201
+ __esDecorate(this, null, _emitGraphZoom_decorators, { kind: "method", name: "emitGraphZoom", static: false, private: false, access: { has: obj => "emitGraphZoom" in obj, get: obj => obj.emitGraphZoom }, metadata: _metadata }, null, _instanceExtraInitializers);
202
+ __esDecorate(this, null, _init_decorators, { kind: "method", name: "init", static: false, private: false, access: { has: obj => "init" in obj, get: obj => obj.init }, metadata: _metadata }, null, _instanceExtraInitializers);
203
+ __esDecorate(this, null, _onDataChange_decorators, { kind: "method", name: "onDataChange", static: false, private: false, access: { has: obj => "onDataChange" in obj, get: obj => obj.onDataChange }, metadata: _metadata }, null, _instanceExtraInitializers);
204
+ __esDecorate(this, null, _onLayoutChange_decorators, { kind: "method", name: "onLayoutChange", static: false, private: false, access: { has: obj => "onLayoutChange" in obj, get: obj => obj.onLayoutChange }, metadata: _metadata }, null, _instanceExtraInitializers);
205
+ __esDecorate(this, null, _onDisplayChange_decorators, { kind: "method", name: "onDisplayChange", static: false, private: false, access: { has: obj => "onDisplayChange" in obj, get: obj => obj.onDisplayChange }, metadata: _metadata }, null, _instanceExtraInitializers);
206
+ __esDecorate(this, null, _cleanup_decorators, { kind: "method", name: "cleanup", static: false, private: false, access: { has: obj => "cleanup" in obj, get: obj => obj.cleanup }, metadata: _metadata }, null, _instanceExtraInitializers);
207
+ __esDecorate(this, null, _renderContent_decorators, { kind: "method", name: "renderContent", static: false, private: false, access: { has: obj => "renderContent" in obj, get: obj => obj.renderContent }, metadata: _metadata }, null, _instanceExtraInitializers);
208
+ __esDecorate(this, null, _componentStyles_decorators, { kind: "method", name: "componentStyles", static: false, private: false, access: { has: obj => "componentStyles" in obj, get: obj => obj.componentStyles }, metadata: _metadata }, null, _instanceExtraInitializers);
209
+ __esDecorate(null, null, _data_decorators, { kind: "field", name: "data", static: false, private: false, access: { has: obj => "data" in obj, get: obj => obj.data, set: (obj, value) => { obj.data = value; } }, metadata: _metadata }, _data_initializers, _data_extraInitializers);
210
+ __esDecorate(null, null, _layout_decorators, { kind: "field", name: "layout", static: false, private: false, access: { has: obj => "layout" in obj, get: obj => obj.layout, set: (obj, value) => { obj.layout = value; } }, metadata: _metadata }, _layout_initializers, _layout_extraInitializers);
211
+ __esDecorate(null, null, _chargeStrength_decorators, { kind: "field", name: "chargeStrength", static: false, private: false, access: { has: obj => "chargeStrength" in obj, get: obj => obj.chargeStrength, set: (obj, value) => { obj.chargeStrength = value; } }, metadata: _metadata }, _chargeStrength_initializers, _chargeStrength_extraInitializers);
212
+ __esDecorate(null, null, _linkDistance_decorators, { kind: "field", name: "linkDistance", static: false, private: false, access: { has: obj => "linkDistance" in obj, get: obj => obj.linkDistance, set: (obj, value) => { obj.linkDistance = value; } }, metadata: _metadata }, _linkDistance_initializers, _linkDistance_extraInitializers);
213
+ __esDecorate(null, null, _zoomEnabled_decorators, { kind: "field", name: "zoomEnabled", static: false, private: false, access: { has: obj => "zoomEnabled" in obj, get: obj => obj.zoomEnabled, set: (obj, value) => { obj.zoomEnabled = value; } }, metadata: _metadata }, _zoomEnabled_initializers, _zoomEnabled_extraInitializers);
214
+ __esDecorate(null, null, _dragEnabled_decorators, { kind: "field", name: "dragEnabled", static: false, private: false, access: { has: obj => "dragEnabled" in obj, get: obj => obj.dragEnabled, set: (obj, value) => { obj.dragEnabled = value; } }, metadata: _metadata }, _dragEnabled_initializers, _dragEnabled_extraInitializers);
215
+ __esDecorate(null, null, _showLabels_decorators, { kind: "field", name: "showLabels", static: false, private: false, access: { has: obj => "showLabels" in obj, get: obj => obj.showLabels, set: (obj, value) => { obj.showLabels = value; } }, metadata: _metadata }, _showLabels_initializers, _showLabels_extraInitializers);
216
+ __esDecorate(null, null, _animation_decorators, { kind: "field", name: "animation", static: false, private: false, access: { has: obj => "animation" in obj, get: obj => obj.animation, set: (obj, value) => { obj.animation = value; } }, metadata: _metadata }, _animation_initializers, _animation_extraInitializers);
217
+ __esDecorate(null, null, _svgElement_decorators, { kind: "field", name: "svgElement", static: false, private: false, access: { has: obj => "svgElement" in obj, get: obj => obj.svgElement, set: (obj, value) => { obj.svgElement = value; } }, metadata: _metadata }, _svgElement_initializers, _svgElement_extraInitializers);
218
+ __esDecorate(null, null, _tooltipEl_decorators, { kind: "field", name: "tooltipEl", static: false, private: false, access: { has: obj => "tooltipEl" in obj, get: obj => obj.tooltipEl, set: (obj, value) => { obj.tooltipEl = value; } }, metadata: _metadata }, _tooltipEl_initializers, _tooltipEl_extraInitializers);
219
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
220
+ _classThis = _classDescriptor.value;
221
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
222
+ __runInitializers(_classThis, _classExtraInitializers);
223
+ }
224
+ emitNodeClick(node) {
225
+ return { node };
226
+ }
227
+ emitEdgeClick(edge) {
228
+ return { edge };
229
+ }
230
+ emitNodeDrag(node, x, y) {
231
+ return { node, x, y };
232
+ }
233
+ emitGraphZoom(scale, x, y) {
234
+ return { scale, x, y };
235
+ }
236
+ init() {
237
+ this.resizeObserver = new ResizeObserver(entries => {
238
+ for (const entry of entries) {
239
+ this.containerWidth = entry.contentRect.width || 600;
240
+ this.containerHeight = entry.contentRect.height || 400;
241
+ this.updateViewBox();
242
+ }
243
+ });
244
+ this.resizeObserver.observe(this);
245
+ // Attach SVG event listeners
246
+ this.attachSvgListeners();
247
+ // Build simulation if data was set before ready
248
+ if (this.data.nodes.length > 0 && !this.simInitialized) {
249
+ this.buildSimulation();
250
+ }
251
+ }
252
+ onDataChange() {
253
+ this.buildSimulation();
254
+ }
255
+ onLayoutChange() {
256
+ this.buildSimulation();
257
+ }
258
+ onDisplayChange() {
259
+ this.rebuildGraph();
260
+ }
261
+ cleanup() {
262
+ this.stopSimulation();
263
+ document.removeEventListener('mousemove', this.boundMouseMove);
264
+ document.removeEventListener('mouseup', this.boundMouseUp);
265
+ if (this.resizeObserver) {
266
+ this.resizeObserver.disconnect();
267
+ this.resizeObserver = null;
268
+ }
269
+ }
270
+ attachSvgListeners() {
271
+ const svg = this.svgElement;
272
+ if (!svg)
273
+ return;
274
+ svg.addEventListener('mousedown', (e) => this.handleSvgMouseDown(e));
275
+ svg.addEventListener('wheel', (e) => this.handleWheel(e), { passive: false });
276
+ // Event delegation for nodes and edges
277
+ svg.addEventListener('mouseenter', (e) => {
278
+ const nodeGroup = e.target.closest('.network-graph__node');
279
+ if (nodeGroup) {
280
+ const nodeId = nodeGroup.getAttribute('data-node-id');
281
+ if (nodeId)
282
+ this.handleNodeEnter(nodeId, e);
283
+ }
284
+ }, true);
285
+ svg.addEventListener('mouseleave', (e) => {
286
+ const nodeGroup = e.target.closest('.network-graph__node');
287
+ if (nodeGroup)
288
+ this.handleNodeLeave();
289
+ }, true);
290
+ svg.addEventListener('dblclick', (e) => {
291
+ const nodeGroup = e.target.closest('.network-graph__node');
292
+ if (nodeGroup) {
293
+ const nodeId = nodeGroup.getAttribute('data-node-id');
294
+ if (nodeId)
295
+ this.handleNodeDblClick(e, nodeId);
296
+ }
297
+ });
298
+ svg.addEventListener('click', (e) => {
299
+ const edgePath = e.target.closest('.network-graph__edge');
300
+ if (edgePath) {
301
+ const edgeIdx = edgePath.getAttribute('data-edge-idx');
302
+ if (edgeIdx !== null) {
303
+ const idx = parseInt(edgeIdx);
304
+ if (this.simEdges[idx]) {
305
+ e.stopPropagation();
306
+ this.emitEdgeClick(this.simEdges[idx].edge);
307
+ }
308
+ }
309
+ }
310
+ });
311
+ }
312
+ getGroupColor(group) {
313
+ if (!group)
314
+ return DEFAULT_COLORS[0];
315
+ const groups = [...new Set(this.data.nodes.map(n => n.group).filter(Boolean))];
316
+ const idx = groups.indexOf(group);
317
+ return DEFAULT_COLORS[idx % DEFAULT_COLORS.length];
318
+ }
319
+ getNodeRadius(node) {
320
+ if (node.size)
321
+ return node.size;
322
+ return Math.max(6, Math.min(20, 4 + node.degree * 2));
323
+ }
324
+ buildSimulation() {
325
+ this.simInitialized = true;
326
+ this.stopSimulation();
327
+ const nodeMap = new Map();
328
+ const degreeMap = new Map();
329
+ // Count degrees
330
+ for (const edge of this.data.edges) {
331
+ degreeMap.set(edge.source, (degreeMap.get(edge.source) || 0) + 1);
332
+ degreeMap.set(edge.target, (degreeMap.get(edge.target) || 0) + 1);
333
+ }
334
+ const w = this.containerWidth || 600;
335
+ const h = this.containerHeight || 400;
336
+ // Create sim nodes
337
+ this.data.nodes.forEach((node, i) => {
338
+ const simNode = {
339
+ ...node,
340
+ x: node.x ?? 0,
341
+ y: node.y ?? 0,
342
+ vx: 0,
343
+ vy: 0,
344
+ fx: (node.x !== undefined) ? node.x : null,
345
+ fy: (node.y !== undefined) ? node.y : null,
346
+ degree: degreeMap.get(node.id) || 0,
347
+ };
348
+ // Place initial positions based on layout
349
+ if (node.x === undefined || node.y === undefined) {
350
+ if (this.layout === 'circular') {
351
+ const angle = (2 * Math.PI * i) / this.data.nodes.length;
352
+ const radius = Math.min(w, h) * 0.35;
353
+ simNode.x = w / 2 + radius * Math.cos(angle);
354
+ simNode.y = h / 2 + radius * Math.sin(angle);
355
+ simNode.fx = simNode.x;
356
+ simNode.fy = simNode.y;
357
+ }
358
+ else if (this.layout === 'grid') {
359
+ const cols = Math.ceil(Math.sqrt(this.data.nodes.length));
360
+ const cellW = w / (cols + 1);
361
+ const cellH = h / (Math.ceil(this.data.nodes.length / cols) + 1);
362
+ simNode.x = (i % cols + 1) * cellW;
363
+ simNode.y = (Math.floor(i / cols) + 1) * cellH;
364
+ simNode.fx = simNode.x;
365
+ simNode.fy = simNode.y;
366
+ }
367
+ else {
368
+ // Force layout: random initial positions centered
369
+ simNode.x = w / 2 + (Math.random() - 0.5) * w * 0.5;
370
+ simNode.y = h / 2 + (Math.random() - 0.5) * h * 0.5;
371
+ simNode.fx = null;
372
+ simNode.fy = null;
373
+ }
374
+ }
375
+ nodeMap.set(node.id, simNode);
376
+ });
377
+ this.simNodes = [...nodeMap.values()];
378
+ // Create sim edges
379
+ this.simEdges = [];
380
+ for (const edge of this.data.edges) {
381
+ const s = nodeMap.get(edge.source);
382
+ const t = nodeMap.get(edge.target);
383
+ if (s && t) {
384
+ this.simEdges.push({ source: s, target: t, edge });
385
+ }
386
+ }
387
+ // Reset zoom/pan
388
+ this.zoomScale = 1;
389
+ this.panX = 0;
390
+ this.panY = 0;
391
+ if (this.layout === 'force' && this.animation) {
392
+ this.simAlpha = 1;
393
+ this.simRunning = true;
394
+ this.tickSimulation();
395
+ }
396
+ else {
397
+ // Static layouts: just render once
398
+ this.rebuildGraph();
399
+ }
400
+ }
401
+ tickSimulation() {
402
+ if (!this.simRunning)
403
+ return;
404
+ const alpha = this.simAlpha;
405
+ if (alpha < 0.001) {
406
+ this.simRunning = false;
407
+ return;
408
+ }
409
+ const w = this.containerWidth || 600;
410
+ const h = this.containerHeight || 400;
411
+ const cx = w / 2;
412
+ const cy = h / 2;
413
+ // Apply forces
414
+ for (const node of this.simNodes) {
415
+ if (node.fx !== null)
416
+ continue;
417
+ // Repulsion between all nodes
418
+ for (const other of this.simNodes) {
419
+ if (node === other)
420
+ continue;
421
+ const dx = node.x - other.x;
422
+ const dy = node.y - other.y;
423
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
424
+ const force = (this.chargeStrength * alpha) / (dist * dist);
425
+ node.vx -= (dx / dist) * force;
426
+ node.vy -= (dy / dist) * force;
427
+ }
428
+ // Centering force
429
+ node.vx += (cx - node.x) * 0.01 * alpha;
430
+ node.vy += (cy - node.y) * 0.01 * alpha;
431
+ }
432
+ // Spring forces along edges
433
+ for (const se of this.simEdges) {
434
+ const dx = se.target.x - se.source.x;
435
+ const dy = se.target.y - se.source.y;
436
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
437
+ const force = (dist - this.linkDistance) * 0.05 * alpha;
438
+ const fx = (dx / dist) * force;
439
+ const fy = (dy / dist) * force;
440
+ if (se.source.fx === null) {
441
+ se.source.vx += fx;
442
+ se.source.vy += fy;
443
+ }
444
+ if (se.target.fx === null) {
445
+ se.target.vx -= fx;
446
+ se.target.vy -= fy;
447
+ }
448
+ }
449
+ // Update positions with velocity damping
450
+ for (const node of this.simNodes) {
451
+ if (node.fx !== null) {
452
+ node.x = node.fx;
453
+ node.y = node.fy;
454
+ node.vx = 0;
455
+ node.vy = 0;
456
+ continue;
457
+ }
458
+ node.vx *= 0.6;
459
+ node.vy *= 0.6;
460
+ node.x += node.vx;
461
+ node.y += node.vy;
462
+ }
463
+ this.simAlpha *= 0.99;
464
+ // Rebuild via innerHTML instead of reactive render
465
+ this.rebuildGraph();
466
+ this.animFrameId = requestAnimationFrame(() => this.tickSimulation());
467
+ }
468
+ stopSimulation() {
469
+ this.simRunning = false;
470
+ if (this.animFrameId) {
471
+ cancelAnimationFrame(this.animFrameId);
472
+ this.animFrameId = 0;
473
+ }
474
+ }
475
+ updateViewBox() {
476
+ const svg = this.svgElement;
477
+ if (!svg)
478
+ return;
479
+ const w = this.containerWidth || 600;
480
+ const h = this.containerHeight || 400;
481
+ svg.setAttribute('viewBox', `0 0 ${w} ${h}`);
482
+ }
483
+ ensureSvgGroups() {
484
+ if (this.edgesGroupEl && this.nodesGroupEl)
485
+ return true;
486
+ const svg = this.svgElement;
487
+ if (!svg)
488
+ return false;
489
+ const ns = 'http://www.w3.org/2000/svg';
490
+ this.transformGroupEl = document.createElementNS(ns, 'g');
491
+ this.transformGroupEl.setAttribute('transform', 'translate(0, 0) scale(1)');
492
+ this.edgesGroupEl = document.createElementNS(ns, 'g');
493
+ this.nodesGroupEl = document.createElementNS(ns, 'g');
494
+ this.transformGroupEl.appendChild(this.edgesGroupEl);
495
+ this.transformGroupEl.appendChild(this.nodesGroupEl);
496
+ svg.appendChild(this.transformGroupEl);
497
+ return true;
498
+ }
499
+ rebuildGraph() {
500
+ if (!this.ensureSvgGroups()) {
501
+ requestAnimationFrame(() => this.rebuildGraph());
502
+ return;
503
+ }
504
+ // Update transform
505
+ if (this.transformGroupEl) {
506
+ this.transformGroupEl.setAttribute('transform', `translate(${this.panX}, ${this.panY}) scale(${this.zoomScale})`);
507
+ }
508
+ // Update viewBox
509
+ this.updateViewBox();
510
+ // Build edges
511
+ this.edgesGroupEl.innerHTML = this.buildEdges();
512
+ // Build nodes
513
+ this.nodesGroupEl.innerHTML = this.buildNodes();
514
+ }
515
+ buildEdges() {
516
+ const hasHover = this.hoveredNodeId !== '';
517
+ let parts = '';
518
+ this.simEdges.forEach((se, idx) => {
519
+ const connected = this.isEdgeConnected(se);
520
+ const edgeColor = se.edge.color || '';
521
+ const weight = se.edge.weight || 1;
522
+ const path = this.renderEdgePath(se);
523
+ const strokeAttr = edgeColor ? ` stroke="${edgeColor}"` : '';
524
+ const cls = ['network-graph__edge'];
525
+ if (hasHover && connected)
526
+ cls.push('network-graph__edge--highlighted');
527
+ if (hasHover && !connected)
528
+ cls.push('network-graph__edge--dimmed');
529
+ parts += `<path class="${cls.join(' ')}" d="${path}"${strokeAttr} stroke-width="${Math.max(1, weight)}" data-edge-idx="${idx}" />`;
530
+ if (this.showLabels && se.edge.label) {
531
+ const labelCls = hasHover && !connected ? 'network-graph__edge-label network-graph__edge-label--dimmed' : 'network-graph__edge-label';
532
+ const mx = (se.source.x + se.target.x) / 2;
533
+ const my = (se.source.y + se.target.y) / 2;
534
+ parts += `<text class="${labelCls}" x="${mx}" y="${my}">${se.edge.label}</text>`;
535
+ }
536
+ });
537
+ return parts;
538
+ }
539
+ buildNodes() {
540
+ this.hoveredNodeId !== '';
541
+ let parts = '';
542
+ this.simNodes.forEach(node => {
543
+ const connected = this.isNodeConnected(node.id);
544
+ const r = this.getNodeRadius(node);
545
+ const fill = node.color || this.getGroupColor(node.group);
546
+ const isDragging = this.dragNode === node;
547
+ const cls = ['network-graph__node'];
548
+ if (!connected)
549
+ cls.push('network-graph__node--dimmed');
550
+ if (isDragging)
551
+ cls.push('network-graph__node--dragging');
552
+ parts += `<g class="${cls.join(' ')}" data-node-id="${node.id}">`;
553
+ parts += `<circle class="network-graph__node-circle" cx="${node.x}" cy="${node.y}" r="${r}" fill="${fill}" />`;
554
+ if (this.showLabels && (node.label || node.id)) {
555
+ const labelCls = !connected ? 'network-graph__node-label network-graph__node-label--dimmed' : 'network-graph__node-label';
556
+ parts += `<text class="${labelCls}" x="${node.x}" y="${node.y + r + 14}">${node.label || node.id}</text>`;
557
+ }
558
+ parts += `</g>`;
559
+ });
560
+ return parts;
561
+ }
562
+ screenToGraph(screenX, screenY) {
563
+ const svg = this.svgElement;
564
+ if (!svg)
565
+ return { x: screenX, y: screenY };
566
+ const rect = svg.getBoundingClientRect();
567
+ return {
568
+ x: (screenX - rect.left - this.panX) / this.zoomScale,
569
+ y: (screenY - rect.top - this.panY) / this.zoomScale,
570
+ };
571
+ }
572
+ findNodeById(id) {
573
+ return this.simNodes.find(n => n.id === id);
574
+ }
575
+ handleSvgMouseDown(e) {
576
+ // Check if clicking on a node
577
+ const nodeGroup = e.target.closest('.network-graph__node');
578
+ if (nodeGroup && this.dragEnabled) {
579
+ e.preventDefault();
580
+ e.stopPropagation();
581
+ const nodeId = nodeGroup.getAttribute('data-node-id');
582
+ if (nodeId) {
583
+ const node = this.findNodeById(nodeId);
584
+ if (node) {
585
+ this.dragNode = node;
586
+ this.dragStartX = e.clientX;
587
+ this.dragStartY = e.clientY;
588
+ document.addEventListener('mousemove', this.boundMouseMove);
589
+ document.addEventListener('mouseup', this.boundMouseUp);
590
+ return;
591
+ }
592
+ }
593
+ }
594
+ // Background pan
595
+ if (!this.zoomEnabled)
596
+ return;
597
+ e.preventDefault();
598
+ this.isPanning = true;
599
+ this.panStartX = e.clientX;
600
+ this.panStartY = e.clientY;
601
+ this.panStartPanX = this.panX;
602
+ this.panStartPanY = this.panY;
603
+ document.addEventListener('mousemove', this.boundMouseMove);
604
+ document.addEventListener('mouseup', this.boundMouseUp);
605
+ }
606
+ handleMouseMove(e) {
607
+ if (this.dragNode) {
608
+ const pos = this.screenToGraph(e.clientX, e.clientY);
609
+ this.dragNode.x = pos.x;
610
+ this.dragNode.y = pos.y;
611
+ this.dragNode.fx = pos.x;
612
+ this.dragNode.fy = pos.y;
613
+ // Reheat simulation
614
+ if (this.layout === 'force' && this.animation) {
615
+ this.simAlpha = Math.max(this.simAlpha, 0.3);
616
+ if (!this.simRunning) {
617
+ this.simRunning = true;
618
+ this.tickSimulation();
619
+ }
620
+ }
621
+ else {
622
+ this.rebuildGraph();
623
+ }
624
+ this.emitNodeDrag(this.dragNode, pos.x, pos.y);
625
+ }
626
+ else if (this.isPanning) {
627
+ const dx = e.clientX - this.panStartX;
628
+ const dy = e.clientY - this.panStartY;
629
+ this.panX = this.panStartPanX + dx;
630
+ this.panY = this.panStartPanY + dy;
631
+ this.rebuildGraph();
632
+ }
633
+ }
634
+ handleMouseUp(e) {
635
+ if (this.dragNode) {
636
+ const dx = Math.abs(e.clientX - this.dragStartX);
637
+ const dy = Math.abs(e.clientY - this.dragStartY);
638
+ if (dx < 3 && dy < 3) {
639
+ this.emitNodeClick(this.dragNode);
640
+ }
641
+ this.dragNode = null;
642
+ }
643
+ this.isPanning = false;
644
+ document.removeEventListener('mousemove', this.boundMouseMove);
645
+ document.removeEventListener('mouseup', this.boundMouseUp);
646
+ }
647
+ handleWheel(e) {
648
+ if (!this.zoomEnabled)
649
+ return;
650
+ e.preventDefault();
651
+ const svg = this.svgElement;
652
+ if (!svg)
653
+ return;
654
+ const rect = svg.getBoundingClientRect();
655
+ const mouseX = e.clientX - rect.left;
656
+ const mouseY = e.clientY - rect.top;
657
+ const delta = e.deltaY > 0 ? 0.9 : 1.1;
658
+ const newScale = Math.max(0.1, Math.min(5, this.zoomScale * delta));
659
+ // Zoom around mouse position
660
+ this.panX = mouseX - (mouseX - this.panX) * (newScale / this.zoomScale);
661
+ this.panY = mouseY - (mouseY - this.panY) * (newScale / this.zoomScale);
662
+ this.zoomScale = newScale;
663
+ this.rebuildGraph();
664
+ this.emitGraphZoom(this.zoomScale, this.panX, this.panY);
665
+ }
666
+ handleNodeDblClick(e, nodeId) {
667
+ e.preventDefault();
668
+ e.stopPropagation();
669
+ const node = this.findNodeById(nodeId);
670
+ if (!node)
671
+ return;
672
+ // Unpin node
673
+ node.fx = null;
674
+ node.fy = null;
675
+ if (this.layout === 'force' && this.animation) {
676
+ this.simAlpha = Math.max(this.simAlpha, 0.3);
677
+ if (!this.simRunning) {
678
+ this.simRunning = true;
679
+ this.tickSimulation();
680
+ }
681
+ }
682
+ }
683
+ handleNodeEnter(nodeId, e) {
684
+ this.hoveredNodeId = nodeId;
685
+ const node = this.findNodeById(nodeId);
686
+ if (!node)
687
+ return;
688
+ const label = node.label || node.id;
689
+ const degree = node.degree;
690
+ // Update tooltip
691
+ const tooltip = this.tooltipEl;
692
+ if (tooltip) {
693
+ tooltip.textContent = `${label} (${degree} connection${degree !== 1 ? 's' : ''})`;
694
+ const svg = this.svgElement;
695
+ if (svg) {
696
+ const rect = svg.getBoundingClientRect();
697
+ tooltip.style.left = `${e.clientX - rect.left}px`;
698
+ tooltip.style.top = `${e.clientY - rect.top}px`;
699
+ }
700
+ tooltip.classList.add('network-graph__tooltip--visible');
701
+ }
702
+ // Rebuild to apply dimming
703
+ this.rebuildGraph();
704
+ }
705
+ handleNodeLeave() {
706
+ this.hoveredNodeId = '';
707
+ const tooltip = this.tooltipEl;
708
+ if (tooltip) {
709
+ tooltip.classList.remove('network-graph__tooltip--visible');
710
+ }
711
+ this.rebuildGraph();
712
+ }
713
+ isNodeConnected(nodeId) {
714
+ if (!this.hoveredNodeId)
715
+ return true;
716
+ if (nodeId === this.hoveredNodeId)
717
+ return true;
718
+ return this.simEdges.some(se => (se.source.id === this.hoveredNodeId && se.target.id === nodeId) ||
719
+ (se.target.id === this.hoveredNodeId && se.source.id === nodeId));
720
+ }
721
+ isEdgeConnected(se) {
722
+ if (!this.hoveredNodeId)
723
+ return true;
724
+ return se.source.id === this.hoveredNodeId || se.target.id === this.hoveredNodeId;
725
+ }
726
+ hasMultiEdge(source, target) {
727
+ let count = 0;
728
+ for (const se of this.simEdges) {
729
+ if ((se.source.id === source && se.target.id === target) ||
730
+ (se.source.id === target && se.target.id === source)) {
731
+ count++;
732
+ if (count > 1)
733
+ return true;
734
+ }
735
+ }
736
+ return false;
737
+ }
738
+ getEdgeCurveIndex(source, target, edge) {
739
+ let idx = 0;
740
+ for (const se of this.simEdges) {
741
+ if ((se.source.id === source && se.target.id === target) ||
742
+ (se.source.id === target && se.target.id === source)) {
743
+ if (se.edge === edge)
744
+ return idx;
745
+ idx++;
746
+ }
747
+ }
748
+ return 0;
749
+ }
750
+ renderEdgePath(se) {
751
+ const isMulti = this.hasMultiEdge(se.source.id, se.target.id);
752
+ if (!isMulti) {
753
+ return `M ${se.source.x} ${se.source.y} L ${se.target.x} ${se.target.y}`;
754
+ }
755
+ const idx = this.getEdgeCurveIndex(se.source.id, se.target.id, se.edge);
756
+ const dx = se.target.x - se.source.x;
757
+ const dy = se.target.y - se.source.y;
758
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
759
+ const nx = -dy / dist;
760
+ const ny = dx / dist;
761
+ const offset = (idx - 0.5) * 30;
762
+ const mx = (se.source.x + se.target.x) / 2 + nx * offset;
763
+ const my = (se.source.y + se.target.y) / 2 + ny * offset;
764
+ return `M ${se.source.x} ${se.source.y} Q ${mx} ${my} ${se.target.x} ${se.target.y}`;
765
+ }
766
+ renderContent() {
767
+ const w = this.containerWidth || 600;
768
+ const h = this.containerHeight || 400;
769
+ return snice.html /*html*/ `
770
+ <div class="network-graph" role="img" aria-label="Network graph visualization">
771
+ <svg class="network-graph__svg" viewBox="0 0 ${w} ${h}"></svg>
772
+ <div class="network-graph__tooltip"></div>
773
+ </div>
774
+ `;
775
+ }
776
+ componentStyles() {
777
+ return snice.css /*css*/ `${cssContent}`;
778
+ }
779
+ });
780
+ return _classThis;
781
+ })();
782
+
783
+ exports.SniceNetworkGraph = SniceNetworkGraph;
784
+
785
+ return exports;
786
+
787
+ })({}, Snice);
788
+ //# sourceMappingURL=snice-network-graph.js.map