snice 4.20.1 → 4.22.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 (362) hide show
  1. package/adapters/react/drawer.d.ts +4 -0
  2. package/adapters/react/drawer.d.ts.map +1 -1
  3. package/adapters/react/drawer.js +1 -1
  4. package/adapters/react/drawer.js.map +1 -1
  5. package/adapters/react/drawer.tsx +5 -1
  6. package/adapters/react/notification-center.d.ts +1 -0
  7. package/adapters/react/notification-center.d.ts.map +1 -1
  8. package/adapters/react/notification-center.js +1 -1
  9. package/adapters/react/notification-center.js.map +1 -1
  10. package/adapters/react/notification-center.tsx +2 -1
  11. package/dist/cdn/accordion/snice-accordion.js +1 -1
  12. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  13. package/dist/cdn/activity-feed/snice-activity-feed.js +1 -1
  14. package/dist/cdn/activity-feed/snice-activity-feed.min.js +1 -1
  15. package/dist/cdn/alert/snice-alert.js +1 -1
  16. package/dist/cdn/alert/snice-alert.min.js +1 -1
  17. package/dist/cdn/app-tiles/README.md +2 -2
  18. package/dist/cdn/app-tiles/snice-app-tiles.js +2 -2
  19. package/dist/cdn/app-tiles/snice-app-tiles.js.map +1 -1
  20. package/dist/cdn/app-tiles/snice-app-tiles.min.js +3 -3
  21. package/dist/cdn/app-tiles/snice-app-tiles.min.js.map +1 -1
  22. package/dist/cdn/approval-flow/snice-approval-flow.js +1 -1
  23. package/dist/cdn/approval-flow/snice-approval-flow.min.js +1 -1
  24. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  25. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  26. package/dist/cdn/availability/snice-availability.js +1 -1
  27. package/dist/cdn/availability/snice-availability.min.js +1 -1
  28. package/dist/cdn/avatar/snice-avatar.js +1 -1
  29. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  30. package/dist/cdn/avatar-group/snice-avatar-group.js +1 -1
  31. package/dist/cdn/avatar-group/snice-avatar-group.min.js +1 -1
  32. package/dist/cdn/badge/snice-badge.js +1 -1
  33. package/dist/cdn/badge/snice-badge.min.js +1 -1
  34. package/dist/cdn/banner/snice-banner.js +1 -1
  35. package/dist/cdn/banner/snice-banner.min.js +1 -1
  36. package/dist/cdn/book/snice-book.js +1 -1
  37. package/dist/cdn/book/snice-book.min.js +1 -1
  38. package/dist/cdn/booking/snice-booking.js +1 -1
  39. package/dist/cdn/booking/snice-booking.min.js +1 -1
  40. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +1 -1
  41. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +1 -1
  42. package/dist/cdn/button/snice-button.js +1 -1
  43. package/dist/cdn/button/snice-button.min.js +1 -1
  44. package/dist/cdn/calendar/snice-calendar.js +1 -1
  45. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  46. package/dist/cdn/camera/snice-camera.js +1 -1
  47. package/dist/cdn/camera/snice-camera.min.js +1 -1
  48. package/dist/cdn/camera-annotate/snice-camera-annotate.js +1 -1
  49. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +1 -1
  50. package/dist/cdn/candlestick/snice-candlestick.js +1 -1
  51. package/dist/cdn/candlestick/snice-candlestick.min.js +1 -1
  52. package/dist/cdn/card/snice-card.js +1 -1
  53. package/dist/cdn/card/snice-card.min.js +1 -1
  54. package/dist/cdn/carousel/snice-carousel.js +1 -1
  55. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  56. package/dist/cdn/cart/README.md +1 -1
  57. package/dist/cdn/cart/snice-cart.js +24 -20
  58. package/dist/cdn/cart/snice-cart.js.map +1 -1
  59. package/dist/cdn/cart/snice-cart.min.js +24 -20
  60. package/dist/cdn/cart/snice-cart.min.js.map +1 -1
  61. package/dist/cdn/chart/snice-chart.js +1 -1
  62. package/dist/cdn/chart/snice-chart.min.js +1 -1
  63. package/dist/cdn/chat/README.md +2 -2
  64. package/dist/cdn/chat/snice-chat.js +177 -10
  65. package/dist/cdn/chat/snice-chat.js.map +1 -1
  66. package/dist/cdn/chat/snice-chat.min.js +49 -17
  67. package/dist/cdn/chat/snice-chat.min.js.map +1 -1
  68. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  69. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  70. package/dist/cdn/chip/snice-chip.js +1 -1
  71. package/dist/cdn/chip/snice-chip.min.js +1 -1
  72. package/dist/cdn/code-block/README.md +1 -1
  73. package/dist/cdn/code-block/snice-code-block.js +2 -2
  74. package/dist/cdn/code-block/snice-code-block.js.map +1 -1
  75. package/dist/cdn/code-block/snice-code-block.min.js +3 -3
  76. package/dist/cdn/code-block/snice-code-block.min.js.map +1 -1
  77. package/dist/cdn/color-display/snice-color-display.js +1 -1
  78. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  79. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  80. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  81. package/dist/cdn/command-palette/snice-command-palette.js +2 -2
  82. package/dist/cdn/command-palette/snice-command-palette.js.map +1 -1
  83. package/dist/cdn/command-palette/snice-command-palette.min.js +2 -2
  84. package/dist/cdn/command-palette/snice-command-palette.min.js.map +1 -1
  85. package/dist/cdn/comments/snice-comments.js +1 -1
  86. package/dist/cdn/comments/snice-comments.min.js +1 -1
  87. package/dist/cdn/countdown/snice-countdown.js +1 -1
  88. package/dist/cdn/countdown/snice-countdown.min.js +1 -1
  89. package/dist/cdn/cropper/snice-cropper.js +1 -1
  90. package/dist/cdn/cropper/snice-cropper.min.js +1 -1
  91. package/dist/cdn/data-card/snice-data-card.js +1 -1
  92. package/dist/cdn/data-card/snice-data-card.min.js +1 -1
  93. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  94. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  95. package/dist/cdn/date-time-picker/snice-date-time-picker.js +1 -1
  96. package/dist/cdn/date-time-picker/snice-date-time-picker.min.js +1 -1
  97. package/dist/cdn/diff/snice-diff.js +1 -1
  98. package/dist/cdn/diff/snice-diff.min.js +1 -1
  99. package/dist/cdn/divider/snice-divider.js +1 -1
  100. package/dist/cdn/divider/snice-divider.min.js +1 -1
  101. package/dist/cdn/doc/snice-doc.js +1 -1
  102. package/dist/cdn/doc/snice-doc.min.js +1 -1
  103. package/dist/cdn/draw/snice-draw.js +1 -1
  104. package/dist/cdn/draw/snice-draw.min.js +1 -1
  105. package/dist/cdn/drawer/README.md +2 -2
  106. package/dist/cdn/drawer/snice-drawer.js +129 -22
  107. package/dist/cdn/drawer/snice-drawer.js.map +1 -1
  108. package/dist/cdn/drawer/snice-drawer.min.js +22 -18
  109. package/dist/cdn/drawer/snice-drawer.min.js.map +1 -1
  110. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  111. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  112. package/dist/cdn/estimate/snice-estimate.js +1 -1
  113. package/dist/cdn/estimate/snice-estimate.min.js +1 -1
  114. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  115. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  116. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  117. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  118. package/dist/cdn/flip-card/snice-flip-card.js +1 -1
  119. package/dist/cdn/flip-card/snice-flip-card.min.js +1 -1
  120. package/dist/cdn/flow/snice-flow.js +1 -1
  121. package/dist/cdn/flow/snice-flow.min.js +1 -1
  122. package/dist/cdn/form-layout/snice-form-layout.js +1 -1
  123. package/dist/cdn/form-layout/snice-form-layout.min.js +1 -1
  124. package/dist/cdn/funnel/snice-funnel.js +1 -1
  125. package/dist/cdn/funnel/snice-funnel.min.js +1 -1
  126. package/dist/cdn/gantt/snice-gantt.js +1 -1
  127. package/dist/cdn/gantt/snice-gantt.min.js +1 -1
  128. package/dist/cdn/gauge/snice-gauge.js +1 -1
  129. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  130. package/dist/cdn/heatmap/README.md +2 -2
  131. package/dist/cdn/heatmap/snice-heatmap.js +2 -2
  132. package/dist/cdn/heatmap/snice-heatmap.js.map +1 -1
  133. package/dist/cdn/heatmap/snice-heatmap.min.js +5 -5
  134. package/dist/cdn/heatmap/snice-heatmap.min.js.map +1 -1
  135. package/dist/cdn/image/snice-image.js +1 -1
  136. package/dist/cdn/image/snice-image.min.js +1 -1
  137. package/dist/cdn/input/snice-input.js +1 -1
  138. package/dist/cdn/input/snice-input.min.js +1 -1
  139. package/dist/cdn/invoice/snice-invoice.js +1 -1
  140. package/dist/cdn/invoice/snice-invoice.min.js +1 -1
  141. package/dist/cdn/kanban/snice-kanban.js +1 -1
  142. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  143. package/dist/cdn/key-value/snice-key-value.js +1 -1
  144. package/dist/cdn/key-value/snice-key-value.min.js +1 -1
  145. package/dist/cdn/kpi/snice-kpi.js +1 -1
  146. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  147. package/dist/cdn/layout/snice-layout.js +1 -1
  148. package/dist/cdn/layout/snice-layout.min.js +1 -1
  149. package/dist/cdn/leaderboard/snice-leaderboard.js +1 -1
  150. package/dist/cdn/leaderboard/snice-leaderboard.min.js +1 -1
  151. package/dist/cdn/link/snice-link.js +1 -1
  152. package/dist/cdn/link/snice-link.min.js +1 -1
  153. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  154. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  155. package/dist/cdn/list/README.md +2 -2
  156. package/dist/cdn/list/snice-list.js +179 -8
  157. package/dist/cdn/list/snice-list.js.map +1 -1
  158. package/dist/cdn/list/snice-list.min.js +45 -9
  159. package/dist/cdn/list/snice-list.min.js.map +1 -1
  160. package/dist/cdn/location/snice-location.js +1 -1
  161. package/dist/cdn/location/snice-location.min.js +1 -1
  162. package/dist/cdn/login/snice-login.js +1 -1
  163. package/dist/cdn/login/snice-login.min.js +1 -1
  164. package/dist/cdn/map/snice-map.js +1 -1
  165. package/dist/cdn/map/snice-map.min.js +1 -1
  166. package/dist/cdn/markdown/snice-markdown.js +1 -1
  167. package/dist/cdn/markdown/snice-markdown.min.js +1 -1
  168. package/dist/cdn/masonry/snice-masonry.js +1 -1
  169. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  170. package/dist/cdn/menu/snice-menu.js +1 -1
  171. package/dist/cdn/menu/snice-menu.min.js +1 -1
  172. package/dist/cdn/message-strip/snice-message-strip.js +1 -1
  173. package/dist/cdn/message-strip/snice-message-strip.min.js +1 -1
  174. package/dist/cdn/metric-table/snice-metric-table.js +1 -1
  175. package/dist/cdn/metric-table/snice-metric-table.min.js +1 -1
  176. package/dist/cdn/modal/snice-modal.js +1 -1
  177. package/dist/cdn/modal/snice-modal.min.js +1 -1
  178. package/dist/cdn/music-player/snice-music-player.js +1 -1
  179. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  180. package/dist/cdn/nav/snice-nav.js +1 -1
  181. package/dist/cdn/nav/snice-nav.min.js +1 -1
  182. package/dist/cdn/network-graph/snice-network-graph.js +1 -1
  183. package/dist/cdn/network-graph/snice-network-graph.min.js +1 -1
  184. package/dist/cdn/notification-center/README.md +2 -2
  185. package/dist/cdn/notification-center/snice-notification-center.js +191 -7
  186. package/dist/cdn/notification-center/snice-notification-center.js.map +1 -1
  187. package/dist/cdn/notification-center/snice-notification-center.min.js +57 -14
  188. package/dist/cdn/notification-center/snice-notification-center.min.js.map +1 -1
  189. package/dist/cdn/order-tracker/snice-order-tracker.js +1 -1
  190. package/dist/cdn/order-tracker/snice-order-tracker.min.js +1 -1
  191. package/dist/cdn/org-chart/snice-org-chart.js +1 -1
  192. package/dist/cdn/org-chart/snice-org-chart.min.js +1 -1
  193. package/dist/cdn/pagination/snice-pagination.js +1 -1
  194. package/dist/cdn/pagination/snice-pagination.min.js +1 -1
  195. package/dist/cdn/paint/snice-paint.js +1 -1
  196. package/dist/cdn/paint/snice-paint.min.js +1 -1
  197. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js +1 -1
  198. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js +1 -1
  199. package/dist/cdn/permission-matrix/snice-permission-matrix.js +1 -1
  200. package/dist/cdn/permission-matrix/snice-permission-matrix.min.js +1 -1
  201. package/dist/cdn/podcast-player/snice-podcast-player.js +1 -1
  202. package/dist/cdn/podcast-player/snice-podcast-player.min.js +1 -1
  203. package/dist/cdn/pricing-table/snice-pricing-table.js +1 -1
  204. package/dist/cdn/pricing-table/snice-pricing-table.min.js +1 -1
  205. package/dist/cdn/product-card/README.md +1 -1
  206. package/dist/cdn/product-card/snice-product-card.js +2 -2
  207. package/dist/cdn/product-card/snice-product-card.js.map +1 -1
  208. package/dist/cdn/product-card/snice-product-card.min.js +18 -18
  209. package/dist/cdn/product-card/snice-product-card.min.js.map +1 -1
  210. package/dist/cdn/progress/snice-progress.js +1 -1
  211. package/dist/cdn/progress/snice-progress.min.js +1 -1
  212. package/dist/cdn/progress-ring/snice-progress-ring.js +1 -1
  213. package/dist/cdn/progress-ring/snice-progress-ring.min.js +1 -1
  214. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  215. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  216. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  217. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  218. package/dist/cdn/radio/snice-radio.js +1 -1
  219. package/dist/cdn/radio/snice-radio.min.js +1 -1
  220. package/dist/cdn/range-slider/snice-range-slider.js +1 -1
  221. package/dist/cdn/range-slider/snice-range-slider.min.js +1 -1
  222. package/dist/cdn/rating/snice-rating.js +1 -1
  223. package/dist/cdn/rating/snice-rating.min.js +1 -1
  224. package/dist/cdn/receipt/snice-receipt.js +1 -1
  225. package/dist/cdn/receipt/snice-receipt.min.js +1 -1
  226. package/dist/cdn/recipe/snice-recipe.js +1 -1
  227. package/dist/cdn/recipe/snice-recipe.min.js +1 -1
  228. package/dist/cdn/runtime/snice-runtime.esm.js +4 -4
  229. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  230. package/dist/cdn/runtime/snice-runtime.esm.min.js +4 -4
  231. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  232. package/dist/cdn/runtime/snice-runtime.js +4 -4
  233. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  234. package/dist/cdn/runtime/snice-runtime.min.js +4 -4
  235. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  236. package/dist/cdn/sankey/snice-sankey.js +1 -1
  237. package/dist/cdn/sankey/snice-sankey.min.js +1 -1
  238. package/dist/cdn/segmented-control/snice-segmented-control.js +1 -1
  239. package/dist/cdn/segmented-control/snice-segmented-control.min.js +1 -1
  240. package/dist/cdn/select/snice-select.js +1 -1
  241. package/dist/cdn/select/snice-select.min.js +1 -1
  242. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  243. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  244. package/dist/cdn/slider/snice-slider.js +1 -1
  245. package/dist/cdn/slider/snice-slider.min.js +1 -1
  246. package/dist/cdn/sortable/snice-sortable.js +1 -1
  247. package/dist/cdn/sortable/snice-sortable.min.js +1 -1
  248. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  249. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  250. package/dist/cdn/spinner/snice-spinner.js +1 -1
  251. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  252. package/dist/cdn/split-button/snice-split-button.js +1 -1
  253. package/dist/cdn/split-button/snice-split-button.min.js +1 -1
  254. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  255. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  256. package/dist/cdn/spotlight/snice-spotlight.js +1 -1
  257. package/dist/cdn/spotlight/snice-spotlight.min.js +1 -1
  258. package/dist/cdn/spreadsheet/snice-spreadsheet.js +1 -1
  259. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js +1 -1
  260. package/dist/cdn/stat-group/snice-stat-group.js +1 -1
  261. package/dist/cdn/stat-group/snice-stat-group.min.js +1 -1
  262. package/dist/cdn/step-input/snice-step-input.js +1 -1
  263. package/dist/cdn/step-input/snice-step-input.min.js +1 -1
  264. package/dist/cdn/stepper/snice-stepper.js +1 -1
  265. package/dist/cdn/stepper/snice-stepper.min.js +1 -1
  266. package/dist/cdn/switch/snice-switch.js +1 -1
  267. package/dist/cdn/switch/snice-switch.min.js +1 -1
  268. package/dist/cdn/table/snice-table.js +1 -1
  269. package/dist/cdn/table/snice-table.min.js +1 -1
  270. package/dist/cdn/tabs/snice-tabs.js +1 -1
  271. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  272. package/dist/cdn/tag/snice-tag.js +1 -1
  273. package/dist/cdn/tag/snice-tag.min.js +1 -1
  274. package/dist/cdn/tag-input/snice-tag-input.js +1 -1
  275. package/dist/cdn/tag-input/snice-tag-input.min.js +1 -1
  276. package/dist/cdn/terminal/snice-terminal.js +1 -1
  277. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  278. package/dist/cdn/testimonial/snice-testimonial.js +1 -1
  279. package/dist/cdn/testimonial/snice-testimonial.min.js +1 -1
  280. package/dist/cdn/textarea/snice-textarea.js +1 -1
  281. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  282. package/dist/cdn/time-picker/snice-time-picker.js +1 -1
  283. package/dist/cdn/time-picker/snice-time-picker.min.js +1 -1
  284. package/dist/cdn/time-range-picker/snice-time-range-picker.js +1 -1
  285. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +1 -1
  286. package/dist/cdn/timeline/snice-timeline.js +1 -1
  287. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  288. package/dist/cdn/timer/snice-timer.js +1 -1
  289. package/dist/cdn/timer/snice-timer.min.js +1 -1
  290. package/dist/cdn/toast/README.md +2 -2
  291. package/dist/cdn/toast/snice-toast.js +9 -9
  292. package/dist/cdn/toast/snice-toast.js.map +1 -1
  293. package/dist/cdn/toast/snice-toast.min.js +12 -12
  294. package/dist/cdn/toast/snice-toast.min.js.map +1 -1
  295. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  296. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  297. package/dist/cdn/tree/snice-tree.js +1 -1
  298. package/dist/cdn/tree/snice-tree.min.js +1 -1
  299. package/dist/cdn/treemap/snice-treemap.js +1 -1
  300. package/dist/cdn/treemap/snice-treemap.min.js +1 -1
  301. package/dist/cdn/user-card/snice-user-card.js +1 -1
  302. package/dist/cdn/user-card/snice-user-card.min.js +1 -1
  303. package/dist/cdn/video-player/snice-video-player.js +1 -1
  304. package/dist/cdn/video-player/snice-video-player.min.js +1 -1
  305. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +1 -1
  306. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +1 -1
  307. package/dist/cdn/waterfall/snice-waterfall.js +1 -1
  308. package/dist/cdn/waterfall/snice-waterfall.min.js +1 -1
  309. package/dist/cdn/weather/snice-weather.js +1 -1
  310. package/dist/cdn/weather/snice-weather.min.js +1 -1
  311. package/dist/cdn/work-order/snice-work-order.js +1 -1
  312. package/dist/cdn/work-order/snice-work-order.min.js +1 -1
  313. package/dist/components/app-tiles/snice-app-tiles.d.ts +1 -1
  314. package/dist/components/app-tiles/snice-app-tiles.js +1 -1
  315. package/dist/components/app-tiles/snice-app-tiles.js.map +1 -1
  316. package/dist/components/app-tiles/snice-app-tiles.types.d.ts +1 -1
  317. package/dist/components/cart/snice-cart.js +23 -19
  318. package/dist/components/cart/snice-cart.js.map +1 -1
  319. package/dist/components/chat/snice-chat.d.ts +1 -0
  320. package/dist/components/chat/snice-chat.js +10 -9
  321. package/dist/components/chat/snice-chat.js.map +1 -1
  322. package/dist/components/code-block/snice-code-block.js +1 -1
  323. package/dist/components/code-block/snice-code-block.js.map +1 -1
  324. package/dist/components/command-palette/snice-command-palette.js +1 -1
  325. package/dist/components/command-palette/snice-command-palette.js.map +1 -1
  326. package/dist/components/drawer/snice-drawer.d.ts +13 -0
  327. package/dist/components/drawer/snice-drawer.js +128 -21
  328. package/dist/components/drawer/snice-drawer.js.map +1 -1
  329. package/dist/components/drawer/snice-drawer.types.d.ts +4 -0
  330. package/dist/components/heatmap/snice-heatmap.js +1 -1
  331. package/dist/components/heatmap/snice-heatmap.js.map +1 -1
  332. package/dist/components/list/snice-list.d.ts +1 -0
  333. package/dist/components/list/snice-list.js +10 -5
  334. package/dist/components/list/snice-list.js.map +1 -1
  335. package/dist/components/notification-center/snice-notification-center.d.ts +2 -0
  336. package/dist/components/notification-center/snice-notification-center.js +24 -6
  337. package/dist/components/notification-center/snice-notification-center.js.map +1 -1
  338. package/dist/components/notification-center/snice-notification-center.types.d.ts +1 -0
  339. package/dist/components/product-card/snice-product-card.js +1 -1
  340. package/dist/components/product-card/snice-product-card.js.map +1 -1
  341. package/dist/components/toast/snice-toast.js +8 -8
  342. package/dist/index.cjs +1 -1
  343. package/dist/index.esm.js +1 -1
  344. package/dist/index.iife.js +1 -1
  345. package/dist/symbols.cjs +1 -1
  346. package/dist/symbols.esm.js +1 -1
  347. package/dist/transitions.cjs +1 -1
  348. package/dist/transitions.esm.js +1 -1
  349. package/docs/ai/components/app-tiles.md +12 -1
  350. package/docs/ai/components/drawer.md +45 -1
  351. package/docs/components/app-tiles.md +24 -8
  352. package/docs/components/drawer.md +65 -0
  353. package/package.json +1 -1
  354. package/adapters/react/icon.d.ts +0 -29
  355. package/adapters/react/icon.d.ts.map +0 -1
  356. package/adapters/react/icon.js +0 -24
  357. package/adapters/react/icon.js.map +0 -1
  358. package/adapters/react/icon.tsx +0 -37
  359. package/dist/components/icon/snice-icon.d.ts +0 -18
  360. package/dist/components/icon/snice-icon.types.d.ts +0 -11
  361. package/docs/ai/components/icon.md +0 -63
  362. package/docs/components/icon.md +0 -186
