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.
- package/adapters/react/camera-annotate.d.ts +27 -0
- package/adapters/react/camera-annotate.d.ts.map +1 -0
- package/adapters/react/camera-annotate.js +24 -0
- package/adapters/react/camera-annotate.js.map +1 -0
- package/adapters/react/camera-annotate.tsx +35 -0
- package/adapters/react/candlestick.d.ts +34 -0
- package/adapters/react/candlestick.d.ts.map +1 -0
- package/adapters/react/candlestick.js +24 -0
- package/adapters/react/candlestick.js.map +1 -0
- package/adapters/react/candlestick.tsx +42 -0
- package/adapters/react/components.d.ts +14 -0
- package/adapters/react/components.d.ts.map +1 -1
- package/adapters/react/components.js +7 -0
- package/adapters/react/components.js.map +1 -1
- package/adapters/react/components.ts +14 -0
- package/adapters/react/funnel.d.ts +31 -0
- package/adapters/react/funnel.d.ts.map +1 -0
- package/adapters/react/funnel.js +24 -0
- package/adapters/react/funnel.js.map +1 -0
- package/adapters/react/funnel.tsx +39 -0
- package/adapters/react/network-graph.d.ts +32 -0
- package/adapters/react/network-graph.d.ts.map +1 -0
- package/adapters/react/network-graph.js +24 -0
- package/adapters/react/network-graph.js.map +1 -0
- package/adapters/react/network-graph.tsx +40 -0
- package/adapters/react/sankey.d.ts +31 -0
- package/adapters/react/sankey.d.ts.map +1 -0
- package/adapters/react/sankey.js +24 -0
- package/adapters/react/sankey.js.map +1 -0
- package/adapters/react/sankey.tsx +39 -0
- package/adapters/react/time-range-picker.d.ts +33 -0
- package/adapters/react/time-range-picker.d.ts.map +1 -0
- package/adapters/react/time-range-picker.js +24 -0
- package/adapters/react/time-range-picker.js.map +1 -0
- package/adapters/react/time-range-picker.tsx +41 -0
- package/adapters/react/treemap.d.ts +30 -0
- package/adapters/react/treemap.d.ts.map +1 -0
- package/adapters/react/treemap.js +24 -0
- package/adapters/react/treemap.js.map +1 -0
- package/adapters/react/treemap.tsx +38 -0
- package/adapters/react/virtual-scroller.d.ts +1 -0
- package/adapters/react/virtual-scroller.d.ts.map +1 -1
- package/adapters/react/virtual-scroller.js +1 -1
- package/adapters/react/virtual-scroller.js.map +1 -1
- package/adapters/react/virtual-scroller.tsx +2 -1
- package/dist/cdn/accordion/snice-accordion.js +1 -1
- package/dist/cdn/accordion/snice-accordion.min.js +1 -1
- package/dist/cdn/alert/snice-alert.js +1 -1
- package/dist/cdn/alert/snice-alert.min.js +1 -1
- package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
- package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
- package/dist/cdn/avatar/snice-avatar.js +1 -1
- package/dist/cdn/avatar/snice-avatar.min.js +1 -1
- package/dist/cdn/badge/snice-badge.js +1 -1
- package/dist/cdn/badge/snice-badge.min.js +1 -1
- package/dist/cdn/banner/snice-banner.js +1 -1
- package/dist/cdn/banner/snice-banner.min.js +1 -1
- package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +2 -2
- package/dist/cdn/breadcrumbs/snice-breadcrumbs.js.map +1 -1
- package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +13 -13
- package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js.map +1 -1
- package/dist/cdn/button/snice-button.js +1 -1
- package/dist/cdn/button/snice-button.min.js +1 -1
- package/dist/cdn/calendar/snice-calendar.js +1 -1
- package/dist/cdn/calendar/snice-calendar.min.js +1 -1
- package/dist/cdn/camera/snice-camera.js +1 -1
- package/dist/cdn/camera/snice-camera.min.js +1 -1
- package/dist/cdn/camera-annotate/README.md +27 -0
- package/dist/cdn/camera-annotate/snice-camera-annotate.js +730 -0
- package/dist/cdn/camera-annotate/snice-camera-annotate.js.map +1 -0
- package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +144 -0
- package/dist/cdn/camera-annotate/snice-camera-annotate.min.js.map +1 -0
- package/dist/cdn/candlestick/README.md +27 -0
- package/dist/cdn/candlestick/snice-candlestick.js +717 -0
- package/dist/cdn/candlestick/snice-candlestick.js.map +1 -0
- package/dist/cdn/candlestick/snice-candlestick.min.js +22 -0
- package/dist/cdn/candlestick/snice-candlestick.min.js.map +1 -0
- package/dist/cdn/card/snice-card.js +1 -1
- package/dist/cdn/card/snice-card.min.js +1 -1
- package/dist/cdn/carousel/snice-carousel.js +1 -1
- package/dist/cdn/carousel/snice-carousel.min.js +1 -1
- package/dist/cdn/chart/snice-chart.js +1 -1
- package/dist/cdn/chart/snice-chart.min.js +1 -1
- package/dist/cdn/chat/snice-chat.js +1 -1
- package/dist/cdn/chat/snice-chat.min.js +1 -1
- package/dist/cdn/checkbox/snice-checkbox.js +1 -1
- package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
- package/dist/cdn/chip/snice-chip.js +1 -1
- package/dist/cdn/chip/snice-chip.min.js +1 -1
- package/dist/cdn/code-block/snice-code-block.js +1 -1
- package/dist/cdn/code-block/snice-code-block.min.js +1 -1
- package/dist/cdn/color-display/snice-color-display.js +1 -1
- package/dist/cdn/color-display/snice-color-display.min.js +1 -1
- package/dist/cdn/color-picker/snice-color-picker.js +1 -1
- package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
- package/dist/cdn/command-palette/snice-command-palette.js +1 -1
- package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
- package/dist/cdn/date-picker/snice-date-picker.js +1 -1
- package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
- package/dist/cdn/divider/snice-divider.js +1 -1
- package/dist/cdn/divider/snice-divider.min.js +1 -1
- package/dist/cdn/doc/snice-doc.js +1 -1
- package/dist/cdn/doc/snice-doc.min.js +1 -1
- package/dist/cdn/draw/snice-draw.js +1 -1
- package/dist/cdn/draw/snice-draw.min.js +1 -1
- package/dist/cdn/drawer/snice-drawer.js +1 -1
- package/dist/cdn/drawer/snice-drawer.min.js +1 -1
- package/dist/cdn/empty-state/snice-empty-state.js +1 -1
- package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
- package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
- package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
- package/dist/cdn/file-upload/snice-file-upload.js +1 -1
- package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
- package/dist/cdn/funnel/README.md +27 -0
- package/dist/cdn/funnel/snice-funnel.js +424 -0
- package/dist/cdn/funnel/snice-funnel.js.map +1 -0
- package/dist/cdn/funnel/snice-funnel.min.js +20 -0
- package/dist/cdn/funnel/snice-funnel.min.js.map +1 -0
- package/dist/cdn/gauge/snice-gauge.js +1 -1
- package/dist/cdn/gauge/snice-gauge.min.js +1 -1
- package/dist/cdn/heatmap/snice-heatmap.js +1 -1
- package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
- package/dist/cdn/image/snice-image.js +1 -1
- package/dist/cdn/image/snice-image.min.js +1 -1
- package/dist/cdn/input/snice-input.js +1 -1
- package/dist/cdn/input/snice-input.min.js +1 -1
- package/dist/cdn/kanban/snice-kanban.js +1 -1
- package/dist/cdn/kanban/snice-kanban.min.js +1 -1
- package/dist/cdn/kpi/snice-kpi.js +1 -1
- package/dist/cdn/kpi/snice-kpi.min.js +1 -1
- package/dist/cdn/layout/README.md +2 -2
- package/dist/cdn/layout/snice-layout.js +23 -6
- package/dist/cdn/layout/snice-layout.js.map +1 -1
- package/dist/cdn/layout/snice-layout.min.js +2 -2
- package/dist/cdn/layout/snice-layout.min.js.map +1 -1
- package/dist/cdn/link/snice-link.js +1 -1
- package/dist/cdn/link/snice-link.min.js +1 -1
- package/dist/cdn/link-preview/snice-link-preview.js +1 -1
- package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
- package/dist/cdn/list/README.md +6 -2
- package/dist/cdn/list/snice-list.js +87 -10
- package/dist/cdn/list/snice-list.js.map +1 -1
- package/dist/cdn/list/snice-list.min.js +20 -6
- package/dist/cdn/list/snice-list.min.js.map +1 -1
- package/dist/cdn/location/snice-location.js +1 -1
- package/dist/cdn/location/snice-location.min.js +1 -1
- package/dist/cdn/login/snice-login.js +1 -1
- package/dist/cdn/login/snice-login.min.js +1 -1
- package/dist/cdn/masonry/snice-masonry.js +1 -1
- package/dist/cdn/masonry/snice-masonry.min.js +1 -1
- package/dist/cdn/menu/snice-menu.js +1 -1
- package/dist/cdn/menu/snice-menu.min.js +1 -1
- package/dist/cdn/modal/snice-modal.js +1 -1
- package/dist/cdn/modal/snice-modal.min.js +1 -1
- package/dist/cdn/music-player/snice-music-player.js +1 -1
- package/dist/cdn/music-player/snice-music-player.min.js +1 -1
- package/dist/cdn/nav/README.md +2 -2
- package/dist/cdn/nav/snice-nav.js +23 -6
- package/dist/cdn/nav/snice-nav.js.map +1 -1
- package/dist/cdn/nav/snice-nav.min.js +2 -2
- package/dist/cdn/nav/snice-nav.min.js.map +1 -1
- package/dist/cdn/network-graph/README.md +27 -0
- package/dist/cdn/network-graph/snice-network-graph.js +788 -0
- package/dist/cdn/network-graph/snice-network-graph.js.map +1 -0
- package/dist/cdn/network-graph/snice-network-graph.min.js +13 -0
- package/dist/cdn/network-graph/snice-network-graph.min.js.map +1 -0
- package/dist/cdn/pagination/README.md +2 -2
- package/dist/cdn/pagination/snice-pagination.js +13 -13
- package/dist/cdn/pagination/snice-pagination.js.map +1 -1
- package/dist/cdn/pagination/snice-pagination.min.js +14 -14
- package/dist/cdn/pagination/snice-pagination.min.js.map +1 -1
- package/dist/cdn/paint/snice-paint.js +1 -1
- package/dist/cdn/paint/snice-paint.min.js +1 -1
- package/dist/cdn/progress/snice-progress.js +1 -1
- package/dist/cdn/progress/snice-progress.min.js +1 -1
- package/dist/cdn/qr-code/snice-qr-code.js +1 -1
- package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
- package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
- package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
- package/dist/cdn/radio/snice-radio.js +1 -1
- package/dist/cdn/radio/snice-radio.min.js +1 -1
- package/dist/cdn/runtime/snice-runtime.esm.js +3 -3
- package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
- package/dist/cdn/runtime/snice-runtime.esm.min.js +3 -3
- package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
- package/dist/cdn/runtime/snice-runtime.js +3 -3
- package/dist/cdn/runtime/snice-runtime.js.map +1 -1
- package/dist/cdn/runtime/snice-runtime.min.js +3 -3
- package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
- package/dist/cdn/sankey/README.md +27 -0
- package/dist/cdn/sankey/snice-sankey.js +679 -0
- package/dist/cdn/sankey/snice-sankey.js.map +1 -0
- package/dist/cdn/sankey/snice-sankey.min.js +21 -0
- package/dist/cdn/sankey/snice-sankey.min.js.map +1 -0
- package/dist/cdn/select/snice-select.js +1 -1
- package/dist/cdn/select/snice-select.min.js +1 -1
- package/dist/cdn/skeleton/snice-skeleton.js +1 -1
- package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
- package/dist/cdn/slider/snice-slider.js +1 -1
- package/dist/cdn/slider/snice-slider.min.js +1 -1
- package/dist/cdn/sparkline/snice-sparkline.js +1 -1
- package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
- package/dist/cdn/spinner/snice-spinner.js +1 -1
- package/dist/cdn/spinner/snice-spinner.min.js +1 -1
- package/dist/cdn/split-pane/snice-split-pane.js +1 -1
- package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
- package/dist/cdn/stepper/README.md +6 -2
- package/dist/cdn/stepper/snice-stepper.js +77 -10
- package/dist/cdn/stepper/snice-stepper.js.map +1 -1
- package/dist/cdn/stepper/snice-stepper.min.js +13 -9
- package/dist/cdn/stepper/snice-stepper.min.js.map +1 -1
- package/dist/cdn/switch/snice-switch.js +1 -1
- package/dist/cdn/switch/snice-switch.min.js +1 -1
- package/dist/cdn/table/snice-table.js +1 -1
- package/dist/cdn/table/snice-table.min.js +1 -1
- package/dist/cdn/tabs/snice-tabs.js +1 -1
- package/dist/cdn/tabs/snice-tabs.min.js +1 -1
- package/dist/cdn/terminal/snice-terminal.js +1 -1
- package/dist/cdn/terminal/snice-terminal.min.js +1 -1
- package/dist/cdn/textarea/snice-textarea.js +1 -1
- package/dist/cdn/textarea/snice-textarea.min.js +1 -1
- package/dist/cdn/time-range-picker/README.md +27 -0
- package/dist/cdn/time-range-picker/snice-time-range-picker.js +635 -0
- package/dist/cdn/time-range-picker/snice-time-range-picker.js.map +1 -0
- package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +34 -0
- package/dist/cdn/time-range-picker/snice-time-range-picker.min.js.map +1 -0
- package/dist/cdn/timeline/snice-timeline.js +1 -1
- package/dist/cdn/timeline/snice-timeline.min.js +1 -1
- package/dist/cdn/timer/snice-timer.js +1 -1
- package/dist/cdn/timer/snice-timer.min.js +1 -1
- package/dist/cdn/toast/snice-toast.js +1 -1
- package/dist/cdn/toast/snice-toast.min.js +1 -1
- package/dist/cdn/tooltip/snice-tooltip.js +1 -1
- package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
- package/dist/cdn/tree/README.md +5 -1
- package/dist/cdn/tree/snice-tree.js +4 -8
- package/dist/cdn/tree/snice-tree.js.map +1 -1
- package/dist/cdn/tree/snice-tree.min.js +5 -5
- package/dist/cdn/tree/snice-tree.min.js.map +1 -1
- package/dist/cdn/treemap/README.md +27 -0
- package/dist/cdn/treemap/snice-treemap.js +522 -0
- package/dist/cdn/treemap/snice-treemap.js.map +1 -0
- package/dist/cdn/treemap/snice-treemap.min.js +14 -0
- package/dist/cdn/treemap/snice-treemap.min.js.map +1 -0
- package/dist/cdn/virtual-scroller/README.md +2 -2
- package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +47 -16
- package/dist/cdn/virtual-scroller/snice-virtual-scroller.js.map +1 -1
- package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +9 -9
- package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js.map +1 -1
- package/dist/components/breadcrumbs/snice-breadcrumbs.js +1 -1
- package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -1
- package/dist/components/camera-annotate/snice-camera-annotate.d.ts +68 -0
- package/dist/components/camera-annotate/snice-camera-annotate.js +663 -0
- package/dist/components/camera-annotate/snice-camera-annotate.js.map +1 -0
- package/dist/components/camera-annotate/snice-camera-annotate.types.d.ts +50 -0
- package/dist/components/candlestick/snice-candlestick.d.ts +78 -0
- package/dist/components/candlestick/snice-candlestick.js +650 -0
- package/dist/components/candlestick/snice-candlestick.js.map +1 -0
- package/dist/components/candlestick/snice-candlestick.types.d.ts +40 -0
- package/dist/components/funnel/snice-funnel.d.ts +37 -0
- package/dist/components/funnel/snice-funnel.js +357 -0
- package/dist/components/funnel/snice-funnel.js.map +1 -0
- package/dist/components/funnel/snice-funnel.types.d.ts +28 -0
- package/dist/components/list/snice-list-item.d.ts +2 -0
- package/dist/components/list/snice-list-item.js +20 -2
- package/dist/components/list/snice-list-item.js.map +1 -1
- package/dist/components/nav/snice-nav.js +22 -5
- package/dist/components/nav/snice-nav.js.map +1 -1
- package/dist/components/network-graph/snice-network-graph.d.ts +80 -0
- package/dist/components/network-graph/snice-network-graph.js +721 -0
- package/dist/components/network-graph/snice-network-graph.js.map +1 -0
- package/dist/components/network-graph/snice-network-graph.types.d.ts +49 -0
- package/dist/components/pagination/snice-pagination.js +12 -12
- package/dist/components/sankey/snice-sankey.d.ts +46 -0
- package/dist/components/sankey/snice-sankey.js +612 -0
- package/dist/components/sankey/snice-sankey.js.map +1 -0
- package/dist/components/sankey/snice-sankey.types.d.ts +59 -0
- package/dist/components/stepper/snice-stepper.js +9 -3
- package/dist/components/stepper/snice-stepper.js.map +1 -1
- package/dist/components/time-range-picker/snice-time-range-picker.d.ts +67 -0
- package/dist/components/time-range-picker/snice-time-range-picker.js +568 -0
- package/dist/components/time-range-picker/snice-time-range-picker.js.map +1 -0
- package/dist/components/time-range-picker/snice-time-range-picker.types.d.ts +39 -0
- package/dist/components/treemap/snice-treemap.d.ts +49 -0
- package/dist/components/treemap/snice-treemap.js +455 -0
- package/dist/components/treemap/snice-treemap.js.map +1 -0
- package/dist/components/treemap/snice-treemap.types.d.ts +42 -0
- package/dist/components/virtual-scroller/snice-virtual-scroller.d.ts +5 -0
- package/dist/components/virtual-scroller/snice-virtual-scroller.js +47 -16
- package/dist/components/virtual-scroller/snice-virtual-scroller.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.esm.js +1 -1
- package/dist/index.esm.js.map +1 -1
- package/dist/index.iife.js +1 -1
- package/dist/index.iife.js.map +1 -1
- package/dist/symbols.cjs +1 -1
- package/dist/symbols.esm.js +1 -1
- package/dist/transitions.cjs +1 -1
- package/dist/transitions.esm.js +1 -1
- package/docs/ai/components/camera-annotate.md +82 -0
- package/docs/ai/components/candlestick.md +79 -0
- package/docs/ai/components/funnel.md +86 -0
- package/docs/ai/components/network-graph.md +87 -0
- package/docs/ai/components/sankey.md +63 -0
- package/docs/ai/components/time-range-picker.md +78 -0
- package/docs/ai/components/treemap.md +78 -0
- package/docs/components/camera-annotate.md +186 -0
- package/docs/components/candlestick.md +196 -0
- package/docs/components/funnel.md +191 -0
- package/docs/components/network-graph.md +215 -0
- package/docs/components/sankey.md +201 -0
- package/docs/components/time-range-picker.md +213 -0
- package/docs/components/treemap.md +198 -0
- 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,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}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, '&').replace(/</g, '<').replace(/>/g, '>').replace(/\"/g, '"');\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.
|
|
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
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
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';
|