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,20 @@
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
+ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be loaded before snice-funnel.min.js");var SniceFunnel=function(e,t){"use strict";function a(e,t,a,n,i,s){function l(e){if(void 0!==e&&"function"!=typeof e)throw new TypeError("Function expected");return e}for(var o,r=n.kind,c="getter"===r?"get":"setter"===r?"set":"value",h=!t&&e?n.static?e:e.prototype:null,u=t||(h?Object.getOwnPropertyDescriptor(h,n.name):{}),d=!1,g=a.length-1;g>=0;g--){var m={};for(var p in n)m[p]="access"===p?{}:n[p];for(var p in n.access)m.access[p]=n.access[p];m.addInitializer=function(e){if(d)throw new TypeError("Cannot add initializers after decoration has completed");s.push(l(e||null))};var f=(0,a[g])("accessor"===r?{get:u.get,set:u.set}:u[c],m);if("accessor"===r){if(void 0===f)continue;if(null===f||"object"!=typeof f)throw new TypeError("Object expected");(o=l(f.get))&&(u.get=o),(o=l(f.set))&&(u.set=o),(o=l(f.init))&&i.unshift(o)}else(o=l(f))&&("field"===r?i.unshift(o):u[c]=o)}h&&Object.defineProperty(h,n.name,u),d=!0}function n(e,t,a){for(var n=arguments.length>2,i=0;i<t.length;i++)a=n?t[i].call(e,a):t[i].call(e);return n?a:void 0}"function"==typeof SuppressedError&&SuppressedError;const i=["rgb(37 99 235)","rgb(59 130 246)","rgb(96 165 250)","rgb(147 197 253)","rgb(191 219 254)","rgb(219 234 254)"];function s(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}let l=(()=>{let e,l,o,r,c,h,u,d,g,m,p,f,v,b,y,x,w,_,$=[t.element("snice-funnel")],S=[],k=HTMLElement,C=[],D=[],L=[],E=[],F=[],V=[],M=[],z=[],P=[],H=[],I=[],B=[],R=[],j=[],T=[],q=[],A=[],O=[],G=[];return class extends k{static{l=this}constructor(){super(...arguments),this.data=(n(this,C),n(this,D,[])),this.variant=(n(this,L),n(this,E,"default")),this.orientation=(n(this,F),n(this,V,"vertical")),this.showLabels=(n(this,M),n(this,z,!0)),this.showValues=(n(this,P),n(this,H,!0)),this.showPercentages=(n(this,I),n(this,B,!0)),this.animation=(n(this,R),n(this,j,!1)),this.chartEl=(n(this,T),n(this,q,void 0)),this.tooltipEl=(n(this,A),n(this,O,void 0)),this.cachedData=(n(this,G),[])}static{const i="function"==typeof Symbol&&Symbol.metadata?Object.create(k[Symbol.metadata]??null):void 0;o=[t.property({type:Array,attribute:!1})],r=[t.property()],c=[t.property()],h=[t.property({type:Boolean,attribute:"show-labels"})],u=[t.property({type:Boolean,attribute:"show-values"})],d=[t.property({type:Boolean,attribute:"show-percentages"})],g=[t.property({type:Boolean})],m=[t.query(".funnel__chart")],p=[t.query(".funnel__tooltip")],f=[t.dispatch("funnel-click",{bubbles:!0,composed:!0})],v=[t.dispatch("funnel-hover",{bubbles:!0,composed:!0})],b=[t.watch("data")],y=[t.watch("variant","orientation","showLabels","showValues","showPercentages","animation")],x=[t.ready()],w=[t.render({once:!0})],_=[t.styles()],a(this,null,f,{kind:"method",name:"emitFunnelClick",static:!1,private:!1,access:{has:e=>"emitFunnelClick"in e,get:e=>e.emitFunnelClick},metadata:i},null,C),a(this,null,v,{kind:"method",name:"emitFunnelHover",static:!1,private:!1,access:{has:e=>"emitFunnelHover"in e,get:e=>e.emitFunnelHover},metadata:i},null,C),a(this,null,b,{kind:"method",name:"onDataChange",static:!1,private:!1,access:{has:e=>"onDataChange"in e,get:e=>e.onDataChange},metadata:i},null,C),a(this,null,y,{kind:"method",name:"onDisplayChange",static:!1,private:!1,access:{has:e=>"onDisplayChange"in e,get:e=>e.onDisplayChange},metadata:i},null,C),a(this,null,x,{kind:"method",name:"init",static:!1,private:!1,access:{has:e=>"init"in e,get:e=>e.init},metadata:i},null,C),a(this,null,w,{kind:"method",name:"renderContent",static:!1,private:!1,access:{has:e=>"renderContent"in e,get:e=>e.renderContent},metadata:i},null,C),a(this,null,_,{kind:"method",name:"componentStyles",static:!1,private:!1,access:{has:e=>"componentStyles"in e,get:e=>e.componentStyles},metadata:i},null,C),a(null,null,o,{kind:"field",name:"data",static:!1,private:!1,access:{has:e=>"data"in e,get:e=>e.data,set:(e,t)=>{e.data=t}},metadata:i},D,L),a(null,null,r,{kind:"field",name:"variant",static:!1,private:!1,access:{has:e=>"variant"in e,get:e=>e.variant,set:(e,t)=>{e.variant=t}},metadata:i},E,F),a(null,null,c,{kind:"field",name:"orientation",static:!1,private:!1,access:{has:e=>"orientation"in e,get:e=>e.orientation,set:(e,t)=>{e.orientation=t}},metadata:i},V,M),a(null,null,h,{kind:"field",name:"showLabels",static:!1,private:!1,access:{has:e=>"showLabels"in e,get:e=>e.showLabels,set:(e,t)=>{e.showLabels=t}},metadata:i},z,P),a(null,null,u,{kind:"field",name:"showValues",static:!1,private:!1,access:{has:e=>"showValues"in e,get:e=>e.showValues,set:(e,t)=>{e.showValues=t}},metadata:i},H,I),a(null,null,d,{kind:"field",name:"showPercentages",static:!1,private:!1,access:{has:e=>"showPercentages"in e,get:e=>e.showPercentages,set:(e,t)=>{e.showPercentages=t}},metadata:i},B,R),a(null,null,g,{kind:"field",name:"animation",static:!1,private:!1,access:{has:e=>"animation"in e,get:e=>e.animation,set:(e,t)=>{e.animation=t}},metadata:i},j,T),a(null,null,m,{kind:"field",name:"chartEl",static:!1,private:!1,access:{has:e=>"chartEl"in e,get:e=>e.chartEl,set:(e,t)=>{e.chartEl=t}},metadata:i},q,A),a(null,null,p,{kind:"field",name:"tooltipEl",static:!1,private:!1,access:{has:e=>"tooltipEl"in e,get:e=>e.tooltipEl,set:(e,t)=>{e.tooltipEl=t}},metadata:i},O,G),a(null,e={value:l},$,{kind:"class",name:l.name,metadata:i},null,S),l=e.value,i&&Object.defineProperty(l,Symbol.metadata,{enumerable:!0,configurable:!0,writable:!0,value:i}),n(l,S)}emitFunnelClick(e,t){return{stage:e,index:t}}emitFunnelHover(e,t){return{stage:e,index:t}}onDataChange(e,t){this.cachedData=t||[],this.rebuildChart()}onDisplayChange(){this.rebuildChart()}init(){0===this.cachedData.length&&this.data.length>0&&(this.cachedData=this.data),this.rebuildChart()}getColor(e,t){if(t.color)return t.color;if("gradient"===this.variant&&this.cachedData.length>0){return`rgba(37, 99, 235, ${1-e/this.cachedData.length*.6})`}return i[e%i.length]}getPercentage(e){if(0===this.cachedData.length)return"0%";const t=this.cachedData[0].value;return 0===t?"0%":`${Math.round(this.cachedData[e].value/t*100)}%`}formatValue(e){return e>=1e6?`${(e/1e6).toFixed(1)}M`:e>=1e3?`${(e/1e3).toFixed(1)}K`:String(e)}handleSvgClick(e){const t=e.target,a=t.dataset?.index??t.closest("[data-index]")?.getAttribute("data-index");if(null==a)return;const n=parseInt(a,10),i=this.cachedData[n];i&&this.emitFunnelClick(i,n)}handleSvgMouseMove(e){const t=e.target,a=void 0!==t.dataset?.index?t:t.closest("[data-index]"),n=this.tooltipEl;if(!a)return void(n&&(n.style.display="none"));const i=parseInt(a.dataset.index,10),s=this.cachedData[i];if(!s||!n)return;const l=a.getBoundingClientRect();n.querySelector(".funnel__tooltip-label").textContent=s.label,n.querySelector(".funnel__tooltip-value").textContent=`${this.formatValue(s.value)} (${this.getPercentage(i)})`,n.style.left=`${l.left+l.width/2}px`,n.style.top=l.top-8+"px",n.style.display="",this.emitFunnelHover(s,i)}handleSvgMouseLeave(){const e=this.tooltipEl;e&&(e.style.display="none")}handleSvgKeyDown(e){if("Enter"!==e.key&&" "!==e.key)return;const t=e.target,a=t.dataset?.index;if(void 0===a)return;e.preventDefault();const n=parseInt(a,10),i=this.cachedData[n];i&&this.emitFunnelClick(i,n)}rebuildChart(){const e=this.chartEl;if(!e)return void requestAnimationFrame(()=>this.rebuildChart());const t="horizontal"===this.orientation?this.buildHorizontalSVG():this.buildVerticalSVG();e.innerHTML=t}buildVerticalSVG(){const e=this.cachedData,t=e.length;if(0===t)return"";const a=50*t+4*(t-1),n=340,i=e[0].value||1;let l=`<svg class="funnel__svg" viewBox="0 0 400 ${a}" preserveAspectRatio="xMidYMid meet" role="img" aria-label="Funnel chart">`;for(let a=0;a<t;a++){const t=e[a],o=t.value/i,r=0===a?n:85+e[a-1].value/i*255,c=85+255*o,h=54*a,u=200,d=u-r/2,g=u+r/2,m=u-c/2,p=u+c/2,f=s(this.getColor(a,t)),v=this.animation?` style="animation-delay:${100*a}ms"`:"",b=`M ${d} ${h} L ${g} ${h} L ${p} ${h+50} L ${m} ${h+50} Z`,y=h+25;if(l+=`<g class="funnel__stage" data-index="${a}" tabindex="0" role="button" aria-label="${s(`${t.label}: ${t.value} (${this.getPercentage(a)})`)}">`,l+=`<path class="funnel__stage-shape" d="${b}" fill="${f}"${v}/>`,this.showLabels){l+=`<text class="funnel__label" x="390" y="${this.showValues||this.showPercentages?y-6:y}" text-anchor="end" dominant-baseline="middle">${s(t.label)}</text>`}if(this.showValues){l+=`<text class="funnel__value" x="390" y="${this.showLabels?y+8:y}" text-anchor="end" dominant-baseline="middle">${s(this.formatValue(t.value))}</text>`}if(this.showPercentages&&a>0){l+=`<text class="funnel__percentage" x="390" y="${this.showLabels?y+20:this.showValues?y+12:y}" text-anchor="end" dominant-baseline="middle">${s(this.getPercentage(a))}</text>`}l+="</g>"}return l+="</svg>",l}buildHorizontalSVG(){const e=this.cachedData,t=e.length;if(0===t)return"";const a=(500-4*(t-1))/t,n=175,i=43.75,l=e[0].value||1;let o='<svg class="funnel__svg" viewBox="0 0 500 250" preserveAspectRatio="xMidYMid meet" role="img" aria-label="Funnel chart">';for(let r=0;r<t;r++){const t=e[r],c=t.value/l,h=0===r?n:i+e[r-1].value/l*131.25,u=i+131.25*c,d=r*(a+4),g=112.5,m=s(this.getColor(r,t)),p=this.animation?` style="animation-delay:${100*r}ms"`:"",f=`M ${d} ${g-h/2} L ${d+a} ${g-u/2} L ${d+a} ${g+u/2} L ${d} ${g+h/2} Z`,v=d+a/2,b=216;o+=`<g class="funnel__stage" data-index="${r}" tabindex="0" role="button" aria-label="${s(`${t.label}: ${t.value} (${this.getPercentage(r)})`)}">`,o+=`<path class="funnel__stage-shape" d="${f}" fill="${m}"${p}/>`,this.showLabels&&(o+=`<text class="funnel__label" x="${v}" y="${b}" text-anchor="middle">${s(t.label)}</text>`),this.showValues&&(o+=`<text class="funnel__value" x="${v}" y="${b+16}" text-anchor="middle">${s(this.formatValue(t.value))}</text>`),this.showPercentages&&r>0&&(o+=`<text class="funnel__percentage" x="${v}" y="${b+30}" text-anchor="middle">${s(this.getPercentage(r))}</text>`),o+="</g>"}return o+="</svg>",o}setStages(e){this.data=[...e]}exportImage(e="png"){const t=this.shadowRoot?.querySelector(".funnel__svg");if(!t)return"";if("svg"===e){const e=new XMLSerializer;return"data:image/svg+xml;charset=utf-8,"+encodeURIComponent(e.serializeToString(t))}const a=(new XMLSerializer).serializeToString(t),n=document.createElement("canvas"),i=t.getBoundingClientRect();n.width=2*i.width,n.height=2*i.height;const s=n.getContext("2d"),l=new Image;return l.src="data:image/svg+xml;charset=utf-8,"+encodeURIComponent(a),s.drawImage(l,0,0,n.width,n.height),n.toDataURL("image/png")}renderContent(){return t.html`
8
+ <div class="funnel"
9
+ @click=${e=>this.handleSvgClick(e)}
10
+ @mousemove=${e=>this.handleSvgMouseMove(e)}
11
+ @mouseleave=${()=>this.handleSvgMouseLeave()}
12
+ @keydown=${e=>this.handleSvgKeyDown(e)}>
13
+ <div class="funnel__chart"></div>
14
+ <div class="funnel__tooltip" style="display:none;transform:translate(-50%,-100%)">
15
+ <div class="funnel__tooltip-label"></div>
16
+ <div class="funnel__tooltip-value"></div>
17
+ </div>
18
+ </div>
19
+ `}componentStyles(){return t.css`${":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%}.funnel{position:relative;width:100%;min-height:12.5rem}.funnel__svg{display:block;width:100%;height:auto}.funnel__stage{cursor:pointer;transition:opacity var(--snice-transition-fast, 150ms) ease}.funnel__stage:hover{opacity:.85}.funnel__stage:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.funnel__label{fill:var(--snice-color-text,rgb(23 23 23));font-size:.875rem;font-weight:var(--snice-font-weight-medium,500);pointer-events:none}.funnel__value{fill:var(--snice-color-text-secondary,rgb(82 82 82));font-size:.75rem;font-weight:var(--snice-font-weight-medium,500);pointer-events:none}.funnel__percentage{fill:var(--snice-color-text-tertiary,rgb(115 115 115));font-size:.6875rem;pointer-events:none}.funnel__tooltip{position:fixed;z-index:9999;padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-sm,.75rem);background:var(--snice-color-text,rgb(23 23 23));color:var(--snice-color-text-inverse,rgb(250 250 250));border-radius:4px;font-size:.75rem;line-height:var(--snice-line-height-normal, 1.5);white-space:nowrap;pointer-events:none;box-shadow:var(--snice-shadow-md,0 4px 6px -1px rgb(0 0 0 / .1),0 2px 4px -2px rgb(0 0 0 / .1))}.funnel__tooltip-label{font-weight:var(--snice-font-weight-semibold,600)}.funnel__tooltip-value{margin-top:var(--snice-spacing-3xs,.125rem)}:host([animation]) .funnel__stage-shape{animation:.6s ease-out both funnel-grow}@keyframes funnel-grow{from{opacity:0;transform:scaleY(.3)}to{opacity:1;transform:scaleY(1)}}:host([orientation=horizontal]) .funnel{min-height:auto}:host([orientation=horizontal]) .funnel__label,:host([orientation=horizontal]) .funnel__percentage,:host([orientation=horizontal]) .funnel__value{text-anchor:middle}"}`}},l})();return e.SniceFunnel=l,e}({},Snice);
20
+ //# sourceMappingURL=snice-funnel.min.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snice-funnel.min.js","sources":["../../../node_modules/tslib/tslib.es6.mjs","../../components/funnel/snice-funnel.js"],"sourcesContent":["/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r, s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n else s |= 1;\n }\n catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n });\n }\n return path;\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension,\n};\n","import { __runInitializers, __esDecorate } from 'tslib';\nimport { element, property, query, dispatch, watch, ready, render, styles, html, css } from 'snice';\n\nvar 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%}.funnel{position:relative;width:100%;min-height:12.5rem}.funnel__svg{display:block;width:100%;height:auto}.funnel__stage{cursor:pointer;transition:opacity var(--snice-transition-fast, 150ms) ease}.funnel__stage:hover{opacity:.85}.funnel__stage:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.funnel__label{fill:var(--snice-color-text,rgb(23 23 23));font-size:.875rem;font-weight:var(--snice-font-weight-medium,500);pointer-events:none}.funnel__value{fill:var(--snice-color-text-secondary,rgb(82 82 82));font-size:.75rem;font-weight:var(--snice-font-weight-medium,500);pointer-events:none}.funnel__percentage{fill:var(--snice-color-text-tertiary,rgb(115 115 115));font-size:.6875rem;pointer-events:none}.funnel__tooltip{position:fixed;z-index:9999;padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-sm,.75rem);background:var(--snice-color-text,rgb(23 23 23));color:var(--snice-color-text-inverse,rgb(250 250 250));border-radius:4px;font-size:.75rem;line-height:var(--snice-line-height-normal, 1.5);white-space:nowrap;pointer-events:none;box-shadow:var(--snice-shadow-md,0 4px 6px -1px rgb(0 0 0 / .1),0 2px 4px -2px rgb(0 0 0 / .1))}.funnel__tooltip-label{font-weight:var(--snice-font-weight-semibold,600)}.funnel__tooltip-value{margin-top:var(--snice-spacing-3xs,.125rem)}:host([animation]) .funnel__stage-shape{animation:.6s ease-out both funnel-grow}@keyframes funnel-grow{from{opacity:0;transform:scaleY(.3)}to{opacity:1;transform:scaleY(1)}}:host([orientation=horizontal]) .funnel{min-height:auto}:host([orientation=horizontal]) .funnel__label,:host([orientation=horizontal]) .funnel__percentage,:host([orientation=horizontal]) .funnel__value{text-anchor:middle}\";\n\nconst DEFAULT_COLORS = [\n 'rgb(37 99 235)',\n 'rgb(59 130 246)',\n 'rgb(96 165 250)',\n 'rgb(147 197 253)',\n 'rgb(191 219 254)',\n 'rgb(219 234 254)',\n];\nfunction escapeHTML(str) {\n return str.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\"/g, '&quot;');\n}\nlet SniceFunnel = (() => {\n let _classDecorators = [element('snice-funnel')];\n let _classDescriptor;\n let _classExtraInitializers = [];\n let _classThis;\n let _classSuper = HTMLElement;\n let _instanceExtraInitializers = [];\n let _data_decorators;\n let _data_initializers = [];\n let _data_extraInitializers = [];\n let _variant_decorators;\n let _variant_initializers = [];\n let _variant_extraInitializers = [];\n let _orientation_decorators;\n let _orientation_initializers = [];\n let _orientation_extraInitializers = [];\n let _showLabels_decorators;\n let _showLabels_initializers = [];\n let _showLabels_extraInitializers = [];\n let _showValues_decorators;\n let _showValues_initializers = [];\n let _showValues_extraInitializers = [];\n let _showPercentages_decorators;\n let _showPercentages_initializers = [];\n let _showPercentages_extraInitializers = [];\n let _animation_decorators;\n let _animation_initializers = [];\n let _animation_extraInitializers = [];\n let _chartEl_decorators;\n let _chartEl_initializers = [];\n let _chartEl_extraInitializers = [];\n let _tooltipEl_decorators;\n let _tooltipEl_initializers = [];\n let _tooltipEl_extraInitializers = [];\n let _emitFunnelClick_decorators;\n let _emitFunnelHover_decorators;\n let _onDataChange_decorators;\n let _onDisplayChange_decorators;\n let _init_decorators;\n let _renderContent_decorators;\n let _componentStyles_decorators;\n (class extends _classSuper {\n static { _classThis = this; }\n constructor() {\n super(...arguments);\n this.data = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _data_initializers, []));\n this.variant = (__runInitializers(this, _data_extraInitializers), __runInitializers(this, _variant_initializers, 'default'));\n this.orientation = (__runInitializers(this, _variant_extraInitializers), __runInitializers(this, _orientation_initializers, 'vertical'));\n this.showLabels = (__runInitializers(this, _orientation_extraInitializers), __runInitializers(this, _showLabels_initializers, true));\n this.showValues = (__runInitializers(this, _showLabels_extraInitializers), __runInitializers(this, _showValues_initializers, true));\n this.showPercentages = (__runInitializers(this, _showValues_extraInitializers), __runInitializers(this, _showPercentages_initializers, true));\n this.animation = (__runInitializers(this, _showPercentages_extraInitializers), __runInitializers(this, _animation_initializers, false));\n this.chartEl = (__runInitializers(this, _animation_extraInitializers), __runInitializers(this, _chartEl_initializers, void 0));\n this.tooltipEl = (__runInitializers(this, _chartEl_extraInitializers), __runInitializers(this, _tooltipEl_initializers, void 0));\n // Cached data to avoid repeated JSON.parse from @property getter\n this.cachedData = (__runInitializers(this, _tooltipEl_extraInitializers), []);\n }\n static {\n const _metadata = typeof Symbol === \"function\" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;\n _data_decorators = [property({ type: Array, attribute: false })];\n _variant_decorators = [property()];\n _orientation_decorators = [property()];\n _showLabels_decorators = [property({ type: Boolean, attribute: 'show-labels' })];\n _showValues_decorators = [property({ type: Boolean, attribute: 'show-values' })];\n _showPercentages_decorators = [property({ type: Boolean, attribute: 'show-percentages' })];\n _animation_decorators = [property({ type: Boolean })];\n _chartEl_decorators = [query('.funnel__chart')];\n _tooltipEl_decorators = [query('.funnel__tooltip')];\n _emitFunnelClick_decorators = [dispatch('funnel-click', { bubbles: true, composed: true })];\n _emitFunnelHover_decorators = [dispatch('funnel-hover', { bubbles: true, composed: true })];\n _onDataChange_decorators = [watch('data')];\n _onDisplayChange_decorators = [watch('variant', 'orientation', 'showLabels', 'showValues', 'showPercentages', 'animation')];\n _init_decorators = [ready()];\n _renderContent_decorators = [render({ once: true })];\n _componentStyles_decorators = [styles()];\n __esDecorate(this, null, _emitFunnelClick_decorators, { kind: \"method\", name: \"emitFunnelClick\", static: false, private: false, access: { has: obj => \"emitFunnelClick\" in obj, get: obj => obj.emitFunnelClick }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _emitFunnelHover_decorators, { kind: \"method\", name: \"emitFunnelHover\", static: false, private: false, access: { has: obj => \"emitFunnelHover\" in obj, get: obj => obj.emitFunnelHover }, metadata: _metadata }, null, _instanceExtraInitializers);\n __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);\n __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);\n __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);\n __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);\n __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);\n __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);\n __esDecorate(null, null, _variant_decorators, { kind: \"field\", name: \"variant\", static: false, private: false, access: { has: obj => \"variant\" in obj, get: obj => obj.variant, set: (obj, value) => { obj.variant = value; } }, metadata: _metadata }, _variant_initializers, _variant_extraInitializers);\n __esDecorate(null, null, _orientation_decorators, { kind: \"field\", name: \"orientation\", static: false, private: false, access: { has: obj => \"orientation\" in obj, get: obj => obj.orientation, set: (obj, value) => { obj.orientation = value; } }, metadata: _metadata }, _orientation_initializers, _orientation_extraInitializers);\n __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);\n __esDecorate(null, null, _showValues_decorators, { kind: \"field\", name: \"showValues\", static: false, private: false, access: { has: obj => \"showValues\" in obj, get: obj => obj.showValues, set: (obj, value) => { obj.showValues = value; } }, metadata: _metadata }, _showValues_initializers, _showValues_extraInitializers);\n __esDecorate(null, null, _showPercentages_decorators, { kind: \"field\", name: \"showPercentages\", static: false, private: false, access: { has: obj => \"showPercentages\" in obj, get: obj => obj.showPercentages, set: (obj, value) => { obj.showPercentages = value; } }, metadata: _metadata }, _showPercentages_initializers, _showPercentages_extraInitializers);\n __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);\n __esDecorate(null, null, _chartEl_decorators, { kind: \"field\", name: \"chartEl\", static: false, private: false, access: { has: obj => \"chartEl\" in obj, get: obj => obj.chartEl, set: (obj, value) => { obj.chartEl = value; } }, metadata: _metadata }, _chartEl_initializers, _chartEl_extraInitializers);\n __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);\n __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: \"class\", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);\n _classThis = _classDescriptor.value;\n if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });\n __runInitializers(_classThis, _classExtraInitializers);\n }\n emitFunnelClick(stage, index) {\n return { stage, index };\n }\n emitFunnelHover(stage, index) {\n return { stage, index };\n }\n onDataChange(_old, newData) {\n this.cachedData = newData || [];\n this.rebuildChart();\n }\n onDisplayChange() {\n this.rebuildChart();\n }\n init() {\n if (this.cachedData.length === 0 && this.data.length > 0) {\n this.cachedData = this.data;\n }\n this.rebuildChart();\n }\n getColor(index, stage) {\n if (stage.color)\n return stage.color;\n if (this.variant === 'gradient' && this.cachedData.length > 0) {\n const opacity = 1 - (index / this.cachedData.length) * 0.6;\n return `rgba(37, 99, 235, ${opacity})`;\n }\n return DEFAULT_COLORS[index % DEFAULT_COLORS.length];\n }\n getPercentage(index) {\n if (this.cachedData.length === 0)\n return '0%';\n const firstValue = this.cachedData[0].value;\n if (firstValue === 0)\n return '0%';\n return `${Math.round((this.cachedData[index].value / firstValue) * 100)}%`;\n }\n formatValue(value) {\n if (value >= 1_000_000)\n return `${(value / 1_000_000).toFixed(1)}M`;\n if (value >= 1_000)\n return `${(value / 1_000).toFixed(1)}K`;\n return String(value);\n }\n handleSvgClick(e) {\n const target = e.target;\n const indexStr = target.dataset?.index ?? target.closest('[data-index]')?.getAttribute('data-index');\n if (indexStr === null || indexStr === undefined)\n return;\n const index = parseInt(indexStr, 10);\n const stage = this.cachedData[index];\n if (!stage)\n return;\n this.emitFunnelClick(stage, index);\n }\n handleSvgMouseMove(e) {\n const target = e.target;\n const el = target.dataset?.index !== undefined ? target : target.closest('[data-index]');\n const tooltip = this.tooltipEl;\n if (!el) {\n if (tooltip)\n tooltip.style.display = 'none';\n return;\n }\n const index = parseInt(el.dataset.index, 10);\n const stage = this.cachedData[index];\n if (!stage || !tooltip)\n return;\n const rect = el.getBoundingClientRect();\n tooltip.querySelector('.funnel__tooltip-label').textContent = stage.label;\n tooltip.querySelector('.funnel__tooltip-value').textContent = `${this.formatValue(stage.value)} (${this.getPercentage(index)})`;\n tooltip.style.left = `${rect.left + rect.width / 2}px`;\n tooltip.style.top = `${rect.top - 8}px`;\n tooltip.style.display = '';\n this.emitFunnelHover(stage, index);\n }\n handleSvgMouseLeave() {\n const tooltip = this.tooltipEl;\n if (tooltip)\n tooltip.style.display = 'none';\n }\n handleSvgKeyDown(e) {\n if (e.key !== 'Enter' && e.key !== ' ')\n return;\n const target = e.target;\n const indexStr = target.dataset?.index;\n if (indexStr === undefined)\n return;\n e.preventDefault();\n const index = parseInt(indexStr, 10);\n const stage = this.cachedData[index];\n if (!stage)\n return;\n this.emitFunnelClick(stage, index);\n }\n rebuildChart() {\n const chart = this.chartEl;\n if (!chart) {\n requestAnimationFrame(() => this.rebuildChart());\n return;\n }\n const svgString = this.orientation === 'horizontal'\n ? this.buildHorizontalSVG()\n : this.buildVerticalSVG();\n chart.innerHTML = svgString;\n }\n buildVerticalSVG() {\n const data = this.cachedData;\n const count = data.length;\n if (count === 0)\n return '';\n const svgWidth = 400;\n const stageHeight = 50;\n const gap = 4;\n const svgHeight = count * stageHeight + (count - 1) * gap;\n const maxWidth = svgWidth * 0.85;\n const minWidth = maxWidth * 0.25;\n const labelX = svgWidth - 10;\n const firstValue = data[0].value || 1;\n let svg = `<svg class=\"funnel__svg\" viewBox=\"0 0 ${svgWidth} ${svgHeight}\" preserveAspectRatio=\"xMidYMid meet\" role=\"img\" aria-label=\"Funnel chart\">`;\n for (let i = 0; i < count; i++) {\n const stage = data[i];\n const ratio = stage.value / firstValue;\n const topWidth = i === 0 ? maxWidth : minWidth + (maxWidth - minWidth) * (data[i - 1].value / firstValue);\n const bottomWidth = minWidth + (maxWidth - minWidth) * ratio;\n const y = i * (stageHeight + gap);\n const cx = svgWidth / 2;\n const topLeft = cx - topWidth / 2;\n const topRight = cx + topWidth / 2;\n const bottomLeft = cx - bottomWidth / 2;\n const bottomRight = cx + bottomWidth / 2;\n const color = escapeHTML(this.getColor(i, stage));\n const delay = this.animation ? ` style=\"animation-delay:${i * 100}ms\"` : '';\n const path = `M ${topLeft} ${y} L ${topRight} ${y} L ${bottomRight} ${y + stageHeight} L ${bottomLeft} ${y + stageHeight} Z`;\n const textY = y + stageHeight / 2;\n const ariaLabel = escapeHTML(`${stage.label}: ${stage.value} (${this.getPercentage(i)})`);\n svg += `<g class=\"funnel__stage\" data-index=\"${i}\" tabindex=\"0\" role=\"button\" aria-label=\"${ariaLabel}\">`;\n svg += `<path class=\"funnel__stage-shape\" d=\"${path}\" fill=\"${color}\"${delay}/>`;\n if (this.showLabels) {\n const labelY = (this.showValues || this.showPercentages) ? textY - 6 : textY;\n svg += `<text class=\"funnel__label\" x=\"${labelX}\" y=\"${labelY}\" text-anchor=\"end\" dominant-baseline=\"middle\">${escapeHTML(stage.label)}</text>`;\n }\n if (this.showValues) {\n const valY = this.showLabels ? textY + 8 : textY;\n svg += `<text class=\"funnel__value\" x=\"${labelX}\" y=\"${valY}\" text-anchor=\"end\" dominant-baseline=\"middle\">${escapeHTML(this.formatValue(stage.value))}</text>`;\n }\n if (this.showPercentages && i > 0) {\n const pctY = this.showLabels ? textY + 20 : (this.showValues ? textY + 12 : textY);\n svg += `<text class=\"funnel__percentage\" x=\"${labelX}\" y=\"${pctY}\" text-anchor=\"end\" dominant-baseline=\"middle\">${escapeHTML(this.getPercentage(i))}</text>`;\n }\n svg += `</g>`;\n }\n svg += `</svg>`;\n return svg;\n }\n buildHorizontalSVG() {\n const data = this.cachedData;\n const count = data.length;\n if (count === 0)\n return '';\n const svgWidth = 500;\n const svgHeight = 250;\n const stageWidth = (svgWidth - (count - 1) * 4) / count;\n const maxHeight = svgHeight * 0.7;\n const minHeight = maxHeight * 0.25;\n const firstValue = data[0].value || 1;\n let svg = `<svg class=\"funnel__svg\" viewBox=\"0 0 ${svgWidth} ${svgHeight}\" preserveAspectRatio=\"xMidYMid meet\" role=\"img\" aria-label=\"Funnel chart\">`;\n for (let i = 0; i < count; i++) {\n const stage = data[i];\n const ratio = stage.value / firstValue;\n const leftHeight = i === 0 ? maxHeight : minHeight + (maxHeight - minHeight) * (data[i - 1].value / firstValue);\n const rightHeight = minHeight + (maxHeight - minHeight) * ratio;\n const x = i * (stageWidth + 4);\n const cy = svgHeight * 0.45;\n const color = escapeHTML(this.getColor(i, stage));\n const delay = this.animation ? ` style=\"animation-delay:${i * 100}ms\"` : '';\n const topLeft = cy - leftHeight / 2;\n const bottomLeft = cy + leftHeight / 2;\n const topRight = cy - rightHeight / 2;\n const bottomRight = cy + rightHeight / 2;\n const path = `M ${x} ${topLeft} L ${x + stageWidth} ${topRight} L ${x + stageWidth} ${bottomRight} L ${x} ${bottomLeft} Z`;\n const textX = x + stageWidth / 2;\n const textY = svgHeight * 0.45 + maxHeight / 2 + 16;\n const ariaLabel = escapeHTML(`${stage.label}: ${stage.value} (${this.getPercentage(i)})`);\n svg += `<g class=\"funnel__stage\" data-index=\"${i}\" tabindex=\"0\" role=\"button\" aria-label=\"${ariaLabel}\">`;\n svg += `<path class=\"funnel__stage-shape\" d=\"${path}\" fill=\"${color}\"${delay}/>`;\n if (this.showLabels) {\n svg += `<text class=\"funnel__label\" x=\"${textX}\" y=\"${textY}\" text-anchor=\"middle\">${escapeHTML(stage.label)}</text>`;\n }\n if (this.showValues) {\n svg += `<text class=\"funnel__value\" x=\"${textX}\" y=\"${textY + 16}\" text-anchor=\"middle\">${escapeHTML(this.formatValue(stage.value))}</text>`;\n }\n if (this.showPercentages && i > 0) {\n svg += `<text class=\"funnel__percentage\" x=\"${textX}\" y=\"${textY + 30}\" text-anchor=\"middle\">${escapeHTML(this.getPercentage(i))}</text>`;\n }\n svg += `</g>`;\n }\n svg += `</svg>`;\n return svg;\n }\n setStages(stages) {\n this.data = [...stages];\n }\n exportImage(format = 'png') {\n const svgEl = this.shadowRoot?.querySelector('.funnel__svg');\n if (!svgEl)\n return '';\n if (format === 'svg') {\n const serializer = new XMLSerializer();\n return 'data:image/svg+xml;charset=utf-8,' + encodeURIComponent(serializer.serializeToString(svgEl));\n }\n const svgData = new XMLSerializer().serializeToString(svgEl);\n const canvas = document.createElement('canvas');\n const bbox = svgEl.getBoundingClientRect();\n canvas.width = bbox.width * 2;\n canvas.height = bbox.height * 2;\n const ctx = canvas.getContext('2d');\n const img = new Image();\n img.src = 'data:image/svg+xml;charset=utf-8,' + encodeURIComponent(svgData);\n ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\n return canvas.toDataURL('image/png');\n }\n renderContent() {\n return html /*html*/ `\n <div class=\"funnel\"\n @click=${(e) => this.handleSvgClick(e)}\n @mousemove=${(e) => this.handleSvgMouseMove(e)}\n @mouseleave=${() => this.handleSvgMouseLeave()}\n @keydown=${(e) => this.handleSvgKeyDown(e)}>\n <div class=\"funnel__chart\"></div>\n <div class=\"funnel__tooltip\" style=\"display:none;transform:translate(-50%,-100%)\">\n <div class=\"funnel__tooltip-label\"></div>\n <div class=\"funnel__tooltip-value\"></div>\n </div>\n </div>\n `;\n }\n componentStyles() {\n return css /*css*/ `${cssContent}`;\n }\n });\n return _classThis;\n})();\n\nexport { SniceFunnel };\n//# sourceMappingURL=snice-funnel.js.map\n"],"names":["__esDecorate","ctor","descriptorIn","decorators","contextIn","initializers","extraInitializers","accept","f","TypeError","_","kind","key","target","prototype","descriptor","Object","getOwnPropertyDescriptor","name","done","i","length","context","p","access","addInitializer","push","result","get","set","init","unshift","defineProperty","__runInitializers","thisArg","value","useValue","arguments","call","SuppressedError","DEFAULT_COLORS","escapeHTML","str","replace","SniceFunnel","_classDescriptor","_classThis","_data_decorators","_variant_decorators","_orientation_decorators","_showLabels_decorators","_showValues_decorators","_showPercentages_decorators","_animation_decorators","_chartEl_decorators","_tooltipEl_decorators","_emitFunnelClick_decorators","_emitFunnelHover_decorators","_onDataChange_decorators","_onDisplayChange_decorators","_init_decorators","_renderContent_decorators","_componentStyles_decorators","_classDecorators","element","_classExtraInitializers","_classSuper","HTMLElement","_instanceExtraInitializers","_data_initializers","_data_extraInitializers","_variant_initializers","_variant_extraInitializers","_orientation_initializers","_orientation_extraInitializers","_showLabels_initializers","_showLabels_extraInitializers","_showValues_initializers","_showValues_extraInitializers","_showPercentages_initializers","_showPercentages_extraInitializers","_animation_initializers","_animation_extraInitializers","_chartEl_initializers","_chartEl_extraInitializers","_tooltipEl_initializers","_tooltipEl_extraInitializers","this","constructor","super","data","variant","orientation","showLabels","showValues","showPercentages","animation","chartEl","tooltipEl","cachedData","_metadata","Symbol","metadata","create","property","type","Array","attribute","Boolean","query","dispatch","bubbles","composed","watch","ready","render","once","styles","static","private","has","obj","emitFunnelClick","emitFunnelHover","onDataChange","onDisplayChange","renderContent","componentStyles","enumerable","configurable","writable","stage","index","_old","newData","rebuildChart","getColor","color","getPercentage","firstValue","Math","round","formatValue","toFixed","String","handleSvgClick","e","indexStr","dataset","closest","getAttribute","parseInt","handleSvgMouseMove","el","undefined","tooltip","style","display","rect","getBoundingClientRect","querySelector","textContent","label","left","width","top","handleSvgMouseLeave","handleSvgKeyDown","preventDefault","chart","requestAnimationFrame","svgString","buildHorizontalSVG","buildVerticalSVG","innerHTML","count","svgHeight","maxWidth","svgWidth","svg","ratio","topWidth","bottomWidth","y","cx","topLeft","topRight","bottomLeft","bottomRight","delay","path","textY","stageHeight","stageWidth","maxHeight","minHeight","leftHeight","rightHeight","x","cy","textX","setStages","stages","exportImage","format","svgEl","shadowRoot","serializer","XMLSerializer","encodeURIComponent","serializeToString","svgData","canvas","document","createElement","bbox","height","ctx","getContext","img","Image","src","drawImage","toDataURL","html","css"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -11,8 +11,8 @@ CDN build of the Snice layout component. Requires the Snice runtime (`snice-runt
11
11
  ```
12
12
 
13
13
  ## Size
14
- - Minified: 13.3 KB
15
- - Gzipped: 4.0 KB
14
+ - Minified: 13.7 KB
15
+ - Gzipped: 4.2 KB
16
16
 
17
17
  ## Theme
18
18
  For proper styling, link the Snice theme CSS:
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.7.0
2
+ * snice v4.8.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
@@ -64,7 +64,7 @@ var SniceLayout = (function (exports, snice) {
64
64
  return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
65
65
  };
66
66
 
67
- var cssContent$1 = ":host{display:block;font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif);contain:layout style paint}.nav{display:flex;gap:var(--snice-spacing-md,1rem)}.nav--horizontal{flex-direction:row;align-items:center}.nav--vertical{flex-direction:column;align-items:stretch}.nav__item{position:relative}.nav__link{display:flex;align-items:center;gap:var(--snice-spacing-sm,.75rem);padding:var(--snice-spacing-sm,.75rem) var(--snice-spacing-md,1rem);color:var(--snice-color-text-secondary,rgb(107 114 128));text-decoration:none;border-radius:var(--snice-border-radius-md,.375rem);font-size:var(--snice-font-size-md, 1rem);font-weight:var(--snice-font-weight-medium,500);transition:background-color var(--snice-transition-fast, 150ms) ease,color var(--snice-transition-fast, 150ms) ease}.nav__link:hover{background-color:var(--snice-color-background-secondary,rgb(243 244 246));color:var(--snice-color-text,rgb(23 23 23))}.nav__link:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.nav__link--active{background-color:var(--snice-color-background-tertiary,rgb(243 244 246));color:var(--snice-color-primary,rgb(37 99 235))}.nav__link--active:hover{background-color:var(--snice-color-background-secondary,rgb(249 250 251));color:var(--snice-color-primary-hover,rgb(29 78 216))}.nav__icon{display:inline-flex;align-items:center;justify-content:center;font-size:var(--snice-font-size-lg, 1.125rem)}.nav__label{white-space:nowrap}.nav--hierarchical{flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--hierarchical .nav__group{display:flex;flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--hierarchical .nav__submenu{list-style:none;margin:0;padding:0 0 0 var(--snice-spacing-xl,2rem);display:flex;flex-direction:column;gap:var(--snice-spacing-2xs,.25rem)}.nav--hierarchical .nav__submenu .nav__item{margin:0}.nav--hierarchical .nav__submenu .nav__link{font-size:var(--snice-font-size-sm, .875rem);padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-md,1rem)}.nav--grouped{flex-direction:column;gap:var(--snice-spacing-lg,1.5rem)}.nav--grouped .nav__group{display:flex;flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--grouped .nav__group-label{font-size:var(--snice-font-size-xs, .75rem);font-weight:var(--snice-font-weight-semibold,600);color:var(--snice-color-text-tertiary,rgb(115 115 115));text-transform:uppercase;letter-spacing:.05em;padding:0 var(--snice-spacing-md,1rem);margin-bottom:var(--snice-spacing-2xs,.25rem)}.nav--vertical .nav__item,.nav--vertical .nav__link{width:100%}@media (max-width:768px){.nav--horizontal{flex-wrap:wrap}.nav__label{font-size:var(--snice-font-size-sm, .875rem)}}";
67
+ var cssContent$1 = ":host{display:block;font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif);contain:layout style paint}.nav{display:flex;gap:var(--snice-spacing-md,1rem)}.nav--horizontal{flex-direction:row;align-items:center}.nav--vertical{flex-direction:column;align-items:stretch}.nav__item{position:relative}.nav__link{display:flex;align-items:center;gap:var(--snice-spacing-sm,.75rem);padding:var(--snice-spacing-sm,.75rem) var(--snice-spacing-md,1rem);color:var(--snice-color-text-secondary,rgb(107 114 128));text-decoration:none;border-radius:var(--snice-border-radius-md,.375rem);font-size:var(--snice-font-size-md, 1rem);font-weight:var(--snice-font-weight-medium,500);transition:background-color var(--snice-transition-fast, 150ms) ease,color var(--snice-transition-fast, 150ms) ease}.nav__link:hover{background-color:var(--snice-color-background-secondary,rgb(243 244 246));color:var(--snice-color-text,rgb(23 23 23))}.nav__link:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.nav__link--active{background-color:var(--snice-color-background-tertiary,rgb(243 244 246));color:var(--snice-color-primary,rgb(37 99 235))}.nav__link--active:hover{background-color:var(--snice-color-background-secondary,rgb(249 250 251));color:var(--snice-color-primary-hover,rgb(29 78 216))}.nav__icon{display:inline-flex;align-items:center;justify-content:center;font-size:var(--snice-font-size-lg, 1.125rem)}.nav__icon img{width:1.25em;height:1.25em;object-fit:contain}.nav__label{white-space:nowrap}.nav--hierarchical{flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--hierarchical .nav__group{display:flex;flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--hierarchical .nav__submenu{list-style:none;margin:0;padding:0 0 0 var(--snice-spacing-xl,2rem);display:flex;flex-direction:column;gap:var(--snice-spacing-2xs,.25rem)}.nav--hierarchical .nav__submenu .nav__item{margin:0}.nav--hierarchical .nav__submenu .nav__link{font-size:var(--snice-font-size-sm, .875rem);padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-md,1rem)}.nav--grouped{flex-direction:column;gap:var(--snice-spacing-lg,1.5rem)}.nav--grouped .nav__group{display:flex;flex-direction:column;gap:var(--snice-spacing-xs,.5rem)}.nav--grouped .nav__group-label{font-size:var(--snice-font-size-xs, .75rem);font-weight:var(--snice-font-weight-semibold,600);color:var(--snice-color-text-tertiary,rgb(115 115 115));text-transform:uppercase;letter-spacing:.05em;padding:0 var(--snice-spacing-md,1rem);margin-bottom:var(--snice-spacing-2xs,.25rem)}.nav--vertical .nav__item,.nav--vertical .nav__link{width:100%}@media (max-width:768px){.nav--horizontal{flex-wrap:wrap}.nav__label{font-size:var(--snice-font-size-sm, .875rem)}}";
68
68
 
69
69
  (() => {
70
70
  let _classDecorators = [snice.element('snice-nav')];
@@ -269,10 +269,27 @@ var SniceLayout = (function (exports, snice) {
269
269
  });
270
270
  }
271
271
  if (placard.icon) {
272
- const iconSpan = document.createElement('span');
273
- iconSpan.className = 'nav__icon';
274
- iconSpan.textContent = placard.icon;
275
- a.appendChild(iconSpan);
272
+ const icon = placard.icon;
273
+ // Match renderIcon() logic from components/utils.ts
274
+ const isImg = icon.startsWith('img://') ||
275
+ /^(https?:\/\/|\/|\.\/|\.\.\/|data:)/.test(icon) ||
276
+ /^[^:]*\w\.(svg|png|jpe?g|jfif|pjp|gif|webp|avif|jxl|ico|cur|bmp|tiff?|heic|heif|apng)$/i.test(icon);
277
+ const forceText = icon.startsWith('text://');
278
+ if (isImg && !forceText) {
279
+ const img = document.createElement('img');
280
+ img.className = 'nav__icon';
281
+ img.src = icon.startsWith('img://') ? icon.slice(6) : icon;
282
+ img.alt = '';
283
+ img.setAttribute('part', 'icon');
284
+ a.appendChild(img);
285
+ }
286
+ else {
287
+ const iconSpan = document.createElement('span');
288
+ iconSpan.className = 'nav__icon';
289
+ iconSpan.setAttribute('part', 'icon');
290
+ iconSpan.textContent = forceText ? icon.slice(7) : icon;
291
+ a.appendChild(iconSpan);
292
+ }
276
293
  }
277
294
  const labelSpan = document.createElement('span');
278
295
  labelSpan.className = 'nav__label';