snice 4.9.0 → 4.10.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 (733) hide show
  1. package/adapters/react/app-tiles.d.ts +28 -0
  2. package/adapters/react/app-tiles.d.ts.map +1 -0
  3. package/adapters/react/app-tiles.js +24 -0
  4. package/adapters/react/app-tiles.js.map +1 -0
  5. package/adapters/react/app-tiles.tsx +36 -0
  6. package/adapters/react/book.d.ts +28 -0
  7. package/adapters/react/book.d.ts.map +1 -0
  8. package/adapters/react/book.js +24 -0
  9. package/adapters/react/book.js.map +1 -0
  10. package/adapters/react/book.tsx +36 -0
  11. package/adapters/react/comments.d.ts +29 -0
  12. package/adapters/react/comments.d.ts.map +1 -0
  13. package/adapters/react/comments.js +24 -0
  14. package/adapters/react/comments.js.map +1 -0
  15. package/adapters/react/comments.tsx +37 -0
  16. package/adapters/react/components.d.ts +52 -0
  17. package/adapters/react/components.d.ts.map +1 -1
  18. package/adapters/react/components.js +26 -0
  19. package/adapters/react/components.js.map +1 -1
  20. package/adapters/react/components.ts +52 -0
  21. package/adapters/react/countdown.d.ts +31 -0
  22. package/adapters/react/countdown.d.ts.map +1 -0
  23. package/adapters/react/countdown.js +24 -0
  24. package/adapters/react/countdown.js.map +1 -0
  25. package/adapters/react/countdown.tsx +39 -0
  26. package/adapters/react/cropper.d.ts +29 -0
  27. package/adapters/react/cropper.d.ts.map +1 -0
  28. package/adapters/react/cropper.js +24 -0
  29. package/adapters/react/cropper.js.map +1 -0
  30. package/adapters/react/cropper.tsx +37 -0
  31. package/adapters/react/diff.d.ts +31 -0
  32. package/adapters/react/diff.d.ts.map +1 -0
  33. package/adapters/react/diff.js +24 -0
  34. package/adapters/react/diff.js.map +1 -0
  35. package/adapters/react/diff.tsx +39 -0
  36. package/adapters/react/flip-card.d.ts +28 -0
  37. package/adapters/react/flip-card.d.ts.map +1 -0
  38. package/adapters/react/flip-card.js +24 -0
  39. package/adapters/react/flip-card.js.map +1 -0
  40. package/adapters/react/flip-card.tsx +36 -0
  41. package/adapters/react/flow.d.ts +32 -0
  42. package/adapters/react/flow.d.ts.map +1 -0
  43. package/adapters/react/flow.js +24 -0
  44. package/adapters/react/flow.js.map +1 -0
  45. package/adapters/react/flow.tsx +40 -0
  46. package/adapters/react/gantt.d.ts +27 -0
  47. package/adapters/react/gantt.d.ts.map +1 -0
  48. package/adapters/react/gantt.js +24 -0
  49. package/adapters/react/gantt.js.map +1 -0
  50. package/adapters/react/gantt.tsx +35 -0
  51. package/adapters/react/map.d.ts +30 -0
  52. package/adapters/react/map.d.ts.map +1 -0
  53. package/adapters/react/map.js +24 -0
  54. package/adapters/react/map.js.map +1 -0
  55. package/adapters/react/map.tsx +38 -0
  56. package/adapters/react/markdown.d.ts +26 -0
  57. package/adapters/react/markdown.d.ts.map +1 -0
  58. package/adapters/react/markdown.js +24 -0
  59. package/adapters/react/markdown.js.map +1 -0
  60. package/adapters/react/markdown.tsx +34 -0
  61. package/adapters/react/notification-center.d.ts +26 -0
  62. package/adapters/react/notification-center.d.ts.map +1 -0
  63. package/adapters/react/notification-center.js +24 -0
  64. package/adapters/react/notification-center.js.map +1 -0
  65. package/adapters/react/notification-center.tsx +34 -0
  66. package/adapters/react/org-chart.d.ts +28 -0
  67. package/adapters/react/org-chart.d.ts.map +1 -0
  68. package/adapters/react/org-chart.js +24 -0
  69. package/adapters/react/org-chart.js.map +1 -0
  70. package/adapters/react/org-chart.tsx +36 -0
  71. package/adapters/react/pdf-viewer.d.ts +28 -0
  72. package/adapters/react/pdf-viewer.d.ts.map +1 -0
  73. package/adapters/react/pdf-viewer.js +24 -0
  74. package/adapters/react/pdf-viewer.js.map +1 -0
  75. package/adapters/react/pdf-viewer.tsx +36 -0
  76. package/adapters/react/podcast-player.d.ts +40 -0
  77. package/adapters/react/podcast-player.d.ts.map +1 -0
  78. package/adapters/react/podcast-player.js +24 -0
  79. package/adapters/react/podcast-player.js.map +1 -0
  80. package/adapters/react/podcast-player.tsx +48 -0
  81. package/adapters/react/pricing-table.d.ts +27 -0
  82. package/adapters/react/pricing-table.d.ts.map +1 -0
  83. package/adapters/react/pricing-table.js +24 -0
  84. package/adapters/react/pricing-table.js.map +1 -0
  85. package/adapters/react/pricing-table.tsx +35 -0
  86. package/adapters/react/rating.d.ts +30 -0
  87. package/adapters/react/rating.d.ts.map +1 -0
  88. package/adapters/react/rating.js +24 -0
  89. package/adapters/react/rating.js.map +1 -0
  90. package/adapters/react/rating.tsx +38 -0
  91. package/adapters/react/recipe.d.ts +43 -0
  92. package/adapters/react/recipe.d.ts.map +1 -0
  93. package/adapters/react/recipe.js +24 -0
  94. package/adapters/react/recipe.js.map +1 -0
  95. package/adapters/react/recipe.tsx +51 -0
  96. package/adapters/react/sortable.d.ts +28 -0
  97. package/adapters/react/sortable.d.ts.map +1 -0
  98. package/adapters/react/sortable.js +24 -0
  99. package/adapters/react/sortable.js.map +1 -0
  100. package/adapters/react/sortable.tsx +36 -0
  101. package/adapters/react/spotlight.d.ts +27 -0
  102. package/adapters/react/spotlight.d.ts.map +1 -0
  103. package/adapters/react/spotlight.js +24 -0
  104. package/adapters/react/spotlight.js.map +1 -0
  105. package/adapters/react/spotlight.tsx +35 -0
  106. package/adapters/react/spreadsheet.d.ts +27 -0
  107. package/adapters/react/spreadsheet.d.ts.map +1 -0
  108. package/adapters/react/spreadsheet.js +24 -0
  109. package/adapters/react/spreadsheet.js.map +1 -0
  110. package/adapters/react/spreadsheet.tsx +35 -0
  111. package/adapters/react/tag-input.d.ts +33 -0
  112. package/adapters/react/tag-input.d.ts.map +1 -0
  113. package/adapters/react/tag-input.js +24 -0
  114. package/adapters/react/tag-input.js.map +1 -0
  115. package/adapters/react/tag-input.tsx +41 -0
  116. package/adapters/react/testimonial.d.ts +31 -0
  117. package/adapters/react/testimonial.d.ts.map +1 -0
  118. package/adapters/react/testimonial.js +24 -0
  119. package/adapters/react/testimonial.js.map +1 -0
  120. package/adapters/react/testimonial.tsx +39 -0
  121. package/adapters/react/video-player.d.ts +34 -0
  122. package/adapters/react/video-player.d.ts.map +1 -0
  123. package/adapters/react/video-player.js +24 -0
  124. package/adapters/react/video-player.js.map +1 -0
  125. package/adapters/react/video-player.tsx +42 -0
  126. package/adapters/react/waterfall.d.ts +29 -0
  127. package/adapters/react/waterfall.d.ts.map +1 -0
  128. package/adapters/react/waterfall.js +24 -0
  129. package/adapters/react/waterfall.js.map +1 -0
  130. package/adapters/react/waterfall.tsx +37 -0
  131. package/adapters/react/weather.d.ts +27 -0
  132. package/adapters/react/weather.d.ts.map +1 -0
  133. package/adapters/react/weather.js +24 -0
  134. package/adapters/react/weather.js.map +1 -0
  135. package/adapters/react/weather.tsx +35 -0
  136. package/dist/cdn/accordion/snice-accordion.js +1 -1
  137. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  138. package/dist/cdn/alert/snice-alert.js +1 -1
  139. package/dist/cdn/alert/snice-alert.min.js +1 -1
  140. package/dist/cdn/app-tiles/README.md +27 -0
  141. package/dist/cdn/app-tiles/snice-app-tiles.js +333 -0
  142. package/dist/cdn/app-tiles/snice-app-tiles.js.map +1 -0
  143. package/dist/cdn/app-tiles/snice-app-tiles.min.js +11 -0
  144. package/dist/cdn/app-tiles/snice-app-tiles.min.js.map +1 -0
  145. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  146. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  147. package/dist/cdn/avatar/snice-avatar.js +1 -1
  148. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  149. package/dist/cdn/badge/snice-badge.js +1 -1
  150. package/dist/cdn/badge/snice-badge.min.js +1 -1
  151. package/dist/cdn/banner/snice-banner.js +1 -1
  152. package/dist/cdn/banner/snice-banner.min.js +1 -1
  153. package/dist/cdn/book/README.md +27 -0
  154. package/dist/cdn/book/snice-book.js +353 -0
  155. package/dist/cdn/book/snice-book.js.map +1 -0
  156. package/dist/cdn/book/snice-book.min.js +13 -0
  157. package/dist/cdn/book/snice-book.min.js.map +1 -0
  158. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +1 -1
  159. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +1 -1
  160. package/dist/cdn/button/snice-button.js +1 -1
  161. package/dist/cdn/button/snice-button.min.js +1 -1
  162. package/dist/cdn/calendar/snice-calendar.js +1 -1
  163. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  164. package/dist/cdn/camera/snice-camera.js +1 -1
  165. package/dist/cdn/camera/snice-camera.min.js +1 -1
  166. package/dist/cdn/camera-annotate/snice-camera-annotate.js +1 -1
  167. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +1 -1
  168. package/dist/cdn/candlestick/snice-candlestick.js +1 -1
  169. package/dist/cdn/candlestick/snice-candlestick.min.js +1 -1
  170. package/dist/cdn/card/snice-card.js +1 -1
  171. package/dist/cdn/card/snice-card.min.js +1 -1
  172. package/dist/cdn/carousel/snice-carousel.js +1 -1
  173. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  174. package/dist/cdn/chart/snice-chart.js +1 -1
  175. package/dist/cdn/chart/snice-chart.min.js +1 -1
  176. package/dist/cdn/chat/snice-chat.js +1 -1
  177. package/dist/cdn/chat/snice-chat.min.js +1 -1
  178. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  179. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  180. package/dist/cdn/chip/snice-chip.js +1 -1
  181. package/dist/cdn/chip/snice-chip.min.js +1 -1
  182. package/dist/cdn/code-block/snice-code-block.js +1 -1
  183. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  184. package/dist/cdn/color-display/snice-color-display.js +1 -1
  185. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  186. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  187. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  188. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  189. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  190. package/dist/cdn/comments/README.md +27 -0
  191. package/dist/cdn/comments/snice-comments.js +544 -0
  192. package/dist/cdn/comments/snice-comments.js.map +1 -0
  193. package/dist/cdn/comments/snice-comments.min.js +100 -0
  194. package/dist/cdn/comments/snice-comments.min.js.map +1 -0
  195. package/dist/cdn/countdown/README.md +27 -0
  196. package/dist/cdn/countdown/snice-countdown.js +235 -0
  197. package/dist/cdn/countdown/snice-countdown.js.map +1 -0
  198. package/dist/cdn/countdown/snice-countdown.min.js +14 -0
  199. package/dist/cdn/countdown/snice-countdown.min.js.map +1 -0
  200. package/dist/cdn/cropper/README.md +27 -0
  201. package/dist/cdn/cropper/snice-cropper.js +352 -0
  202. package/dist/cdn/cropper/snice-cropper.js.map +1 -0
  203. package/dist/cdn/cropper/snice-cropper.min.js +25 -0
  204. package/dist/cdn/cropper/snice-cropper.min.js.map +1 -0
  205. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  206. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  207. package/dist/cdn/diff/README.md +27 -0
  208. package/dist/cdn/diff/snice-diff.js +441 -0
  209. package/dist/cdn/diff/snice-diff.js.map +1 -0
  210. package/dist/cdn/diff/snice-diff.min.js +54 -0
  211. package/dist/cdn/diff/snice-diff.min.js.map +1 -0
  212. package/dist/cdn/divider/snice-divider.js +1 -1
  213. package/dist/cdn/divider/snice-divider.min.js +1 -1
  214. package/dist/cdn/doc/snice-doc.js +1 -1
  215. package/dist/cdn/doc/snice-doc.min.js +1 -1
  216. package/dist/cdn/draw/snice-draw.js +1 -1
  217. package/dist/cdn/draw/snice-draw.min.js +1 -1
  218. package/dist/cdn/drawer/snice-drawer.js +1 -1
  219. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  220. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  221. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  222. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  223. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  224. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  225. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  226. package/dist/cdn/flip-card/README.md +27 -0
  227. package/dist/cdn/flip-card/snice-flip-card.js +183 -0
  228. package/dist/cdn/flip-card/snice-flip-card.js.map +1 -0
  229. package/dist/cdn/flip-card/snice-flip-card.min.js +22 -0
  230. package/dist/cdn/flip-card/snice-flip-card.min.js.map +1 -0
  231. package/dist/cdn/flow/README.md +27 -0
  232. package/dist/cdn/flow/snice-flow.js +822 -0
  233. package/dist/cdn/flow/snice-flow.js.map +1 -0
  234. package/dist/cdn/flow/snice-flow.min.js +17 -0
  235. package/dist/cdn/flow/snice-flow.min.js.map +1 -0
  236. package/dist/cdn/funnel/snice-funnel.js +1 -1
  237. package/dist/cdn/funnel/snice-funnel.min.js +1 -1
  238. package/dist/cdn/gantt/README.md +27 -0
  239. package/dist/cdn/gantt/snice-gantt.js +436 -0
  240. package/dist/cdn/gantt/snice-gantt.js.map +1 -0
  241. package/dist/cdn/gantt/snice-gantt.min.js +60 -0
  242. package/dist/cdn/gantt/snice-gantt.min.js.map +1 -0
  243. package/dist/cdn/gauge/snice-gauge.js +1 -1
  244. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  245. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  246. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  247. package/dist/cdn/image/snice-image.js +1 -1
  248. package/dist/cdn/image/snice-image.min.js +1 -1
  249. package/dist/cdn/input/snice-input.js +1 -1
  250. package/dist/cdn/input/snice-input.min.js +1 -1
  251. package/dist/cdn/kanban/snice-kanban.js +1 -1
  252. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  253. package/dist/cdn/kpi/snice-kpi.js +1 -1
  254. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  255. package/dist/cdn/layout/snice-layout.js +1 -1
  256. package/dist/cdn/layout/snice-layout.min.js +1 -1
  257. package/dist/cdn/link/snice-link.js +1 -1
  258. package/dist/cdn/link/snice-link.min.js +1 -1
  259. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  260. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  261. package/dist/cdn/list/snice-list.js +1 -1
  262. package/dist/cdn/list/snice-list.min.js +1 -1
  263. package/dist/cdn/location/snice-location.js +1 -1
  264. package/dist/cdn/location/snice-location.min.js +1 -1
  265. package/dist/cdn/login/snice-login.js +1 -1
  266. package/dist/cdn/login/snice-login.min.js +1 -1
  267. package/dist/cdn/map/README.md +27 -0
  268. package/dist/cdn/map/snice-map.js +415 -0
  269. package/dist/cdn/map/snice-map.js.map +1 -0
  270. package/dist/cdn/map/snice-map.min.js +52 -0
  271. package/dist/cdn/map/snice-map.min.js.map +1 -0
  272. package/dist/cdn/markdown/README.md +27 -0
  273. package/dist/cdn/markdown/snice-markdown.js +317 -0
  274. package/dist/cdn/markdown/snice-markdown.js.map +1 -0
  275. package/dist/cdn/markdown/snice-markdown.min.js +11 -0
  276. package/dist/cdn/markdown/snice-markdown.min.js.map +1 -0
  277. package/dist/cdn/masonry/snice-masonry.js +1 -1
  278. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  279. package/dist/cdn/menu/snice-menu.js +1 -1
  280. package/dist/cdn/menu/snice-menu.min.js +1 -1
  281. package/dist/cdn/modal/snice-modal.js +1 -1
  282. package/dist/cdn/modal/snice-modal.min.js +1 -1
  283. package/dist/cdn/music-player/snice-music-player.js +1 -1
  284. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  285. package/dist/cdn/nav/snice-nav.js +1 -1
  286. package/dist/cdn/nav/snice-nav.min.js +1 -1
  287. package/dist/cdn/network-graph/snice-network-graph.js +1 -1
  288. package/dist/cdn/network-graph/snice-network-graph.min.js +1 -1
  289. package/dist/cdn/notification-center/README.md +27 -0
  290. package/dist/cdn/notification-center/snice-notification-center.js +204 -0
  291. package/dist/cdn/notification-center/snice-notification-center.js.map +1 -0
  292. package/dist/cdn/notification-center/snice-notification-center.min.js +33 -0
  293. package/dist/cdn/notification-center/snice-notification-center.min.js.map +1 -0
  294. package/dist/cdn/org-chart/README.md +27 -0
  295. package/dist/cdn/org-chart/snice-org-chart.js +294 -0
  296. package/dist/cdn/org-chart/snice-org-chart.js.map +1 -0
  297. package/dist/cdn/org-chart/snice-org-chart.min.js +32 -0
  298. package/dist/cdn/org-chart/snice-org-chart.min.js.map +1 -0
  299. package/dist/cdn/pagination/snice-pagination.js +1 -1
  300. package/dist/cdn/pagination/snice-pagination.min.js +1 -1
  301. package/dist/cdn/paint/snice-paint.js +1 -1
  302. package/dist/cdn/paint/snice-paint.min.js +1 -1
  303. package/dist/cdn/pdf-viewer/README.md +27 -0
  304. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js +594 -0
  305. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  306. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js +88 -0
  307. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js.map +1 -0
  308. package/dist/cdn/podcast-player/README.md +27 -0
  309. package/dist/cdn/podcast-player/snice-podcast-player.js +835 -0
  310. package/dist/cdn/podcast-player/snice-podcast-player.js.map +1 -0
  311. package/dist/cdn/podcast-player/snice-podcast-player.min.js +209 -0
  312. package/dist/cdn/podcast-player/snice-podcast-player.min.js.map +1 -0
  313. package/dist/cdn/pricing-table/README.md +27 -0
  314. package/dist/cdn/pricing-table/snice-pricing-table.js +491 -0
  315. package/dist/cdn/pricing-table/snice-pricing-table.js.map +1 -0
  316. package/dist/cdn/pricing-table/snice-pricing-table.min.js +141 -0
  317. package/dist/cdn/pricing-table/snice-pricing-table.min.js.map +1 -0
  318. package/dist/cdn/progress/snice-progress.js +1 -1
  319. package/dist/cdn/progress/snice-progress.min.js +1 -1
  320. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  321. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  322. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  323. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  324. package/dist/cdn/radio/snice-radio.js +1 -1
  325. package/dist/cdn/radio/snice-radio.min.js +1 -1
  326. package/dist/cdn/rating/README.md +27 -0
  327. package/dist/cdn/rating/snice-rating.js +210 -0
  328. package/dist/cdn/rating/snice-rating.js.map +1 -0
  329. package/dist/cdn/rating/snice-rating.min.js +25 -0
  330. package/dist/cdn/rating/snice-rating.min.js.map +1 -0
  331. package/dist/cdn/recipe/README.md +27 -0
  332. package/dist/cdn/recipe/snice-recipe.js +619 -0
  333. package/dist/cdn/recipe/snice-recipe.js.map +1 -0
  334. package/dist/cdn/recipe/snice-recipe.min.js +185 -0
  335. package/dist/cdn/recipe/snice-recipe.min.js.map +1 -0
  336. package/dist/cdn/runtime/snice-runtime.esm.js +3 -3
  337. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  338. package/dist/cdn/runtime/snice-runtime.esm.min.js +3 -3
  339. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  340. package/dist/cdn/runtime/snice-runtime.js +3 -3
  341. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  342. package/dist/cdn/runtime/snice-runtime.min.js +3 -3
  343. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  344. package/dist/cdn/sankey/snice-sankey.js +1 -1
  345. package/dist/cdn/sankey/snice-sankey.min.js +1 -1
  346. package/dist/cdn/select/snice-select.js +1 -1
  347. package/dist/cdn/select/snice-select.min.js +1 -1
  348. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  349. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  350. package/dist/cdn/slider/snice-slider.js +1 -1
  351. package/dist/cdn/slider/snice-slider.min.js +1 -1
  352. package/dist/cdn/sortable/README.md +27 -0
  353. package/dist/cdn/sortable/snice-sortable.js +254 -0
  354. package/dist/cdn/sortable/snice-sortable.js.map +1 -0
  355. package/dist/cdn/sortable/snice-sortable.min.js +12 -0
  356. package/dist/cdn/sortable/snice-sortable.min.js.map +1 -0
  357. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  358. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  359. package/dist/cdn/spinner/snice-spinner.js +1 -1
  360. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  361. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  362. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  363. package/dist/cdn/spotlight/README.md +27 -0
  364. package/dist/cdn/spotlight/snice-spotlight.js +397 -0
  365. package/dist/cdn/spotlight/snice-spotlight.js.map +1 -0
  366. package/dist/cdn/spotlight/snice-spotlight.min.js +8 -0
  367. package/dist/cdn/spotlight/snice-spotlight.min.js.map +1 -0
  368. package/dist/cdn/spreadsheet/README.md +27 -0
  369. package/dist/cdn/spreadsheet/snice-spreadsheet.js +1171 -0
  370. package/dist/cdn/spreadsheet/snice-spreadsheet.js.map +1 -0
  371. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js +30 -0
  372. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js.map +1 -0
  373. package/dist/cdn/stepper/snice-stepper.js +1 -1
  374. package/dist/cdn/stepper/snice-stepper.min.js +1 -1
  375. package/dist/cdn/switch/snice-switch.js +1 -1
  376. package/dist/cdn/switch/snice-switch.min.js +1 -1
  377. package/dist/cdn/table/snice-table.js +1 -1
  378. package/dist/cdn/table/snice-table.min.js +1 -1
  379. package/dist/cdn/tabs/snice-tabs.js +1 -1
  380. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  381. package/dist/cdn/tag-input/README.md +27 -0
  382. package/dist/cdn/tag-input/snice-tag-input.js +387 -0
  383. package/dist/cdn/tag-input/snice-tag-input.js.map +1 -0
  384. package/dist/cdn/tag-input/snice-tag-input.min.js +65 -0
  385. package/dist/cdn/tag-input/snice-tag-input.min.js.map +1 -0
  386. package/dist/cdn/terminal/snice-terminal.js +1 -1
  387. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  388. package/dist/cdn/testimonial/README.md +27 -0
  389. package/dist/cdn/testimonial/snice-testimonial.js +187 -0
  390. package/dist/cdn/testimonial/snice-testimonial.js.map +1 -0
  391. package/dist/cdn/testimonial/snice-testimonial.min.js +21 -0
  392. package/dist/cdn/testimonial/snice-testimonial.min.js.map +1 -0
  393. package/dist/cdn/textarea/snice-textarea.js +1 -1
  394. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  395. package/dist/cdn/time-range-picker/snice-time-range-picker.js +1 -1
  396. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +1 -1
  397. package/dist/cdn/timeline/snice-timeline.js +1 -1
  398. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  399. package/dist/cdn/timer/snice-timer.js +1 -1
  400. package/dist/cdn/timer/snice-timer.min.js +1 -1
  401. package/dist/cdn/toast/snice-toast.js +1 -1
  402. package/dist/cdn/toast/snice-toast.min.js +1 -1
  403. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  404. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  405. package/dist/cdn/tree/snice-tree.js +1 -1
  406. package/dist/cdn/tree/snice-tree.min.js +1 -1
  407. package/dist/cdn/treemap/snice-treemap.js +1 -1
  408. package/dist/cdn/treemap/snice-treemap.min.js +1 -1
  409. package/dist/cdn/video-player/README.md +27 -0
  410. package/dist/cdn/video-player/snice-video-player.js +721 -0
  411. package/dist/cdn/video-player/snice-video-player.js.map +1 -0
  412. package/dist/cdn/video-player/snice-video-player.min.js +153 -0
  413. package/dist/cdn/video-player/snice-video-player.min.js.map +1 -0
  414. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +1 -1
  415. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +1 -1
  416. package/dist/cdn/waterfall/README.md +27 -0
  417. package/dist/cdn/waterfall/snice-waterfall.js +292 -0
  418. package/dist/cdn/waterfall/snice-waterfall.js.map +1 -0
  419. package/dist/cdn/waterfall/snice-waterfall.min.js +12 -0
  420. package/dist/cdn/waterfall/snice-waterfall.min.js.map +1 -0
  421. package/dist/cdn/weather/README.md +27 -0
  422. package/dist/cdn/weather/snice-weather.js +194 -0
  423. package/dist/cdn/weather/snice-weather.js.map +1 -0
  424. package/dist/cdn/weather/snice-weather.min.js +42 -0
  425. package/dist/cdn/weather/snice-weather.min.js.map +1 -0
  426. package/dist/components/app-tiles/snice-app-tiles.d.ts +36 -0
  427. package/dist/components/app-tiles/snice-app-tiles.js +265 -0
  428. package/dist/components/app-tiles/snice-app-tiles.js.map +1 -0
  429. package/dist/components/app-tiles/snice-app-tiles.types.d.ts +22 -0
  430. package/dist/components/book/snice-book.d.ts +46 -0
  431. package/dist/components/book/snice-book.js +285 -0
  432. package/dist/components/book/snice-book.js.map +1 -0
  433. package/dist/components/book/snice-book.types.d.ts +21 -0
  434. package/dist/components/comments/snice-comments.d.ts +62 -0
  435. package/dist/components/comments/snice-comments.js +476 -0
  436. package/dist/components/comments/snice-comments.js.map +1 -0
  437. package/dist/components/comments/snice-comments.types.d.ts +64 -0
  438. package/dist/components/countdown/snice-countdown.d.ts +21 -0
  439. package/dist/components/countdown/snice-countdown.js +168 -0
  440. package/dist/components/countdown/snice-countdown.js.map +1 -0
  441. package/dist/components/countdown/snice-countdown.types.d.ts +18 -0
  442. package/dist/components/cropper/snice-cropper.d.ts +32 -0
  443. package/dist/components/cropper/snice-cropper.js +285 -0
  444. package/dist/components/cropper/snice-cropper.js.map +1 -0
  445. package/dist/components/cropper/snice-cropper.types.d.ts +26 -0
  446. package/dist/components/diff/snice-diff.d.ts +32 -0
  447. package/dist/components/diff/snice-diff.js +374 -0
  448. package/dist/components/diff/snice-diff.js.map +1 -0
  449. package/dist/components/diff/snice-diff.types.d.ts +26 -0
  450. package/dist/components/flip-card/snice-flip-card.d.ts +15 -0
  451. package/dist/components/flip-card/snice-flip-card.js +116 -0
  452. package/dist/components/flip-card/snice-flip-card.js.map +1 -0
  453. package/dist/components/flip-card/snice-flip-card.types.d.ts +16 -0
  454. package/dist/components/flow/snice-flow.d.ts +91 -0
  455. package/dist/components/flow/snice-flow.js +755 -0
  456. package/dist/components/flow/snice-flow.js.map +1 -0
  457. package/dist/components/flow/snice-flow.types.d.ts +64 -0
  458. package/dist/components/gantt/snice-gantt.d.ts +34 -0
  459. package/dist/components/gantt/snice-gantt.js +369 -0
  460. package/dist/components/gantt/snice-gantt.js.map +1 -0
  461. package/dist/components/gantt/snice-gantt.types.d.ts +37 -0
  462. package/dist/components/map/snice-map.d.ts +44 -0
  463. package/dist/components/map/snice-map.js +348 -0
  464. package/dist/components/map/snice-map.js.map +1 -0
  465. package/dist/components/map/snice-map.types.d.ts +41 -0
  466. package/dist/components/markdown/snice-markdown.d.ts +24 -0
  467. package/dist/components/markdown/snice-markdown.js +250 -0
  468. package/dist/components/markdown/snice-markdown.js.map +1 -0
  469. package/dist/components/markdown/snice-markdown.types.d.ts +16 -0
  470. package/dist/components/notification-center/snice-notification-center.d.ts +18 -0
  471. package/dist/components/notification-center/snice-notification-center.js +137 -0
  472. package/dist/components/notification-center/snice-notification-center.js.map +1 -0
  473. package/dist/components/notification-center/snice-notification-center.types.d.ts +24 -0
  474. package/dist/components/org-chart/snice-org-chart.d.ts +28 -0
  475. package/dist/components/org-chart/snice-org-chart.js +227 -0
  476. package/dist/components/org-chart/snice-org-chart.js.map +1 -0
  477. package/dist/components/org-chart/snice-org-chart.types.d.ts +28 -0
  478. package/dist/components/pdf-viewer/pdf.min.mjs +21 -0
  479. package/dist/components/pdf-viewer/pdf.worker.min.mjs +21 -0
  480. package/dist/components/pdf-viewer/snice-pdf-viewer.d.ts +59 -0
  481. package/dist/components/pdf-viewer/snice-pdf-viewer.js +527 -0
  482. package/dist/components/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  483. package/dist/components/pdf-viewer/snice-pdf-viewer.types.d.ts +25 -0
  484. package/dist/components/podcast-player/snice-podcast-player.d.ts +72 -0
  485. package/dist/components/podcast-player/snice-podcast-player.js +768 -0
  486. package/dist/components/podcast-player/snice-podcast-player.js.map +1 -0
  487. package/dist/components/podcast-player/snice-podcast-player.types.d.ts +79 -0
  488. package/dist/components/pricing-table/snice-pricing-table.d.ts +51 -0
  489. package/dist/components/pricing-table/snice-pricing-table.js +422 -0
  490. package/dist/components/pricing-table/snice-pricing-table.js.map +1 -0
  491. package/dist/components/pricing-table/snice-pricing-table.types.d.ts +49 -0
  492. package/dist/components/rating/snice-rating.d.ts +15 -0
  493. package/dist/components/rating/snice-rating.js +143 -0
  494. package/dist/components/rating/snice-rating.js.map +1 -0
  495. package/dist/components/rating/snice-rating.types.d.ts +15 -0
  496. package/dist/components/recipe/snice-recipe.d.ts +53 -0
  497. package/dist/components/recipe/snice-recipe.js +552 -0
  498. package/dist/components/recipe/snice-recipe.js.map +1 -0
  499. package/dist/components/recipe/snice-recipe.types.d.ts +56 -0
  500. package/dist/components/sortable/snice-sortable.d.ts +24 -0
  501. package/dist/components/sortable/snice-sortable.js +187 -0
  502. package/dist/components/sortable/snice-sortable.js.map +1 -0
  503. package/dist/components/sortable/snice-sortable.types.d.ts +20 -0
  504. package/dist/components/spotlight/snice-spotlight.d.ts +42 -0
  505. package/dist/components/spotlight/snice-spotlight.js +330 -0
  506. package/dist/components/spotlight/snice-spotlight.js.map +1 -0
  507. package/dist/components/spotlight/snice-spotlight.types.d.ts +26 -0
  508. package/dist/components/spreadsheet/snice-spreadsheet.d.ts +102 -0
  509. package/dist/components/spreadsheet/snice-spreadsheet.js +1104 -0
  510. package/dist/components/spreadsheet/snice-spreadsheet.js.map +1 -0
  511. package/dist/components/spreadsheet/snice-spreadsheet.types.d.ts +54 -0
  512. package/dist/components/tag-input/snice-tag-input.d.ts +40 -0
  513. package/dist/components/tag-input/snice-tag-input.js +320 -0
  514. package/dist/components/tag-input/snice-tag-input.js.map +1 -0
  515. package/dist/components/tag-input/snice-tag-input.types.d.ts +29 -0
  516. package/dist/components/testimonial/snice-testimonial.d.ts +15 -0
  517. package/dist/components/testimonial/snice-testimonial.js +120 -0
  518. package/dist/components/testimonial/snice-testimonial.js.map +1 -0
  519. package/dist/components/testimonial/snice-testimonial.types.d.ts +10 -0
  520. package/dist/components/video-player/snice-video-player.d.ts +78 -0
  521. package/dist/components/video-player/snice-video-player.js +654 -0
  522. package/dist/components/video-player/snice-video-player.js.map +1 -0
  523. package/dist/components/video-player/snice-video-player.types.d.ts +47 -0
  524. package/dist/components/waterfall/snice-waterfall.d.ts +30 -0
  525. package/dist/components/waterfall/snice-waterfall.js +225 -0
  526. package/dist/components/waterfall/snice-waterfall.js.map +1 -0
  527. package/dist/components/waterfall/snice-waterfall.types.d.ts +23 -0
  528. package/dist/components/weather/snice-weather.d.ts +10 -0
  529. package/dist/components/weather/snice-weather.js +127 -0
  530. package/dist/components/weather/snice-weather.js.map +1 -0
  531. package/dist/components/weather/snice-weather.types.d.ts +22 -0
  532. package/dist/index.cjs +1 -1
  533. package/dist/index.esm.js +1 -1
  534. package/dist/index.iife.js +1 -1
  535. package/dist/symbols.cjs +1 -1
  536. package/dist/symbols.esm.js +1 -1
  537. package/dist/transitions.cjs +1 -1
  538. package/dist/transitions.esm.js +1 -1
  539. package/docs/ai/DEVELOPMENT.md +1 -1
  540. package/docs/ai/api.md +6 -3
  541. package/docs/ai/components/accordion.md +0 -34
  542. package/docs/ai/components/app-tiles.md +77 -0
  543. package/docs/ai/components/audio-recorder.md +2 -0
  544. package/docs/ai/components/badge.md +7 -0
  545. package/docs/ai/components/book.md +78 -0
  546. package/docs/ai/components/button.md +5 -0
  547. package/docs/ai/components/chart.md +0 -24
  548. package/docs/ai/components/chat.md +7 -95
  549. package/docs/ai/components/code-block.md +3 -82
  550. package/docs/ai/components/color-display.md +3 -3
  551. package/docs/ai/components/color-picker.md +4 -4
  552. package/docs/ai/components/comments.md +75 -0
  553. package/docs/ai/components/countdown.md +54 -0
  554. package/docs/ai/components/cropper.md +57 -0
  555. package/docs/ai/components/date-picker.md +15 -9
  556. package/docs/ai/components/diff.md +66 -0
  557. package/docs/ai/components/divider.md +1 -1
  558. package/docs/ai/components/draw.md +5 -5
  559. package/docs/ai/components/drawer.md +5 -5
  560. package/docs/ai/components/empty-state.md +2 -2
  561. package/docs/ai/components/file-gallery.md +16 -87
  562. package/docs/ai/components/file-upload.md +6 -6
  563. package/docs/ai/components/flip-card.md +52 -0
  564. package/docs/ai/components/flow.md +104 -0
  565. package/docs/ai/components/funnel.md +3 -3
  566. package/docs/ai/components/gantt.md +63 -0
  567. package/docs/ai/components/gauge.md +1 -1
  568. package/docs/ai/components/heatmap.md +5 -5
  569. package/docs/ai/components/input.md +20 -18
  570. package/docs/ai/components/kanban.md +2 -2
  571. package/docs/ai/components/kpi.md +4 -53
  572. package/docs/ai/components/layout.md +10 -235
  573. package/docs/ai/components/link-preview.md +20 -29
  574. package/docs/ai/components/link.md +27 -47
  575. package/docs/ai/components/list.md +51 -31
  576. package/docs/ai/components/location.md +15 -27
  577. package/docs/ai/components/login.md +43 -94
  578. package/docs/ai/components/map.md +72 -0
  579. package/docs/ai/components/markdown.md +63 -0
  580. package/docs/ai/components/masonry.md +10 -6
  581. package/docs/ai/components/menu.md +40 -72
  582. package/docs/ai/components/modal.md +25 -42
  583. package/docs/ai/components/music-player.md +37 -89
  584. package/docs/ai/components/nav.md +25 -39
  585. package/docs/ai/components/network-graph.md +39 -43
  586. package/docs/ai/components/notification-center.md +79 -0
  587. package/docs/ai/components/org-chart.md +62 -0
  588. package/docs/ai/components/pagination.md +16 -18
  589. package/docs/ai/components/pdf-viewer.md +57 -0
  590. package/docs/ai/components/podcast-player.md +94 -0
  591. package/docs/ai/components/pricing-table.md +87 -0
  592. package/docs/ai/components/progress.md +23 -39
  593. package/docs/ai/components/qr-code.md +37 -84
  594. package/docs/ai/components/qr-reader.md +51 -61
  595. package/docs/ai/components/radio.md +27 -39
  596. package/docs/ai/components/rating.md +56 -0
  597. package/docs/ai/components/recipe.md +90 -0
  598. package/docs/ai/components/skeleton.md +0 -8
  599. package/docs/ai/components/slider.md +10 -50
  600. package/docs/ai/components/sortable.md +57 -0
  601. package/docs/ai/components/sparkline.md +26 -152
  602. package/docs/ai/components/spinner.md +0 -21
  603. package/docs/ai/components/split-pane.md +16 -38
  604. package/docs/ai/components/spotlight.md +61 -0
  605. package/docs/ai/components/spreadsheet.md +138 -0
  606. package/docs/ai/components/stepper.md +37 -183
  607. package/docs/ai/components/switch.md +28 -35
  608. package/docs/ai/components/table.md +43 -172
  609. package/docs/ai/components/tabs.md +31 -52
  610. package/docs/ai/components/tag-input.md +70 -0
  611. package/docs/ai/components/terminal.md +34 -116
  612. package/docs/ai/components/testimonial.md +56 -0
  613. package/docs/ai/components/textarea.md +11 -43
  614. package/docs/ai/components/theme.md +120 -0
  615. package/docs/ai/components/time-range-picker.md +17 -49
  616. package/docs/ai/components/timeline.md +7 -46
  617. package/docs/ai/components/timer.md +41 -37
  618. package/docs/ai/components/toast.md +19 -90
  619. package/docs/ai/components/tooltip.md +17 -104
  620. package/docs/ai/components/tree.md +38 -162
  621. package/docs/ai/components/treemap.md +23 -44
  622. package/docs/ai/components/video-player.md +91 -0
  623. package/docs/ai/components/virtual-scroller.md +23 -46
  624. package/docs/ai/components/waterfall.md +56 -0
  625. package/docs/ai/components/weather.md +78 -0
  626. package/docs/ai/decorators.md +25 -3
  627. package/docs/ai/patterns.md +17 -1
  628. package/docs/components/accordion.md +8 -6
  629. package/docs/components/alert.md +2 -0
  630. package/docs/components/app-tiles.md +162 -0
  631. package/docs/components/audio-recorder.md +6 -0
  632. package/docs/components/avatar.md +225 -0
  633. package/docs/components/badge.md +2 -0
  634. package/docs/components/banner.md +2 -0
  635. package/docs/components/book.md +184 -0
  636. package/docs/components/breadcrumbs.md +2 -0
  637. package/docs/components/button.md +15 -0
  638. package/docs/components/calendar.md +2 -0
  639. package/docs/components/camera-annotate.md +2 -0
  640. package/docs/components/camera.md +2 -0
  641. package/docs/components/candlestick.md +2 -0
  642. package/docs/components/card.md +2 -0
  643. package/docs/components/carousel.md +205 -36
  644. package/docs/components/chart.md +2 -0
  645. package/docs/components/chat.md +2 -0
  646. package/docs/components/checkbox.md +2 -0
  647. package/docs/components/chip.md +2 -0
  648. package/docs/components/code-block.md +2 -0
  649. package/docs/components/color-display.md +2 -0
  650. package/docs/components/color-picker.md +6 -4
  651. package/docs/components/command-palette.md +2 -0
  652. package/docs/components/comments.md +235 -0
  653. package/docs/components/countdown.md +121 -0
  654. package/docs/components/cropper.md +152 -0
  655. package/docs/components/date-picker.md +201 -0
  656. package/docs/components/diff.md +177 -0
  657. package/docs/components/divider.md +132 -0
  658. package/docs/components/doc.md +2 -0
  659. package/docs/components/draw.md +2 -0
  660. package/docs/components/drawer.md +2 -0
  661. package/docs/components/empty-state.md +2 -0
  662. package/docs/components/file-gallery.md +2 -0
  663. package/docs/components/file-upload.md +2 -0
  664. package/docs/components/flip-card.md +169 -0
  665. package/docs/components/flow.md +208 -0
  666. package/docs/components/funnel.md +2 -0
  667. package/docs/components/gantt.md +187 -0
  668. package/docs/components/gauge.md +2 -0
  669. package/docs/components/heatmap.md +2 -0
  670. package/docs/components/image.md +2 -0
  671. package/docs/components/input.md +242 -0
  672. package/docs/components/kanban.md +2 -0
  673. package/docs/components/kpi.md +2 -0
  674. package/docs/components/layout.md +84 -0
  675. package/docs/components/link-preview.md +66 -92
  676. package/docs/components/link.md +73 -157
  677. package/docs/components/list.md +140 -44
  678. package/docs/components/location.md +96 -283
  679. package/docs/components/login.md +131 -498
  680. package/docs/components/map.md +203 -0
  681. package/docs/components/markdown.md +220 -0
  682. package/docs/components/masonry.md +57 -102
  683. package/docs/components/menu.md +87 -494
  684. package/docs/components/modal.md +83 -436
  685. package/docs/components/music-player.md +116 -221
  686. package/docs/components/nav.md +107 -170
  687. package/docs/components/network-graph.md +83 -111
  688. package/docs/components/notification-center.md +256 -0
  689. package/docs/components/org-chart.md +275 -0
  690. package/docs/components/pagination.md +75 -218
  691. package/docs/components/paint.md +108 -73
  692. package/docs/components/pdf-viewer.md +204 -0
  693. package/docs/components/podcast-player.md +277 -0
  694. package/docs/components/pricing-table.md +249 -0
  695. package/docs/components/progress.md +169 -0
  696. package/docs/components/qr-code.md +95 -378
  697. package/docs/components/qr-reader.md +83 -258
  698. package/docs/components/radio.md +151 -0
  699. package/docs/components/rating.md +154 -0
  700. package/docs/components/recipe.md +323 -0
  701. package/docs/components/sankey.md +84 -107
  702. package/docs/components/select.md +114 -485
  703. package/docs/components/skeleton.md +96 -0
  704. package/docs/components/slider.md +92 -235
  705. package/docs/components/sortable.md +267 -0
  706. package/docs/components/sparkline.md +76 -222
  707. package/docs/components/spinner.md +37 -18
  708. package/docs/components/split-pane.md +62 -226
  709. package/docs/components/spotlight.md +240 -0
  710. package/docs/components/spreadsheet.md +405 -0
  711. package/docs/components/stepper.md +72 -306
  712. package/docs/components/switch.md +69 -293
  713. package/docs/components/table.md +250 -0
  714. package/docs/components/tabs.md +92 -471
  715. package/docs/components/tag-input.md +257 -0
  716. package/docs/components/terminal.md +87 -391
  717. package/docs/components/testimonial.md +185 -0
  718. package/docs/components/textarea.md +96 -181
  719. package/docs/components/theme.md +216 -0
  720. package/docs/components/time-range-picker.md +99 -151
  721. package/docs/components/timeline.md +67 -115
  722. package/docs/components/timer.md +44 -86
  723. package/docs/components/toast.md +93 -432
  724. package/docs/components/tooltip.md +75 -419
  725. package/docs/components/tree.md +110 -436
  726. package/docs/components/treemap.md +86 -129
  727. package/docs/components/video-player.md +336 -0
  728. package/docs/components/virtual-scroller.md +86 -226
  729. package/docs/components/waterfall.md +217 -0
  730. package/docs/components/weather.md +239 -0
  731. package/package.json +1 -1
  732. package/docs/ai/components/popover.md +0 -70
  733. package/docs/components/popover.md +0 -333
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * snice v4.8.0
2
+ * snice v4.9.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.
@@ -0,0 +1,27 @@
1
+ # Snice Spotlight - CDN Build
2
+
3
+ CDN build of the Snice spotlight component. Requires the Snice runtime (`snice-runtime.min.js`) to be loaded first.
4
+
5
+ ## Usage
6
+
7
+ ```html
8
+ <script src="snice-runtime.min.js"></script>
9
+ <script src="snice-spotlight.min.js"></script>
10
+ <snice-spotlight></snice-spotlight>
11
+ ```
12
+
13
+ ## Size
14
+ - Minified: 14.5 KB
15
+ - Gzipped: 4.0 KB
16
+
17
+ ## Theme
18
+ For proper styling, link the Snice theme CSS:
19
+ ```html
20
+ <link rel="stylesheet" href="https://unpkg.com/snice/dist/components/theme/theme.css">
21
+ ```
22
+
23
+ ## Documentation
24
+ https://snice.dev
25
+
26
+ ## License
27
+ MIT
@@ -0,0 +1,397 @@
1
+ /*!
2
+ * snice v4.9.0
3
+ * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
+ * (c) 2024
5
+ * Released under the MIT License.
6
+ */
7
+ if(typeof globalThis.Snice==="undefined"){console.warn("[snice] snice-runtime.min.js must be loaded before snice-spotlight.min.js");}
8
+ var SniceSpotlight = (function (exports, snice) {
9
+ 'use strict';
10
+
11
+ /******************************************************************************
12
+ Copyright (c) Microsoft Corporation.
13
+
14
+ Permission to use, copy, modify, and/or distribute this software for any
15
+ purpose with or without fee is hereby granted.
16
+
17
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
18
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
19
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
20
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
21
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
22
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
23
+ PERFORMANCE OF THIS SOFTWARE.
24
+ ***************************************************************************** */
25
+ /* global Reflect, Promise, SuppressedError, Symbol, Iterator */
26
+
27
+
28
+ function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
29
+ function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
30
+ var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
31
+ var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
32
+ var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
33
+ var _, done = false;
34
+ for (var i = decorators.length - 1; i >= 0; i--) {
35
+ var context = {};
36
+ for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
37
+ for (var p in contextIn.access) context.access[p] = contextIn.access[p];
38
+ context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
39
+ var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
40
+ if (kind === "accessor") {
41
+ if (result === void 0) continue;
42
+ if (result === null || typeof result !== "object") throw new TypeError("Object expected");
43
+ if (_ = accept(result.get)) descriptor.get = _;
44
+ if (_ = accept(result.set)) descriptor.set = _;
45
+ if (_ = accept(result.init)) initializers.unshift(_);
46
+ }
47
+ else if (_ = accept(result)) {
48
+ if (kind === "field") initializers.unshift(_);
49
+ else descriptor[key] = _;
50
+ }
51
+ }
52
+ if (target) Object.defineProperty(target, contextIn.name, descriptor);
53
+ done = true;
54
+ }
55
+ function __runInitializers(thisArg, initializers, value) {
56
+ var useValue = arguments.length > 2;
57
+ for (var i = 0; i < initializers.length; i++) {
58
+ value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
59
+ }
60
+ return useValue ? value : void 0;
61
+ }
62
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
63
+ var e = new Error(message);
64
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
65
+ };
66
+
67
+ var cssContent = ":host{font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif)}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9998;pointer-events:none}.overlay[hidden]{display:none}.backdrop{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:auto}.cutout{position:fixed;background:0 0;box-shadow:0 0 0 9999px rgb(0 0 0 / .5);border-radius:4px;z-index:9999;pointer-events:none;transition:top var(--snice-transition-medium, 250ms) ease,left var(--snice-transition-medium, 250ms) ease,width var(--snice-transition-medium, 250ms) ease,height var(--snice-transition-medium, 250ms) ease}.popover{position:fixed;z-index:10000;background:var(--snice-color-background,rgb(255 255 255));border:1px solid var(--snice-color-border,rgb(226 226 226));border-radius:var(--snice-border-radius-lg,.5rem);box-shadow:var(--snice-shadow-lg,0 10px 15px -3px rgb(0 0 0 / .1),0 4px 6px -4px rgb(0 0 0 / .1));padding:var(--snice-spacing-md,1rem);max-width:20rem;min-width:15rem;pointer-events:auto;color:var(--snice-color-text,rgb(23 23 23))}.popover[hidden]{display:none}.popover-title{font-size:var(--snice-font-size-lg, 1.125rem);font-weight:var(--snice-font-weight-semibold,600);margin-bottom:var(--snice-spacing-2xs,.25rem)}.popover-description{font-size:var(--snice-font-size-md, 1rem);color:var(--snice-color-text-secondary,rgb(82 82 82));line-height:var(--snice-line-height-normal, 1.5);margin-bottom:var(--snice-spacing-sm,.75rem)}.popover-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--snice-spacing-xs,.5rem)}.step-indicator{font-size:var(--snice-font-size-sm, .875rem);color:var(--snice-color-text-tertiary,rgb(115 115 115))}.popover-actions{display:flex;gap:var(--snice-spacing-2xs,.25rem)}.btn{padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-sm,.75rem);border-radius:var(--snice-border-radius-md,.25rem);font-size:var(--snice-font-size-sm, .875rem);cursor:pointer;border:1px solid var(--snice-color-border,rgb(226 226 226));background:var(--snice-color-background,rgb(255 255 255));color:var(--snice-color-text,rgb(23 23 23));font-family:inherit}.btn:hover{background:var(--snice-color-background-element,rgb(252 251 249))}.btn-primary{background:var(--snice-color-primary,rgb(37 99 235));color:var(--snice-color-text-inverse,rgb(250 250 250));border-color:var(--snice-color-primary,rgb(37 99 235))}.btn-primary:hover{opacity:.9}.btn-skip{border:none;background:0 0;color:var(--snice-color-text-tertiary,rgb(115 115 115));padding:var(--snice-spacing-2xs,.25rem)}.btn-skip:hover{color:var(--snice-color-text,rgb(23 23 23))}";
68
+
69
+ let SniceSpotlight = (() => {
70
+ let _classDecorators = [snice.element('snice-spotlight')];
71
+ let _classDescriptor;
72
+ let _classExtraInitializers = [];
73
+ let _classThis;
74
+ let _classSuper = HTMLElement;
75
+ let _instanceExtraInitializers = [];
76
+ let _steps_decorators;
77
+ let _steps_initializers = [];
78
+ let _steps_extraInitializers = [];
79
+ let _currentIndex_decorators;
80
+ let _currentIndex_initializers = [];
81
+ let _currentIndex_extraInitializers = [];
82
+ let _active_decorators;
83
+ let _active_initializers = [];
84
+ let _active_extraInitializers = [];
85
+ let _emitStart_decorators;
86
+ let _emitStep_decorators;
87
+ let _emitEnd_decorators;
88
+ let _emitSkip_decorators;
89
+ let _cleanup_decorators;
90
+ let _template_decorators;
91
+ let _componentStyles_decorators;
92
+ (class extends _classSuper {
93
+ static { _classThis = this; }
94
+ constructor() {
95
+ super(...arguments);
96
+ this.steps = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _steps_initializers, []));
97
+ this.currentIndex = (__runInitializers(this, _steps_extraInitializers), __runInitializers(this, _currentIndex_initializers, -1));
98
+ this.active = (__runInitializers(this, _currentIndex_extraInitializers), __runInitializers(this, _active_initializers, false));
99
+ /**
100
+ * Portal div appended to document.body. All overlay UI lives here
101
+ * to escape ancestor transforms/filters/contain that break position:fixed.
102
+ */
103
+ this._portal = (__runInitializers(this, _active_extraInitializers), null);
104
+ this._cutoutEl = null;
105
+ this._popoverEl = null;
106
+ this._scrollHandler = null;
107
+ this._resizeHandler = null;
108
+ }
109
+ static {
110
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
111
+ _steps_decorators = [snice.property({ type: Array })];
112
+ _currentIndex_decorators = [snice.property({ type: Number })];
113
+ _active_decorators = [snice.property({ type: Boolean })];
114
+ _emitStart_decorators = [snice.dispatch('spotlight-start', { bubbles: true, composed: true })];
115
+ _emitStep_decorators = [snice.dispatch('spotlight-step', { bubbles: true, composed: true })];
116
+ _emitEnd_decorators = [snice.dispatch('spotlight-end', { bubbles: true, composed: true })];
117
+ _emitSkip_decorators = [snice.dispatch('spotlight-skip', { bubbles: true, composed: true })];
118
+ _cleanup_decorators = [snice.dispose()];
119
+ _template_decorators = [snice.render()];
120
+ _componentStyles_decorators = [snice.styles()];
121
+ __esDecorate(this, null, _emitStart_decorators, { kind: "method", name: "emitStart", static: false, private: false, access: { has: obj => "emitStart" in obj, get: obj => obj.emitStart }, metadata: _metadata }, null, _instanceExtraInitializers);
122
+ __esDecorate(this, null, _emitStep_decorators, { kind: "method", name: "emitStep", static: false, private: false, access: { has: obj => "emitStep" in obj, get: obj => obj.emitStep }, metadata: _metadata }, null, _instanceExtraInitializers);
123
+ __esDecorate(this, null, _emitEnd_decorators, { kind: "method", name: "emitEnd", static: false, private: false, access: { has: obj => "emitEnd" in obj, get: obj => obj.emitEnd }, metadata: _metadata }, null, _instanceExtraInitializers);
124
+ __esDecorate(this, null, _emitSkip_decorators, { kind: "method", name: "emitSkip", static: false, private: false, access: { has: obj => "emitSkip" in obj, get: obj => obj.emitSkip }, metadata: _metadata }, null, _instanceExtraInitializers);
125
+ __esDecorate(this, null, _cleanup_decorators, { kind: "method", name: "cleanup", static: false, private: false, access: { has: obj => "cleanup" in obj, get: obj => obj.cleanup }, metadata: _metadata }, null, _instanceExtraInitializers);
126
+ __esDecorate(this, null, _template_decorators, { kind: "method", name: "template", static: false, private: false, access: { has: obj => "template" in obj, get: obj => obj.template }, metadata: _metadata }, null, _instanceExtraInitializers);
127
+ __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);
128
+ __esDecorate(null, null, _steps_decorators, { kind: "field", name: "steps", static: false, private: false, access: { has: obj => "steps" in obj, get: obj => obj.steps, set: (obj, value) => { obj.steps = value; } }, metadata: _metadata }, _steps_initializers, _steps_extraInitializers);
129
+ __esDecorate(null, null, _currentIndex_decorators, { kind: "field", name: "currentIndex", static: false, private: false, access: { has: obj => "currentIndex" in obj, get: obj => obj.currentIndex, set: (obj, value) => { obj.currentIndex = value; } }, metadata: _metadata }, _currentIndex_initializers, _currentIndex_extraInitializers);
130
+ __esDecorate(null, null, _active_decorators, { kind: "field", name: "active", static: false, private: false, access: { has: obj => "active" in obj, get: obj => obj.active, set: (obj, value) => { obj.active = value; } }, metadata: _metadata }, _active_initializers, _active_extraInitializers);
131
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
132
+ _classThis = _classDescriptor.value;
133
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
134
+ __runInitializers(_classThis, _classExtraInitializers);
135
+ }
136
+ emitStart() { return undefined; }
137
+ emitStep() {
138
+ return { index: this.currentIndex, step: this.steps[this.currentIndex] };
139
+ }
140
+ emitEnd() { return undefined; }
141
+ emitSkip() {
142
+ return { index: this.currentIndex };
143
+ }
144
+ cleanup() {
145
+ this._removePortal();
146
+ }
147
+ /**
148
+ * Create the portal div on document.body with all overlay UI.
149
+ * This avoids moving the component itself (which triggers @dispose).
150
+ */
151
+ _createPortal() {
152
+ if (this._portal)
153
+ return;
154
+ const portal = document.createElement('div');
155
+ portal.setAttribute('data-snice-spotlight-portal', '');
156
+ portal.innerHTML = `
157
+ <style>${cssContent}
158
+ [data-snice-spotlight-portal] { font-family: var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif); }
159
+ [data-snice-spotlight-portal] .overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9998; pointer-events: none; }
160
+ [data-snice-spotlight-portal] .backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; pointer-events: auto; }
161
+ [data-snice-spotlight-portal] .cutout { position: fixed; background: transparent; box-shadow: 0 0 0 9999px rgb(0 0 0 / 0.5); border-radius: 4px; z-index: 9999; pointer-events: none; transition: top var(--snice-transition-medium, 250ms) ease, left var(--snice-transition-medium, 250ms) ease, width var(--snice-transition-medium, 250ms) ease, height var(--snice-transition-medium, 250ms) ease; }
162
+ [data-snice-spotlight-portal] .popover { position: fixed; z-index: 10000; background: var(--snice-color-background, rgb(255 255 255)); border: 1px solid var(--snice-color-border, rgb(226 226 226)); border-radius: var(--snice-border-radius-lg, 0.5rem); box-shadow: var(--snice-shadow-lg, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)); padding: var(--snice-spacing-md, 1rem); max-width: 20rem; min-width: 15rem; pointer-events: auto; color: var(--snice-color-text, rgb(23 23 23)); }
163
+ [data-snice-spotlight-portal] .popover-title { font-size: var(--snice-font-size-lg, 1.125rem); font-weight: var(--snice-font-weight-semibold, 600); margin-bottom: var(--snice-spacing-2xs, 0.25rem); }
164
+ [data-snice-spotlight-portal] .popover-description { font-size: var(--snice-font-size-md, 1rem); color: var(--snice-color-text-secondary, rgb(82 82 82)); line-height: var(--snice-line-height-normal, 1.5); margin-bottom: var(--snice-spacing-sm, 0.75rem); }
165
+ [data-snice-spotlight-portal] .popover-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--snice-spacing-xs, 0.5rem); }
166
+ [data-snice-spotlight-portal] .step-indicator { font-size: var(--snice-font-size-sm, 0.875rem); color: var(--snice-color-text-tertiary, rgb(115 115 115)); }
167
+ [data-snice-spotlight-portal] .popover-actions { display: flex; gap: var(--snice-spacing-2xs, 0.25rem); }
168
+ [data-snice-spotlight-portal] .btn { padding: var(--snice-spacing-2xs, 0.25rem) var(--snice-spacing-sm, 0.75rem); border-radius: var(--snice-border-radius-md, 0.25rem); font-size: var(--snice-font-size-sm, 0.875rem); cursor: pointer; border: 1px solid var(--snice-color-border, rgb(226 226 226)); background: var(--snice-color-background, rgb(255 255 255)); color: var(--snice-color-text, rgb(23 23 23)); font-family: inherit; }
169
+ [data-snice-spotlight-portal] .btn:hover { background: var(--snice-color-background-element, rgb(252 251 249)); }
170
+ [data-snice-spotlight-portal] .btn-primary { background: var(--snice-color-primary, rgb(37 99 235)); color: var(--snice-color-text-inverse, rgb(250 250 250)); border-color: var(--snice-color-primary, rgb(37 99 235)); }
171
+ [data-snice-spotlight-portal] .btn-primary:hover { opacity: 0.9; }
172
+ [data-snice-spotlight-portal] .btn-skip { border: none; background: none; color: var(--snice-color-text-tertiary, rgb(115 115 115)); padding: var(--snice-spacing-2xs, 0.25rem); }
173
+ [data-snice-spotlight-portal] .btn-skip:hover { color: var(--snice-color-text, rgb(23 23 23)); }
174
+ </style>
175
+ <div class="overlay">
176
+ <div class="backdrop"></div>
177
+ <div class="cutout"></div>
178
+ <div class="popover">
179
+ <div class="popover-title"></div>
180
+ <div class="popover-description"></div>
181
+ <div class="popover-footer">
182
+ <span class="step-indicator"></span>
183
+ <div class="popover-actions"></div>
184
+ </div>
185
+ </div>
186
+ </div>
187
+ `;
188
+ // Wire up event handlers
189
+ const backdrop = portal.querySelector('.backdrop');
190
+ backdrop?.addEventListener('click', () => this.skip());
191
+ this._portal = portal;
192
+ this._cutoutEl = portal.querySelector('.cutout');
193
+ this._popoverEl = portal.querySelector('.popover');
194
+ document.body.appendChild(portal);
195
+ // Listen for scroll and resize to reposition
196
+ this._scrollHandler = () => this._updatePosition();
197
+ this._resizeHandler = () => this._updatePosition();
198
+ window.addEventListener('scroll', this._scrollHandler, true);
199
+ window.addEventListener('resize', this._resizeHandler);
200
+ }
201
+ /** Remove portal from document.body and clean up listeners. */
202
+ _removePortal() {
203
+ if (this._scrollHandler) {
204
+ window.removeEventListener('scroll', this._scrollHandler, true);
205
+ this._scrollHandler = null;
206
+ }
207
+ if (this._resizeHandler) {
208
+ window.removeEventListener('resize', this._resizeHandler);
209
+ this._resizeHandler = null;
210
+ }
211
+ if (this._portal) {
212
+ this._portal.remove();
213
+ this._portal = null;
214
+ this._cutoutEl = null;
215
+ this._popoverEl = null;
216
+ }
217
+ }
218
+ /** Update the portal HTML to reflect current step state. */
219
+ _updatePortalContent() {
220
+ if (!this._portal)
221
+ return;
222
+ const step = this.currentIndex >= 0 ? this.steps[this.currentIndex] : null;
223
+ const isLast = this.currentIndex === this.steps.length - 1;
224
+ const isFirst = this.currentIndex === 0;
225
+ // Update popover content
226
+ const titleEl = this._portal.querySelector('.popover-title');
227
+ const descEl = this._portal.querySelector('.popover-description');
228
+ const indicatorEl = this._portal.querySelector('.step-indicator');
229
+ const actionsEl = this._portal.querySelector('.popover-actions');
230
+ const popoverEl = this._popoverEl;
231
+ if (!step || !popoverEl)
232
+ return;
233
+ popoverEl.style.display = '';
234
+ if (titleEl)
235
+ titleEl.textContent = step.title;
236
+ if (descEl)
237
+ descEl.textContent = step.description;
238
+ if (indicatorEl)
239
+ indicatorEl.textContent = `${this.currentIndex + 1} / ${this.steps.length}`;
240
+ if (actionsEl) {
241
+ actionsEl.innerHTML = '';
242
+ const skipBtn = document.createElement('button');
243
+ skipBtn.className = 'btn btn-skip';
244
+ skipBtn.textContent = 'Skip';
245
+ skipBtn.addEventListener('click', () => this.skip());
246
+ actionsEl.appendChild(skipBtn);
247
+ if (!isFirst) {
248
+ const backBtn = document.createElement('button');
249
+ backBtn.className = 'btn';
250
+ backBtn.textContent = 'Back';
251
+ backBtn.addEventListener('click', () => this.prev());
252
+ actionsEl.appendChild(backBtn);
253
+ }
254
+ const nextBtn = document.createElement('button');
255
+ nextBtn.className = 'btn btn-primary';
256
+ nextBtn.textContent = isLast ? 'Done' : 'Next';
257
+ nextBtn.addEventListener('click', () => this.next());
258
+ actionsEl.appendChild(nextBtn);
259
+ }
260
+ }
261
+ /** Position the cutout and popover over the current target. */
262
+ _updatePosition() {
263
+ if (this.currentIndex < 0 || !this.steps[this.currentIndex])
264
+ return;
265
+ if (!this._cutoutEl || !this._popoverEl)
266
+ return;
267
+ const step = this.steps[this.currentIndex];
268
+ const target = document.querySelector(step.target);
269
+ if (!target)
270
+ return;
271
+ const rect = target.getBoundingClientRect();
272
+ const padding = 8;
273
+ // Position cutout
274
+ this._cutoutEl.style.top = `${rect.top - padding}px`;
275
+ this._cutoutEl.style.left = `${rect.left - padding}px`;
276
+ this._cutoutEl.style.width = `${rect.width + padding * 2}px`;
277
+ this._cutoutEl.style.height = `${rect.height + padding * 2}px`;
278
+ // Position popover
279
+ const position = step.position || 'auto';
280
+ this._positionPopover(rect, position, padding);
281
+ }
282
+ _positionPopover(targetRect, position, padding) {
283
+ const popover = this._popoverEl;
284
+ if (!popover)
285
+ return;
286
+ const gap = 12;
287
+ popover.style.top = '';
288
+ popover.style.left = '';
289
+ popover.style.bottom = '';
290
+ popover.style.right = '';
291
+ let pos = position;
292
+ if (pos === 'auto') {
293
+ const spaceBelow = window.innerHeight - targetRect.bottom;
294
+ const spaceAbove = targetRect.top;
295
+ pos = spaceBelow > 200 ? 'bottom' : spaceAbove > 200 ? 'top' : 'bottom';
296
+ }
297
+ switch (pos) {
298
+ case 'bottom':
299
+ popover.style.top = `${targetRect.bottom + padding + gap}px`;
300
+ popover.style.left = `${Math.max(8, targetRect.left)}px`;
301
+ break;
302
+ case 'top':
303
+ popover.style.bottom = `${window.innerHeight - targetRect.top + padding + gap}px`;
304
+ popover.style.left = `${Math.max(8, targetRect.left)}px`;
305
+ break;
306
+ case 'left':
307
+ popover.style.top = `${targetRect.top}px`;
308
+ popover.style.right = `${window.innerWidth - targetRect.left + padding + gap}px`;
309
+ break;
310
+ case 'right':
311
+ popover.style.top = `${targetRect.top}px`;
312
+ popover.style.left = `${targetRect.right + padding + gap}px`;
313
+ break;
314
+ }
315
+ }
316
+ /** Scroll target into view, then position once scroll settles. */
317
+ _scrollAndPosition() {
318
+ if (this.currentIndex < 0 || !this.steps[this.currentIndex])
319
+ return;
320
+ const step = this.steps[this.currentIndex];
321
+ const target = document.querySelector(step.target);
322
+ if (!target)
323
+ return;
324
+ // Use instant scroll so getBoundingClientRect is accurate immediately
325
+ target.scrollIntoView({ behavior: 'instant', block: 'center' });
326
+ // Position after layout
327
+ requestAnimationFrame(() => this._updatePosition());
328
+ }
329
+ start() {
330
+ if (this.steps.length === 0)
331
+ return;
332
+ this._createPortal();
333
+ this.active = true;
334
+ this.currentIndex = 0;
335
+ this._updatePortalContent();
336
+ this.emitStart();
337
+ this._scrollAndPosition();
338
+ }
339
+ next() {
340
+ if (this.currentIndex < this.steps.length - 1) {
341
+ this.currentIndex++;
342
+ this._updatePortalContent();
343
+ this.emitStep();
344
+ this._scrollAndPosition();
345
+ }
346
+ else {
347
+ this.end();
348
+ }
349
+ }
350
+ prev() {
351
+ if (this.currentIndex > 0) {
352
+ this.currentIndex--;
353
+ this._updatePortalContent();
354
+ this.emitStep();
355
+ this._scrollAndPosition();
356
+ }
357
+ }
358
+ goToStep(index) {
359
+ if (index >= 0 && index < this.steps.length) {
360
+ this.currentIndex = index;
361
+ if (!this.active) {
362
+ this._createPortal();
363
+ this.active = true;
364
+ }
365
+ this._updatePortalContent();
366
+ this.emitStep();
367
+ this._scrollAndPosition();
368
+ }
369
+ }
370
+ end() {
371
+ this.active = false;
372
+ this.currentIndex = -1;
373
+ this._removePortal();
374
+ this.emitEnd();
375
+ }
376
+ skip() {
377
+ this.emitSkip();
378
+ this.end();
379
+ }
380
+ template() {
381
+ // The overlay UI lives in the portal on document.body.
382
+ // The component itself renders nothing visible.
383
+ return snice.html ``;
384
+ }
385
+ componentStyles() {
386
+ return snice.css `:host { display: none; }`;
387
+ }
388
+ });
389
+ return _classThis;
390
+ })();
391
+
392
+ exports.SniceSpotlight = SniceSpotlight;
393
+
394
+ return exports;
395
+
396
+ })({}, Snice);
397
+ //# sourceMappingURL=snice-spotlight.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snice-spotlight.js","sources":["../../../node_modules/tslib/tslib.es6.mjs","../../components/spotlight/snice-spotlight.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, dispatch, dispose, render, styles, html, css } from 'snice';\n\nvar cssContent = \":host{font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif)}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9998;pointer-events:none}.overlay[hidden]{display:none}.backdrop{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:auto}.cutout{position:fixed;background:0 0;box-shadow:0 0 0 9999px rgb(0 0 0 / .5);border-radius:4px;z-index:9999;pointer-events:none;transition:top var(--snice-transition-medium, 250ms) ease,left var(--snice-transition-medium, 250ms) ease,width var(--snice-transition-medium, 250ms) ease,height var(--snice-transition-medium, 250ms) ease}.popover{position:fixed;z-index:10000;background:var(--snice-color-background,rgb(255 255 255));border:1px solid var(--snice-color-border,rgb(226 226 226));border-radius:var(--snice-border-radius-lg,.5rem);box-shadow:var(--snice-shadow-lg,0 10px 15px -3px rgb(0 0 0 / .1),0 4px 6px -4px rgb(0 0 0 / .1));padding:var(--snice-spacing-md,1rem);max-width:20rem;min-width:15rem;pointer-events:auto;color:var(--snice-color-text,rgb(23 23 23))}.popover[hidden]{display:none}.popover-title{font-size:var(--snice-font-size-lg, 1.125rem);font-weight:var(--snice-font-weight-semibold,600);margin-bottom:var(--snice-spacing-2xs,.25rem)}.popover-description{font-size:var(--snice-font-size-md, 1rem);color:var(--snice-color-text-secondary,rgb(82 82 82));line-height:var(--snice-line-height-normal, 1.5);margin-bottom:var(--snice-spacing-sm,.75rem)}.popover-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--snice-spacing-xs,.5rem)}.step-indicator{font-size:var(--snice-font-size-sm, .875rem);color:var(--snice-color-text-tertiary,rgb(115 115 115))}.popover-actions{display:flex;gap:var(--snice-spacing-2xs,.25rem)}.btn{padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-sm,.75rem);border-radius:var(--snice-border-radius-md,.25rem);font-size:var(--snice-font-size-sm, .875rem);cursor:pointer;border:1px solid var(--snice-color-border,rgb(226 226 226));background:var(--snice-color-background,rgb(255 255 255));color:var(--snice-color-text,rgb(23 23 23));font-family:inherit}.btn:hover{background:var(--snice-color-background-element,rgb(252 251 249))}.btn-primary{background:var(--snice-color-primary,rgb(37 99 235));color:var(--snice-color-text-inverse,rgb(250 250 250));border-color:var(--snice-color-primary,rgb(37 99 235))}.btn-primary:hover{opacity:.9}.btn-skip{border:none;background:0 0;color:var(--snice-color-text-tertiary,rgb(115 115 115));padding:var(--snice-spacing-2xs,.25rem)}.btn-skip:hover{color:var(--snice-color-text,rgb(23 23 23))}\";\n\nlet SniceSpotlight = (() => {\n let _classDecorators = [element('snice-spotlight')];\n let _classDescriptor;\n let _classExtraInitializers = [];\n let _classThis;\n let _classSuper = HTMLElement;\n let _instanceExtraInitializers = [];\n let _steps_decorators;\n let _steps_initializers = [];\n let _steps_extraInitializers = [];\n let _currentIndex_decorators;\n let _currentIndex_initializers = [];\n let _currentIndex_extraInitializers = [];\n let _active_decorators;\n let _active_initializers = [];\n let _active_extraInitializers = [];\n let _emitStart_decorators;\n let _emitStep_decorators;\n let _emitEnd_decorators;\n let _emitSkip_decorators;\n let _cleanup_decorators;\n let _template_decorators;\n let _componentStyles_decorators;\n (class extends _classSuper {\n static { _classThis = this; }\n constructor() {\n super(...arguments);\n this.steps = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _steps_initializers, []));\n this.currentIndex = (__runInitializers(this, _steps_extraInitializers), __runInitializers(this, _currentIndex_initializers, -1));\n this.active = (__runInitializers(this, _currentIndex_extraInitializers), __runInitializers(this, _active_initializers, false));\n /**\n * Portal div appended to document.body. All overlay UI lives here\n * to escape ancestor transforms/filters/contain that break position:fixed.\n */\n this._portal = (__runInitializers(this, _active_extraInitializers), null);\n this._cutoutEl = null;\n this._popoverEl = null;\n this._scrollHandler = null;\n this._resizeHandler = null;\n }\n static {\n const _metadata = typeof Symbol === \"function\" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;\n _steps_decorators = [property({ type: Array })];\n _currentIndex_decorators = [property({ type: Number })];\n _active_decorators = [property({ type: Boolean })];\n _emitStart_decorators = [dispatch('spotlight-start', { bubbles: true, composed: true })];\n _emitStep_decorators = [dispatch('spotlight-step', { bubbles: true, composed: true })];\n _emitEnd_decorators = [dispatch('spotlight-end', { bubbles: true, composed: true })];\n _emitSkip_decorators = [dispatch('spotlight-skip', { bubbles: true, composed: true })];\n _cleanup_decorators = [dispose()];\n _template_decorators = [render()];\n _componentStyles_decorators = [styles()];\n __esDecorate(this, null, _emitStart_decorators, { kind: \"method\", name: \"emitStart\", static: false, private: false, access: { has: obj => \"emitStart\" in obj, get: obj => obj.emitStart }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _emitStep_decorators, { kind: \"method\", name: \"emitStep\", static: false, private: false, access: { has: obj => \"emitStep\" in obj, get: obj => obj.emitStep }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _emitEnd_decorators, { kind: \"method\", name: \"emitEnd\", static: false, private: false, access: { has: obj => \"emitEnd\" in obj, get: obj => obj.emitEnd }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _emitSkip_decorators, { kind: \"method\", name: \"emitSkip\", static: false, private: false, access: { has: obj => \"emitSkip\" in obj, get: obj => obj.emitSkip }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _cleanup_decorators, { kind: \"method\", name: \"cleanup\", static: false, private: false, access: { has: obj => \"cleanup\" in obj, get: obj => obj.cleanup }, metadata: _metadata }, null, _instanceExtraInitializers);\n __esDecorate(this, null, _template_decorators, { kind: \"method\", name: \"template\", static: false, private: false, access: { has: obj => \"template\" in obj, get: obj => obj.template }, 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, _steps_decorators, { kind: \"field\", name: \"steps\", static: false, private: false, access: { has: obj => \"steps\" in obj, get: obj => obj.steps, set: (obj, value) => { obj.steps = value; } }, metadata: _metadata }, _steps_initializers, _steps_extraInitializers);\n __esDecorate(null, null, _currentIndex_decorators, { kind: \"field\", name: \"currentIndex\", static: false, private: false, access: { has: obj => \"currentIndex\" in obj, get: obj => obj.currentIndex, set: (obj, value) => { obj.currentIndex = value; } }, metadata: _metadata }, _currentIndex_initializers, _currentIndex_extraInitializers);\n __esDecorate(null, null, _active_decorators, { kind: \"field\", name: \"active\", static: false, private: false, access: { has: obj => \"active\" in obj, get: obj => obj.active, set: (obj, value) => { obj.active = value; } }, metadata: _metadata }, _active_initializers, _active_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 emitStart() { return undefined; }\n emitStep() {\n return { index: this.currentIndex, step: this.steps[this.currentIndex] };\n }\n emitEnd() { return undefined; }\n emitSkip() {\n return { index: this.currentIndex };\n }\n cleanup() {\n this._removePortal();\n }\n /**\n * Create the portal div on document.body with all overlay UI.\n * This avoids moving the component itself (which triggers @dispose).\n */\n _createPortal() {\n if (this._portal)\n return;\n const portal = document.createElement('div');\n portal.setAttribute('data-snice-spotlight-portal', '');\n portal.innerHTML = `\n <style>${cssContent}\n [data-snice-spotlight-portal] { font-family: var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif); }\n [data-snice-spotlight-portal] .overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9998; pointer-events: none; }\n [data-snice-spotlight-portal] .backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; pointer-events: auto; }\n [data-snice-spotlight-portal] .cutout { position: fixed; background: transparent; box-shadow: 0 0 0 9999px rgb(0 0 0 / 0.5); border-radius: 4px; z-index: 9999; pointer-events: none; transition: top var(--snice-transition-medium, 250ms) ease, left var(--snice-transition-medium, 250ms) ease, width var(--snice-transition-medium, 250ms) ease, height var(--snice-transition-medium, 250ms) ease; }\n [data-snice-spotlight-portal] .popover { position: fixed; z-index: 10000; background: var(--snice-color-background, rgb(255 255 255)); border: 1px solid var(--snice-color-border, rgb(226 226 226)); border-radius: var(--snice-border-radius-lg, 0.5rem); box-shadow: var(--snice-shadow-lg, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)); padding: var(--snice-spacing-md, 1rem); max-width: 20rem; min-width: 15rem; pointer-events: auto; color: var(--snice-color-text, rgb(23 23 23)); }\n [data-snice-spotlight-portal] .popover-title { font-size: var(--snice-font-size-lg, 1.125rem); font-weight: var(--snice-font-weight-semibold, 600); margin-bottom: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .popover-description { font-size: var(--snice-font-size-md, 1rem); color: var(--snice-color-text-secondary, rgb(82 82 82)); line-height: var(--snice-line-height-normal, 1.5); margin-bottom: var(--snice-spacing-sm, 0.75rem); }\n [data-snice-spotlight-portal] .popover-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--snice-spacing-xs, 0.5rem); }\n [data-snice-spotlight-portal] .step-indicator { font-size: var(--snice-font-size-sm, 0.875rem); color: var(--snice-color-text-tertiary, rgb(115 115 115)); }\n [data-snice-spotlight-portal] .popover-actions { display: flex; gap: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .btn { padding: var(--snice-spacing-2xs, 0.25rem) var(--snice-spacing-sm, 0.75rem); border-radius: var(--snice-border-radius-md, 0.25rem); font-size: var(--snice-font-size-sm, 0.875rem); cursor: pointer; border: 1px solid var(--snice-color-border, rgb(226 226 226)); background: var(--snice-color-background, rgb(255 255 255)); color: var(--snice-color-text, rgb(23 23 23)); font-family: inherit; }\n [data-snice-spotlight-portal] .btn:hover { background: var(--snice-color-background-element, rgb(252 251 249)); }\n [data-snice-spotlight-portal] .btn-primary { background: var(--snice-color-primary, rgb(37 99 235)); color: var(--snice-color-text-inverse, rgb(250 250 250)); border-color: var(--snice-color-primary, rgb(37 99 235)); }\n [data-snice-spotlight-portal] .btn-primary:hover { opacity: 0.9; }\n [data-snice-spotlight-portal] .btn-skip { border: none; background: none; color: var(--snice-color-text-tertiary, rgb(115 115 115)); padding: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .btn-skip:hover { color: var(--snice-color-text, rgb(23 23 23)); }\n </style>\n <div class=\"overlay\">\n <div class=\"backdrop\"></div>\n <div class=\"cutout\"></div>\n <div class=\"popover\">\n <div class=\"popover-title\"></div>\n <div class=\"popover-description\"></div>\n <div class=\"popover-footer\">\n <span class=\"step-indicator\"></span>\n <div class=\"popover-actions\"></div>\n </div>\n </div>\n </div>\n `;\n // Wire up event handlers\n const backdrop = portal.querySelector('.backdrop');\n backdrop?.addEventListener('click', () => this.skip());\n this._portal = portal;\n this._cutoutEl = portal.querySelector('.cutout');\n this._popoverEl = portal.querySelector('.popover');\n document.body.appendChild(portal);\n // Listen for scroll and resize to reposition\n this._scrollHandler = () => this._updatePosition();\n this._resizeHandler = () => this._updatePosition();\n window.addEventListener('scroll', this._scrollHandler, true);\n window.addEventListener('resize', this._resizeHandler);\n }\n /** Remove portal from document.body and clean up listeners. */\n _removePortal() {\n if (this._scrollHandler) {\n window.removeEventListener('scroll', this._scrollHandler, true);\n this._scrollHandler = null;\n }\n if (this._resizeHandler) {\n window.removeEventListener('resize', this._resizeHandler);\n this._resizeHandler = null;\n }\n if (this._portal) {\n this._portal.remove();\n this._portal = null;\n this._cutoutEl = null;\n this._popoverEl = null;\n }\n }\n /** Update the portal HTML to reflect current step state. */\n _updatePortalContent() {\n if (!this._portal)\n return;\n const step = this.currentIndex >= 0 ? this.steps[this.currentIndex] : null;\n const isLast = this.currentIndex === this.steps.length - 1;\n const isFirst = this.currentIndex === 0;\n // Update popover content\n const titleEl = this._portal.querySelector('.popover-title');\n const descEl = this._portal.querySelector('.popover-description');\n const indicatorEl = this._portal.querySelector('.step-indicator');\n const actionsEl = this._portal.querySelector('.popover-actions');\n const popoverEl = this._popoverEl;\n if (!step || !popoverEl)\n return;\n popoverEl.style.display = '';\n if (titleEl)\n titleEl.textContent = step.title;\n if (descEl)\n descEl.textContent = step.description;\n if (indicatorEl)\n indicatorEl.textContent = `${this.currentIndex + 1} / ${this.steps.length}`;\n if (actionsEl) {\n actionsEl.innerHTML = '';\n const skipBtn = document.createElement('button');\n skipBtn.className = 'btn btn-skip';\n skipBtn.textContent = 'Skip';\n skipBtn.addEventListener('click', () => this.skip());\n actionsEl.appendChild(skipBtn);\n if (!isFirst) {\n const backBtn = document.createElement('button');\n backBtn.className = 'btn';\n backBtn.textContent = 'Back';\n backBtn.addEventListener('click', () => this.prev());\n actionsEl.appendChild(backBtn);\n }\n const nextBtn = document.createElement('button');\n nextBtn.className = 'btn btn-primary';\n nextBtn.textContent = isLast ? 'Done' : 'Next';\n nextBtn.addEventListener('click', () => this.next());\n actionsEl.appendChild(nextBtn);\n }\n }\n /** Position the cutout and popover over the current target. */\n _updatePosition() {\n if (this.currentIndex < 0 || !this.steps[this.currentIndex])\n return;\n if (!this._cutoutEl || !this._popoverEl)\n return;\n const step = this.steps[this.currentIndex];\n const target = document.querySelector(step.target);\n if (!target)\n return;\n const rect = target.getBoundingClientRect();\n const padding = 8;\n // Position cutout\n this._cutoutEl.style.top = `${rect.top - padding}px`;\n this._cutoutEl.style.left = `${rect.left - padding}px`;\n this._cutoutEl.style.width = `${rect.width + padding * 2}px`;\n this._cutoutEl.style.height = `${rect.height + padding * 2}px`;\n // Position popover\n const position = step.position || 'auto';\n this._positionPopover(rect, position, padding);\n }\n _positionPopover(targetRect, position, padding) {\n const popover = this._popoverEl;\n if (!popover)\n return;\n const gap = 12;\n popover.style.top = '';\n popover.style.left = '';\n popover.style.bottom = '';\n popover.style.right = '';\n let pos = position;\n if (pos === 'auto') {\n const spaceBelow = window.innerHeight - targetRect.bottom;\n const spaceAbove = targetRect.top;\n pos = spaceBelow > 200 ? 'bottom' : spaceAbove > 200 ? 'top' : 'bottom';\n }\n switch (pos) {\n case 'bottom':\n popover.style.top = `${targetRect.bottom + padding + gap}px`;\n popover.style.left = `${Math.max(8, targetRect.left)}px`;\n break;\n case 'top':\n popover.style.bottom = `${window.innerHeight - targetRect.top + padding + gap}px`;\n popover.style.left = `${Math.max(8, targetRect.left)}px`;\n break;\n case 'left':\n popover.style.top = `${targetRect.top}px`;\n popover.style.right = `${window.innerWidth - targetRect.left + padding + gap}px`;\n break;\n case 'right':\n popover.style.top = `${targetRect.top}px`;\n popover.style.left = `${targetRect.right + padding + gap}px`;\n break;\n }\n }\n /** Scroll target into view, then position once scroll settles. */\n _scrollAndPosition() {\n if (this.currentIndex < 0 || !this.steps[this.currentIndex])\n return;\n const step = this.steps[this.currentIndex];\n const target = document.querySelector(step.target);\n if (!target)\n return;\n // Use instant scroll so getBoundingClientRect is accurate immediately\n target.scrollIntoView({ behavior: 'instant', block: 'center' });\n // Position after layout\n requestAnimationFrame(() => this._updatePosition());\n }\n start() {\n if (this.steps.length === 0)\n return;\n this._createPortal();\n this.active = true;\n this.currentIndex = 0;\n this._updatePortalContent();\n this.emitStart();\n this._scrollAndPosition();\n }\n next() {\n if (this.currentIndex < this.steps.length - 1) {\n this.currentIndex++;\n this._updatePortalContent();\n this.emitStep();\n this._scrollAndPosition();\n }\n else {\n this.end();\n }\n }\n prev() {\n if (this.currentIndex > 0) {\n this.currentIndex--;\n this._updatePortalContent();\n this.emitStep();\n this._scrollAndPosition();\n }\n }\n goToStep(index) {\n if (index >= 0 && index < this.steps.length) {\n this.currentIndex = index;\n if (!this.active) {\n this._createPortal();\n this.active = true;\n }\n this._updatePortalContent();\n this.emitStep();\n this._scrollAndPosition();\n }\n }\n end() {\n this.active = false;\n this.currentIndex = -1;\n this._removePortal();\n this.emitEnd();\n }\n skip() {\n this.emitSkip();\n this.end();\n }\n template() {\n // The overlay UI lives in the portal on document.body.\n // The component itself renders nothing visible.\n return html ``;\n }\n componentStyles() {\n return css `:host { display: none; }`;\n }\n });\n return _classThis;\n})();\n\nexport { SniceSpotlight };\n//# sourceMappingURL=snice-spotlight.js.map\n"],"names":["element","property","dispatch","dispose","render","styles","html","css"],"mappings":"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","x_google_ignoreList":[0]}
@@ -0,0 +1,8 @@
1
+ /*!
2
+ * snice v4.9.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-spotlight.min.js");var SniceSpotlight=function(t,e){"use strict";function i(t,e,i,n,r,s){function o(t){if(void 0!==t&&"function"!=typeof t)throw new TypeError("Function expected");return t}for(var a,c=n.kind,l="getter"===c?"get":"setter"===c?"set":"value",p=!e&&t?n.static?t:t.prototype:null,d=e||(p?Object.getOwnPropertyDescriptor(p,n.name):{}),h=!1,m=i.length-1;m>=0;m--){var u={};for(var v in n)u[v]="access"===v?{}:n[v];for(var v in n.access)u.access[v]=n.access[v];u.addInitializer=function(t){if(h)throw new TypeError("Cannot add initializers after decoration has completed");s.push(o(t||null))};var g=(0,i[m])("accessor"===c?{get:d.get,set:d.set}:d[l],u);if("accessor"===c){if(void 0===g)continue;if(null===g||"object"!=typeof g)throw new TypeError("Object expected");(a=o(g.get))&&(d.get=a),(a=o(g.set))&&(d.set=a),(a=o(g.init))&&r.unshift(a)}else(a=o(g))&&("field"===c?r.unshift(a):d[l]=a)}p&&Object.defineProperty(p,n.name,d),h=!0}function n(t,e,i){for(var n=arguments.length>2,r=0;r<e.length;r++)i=n?e[r].call(t,i):e[r].call(t);return n?i:void 0}"function"==typeof SuppressedError&&SuppressedError;let r=(()=>{let t,r,s,o,a,c,l,p,d,h,m,u,v=[e.element("snice-spotlight")],g=[],b=HTMLElement,x=[],f=[],y=[],k=[],_=[],w=[],S=[];return class extends b{static{r=this}constructor(){super(...arguments),this.steps=(n(this,x),n(this,f,[])),this.currentIndex=(n(this,y),n(this,k,-1)),this.active=(n(this,_),n(this,w,!1)),this._portal=(n(this,S),null),this._cutoutEl=null,this._popoverEl=null,this._scrollHandler=null,this._resizeHandler=null}static{const E="function"==typeof Symbol&&Symbol.metadata?Object.create(b[Symbol.metadata]??null):void 0;s=[e.property({type:Array})],o=[e.property({type:Number})],a=[e.property({type:Boolean})],c=[e.dispatch("spotlight-start",{bubbles:!0,composed:!0})],l=[e.dispatch("spotlight-step",{bubbles:!0,composed:!0})],p=[e.dispatch("spotlight-end",{bubbles:!0,composed:!0})],d=[e.dispatch("spotlight-skip",{bubbles:!0,composed:!0})],h=[e.dispose()],m=[e.render()],u=[e.styles()],i(this,null,c,{kind:"method",name:"emitStart",static:!1,private:!1,access:{has:t=>"emitStart"in t,get:t=>t.emitStart},metadata:E},null,x),i(this,null,l,{kind:"method",name:"emitStep",static:!1,private:!1,access:{has:t=>"emitStep"in t,get:t=>t.emitStep},metadata:E},null,x),i(this,null,p,{kind:"method",name:"emitEnd",static:!1,private:!1,access:{has:t=>"emitEnd"in t,get:t=>t.emitEnd},metadata:E},null,x),i(this,null,d,{kind:"method",name:"emitSkip",static:!1,private:!1,access:{has:t=>"emitSkip"in t,get:t=>t.emitSkip},metadata:E},null,x),i(this,null,h,{kind:"method",name:"cleanup",static:!1,private:!1,access:{has:t=>"cleanup"in t,get:t=>t.cleanup},metadata:E},null,x),i(this,null,m,{kind:"method",name:"template",static:!1,private:!1,access:{has:t=>"template"in t,get:t=>t.template},metadata:E},null,x),i(this,null,u,{kind:"method",name:"componentStyles",static:!1,private:!1,access:{has:t=>"componentStyles"in t,get:t=>t.componentStyles},metadata:E},null,x),i(null,null,s,{kind:"field",name:"steps",static:!1,private:!1,access:{has:t=>"steps"in t,get:t=>t.steps,set:(t,e)=>{t.steps=e}},metadata:E},f,y),i(null,null,o,{kind:"field",name:"currentIndex",static:!1,private:!1,access:{has:t=>"currentIndex"in t,get:t=>t.currentIndex,set:(t,e)=>{t.currentIndex=e}},metadata:E},k,_),i(null,null,a,{kind:"field",name:"active",static:!1,private:!1,access:{has:t=>"active"in t,get:t=>t.active,set:(t,e)=>{t.active=e}},metadata:E},w,S),i(null,t={value:r},v,{kind:"class",name:r.name,metadata:E},null,g),r=t.value,E&&Object.defineProperty(r,Symbol.metadata,{enumerable:!0,configurable:!0,writable:!0,value:E}),n(r,g)}emitStart(){}emitStep(){return{index:this.currentIndex,step:this.steps[this.currentIndex]}}emitEnd(){}emitSkip(){return{index:this.currentIndex}}cleanup(){this._removePortal()}_createPortal(){if(this._portal)return;const t=document.createElement("div");t.setAttribute("data-snice-spotlight-portal",""),t.innerHTML='\n <style>:host{font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, \'Segoe UI\', Roboto, Helvetica, Arial, sans-serif)}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9998;pointer-events:none}.overlay[hidden]{display:none}.backdrop{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:auto}.cutout{position:fixed;background:0 0;box-shadow:0 0 0 9999px rgb(0 0 0 / .5);border-radius:4px;z-index:9999;pointer-events:none;transition:top var(--snice-transition-medium, 250ms) ease,left var(--snice-transition-medium, 250ms) ease,width var(--snice-transition-medium, 250ms) ease,height var(--snice-transition-medium, 250ms) ease}.popover{position:fixed;z-index:10000;background:var(--snice-color-background,rgb(255 255 255));border:1px solid var(--snice-color-border,rgb(226 226 226));border-radius:var(--snice-border-radius-lg,.5rem);box-shadow:var(--snice-shadow-lg,0 10px 15px -3px rgb(0 0 0 / .1),0 4px 6px -4px rgb(0 0 0 / .1));padding:var(--snice-spacing-md,1rem);max-width:20rem;min-width:15rem;pointer-events:auto;color:var(--snice-color-text,rgb(23 23 23))}.popover[hidden]{display:none}.popover-title{font-size:var(--snice-font-size-lg, 1.125rem);font-weight:var(--snice-font-weight-semibold,600);margin-bottom:var(--snice-spacing-2xs,.25rem)}.popover-description{font-size:var(--snice-font-size-md, 1rem);color:var(--snice-color-text-secondary,rgb(82 82 82));line-height:var(--snice-line-height-normal, 1.5);margin-bottom:var(--snice-spacing-sm,.75rem)}.popover-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--snice-spacing-xs,.5rem)}.step-indicator{font-size:var(--snice-font-size-sm, .875rem);color:var(--snice-color-text-tertiary,rgb(115 115 115))}.popover-actions{display:flex;gap:var(--snice-spacing-2xs,.25rem)}.btn{padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-sm,.75rem);border-radius:var(--snice-border-radius-md,.25rem);font-size:var(--snice-font-size-sm, .875rem);cursor:pointer;border:1px solid var(--snice-color-border,rgb(226 226 226));background:var(--snice-color-background,rgb(255 255 255));color:var(--snice-color-text,rgb(23 23 23));font-family:inherit}.btn:hover{background:var(--snice-color-background-element,rgb(252 251 249))}.btn-primary{background:var(--snice-color-primary,rgb(37 99 235));color:var(--snice-color-text-inverse,rgb(250 250 250));border-color:var(--snice-color-primary,rgb(37 99 235))}.btn-primary:hover{opacity:.9}.btn-skip{border:none;background:0 0;color:var(--snice-color-text-tertiary,rgb(115 115 115));padding:var(--snice-spacing-2xs,.25rem)}.btn-skip:hover{color:var(--snice-color-text,rgb(23 23 23))}\n [data-snice-spotlight-portal] { font-family: var(--snice-font-family, -apple-system, BlinkMacSystemFont, \'Segoe UI\', Roboto, Helvetica, Arial, sans-serif); }\n [data-snice-spotlight-portal] .overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9998; pointer-events: none; }\n [data-snice-spotlight-portal] .backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; pointer-events: auto; }\n [data-snice-spotlight-portal] .cutout { position: fixed; background: transparent; box-shadow: 0 0 0 9999px rgb(0 0 0 / 0.5); border-radius: 4px; z-index: 9999; pointer-events: none; transition: top var(--snice-transition-medium, 250ms) ease, left var(--snice-transition-medium, 250ms) ease, width var(--snice-transition-medium, 250ms) ease, height var(--snice-transition-medium, 250ms) ease; }\n [data-snice-spotlight-portal] .popover { position: fixed; z-index: 10000; background: var(--snice-color-background, rgb(255 255 255)); border: 1px solid var(--snice-color-border, rgb(226 226 226)); border-radius: var(--snice-border-radius-lg, 0.5rem); box-shadow: var(--snice-shadow-lg, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)); padding: var(--snice-spacing-md, 1rem); max-width: 20rem; min-width: 15rem; pointer-events: auto; color: var(--snice-color-text, rgb(23 23 23)); }\n [data-snice-spotlight-portal] .popover-title { font-size: var(--snice-font-size-lg, 1.125rem); font-weight: var(--snice-font-weight-semibold, 600); margin-bottom: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .popover-description { font-size: var(--snice-font-size-md, 1rem); color: var(--snice-color-text-secondary, rgb(82 82 82)); line-height: var(--snice-line-height-normal, 1.5); margin-bottom: var(--snice-spacing-sm, 0.75rem); }\n [data-snice-spotlight-portal] .popover-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--snice-spacing-xs, 0.5rem); }\n [data-snice-spotlight-portal] .step-indicator { font-size: var(--snice-font-size-sm, 0.875rem); color: var(--snice-color-text-tertiary, rgb(115 115 115)); }\n [data-snice-spotlight-portal] .popover-actions { display: flex; gap: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .btn { padding: var(--snice-spacing-2xs, 0.25rem) var(--snice-spacing-sm, 0.75rem); border-radius: var(--snice-border-radius-md, 0.25rem); font-size: var(--snice-font-size-sm, 0.875rem); cursor: pointer; border: 1px solid var(--snice-color-border, rgb(226 226 226)); background: var(--snice-color-background, rgb(255 255 255)); color: var(--snice-color-text, rgb(23 23 23)); font-family: inherit; }\n [data-snice-spotlight-portal] .btn:hover { background: var(--snice-color-background-element, rgb(252 251 249)); }\n [data-snice-spotlight-portal] .btn-primary { background: var(--snice-color-primary, rgb(37 99 235)); color: var(--snice-color-text-inverse, rgb(250 250 250)); border-color: var(--snice-color-primary, rgb(37 99 235)); }\n [data-snice-spotlight-portal] .btn-primary:hover { opacity: 0.9; }\n [data-snice-spotlight-portal] .btn-skip { border: none; background: none; color: var(--snice-color-text-tertiary, rgb(115 115 115)); padding: var(--snice-spacing-2xs, 0.25rem); }\n [data-snice-spotlight-portal] .btn-skip:hover { color: var(--snice-color-text, rgb(23 23 23)); }\n </style>\n <div class="overlay">\n <div class="backdrop"></div>\n <div class="cutout"></div>\n <div class="popover">\n <div class="popover-title"></div>\n <div class="popover-description"></div>\n <div class="popover-footer">\n <span class="step-indicator"></span>\n <div class="popover-actions"></div>\n </div>\n </div>\n </div>\n ';const e=t.querySelector(".backdrop");e?.addEventListener("click",()=>this.skip()),this._portal=t,this._cutoutEl=t.querySelector(".cutout"),this._popoverEl=t.querySelector(".popover"),document.body.appendChild(t),this._scrollHandler=()=>this._updatePosition(),this._resizeHandler=()=>this._updatePosition(),window.addEventListener("scroll",this._scrollHandler,!0),window.addEventListener("resize",this._resizeHandler)}_removePortal(){this._scrollHandler&&(window.removeEventListener("scroll",this._scrollHandler,!0),this._scrollHandler=null),this._resizeHandler&&(window.removeEventListener("resize",this._resizeHandler),this._resizeHandler=null),this._portal&&(this._portal.remove(),this._portal=null,this._cutoutEl=null,this._popoverEl=null)}_updatePortalContent(){if(!this._portal)return;const t=this.currentIndex>=0?this.steps[this.currentIndex]:null,e=this.currentIndex===this.steps.length-1,i=0===this.currentIndex,n=this._portal.querySelector(".popover-title"),r=this._portal.querySelector(".popover-description"),s=this._portal.querySelector(".step-indicator"),o=this._portal.querySelector(".popover-actions"),a=this._popoverEl;if(t&&a&&(a.style.display="",n&&(n.textContent=t.title),r&&(r.textContent=t.description),s&&(s.textContent=`${this.currentIndex+1} / ${this.steps.length}`),o)){o.innerHTML="";const t=document.createElement("button");if(t.className="btn btn-skip",t.textContent="Skip",t.addEventListener("click",()=>this.skip()),o.appendChild(t),!i){const t=document.createElement("button");t.className="btn",t.textContent="Back",t.addEventListener("click",()=>this.prev()),o.appendChild(t)}const n=document.createElement("button");n.className="btn btn-primary",n.textContent=e?"Done":"Next",n.addEventListener("click",()=>this.next()),o.appendChild(n)}}_updatePosition(){if(this.currentIndex<0||!this.steps[this.currentIndex])return;if(!this._cutoutEl||!this._popoverEl)return;const t=this.steps[this.currentIndex],e=document.querySelector(t.target);if(!e)return;const i=e.getBoundingClientRect();this._cutoutEl.style.top=i.top-8+"px",this._cutoutEl.style.left=i.left-8+"px",this._cutoutEl.style.width=`${i.width+16}px`,this._cutoutEl.style.height=`${i.height+16}px`;const n=t.position||"auto";this._positionPopover(i,n,8)}_positionPopover(t,e,i){const n=this._popoverEl;if(!n)return;n.style.top="",n.style.left="",n.style.bottom="",n.style.right="";let r=e;if("auto"===r){const e=window.innerHeight-t.bottom,i=t.top;r=e>200?"bottom":i>200?"top":"bottom"}switch(r){case"bottom":n.style.top=`${t.bottom+i+12}px`,n.style.left=`${Math.max(8,t.left)}px`;break;case"top":n.style.bottom=`${window.innerHeight-t.top+i+12}px`,n.style.left=`${Math.max(8,t.left)}px`;break;case"left":n.style.top=`${t.top}px`,n.style.right=`${window.innerWidth-t.left+i+12}px`;break;case"right":n.style.top=`${t.top}px`,n.style.left=`${t.right+i+12}px`}}_scrollAndPosition(){if(this.currentIndex<0||!this.steps[this.currentIndex])return;const t=this.steps[this.currentIndex],e=document.querySelector(t.target);e&&(e.scrollIntoView({behavior:"instant",block:"center"}),requestAnimationFrame(()=>this._updatePosition()))}start(){0!==this.steps.length&&(this._createPortal(),this.active=!0,this.currentIndex=0,this._updatePortalContent(),this.emitStart(),this._scrollAndPosition())}next(){this.currentIndex<this.steps.length-1?(this.currentIndex++,this._updatePortalContent(),this.emitStep(),this._scrollAndPosition()):this.end()}prev(){this.currentIndex>0&&(this.currentIndex--,this._updatePortalContent(),this.emitStep(),this._scrollAndPosition())}goToStep(t){t>=0&&t<this.steps.length&&(this.currentIndex=t,this.active||(this._createPortal(),this.active=!0),this._updatePortalContent(),this.emitStep(),this._scrollAndPosition())}end(){this.active=!1,this.currentIndex=-1,this._removePortal(),this.emitEnd()}skip(){this.emitSkip(),this.end()}template(){return e.html``}componentStyles(){return e.css`:host { display: none; }`}},r})();return t.SniceSpotlight=r,t}({},Snice);
8
+ //# sourceMappingURL=snice-spotlight.min.js.map