@@ -1,10 +1,43 @@
1
1
  /*!
2
- * snice v4.20.0
2
+ * snice v4.21.0
3
3
  * Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.
4
4
  * (c) 2024
5
5
  * Released under the MIT License.
6
6
  */
7
- void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be loaded before snice-chat.min.js");var SniceChat=function(e,t){"use strict";function s(e,t,s,a,i,n){function r(e){if(void 0!==e&&"function"!=typeof e)throw new TypeError("Function expected");return e}for(var o,l=a.kind,c="getter"===l?"get":"setter"===l?"set":"value",d=!t&&e?a.static?e:e.prototype:null,p=t||(d?Object.getOwnPropertyDescriptor(d,a.name):{}),h=!1,m=s.length-1;m>=0;m--){var g={};for(var u in a)g[u]="access"===u?{}:a[u];for(var u in a.access)g.access[u]=a.access[u];g.addInitializer=function(e){if(h)throw new TypeError("Cannot add initializers after decoration has completed");n.push(r(e||null))};var v=(0,s[m])("accessor"===l?{get:p.get,set:p.set}:p[c],g);if("accessor"===l){if(void 0===v)continue;if(null===v||"object"!=typeof v)throw new TypeError("Object expected");(o=r(v.get))&&(p.get=o),(o=r(v.set))&&(p.set=o),(o=r(v.init))&&i.unshift(o)}else(o=r(v))&&("field"===l?i.unshift(o):p[c]=o)}d&&Object.defineProperty(d,a.name,p),h=!0}function a(e,t,s){for(var a=arguments.length>2,i=0;i<t.length;i++)s=a?t[i].call(e,s):t[i].call(e);return a?s:void 0}"function"==typeof SuppressedError&&SuppressedError;let i=(()=>{let e,i,n,r,o,l,c,d,p,h,m,g,u,v,y,b,x,f,w,k,T,M,$,S,z=[t.element("snice-chat")],A=[],I=HTMLElement,E=[],C=[],j=[],F=[],D=[],B=[],H=[],R=[],U=[],V=[],O=[],K=[],L=[],q=[],P=[],Y=[],_=[],N=[],G=[],J=[],Q=[];return class extends I{static{i=this}constructor(){super(...arguments),this.messages=(a(this,E),a(this,C,[])),this.currentUser=(a(this,j),a(this,F,"You")),this.currentAvatar=(a(this,D),a(this,B,"")),this.placeholder=(a(this,H),a(this,R,"Type a message...")),this.allowFiles=(a(this,U),a(this,V,!0)),this.showTyping=(a(this,O),a(this,K,!0)),this.showAvatars=(a(this,L),a(this,q,!0)),this.showTimestamps=(a(this,P),a(this,Y,!0)),this.messagesArea=(a(this,_),a(this,N,void 0)),this.inputField=(a(this,G),a(this,J,void 0)),this.typingIndicators=(a(this,Q),new Map),this.typingTimeout=null,this.fileInput=null,this.handleKeyDown=e=>{e.target===this.inputField&&("Enter"!==e.key||e.shiftKey||(e.preventDefault(),this.sendMessage()))}}static{const W="function"==typeof Symbol&&Symbol.metadata?Object.create(I[Symbol.metadata]??null):void 0;n=[t.property({type:Array,attribute:!1})],r=[t.property({type:String,attribute:"current-user"})],o=[t.property({type:String,attribute:"current-avatar"})],l=[t.property({type:String})],c=[t.property({type:Boolean,attribute:"allow-files"})],d=[t.property({type:Boolean,attribute:"show-typing"})],p=[t.property({type:Boolean,attribute:"show-avatars"})],h=[t.property({type:Boolean,attribute:"show-timestamps"})],m=[t.query(".messages-area")],g=[t.query(".input-field")],u=[t.styles()],v=[t.ready()],y=[t.dispose()],b=[t.watch("messages")],x=[t.dispatch("message-send")],f=[t.dispatch("message-edit")],w=[t.dispatch("message-delete")],k=[t.dispatch("message-react")],T=[t.dispatch("message-thread")],M=[t.dispatch("typing-start")],$=[t.dispatch("typing-stop")],S=[t.render()],s(this,null,u,{kind:"method",name:"styles",static:!1,private:!1,access:{has:e=>"styles"in e,get:e=>e.styles},metadata:W},null,E),s(this,null,v,{kind:"method",name:"init",static:!1,private:!1,access:{has:e=>"init"in e,get:e=>e.init},metadata:W},null,E),s(this,null,y,{kind:"method",name:"cleanup",static:!1,private:!1,access:{has:e=>"cleanup"in e,get:e=>e.cleanup},metadata:W},null,E),s(this,null,b,{kind:"method",name:"messagesChanged",static:!1,private:!1,access:{has:e=>"messagesChanged"in e,get:e=>e.messagesChanged},metadata:W},null,E),s(this,null,x,{kind:"method",name:"emitMessageSend",static:!1,private:!1,access:{has:e=>"emitMessageSend"in e,get:e=>e.emitMessageSend},metadata:W},null,E),s(this,null,f,{kind:"method",name:"emitMessageEdit",static:!1,private:!1,access:{has:e=>"emitMessageEdit"in e,get:e=>e.emitMessageEdit},metadata:W},null,E),s(this,null,w,{kind:"method",name:"emitMessageDelete",static:!1,private:!1,access:{has:e=>"emitMessageDelete"in e,get:e=>e.emitMessageDelete},metadata:W},null,E),s(this,null,k,{kind:"method",name:"emitMessageReact",static:!1,private:!1,access:{has:e=>"emitMessageReact"in e,get:e=>e.emitMessageReact},metadata:W},null,E),s(this,null,T,{kind:"method",name:"emitMessageThread",static:!1,private:!1,access:{has:e=>"emitMessageThread"in e,get:e=>e.emitMessageThread},metadata:W},null,E),s(this,null,M,{kind:"method",name:"emitTypingStart",static:!1,private:!1,access:{has:e=>"emitTypingStart"in e,get:e=>e.emitTypingStart},metadata:W},null,E),s(this,null,$,{kind:"method",name:"emitTypingStop",static:!1,private:!1,access:{has:e=>"emitTypingStop"in e,get:e=>e.emitTypingStop},metadata:W},null,E),s(this,null,S,{kind:"method",name:"render",static:!1,private:!1,access:{has:e=>"render"in e,get:e=>e.render},metadata:W},null,E),s(null,null,n,{kind:"field",name:"messages",static:!1,private:!1,access:{has:e=>"messages"in e,get:e=>e.messages,set:(e,t)=>{e.messages=t}},metadata:W},C,j),s(null,null,r,{kind:"field",name:"currentUser",static:!1,private:!1,access:{has:e=>"currentUser"in e,get:e=>e.currentUser,set:(e,t)=>{e.currentUser=t}},metadata:W},F,D),s(null,null,o,{kind:"field",name:"currentAvatar",static:!1,private:!1,access:{has:e=>"currentAvatar"in e,get:e=>e.currentAvatar,set:(e,t)=>{e.currentAvatar=t}},metadata:W},B,H),s(null,null,l,{kind:"field",name:"placeholder",static:!1,private:!1,access:{has:e=>"placeholder"in e,get:e=>e.placeholder,set:(e,t)=>{e.placeholder=t}},metadata:W},R,U),s(null,null,c,{kind:"field",name:"allowFiles",static:!1,private:!1,access:{has:e=>"allowFiles"in e,get:e=>e.allowFiles,set:(e,t)=>{e.allowFiles=t}},metadata:W},V,O),s(null,null,d,{kind:"field",name:"showTyping",static:!1,private:!1,access:{has:e=>"showTyping"in e,get:e=>e.showTyping,set:(e,t)=>{e.showTyping=t}},metadata:W},K,L),s(null,null,p,{kind:"field",name:"showAvatars",static:!1,private:!1,access:{has:e=>"showAvatars"in e,get:e=>e.showAvatars,set:(e,t)=>{e.showAvatars=t}},metadata:W},q,P),s(null,null,h,{kind:"field",name:"showTimestamps",static:!1,private:!1,access:{has:e=>"showTimestamps"in e,get:e=>e.showTimestamps,set:(e,t)=>{e.showTimestamps=t}},metadata:W},Y,_),s(null,null,m,{kind:"field",name:"messagesArea",static:!1,private:!1,access:{has:e=>"messagesArea"in e,get:e=>e.messagesArea,set:(e,t)=>{e.messagesArea=t}},metadata:W},N,G),s(null,null,g,{kind:"field",name:"inputField",static:!1,private:!1,access:{has:e=>"inputField"in e,get:e=>e.inputField,set:(e,t)=>{e.inputField=t}},metadata:W},J,Q),s(null,e={value:i},z,{kind:"class",name:i.name,metadata:W},null,A),i=e.value,W&&Object.defineProperty(i,Symbol.metadata,{enumerable:!0,configurable:!0,writable:!0,value:W}),a(i,A)}styles(){return t.css`${":host{display:flex;flex-direction:column;height:var(--snice-chat-height,600px);font-family:var(--snice-font-family);font-size:15px;line-height:1.5;color:var(--snice-color-text);background:var(--snice-color-background-element);border:1px solid var(--snice-color-border);border-radius:var(--snice-border-radius-md);overflow:hidden;box-shadow:var(--snice-shadow-md)}.chat-container{display:flex;flex-direction:column;height:100%}.messages-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.messages-area::-webkit-scrollbar{width:8px}.messages-area::-webkit-scrollbar-track{background:0 0}.messages-area::-webkit-scrollbar-thumb{background:var(--snice-color-border);border-radius:4px}.messages-area::-webkit-scrollbar-thumb:hover{background:var(--snice-color-text-secondary)}.message{display:flex;gap:12px;padding:4px 0;position:relative}.message:hover .message-actions{opacity:1}.message-avatar{width:36px;height:36px;border-radius:4px;background:var(--snice-color-background-secondary);display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);font-weight:600;font-size:14px;flex-shrink:0}.message-avatar img{width:100%;height:100%;border-radius:4px;object-fit:cover}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-author{font-weight:700;color:var(--snice-color-text)}.message-timestamp{font-size:12px;color:var(--snice-color-text-secondary)}.message-edited{font-size:12px;color:var(--snice-color-text-secondary);font-style:italic}.message-text{word-wrap:break-word;white-space:pre-wrap;color:var(--snice-color-text)}.message.system{justify-content:center}.message.system .message-text{text-align:center;color:var(--snice-color-text-secondary);font-size:13px;font-style:italic}.message-attachment{margin-top:8px;border:1px solid var(--snice-color-border);border-radius:4px;overflow:hidden;max-width:400px}.message-attachment img{max-width:100%;display:block}.attachment-file{display:flex;align-items:center;gap:12px;padding:12px;background:var(--snice-color-background-secondary)}.attachment-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--snice-color-background);border-radius:4px;color:var(--snice-color-text-secondary)}.attachment-info{flex:1;min-width:0}.attachment-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{font-size:12px;color:var(--snice-color-text-secondary)}.message-reactions{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.reaction{display:flex;align-items:center;gap:4px;padding:2px 8px;background:var(--snice-color-background-secondary);border:1px solid var(--snice-color-border);border-radius:12px;font-size:13px;cursor:pointer;transition:.2s}.reaction:hover{background:var(--snice-color-background-hover)}.reaction.active{background:var(--snice-color-primary);color:var(--snice-color-text-inverse);border-color:var(--snice-color-primary)}.reaction-emoji{font-size:14px}.reaction-count{font-size:12px;font-weight:500}.message-actions{position:absolute;top:-12px;right:16px;background:var(--snice-color-background-element);border:1px solid var(--snice-color-border);border-radius:4px;box-shadow:var(--snice-shadow-md);display:flex;gap:2px;opacity:0;transition:opacity .2s;padding:2px}.action-button{width:28px;height:28px;border:none;background:0 0;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);transition:background .2s}.action-button:hover{background:var(--snice-color-background-hover)}.action-button svg{width:16px;height:16px}.typing-indicators{padding:0 16px 8px;min-height:24px}.typing-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--snice-color-text-secondary);font-style:italic}.typing-dots{display:flex;gap:3px}.typing-dot{width:6px;height:6px;background:var(--snice-color-text-secondary);border-radius:50%;animation:1.4s ease-in-out infinite typing-bounce}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,100%,60%{transform:translateY(0)}30%{transform:translateY(-4px)}}.input-area{border-top:1px solid var(--snice-color-border);padding:16px;background:var(--snice-color-background-element)}.input-container{display:flex;align-items:flex-end;gap:8px;background:var(--snice-color-background-input);border:1px solid var(--snice-color-border);border-radius:4px;padding:8px;transition:border-color .2s}.input-container:focus-within{border-color:var(--snice-color-primary)}.input-field{flex:1;border:none;outline:0;resize:none;font-family:inherit;font-size:15px;line-height:1.5;min-height:22px;max-height:150px;overflow-y:auto;background:0 0;color:var(--snice-color-text)}.input-field::placeholder{color:var(--snice-color-text-secondary)}.input-field::-webkit-scrollbar{width:4px}.input-field::-webkit-scrollbar-thumb{background:var(--snice-color-border);border-radius:2px}.input-buttons{display:flex;gap:4px}.input-button{width:32px;height:32px;border:none;background:0 0;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);transition:background .2s}.input-button:hover{background:var(--snice-color-background-hover)}.input-button:disabled{opacity:.5;cursor:not-allowed}.input-button.send{color:var(--snice-color-text-inverse);background:var(--snice-color-primary)}.input-button.send:hover:not(:disabled){background:var(--snice-color-primary-dark)}.input-button svg{width:18px;height:18px}input[type=file]{display:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--snice-color-text-secondary);text-align:center;padding:20px}.empty-state-icon{width:64px;height:64px;margin-bottom:16px;opacity:.3}"}`}init(){this.addEventListener("keydown",this.handleKeyDown)}cleanup(){this.removeEventListener("keydown",this.handleKeyDown),this.typingTimeout&&clearTimeout(this.typingTimeout)}messagesChanged(){setTimeout(()=>this.scrollToBottom(),0)}emitMessageSend(e,t){return new CustomEvent("message-send",{detail:{message:e,attachments:t},bubbles:!0,composed:!0})}emitMessageEdit(e,t){return new CustomEvent("message-edit",{detail:{messageId:e,newContent:t},bubbles:!0,composed:!0})}emitMessageDelete(e){return new CustomEvent("message-delete",{detail:{messageId:e},bubbles:!0,composed:!0})}emitMessageReact(e,t){return new CustomEvent("message-react",{detail:{messageId:e,emoji:t},bubbles:!0,composed:!0})}emitMessageThread(e){return new CustomEvent("message-thread",{detail:{messageId:e},bubbles:!0,composed:!0})}emitTypingStart(){return new CustomEvent("typing-start",{bubbles:!0,composed:!0})}emitTypingStop(){return new CustomEvent("typing-stop",{bubbles:!0,composed:!0})}addMessage(e){const t={...e,id:`msg_${Date.now()}_${Math.random().toString(36).substring(2,9)}`};this.messages=[...this.messages,t]}updateMessage(e,t){this.messages=this.messages.map(s=>s.id===e?{...s,...t}:s)}deleteMessage(e){this.messages=this.messages.filter(t=>t.id!==e)}addTypingIndicator(e){this.typingIndicators.set(e,{user:e,timestamp:new Date})}removeTypingIndicator(e){this.typingIndicators.delete(e)}clear(){this.messages=[]}scrollToBottom(){this.messagesArea&&(this.messagesArea.scrollTop=this.messagesArea.scrollHeight)}scrollToMessage(e){const t=this.shadowRoot?.querySelector(`[data-message-id="${e}"]`);t&&t.scrollIntoView({behavior:"smooth",block:"center"})}handleInput(){this.typingTimeout||this.emitTypingStart(),this.typingTimeout&&clearTimeout(this.typingTimeout),this.typingTimeout=window.setTimeout(()=>{this.emitTypingStop(),this.typingTimeout=null},1e3)}sendMessage(){const e=this.inputField.value.trim();e&&(this.emitMessageSend(e),this.inputField.value="",this.adjustTextareaHeight(),this.typingTimeout&&(clearTimeout(this.typingTimeout),this.typingTimeout=null),this.emitTypingStop())}handleFileClick(){this.fileInput||(this.fileInput=document.createElement("input"),this.fileInput.type="file",this.fileInput.multiple=!0,this.fileInput.addEventListener("change",()=>this.handleFileSelect())),this.fileInput.click()}handleFileSelect(){if(!this.fileInput?.files||0===this.fileInput.files.length)return;const e=Array.from(this.fileInput.files);this.emitMessageSend("",e),this.fileInput.value=""}adjustTextareaHeight(){this.inputField&&(this.inputField.style.height="auto",this.inputField.style.height=`${Math.min(this.inputField.scrollHeight,150)}px`)}handleReaction(e,t){this.emitMessageReact(e,t)}handleEdit(e){const t=this.messages.find(t=>t.id===e);if(!t)return;const s=prompt("Edit message:",t.content);s&&s!==t.content&&this.emitMessageEdit(e,s)}handleDelete(e){confirm("Delete this message?")&&this.emitMessageDelete(e)}handleThread(e){this.emitMessageThread(e)}render(){return t.html`
7
+ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be loaded before snice-chat.min.js");var SniceChat=function(e,t){"use strict";function s(e,t,s,i,a,n){function r(e){if(void 0!==e&&"function"!=typeof e)throw new TypeError("Function expected");return e}for(var o,c=i.kind,l="getter"===c?"get":"setter"===c?"set":"value",d=!t&&e?i.static?e:e.prototype:null,p=t||(d?Object.getOwnPropertyDescriptor(d,i.name):{}),m=!1,h=s.length-1;h>=0;h--){var g={};for(var u in i)g[u]="access"===u?{}:i[u];for(var u in i.access)g.access[u]=i.access[u];g.addInitializer=function(e){if(m)throw new TypeError("Cannot add initializers after decoration has completed");n.push(r(e||null))};var v=(0,s[h])("accessor"===c?{get:p.get,set:p.set}:p[l],g);if("accessor"===c){if(void 0===v)continue;if(null===v||"object"!=typeof v)throw new TypeError("Object expected");(o=r(v.get))&&(p.get=o),(o=r(v.set))&&(p.set=o),(o=r(v.init))&&a.unshift(o)}else(o=r(v))&&("field"===c?a.unshift(o):p[l]=o)}d&&Object.defineProperty(d,i.name,p),m=!0}function i(e,t,s){for(var i=arguments.length>2,a=0;a<t.length;a++)s=i?t[a].call(e,s):t[a].call(e);return i?s:void 0}"function"==typeof SuppressedError&&SuppressedError;(()=>{let e,a,n,r,o,c,l,d,p,m,h,g=[t.element("snice-empty-state")],u=[],v=HTMLElement,y=[],f=[],b=[],x=[],w=[],k=[],z=[],$=[],T=[],_=[],M=[],S=[],A=[];(class extends v{static{a=this}static{const j="function"==typeof Symbol&&Symbol.metadata?Object.create(v[Symbol.metadata]??null):void 0;n=[t.property({})],r=[t.property({})],o=[t.property({})],c=[t.property({})],l=[t.property({attribute:"action-text"})],d=[t.property({attribute:"action-href"})],p=[t.render()],m=[t.styles()],h=[t.dispatch("empty-state-action",{bubbles:!0,composed:!0})],s(this,null,p,{kind:"method",name:"render",static:!1,private:!1,access:{has:e=>"render"in e,get:e=>e.render},metadata:j},null,y),s(this,null,m,{kind:"method",name:"styles",static:!1,private:!1,access:{has:e=>"styles"in e,get:e=>e.styles},metadata:j},null,y),s(this,null,h,{kind:"method",name:"dispatchActionEvent",static:!1,private:!1,access:{has:e=>"dispatchActionEvent"in e,get:e=>e.dispatchActionEvent},metadata:j},null,y),s(null,null,n,{kind:"field",name:"size",static:!1,private:!1,access:{has:e=>"size"in e,get:e=>e.size,set:(e,t)=>{e.size=t}},metadata:j},f,b),s(null,null,r,{kind:"field",name:"icon",static:!1,private:!1,access:{has:e=>"icon"in e,get:e=>e.icon,set:(e,t)=>{e.icon=t}},metadata:j},x,w),s(null,null,o,{kind:"field",name:"title",static:!1,private:!1,access:{has:e=>"title"in e,get:e=>e.title,set:(e,t)=>{e.title=t}},metadata:j},k,z),s(null,null,c,{kind:"field",name:"description",static:!1,private:!1,access:{has:e=>"description"in e,get:e=>e.description,set:(e,t)=>{e.description=t}},metadata:j},$,T),s(null,null,l,{kind:"field",name:"actionText",static:!1,private:!1,access:{has:e=>"actionText"in e,get:e=>e.actionText,set:(e,t)=>{e.actionText=t}},metadata:j},_,M),s(null,null,d,{kind:"field",name:"actionHref",static:!1,private:!1,access:{has:e=>"actionHref"in e,get:e=>e.actionHref,set:(e,t)=>{e.actionHref=t}},metadata:j},S,A),s(null,e={value:a},g,{kind:"class",name:a.name,metadata:j},null,u),a=e.value,j&&Object.defineProperty(a,Symbol.metadata,{enumerable:!0,configurable:!0,writable:!0,value:j}),i(a,u)}render(){const e=["empty-state",`empty-state--${this.size}`].filter(Boolean).join(" ");return t.html`
8
+ <div class="${e}" part="container">
9
+ <div class="empty-state__icon-wrapper" part="icon">
10
+ <slot name="icon">
11
+ ${function(e,s="icon"){if(!e)return t.html``;if(e.startsWith("img://")){const i=e.slice(6);return t.html`<img class="${s}" src="${i}" alt="" part="icon" />`}if(e.startsWith("text://")){const i=e.slice(7);return t.html`<span class="${s}" part="icon">${i}</span>`}return/^(https?:\/\/|\/|\.\/|\.\.\/|data:)/.test(e)||/^[^:]*\w\.(svg|png|jpe?g|jfif|pjp|gif|webp|avif|jxl|ico|cur|bmp|tiff?|heic|heif|apng)$/i.test(e)?t.html`<img class="${s}" src="${e}" alt="" part="icon" />`:t.html`<span class="${s}" part="icon">${e}</span>`}(this.icon,"empty-state__icon")}
12
+ </slot>
13
+ </div>
14
+ <h3 class="empty-state__title" part="title">${this.title}</h3>
15
+ <if ${this.description}>
16
+ <p class="empty-state__description" part="description">${this.description}</p>
17
+ </if>
18
+ <if ${this.actionText}>
19
+ <case ${this.actionHref?"link":"button"}>
20
+ <when value="link">
21
+ <a
22
+ href="${this.actionHref}"
23
+ class="empty-state__action"
24
+ part="action"
25
+ @click=${this.handleActionClick}
26
+ >${this.actionText}</a>
27
+ </when>
28
+ <when value="button">
29
+ <button
30
+ class="empty-state__action"
31
+ part="action"
32
+ type="button"
33
+ @click=${this.handleActionClick}
34
+ >${this.actionText}</button>
35
+ </when>
36
+ </case>
37
+ </if>
38
+ <slot></slot>
39
+ </div>
40
+ `}styles(){return t.css`${":host{display:block;font-family:var(--snice-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif);contain:layout style paint}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--snice-spacing-2xl,3rem) var(--snice-spacing-xl,2rem);color:var(--snice-color-text-secondary,rgb(82 82 82))}.empty-state--small{padding:var(--snice-spacing-xl,2rem) var(--snice-spacing-lg,1.5rem)}.empty-state--medium{padding:var(--snice-spacing-2xl,3rem) var(--snice-spacing-xl,2rem)}.empty-state--large{padding:var(--snice-spacing-3xl,4rem) var(--snice-spacing-2xl,2.5rem)}.empty-state__icon-wrapper{display:flex;align-items:center;justify-content:center;margin-bottom:var(--snice-spacing-lg,1.5rem)}.empty-state__icon{font-size:var(--snice-font-size-4xl, 4rem);opacity:.5;line-height:1}.empty-state__icon-wrapper ::slotted(*){display:flex;align-items:center;justify-content:center;font-size:var(--snice-font-size-4xl, 4rem);opacity:.5;line-height:1}.empty-state__icon-wrapper ::slotted(svg){width:var(--snice-font-size-4xl,4rem);height:var(--snice-font-size-4xl,4rem)}.empty-state__icon-wrapper ::slotted(img){width:var(--snice-font-size-4xl,4rem);height:var(--snice-font-size-4xl,4rem);object-fit:contain}.empty-state--small .empty-state__icon-wrapper{margin-bottom:var(--snice-spacing-md,1rem)}.empty-state--small .empty-state__icon{font-size:var(--snice-font-size-3xl, 3rem)}.empty-state--small .empty-state__icon-wrapper ::slotted(*){font-size:var(--snice-font-size-3xl, 3rem)}.empty-state--small .empty-state__icon-wrapper ::slotted(img),.empty-state--small .empty-state__icon-wrapper ::slotted(svg){width:var(--snice-font-size-3xl,3rem);height:var(--snice-font-size-3xl,3rem)}.empty-state--large .empty-state__icon-wrapper{margin-bottom:var(--snice-spacing-xl,2rem)}.empty-state--large .empty-state__icon{font-size:var(--snice-font-size-5xl, 5rem)}.empty-state--large .empty-state__icon-wrapper ::slotted(*){font-size:var(--snice-font-size-5xl, 5rem)}.empty-state--large .empty-state__icon-wrapper ::slotted(img),.empty-state--large .empty-state__icon-wrapper ::slotted(svg){width:var(--snice-font-size-5xl,5rem);height:var(--snice-font-size-5xl,5rem)}.empty-state__title{font-size:var(--snice-font-size-xl, 1.25rem);font-weight:var(--snice-font-weight-semibold,600);color:var(--snice-color-text,rgb(23 23 23));margin:0 0 var(--snice-spacing-xs,.5rem) 0}.empty-state--small .empty-state__title{font-size:var(--snice-font-size-lg, 1.125rem);margin-bottom:var(--snice-spacing-2xs,.375rem)}.empty-state--large .empty-state__title{font-size:var(--snice-font-size-2xl, 1.5rem);margin-bottom:var(--snice-spacing-sm,.75rem)}.empty-state__description{font-size:var(--snice-font-size-sm, .875rem);color:var(--snice-color-text-secondary,rgb(82 82 82));margin:0 0 var(--snice-spacing-lg,1.5rem) 0;max-width:32rem;line-height:var(--snice-line-height-normal, 1.5)}.empty-state--small .empty-state__description{font-size:var(--snice-font-size-xs, .8125rem);margin-bottom:var(--snice-spacing-md,1rem)}.empty-state--large .empty-state__description{font-size:var(--snice-font-size-md, 1rem);margin-bottom:var(--snice-spacing-xl,2rem)}.empty-state__action{display:inline-flex;align-items:center;justify-content:center;padding:var(--snice-spacing-xs,.5rem) var(--snice-spacing-md,1rem);font-size:var(--snice-font-size-sm, .875rem);font-weight:var(--snice-font-weight-medium,500);color:var(--snice-color-text-inverse,rgb(250 250 250));background:var(--snice-color-primary,rgb(37 99 235));border:none;border-radius:var(--snice-border-radius-md,.375rem);text-decoration:none;cursor:pointer;transition:background var(--snice-transition-fast, 150ms)}.empty-state__action:hover{background:var(--snice-color-primary-dark,rgb(29 78 216))}.empty-state--small .empty-state__action{padding:var(--snice-spacing-2xs,.375rem) var(--snice-spacing-sm,.75rem);font-size:var(--snice-font-size-xs, .8125rem)}.empty-state--large .empty-state__action{padding:var(--snice-spacing-sm,.625rem) var(--snice-spacing-lg,1.25rem);font-size:var(--snice-font-size-md, 1rem)}::slotted(*){margin-top:var(--snice-spacing-md,1rem)}"}`}handleActionClick(e){this.actionHref||e.preventDefault(),this.dispatchActionEvent()}dispatchActionEvent(){return{emptyState:this}}constructor(){super(...arguments),this.size=(i(this,y),i(this,f,"medium")),this.icon=(i(this,b),i(this,x,"📭")),this.title=(i(this,w),i(this,k,"No data")),this.description=(i(this,z),i(this,$,"")),this.actionText=(i(this,T),i(this,_,"")),this.actionHref=(i(this,M),i(this,S,"")),i(this,A)}})})();let a=(()=>{let e,a,n,r,o,c,l,d,p,m,h,g,u,v,y,f,b,x,w,k,z,$,T,_,M=[t.element("snice-chat")],S=[],A=HTMLElement,j=[],E=[],I=[],C=[],F=[],H=[],D=[],B=[],R=[],U=[],O=[],L=[],V=[],K=[],P=[],q=[],Y=[],N=[],W=[],G=[],J=[];return class extends A{static{a=this}constructor(){super(...arguments),this.messages=(i(this,j),i(this,E,[])),this.currentUser=(i(this,I),i(this,C,"You")),this.currentAvatar=(i(this,F),i(this,H,"")),this.placeholder=(i(this,D),i(this,B,"Type a message...")),this.allowFiles=(i(this,R),i(this,U,!0)),this.showTyping=(i(this,O),i(this,L,!0)),this.showAvatars=(i(this,V),i(this,K,!0)),this.showTimestamps=(i(this,P),i(this,q,!0)),this.messagesArea=(i(this,Y),i(this,N,void 0)),this.inputField=(i(this,W),i(this,G,void 0)),this.typingIndicators=(i(this,J),new Map),this.typingTimeout=null,this.fileInput=null,this.handleKeyDown=e=>{e.target===this.inputField&&("Enter"!==e.key||e.shiftKey||(e.preventDefault(),this.sendMessage()))}}static{const Q="function"==typeof Symbol&&Symbol.metadata?Object.create(A[Symbol.metadata]??null):void 0;n=[t.property({type:Array,attribute:!1})],r=[t.property({type:String,attribute:"current-user"})],o=[t.property({type:String,attribute:"current-avatar"})],c=[t.property({type:String})],l=[t.property({type:Boolean,attribute:"allow-files"})],d=[t.property({type:Boolean,attribute:"show-typing"})],p=[t.property({type:Boolean,attribute:"show-avatars"})],m=[t.property({type:Boolean,attribute:"show-timestamps"})],h=[t.query(".messages-area")],g=[t.query(".input-field")],u=[t.styles()],v=[t.ready()],y=[t.dispose()],f=[t.watch("messages")],b=[t.dispatch("message-send")],x=[t.dispatch("message-edit")],w=[t.dispatch("message-delete")],k=[t.dispatch("message-react")],z=[t.dispatch("message-thread")],$=[t.dispatch("typing-start")],T=[t.dispatch("typing-stop")],_=[t.render()],s(this,null,u,{kind:"method",name:"styles",static:!1,private:!1,access:{has:e=>"styles"in e,get:e=>e.styles},metadata:Q},null,j),s(this,null,v,{kind:"method",name:"init",static:!1,private:!1,access:{has:e=>"init"in e,get:e=>e.init},metadata:Q},null,j),s(this,null,y,{kind:"method",name:"cleanup",static:!1,private:!1,access:{has:e=>"cleanup"in e,get:e=>e.cleanup},metadata:Q},null,j),s(this,null,f,{kind:"method",name:"messagesChanged",static:!1,private:!1,access:{has:e=>"messagesChanged"in e,get:e=>e.messagesChanged},metadata:Q},null,j),s(this,null,b,{kind:"method",name:"emitMessageSend",static:!1,private:!1,access:{has:e=>"emitMessageSend"in e,get:e=>e.emitMessageSend},metadata:Q},null,j),s(this,null,x,{kind:"method",name:"emitMessageEdit",static:!1,private:!1,access:{has:e=>"emitMessageEdit"in e,get:e=>e.emitMessageEdit},metadata:Q},null,j),s(this,null,w,{kind:"method",name:"emitMessageDelete",static:!1,private:!1,access:{has:e=>"emitMessageDelete"in e,get:e=>e.emitMessageDelete},metadata:Q},null,j),s(this,null,k,{kind:"method",name:"emitMessageReact",static:!1,private:!1,access:{has:e=>"emitMessageReact"in e,get:e=>e.emitMessageReact},metadata:Q},null,j),s(this,null,z,{kind:"method",name:"emitMessageThread",static:!1,private:!1,access:{has:e=>"emitMessageThread"in e,get:e=>e.emitMessageThread},metadata:Q},null,j),s(this,null,$,{kind:"method",name:"emitTypingStart",static:!1,private:!1,access:{has:e=>"emitTypingStart"in e,get:e=>e.emitTypingStart},metadata:Q},null,j),s(this,null,T,{kind:"method",name:"emitTypingStop",static:!1,private:!1,access:{has:e=>"emitTypingStop"in e,get:e=>e.emitTypingStop},metadata:Q},null,j),s(this,null,_,{kind:"method",name:"render",static:!1,private:!1,access:{has:e=>"render"in e,get:e=>e.render},metadata:Q},null,j),s(null,null,n,{kind:"field",name:"messages",static:!1,private:!1,access:{has:e=>"messages"in e,get:e=>e.messages,set:(e,t)=>{e.messages=t}},metadata:Q},E,I),s(null,null,r,{kind:"field",name:"currentUser",static:!1,private:!1,access:{has:e=>"currentUser"in e,get:e=>e.currentUser,set:(e,t)=>{e.currentUser=t}},metadata:Q},C,F),s(null,null,o,{kind:"field",name:"currentAvatar",static:!1,private:!1,access:{has:e=>"currentAvatar"in e,get:e=>e.currentAvatar,set:(e,t)=>{e.currentAvatar=t}},metadata:Q},H,D),s(null,null,c,{kind:"field",name:"placeholder",static:!1,private:!1,access:{has:e=>"placeholder"in e,get:e=>e.placeholder,set:(e,t)=>{e.placeholder=t}},metadata:Q},B,R),s(null,null,l,{kind:"field",name:"allowFiles",static:!1,private:!1,access:{has:e=>"allowFiles"in e,get:e=>e.allowFiles,set:(e,t)=>{e.allowFiles=t}},metadata:Q},U,O),s(null,null,d,{kind:"field",name:"showTyping",static:!1,private:!1,access:{has:e=>"showTyping"in e,get:e=>e.showTyping,set:(e,t)=>{e.showTyping=t}},metadata:Q},L,V),s(null,null,p,{kind:"field",name:"showAvatars",static:!1,private:!1,access:{has:e=>"showAvatars"in e,get:e=>e.showAvatars,set:(e,t)=>{e.showAvatars=t}},metadata:Q},K,P),s(null,null,m,{kind:"field",name:"showTimestamps",static:!1,private:!1,access:{has:e=>"showTimestamps"in e,get:e=>e.showTimestamps,set:(e,t)=>{e.showTimestamps=t}},metadata:Q},q,Y),s(null,null,h,{kind:"field",name:"messagesArea",static:!1,private:!1,access:{has:e=>"messagesArea"in e,get:e=>e.messagesArea,set:(e,t)=>{e.messagesArea=t}},metadata:Q},N,W),s(null,null,g,{kind:"field",name:"inputField",static:!1,private:!1,access:{has:e=>"inputField"in e,get:e=>e.inputField,set:(e,t)=>{e.inputField=t}},metadata:Q},G,J),s(null,e={value:a},M,{kind:"class",name:a.name,metadata:Q},null,S),a=e.value,Q&&Object.defineProperty(a,Symbol.metadata,{enumerable:!0,configurable:!0,writable:!0,value:Q}),i(a,S)}styles(){return t.css`${":host{display:flex;flex-direction:column;height:var(--snice-chat-height,600px);font-family:var(--snice-font-family);font-size:15px;line-height:1.5;color:var(--snice-color-text);background:var(--snice-color-background-element);border:1px solid var(--snice-color-border);border-radius:var(--snice-border-radius-md);overflow:hidden;box-shadow:var(--snice-shadow-md)}.chat-container{display:flex;flex-direction:column;height:100%}.messages-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.messages-area::-webkit-scrollbar{width:8px}.messages-area::-webkit-scrollbar-track{background:0 0}.messages-area::-webkit-scrollbar-thumb{background:var(--snice-color-border);border-radius:4px}.messages-area::-webkit-scrollbar-thumb:hover{background:var(--snice-color-text-secondary)}.message{display:flex;gap:12px;padding:4px 0;position:relative}.message:hover .message-actions{opacity:1}.message-avatar{width:36px;height:36px;border-radius:4px;background:var(--snice-color-background-secondary);display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);font-weight:600;font-size:14px;flex-shrink:0}.message-avatar img{width:100%;height:100%;border-radius:4px;object-fit:cover}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-author{font-weight:700;color:var(--snice-color-text)}.message-timestamp{font-size:12px;color:var(--snice-color-text-secondary)}.message-edited{font-size:12px;color:var(--snice-color-text-secondary);font-style:italic}.message-text{word-wrap:break-word;white-space:pre-wrap;color:var(--snice-color-text)}.message.system{justify-content:center}.message.system .message-text{text-align:center;color:var(--snice-color-text-secondary);font-size:13px;font-style:italic}.message-attachment{margin-top:8px;border:1px solid var(--snice-color-border);border-radius:4px;overflow:hidden;max-width:400px}.message-attachment img{max-width:100%;display:block}.attachment-file{display:flex;align-items:center;gap:12px;padding:12px;background:var(--snice-color-background-secondary)}.attachment-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--snice-color-background);border-radius:4px;color:var(--snice-color-text-secondary)}.attachment-info{flex:1;min-width:0}.attachment-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{font-size:12px;color:var(--snice-color-text-secondary)}.message-reactions{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.reaction{display:flex;align-items:center;gap:4px;padding:2px 8px;background:var(--snice-color-background-secondary);border:1px solid var(--snice-color-border);border-radius:12px;font-size:13px;cursor:pointer;transition:.2s}.reaction:hover{background:var(--snice-color-background-hover)}.reaction.active{background:var(--snice-color-primary);color:var(--snice-color-text-inverse);border-color:var(--snice-color-primary)}.reaction-emoji{font-size:14px}.reaction-count{font-size:12px;font-weight:500}.message-actions{position:absolute;top:-12px;right:16px;background:var(--snice-color-background-element);border:1px solid var(--snice-color-border);border-radius:4px;box-shadow:var(--snice-shadow-md);display:flex;gap:2px;opacity:0;transition:opacity .2s;padding:2px}.action-button{width:28px;height:28px;border:none;background:0 0;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);transition:background .2s}.action-button:hover{background:var(--snice-color-background-hover)}.action-button svg{width:16px;height:16px}.typing-indicators{padding:0 16px 8px;min-height:24px}.typing-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--snice-color-text-secondary);font-style:italic}.typing-dots{display:flex;gap:3px}.typing-dot{width:6px;height:6px;background:var(--snice-color-text-secondary);border-radius:50%;animation:1.4s ease-in-out infinite typing-bounce}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,100%,60%{transform:translateY(0)}30%{transform:translateY(-4px)}}.input-area{border-top:1px solid var(--snice-color-border);padding:16px;background:var(--snice-color-background-element)}.input-container{display:flex;align-items:flex-end;gap:8px;background:var(--snice-color-background-input);border:1px solid var(--snice-color-border);border-radius:4px;padding:8px;transition:border-color .2s}.input-container:focus-within{border-color:var(--snice-color-primary)}.input-field{flex:1;border:none;outline:0;resize:none;font-family:inherit;font-size:15px;line-height:1.5;min-height:22px;max-height:150px;overflow-y:auto;background:0 0;color:var(--snice-color-text)}.input-field::placeholder{color:var(--snice-color-text-secondary)}.input-field::-webkit-scrollbar{width:4px}.input-field::-webkit-scrollbar-thumb{background:var(--snice-color-border);border-radius:2px}.input-buttons{display:flex;gap:4px}.input-button{width:32px;height:32px;border:none;background:0 0;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--snice-color-text-secondary);transition:background .2s}.input-button:hover{background:var(--snice-color-background-hover)}.input-button:disabled{opacity:.5;cursor:not-allowed}.input-button.send{color:var(--snice-color-text-inverse);background:var(--snice-color-primary)}.input-button.send:hover:not(:disabled){background:var(--snice-color-primary-dark)}.input-button svg{width:18px;height:18px}input[type=file]{display:none}"}`}init(){this.addEventListener("keydown",this.handleKeyDown)}cleanup(){this.removeEventListener("keydown",this.handleKeyDown),this.typingTimeout&&clearTimeout(this.typingTimeout)}messagesChanged(){setTimeout(()=>this.scrollToBottom(),0)}emitMessageSend(e,t){return new CustomEvent("message-send",{detail:{message:e,attachments:t},bubbles:!0,composed:!0})}emitMessageEdit(e,t){return new CustomEvent("message-edit",{detail:{messageId:e,newContent:t},bubbles:!0,composed:!0})}emitMessageDelete(e){return new CustomEvent("message-delete",{detail:{messageId:e},bubbles:!0,composed:!0})}emitMessageReact(e,t){return new CustomEvent("message-react",{detail:{messageId:e,emoji:t},bubbles:!0,composed:!0})}emitMessageThread(e){return new CustomEvent("message-thread",{detail:{messageId:e},bubbles:!0,composed:!0})}emitTypingStart(){return new CustomEvent("typing-start",{bubbles:!0,composed:!0})}emitTypingStop(){return new CustomEvent("typing-stop",{bubbles:!0,composed:!0})}addMessage(e){const t={...e,id:`msg_${Date.now()}_${Math.random().toString(36).substring(2,9)}`};this.messages=[...this.messages,t]}updateMessage(e,t){this.messages=this.messages.map(s=>s.id===e?{...s,...t}:s)}deleteMessage(e){this.messages=this.messages.filter(t=>t.id!==e)}addTypingIndicator(e){this.typingIndicators.set(e,{user:e,timestamp:new Date})}removeTypingIndicator(e){this.typingIndicators.delete(e)}clear(){this.messages=[]}scrollToBottom(){this.messagesArea&&(this.messagesArea.scrollTop=this.messagesArea.scrollHeight)}scrollToMessage(e){const t=this.shadowRoot?.querySelector(`[data-message-id="${e}"]`);t&&t.scrollIntoView({behavior:"smooth",block:"center"})}handleInput(){this.typingTimeout||this.emitTypingStart(),this.typingTimeout&&clearTimeout(this.typingTimeout),this.typingTimeout=window.setTimeout(()=>{this.emitTypingStop(),this.typingTimeout=null},1e3)}sendMessage(){const e=this.inputField.value.trim();e&&(this.emitMessageSend(e),this.inputField.value="",this.adjustTextareaHeight(),this.typingTimeout&&(clearTimeout(this.typingTimeout),this.typingTimeout=null),this.emitTypingStop())}handleFileClick(){this.fileInput||(this.fileInput=document.createElement("input"),this.fileInput.type="file",this.fileInput.multiple=!0,this.fileInput.addEventListener("change",()=>this.handleFileSelect())),this.fileInput.click()}handleFileSelect(){if(!this.fileInput?.files||0===this.fileInput.files.length)return;const e=Array.from(this.fileInput.files);this.emitMessageSend("",e),this.fileInput.value=""}adjustTextareaHeight(){this.inputField&&(this.inputField.style.height="auto",this.inputField.style.height=`${Math.min(this.inputField.scrollHeight,150)}px`)}handleReaction(e,t){this.emitMessageReact(e,t)}handleEdit(e){const t=this.messages.find(t=>t.id===e);if(!t)return;const s=prompt("Edit message:",t.content);s&&s!==t.content&&this.emitMessageEdit(e,s)}handleDelete(e){confirm("Delete this message?")&&this.emitMessageDelete(e)}handleThread(e){this.emitMessageThread(e)}render(){return t.html`
8
41
  <div part="base" class="chat-container">
