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
@@ -0,0 +1,27 @@
1
+ # Snice Comments - CDN Build
2
+
3
+ CDN build of the Snice comments 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-comments.min.js"></script>
10
+ <snice-comments></snice-comments>
11
+ ```
12
+
13
+ ## Size
14
+ - Minified: 18.5 KB
15
+ - Gzipped: 4.9 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,544 @@
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-comments.min.js");}
8
+ var SniceComments = (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{display:block;contain:layout style paint;font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif);color:var(--snice-color-text,rgb(23 23 23));--comments-bg:var(--snice-color-background, rgb(255 255 255));--comments-border:var(--snice-color-border, rgb(226 226 226));--comments-text:var(--snice-color-text, rgb(23 23 23));--comments-text-secondary:var(--snice-color-text-secondary, rgb(82 82 82));--comments-text-tertiary:var(--snice-color-text-tertiary, rgb(115 115 115));--comments-primary:var(--snice-color-primary, rgb(37 99 235));--comments-danger:var(--snice-color-danger, rgb(220 38 38));--comments-bg-element:var(--snice-color-background-element, rgb(252 251 249))}*{box-sizing:border-box}.comments{display:flex;flex-direction:column;gap:var(--snice-spacing-md,1rem)}.comments__input-area{display:flex;gap:var(--snice-spacing-sm,.75rem);align-items:flex-start}.comments__input{flex:1;min-height:2.5rem;padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-sm,.75rem);border:1px solid var(--comments-border);border-radius:var(--snice-border-radius-md,.25rem);background:var(--comments-bg);color:var(--comments-text);font-family:inherit;font-size:var(--snice-font-size-md, 1rem);resize:vertical;line-height:var(--snice-line-height-normal, 1.5)}.comments__input:focus{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px);border-color:var(--comments-primary)}.comments__input::placeholder{color:var(--comments-text-tertiary)}.comments__submit{padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-md,1rem);background:var(--comments-primary);color:rgb(255 255 255);border:none;border-radius:var(--snice-border-radius-md,.25rem);cursor:pointer;font-family:inherit;font-size:var(--snice-font-size-md, 1rem);font-weight:var(--snice-font-weight-medium,500);transition:opacity var(--snice-transition-fast, 150ms);white-space:nowrap}.comments__submit:hover{opacity:.9}.comments__submit:disabled{opacity:.4;cursor:not-allowed}.comments__submit:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.comments__list{display:flex;flex-direction:column;gap:var(--snice-spacing-sm,.75rem)}.comment{display:flex;gap:var(--snice-spacing-sm,.75rem);align-items:flex-start}.comment__avatar{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--comments-bg-element);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:var(--snice-font-weight-semibold,600);color:var(--comments-text-secondary)}.comment__avatar img{width:100%;height:100%;object-fit:cover}.comment__body{flex:1;min-width:0}.comment__header{display:flex;align-items:baseline;gap:var(--snice-spacing-xs,.5rem);margin-bottom:var(--snice-spacing-3xs,.125rem)}.comment__author{font-weight:var(--snice-font-weight-semibold,600);font-size:var(--snice-font-size-md, 1rem);color:var(--comments-text)}.comment__time{font-size:.75rem;color:var(--comments-text-tertiary)}.comment__text{font-size:var(--snice-font-size-md, 1rem);line-height:var(--snice-line-height-normal, 1.5);color:var(--comments-text);margin:0;white-space:pre-wrap;word-break:break-word}.comment__actions{display:flex;gap:var(--snice-spacing-sm,.75rem);margin-top:var(--snice-spacing-2xs,.25rem)}.comment__action{display:inline-flex;align-items:center;gap:var(--snice-spacing-3xs,.125rem);background:0 0;border:none;cursor:pointer;font-family:inherit;font-size:.75rem;color:var(--comments-text-tertiary);padding:var(--snice-spacing-3xs,.125rem) var(--snice-spacing-2xs,.25rem);border-radius:var(--snice-border-radius-md,.25rem);transition:color var(--snice-transition-fast, 150ms),background var(--snice-transition-fast, 150ms)}.comment__action:hover{color:var(--comments-text-secondary);background:var(--comments-bg-element)}.comment__action:focus-visible{outline:var(--snice-focus-ring-width,2px) solid var(--snice-focus-ring-color,rgb(59 130 246 / .5));outline-offset:var(--snice-focus-ring-offset,2px)}.comment__action--liked,.comment__action--liked:hover{color:var(--comments-primary)}.comment__action--delete:hover{color:var(--comments-danger)}.comment__like-count{font-size:.75rem}.comment__replies{margin-top:var(--snice-spacing-sm,.75rem);margin-left:var(--snice-spacing-lg,1.5rem);padding-left:var(--snice-spacing-sm,.75rem);border-left:2px solid var(--comments-border);display:flex;flex-direction:column;gap:var(--snice-spacing-sm,.75rem)}.comment__reply-input{display:flex;gap:var(--snice-spacing-xs,.5rem);margin-top:var(--snice-spacing-xs,.5rem);margin-left:var(--snice-spacing-lg,1.5rem);padding-left:var(--snice-spacing-sm,.75rem)}.comment__reply-input .comments__input{font-size:.875rem;min-height:2rem;padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-xs,.5rem)}.comment__reply-input .comments__submit{font-size:.8125rem;padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-sm,.75rem)}.comment__cancel{padding:var(--snice-spacing-2xs,.25rem) var(--snice-spacing-sm,.75rem);background:0 0;border:1px solid var(--comments-border);border-radius:var(--snice-border-radius-md,.25rem);cursor:pointer;font-family:inherit;font-size:.8125rem;color:var(--comments-text-secondary);transition:background var(--snice-transition-fast, 150ms)}.comment__cancel:hover{background:var(--comments-bg-element)}.comments__empty{text-align:center;padding:var(--snice-spacing-xl,2rem);color:var(--comments-text-tertiary);font-style:italic}";
68
+
69
+ /**
70
+ * <snice-comment> — declarative child element for comments.
71
+ *
72
+ * Usage:
73
+ * <snice-comments current-user="John">
74
+ * <snice-comment author="Alice" avatar="alice.jpg" timestamp="2024-01-15T10:30:00Z">
75
+ * Great article!
76
+ * <snice-comment author="Bob" timestamp="2024-01-15T11:00:00Z">
77
+ * Thanks Alice!
78
+ * </snice-comment>
79
+ * </snice-comment>
80
+ * </snice-comments>
81
+ *
82
+ * Attributes: author, avatar, timestamp, likes (number), liked (boolean)
83
+ * Nested <snice-comment> elements become replies.
84
+ */
85
+ let SniceComment = (() => {
86
+ let _classDecorators = [snice.element('snice-comment')];
87
+ let _classDescriptor;
88
+ let _classExtraInitializers = [];
89
+ let _classThis;
90
+ let _classSuper = HTMLElement;
91
+ let _instanceExtraInitializers = [];
92
+ let _renderContent_decorators;
93
+ let _componentStyles_decorators;
94
+ (class extends _classSuper {
95
+ static { _classThis = this; }
96
+ static {
97
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
98
+ _renderContent_decorators = [snice.render()];
99
+ _componentStyles_decorators = [snice.styles()];
100
+ __esDecorate(this, null, _renderContent_decorators, { kind: "method", name: "renderContent", static: false, private: false, access: { has: obj => "renderContent" in obj, get: obj => obj.renderContent }, metadata: _metadata }, null, _instanceExtraInitializers);
101
+ __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);
102
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
103
+ _classThis = _classDescriptor.value;
104
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
105
+ __runInitializers(_classThis, _classExtraInitializers);
106
+ }
107
+ renderContent() {
108
+ return snice.html `<slot></slot>`;
109
+ }
110
+ componentStyles() {
111
+ return snice.css `:host { display: none; }`;
112
+ }
113
+ constructor() {
114
+ super(...arguments);
115
+ __runInitializers(this, _instanceExtraInitializers);
116
+ }
117
+ });
118
+ return _classThis;
119
+ })();
120
+ let SniceComments = (() => {
121
+ let _classDecorators = [snice.element('snice-comments')];
122
+ let _classDescriptor;
123
+ let _classExtraInitializers = [];
124
+ let _classThis;
125
+ let _classSuper = HTMLElement;
126
+ let _instanceExtraInitializers = [];
127
+ let _comments_decorators;
128
+ let _comments_initializers = [];
129
+ let _comments_extraInitializers = [];
130
+ let _currentUser_decorators;
131
+ let _currentUser_initializers = [];
132
+ let _currentUser_extraInitializers = [];
133
+ let _allowReplies_decorators;
134
+ let _allowReplies_initializers = [];
135
+ let _allowReplies_extraInitializers = [];
136
+ let _allowLikes_decorators;
137
+ let _allowLikes_initializers = [];
138
+ let _allowLikes_extraInitializers = [];
139
+ let _maxDepth_decorators;
140
+ let _maxDepth_initializers = [];
141
+ let _maxDepth_extraInitializers = [];
142
+ let _newInput_decorators;
143
+ let _newInput_initializers = [];
144
+ let _newInput_extraInitializers = [];
145
+ let _init_decorators;
146
+ let _handleSlotChange_decorators;
147
+ let _handleCommentsChange_decorators;
148
+ let _emitCommentAdd_decorators;
149
+ let _emitCommentReply_decorators;
150
+ let _emitCommentDelete_decorators;
151
+ let _emitCommentLike_decorators;
152
+ let _renderContent_decorators;
153
+ let _componentStyles_decorators;
154
+ (class extends _classSuper {
155
+ static { _classThis = this; }
156
+ constructor() {
157
+ super(...arguments);
158
+ this.comments = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _comments_initializers, []));
159
+ this.currentUser = (__runInitializers(this, _comments_extraInitializers), __runInitializers(this, _currentUser_initializers, ''));
160
+ this.allowReplies = (__runInitializers(this, _currentUser_extraInitializers), __runInitializers(this, _allowReplies_initializers, true));
161
+ this.allowLikes = (__runInitializers(this, _allowReplies_extraInitializers), __runInitializers(this, _allowLikes_initializers, true));
162
+ this.maxDepth = (__runInitializers(this, _allowLikes_extraInitializers), __runInitializers(this, _maxDepth_initializers, 3));
163
+ this.newInput = (__runInitializers(this, _maxDepth_extraInitializers), __runInitializers(this, _newInput_initializers, void 0));
164
+ this.replyingTo = (__runInitializers(this, _newInput_extraInitializers), null);
165
+ this.replyText = '';
166
+ this.newCommentText = '';
167
+ }
168
+ static {
169
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
170
+ _comments_decorators = [snice.property({ type: Array })];
171
+ _currentUser_decorators = [snice.property({ attribute: 'current-user' })];
172
+ _allowReplies_decorators = [snice.property({ type: Boolean, attribute: 'allow-replies' })];
173
+ _allowLikes_decorators = [snice.property({ type: Boolean, attribute: 'allow-likes' })];
174
+ _maxDepth_decorators = [snice.property({ type: Number, attribute: 'max-depth' })];
175
+ _newInput_decorators = [snice.query('.comments__new-input')];
176
+ _init_decorators = [snice.ready()];
177
+ _handleSlotChange_decorators = [snice.on('slotchange', { target: 'slot' })];
178
+ _handleCommentsChange_decorators = [snice.watch('comments')];
179
+ _emitCommentAdd_decorators = [snice.dispatch('comment-add', { bubbles: true, composed: true })];
180
+ _emitCommentReply_decorators = [snice.dispatch('comment-reply', { bubbles: true, composed: true })];
181
+ _emitCommentDelete_decorators = [snice.dispatch('comment-delete', { bubbles: true, composed: true })];
182
+ _emitCommentLike_decorators = [snice.dispatch('comment-like', { bubbles: true, composed: true })];
183
+ _renderContent_decorators = [snice.render()];
184
+ _componentStyles_decorators = [snice.styles()];
185
+ __esDecorate(this, null, _init_decorators, { kind: "method", name: "init", static: false, private: false, access: { has: obj => "init" in obj, get: obj => obj.init }, metadata: _metadata }, null, _instanceExtraInitializers);
186
+ __esDecorate(this, null, _handleSlotChange_decorators, { kind: "method", name: "handleSlotChange", static: false, private: false, access: { has: obj => "handleSlotChange" in obj, get: obj => obj.handleSlotChange }, metadata: _metadata }, null, _instanceExtraInitializers);
187
+ __esDecorate(this, null, _handleCommentsChange_decorators, { kind: "method", name: "handleCommentsChange", static: false, private: false, access: { has: obj => "handleCommentsChange" in obj, get: obj => obj.handleCommentsChange }, metadata: _metadata }, null, _instanceExtraInitializers);
188
+ __esDecorate(this, null, _emitCommentAdd_decorators, { kind: "method", name: "emitCommentAdd", static: false, private: false, access: { has: obj => "emitCommentAdd" in obj, get: obj => obj.emitCommentAdd }, metadata: _metadata }, null, _instanceExtraInitializers);
189
+ __esDecorate(this, null, _emitCommentReply_decorators, { kind: "method", name: "emitCommentReply", static: false, private: false, access: { has: obj => "emitCommentReply" in obj, get: obj => obj.emitCommentReply }, metadata: _metadata }, null, _instanceExtraInitializers);
190
+ __esDecorate(this, null, _emitCommentDelete_decorators, { kind: "method", name: "emitCommentDelete", static: false, private: false, access: { has: obj => "emitCommentDelete" in obj, get: obj => obj.emitCommentDelete }, metadata: _metadata }, null, _instanceExtraInitializers);
191
+ __esDecorate(this, null, _emitCommentLike_decorators, { kind: "method", name: "emitCommentLike", static: false, private: false, access: { has: obj => "emitCommentLike" in obj, get: obj => obj.emitCommentLike }, metadata: _metadata }, null, _instanceExtraInitializers);
192
+ __esDecorate(this, null, _renderContent_decorators, { kind: "method", name: "renderContent", static: false, private: false, access: { has: obj => "renderContent" in obj, get: obj => obj.renderContent }, metadata: _metadata }, null, _instanceExtraInitializers);
193
+ __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);
194
+ __esDecorate(null, null, _comments_decorators, { kind: "field", name: "comments", static: false, private: false, access: { has: obj => "comments" in obj, get: obj => obj.comments, set: (obj, value) => { obj.comments = value; } }, metadata: _metadata }, _comments_initializers, _comments_extraInitializers);
195
+ __esDecorate(null, null, _currentUser_decorators, { kind: "field", name: "currentUser", static: false, private: false, access: { has: obj => "currentUser" in obj, get: obj => obj.currentUser, set: (obj, value) => { obj.currentUser = value; } }, metadata: _metadata }, _currentUser_initializers, _currentUser_extraInitializers);
196
+ __esDecorate(null, null, _allowReplies_decorators, { kind: "field", name: "allowReplies", static: false, private: false, access: { has: obj => "allowReplies" in obj, get: obj => obj.allowReplies, set: (obj, value) => { obj.allowReplies = value; } }, metadata: _metadata }, _allowReplies_initializers, _allowReplies_extraInitializers);
197
+ __esDecorate(null, null, _allowLikes_decorators, { kind: "field", name: "allowLikes", static: false, private: false, access: { has: obj => "allowLikes" in obj, get: obj => obj.allowLikes, set: (obj, value) => { obj.allowLikes = value; } }, metadata: _metadata }, _allowLikes_initializers, _allowLikes_extraInitializers);
198
+ __esDecorate(null, null, _maxDepth_decorators, { kind: "field", name: "maxDepth", static: false, private: false, access: { has: obj => "maxDepth" in obj, get: obj => obj.maxDepth, set: (obj, value) => { obj.maxDepth = value; } }, metadata: _metadata }, _maxDepth_initializers, _maxDepth_extraInitializers);
199
+ __esDecorate(null, null, _newInput_decorators, { kind: "field", name: "newInput", static: false, private: false, access: { has: obj => "newInput" in obj, get: obj => obj.newInput, set: (obj, value) => { obj.newInput = value; } }, metadata: _metadata }, _newInput_initializers, _newInput_extraInitializers);
200
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
201
+ _classThis = _classDescriptor.value;
202
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
203
+ __runInitializers(_classThis, _classExtraInitializers);
204
+ }
205
+ init() {
206
+ this.collectCommentsFromChildren();
207
+ }
208
+ handleSlotChange() {
209
+ this.collectCommentsFromChildren();
210
+ }
211
+ /** Reads <snice-comment> children into the comments array (only if no comments set via property) */
212
+ collectCommentsFromChildren() {
213
+ if (this.comments.length > 0)
214
+ return;
215
+ const commentEls = Array.from(this.querySelectorAll(':scope > snice-comment'));
216
+ if (commentEls.length === 0)
217
+ return;
218
+ this.comments = commentEls.map(el => this.parseCommentElement(el));
219
+ }
220
+ parseCommentElement(el) {
221
+ // Get direct text content (excluding child element text)
222
+ const text = Array.from(el.childNodes)
223
+ .filter(n => n.nodeType === Node.TEXT_NODE)
224
+ .map(n => n.textContent?.trim())
225
+ .filter(Boolean)
226
+ .join(' ');
227
+ const comment = {
228
+ id: el.getAttribute('id') || `c_${Date.now()}_${Math.random().toString(36).slice(2, 8)}`,
229
+ author: el.getAttribute('author') || 'Anonymous',
230
+ text,
231
+ timestamp: el.getAttribute('timestamp') || new Date().toISOString(),
232
+ likes: parseInt(el.getAttribute('likes') || '0', 10),
233
+ liked: el.hasAttribute('liked'),
234
+ };
235
+ if (el.getAttribute('avatar')) {
236
+ comment.avatar = el.getAttribute('avatar');
237
+ }
238
+ // Parse nested <snice-comment> as replies
239
+ const replyEls = Array.from(el.querySelectorAll(':scope > snice-comment'));
240
+ if (replyEls.length > 0) {
241
+ comment.replies = replyEls.map(r => this.parseCommentElement(r));
242
+ }
243
+ return comment;
244
+ }
245
+ handleCommentsChange() {
246
+ // Re-render on comments change
247
+ }
248
+ generateId() {
249
+ return `c_${Date.now()}_${Math.random().toString(36).slice(2, 8)}`;
250
+ }
251
+ getInitials(name) {
252
+ return name
253
+ .split(' ')
254
+ .map(part => part.charAt(0))
255
+ .join('')
256
+ .toUpperCase()
257
+ .slice(0, 2);
258
+ }
259
+ formatTimestamp(ts) {
260
+ try {
261
+ const date = new Date(ts);
262
+ const now = new Date();
263
+ const diff = now.getTime() - date.getTime();
264
+ const minutes = Math.floor(diff / 60000);
265
+ const hours = Math.floor(diff / 3600000);
266
+ const days = Math.floor(diff / 86400000);
267
+ if (minutes < 1)
268
+ return 'just now';
269
+ if (minutes < 60)
270
+ return `${minutes}m ago`;
271
+ if (hours < 24)
272
+ return `${hours}h ago`;
273
+ if (days < 7)
274
+ return `${days}d ago`;
275
+ return date.toLocaleDateString();
276
+ }
277
+ catch {
278
+ return ts;
279
+ }
280
+ }
281
+ findComment(comments, id) {
282
+ for (const c of comments) {
283
+ if (c.id === id)
284
+ return c;
285
+ if (c.replies) {
286
+ const found = this.findComment(c.replies, id);
287
+ if (found)
288
+ return found;
289
+ }
290
+ }
291
+ return null;
292
+ }
293
+ removeComment(comments, id) {
294
+ return comments
295
+ .filter(c => c.id !== id)
296
+ .map(c => ({
297
+ ...c,
298
+ replies: c.replies ? this.removeComment(c.replies, id) : undefined
299
+ }));
300
+ }
301
+ updateComment(comments, id, updater) {
302
+ return comments.map(c => {
303
+ if (c.id === id)
304
+ return updater(c);
305
+ if (c.replies) {
306
+ return { ...c, replies: this.updateComment(c.replies, id, updater) };
307
+ }
308
+ return c;
309
+ });
310
+ }
311
+ // --- Public API ---
312
+ addComment(text, parentId) {
313
+ if (!text.trim())
314
+ return;
315
+ const newComment = {
316
+ id: this.generateId(),
317
+ author: this.currentUser || 'Anonymous',
318
+ text: text.trim(),
319
+ timestamp: new Date().toISOString(),
320
+ likes: 0,
321
+ liked: false
322
+ };
323
+ if (parentId) {
324
+ const parent = this.findComment(this.comments, parentId);
325
+ if (!parent)
326
+ return;
327
+ this.comments = this.updateComment(this.comments, parentId, c => ({
328
+ ...c,
329
+ replies: [...(c.replies || []), newComment]
330
+ }));
331
+ this.emitCommentReply({
332
+ id: newComment.id,
333
+ text: newComment.text,
334
+ author: newComment.author,
335
+ parentId
336
+ });
337
+ }
338
+ else {
339
+ this.comments = [...this.comments, newComment];
340
+ this.emitCommentAdd({
341
+ id: newComment.id,
342
+ text: newComment.text,
343
+ author: newComment.author
344
+ });
345
+ }
346
+ }
347
+ deleteComment(id) {
348
+ const comment = this.findComment(this.comments, id);
349
+ if (!comment)
350
+ return;
351
+ this.comments = this.removeComment(this.comments, id);
352
+ this.emitCommentDelete({ id });
353
+ }
354
+ likeComment(id) {
355
+ const comment = this.findComment(this.comments, id);
356
+ if (!comment)
357
+ return;
358
+ const newLiked = !comment.liked;
359
+ const newLikes = (comment.likes || 0) + (newLiked ? 1 : -1);
360
+ this.comments = this.updateComment(this.comments, id, c => ({
361
+ ...c,
362
+ liked: newLiked,
363
+ likes: newLikes
364
+ }));
365
+ this.emitCommentLike({
366
+ id,
367
+ likes: newLikes,
368
+ liked: newLiked
369
+ });
370
+ }
371
+ emitCommentAdd(detail) {
372
+ return detail;
373
+ }
374
+ emitCommentReply(detail) {
375
+ return detail;
376
+ }
377
+ emitCommentDelete(detail) {
378
+ return detail;
379
+ }
380
+ emitCommentLike(detail) {
381
+ return detail;
382
+ }
383
+ handleNewComment() {
384
+ if (!this.newCommentText.trim())
385
+ return;
386
+ this.addComment(this.newCommentText);
387
+ this.newCommentText = '';
388
+ if (this.newInput) {
389
+ this.newInput.value = '';
390
+ }
391
+ }
392
+ handleReply(parentId) {
393
+ if (!this.replyText.trim())
394
+ return;
395
+ this.addComment(this.replyText, parentId);
396
+ this.replyText = '';
397
+ this.replyingTo = null;
398
+ }
399
+ handleNewInputChange(e) {
400
+ this.newCommentText = e.target.value;
401
+ }
402
+ handleReplyInputChange(e) {
403
+ this.replyText = e.target.value;
404
+ }
405
+ handleNewKeydown(e) {
406
+ if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {
407
+ e.preventDefault();
408
+ this.handleNewComment();
409
+ }
410
+ }
411
+ handleReplyKeydown(e, parentId) {
412
+ if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {
413
+ e.preventDefault();
414
+ this.handleReply(parentId);
415
+ }
416
+ if (e.key === 'Escape') {
417
+ this.replyingTo = null;
418
+ }
419
+ }
420
+ startReply(commentId) {
421
+ this.replyingTo = commentId;
422
+ this.replyText = '';
423
+ }
424
+ cancelReply() {
425
+ this.replyingTo = null;
426
+ this.replyText = '';
427
+ }
428
+ renderComment(comment, depth) {
429
+ const canReply = this.allowReplies && depth < this.maxDepth;
430
+ const isOwn = this.currentUser && comment.author === this.currentUser;
431
+ const isReplying = this.replyingTo === comment.id;
432
+ const hasLikes = (comment.likes || 0) > 0;
433
+ return snice.html /*html*/ `
434
+ <div class="comment" data-id="${comment.id}">
435
+ <div class="comment__avatar">
436
+ <if ${comment.avatar}>
437
+ <img src="${comment.avatar}" alt="${comment.author}" />
438
+ </if>
439
+ <if ${!comment.avatar}>
440
+ ${this.getInitials(comment.author)}
441
+ </if>
442
+ </div>
443
+ <div class="comment__body">
444
+ <div class="comment__header">
445
+ <span class="comment__author">${comment.author}</span>
446
+ <span class="comment__time">${this.formatTimestamp(comment.timestamp)}</span>
447
+ </div>
448
+ <p class="comment__text">${comment.text}</p>
449
+ <div class="comment__actions">
450
+ <if ${this.allowLikes}>
451
+ <button class="comment__action ${comment.liked ? 'comment__action--liked' : ''}"
452
+ @click=${() => this.likeComment(comment.id)}
453
+ aria-label="${comment.liked ? 'Unlike' : 'Like'}">
454
+ <span>${comment.liked ? '\u2764' : '\u2661'}</span>
455
+ <if ${hasLikes}>
456
+ <span class="comment__like-count">${comment.likes}</span>
457
+ </if>
458
+ </button>
459
+ </if>
460
+ <if ${canReply}>
461
+ <button class="comment__action"
462
+ @click=${() => this.startReply(comment.id)}
463
+ aria-label="Reply">
464
+ Reply
465
+ </button>
466
+ </if>
467
+ <if ${isOwn}>
468
+ <button class="comment__action comment__action--delete"
469
+ @click=${() => this.deleteComment(comment.id)}
470
+ aria-label="Delete comment">
471
+ Delete
472
+ </button>
473
+ </if>
474
+ </div>
475
+
476
+ <if ${isReplying}>
477
+ <div class="comment__reply-input">
478
+ <textarea class="comments__input"
479
+ placeholder="Write a reply..."
480
+ rows="1"
481
+ @input=${this.handleReplyInputChange}
482
+ @keydown=${(e) => this.handleReplyKeydown(e, comment.id)}></textarea>
483
+ <button class="comments__submit"
484
+ @click=${() => this.handleReply(comment.id)}>
485
+ Reply
486
+ </button>
487
+ <button class="comment__cancel"
488
+ @click=${() => this.cancelReply()}>
489
+ Cancel
490
+ </button>
491
+ </div>
492
+ </if>
493
+
494
+ <if ${comment.replies && comment.replies.length > 0}>
495
+ <div class="comment__replies">
496
+ ${(comment.replies || []).map(reply => this.renderComment(reply, depth + 1))}
497
+ </div>
498
+ </if>
499
+ </div>
500
+ </div>
501
+ `;
502
+ }
503
+ renderContent() {
504
+ const hasComments = this.comments.length > 0;
505
+ return snice.html /*html*/ `
506
+ <div class="comments" part="base">
507
+ <div class="comments__input-area" part="input-area">
508
+ <textarea class="comments__input comments__new-input"
509
+ placeholder="Write a comment..."
510
+ rows="2"
511
+ @input=${this.handleNewInputChange}
512
+ @keydown=${this.handleNewKeydown}></textarea>
513
+ <button class="comments__submit"
514
+ @click=${() => this.handleNewComment()}
515
+ aria-label="Post comment">
516
+ Post
517
+ </button>
518
+ </div>
519
+
520
+ <if ${hasComments}>
521
+ <div class="comments__list" part="list">
522
+ ${this.comments.map(c => this.renderComment(c, 0))}
523
+ </div>
524
+ </if>
525
+ <if ${!hasComments}>
526
+ <div class="comments__empty">No comments yet. Be the first to comment!</div>
527
+ </if>
528
+ </div>
529
+ `;
530
+ }
531
+ componentStyles() {
532
+ return snice.css `${cssContent}`;
533
+ }
534
+ });
535
+ return _classThis;
536
+ })();
537
+
538
+ exports.SniceComment = SniceComment;
539
+ exports.SniceComments = SniceComments;
540
+
541
+ return exports;
542
+
543
+ })({}, Snice);
544
+ //# sourceMappingURL=snice-comments.js.map