snice 4.8.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 (864) 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/camera-annotate.d.ts +27 -0
  12. package/adapters/react/camera-annotate.d.ts.map +1 -0
  13. package/adapters/react/camera-annotate.js +24 -0
  14. package/adapters/react/camera-annotate.js.map +1 -0
  15. package/adapters/react/camera-annotate.tsx +35 -0
  16. package/adapters/react/candlestick.d.ts +34 -0
  17. package/adapters/react/candlestick.d.ts.map +1 -0
  18. package/adapters/react/candlestick.js +24 -0
  19. package/adapters/react/candlestick.js.map +1 -0
  20. package/adapters/react/candlestick.tsx +42 -0
  21. package/adapters/react/comments.d.ts +29 -0
  22. package/adapters/react/comments.d.ts.map +1 -0
  23. package/adapters/react/comments.js +24 -0
  24. package/adapters/react/comments.js.map +1 -0
  25. package/adapters/react/comments.tsx +37 -0
  26. package/adapters/react/components.d.ts +66 -0
  27. package/adapters/react/components.d.ts.map +1 -1
  28. package/adapters/react/components.js +33 -0
  29. package/adapters/react/components.js.map +1 -1
  30. package/adapters/react/components.ts +66 -0
  31. package/adapters/react/countdown.d.ts +31 -0
  32. package/adapters/react/countdown.d.ts.map +1 -0
  33. package/adapters/react/countdown.js +24 -0
  34. package/adapters/react/countdown.js.map +1 -0
  35. package/adapters/react/countdown.tsx +39 -0
  36. package/adapters/react/cropper.d.ts +29 -0
  37. package/adapters/react/cropper.d.ts.map +1 -0
  38. package/adapters/react/cropper.js +24 -0
  39. package/adapters/react/cropper.js.map +1 -0
  40. package/adapters/react/cropper.tsx +37 -0
  41. package/adapters/react/diff.d.ts +31 -0
  42. package/adapters/react/diff.d.ts.map +1 -0
  43. package/adapters/react/diff.js +24 -0
  44. package/adapters/react/diff.js.map +1 -0
  45. package/adapters/react/diff.tsx +39 -0
  46. package/adapters/react/flip-card.d.ts +28 -0
  47. package/adapters/react/flip-card.d.ts.map +1 -0
  48. package/adapters/react/flip-card.js +24 -0
  49. package/adapters/react/flip-card.js.map +1 -0
  50. package/adapters/react/flip-card.tsx +36 -0
  51. package/adapters/react/flow.d.ts +32 -0
  52. package/adapters/react/flow.d.ts.map +1 -0
  53. package/adapters/react/flow.js +24 -0
  54. package/adapters/react/flow.js.map +1 -0
  55. package/adapters/react/flow.tsx +40 -0
  56. package/adapters/react/funnel.d.ts +31 -0
  57. package/adapters/react/funnel.d.ts.map +1 -0
  58. package/adapters/react/funnel.js +24 -0
  59. package/adapters/react/funnel.js.map +1 -0
  60. package/adapters/react/funnel.tsx +39 -0
  61. package/adapters/react/gantt.d.ts +27 -0
  62. package/adapters/react/gantt.d.ts.map +1 -0
  63. package/adapters/react/gantt.js +24 -0
  64. package/adapters/react/gantt.js.map +1 -0
  65. package/adapters/react/gantt.tsx +35 -0
  66. package/adapters/react/map.d.ts +30 -0
  67. package/adapters/react/map.d.ts.map +1 -0
  68. package/adapters/react/map.js +24 -0
  69. package/adapters/react/map.js.map +1 -0
  70. package/adapters/react/map.tsx +38 -0
  71. package/adapters/react/markdown.d.ts +26 -0
  72. package/adapters/react/markdown.d.ts.map +1 -0
  73. package/adapters/react/markdown.js +24 -0
  74. package/adapters/react/markdown.js.map +1 -0
  75. package/adapters/react/markdown.tsx +34 -0
  76. package/adapters/react/network-graph.d.ts +32 -0
  77. package/adapters/react/network-graph.d.ts.map +1 -0
  78. package/adapters/react/network-graph.js +24 -0
  79. package/adapters/react/network-graph.js.map +1 -0
  80. package/adapters/react/network-graph.tsx +40 -0
  81. package/adapters/react/notification-center.d.ts +26 -0
  82. package/adapters/react/notification-center.d.ts.map +1 -0
  83. package/adapters/react/notification-center.js +24 -0
  84. package/adapters/react/notification-center.js.map +1 -0
  85. package/adapters/react/notification-center.tsx +34 -0
  86. package/adapters/react/org-chart.d.ts +28 -0
  87. package/adapters/react/org-chart.d.ts.map +1 -0
  88. package/adapters/react/org-chart.js +24 -0
  89. package/adapters/react/org-chart.js.map +1 -0
  90. package/adapters/react/org-chart.tsx +36 -0
  91. package/adapters/react/pdf-viewer.d.ts +28 -0
  92. package/adapters/react/pdf-viewer.d.ts.map +1 -0
  93. package/adapters/react/pdf-viewer.js +24 -0
  94. package/adapters/react/pdf-viewer.js.map +1 -0
  95. package/adapters/react/pdf-viewer.tsx +36 -0
  96. package/adapters/react/podcast-player.d.ts +40 -0
  97. package/adapters/react/podcast-player.d.ts.map +1 -0
  98. package/adapters/react/podcast-player.js +24 -0
  99. package/adapters/react/podcast-player.js.map +1 -0
  100. package/adapters/react/podcast-player.tsx +48 -0
  101. package/adapters/react/pricing-table.d.ts +27 -0
  102. package/adapters/react/pricing-table.d.ts.map +1 -0
  103. package/adapters/react/pricing-table.js +24 -0
  104. package/adapters/react/pricing-table.js.map +1 -0
  105. package/adapters/react/pricing-table.tsx +35 -0
  106. package/adapters/react/rating.d.ts +30 -0
  107. package/adapters/react/rating.d.ts.map +1 -0
  108. package/adapters/react/rating.js +24 -0
  109. package/adapters/react/rating.js.map +1 -0
  110. package/adapters/react/rating.tsx +38 -0
  111. package/adapters/react/recipe.d.ts +43 -0
  112. package/adapters/react/recipe.d.ts.map +1 -0
  113. package/adapters/react/recipe.js +24 -0
  114. package/adapters/react/recipe.js.map +1 -0
  115. package/adapters/react/recipe.tsx +51 -0
  116. package/adapters/react/sankey.d.ts +31 -0
  117. package/adapters/react/sankey.d.ts.map +1 -0
  118. package/adapters/react/sankey.js +24 -0
  119. package/adapters/react/sankey.js.map +1 -0
  120. package/adapters/react/sankey.tsx +39 -0
  121. package/adapters/react/sortable.d.ts +28 -0
  122. package/adapters/react/sortable.d.ts.map +1 -0
  123. package/adapters/react/sortable.js +24 -0
  124. package/adapters/react/sortable.js.map +1 -0
  125. package/adapters/react/sortable.tsx +36 -0
  126. package/adapters/react/spotlight.d.ts +27 -0
  127. package/adapters/react/spotlight.d.ts.map +1 -0
  128. package/adapters/react/spotlight.js +24 -0
  129. package/adapters/react/spotlight.js.map +1 -0
  130. package/adapters/react/spotlight.tsx +35 -0
  131. package/adapters/react/spreadsheet.d.ts +27 -0
  132. package/adapters/react/spreadsheet.d.ts.map +1 -0
  133. package/adapters/react/spreadsheet.js +24 -0
  134. package/adapters/react/spreadsheet.js.map +1 -0
  135. package/adapters/react/spreadsheet.tsx +35 -0
  136. package/adapters/react/tag-input.d.ts +33 -0
  137. package/adapters/react/tag-input.d.ts.map +1 -0
  138. package/adapters/react/tag-input.js +24 -0
  139. package/adapters/react/tag-input.js.map +1 -0
  140. package/adapters/react/tag-input.tsx +41 -0
  141. package/adapters/react/testimonial.d.ts +31 -0
  142. package/adapters/react/testimonial.d.ts.map +1 -0
  143. package/adapters/react/testimonial.js +24 -0
  144. package/adapters/react/testimonial.js.map +1 -0
  145. package/adapters/react/testimonial.tsx +39 -0
  146. package/adapters/react/time-range-picker.d.ts +33 -0
  147. package/adapters/react/time-range-picker.d.ts.map +1 -0
  148. package/adapters/react/time-range-picker.js +24 -0
  149. package/adapters/react/time-range-picker.js.map +1 -0
  150. package/adapters/react/time-range-picker.tsx +41 -0
  151. package/adapters/react/treemap.d.ts +30 -0
  152. package/adapters/react/treemap.d.ts.map +1 -0
  153. package/adapters/react/treemap.js +24 -0
  154. package/adapters/react/treemap.js.map +1 -0
  155. package/adapters/react/treemap.tsx +38 -0
  156. package/adapters/react/video-player.d.ts +34 -0
  157. package/adapters/react/video-player.d.ts.map +1 -0
  158. package/adapters/react/video-player.js +24 -0
  159. package/adapters/react/video-player.js.map +1 -0
  160. package/adapters/react/video-player.tsx +42 -0
  161. package/adapters/react/virtual-scroller.d.ts +1 -0
  162. package/adapters/react/virtual-scroller.d.ts.map +1 -1
  163. package/adapters/react/virtual-scroller.js +1 -1
  164. package/adapters/react/virtual-scroller.js.map +1 -1
  165. package/adapters/react/virtual-scroller.tsx +2 -1
  166. package/adapters/react/waterfall.d.ts +29 -0
  167. package/adapters/react/waterfall.d.ts.map +1 -0
  168. package/adapters/react/waterfall.js +24 -0
  169. package/adapters/react/waterfall.js.map +1 -0
  170. package/adapters/react/waterfall.tsx +37 -0
  171. package/adapters/react/weather.d.ts +27 -0
  172. package/adapters/react/weather.d.ts.map +1 -0
  173. package/adapters/react/weather.js +24 -0
  174. package/adapters/react/weather.js.map +1 -0
  175. package/adapters/react/weather.tsx +35 -0
  176. package/dist/cdn/accordion/snice-accordion.js +1 -1
  177. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  178. package/dist/cdn/alert/snice-alert.js +1 -1
  179. package/dist/cdn/alert/snice-alert.min.js +1 -1
  180. package/dist/cdn/app-tiles/README.md +27 -0
  181. package/dist/cdn/app-tiles/snice-app-tiles.js +333 -0
  182. package/dist/cdn/app-tiles/snice-app-tiles.js.map +1 -0
  183. package/dist/cdn/app-tiles/snice-app-tiles.min.js +11 -0
  184. package/dist/cdn/app-tiles/snice-app-tiles.min.js.map +1 -0
  185. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  186. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  187. package/dist/cdn/avatar/snice-avatar.js +1 -1
  188. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  189. package/dist/cdn/badge/snice-badge.js +1 -1
  190. package/dist/cdn/badge/snice-badge.min.js +1 -1
  191. package/dist/cdn/banner/snice-banner.js +1 -1
  192. package/dist/cdn/banner/snice-banner.min.js +1 -1
  193. package/dist/cdn/book/README.md +27 -0
  194. package/dist/cdn/book/snice-book.js +353 -0
  195. package/dist/cdn/book/snice-book.js.map +1 -0
  196. package/dist/cdn/book/snice-book.min.js +13 -0
  197. package/dist/cdn/book/snice-book.min.js.map +1 -0
  198. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +2 -2
  199. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js.map +1 -1
  200. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +13 -13
  201. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js.map +1 -1
  202. package/dist/cdn/button/snice-button.js +1 -1
  203. package/dist/cdn/button/snice-button.min.js +1 -1
  204. package/dist/cdn/calendar/snice-calendar.js +1 -1
  205. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  206. package/dist/cdn/camera/snice-camera.js +1 -1
  207. package/dist/cdn/camera/snice-camera.min.js +1 -1
  208. package/dist/cdn/camera-annotate/README.md +27 -0
  209. package/dist/cdn/camera-annotate/snice-camera-annotate.js +730 -0
  210. package/dist/cdn/camera-annotate/snice-camera-annotate.js.map +1 -0
  211. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +144 -0
  212. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js.map +1 -0
  213. package/dist/cdn/candlestick/README.md +27 -0
  214. package/dist/cdn/candlestick/snice-candlestick.js +717 -0
  215. package/dist/cdn/candlestick/snice-candlestick.js.map +1 -0
  216. package/dist/cdn/candlestick/snice-candlestick.min.js +22 -0
  217. package/dist/cdn/candlestick/snice-candlestick.min.js.map +1 -0
  218. package/dist/cdn/card/snice-card.js +1 -1
  219. package/dist/cdn/card/snice-card.min.js +1 -1
  220. package/dist/cdn/carousel/snice-carousel.js +1 -1
  221. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  222. package/dist/cdn/chart/snice-chart.js +1 -1
  223. package/dist/cdn/chart/snice-chart.min.js +1 -1
  224. package/dist/cdn/chat/snice-chat.js +1 -1
  225. package/dist/cdn/chat/snice-chat.min.js +1 -1
  226. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  227. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  228. package/dist/cdn/chip/snice-chip.js +1 -1
  229. package/dist/cdn/chip/snice-chip.min.js +1 -1
  230. package/dist/cdn/code-block/snice-code-block.js +1 -1
  231. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  232. package/dist/cdn/color-display/snice-color-display.js +1 -1
  233. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  234. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  235. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  236. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  237. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  238. package/dist/cdn/comments/README.md +27 -0
  239. package/dist/cdn/comments/snice-comments.js +544 -0
  240. package/dist/cdn/comments/snice-comments.js.map +1 -0
  241. package/dist/cdn/comments/snice-comments.min.js +100 -0
  242. package/dist/cdn/comments/snice-comments.min.js.map +1 -0
  243. package/dist/cdn/countdown/README.md +27 -0
  244. package/dist/cdn/countdown/snice-countdown.js +235 -0
  245. package/dist/cdn/countdown/snice-countdown.js.map +1 -0
  246. package/dist/cdn/countdown/snice-countdown.min.js +14 -0
  247. package/dist/cdn/countdown/snice-countdown.min.js.map +1 -0
  248. package/dist/cdn/cropper/README.md +27 -0
  249. package/dist/cdn/cropper/snice-cropper.js +352 -0
  250. package/dist/cdn/cropper/snice-cropper.js.map +1 -0
  251. package/dist/cdn/cropper/snice-cropper.min.js +25 -0
  252. package/dist/cdn/cropper/snice-cropper.min.js.map +1 -0
  253. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  254. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  255. package/dist/cdn/diff/README.md +27 -0
  256. package/dist/cdn/diff/snice-diff.js +441 -0
  257. package/dist/cdn/diff/snice-diff.js.map +1 -0
  258. package/dist/cdn/diff/snice-diff.min.js +54 -0
  259. package/dist/cdn/diff/snice-diff.min.js.map +1 -0
  260. package/dist/cdn/divider/snice-divider.js +1 -1
  261. package/dist/cdn/divider/snice-divider.min.js +1 -1
  262. package/dist/cdn/doc/snice-doc.js +1 -1
  263. package/dist/cdn/doc/snice-doc.min.js +1 -1
  264. package/dist/cdn/draw/snice-draw.js +1 -1
  265. package/dist/cdn/draw/snice-draw.min.js +1 -1
  266. package/dist/cdn/drawer/snice-drawer.js +1 -1
  267. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  268. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  269. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  270. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  271. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  272. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  273. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  274. package/dist/cdn/flip-card/README.md +27 -0
  275. package/dist/cdn/flip-card/snice-flip-card.js +183 -0
  276. package/dist/cdn/flip-card/snice-flip-card.js.map +1 -0
  277. package/dist/cdn/flip-card/snice-flip-card.min.js +22 -0
  278. package/dist/cdn/flip-card/snice-flip-card.min.js.map +1 -0
  279. package/dist/cdn/flow/README.md +27 -0
  280. package/dist/cdn/flow/snice-flow.js +822 -0
  281. package/dist/cdn/flow/snice-flow.js.map +1 -0
  282. package/dist/cdn/flow/snice-flow.min.js +17 -0
  283. package/dist/cdn/flow/snice-flow.min.js.map +1 -0
  284. package/dist/cdn/funnel/README.md +27 -0
  285. package/dist/cdn/funnel/snice-funnel.js +424 -0
  286. package/dist/cdn/funnel/snice-funnel.js.map +1 -0
  287. package/dist/cdn/funnel/snice-funnel.min.js +20 -0
  288. package/dist/cdn/funnel/snice-funnel.min.js.map +1 -0
  289. package/dist/cdn/gantt/README.md +27 -0
  290. package/dist/cdn/gantt/snice-gantt.js +436 -0
  291. package/dist/cdn/gantt/snice-gantt.js.map +1 -0
  292. package/dist/cdn/gantt/snice-gantt.min.js +60 -0
  293. package/dist/cdn/gantt/snice-gantt.min.js.map +1 -0
  294. package/dist/cdn/gauge/snice-gauge.js +1 -1
  295. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  296. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  297. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  298. package/dist/cdn/image/snice-image.js +1 -1
  299. package/dist/cdn/image/snice-image.min.js +1 -1
  300. package/dist/cdn/input/snice-input.js +1 -1
  301. package/dist/cdn/input/snice-input.min.js +1 -1
  302. package/dist/cdn/kanban/snice-kanban.js +1 -1
  303. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  304. package/dist/cdn/kpi/snice-kpi.js +1 -1
  305. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  306. package/dist/cdn/layout/README.md +2 -2
  307. package/dist/cdn/layout/snice-layout.js +23 -6
  308. package/dist/cdn/layout/snice-layout.js.map +1 -1
  309. package/dist/cdn/layout/snice-layout.min.js +2 -2
  310. package/dist/cdn/layout/snice-layout.min.js.map +1 -1
  311. package/dist/cdn/link/snice-link.js +1 -1
  312. package/dist/cdn/link/snice-link.min.js +1 -1
  313. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  314. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  315. package/dist/cdn/list/README.md +6 -2
  316. package/dist/cdn/list/snice-list.js +87 -10
  317. package/dist/cdn/list/snice-list.js.map +1 -1
  318. package/dist/cdn/list/snice-list.min.js +20 -6
  319. package/dist/cdn/list/snice-list.min.js.map +1 -1
  320. package/dist/cdn/location/snice-location.js +1 -1
  321. package/dist/cdn/location/snice-location.min.js +1 -1
  322. package/dist/cdn/login/snice-login.js +1 -1
  323. package/dist/cdn/login/snice-login.min.js +1 -1
  324. package/dist/cdn/map/README.md +27 -0
  325. package/dist/cdn/map/snice-map.js +415 -0
  326. package/dist/cdn/map/snice-map.js.map +1 -0
  327. package/dist/cdn/map/snice-map.min.js +52 -0
  328. package/dist/cdn/map/snice-map.min.js.map +1 -0
  329. package/dist/cdn/markdown/README.md +27 -0
  330. package/dist/cdn/markdown/snice-markdown.js +317 -0
  331. package/dist/cdn/markdown/snice-markdown.js.map +1 -0
  332. package/dist/cdn/markdown/snice-markdown.min.js +11 -0
  333. package/dist/cdn/markdown/snice-markdown.min.js.map +1 -0
  334. package/dist/cdn/masonry/snice-masonry.js +1 -1
  335. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  336. package/dist/cdn/menu/snice-menu.js +1 -1
  337. package/dist/cdn/menu/snice-menu.min.js +1 -1
  338. package/dist/cdn/modal/snice-modal.js +1 -1
  339. package/dist/cdn/modal/snice-modal.min.js +1 -1
  340. package/dist/cdn/music-player/snice-music-player.js +1 -1
  341. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  342. package/dist/cdn/nav/README.md +2 -2
  343. package/dist/cdn/nav/snice-nav.js +23 -6
  344. package/dist/cdn/nav/snice-nav.js.map +1 -1
  345. package/dist/cdn/nav/snice-nav.min.js +2 -2
  346. package/dist/cdn/nav/snice-nav.min.js.map +1 -1
  347. package/dist/cdn/network-graph/README.md +27 -0
  348. package/dist/cdn/network-graph/snice-network-graph.js +788 -0
  349. package/dist/cdn/network-graph/snice-network-graph.js.map +1 -0
  350. package/dist/cdn/network-graph/snice-network-graph.min.js +13 -0
  351. package/dist/cdn/network-graph/snice-network-graph.min.js.map +1 -0
  352. package/dist/cdn/notification-center/README.md +27 -0
  353. package/dist/cdn/notification-center/snice-notification-center.js +204 -0
  354. package/dist/cdn/notification-center/snice-notification-center.js.map +1 -0
  355. package/dist/cdn/notification-center/snice-notification-center.min.js +33 -0
  356. package/dist/cdn/notification-center/snice-notification-center.min.js.map +1 -0
  357. package/dist/cdn/org-chart/README.md +27 -0
  358. package/dist/cdn/org-chart/snice-org-chart.js +294 -0
  359. package/dist/cdn/org-chart/snice-org-chart.js.map +1 -0
  360. package/dist/cdn/org-chart/snice-org-chart.min.js +32 -0
  361. package/dist/cdn/org-chart/snice-org-chart.min.js.map +1 -0
  362. package/dist/cdn/pagination/README.md +2 -2
  363. package/dist/cdn/pagination/snice-pagination.js +13 -13
  364. package/dist/cdn/pagination/snice-pagination.js.map +1 -1
  365. package/dist/cdn/pagination/snice-pagination.min.js +14 -14
  366. package/dist/cdn/pagination/snice-pagination.min.js.map +1 -1
  367. package/dist/cdn/paint/snice-paint.js +1 -1
  368. package/dist/cdn/paint/snice-paint.min.js +1 -1
  369. package/dist/cdn/pdf-viewer/README.md +27 -0
  370. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js +594 -0
  371. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  372. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js +88 -0
  373. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js.map +1 -0
  374. package/dist/cdn/podcast-player/README.md +27 -0
  375. package/dist/cdn/podcast-player/snice-podcast-player.js +835 -0
  376. package/dist/cdn/podcast-player/snice-podcast-player.js.map +1 -0
  377. package/dist/cdn/podcast-player/snice-podcast-player.min.js +209 -0
  378. package/dist/cdn/podcast-player/snice-podcast-player.min.js.map +1 -0
  379. package/dist/cdn/pricing-table/README.md +27 -0
  380. package/dist/cdn/pricing-table/snice-pricing-table.js +491 -0
  381. package/dist/cdn/pricing-table/snice-pricing-table.js.map +1 -0
  382. package/dist/cdn/pricing-table/snice-pricing-table.min.js +141 -0
  383. package/dist/cdn/pricing-table/snice-pricing-table.min.js.map +1 -0
  384. package/dist/cdn/progress/snice-progress.js +1 -1
  385. package/dist/cdn/progress/snice-progress.min.js +1 -1
  386. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  387. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  388. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  389. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  390. package/dist/cdn/radio/snice-radio.js +1 -1
  391. package/dist/cdn/radio/snice-radio.min.js +1 -1
  392. package/dist/cdn/rating/README.md +27 -0
  393. package/dist/cdn/rating/snice-rating.js +210 -0
  394. package/dist/cdn/rating/snice-rating.js.map +1 -0
  395. package/dist/cdn/rating/snice-rating.min.js +25 -0
  396. package/dist/cdn/rating/snice-rating.min.js.map +1 -0
  397. package/dist/cdn/recipe/README.md +27 -0
  398. package/dist/cdn/recipe/snice-recipe.js +619 -0
  399. package/dist/cdn/recipe/snice-recipe.js.map +1 -0
  400. package/dist/cdn/recipe/snice-recipe.min.js +185 -0
  401. package/dist/cdn/recipe/snice-recipe.min.js.map +1 -0
  402. package/dist/cdn/runtime/snice-runtime.esm.js +3 -3
  403. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  404. package/dist/cdn/runtime/snice-runtime.esm.min.js +3 -3
  405. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  406. package/dist/cdn/runtime/snice-runtime.js +3 -3
  407. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  408. package/dist/cdn/runtime/snice-runtime.min.js +3 -3
  409. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  410. package/dist/cdn/sankey/README.md +27 -0
  411. package/dist/cdn/sankey/snice-sankey.js +679 -0
  412. package/dist/cdn/sankey/snice-sankey.js.map +1 -0
  413. package/dist/cdn/sankey/snice-sankey.min.js +21 -0
  414. package/dist/cdn/sankey/snice-sankey.min.js.map +1 -0
  415. package/dist/cdn/select/snice-select.js +1 -1
  416. package/dist/cdn/select/snice-select.min.js +1 -1
  417. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  418. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  419. package/dist/cdn/slider/snice-slider.js +1 -1
  420. package/dist/cdn/slider/snice-slider.min.js +1 -1
  421. package/dist/cdn/sortable/README.md +27 -0
  422. package/dist/cdn/sortable/snice-sortable.js +254 -0
  423. package/dist/cdn/sortable/snice-sortable.js.map +1 -0
  424. package/dist/cdn/sortable/snice-sortable.min.js +12 -0
  425. package/dist/cdn/sortable/snice-sortable.min.js.map +1 -0
  426. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  427. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  428. package/dist/cdn/spinner/snice-spinner.js +1 -1
  429. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  430. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  431. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  432. package/dist/cdn/spotlight/README.md +27 -0
  433. package/dist/cdn/spotlight/snice-spotlight.js +397 -0
  434. package/dist/cdn/spotlight/snice-spotlight.js.map +1 -0
  435. package/dist/cdn/spotlight/snice-spotlight.min.js +8 -0
  436. package/dist/cdn/spotlight/snice-spotlight.min.js.map +1 -0
  437. package/dist/cdn/spreadsheet/README.md +27 -0
  438. package/dist/cdn/spreadsheet/snice-spreadsheet.js +1171 -0
  439. package/dist/cdn/spreadsheet/snice-spreadsheet.js.map +1 -0
  440. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js +30 -0
  441. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js.map +1 -0
  442. package/dist/cdn/stepper/README.md +6 -2
  443. package/dist/cdn/stepper/snice-stepper.js +77 -10
  444. package/dist/cdn/stepper/snice-stepper.js.map +1 -1
  445. package/dist/cdn/stepper/snice-stepper.min.js +13 -9
  446. package/dist/cdn/stepper/snice-stepper.min.js.map +1 -1
  447. package/dist/cdn/switch/snice-switch.js +1 -1
  448. package/dist/cdn/switch/snice-switch.min.js +1 -1
  449. package/dist/cdn/table/snice-table.js +1 -1
  450. package/dist/cdn/table/snice-table.min.js +1 -1
  451. package/dist/cdn/tabs/snice-tabs.js +1 -1
  452. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  453. package/dist/cdn/tag-input/README.md +27 -0
  454. package/dist/cdn/tag-input/snice-tag-input.js +387 -0
  455. package/dist/cdn/tag-input/snice-tag-input.js.map +1 -0
  456. package/dist/cdn/tag-input/snice-tag-input.min.js +65 -0
  457. package/dist/cdn/tag-input/snice-tag-input.min.js.map +1 -0
  458. package/dist/cdn/terminal/snice-terminal.js +1 -1
  459. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  460. package/dist/cdn/testimonial/README.md +27 -0
  461. package/dist/cdn/testimonial/snice-testimonial.js +187 -0
  462. package/dist/cdn/testimonial/snice-testimonial.js.map +1 -0
  463. package/dist/cdn/testimonial/snice-testimonial.min.js +21 -0
  464. package/dist/cdn/testimonial/snice-testimonial.min.js.map +1 -0
  465. package/dist/cdn/textarea/snice-textarea.js +1 -1
  466. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  467. package/dist/cdn/time-range-picker/README.md +27 -0
  468. package/dist/cdn/time-range-picker/snice-time-range-picker.js +635 -0
  469. package/dist/cdn/time-range-picker/snice-time-range-picker.js.map +1 -0
  470. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +34 -0
  471. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js.map +1 -0
  472. package/dist/cdn/timeline/snice-timeline.js +1 -1
  473. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  474. package/dist/cdn/timer/snice-timer.js +1 -1
  475. package/dist/cdn/timer/snice-timer.min.js +1 -1
  476. package/dist/cdn/toast/snice-toast.js +1 -1
  477. package/dist/cdn/toast/snice-toast.min.js +1 -1
  478. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  479. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  480. package/dist/cdn/tree/README.md +5 -1
  481. package/dist/cdn/tree/snice-tree.js +4 -8
  482. package/dist/cdn/tree/snice-tree.js.map +1 -1
  483. package/dist/cdn/tree/snice-tree.min.js +5 -5
  484. package/dist/cdn/tree/snice-tree.min.js.map +1 -1
  485. package/dist/cdn/treemap/README.md +27 -0
  486. package/dist/cdn/treemap/snice-treemap.js +522 -0
  487. package/dist/cdn/treemap/snice-treemap.js.map +1 -0
  488. package/dist/cdn/treemap/snice-treemap.min.js +14 -0
  489. package/dist/cdn/treemap/snice-treemap.min.js.map +1 -0
  490. package/dist/cdn/video-player/README.md +27 -0
  491. package/dist/cdn/video-player/snice-video-player.js +721 -0
  492. package/dist/cdn/video-player/snice-video-player.js.map +1 -0
  493. package/dist/cdn/video-player/snice-video-player.min.js +153 -0
  494. package/dist/cdn/video-player/snice-video-player.min.js.map +1 -0
  495. package/dist/cdn/virtual-scroller/README.md +2 -2
  496. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +47 -16
  497. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js.map +1 -1
  498. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +9 -9
  499. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js.map +1 -1
  500. package/dist/cdn/waterfall/README.md +27 -0
  501. package/dist/cdn/waterfall/snice-waterfall.js +292 -0
  502. package/dist/cdn/waterfall/snice-waterfall.js.map +1 -0
  503. package/dist/cdn/waterfall/snice-waterfall.min.js +12 -0
  504. package/dist/cdn/waterfall/snice-waterfall.min.js.map +1 -0
  505. package/dist/cdn/weather/README.md +27 -0
  506. package/dist/cdn/weather/snice-weather.js +194 -0
  507. package/dist/cdn/weather/snice-weather.js.map +1 -0
  508. package/dist/cdn/weather/snice-weather.min.js +42 -0
  509. package/dist/cdn/weather/snice-weather.min.js.map +1 -0
  510. package/dist/components/app-tiles/snice-app-tiles.d.ts +36 -0
  511. package/dist/components/app-tiles/snice-app-tiles.js +265 -0
  512. package/dist/components/app-tiles/snice-app-tiles.js.map +1 -0
  513. package/dist/components/app-tiles/snice-app-tiles.types.d.ts +22 -0
  514. package/dist/components/book/snice-book.d.ts +46 -0
  515. package/dist/components/book/snice-book.js +285 -0
  516. package/dist/components/book/snice-book.js.map +1 -0
  517. package/dist/components/book/snice-book.types.d.ts +21 -0
  518. package/dist/components/breadcrumbs/snice-breadcrumbs.js +1 -1
  519. package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -1
  520. package/dist/components/camera-annotate/snice-camera-annotate.d.ts +68 -0
  521. package/dist/components/camera-annotate/snice-camera-annotate.js +663 -0
  522. package/dist/components/camera-annotate/snice-camera-annotate.js.map +1 -0
  523. package/dist/components/camera-annotate/snice-camera-annotate.types.d.ts +50 -0
  524. package/dist/components/candlestick/snice-candlestick.d.ts +78 -0
  525. package/dist/components/candlestick/snice-candlestick.js +650 -0
  526. package/dist/components/candlestick/snice-candlestick.js.map +1 -0
  527. package/dist/components/candlestick/snice-candlestick.types.d.ts +40 -0
  528. package/dist/components/comments/snice-comments.d.ts +62 -0
  529. package/dist/components/comments/snice-comments.js +476 -0
  530. package/dist/components/comments/snice-comments.js.map +1 -0
  531. package/dist/components/comments/snice-comments.types.d.ts +64 -0
  532. package/dist/components/countdown/snice-countdown.d.ts +21 -0
  533. package/dist/components/countdown/snice-countdown.js +168 -0
  534. package/dist/components/countdown/snice-countdown.js.map +1 -0
  535. package/dist/components/countdown/snice-countdown.types.d.ts +18 -0
  536. package/dist/components/cropper/snice-cropper.d.ts +32 -0
  537. package/dist/components/cropper/snice-cropper.js +285 -0
  538. package/dist/components/cropper/snice-cropper.js.map +1 -0
  539. package/dist/components/cropper/snice-cropper.types.d.ts +26 -0
  540. package/dist/components/diff/snice-diff.d.ts +32 -0
  541. package/dist/components/diff/snice-diff.js +374 -0
  542. package/dist/components/diff/snice-diff.js.map +1 -0
  543. package/dist/components/diff/snice-diff.types.d.ts +26 -0
  544. package/dist/components/flip-card/snice-flip-card.d.ts +15 -0
  545. package/dist/components/flip-card/snice-flip-card.js +116 -0
  546. package/dist/components/flip-card/snice-flip-card.js.map +1 -0
  547. package/dist/components/flip-card/snice-flip-card.types.d.ts +16 -0
  548. package/dist/components/flow/snice-flow.d.ts +91 -0
  549. package/dist/components/flow/snice-flow.js +755 -0
  550. package/dist/components/flow/snice-flow.js.map +1 -0
  551. package/dist/components/flow/snice-flow.types.d.ts +64 -0
  552. package/dist/components/funnel/snice-funnel.d.ts +37 -0
  553. package/dist/components/funnel/snice-funnel.js +357 -0
  554. package/dist/components/funnel/snice-funnel.js.map +1 -0
  555. package/dist/components/funnel/snice-funnel.types.d.ts +28 -0
  556. package/dist/components/gantt/snice-gantt.d.ts +34 -0
  557. package/dist/components/gantt/snice-gantt.js +369 -0
  558. package/dist/components/gantt/snice-gantt.js.map +1 -0
  559. package/dist/components/gantt/snice-gantt.types.d.ts +37 -0
  560. package/dist/components/list/snice-list-item.d.ts +2 -0
  561. package/dist/components/list/snice-list-item.js +20 -2
  562. package/dist/components/list/snice-list-item.js.map +1 -1
  563. package/dist/components/map/snice-map.d.ts +44 -0
  564. package/dist/components/map/snice-map.js +348 -0
  565. package/dist/components/map/snice-map.js.map +1 -0
  566. package/dist/components/map/snice-map.types.d.ts +41 -0
  567. package/dist/components/markdown/snice-markdown.d.ts +24 -0
  568. package/dist/components/markdown/snice-markdown.js +250 -0
  569. package/dist/components/markdown/snice-markdown.js.map +1 -0
  570. package/dist/components/markdown/snice-markdown.types.d.ts +16 -0
  571. package/dist/components/nav/snice-nav.js +22 -5
  572. package/dist/components/nav/snice-nav.js.map +1 -1
  573. package/dist/components/network-graph/snice-network-graph.d.ts +80 -0
  574. package/dist/components/network-graph/snice-network-graph.js +721 -0
  575. package/dist/components/network-graph/snice-network-graph.js.map +1 -0
  576. package/dist/components/network-graph/snice-network-graph.types.d.ts +49 -0
  577. package/dist/components/notification-center/snice-notification-center.d.ts +18 -0
  578. package/dist/components/notification-center/snice-notification-center.js +137 -0
  579. package/dist/components/notification-center/snice-notification-center.js.map +1 -0
  580. package/dist/components/notification-center/snice-notification-center.types.d.ts +24 -0
  581. package/dist/components/org-chart/snice-org-chart.d.ts +28 -0
  582. package/dist/components/org-chart/snice-org-chart.js +227 -0
  583. package/dist/components/org-chart/snice-org-chart.js.map +1 -0
  584. package/dist/components/org-chart/snice-org-chart.types.d.ts +28 -0
  585. package/dist/components/pagination/snice-pagination.js +12 -12
  586. package/dist/components/pdf-viewer/pdf.min.mjs +21 -0
  587. package/dist/components/pdf-viewer/pdf.worker.min.mjs +21 -0
  588. package/dist/components/pdf-viewer/snice-pdf-viewer.d.ts +59 -0
  589. package/dist/components/pdf-viewer/snice-pdf-viewer.js +527 -0
  590. package/dist/components/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  591. package/dist/components/pdf-viewer/snice-pdf-viewer.types.d.ts +25 -0
  592. package/dist/components/podcast-player/snice-podcast-player.d.ts +72 -0
  593. package/dist/components/podcast-player/snice-podcast-player.js +768 -0
  594. package/dist/components/podcast-player/snice-podcast-player.js.map +1 -0
  595. package/dist/components/podcast-player/snice-podcast-player.types.d.ts +79 -0
  596. package/dist/components/pricing-table/snice-pricing-table.d.ts +51 -0
  597. package/dist/components/pricing-table/snice-pricing-table.js +422 -0
  598. package/dist/components/pricing-table/snice-pricing-table.js.map +1 -0
  599. package/dist/components/pricing-table/snice-pricing-table.types.d.ts +49 -0
  600. package/dist/components/rating/snice-rating.d.ts +15 -0
  601. package/dist/components/rating/snice-rating.js +143 -0
  602. package/dist/components/rating/snice-rating.js.map +1 -0
  603. package/dist/components/rating/snice-rating.types.d.ts +15 -0
  604. package/dist/components/recipe/snice-recipe.d.ts +53 -0
  605. package/dist/components/recipe/snice-recipe.js +552 -0
  606. package/dist/components/recipe/snice-recipe.js.map +1 -0
  607. package/dist/components/recipe/snice-recipe.types.d.ts +56 -0
  608. package/dist/components/sankey/snice-sankey.d.ts +46 -0
  609. package/dist/components/sankey/snice-sankey.js +612 -0
  610. package/dist/components/sankey/snice-sankey.js.map +1 -0
  611. package/dist/components/sankey/snice-sankey.types.d.ts +59 -0
  612. package/dist/components/sortable/snice-sortable.d.ts +24 -0
  613. package/dist/components/sortable/snice-sortable.js +187 -0
  614. package/dist/components/sortable/snice-sortable.js.map +1 -0
  615. package/dist/components/sortable/snice-sortable.types.d.ts +20 -0
  616. package/dist/components/spotlight/snice-spotlight.d.ts +42 -0
  617. package/dist/components/spotlight/snice-spotlight.js +330 -0
  618. package/dist/components/spotlight/snice-spotlight.js.map +1 -0
  619. package/dist/components/spotlight/snice-spotlight.types.d.ts +26 -0
  620. package/dist/components/spreadsheet/snice-spreadsheet.d.ts +102 -0
  621. package/dist/components/spreadsheet/snice-spreadsheet.js +1104 -0
  622. package/dist/components/spreadsheet/snice-spreadsheet.js.map +1 -0
  623. package/dist/components/spreadsheet/snice-spreadsheet.types.d.ts +54 -0
  624. package/dist/components/stepper/snice-stepper.js +9 -3
  625. package/dist/components/stepper/snice-stepper.js.map +1 -1
  626. package/dist/components/tag-input/snice-tag-input.d.ts +40 -0
  627. package/dist/components/tag-input/snice-tag-input.js +320 -0
  628. package/dist/components/tag-input/snice-tag-input.js.map +1 -0
  629. package/dist/components/tag-input/snice-tag-input.types.d.ts +29 -0
  630. package/dist/components/testimonial/snice-testimonial.d.ts +15 -0
  631. package/dist/components/testimonial/snice-testimonial.js +120 -0
  632. package/dist/components/testimonial/snice-testimonial.js.map +1 -0
  633. package/dist/components/testimonial/snice-testimonial.types.d.ts +10 -0
  634. package/dist/components/time-range-picker/snice-time-range-picker.d.ts +67 -0
  635. package/dist/components/time-range-picker/snice-time-range-picker.js +568 -0
  636. package/dist/components/time-range-picker/snice-time-range-picker.js.map +1 -0
  637. package/dist/components/time-range-picker/snice-time-range-picker.types.d.ts +39 -0
  638. package/dist/components/treemap/snice-treemap.d.ts +49 -0
  639. package/dist/components/treemap/snice-treemap.js +455 -0
  640. package/dist/components/treemap/snice-treemap.js.map +1 -0
  641. package/dist/components/treemap/snice-treemap.types.d.ts +42 -0
  642. package/dist/components/video-player/snice-video-player.d.ts +78 -0
  643. package/dist/components/video-player/snice-video-player.js +654 -0
  644. package/dist/components/video-player/snice-video-player.js.map +1 -0
  645. package/dist/components/video-player/snice-video-player.types.d.ts +47 -0
  646. package/dist/components/virtual-scroller/snice-virtual-scroller.d.ts +5 -0
  647. package/dist/components/virtual-scroller/snice-virtual-scroller.js +47 -16
  648. package/dist/components/virtual-scroller/snice-virtual-scroller.js.map +1 -1
  649. package/dist/components/waterfall/snice-waterfall.d.ts +30 -0
  650. package/dist/components/waterfall/snice-waterfall.js +225 -0
  651. package/dist/components/waterfall/snice-waterfall.js.map +1 -0
  652. package/dist/components/waterfall/snice-waterfall.types.d.ts +23 -0
  653. package/dist/components/weather/snice-weather.d.ts +10 -0
  654. package/dist/components/weather/snice-weather.js +127 -0
  655. package/dist/components/weather/snice-weather.js.map +1 -0
  656. package/dist/components/weather/snice-weather.types.d.ts +22 -0
  657. package/dist/index.cjs +1 -1
  658. package/dist/index.cjs.map +1 -1
  659. package/dist/index.esm.js +1 -1
  660. package/dist/index.esm.js.map +1 -1
  661. package/dist/index.iife.js +1 -1
  662. package/dist/index.iife.js.map +1 -1
  663. package/dist/symbols.cjs +1 -1
  664. package/dist/symbols.esm.js +1 -1
  665. package/dist/transitions.cjs +1 -1
  666. package/dist/transitions.esm.js +1 -1
  667. package/docs/ai/DEVELOPMENT.md +1 -1
  668. package/docs/ai/api.md +6 -3
  669. package/docs/ai/components/accordion.md +0 -34
  670. package/docs/ai/components/app-tiles.md +77 -0
  671. package/docs/ai/components/audio-recorder.md +2 -0
  672. package/docs/ai/components/badge.md +7 -0
  673. package/docs/ai/components/book.md +78 -0
  674. package/docs/ai/components/button.md +5 -0
  675. package/docs/ai/components/camera-annotate.md +82 -0
  676. package/docs/ai/components/candlestick.md +79 -0
  677. package/docs/ai/components/chart.md +0 -24
  678. package/docs/ai/components/chat.md +7 -95
  679. package/docs/ai/components/code-block.md +3 -82
  680. package/docs/ai/components/color-display.md +3 -3
  681. package/docs/ai/components/color-picker.md +4 -4
  682. package/docs/ai/components/comments.md +75 -0
  683. package/docs/ai/components/countdown.md +54 -0
  684. package/docs/ai/components/cropper.md +57 -0
  685. package/docs/ai/components/date-picker.md +15 -9
  686. package/docs/ai/components/diff.md +66 -0
  687. package/docs/ai/components/divider.md +1 -1
  688. package/docs/ai/components/draw.md +5 -5
  689. package/docs/ai/components/drawer.md +5 -5
  690. package/docs/ai/components/empty-state.md +2 -2
  691. package/docs/ai/components/file-gallery.md +16 -87
  692. package/docs/ai/components/file-upload.md +6 -6
  693. package/docs/ai/components/flip-card.md +52 -0
  694. package/docs/ai/components/flow.md +104 -0
  695. package/docs/ai/components/funnel.md +86 -0
  696. package/docs/ai/components/gantt.md +63 -0
  697. package/docs/ai/components/gauge.md +1 -1
  698. package/docs/ai/components/heatmap.md +5 -5
  699. package/docs/ai/components/input.md +20 -18
  700. package/docs/ai/components/kanban.md +2 -2
  701. package/docs/ai/components/kpi.md +4 -53
  702. package/docs/ai/components/layout.md +10 -235
  703. package/docs/ai/components/link-preview.md +20 -29
  704. package/docs/ai/components/link.md +27 -47
  705. package/docs/ai/components/list.md +51 -31
  706. package/docs/ai/components/location.md +15 -27
  707. package/docs/ai/components/login.md +43 -94
  708. package/docs/ai/components/map.md +72 -0
  709. package/docs/ai/components/markdown.md +63 -0
  710. package/docs/ai/components/masonry.md +10 -6
  711. package/docs/ai/components/menu.md +40 -72
  712. package/docs/ai/components/modal.md +25 -42
  713. package/docs/ai/components/music-player.md +37 -89
  714. package/docs/ai/components/nav.md +25 -39
  715. package/docs/ai/components/network-graph.md +83 -0
  716. package/docs/ai/components/notification-center.md +79 -0
  717. package/docs/ai/components/org-chart.md +62 -0
  718. package/docs/ai/components/pagination.md +16 -18
  719. package/docs/ai/components/pdf-viewer.md +57 -0
  720. package/docs/ai/components/podcast-player.md +94 -0
  721. package/docs/ai/components/pricing-table.md +87 -0
  722. package/docs/ai/components/progress.md +23 -39
  723. package/docs/ai/components/qr-code.md +37 -84
  724. package/docs/ai/components/qr-reader.md +51 -61
  725. package/docs/ai/components/radio.md +27 -39
  726. package/docs/ai/components/rating.md +56 -0
  727. package/docs/ai/components/recipe.md +90 -0
  728. package/docs/ai/components/sankey.md +63 -0
  729. package/docs/ai/components/skeleton.md +0 -8
  730. package/docs/ai/components/slider.md +10 -50
  731. package/docs/ai/components/sortable.md +57 -0
  732. package/docs/ai/components/sparkline.md +26 -152
  733. package/docs/ai/components/spinner.md +0 -21
  734. package/docs/ai/components/split-pane.md +16 -38
  735. package/docs/ai/components/spotlight.md +61 -0
  736. package/docs/ai/components/spreadsheet.md +138 -0
  737. package/docs/ai/components/stepper.md +37 -183
  738. package/docs/ai/components/switch.md +28 -35
  739. package/docs/ai/components/table.md +43 -172
  740. package/docs/ai/components/tabs.md +31 -52
  741. package/docs/ai/components/tag-input.md +70 -0
  742. package/docs/ai/components/terminal.md +34 -116
  743. package/docs/ai/components/testimonial.md +56 -0
  744. package/docs/ai/components/textarea.md +11 -43
  745. package/docs/ai/components/theme.md +120 -0
  746. package/docs/ai/components/time-range-picker.md +46 -0
  747. package/docs/ai/components/timeline.md +7 -46
  748. package/docs/ai/components/timer.md +41 -37
  749. package/docs/ai/components/toast.md +19 -90
  750. package/docs/ai/components/tooltip.md +17 -104
  751. package/docs/ai/components/tree.md +38 -162
  752. package/docs/ai/components/treemap.md +57 -0
  753. package/docs/ai/components/video-player.md +91 -0
  754. package/docs/ai/components/virtual-scroller.md +23 -46
  755. package/docs/ai/components/waterfall.md +56 -0
  756. package/docs/ai/components/weather.md +78 -0
  757. package/docs/ai/decorators.md +25 -3
  758. package/docs/ai/patterns.md +17 -1
  759. package/docs/components/accordion.md +8 -6
  760. package/docs/components/alert.md +2 -0
  761. package/docs/components/app-tiles.md +162 -0
  762. package/docs/components/audio-recorder.md +6 -0
  763. package/docs/components/avatar.md +225 -0
  764. package/docs/components/badge.md +2 -0
  765. package/docs/components/banner.md +2 -0
  766. package/docs/components/book.md +184 -0
  767. package/docs/components/breadcrumbs.md +2 -0
  768. package/docs/components/button.md +15 -0
  769. package/docs/components/calendar.md +2 -0
  770. package/docs/components/camera-annotate.md +188 -0
  771. package/docs/components/camera.md +2 -0
  772. package/docs/components/candlestick.md +198 -0
  773. package/docs/components/card.md +2 -0
  774. package/docs/components/carousel.md +205 -36
  775. package/docs/components/chart.md +2 -0
  776. package/docs/components/chat.md +2 -0
  777. package/docs/components/checkbox.md +2 -0
  778. package/docs/components/chip.md +2 -0
  779. package/docs/components/code-block.md +2 -0
  780. package/docs/components/color-display.md +2 -0
  781. package/docs/components/color-picker.md +6 -4
  782. package/docs/components/command-palette.md +2 -0
  783. package/docs/components/comments.md +235 -0
  784. package/docs/components/countdown.md +121 -0
  785. package/docs/components/cropper.md +152 -0
  786. package/docs/components/date-picker.md +201 -0
  787. package/docs/components/diff.md +177 -0
  788. package/docs/components/divider.md +132 -0
  789. package/docs/components/doc.md +2 -0
  790. package/docs/components/draw.md +2 -0
  791. package/docs/components/drawer.md +2 -0
  792. package/docs/components/empty-state.md +2 -0
  793. package/docs/components/file-gallery.md +2 -0
  794. package/docs/components/file-upload.md +2 -0
  795. package/docs/components/flip-card.md +169 -0
  796. package/docs/components/flow.md +208 -0
  797. package/docs/components/funnel.md +193 -0
  798. package/docs/components/gantt.md +187 -0
  799. package/docs/components/gauge.md +2 -0
  800. package/docs/components/heatmap.md +2 -0
  801. package/docs/components/image.md +2 -0
  802. package/docs/components/input.md +242 -0
  803. package/docs/components/kanban.md +2 -0
  804. package/docs/components/kpi.md +2 -0
  805. package/docs/components/layout.md +84 -0
  806. package/docs/components/link-preview.md +66 -92
  807. package/docs/components/link.md +73 -157
  808. package/docs/components/list.md +140 -44
  809. package/docs/components/location.md +96 -283
  810. package/docs/components/login.md +131 -498
  811. package/docs/components/map.md +203 -0
  812. package/docs/components/markdown.md +220 -0
  813. package/docs/components/masonry.md +57 -102
  814. package/docs/components/menu.md +87 -494
  815. package/docs/components/modal.md +83 -436
  816. package/docs/components/music-player.md +116 -221
  817. package/docs/components/nav.md +107 -170
  818. package/docs/components/network-graph.md +187 -0
  819. package/docs/components/notification-center.md +256 -0
  820. package/docs/components/org-chart.md +275 -0
  821. package/docs/components/pagination.md +75 -218
  822. package/docs/components/paint.md +108 -73
  823. package/docs/components/pdf-viewer.md +204 -0
  824. package/docs/components/podcast-player.md +277 -0
  825. package/docs/components/pricing-table.md +249 -0
  826. package/docs/components/progress.md +169 -0
  827. package/docs/components/qr-code.md +95 -378
  828. package/docs/components/qr-reader.md +83 -258
  829. package/docs/components/radio.md +151 -0
  830. package/docs/components/rating.md +154 -0
  831. package/docs/components/recipe.md +323 -0
  832. package/docs/components/sankey.md +178 -0
  833. package/docs/components/select.md +114 -485
  834. package/docs/components/skeleton.md +96 -0
  835. package/docs/components/slider.md +92 -235
  836. package/docs/components/sortable.md +267 -0
  837. package/docs/components/sparkline.md +76 -222
  838. package/docs/components/spinner.md +37 -18
  839. package/docs/components/split-pane.md +62 -226
  840. package/docs/components/spotlight.md +240 -0
  841. package/docs/components/spreadsheet.md +405 -0
  842. package/docs/components/stepper.md +72 -306
  843. package/docs/components/switch.md +69 -293
  844. package/docs/components/table.md +250 -0
  845. package/docs/components/tabs.md +92 -471
  846. package/docs/components/tag-input.md +257 -0
  847. package/docs/components/terminal.md +87 -391
  848. package/docs/components/testimonial.md +185 -0
  849. package/docs/components/textarea.md +96 -181
  850. package/docs/components/theme.md +216 -0
  851. package/docs/components/time-range-picker.md +161 -0
  852. package/docs/components/timeline.md +67 -115
  853. package/docs/components/timer.md +44 -86
  854. package/docs/components/toast.md +93 -432
  855. package/docs/components/tooltip.md +75 -419
  856. package/docs/components/tree.md +110 -436
  857. package/docs/components/treemap.md +155 -0
  858. package/docs/components/video-player.md +336 -0
  859. package/docs/components/virtual-scroller.md +86 -226
  860. package/docs/components/waterfall.md +217 -0
  861. package/docs/components/weather.md +239 -0
  862. package/package.json +1 -1
  863. package/docs/ai/components/popover.md +0 -70
  864. package/docs/components/popover.md +0 -333