9
42
  <div part="messages" class="messages-area">
10
43
  ${0===this.messages.length?this.renderEmptyState():this.messages.map(e=>this.renderMessage(e))}
@@ -13,16 +46,15 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
13
46
  ${this.renderInputArea()}
14
47
  </div>
15
48
  `}renderEmptyState(){return t.html`
16
- <div class="empty-state">
17
- <svg class="empty-state-icon" viewBox="0 0 24 24" fill="currentColor">
18
- <path
19
- d="M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 14H6l-2 2V4h16v12z"
20
- />
21
- </svg>
22
- <div>No messages yet</div>
23
- <div style="font-size: 13px; margin-top: 4px;">Start the conversation!</div>
49
+ <div style="padding: 2rem;">
50
+ <snice-empty-state
51
+ icon="💬"
52
+ title="No messages yet"
53
+ description="Start the conversation!"
54
+ size="medium">
55
+ </snice-empty-state>
24
56
  </div>
25
- `}renderMessage(e){const s="system"===e.type,a=e.author===this.currentUser;return s?t.html`
57
+ `}renderMessage(e){const s="system"===e.type,i=e.author===this.currentUser;return s?t.html`
26
58
  <div class="message system" data-message-id="${e.id}">
27
59
  <div class="message-content">
28
60
  <div class="message-text">${e.content}</div>
