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,721 @@
1
+ import { __runInitializers, __esDecorate } from 'tslib';
2
+ import { element, property, query, dispatch, ready, watch, dispose, render, styles, html, css } from 'snice';
3
+
4
+ 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}";
5
+
6
+ const DEFAULT_COLORS = [
7
+ 'rgb(37 99 235)', // blue
8
+ 'rgb(22 163 74)', // green
9
+ 'rgb(234 88 12)', // orange
10
+ 'rgb(220 38 38)', // red
11
+ 'rgb(147 51 234)', // purple
12
+ 'rgb(6 182 212)', // cyan
13
+ 'rgb(236 72 153)', // pink
14
+ 'rgb(245 158 11)', // amber
15
+ 'rgb(20 184 166)', // teal
16
+ 'rgb(99 102 241)', // indigo
17
+ ];
18
+ let SniceNetworkGraph = (() => {
19
+ let _classDecorators = [element('snice-network-graph')];
20
+ let _classDescriptor;
21
+ let _classExtraInitializers = [];
22
+ let _classThis;
23
+ let _classSuper = HTMLElement;
24
+ let _instanceExtraInitializers = [];
25
+ let _data_decorators;
26
+ let _data_initializers = [];
27
+ let _data_extraInitializers = [];
28
+ let _layout_decorators;
29
+ let _layout_initializers = [];
30
+ let _layout_extraInitializers = [];
31
+ let _chargeStrength_decorators;
32
+ let _chargeStrength_initializers = [];
33
+ let _chargeStrength_extraInitializers = [];
34
+ let _linkDistance_decorators;
35
+ let _linkDistance_initializers = [];
36
+ let _linkDistance_extraInitializers = [];
37
+ let _zoomEnabled_decorators;
38
+ let _zoomEnabled_initializers = [];
39
+ let _zoomEnabled_extraInitializers = [];
40
+ let _dragEnabled_decorators;
41
+ let _dragEnabled_initializers = [];
42
+ let _dragEnabled_extraInitializers = [];
43
+ let _showLabels_decorators;
44
+ let _showLabels_initializers = [];
45
+ let _showLabels_extraInitializers = [];
46
+ let _animation_decorators;
47
+ let _animation_initializers = [];
48
+ let _animation_extraInitializers = [];
49
+ let _svgElement_decorators;
50
+ let _svgElement_initializers = [];
51
+ let _svgElement_extraInitializers = [];
52
+ let _tooltipEl_decorators;
53
+ let _tooltipEl_initializers = [];
54
+ let _tooltipEl_extraInitializers = [];
55
+ let _emitNodeClick_decorators;
56
+ let _emitEdgeClick_decorators;
57
+ let _emitNodeDrag_decorators;
58
+ let _emitGraphZoom_decorators;
59
+ let _init_decorators;
60
+ let _onDataChange_decorators;
61
+ let _onLayoutChange_decorators;
62
+ let _onDisplayChange_decorators;
63
+ let _cleanup_decorators;
64
+ let _renderContent_decorators;
65
+ let _componentStyles_decorators;
66
+ (class extends _classSuper {
67
+ static { _classThis = this; }
68
+ constructor() {
69
+ super(...arguments);
70
+ this.data = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _data_initializers, { nodes: [], edges: [] }));
71
+ this.layout = (__runInitializers(this, _data_extraInitializers), __runInitializers(this, _layout_initializers, 'force'));
72
+ this.chargeStrength = (__runInitializers(this, _layout_extraInitializers), __runInitializers(this, _chargeStrength_initializers, -300));
73
+ this.linkDistance = (__runInitializers(this, _chargeStrength_extraInitializers), __runInitializers(this, _linkDistance_initializers, 80));
74
+ this.zoomEnabled = (__runInitializers(this, _linkDistance_extraInitializers), __runInitializers(this, _zoomEnabled_initializers, true));
75
+ this.dragEnabled = (__runInitializers(this, _zoomEnabled_extraInitializers), __runInitializers(this, _dragEnabled_initializers, true));
76
+ this.showLabels = (__runInitializers(this, _dragEnabled_extraInitializers), __runInitializers(this, _showLabels_initializers, true));
77
+ this.animation = (__runInitializers(this, _showLabels_extraInitializers), __runInitializers(this, _animation_initializers, true));
78
+ this.svgElement = (__runInitializers(this, _animation_extraInitializers), __runInitializers(this, _svgElement_initializers, void 0));
79
+ this.tooltipEl = (__runInitializers(this, _svgElement_extraInitializers), __runInitializers(this, _tooltipEl_initializers, void 0));
80
+ // Manually created SVG-namespace groups (template engine can't create nested SVG children)
81
+ this.transformGroupEl = __runInitializers(this, _tooltipEl_extraInitializers);
82
+ this.simNodes = [];
83
+ this.simEdges = [];
84
+ this.animFrameId = 0;
85
+ this.simAlpha = 1;
86
+ this.simRunning = false;
87
+ this.simInitialized = false;
88
+ // Zoom/pan state
89
+ this.zoomScale = 1;
90
+ this.panX = 0;
91
+ this.panY = 0;
92
+ // Drag state
93
+ this.dragNode = null;
94
+ this.dragStartX = 0;
95
+ this.dragStartY = 0;
96
+ // Pan state
97
+ this.isPanning = false;
98
+ this.panStartX = 0;
99
+ this.panStartY = 0;
100
+ this.panStartPanX = 0;
101
+ this.panStartPanY = 0;
102
+ // Hover state
103
+ this.hoveredNodeId = '';
104
+ // Bound handlers for cleanup
105
+ this.boundMouseMove = this.handleMouseMove.bind(this);
106
+ this.boundMouseUp = this.handleMouseUp.bind(this);
107
+ // ResizeObserver
108
+ this.resizeObserver = null;
109
+ this.containerWidth = 600;
110
+ this.containerHeight = 400;
111
+ }
112
+ static {
113
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
114
+ _data_decorators = [property({ type: Object, attribute: false })];
115
+ _layout_decorators = [property({ attribute: 'layout' })];
116
+ _chargeStrength_decorators = [property({ type: Number, attribute: 'charge-strength' })];
117
+ _linkDistance_decorators = [property({ type: Number, attribute: 'link-distance' })];
118
+ _zoomEnabled_decorators = [property({ type: Boolean, attribute: 'zoom-enabled' })];
119
+ _dragEnabled_decorators = [property({ type: Boolean, attribute: 'drag-enabled' })];
120
+ _showLabels_decorators = [property({ type: Boolean, attribute: 'show-labels' })];
121
+ _animation_decorators = [property({ type: Boolean })];
122
+ _svgElement_decorators = [query('.network-graph__svg')];
123
+ _tooltipEl_decorators = [query('.network-graph__tooltip')];
124
+ _emitNodeClick_decorators = [dispatch('node-click', { bubbles: true, composed: true })];
125
+ _emitEdgeClick_decorators = [dispatch('edge-click', { bubbles: true, composed: true })];
126
+ _emitNodeDrag_decorators = [dispatch('node-drag', { bubbles: true, composed: true })];
127
+ _emitGraphZoom_decorators = [dispatch('graph-zoom', { bubbles: true, composed: true })];
128
+ _init_decorators = [ready()];
129
+ _onDataChange_decorators = [watch('data')];
130
+ _onLayoutChange_decorators = [watch('layout')];
131
+ _onDisplayChange_decorators = [watch('showLabels')];
132
+ _cleanup_decorators = [dispose()];
133
+ _renderContent_decorators = [render({ once: true })];
134
+ _componentStyles_decorators = [styles()];
135
+ __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);
136
+ __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);
137
+ __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);
138
+ __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);
139
+ __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);
140
+ __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);
141
+ __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);
142
+ __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);
143
+ __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);
144
+ __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);
145
+ __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);
146
+ __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);
147
+ __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);
148
+ __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);
149
+ __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);
150
+ __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);
151
+ __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);
152
+ __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);
153
+ __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);
154
+ __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);
155
+ __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);
156
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
157
+ _classThis = _classDescriptor.value;
158
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
159
+ __runInitializers(_classThis, _classExtraInitializers);
160
+ }
161
+ emitNodeClick(node) {
162
+ return { node };
163
+ }
164
+ emitEdgeClick(edge) {
165
+ return { edge };
166
+ }
167
+ emitNodeDrag(node, x, y) {
168
+ return { node, x, y };
169
+ }
170
+ emitGraphZoom(scale, x, y) {
171
+ return { scale, x, y };
172
+ }
173
+ init() {
174
+ this.resizeObserver = new ResizeObserver(entries => {
175
+ for (const entry of entries) {
176
+ this.containerWidth = entry.contentRect.width || 600;
177
+ this.containerHeight = entry.contentRect.height || 400;
178
+ this.updateViewBox();
179
+ }
180
+ });
181
+ this.resizeObserver.observe(this);
182
+ // Attach SVG event listeners
183
+ this.attachSvgListeners();
184
+ // Build simulation if data was set before ready
185
+ if (this.data.nodes.length > 0 && !this.simInitialized) {
186
+ this.buildSimulation();
187
+ }
188
+ }
189
+ onDataChange() {
190
+ this.buildSimulation();
191
+ }
192
+ onLayoutChange() {
193
+ this.buildSimulation();
194
+ }
195
+ onDisplayChange() {
196
+ this.rebuildGraph();
197
+ }
198
+ cleanup() {
199
+ this.stopSimulation();
200
+ document.removeEventListener('mousemove', this.boundMouseMove);
201
+ document.removeEventListener('mouseup', this.boundMouseUp);
202
+ if (this.resizeObserver) {
203
+ this.resizeObserver.disconnect();
204
+ this.resizeObserver = null;
205
+ }
206
+ }
207
+ attachSvgListeners() {
208
+ const svg = this.svgElement;
209
+ if (!svg)
210
+ return;
211
+ svg.addEventListener('mousedown', (e) => this.handleSvgMouseDown(e));
212
+ svg.addEventListener('wheel', (e) => this.handleWheel(e), { passive: false });
213
+ // Event delegation for nodes and edges
214
+ svg.addEventListener('mouseenter', (e) => {
215
+ const nodeGroup = e.target.closest('.network-graph__node');
216
+ if (nodeGroup) {
217
+ const nodeId = nodeGroup.getAttribute('data-node-id');
218
+ if (nodeId)
219
+ this.handleNodeEnter(nodeId, e);
220
+ }
221
+ }, true);
222
+ svg.addEventListener('mouseleave', (e) => {
223
+ const nodeGroup = e.target.closest('.network-graph__node');
224
+ if (nodeGroup)
225
+ this.handleNodeLeave();
226
+ }, true);
227
+ svg.addEventListener('dblclick', (e) => {
228
+ const nodeGroup = e.target.closest('.network-graph__node');
229
+ if (nodeGroup) {
230
+ const nodeId = nodeGroup.getAttribute('data-node-id');
231
+ if (nodeId)
232
+ this.handleNodeDblClick(e, nodeId);
233
+ }
234
+ });
235
+ svg.addEventListener('click', (e) => {
236
+ const edgePath = e.target.closest('.network-graph__edge');
237
+ if (edgePath) {
238
+ const edgeIdx = edgePath.getAttribute('data-edge-idx');
239
+ if (edgeIdx !== null) {
240
+ const idx = parseInt(edgeIdx);
241
+ if (this.simEdges[idx]) {
242
+ e.stopPropagation();
243
+ this.emitEdgeClick(this.simEdges[idx].edge);
244
+ }
245
+ }
246
+ }
247
+ });
248
+ }
249
+ getGroupColor(group) {
250
+ if (!group)
251
+ return DEFAULT_COLORS[0];
252
+ const groups = [...new Set(this.data.nodes.map(n => n.group).filter(Boolean))];
253
+ const idx = groups.indexOf(group);
254
+ return DEFAULT_COLORS[idx % DEFAULT_COLORS.length];
255
+ }
256
+ getNodeRadius(node) {
257
+ if (node.size)
258
+ return node.size;
259
+ return Math.max(6, Math.min(20, 4 + node.degree * 2));
260
+ }
261
+ buildSimulation() {
262
+ this.simInitialized = true;
263
+ this.stopSimulation();
264
+ const nodeMap = new Map();
265
+ const degreeMap = new Map();
266
+ // Count degrees
267
+ for (const edge of this.data.edges) {
268
+ degreeMap.set(edge.source, (degreeMap.get(edge.source) || 0) + 1);
269
+ degreeMap.set(edge.target, (degreeMap.get(edge.target) || 0) + 1);
270
+ }
271
+ const w = this.containerWidth || 600;
272
+ const h = this.containerHeight || 400;
273
+ // Create sim nodes
274
+ this.data.nodes.forEach((node, i) => {
275
+ const simNode = {
276
+ ...node,
277
+ x: node.x ?? 0,
278
+ y: node.y ?? 0,
279
+ vx: 0,
280
+ vy: 0,
281
+ fx: (node.x !== undefined) ? node.x : null,
282
+ fy: (node.y !== undefined) ? node.y : null,
283
+ degree: degreeMap.get(node.id) || 0,
284
+ };
285
+ // Place initial positions based on layout
286
+ if (node.x === undefined || node.y === undefined) {
287
+ if (this.layout === 'circular') {
288
+ const angle = (2 * Math.PI * i) / this.data.nodes.length;
289
+ const radius = Math.min(w, h) * 0.35;
290
+ simNode.x = w / 2 + radius * Math.cos(angle);
291
+ simNode.y = h / 2 + radius * Math.sin(angle);
292
+ simNode.fx = simNode.x;
293
+ simNode.fy = simNode.y;
294
+ }
295
+ else if (this.layout === 'grid') {
296
+ const cols = Math.ceil(Math.sqrt(this.data.nodes.length));
297
+ const cellW = w / (cols + 1);
298
+ const cellH = h / (Math.ceil(this.data.nodes.length / cols) + 1);
299
+ simNode.x = (i % cols + 1) * cellW;
300
+ simNode.y = (Math.floor(i / cols) + 1) * cellH;
301
+ simNode.fx = simNode.x;
302
+ simNode.fy = simNode.y;
303
+ }
304
+ else {
305
+ // Force layout: random initial positions centered
306
+ simNode.x = w / 2 + (Math.random() - 0.5) * w * 0.5;
307
+ simNode.y = h / 2 + (Math.random() - 0.5) * h * 0.5;
308
+ simNode.fx = null;
309
+ simNode.fy = null;
310
+ }
311
+ }
312
+ nodeMap.set(node.id, simNode);
313
+ });
314
+ this.simNodes = [...nodeMap.values()];
315
+ // Create sim edges
316
+ this.simEdges = [];
317
+ for (const edge of this.data.edges) {
318
+ const s = nodeMap.get(edge.source);
319
+ const t = nodeMap.get(edge.target);
320
+ if (s && t) {
321
+ this.simEdges.push({ source: s, target: t, edge });
322
+ }
323
+ }
324
+ // Reset zoom/pan
325
+ this.zoomScale = 1;
326
+ this.panX = 0;
327
+ this.panY = 0;
328
+ if (this.layout === 'force' && this.animation) {
329
+ this.simAlpha = 1;
330
+ this.simRunning = true;
331
+ this.tickSimulation();
332
+ }
333
+ else {
334
+ // Static layouts: just render once
335
+ this.rebuildGraph();
336
+ }
337
+ }
338
+ tickSimulation() {
339
+ if (!this.simRunning)
340
+ return;
341
+ const alpha = this.simAlpha;
342
+ if (alpha < 0.001) {
343
+ this.simRunning = false;
344
+ return;
345
+ }
346
+ const w = this.containerWidth || 600;
347
+ const h = this.containerHeight || 400;
348
+ const cx = w / 2;
349
+ const cy = h / 2;
350
+ // Apply forces
351
+ for (const node of this.simNodes) {
352
+ if (node.fx !== null)
353
+ continue;
354
+ // Repulsion between all nodes
355
+ for (const other of this.simNodes) {
356
+ if (node === other)
357
+ continue;
358
+ const dx = node.x - other.x;
359
+ const dy = node.y - other.y;
360
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
361
+ const force = (this.chargeStrength * alpha) / (dist * dist);
362
+ node.vx -= (dx / dist) * force;
363
+ node.vy -= (dy / dist) * force;
364
+ }
365
+ // Centering force
366
+ node.vx += (cx - node.x) * 0.01 * alpha;
367
+ node.vy += (cy - node.y) * 0.01 * alpha;
368
+ }
369
+ // Spring forces along edges
370
+ for (const se of this.simEdges) {
371
+ const dx = se.target.x - se.source.x;
372
+ const dy = se.target.y - se.source.y;
373
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
374
+ const force = (dist - this.linkDistance) * 0.05 * alpha;
375
+ const fx = (dx / dist) * force;
376
+ const fy = (dy / dist) * force;
377
+ if (se.source.fx === null) {
378
+ se.source.vx += fx;
379
+ se.source.vy += fy;
380
+ }
381
+ if (se.target.fx === null) {
382
+ se.target.vx -= fx;
383
+ se.target.vy -= fy;
384
+ }
385
+ }
386
+ // Update positions with velocity damping
387
+ for (const node of this.simNodes) {
388
+ if (node.fx !== null) {
389
+ node.x = node.fx;
390
+ node.y = node.fy;
391
+ node.vx = 0;
392
+ node.vy = 0;
393
+ continue;
394
+ }
395
+ node.vx *= 0.6;
396
+ node.vy *= 0.6;
397
+ node.x += node.vx;
398
+ node.y += node.vy;
399
+ }
400
+ this.simAlpha *= 0.99;
401
+ // Rebuild via innerHTML instead of reactive render
402
+ this.rebuildGraph();
403
+ this.animFrameId = requestAnimationFrame(() => this.tickSimulation());
404
+ }
405
+ stopSimulation() {
406
+ this.simRunning = false;
407
+ if (this.animFrameId) {
408
+ cancelAnimationFrame(this.animFrameId);
409
+ this.animFrameId = 0;
410
+ }
411
+ }
412
+ updateViewBox() {
413
+ const svg = this.svgElement;
414
+ if (!svg)
415
+ return;
416
+ const w = this.containerWidth || 600;
417
+ const h = this.containerHeight || 400;
418
+ svg.setAttribute('viewBox', `0 0 ${w} ${h}`);
419
+ }
420
+ ensureSvgGroups() {
421
+ if (this.edgesGroupEl && this.nodesGroupEl)
422
+ return true;
423
+ const svg = this.svgElement;
424
+ if (!svg)
425
+ return false;
426
+ const ns = 'http://www.w3.org/2000/svg';
427
+ this.transformGroupEl = document.createElementNS(ns, 'g');
428
+ this.transformGroupEl.setAttribute('transform', 'translate(0, 0) scale(1)');
429
+ this.edgesGroupEl = document.createElementNS(ns, 'g');
430
+ this.nodesGroupEl = document.createElementNS(ns, 'g');
431
+ this.transformGroupEl.appendChild(this.edgesGroupEl);
432
+ this.transformGroupEl.appendChild(this.nodesGroupEl);
433
+ svg.appendChild(this.transformGroupEl);
434
+ return true;
435
+ }
436
+ rebuildGraph() {
437
+ if (!this.ensureSvgGroups()) {
438
+ requestAnimationFrame(() => this.rebuildGraph());
439
+ return;
440
+ }
441
+ // Update transform
442
+ if (this.transformGroupEl) {
443
+ this.transformGroupEl.setAttribute('transform', `translate(${this.panX}, ${this.panY}) scale(${this.zoomScale})`);
444
+ }
445
+ // Update viewBox
446
+ this.updateViewBox();
447
+ // Build edges
448
+ this.edgesGroupEl.innerHTML = this.buildEdges();
449
+ // Build nodes
450
+ this.nodesGroupEl.innerHTML = this.buildNodes();
451
+ }
452
+ buildEdges() {
453
+ const hasHover = this.hoveredNodeId !== '';
454
+ let parts = '';
455
+ this.simEdges.forEach((se, idx) => {
456
+ const connected = this.isEdgeConnected(se);
457
+ const edgeColor = se.edge.color || '';
458
+ const weight = se.edge.weight || 1;
459
+ const path = this.renderEdgePath(se);
460
+ const strokeAttr = edgeColor ? ` stroke="${edgeColor}"` : '';
461
+ const cls = ['network-graph__edge'];
462
+ if (hasHover && connected)
463
+ cls.push('network-graph__edge--highlighted');
464
+ if (hasHover && !connected)
465
+ cls.push('network-graph__edge--dimmed');
466
+ parts += `<path class="${cls.join(' ')}" d="${path}"${strokeAttr} stroke-width="${Math.max(1, weight)}" data-edge-idx="${idx}" />`;
467
+ if (this.showLabels && se.edge.label) {
468
+ const labelCls = hasHover && !connected ? 'network-graph__edge-label network-graph__edge-label--dimmed' : 'network-graph__edge-label';
469
+ const mx = (se.source.x + se.target.x) / 2;
470
+ const my = (se.source.y + se.target.y) / 2;
471
+ parts += `<text class="${labelCls}" x="${mx}" y="${my}">${se.edge.label}</text>`;
472
+ }
473
+ });
474
+ return parts;
475
+ }
476
+ buildNodes() {
477
+ this.hoveredNodeId !== '';
478
+ let parts = '';
479
+ this.simNodes.forEach(node => {
480
+ const connected = this.isNodeConnected(node.id);
481
+ const r = this.getNodeRadius(node);
482
+ const fill = node.color || this.getGroupColor(node.group);
483
+ const isDragging = this.dragNode === node;
484
+ const cls = ['network-graph__node'];
485
+ if (!connected)
486
+ cls.push('network-graph__node--dimmed');
487
+ if (isDragging)
488
+ cls.push('network-graph__node--dragging');
489
+ parts += `<g class="${cls.join(' ')}" data-node-id="${node.id}">`;
490
+ parts += `<circle class="network-graph__node-circle" cx="${node.x}" cy="${node.y}" r="${r}" fill="${fill}" />`;
491
+ if (this.showLabels && (node.label || node.id)) {
492
+ const labelCls = !connected ? 'network-graph__node-label network-graph__node-label--dimmed' : 'network-graph__node-label';
493
+ parts += `<text class="${labelCls}" x="${node.x}" y="${node.y + r + 14}">${node.label || node.id}</text>`;
494
+ }
495
+ parts += `</g>`;
496
+ });
497
+ return parts;
498
+ }
499
+ screenToGraph(screenX, screenY) {
500
+ const svg = this.svgElement;
501
+ if (!svg)
502
+ return { x: screenX, y: screenY };
503
+ const rect = svg.getBoundingClientRect();
504
+ return {
505
+ x: (screenX - rect.left - this.panX) / this.zoomScale,
506
+ y: (screenY - rect.top - this.panY) / this.zoomScale,
507
+ };
508
+ }
509
+ findNodeById(id) {
510
+ return this.simNodes.find(n => n.id === id);
511
+ }
512
+ handleSvgMouseDown(e) {
513
+ // Check if clicking on a node
514
+ const nodeGroup = e.target.closest('.network-graph__node');
515
+ if (nodeGroup && this.dragEnabled) {
516
+ e.preventDefault();
517
+ e.stopPropagation();
518
+ const nodeId = nodeGroup.getAttribute('data-node-id');
519
+ if (nodeId) {
520
+ const node = this.findNodeById(nodeId);
521
+ if (node) {
522
+ this.dragNode = node;
523
+ this.dragStartX = e.clientX;
524
+ this.dragStartY = e.clientY;
525
+ document.addEventListener('mousemove', this.boundMouseMove);
526
+ document.addEventListener('mouseup', this.boundMouseUp);
527
+ return;
528
+ }
529
+ }
530
+ }
531
+ // Background pan
532
+ if (!this.zoomEnabled)
533
+ return;
534
+ e.preventDefault();
535
+ this.isPanning = true;
536
+ this.panStartX = e.clientX;
537
+ this.panStartY = e.clientY;
538
+ this.panStartPanX = this.panX;
539
+ this.panStartPanY = this.panY;
540
+ document.addEventListener('mousemove', this.boundMouseMove);
541
+ document.addEventListener('mouseup', this.boundMouseUp);
542
+ }
543
+ handleMouseMove(e) {
544
+ if (this.dragNode) {
545
+ const pos = this.screenToGraph(e.clientX, e.clientY);
546
+ this.dragNode.x = pos.x;
547
+ this.dragNode.y = pos.y;
548
+ this.dragNode.fx = pos.x;
549
+ this.dragNode.fy = pos.y;
550
+ // Reheat simulation
551
+ if (this.layout === 'force' && this.animation) {
552
+ this.simAlpha = Math.max(this.simAlpha, 0.3);
553
+ if (!this.simRunning) {
554
+ this.simRunning = true;
555
+ this.tickSimulation();
556
+ }
557
+ }
558
+ else {
559
+ this.rebuildGraph();
560
+ }
561
+ this.emitNodeDrag(this.dragNode, pos.x, pos.y);
562
+ }
563
+ else if (this.isPanning) {
564
+ const dx = e.clientX - this.panStartX;
565
+ const dy = e.clientY - this.panStartY;
566
+ this.panX = this.panStartPanX + dx;
567
+ this.panY = this.panStartPanY + dy;
568
+ this.rebuildGraph();
569
+ }
570
+ }
571
+ handleMouseUp(e) {
572
+ if (this.dragNode) {
573
+ const dx = Math.abs(e.clientX - this.dragStartX);
574
+ const dy = Math.abs(e.clientY - this.dragStartY);
575
+ if (dx < 3 && dy < 3) {
576
+ this.emitNodeClick(this.dragNode);
577
+ }
578
+ this.dragNode = null;
579
+ }
580
+ this.isPanning = false;
581
+ document.removeEventListener('mousemove', this.boundMouseMove);
582
+ document.removeEventListener('mouseup', this.boundMouseUp);
583
+ }
584
+ handleWheel(e) {
585
+ if (!this.zoomEnabled)
586
+ return;
587
+ e.preventDefault();
588
+ const svg = this.svgElement;
589
+ if (!svg)
590
+ return;
591
+ const rect = svg.getBoundingClientRect();
592
+ const mouseX = e.clientX - rect.left;
593
+ const mouseY = e.clientY - rect.top;
594
+ const delta = e.deltaY > 0 ? 0.9 : 1.1;
595
+ const newScale = Math.max(0.1, Math.min(5, this.zoomScale * delta));
596
+ // Zoom around mouse position
597
+ this.panX = mouseX - (mouseX - this.panX) * (newScale / this.zoomScale);
598
+ this.panY = mouseY - (mouseY - this.panY) * (newScale / this.zoomScale);
599
+ this.zoomScale = newScale;
600
+ this.rebuildGraph();
601
+ this.emitGraphZoom(this.zoomScale, this.panX, this.panY);
602
+ }
603
+ handleNodeDblClick(e, nodeId) {
604
+ e.preventDefault();
605
+ e.stopPropagation();
606
+ const node = this.findNodeById(nodeId);
607
+ if (!node)
608
+ return;
609
+ // Unpin node
610
+ node.fx = null;
611
+ node.fy = null;
612
+ if (this.layout === 'force' && this.animation) {
613
+ this.simAlpha = Math.max(this.simAlpha, 0.3);
614
+ if (!this.simRunning) {
615
+ this.simRunning = true;
616
+ this.tickSimulation();
617
+ }
618
+ }
619
+ }
620
+ handleNodeEnter(nodeId, e) {
621
+ this.hoveredNodeId = nodeId;
622
+ const node = this.findNodeById(nodeId);
623
+ if (!node)
624
+ return;
625
+ const label = node.label || node.id;
626
+ const degree = node.degree;
627
+ // Update tooltip
628
+ const tooltip = this.tooltipEl;
629
+ if (tooltip) {
630
+ tooltip.textContent = `${label} (${degree} connection${degree !== 1 ? 's' : ''})`;
631
+ const svg = this.svgElement;
632
+ if (svg) {
633
+ const rect = svg.getBoundingClientRect();
634
+ tooltip.style.left = `${e.clientX - rect.left}px`;
635
+ tooltip.style.top = `${e.clientY - rect.top}px`;
636
+ }
637
+ tooltip.classList.add('network-graph__tooltip--visible');
638
+ }
639
+ // Rebuild to apply dimming
640
+ this.rebuildGraph();
641
+ }
642
+ handleNodeLeave() {
643
+ this.hoveredNodeId = '';
644
+ const tooltip = this.tooltipEl;
645
+ if (tooltip) {
646
+ tooltip.classList.remove('network-graph__tooltip--visible');
647
+ }
648
+ this.rebuildGraph();
649
+ }
650
+ isNodeConnected(nodeId) {
651
+ if (!this.hoveredNodeId)
652
+ return true;
653
+ if (nodeId === this.hoveredNodeId)
654
+ return true;
655
+ return this.simEdges.some(se => (se.source.id === this.hoveredNodeId && se.target.id === nodeId) ||
656
+ (se.target.id === this.hoveredNodeId && se.source.id === nodeId));
657
+ }
658
+ isEdgeConnected(se) {
659
+ if (!this.hoveredNodeId)
660
+ return true;
661
+ return se.source.id === this.hoveredNodeId || se.target.id === this.hoveredNodeId;
662
+ }
663
+ hasMultiEdge(source, target) {
664
+ let count = 0;
665
+ for (const se of this.simEdges) {
666
+ if ((se.source.id === source && se.target.id === target) ||
667
+ (se.source.id === target && se.target.id === source)) {
668
+ count++;
669
+ if (count > 1)
670
+ return true;
671
+ }
672
+ }
673
+ return false;
674
+ }
675
+ getEdgeCurveIndex(source, target, edge) {
676
+ let idx = 0;
677
+ for (const se of this.simEdges) {
678
+ if ((se.source.id === source && se.target.id === target) ||
679
+ (se.source.id === target && se.target.id === source)) {
680
+ if (se.edge === edge)
681
+ return idx;
682
+ idx++;
683
+ }
684
+ }
685
+ return 0;
686
+ }
687
+ renderEdgePath(se) {
688
+ const isMulti = this.hasMultiEdge(se.source.id, se.target.id);
689
+ if (!isMulti) {
690
+ return `M ${se.source.x} ${se.source.y} L ${se.target.x} ${se.target.y}`;
691
+ }
692
+ const idx = this.getEdgeCurveIndex(se.source.id, se.target.id, se.edge);
693
+ const dx = se.target.x - se.source.x;
694
+ const dy = se.target.y - se.source.y;
695
+ const dist = Math.sqrt(dx * dx + dy * dy) || 1;
696
+ const nx = -dy / dist;
697
+ const ny = dx / dist;
698
+ const offset = (idx - 0.5) * 30;
699
+ const mx = (se.source.x + se.target.x) / 2 + nx * offset;
700
+ const my = (se.source.y + se.target.y) / 2 + ny * offset;
701
+ return `M ${se.source.x} ${se.source.y} Q ${mx} ${my} ${se.target.x} ${se.target.y}`;
702
+ }
703
+ renderContent() {
704
+ const w = this.containerWidth || 600;
705
+ const h = this.containerHeight || 400;
706
+ return html /*html*/ `
707
+ <div class="network-graph" role="img" aria-label="Network graph visualization">
708
+ <svg class="network-graph__svg" viewBox="0 0 ${w} ${h}"></svg>
709
+ <div class="network-graph__tooltip"></div>
710
+ </div>
711
+ `;
712
+ }
713
+ componentStyles() {
714
+ return css /*css*/ `${cssContent}`;
715
+ }
716
+ });
717
+ return _classThis;
718
+ })();
719
+
720
+ export { SniceNetworkGraph };
721
+ //# sourceMappingURL=snice-network-graph.js.map