@@ -1,63 +1,85 @@
1
- # Login Component
1
+ [//]: # (AI: For a low-token version of this doc, use docs/ai/components/login.md instead)
2
2
 
3
- The login component provides a complete authentication form with username and password fields. It uses Snice's @request/@respond pattern for communication with authentication controllers, with event dispatching as a fallback for non-Snice frameworks.
3
+ # Login
4
+ `<snice-login>`
4
5
 
5
- ## Table of Contents
6
- - [Basic Usage](#basic-usage)
7
- - [Request/Respond Pattern](#requestrespond-pattern)
8
- - [Properties](#properties)
9
- - [Methods](#methods)
10
- - [Events](#events)
11
- - [Slots](#slots)
12
- - [Examples](#examples)
6
+ A complete authentication form with username/password fields, using Snice's @request/@respond pattern for controller communication.
13
7
 
14
8
  ## Basic Usage
15
9
 
10
+ ```typescript
11
+ import 'snice/components/login/snice-login';
12
+ ```
13
+
16
14
  ```html
17
15
  <snice-login controller="auth-controller"></snice-login>
18
16
  ```
19
17
 
18
+ ## Importing
19
+
20
+ **ESM (bundler)**
20
21
  ```typescript
21
22
  import 'snice/components/login/snice-login';
22
23
  ```
23
24
 
24
- ## Request/Respond Pattern
25
+ **CDN**
26
+ ```html
27
+ <script src="snice-runtime.min.js"></script>
28
+ <script src="snice-login.min.js"></script>
29
+ ```
25
30
 
26
- The login component uses Snice's @request/@respond pattern as its primary communication method. This enables bidirectional request/response communication between the login element and an authentication controller.
31
+ ## Examples
27
32
 
28
- ### How It Works
33
+ ### Variants
29
34
 
30
- 1. User submits the login form
31
- 2. Element sends `@request('login-user')` with credentials
32
- 3. Controller receives request via `@respond('login-user')`
33
- 4. Controller validates, authenticates, and returns result
34
- 5. Element processes response and updates UI
35
+ Use the `variant` attribute to change the visual style.
35
36
 
36
- ### Request Payload
37
+ ```html
38
+ <snice-login variant="default" controller="auth-controller"></snice-login>
39
+ <snice-login variant="card" controller="auth-controller"></snice-login>
40
+ <snice-login variant="minimal" controller="auth-controller"></snice-login>
41
+ ```
37
42
 
38
- The element sends a `LoginCredentials` object:
43
+ ### Sizes
39
44
 
40
- ```typescript
41
- interface LoginCredentials {
42
- username: string;
43
- password: string;
44
- remember?: boolean; // If showRememberMe is enabled
45
- }
45
+ Use the `size` attribute to change the form size.
46
+
47
+ ```html
48
+ <snice-login size="small" controller="auth-controller"></snice-login>
49
+ <snice-login size="large" controller="auth-controller"></snice-login>
46
50
  ```
47
51
 
48
- ### Response Payload
52
+ ### Custom Title and Action
49
53
 
50
- The controller must return a `LoginResult` object:
54
+ Use `title` and `action-text` to customize the form text.
51
55
 
52
- ```typescript
53
- interface LoginResult {
54
- success: boolean; // Whether authentication succeeded
55
- error?: string; // Error message if failed
56
- data?: any; // Additional data (user, token, etc.)
57
- }
56
+ ```html
57
+ <snice-login
58
+ controller="auth-controller"
59
+ title="Admin Portal"
60
+ action-text="Access Portal"
61
+ show-remember-me
62
+ show-forgot-password>
63
+ </snice-login>
58
64
  ```
59
65
 
60
- ### Creating an Authentication Controller
66
+ ### Custom Slots
67
+
68
+ ```html
69
+ <snice-login controller="auth-controller">
70
+ <p slot="subtitle">Administrator access required</p>
71
+ <div slot="before-form">
72
+ <button onclick="loginWithGoogle()">Continue with Google</button>
73
+ </div>
74
+ <div slot="footer">
75
+ <p>Don't have an account? <a href="/signup">Sign up</a></p>
76
+ </div>
77
+ </snice-login>
78
+ ```
79
+
80
+ ### Request/Respond Pattern
81
+
82
+ The login component uses `@request('login-user')` to communicate with an authentication controller.
61
83
 
62
84
  ```typescript
63
85
  import { controller, respond, IController } from 'snice';
@@ -65,260 +87,94 @@ import type { LoginCredentials, LoginResult } from 'snice/components/login/snice
65
87
 
66
88
  @controller('auth-controller')
67
89
  export class AuthController implements IController {
68
- async attach(element: HTMLElement) {
69
- console.log('Auth controller attached');
70
- }
71
-
72
- async detach(element: HTMLElement) {
73
- console.log('Auth controller detached');
74
- }
90
+ async attach(element: HTMLElement) {}
91
+ async detach(element: HTMLElement) {}
75
92
 
76
93
  @respond('login-user')
77
94
  async handleLogin(credentials: LoginCredentials): Promise<LoginResult> {
78
- try {
79
- // Validate credentials
80
- if (!credentials.username || !credentials.password) {
81
- return {
82
- success: false,
83
- error: 'Username and password are required'
84
- };
85
- }
86
-
87
- // Make API call to authenticate
88
- const response = await fetch('/api/auth/login', {
89
- method: 'POST',
90
- headers: { 'Content-Type': 'application/json' },
91
- body: JSON.stringify({
92
- username: credentials.username,
93
- password: credentials.password
94
- })
95
- });
96
-
97
- if (!response.ok) {
98
- return {
99
- success: false,
100
- error: 'Invalid username or password'
101
- };
102
- }
103
-
104
- const data = await response.json();
105
-
106
- // Store authentication token
107
- if (credentials.remember) {
108
- localStorage.setItem('authToken', data.token);
109
- } else {
110
- sessionStorage.setItem('authToken', data.token);
111
- }
112
-
113
- return {
114
- success: true,
115
- data: {
116
- user: data.user,
117
- token: data.token
118
- }
119
- };
120
-
121
- } catch (error) {
122
- return {
123
- success: false,
124
- error: 'Authentication service unavailable'
125
- };
95
+ const response = await fetch('/api/auth/login', {
96
+ method: 'POST',
97
+ headers: { 'Content-Type': 'application/json' },
98
+ body: JSON.stringify(credentials)
99
+ });
100
+
101
+ if (!response.ok) {
102
+ return { success: false, error: 'Invalid credentials' };
126
103
  }
104
+
105
+ const data = await response.json();
106
+ return { success: true, data: { user: data.user, token: data.token } };
127
107
  }
128
108
  }
129
109
  ```
130
110
 
131
- ### Using the Controller
111
+ ### Event-Based (Without Controller)
132
112
 
133
113
  ```html
134
- <!-- Import the controller -->
114
+ <snice-login id="login"></snice-login>
115
+
135
116
  <script type="module">
136
- import './auth-controller.ts';
137
117
  import 'snice/components/login/snice-login';
138
- </script>
139
-
140
- <!-- Connect login to controller -->
141
- <snice-login
142
- controller="auth-controller"
143
- title="Welcome Back"
144
- show-remember-me
145
- show-forgot-password>
146
- </snice-login>
147
118
 
148
- <!-- Handle success with events -->
149
- <script type="module">
150
- const login = document.querySelector('snice-login');
119
+ const login = document.getElementById('login');
151
120
 
152
121
  login.addEventListener('login-success', () => {
153
122
  window.location.href = '/dashboard';
154
123
  });
155
124
 
156
125
  login.addEventListener('login-error', (e) => {
157
- console.error('Login failed:', e.detail.error);
126
+ console.error('Failed:', e.detail.error);
158
127
  });
159
- </script>
160
- ```
161
-
162
- ## Properties
163
-
164
- | Property | Type | Default | Description |
165
- |----------|------|---------|-------------|
166
- | `variant` | `'default' \| 'card' \| 'minimal'` | `'default'` | Visual style variant |
167
- | `size` | `'small' \| 'medium' \| 'large'` | `'medium'` | Form size |
168
- | `title` | `string` | `'Sign In'` | Form title |
169
- | `disabled` | `boolean` | `false` | Disable the form |
170
- | `loading` | `boolean` | `false` | Show loading state |
171
- | `showRememberMe` | `boolean` | `true` | Show "Remember me" checkbox |
172
- | `showForgotPassword` | `boolean` | `true` | Show "Forgot password" link |
173
- | `actionText` | `string` | `'Sign In'` | Submit button text |
174
128
 
175
- ## Methods
176
-
177
- #### `login(credentials?: LoginCredentials): Promise<LoginResult>`
178
-
179
- Programmatically trigger login. If credentials are not provided, uses form values.
180
-
181
- ```typescript
182
- const loginElement = document.querySelector('snice-login');
183
-
184
- // Use form values
185
- const result = await loginElement.login();
186
-
187
- // Or provide credentials directly
188
- const result = await loginElement.login({
189
- username: 'user@example.com',
190
- password: 'password123',
191
- remember: true
192
- });
193
-
194
- if (result.success) {
195
- console.log('Logged in:', result.data);
196
- } else {
197
- console.error('Login failed:', result.error);
198
- }
129
+ login.addEventListener('login-forgot-password', () => {
130
+ window.location.href = '/forgot-password';
131
+ });
132
+ </script>
199
133
  ```
200
134
 
201
- #### `reset(): void`
202
-
203
- Clear the form, remove any error messages, and reset loading state.
135
+ ### Programmatic Control
204
136
 
205
137
  ```typescript
206
- loginElement.reset();
207
- ```
208
-
209
- #### `setError(message: string): void`
210
-
211
- Display an error message.
138
+ const login = document.querySelector('snice-login');
212
139
 
213
- ```typescript
214
- loginElement.setError('Invalid credentials. Please try again.');
215
- ```
140
+ // Set credentials
141
+ login.setCredentials({ username: 'user@example.com', password: 'pass123' });
216
142
 
217
- #### `clearError(): void`
143
+ // Trigger login
144
+ const result = await login.login();
218
145
 
219
- Remove any displayed error message.
146
+ // Error handling
147
+ login.setError('Invalid credentials');
148
+ login.clearError();
220
149
 
221
- ```typescript
222
- loginElement.clearError();
150
+ // Reset form
151
+ login.reset();
223
152
  ```
224
153
 
225
- #### `setCredentials(credentials: Partial<LoginCredentials>): void`
226
-
227
- Set form field values programmatically.
154
+ ## Request/Respond Types
228
155
 
229
156
  ```typescript
230
- loginElement.setCredentials({
231
- username: 'user@example.com',
232
- password: 'pass123',
233
- remember: true
234
- });
235
- ```
236
-
237
- ## Events
238
-
239
- Events are dispatched as a fallback for non-Snice frameworks or when using the login component without a controller.
240
-
241
- ### `login-attempt`
242
-
243
- Dispatched when the user submits the login form.
244
-
245
- ```typescript
246
- detail: {
157
+ interface LoginCredentials {
247
158
  username: string;
248
- timestamp: string;
249
- }
250
- ```
251
-
252
- ### `login-success`
253
-
254
- Dispatched when login succeeds.
255
-
256
- ```typescript
257
- detail: {
258
- timestamp: string;
259
- }
260
- ```
261
-
262
- ### `login-error`
263
-
264
- Dispatched when login fails.
265
-
266
- ```typescript
267
- detail: {
268
- error: string;
269
- timestamp: string;
159
+ password: string;
160
+ remember?: boolean;
270
161
  }
271
- ```
272
-
273
- ### `login-forgot-password`
274
162
 
275
- Dispatched when the user clicks "Forgot password?".
276
-
277
- ```typescript
278
- detail: {
279
- timestamp: string;
163
+ interface LoginResult {
164
+ success: boolean;
165
+ error?: string;
166
+ data?: any;
280
167
  }
281
168
  ```
282
169
 
283
- ### Event Usage Example
284
-
285
- ```html
286
- <snice-login id="login"></snice-login>
287
-
288
- <script type="module">
289
- const login = document.getElementById('login');
290
-
291
- login.addEventListener('login-attempt', (e) => {
292
- console.log('Login attempt for:', e.detail.username);
293
- });
294
-
295
- login.addEventListener('login-success', async () => {
296
- // Redirect to dashboard
297
- window.location.href = '/dashboard';
298
- });
299
-
300
- login.addEventListener('login-error', (e) => {
301
- // Show error notification
302
- console.error('Login failed:', e.detail.error);
303
- });
304
-
305
- login.addEventListener('login-forgot-password', () => {
306
- // Navigate to password reset
307
- window.location.href = '/forgot-password';
308
- });
309
- </script>
310
- ```
311
-
312
170
  ## Slots
313
171
 
314
- Customize the login form with named slots:
315
-
316
- | Slot | Description |
172
+ | Name | Description |
317
173
  |------|-------------|
318
174
  | `before-header` | Content before the header |
319
175
  | `after-header` | Content after the header |
320
- | `subtitle` | Custom subtitle (default: "Enter your credentials to continue") |
321
- | `before-form` | Content before the form |
176
+ | `subtitle` | Custom subtitle text |
177
+ | `before-form` | Content before the form (e.g., OAuth buttons) |
322
178
  | `after-form` | Content after the form |
323
179
  | `form-top` | Content at top of form |
324
180
  | `between-fields` | Content between username and password fields |
@@ -326,263 +182,40 @@ Customize the login form with named slots:
326
182
  | `after-submit` | Content after submit button |
327
183
  | `footer` | Footer content (e.g., signup link) |
328
184
 
329
- ## Examples
330
-
331
- ### Card Variant
332
-
333
- ```html
334
- <snice-login
335
- variant="card"
336
- controller="auth-controller"
337
- title="Admin Portal"
338
- action-text="Access Portal">
339
-
340
- <p slot="subtitle">Administrator access required</p>
341
- </snice-login>
342
- ```
343
-
344
- ### Minimal Variant
345
-
346
- ```html
347
- <snice-login
348
- variant="minimal"
349
- size="small"
350
- title="Quick Sign In"
351
- action-text="Continue"
352
- show-forgot-password="false"
353
- controller="auth-controller">
354
- </snice-login>
355
- ```
356
-
357
- ### Custom Footer
358
-
359
- ```html
360
- <snice-login controller="auth-controller">
361
- <div slot="footer">
362
- <p>Don't have an account?</p>
363
- <a href="/signup">Sign up here</a>
364
- </div>
365
- </snice-login>
366
- ```
367
-
368
- ### Without Controller (Event-Based)
369
-
370
- When not using a controller, handle authentication manually with events:
371
-
372
- ```html
373
- <snice-login id="manual-login"></snice-login>
374
-
375
- <script type="module">
376
- import 'snice/components/login/snice-login';
377
-
378
- const login = document.getElementById('manual-login');
379
-
380
- login.addEventListener('login-attempt', async (e) => {
381
- const { username } = e.detail;
382
-
383
- // Get form data
384
- const formData = {
385
- username: login.querySelector('input[name="username"]').value,
386
- password: login.querySelector('input[name="password"]').value,
387
- remember: login.querySelector('input[name="remember"]')?.checked
388
- };
389
-
390
- // Show loading
391
- login.loading = true;
392
- login.clearError();
393
-
394
- try {
395
- const response = await fetch('/api/auth/login', {
396
- method: 'POST',
397
- headers: { 'Content-Type': 'application/json' },
398
- body: JSON.stringify(formData)
399
- });
400
-
401
- if (!response.ok) {
402
- throw new Error('Invalid credentials');
403
- }
404
-
405
- const data = await response.json();
406
-
407
- // Store token
408
- if (formData.remember) {
409
- localStorage.setItem('authToken', data.token);
410
- } else {
411
- sessionStorage.setItem('authToken', data.token);
412
- }
413
-
414
- // Success
415
- window.location.href = '/dashboard';
416
-
417
- } catch (error) {
418
- login.setError(error.message);
419
- } finally {
420
- login.loading = false;
421
- }
422
- });
423
-
424
- login.addEventListener('login-forgot-password', () => {
425
- window.location.href = '/forgot-password';
426
- });
427
- </script>
428
- ```
429
-
430
- ### Multi-Step Authentication
431
-
432
- ```html
433
- <snice-login
434
- id="mfa-login"
435
- controller="auth-controller"
436
- title="Sign In">
437
- </snice-login>
438
-
439
- <script type="module">
440
- const login = document.getElementById('mfa-login');
441
-
442
- login.addEventListener('login-success', async (e) => {
443
- // Check if MFA is required
444
- const session = JSON.parse(sessionStorage.getItem('authSession'));
445
-
446
- if (session.requiresMFA) {
447
- // Redirect to MFA verification
448
- window.location.href = '/verify-mfa';
449
- } else {
450
- // Direct to dashboard
451
- window.location.href = '/dashboard';
452
- }
453
- });
454
- </script>
455
- ```
456
-
457
- ### OAuth Integration
458
-
459
- ```html
460
- <snice-login controller="auth-controller">
461
- <div slot="before-form">
462
- <button class="oauth-button" onclick="loginWithGoogle()">
463
- <img src="/icons/google.svg" alt="Google">
464
- Continue with Google
465
- </button>
466
-
467
- <button class="oauth-button" onclick="loginWithGitHub()">
468
- <img src="/icons/github.svg" alt="GitHub">
469
- Continue with GitHub
470
- </button>
471
-
472
- <div class="divider">
473
- <span>or sign in with email</span>
474
- </div>
475
- </div>
476
- </snice-login>
477
-
478
- <script>
479
- function loginWithGoogle() {
480
- window.location.href = '/api/auth/google';
481
- }
482
-
483
- function loginWithGitHub() {
484
- window.location.href = '/api/auth/github';
485
- }
486
- </script>
487
- ```
488
-
489
- ### Custom Styling
490
-
491
- ```html
492
- <style>
493
- .login-container {
494
- display: flex;
495
- justify-content: center;
496
- align-items: center;
497
- min-height: 100vh;
498
- background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
499
- }
500
-
501
- snice-login {
502
- width: 100%;
503
- max-width: 400px;
504
- }
505
- </style>
506
-
507
- <div class="login-container">
508
- <snice-login
509
- variant="card"
510
- size="large"
511
- controller="auth-controller"
512
- title="Welcome Back">
513
-
514
- <p slot="subtitle">Sign in to continue to your account</p>
515
-
516
- <div slot="footer" style="text-align: center; margin-top: 1rem;">
517
- <p style="color: #6b7280; font-size: 0.875rem;">
518
- Don't have an account?
519
- <a href="/signup" style="color: #3b82f6; text-decoration: none;">
520
- Sign up
521
- </a>
522
- </p>
523
- </div>
524
- </snice-login>
525
- </div>
526
- ```
527
-
528
- ### Loading States
529
-
530
- ```html
531
- <snice-login id="loading-demo" controller="auth-controller"></snice-login>
532
-
533
- <script type="module">
534
- const login = document.getElementById('loading-demo');
535
-
536
- login.addEventListener('login-attempt', () => {
537
- // Automatically set to loading by component
538
- console.log('Login in progress...');
539
- });
540
-
541
- // Manually trigger loading (if needed)
542
- login.loading = true;
543
-
544
- // Disable form during maintenance
545
- login.disabled = true;
546
- login.setError('Login is temporarily unavailable for maintenance.');
547
- </script>
548
- ```
549
-
550
- ## Accessibility
551
-
552
- - **Keyboard support**: Full keyboard navigation with Tab and Enter
553
- - **Form semantics**: Proper form, label, and input associations
554
- - **ARIA attributes**: Screen reader support with proper roles
555
- - **Autocomplete**: username and current-password autocomplete attributes
556
- - **Focus management**: Clear focus indicators for all interactive elements
557
- - **Error handling**: Error messages announced to screen readers
558
-
559
- ## Browser Support
185
+ ## Properties
560
186
 
561
- - Modern browsers (Chrome, Firefox, Safari, Edge)
562
- - Requires Custom Elements v1 and Shadow DOM support
187
+ | Property | Type | Default | Description |
188
+ |----------|------|---------|-------------|
189
+ | `variant` | `'default' \| 'card' \| 'minimal'` | `'default'` | Visual style |
190
+ | `size` | `'small' \| 'medium' \| 'large'` | `'medium'` | Form size |
191
+ | `title` | `string` | `'Sign In'` | Form title |
192
+ | `disabled` | `boolean` | `false` | Disable the form |
193
+ | `loading` | `boolean` | `false` | Show loading state |
194
+ | `showRememberMe` (attr: `show-remember-me`) | `boolean` | `true` | Show "Remember me" checkbox |
195
+ | `showForgotPassword` (attr: `show-forgot-password`) | `boolean` | `true` | Show "Forgot password" link |
196
+ | `actionText` (attr: `action-text`) | `string` | `'Sign In'` | Submit button text |
563
197
 
564
- ## Best Practices
198
+ ## Events
565
199
 
566
- 1. **Always use a controller**: The @request/@respond pattern provides better separation of concerns
567
- 2. **Secure authentication**: Never store passwords in plain text, always use HTTPS
568
- 3. **Provide clear feedback**: Use loading states and error messages to guide users
569
- 4. **Handle forgot password**: Implement password reset flow for better UX
570
- 5. **Consider MFA**: Add multi-factor authentication for sensitive applications
571
- 6. **Token storage**: Use localStorage for "remember me", sessionStorage otherwise
572
- 7. **Error messages**: Be specific but don't reveal whether username or password was wrong
573
- 8. **Rate limiting**: Implement server-side rate limiting to prevent brute force
574
- 9. **Keyboard accessibility**: Ensure all functionality works without a mouse
575
- 10. **Mobile responsive**: Test on mobile devices and adjust sizes accordingly
200
+ | Event | Detail | Description |
201
+ |-------|--------|-------------|
202
+ | `login-attempt` | `{ username, timestamp }` | Form submitted |
203
+ | `login-success` | `{ timestamp }` | Login succeeded |
204
+ | `login-error` | `{ error, timestamp }` | Login failed |
205
+ | `login-forgot-password` | `{ timestamp }` | Forgot password clicked |
576
206
 
577
- ## Related Components
207
+ ## Methods
578
208
 
579
- - **snice-button**: Used internally for submit button
580
- - **snice-alert**: Used internally for error/success messages
581
- - **snice-input**: Consider for custom input styling
582
- - **snice-modal**: Can be combined for modal login dialogs
209
+ | Method | Arguments | Description |
210
+ |--------|-----------|-------------|
211
+ | `login()` | `credentials?: LoginCredentials` | Trigger login (uses form values if no args) |
212
+ | `reset()` | -- | Clear form, error, and loading state |
213
+ | `setError()` | `message: string` | Display an error message |
214
+ | `clearError()` | -- | Remove error message |
215
+ | `setCredentials()` | `credentials: Partial<LoginCredentials>` | Set form field values |
583
216
 
584
- ## Learn More
217
+ ## Requests
585
218
 
586
- - [Request/Response Pattern Documentation](../request-response.md)
587
- - [Controllers Documentation](../controllers.md)
588
- - [Events Documentation](../events.md)
219
+ | Request | Params | Description |
220
+ |---------|--------|-------------|
221
+ | `login-user` | `LoginCredentials` | Sent to controller on login attempt |