@@ -32,7 +64,7 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
32
64
  <div class="message" data-message-id="${e.id}">
33
65
  ${this.showAvatars?t.html`
34
66
  <div class="message-avatar">
35
- ${e.avatar?t.html`<img src="${e.avatar}" alt="${e.author}" />`:(i=e.author,i.split(" ").map(e=>e[0]).join("").toUpperCase().substring(0,2))}
67
+ ${e.avatar?t.html`<img src="${e.avatar}" alt="${e.author}" />`:(a=e.author,a.split(" ").map(e=>e[0]).join("").toUpperCase().substring(0,2))}
36
68
  </div>
37
69
  `:""}
38
70
  <div class="message-content">
@@ -43,9 +75,9 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
43
75
  </div>
44
76
  ${e.content?t.html`<div class="message-text">${e.content}</div>`:""}
45
77
  ${e.attachment?this.renderAttachment(e.attachment):""}
46
- ${e.reactions&&e.reactions.length>0?this.renderReactions(e.id,e.reactions,a):""}
78
+ ${e.reactions&&e.reactions.length>0?this.renderReactions(e.id,e.reactions,i):""}
47
79
  </div>
48
- ${a?t.html`
80
+ ${i?t.html`
49
81
  <div class="message-actions">
50
82
  <button
51
83
  class="action-button"
@@ -83,7 +115,7 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
83
115
  </div>
84
116
  `:""}
85
117
  </div>
86
- `;var i}renderAttachment(e){return e?"image"===e.type?t.html`
118
+ `;var a}renderAttachment(e){return e?"image"===e.type?t.html`
87
119
  <div class="message-attachment">
88
120
  <img src="${e.url}" alt="${e.name}" />
89
121
  </div>
@@ -103,7 +135,7 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
103
135
  </div>
104
136
  </div>
105
137
  </div>
106
- `:"";var s}renderReactions(e,s,a){return s&&0!==s.length?t.html`
138
+ `:"";var s}renderReactions(e,s,i){return s&&0!==s.length?t.html`
107
139
  <div class="message-reactions">
108
140
  ${s.map(s=>t.html`
109
141
  <div
@@ -161,5 +193,5 @@ void 0===globalThis.Snice&&console.warn("[snice] snice-runtime.min.js must be lo
161
193
  </div>
162
194
  </div>
163
195
  </div>
164
- `}},i})();return e.SniceChat=i,e}({},Snice);
196
+ `}},a})();return e.SniceChat=a,e}({},Snice);
165
197
  //# sourceMappingURL=snice-chat.min.js.map