snice 4.27.0 → 4.29.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 (624) hide show
  1. package/adapters/react/action-bar.d.ts +30 -0
  2. package/adapters/react/action-bar.d.ts.map +1 -0
  3. package/adapters/react/action-bar.js +24 -0
  4. package/adapters/react/action-bar.js.map +1 -0
  5. package/adapters/react/action-bar.tsx +38 -0
  6. package/adapters/react/binpack.d.ts +35 -0
  7. package/adapters/react/binpack.d.ts.map +1 -0
  8. package/adapters/react/binpack.js +24 -0
  9. package/adapters/react/binpack.js.map +1 -0
  10. package/adapters/react/binpack.tsx +43 -0
  11. package/adapters/react/components.d.ts +4 -0
  12. package/adapters/react/components.d.ts.map +1 -1
  13. package/adapters/react/components.js +2 -0
  14. package/adapters/react/components.js.map +1 -1
  15. package/adapters/react/components.ts +4 -0
  16. package/adapters/react/useRequestHandler.d.ts +56 -0
  17. package/adapters/react/useRequestHandler.js +103 -0
  18. package/adapters/react/useRequestHandler.js.map +1 -0
  19. package/dist/cdn/accordion/snice-accordion.js +1 -1
  20. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  21. package/dist/cdn/action-bar/README.md +27 -0
  22. package/dist/cdn/action-bar/snice-action-bar.js +249 -0
  23. package/dist/cdn/action-bar/snice-action-bar.js.map +1 -0
  24. package/dist/cdn/action-bar/snice-action-bar.min.js +12 -0
  25. package/dist/cdn/action-bar/snice-action-bar.min.js.map +1 -0
  26. package/dist/cdn/activity-feed/snice-activity-feed.js +1 -1
  27. package/dist/cdn/activity-feed/snice-activity-feed.min.js +1 -1
  28. package/dist/cdn/alert/snice-alert.js +1 -1
  29. package/dist/cdn/alert/snice-alert.min.js +1 -1
  30. package/dist/cdn/app-tiles/snice-app-tiles.js +1 -1
  31. package/dist/cdn/app-tiles/snice-app-tiles.min.js +1 -1
  32. package/dist/cdn/approval-flow/snice-approval-flow.js +1 -1
  33. package/dist/cdn/approval-flow/snice-approval-flow.min.js +1 -1
  34. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  35. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  36. package/dist/cdn/availability/snice-availability.js +1 -1
  37. package/dist/cdn/availability/snice-availability.min.js +1 -1
  38. package/dist/cdn/avatar/snice-avatar.js +1 -1
  39. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  40. package/dist/cdn/avatar-group/snice-avatar-group.js +1 -1
  41. package/dist/cdn/avatar-group/snice-avatar-group.min.js +1 -1
  42. package/dist/cdn/badge/snice-badge.js +2 -2
  43. package/dist/cdn/badge/snice-badge.js.map +1 -1
  44. package/dist/cdn/badge/snice-badge.min.js +2 -2
  45. package/dist/cdn/badge/snice-badge.min.js.map +1 -1
  46. package/dist/cdn/banner/snice-banner.js +1 -1
  47. package/dist/cdn/banner/snice-banner.min.js +1 -1
  48. package/dist/cdn/binpack/README.md +27 -0
  49. package/dist/cdn/binpack/snice-binpack.js +1037 -0
  50. package/dist/cdn/binpack/snice-binpack.js.map +1 -0
  51. package/dist/cdn/binpack/snice-binpack.min.js +13 -0
  52. package/dist/cdn/binpack/snice-binpack.min.js.map +1 -0
  53. package/dist/cdn/book/snice-book.js +1 -1
  54. package/dist/cdn/book/snice-book.min.js +1 -1
  55. package/dist/cdn/booking/snice-booking.js +1 -1
  56. package/dist/cdn/booking/snice-booking.min.js +1 -1
  57. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +1 -1
  58. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +1 -1
  59. package/dist/cdn/button/README.md +1 -1
  60. package/dist/cdn/button/snice-button.js +11 -10
  61. package/dist/cdn/button/snice-button.js.map +1 -1
  62. package/dist/cdn/button/snice-button.min.js +3 -3
  63. package/dist/cdn/button/snice-button.min.js.map +1 -1
  64. package/dist/cdn/calendar/snice-calendar.js +1 -1
  65. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  66. package/dist/cdn/camera/snice-camera.js +1 -1
  67. package/dist/cdn/camera/snice-camera.min.js +1 -1
  68. package/dist/cdn/camera-annotate/snice-camera-annotate.js +1 -1
  69. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +1 -1
  70. package/dist/cdn/candlestick/snice-candlestick.js +1 -1
  71. package/dist/cdn/candlestick/snice-candlestick.min.js +1 -1
  72. package/dist/cdn/card/snice-card.js +1 -1
  73. package/dist/cdn/card/snice-card.min.js +1 -1
  74. package/dist/cdn/carousel/snice-carousel.js +1 -1
  75. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  76. package/dist/cdn/cart/snice-cart.js +1 -1
  77. package/dist/cdn/cart/snice-cart.min.js +1 -1
  78. package/dist/cdn/chart/snice-chart.js +1 -1
  79. package/dist/cdn/chart/snice-chart.min.js +1 -1
  80. package/dist/cdn/chat/snice-chat.js +1 -1
  81. package/dist/cdn/chat/snice-chat.min.js +1 -1
  82. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  83. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  84. package/dist/cdn/chip/snice-chip.js +1 -1
  85. package/dist/cdn/chip/snice-chip.min.js +1 -1
  86. package/dist/cdn/code-block/snice-code-block.js +1 -1
  87. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  88. package/dist/cdn/color-display/snice-color-display.js +1 -1
  89. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  90. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  91. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  92. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  93. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  94. package/dist/cdn/comments/snice-comments.js +1 -1
  95. package/dist/cdn/comments/snice-comments.min.js +1 -1
  96. package/dist/cdn/countdown/snice-countdown.js +1 -1
  97. package/dist/cdn/countdown/snice-countdown.min.js +1 -1
  98. package/dist/cdn/cropper/snice-cropper.js +1 -1
  99. package/dist/cdn/cropper/snice-cropper.min.js +1 -1
  100. package/dist/cdn/data-card/snice-data-card.js +1 -1
  101. package/dist/cdn/data-card/snice-data-card.min.js +1 -1
  102. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  103. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  104. package/dist/cdn/date-range-picker/snice-date-range-picker.js +1 -1
  105. package/dist/cdn/date-range-picker/snice-date-range-picker.min.js +1 -1
  106. package/dist/cdn/date-time-picker/snice-date-time-picker.js +1 -1
  107. package/dist/cdn/date-time-picker/snice-date-time-picker.min.js +1 -1
  108. package/dist/cdn/diff/snice-diff.js +1 -1
  109. package/dist/cdn/diff/snice-diff.min.js +1 -1
  110. package/dist/cdn/divider/snice-divider.js +1 -1
  111. package/dist/cdn/divider/snice-divider.min.js +1 -1
  112. package/dist/cdn/doc/snice-doc.js +1 -1
  113. package/dist/cdn/doc/snice-doc.min.js +1 -1
  114. package/dist/cdn/draw/snice-draw.js +1 -1
  115. package/dist/cdn/draw/snice-draw.min.js +1 -1
  116. package/dist/cdn/drawer/snice-drawer.js +1 -1
  117. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  118. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  119. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  120. package/dist/cdn/estimate/snice-estimate.js +1 -1
  121. package/dist/cdn/estimate/snice-estimate.min.js +1 -1
  122. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  123. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  124. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  125. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  126. package/dist/cdn/flip-card/snice-flip-card.js +1 -1
  127. package/dist/cdn/flip-card/snice-flip-card.min.js +1 -1
  128. package/dist/cdn/flow/snice-flow.js +1 -1
  129. package/dist/cdn/flow/snice-flow.min.js +1 -1
  130. package/dist/cdn/form-layout/snice-form-layout.js +1 -1
  131. package/dist/cdn/form-layout/snice-form-layout.min.js +1 -1
  132. package/dist/cdn/funnel/snice-funnel.js +1 -1
  133. package/dist/cdn/funnel/snice-funnel.min.js +1 -1
  134. package/dist/cdn/gantt/snice-gantt.js +1 -1
  135. package/dist/cdn/gantt/snice-gantt.min.js +1 -1
  136. package/dist/cdn/gauge/snice-gauge.js +1 -1
  137. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  138. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  139. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  140. package/dist/cdn/image/snice-image.js +1 -1
  141. package/dist/cdn/image/snice-image.min.js +1 -1
  142. package/dist/cdn/input/snice-input.js +1 -1
  143. package/dist/cdn/input/snice-input.min.js +1 -1
  144. package/dist/cdn/invoice/snice-invoice.js +1 -1
  145. package/dist/cdn/invoice/snice-invoice.min.js +1 -1
  146. package/dist/cdn/kanban/snice-kanban.js +1 -1
  147. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  148. package/dist/cdn/key-value/snice-key-value.js +1 -1
  149. package/dist/cdn/key-value/snice-key-value.min.js +1 -1
  150. package/dist/cdn/kpi/snice-kpi.js +1 -1
  151. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  152. package/dist/cdn/layout/snice-layout.js +1 -1
  153. package/dist/cdn/layout/snice-layout.min.js +1 -1
  154. package/dist/cdn/leaderboard/snice-leaderboard.js +1 -1
  155. package/dist/cdn/leaderboard/snice-leaderboard.min.js +1 -1
  156. package/dist/cdn/link/snice-link.js +1 -1
  157. package/dist/cdn/link/snice-link.min.js +1 -1
  158. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  159. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  160. package/dist/cdn/list/snice-list.js +1 -1
  161. package/dist/cdn/list/snice-list.min.js +1 -1
  162. package/dist/cdn/location/snice-location.js +1 -1
  163. package/dist/cdn/location/snice-location.min.js +1 -1
  164. package/dist/cdn/login/README.md +2 -2
  165. package/dist/cdn/login/snice-login.js +11 -10
  166. package/dist/cdn/login/snice-login.js.map +1 -1
  167. package/dist/cdn/login/snice-login.min.js +5 -5
  168. package/dist/cdn/login/snice-login.min.js.map +1 -1
  169. package/dist/cdn/map/snice-map.js +1 -1
  170. package/dist/cdn/map/snice-map.min.js +1 -1
  171. package/dist/cdn/markdown/snice-markdown.js +1 -1
  172. package/dist/cdn/markdown/snice-markdown.min.js +1 -1
  173. package/dist/cdn/masonry/snice-masonry.js +1 -1
  174. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  175. package/dist/cdn/menu/snice-menu.js +1 -1
  176. package/dist/cdn/menu/snice-menu.min.js +1 -1
  177. package/dist/cdn/message-strip/snice-message-strip.js +1 -1
  178. package/dist/cdn/message-strip/snice-message-strip.min.js +1 -1
  179. package/dist/cdn/metric-table/snice-metric-table.js +1 -1
  180. package/dist/cdn/metric-table/snice-metric-table.min.js +1 -1
  181. package/dist/cdn/modal/snice-modal.js +1 -1
  182. package/dist/cdn/modal/snice-modal.min.js +1 -1
  183. package/dist/cdn/music-player/snice-music-player.js +1 -1
  184. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  185. package/dist/cdn/nav/snice-nav.js +1 -1
  186. package/dist/cdn/nav/snice-nav.min.js +1 -1
  187. package/dist/cdn/network-graph/snice-network-graph.js +1 -1
  188. package/dist/cdn/network-graph/snice-network-graph.min.js +1 -1
  189. package/dist/cdn/notification-center/snice-notification-center.js +1 -1
  190. package/dist/cdn/notification-center/snice-notification-center.min.js +1 -1
  191. package/dist/cdn/order-tracker/snice-order-tracker.js +1 -1
  192. package/dist/cdn/order-tracker/snice-order-tracker.min.js +1 -1
  193. package/dist/cdn/org-chart/snice-org-chart.js +1 -1
  194. package/dist/cdn/org-chart/snice-org-chart.min.js +1 -1
  195. package/dist/cdn/pagination/snice-pagination.js +1 -1
  196. package/dist/cdn/pagination/snice-pagination.min.js +1 -1
  197. package/dist/cdn/paint/snice-paint.js +1 -1
  198. package/dist/cdn/paint/snice-paint.min.js +1 -1
  199. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js +1 -1
  200. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js +1 -1
  201. package/dist/cdn/permission-matrix/snice-permission-matrix.js +1 -1
  202. package/dist/cdn/permission-matrix/snice-permission-matrix.min.js +1 -1
  203. package/dist/cdn/podcast-player/snice-podcast-player.js +1 -1
  204. package/dist/cdn/podcast-player/snice-podcast-player.min.js +1 -1
  205. package/dist/cdn/pricing-table/snice-pricing-table.js +1 -1
  206. package/dist/cdn/pricing-table/snice-pricing-table.min.js +1 -1
  207. package/dist/cdn/product-card/snice-product-card.js +1 -1
  208. package/dist/cdn/product-card/snice-product-card.min.js +1 -1
  209. package/dist/cdn/progress/snice-progress.js +1 -1
  210. package/dist/cdn/progress/snice-progress.min.js +1 -1
  211. package/dist/cdn/progress-ring/snice-progress-ring.js +1 -1
  212. package/dist/cdn/progress-ring/snice-progress-ring.min.js +1 -1
  213. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  214. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  215. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  216. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  217. package/dist/cdn/radio/snice-radio.js +1 -1
  218. package/dist/cdn/radio/snice-radio.min.js +1 -1
  219. package/dist/cdn/range-slider/snice-range-slider.js +1 -1
  220. package/dist/cdn/range-slider/snice-range-slider.min.js +1 -1
  221. package/dist/cdn/rating/snice-rating.js +1 -1
  222. package/dist/cdn/rating/snice-rating.min.js +1 -1
  223. package/dist/cdn/receipt/snice-receipt.js +1 -1
  224. package/dist/cdn/receipt/snice-receipt.min.js +1 -1
  225. package/dist/cdn/recipe/snice-recipe.js +1 -1
  226. package/dist/cdn/recipe/snice-recipe.min.js +1 -1
  227. package/dist/cdn/runtime/README.md +2 -2
  228. package/dist/cdn/runtime/snice-runtime.esm.js +152 -62
  229. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  230. package/dist/cdn/runtime/snice-runtime.esm.min.js +8 -8
  231. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  232. package/dist/cdn/runtime/snice-runtime.js +152 -61
  233. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  234. package/dist/cdn/runtime/snice-runtime.min.js +8 -8
  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/README.md +1 -1
  269. package/dist/cdn/table/snice-table.js +11 -10
  270. package/dist/cdn/table/snice-table.js.map +1 -1
  271. package/dist/cdn/table/snice-table.min.js +73 -73
  272. package/dist/cdn/table/snice-table.min.js.map +1 -1
  273. package/dist/cdn/tabs/snice-tabs.js +1 -1
  274. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  275. package/dist/cdn/tag/snice-tag.js +1 -1
  276. package/dist/cdn/tag/snice-tag.min.js +1 -1
  277. package/dist/cdn/tag-input/snice-tag-input.js +1 -1
  278. package/dist/cdn/tag-input/snice-tag-input.min.js +1 -1
  279. package/dist/cdn/terminal/snice-terminal.js +1 -1
  280. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  281. package/dist/cdn/testimonial/snice-testimonial.js +1 -1
  282. package/dist/cdn/testimonial/snice-testimonial.min.js +1 -1
  283. package/dist/cdn/textarea/snice-textarea.js +1 -1
  284. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  285. package/dist/cdn/time-picker/snice-time-picker.js +1 -1
  286. package/dist/cdn/time-picker/snice-time-picker.min.js +1 -1
  287. package/dist/cdn/time-range-picker/snice-time-range-picker.js +1 -1
  288. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +1 -1
  289. package/dist/cdn/timeline/snice-timeline.js +1 -1
  290. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  291. package/dist/cdn/timer/snice-timer.js +1 -1
  292. package/dist/cdn/timer/snice-timer.min.js +1 -1
  293. package/dist/cdn/toast/snice-toast.js +1 -1
  294. package/dist/cdn/toast/snice-toast.min.js +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/action-bar/snice-action-bar.d.ts +22 -0
  314. package/dist/components/action-bar/snice-action-bar.js +182 -0
  315. package/dist/components/action-bar/snice-action-bar.js.map +1 -0
  316. package/dist/components/action-bar/snice-action-bar.types.d.ts +17 -0
  317. package/dist/components/badge/snice-badge.js +1 -1
  318. package/dist/components/badge/snice-badge.js.map +1 -1
  319. package/dist/components/binpack/snice-binpack.d.ts +82 -0
  320. package/dist/components/binpack/snice-binpack.js +970 -0
  321. package/dist/components/binpack/snice-binpack.js.map +1 -0
  322. package/dist/components/binpack/snice-binpack.types.d.ts +52 -0
  323. package/dist/components/button/snice-button.d.ts +2 -2
  324. package/dist/components/button/snice-button.js +11 -10
  325. package/dist/components/button/snice-button.js.map +1 -1
  326. package/dist/create-request-handler.d.ts +42 -0
  327. package/dist/index.cjs +149 -58
  328. package/dist/index.cjs.map +1 -1
  329. package/dist/index.d.ts +2 -0
  330. package/dist/index.esm.js +149 -59
  331. package/dist/index.esm.js.map +1 -1
  332. package/dist/index.iife.js +149 -58
  333. package/dist/index.iife.js.map +1 -1
  334. package/dist/parts.d.ts +9 -7
  335. package/dist/react/useRequestHandler.d.ts +56 -0
  336. package/dist/react/useRequestHandler.js +103 -0
  337. package/dist/react/useRequestHandler.js.map +1 -0
  338. package/dist/symbols.cjs +1 -1
  339. package/dist/symbols.esm.js +1 -1
  340. package/dist/transitions.cjs +1 -1
  341. package/dist/transitions.esm.js +1 -1
  342. package/docs/ai/DEVELOPMENT.md +1 -1
  343. package/docs/ai/components/accordion.md +46 -80
  344. package/docs/ai/components/action-bar.md +75 -0
  345. package/docs/ai/components/activity-feed.md +7 -7
  346. package/docs/ai/components/alert.md +26 -44
  347. package/docs/ai/components/app-tiles.md +34 -39
  348. package/docs/ai/components/approval-flow.md +1 -1
  349. package/docs/ai/components/audio-recorder.md +35 -67
  350. package/docs/ai/components/availability.md +13 -34
  351. package/docs/ai/components/avatar-group.md +26 -13
  352. package/docs/ai/components/avatar.md +52 -36
  353. package/docs/ai/components/badge.md +21 -32
  354. package/docs/ai/components/banner.md +21 -43
  355. package/docs/ai/components/binpack.md +89 -0
  356. package/docs/ai/components/book.md +25 -23
  357. package/docs/ai/components/booking.md +31 -36
  358. package/docs/ai/components/breadcrumbs.md +36 -11
  359. package/docs/ai/components/button.md +33 -44
  360. package/docs/ai/components/calendar.md +37 -70
  361. package/docs/ai/components/camera-annotate.md +31 -64
  362. package/docs/ai/components/camera.md +38 -120
  363. package/docs/ai/components/candlestick.md +32 -52
  364. package/docs/ai/components/card.md +20 -30
  365. package/docs/ai/components/carousel.md +32 -32
  366. package/docs/ai/components/cart.md +24 -29
  367. package/docs/ai/components/chart.md +29 -114
  368. package/docs/ai/components/chat.md +38 -75
  369. package/docs/ai/components/checkbox.md +22 -41
  370. package/docs/ai/components/chip.md +18 -54
  371. package/docs/ai/components/code-block.md +57 -178
  372. package/docs/ai/components/color-display.md +12 -32
  373. package/docs/ai/components/color-picker.md +17 -39
  374. package/docs/ai/components/command-palette.md +49 -71
  375. package/docs/ai/components/comments.md +55 -36
  376. package/docs/ai/components/countdown.md +28 -30
  377. package/docs/ai/components/cropper.md +33 -33
  378. package/docs/ai/components/data-card.md +20 -14
  379. package/docs/ai/components/date-picker.md +40 -47
  380. package/docs/ai/components/date-range-picker.md +31 -15
  381. package/docs/ai/components/date-time-picker.md +23 -46
  382. package/docs/ai/components/diff.md +30 -31
  383. package/docs/ai/components/divider.md +17 -47
  384. package/docs/ai/components/doc.md +43 -68
  385. package/docs/ai/components/draw.md +35 -87
  386. package/docs/ai/components/drawer.md +48 -77
  387. package/docs/ai/components/empty-state.md +10 -44
  388. package/docs/ai/components/estimate.md +33 -58
  389. package/docs/ai/components/file-gallery.md +48 -100
  390. package/docs/ai/components/file-upload.md +17 -53
  391. package/docs/ai/components/flip-card.md +31 -23
  392. package/docs/ai/components/flow.md +37 -65
  393. package/docs/ai/components/form-builder.md +35 -75
  394. package/docs/ai/components/form-layout.md +10 -20
  395. package/docs/ai/components/funnel.md +33 -48
  396. package/docs/ai/components/gantt.md +27 -23
  397. package/docs/ai/components/gauge.md +16 -17
  398. package/docs/ai/components/heatmap.md +21 -21
  399. package/docs/ai/components/image.md +7 -13
  400. package/docs/ai/components/input.md +38 -70
  401. package/docs/ai/components/invoice.md +35 -36
  402. package/docs/ai/components/kanban.md +32 -61
  403. package/docs/ai/components/key-value.md +32 -16
  404. package/docs/ai/components/kpi.md +38 -73
  405. package/docs/ai/components/layout.md +29 -23
  406. package/docs/ai/components/leaderboard.md +28 -37
  407. package/docs/ai/components/link-preview.md +12 -18
  408. package/docs/ai/components/link.md +10 -7
  409. package/docs/ai/components/list.md +21 -5
  410. package/docs/ai/components/location.md +21 -25
  411. package/docs/ai/components/login.md +14 -9
  412. package/docs/ai/components/map.md +27 -33
  413. package/docs/ai/components/markdown.md +20 -24
  414. package/docs/ai/components/masonry.md +10 -14
  415. package/docs/ai/components/mentions.md +26 -12
  416. package/docs/ai/components/menu.md +54 -52
  417. package/docs/ai/components/message-strip.md +20 -20
  418. package/docs/ai/components/metric-table.md +14 -21
  419. package/docs/ai/components/modal.md +27 -18
  420. package/docs/ai/components/music-player.md +49 -41
  421. package/docs/ai/components/nav.md +34 -31
  422. package/docs/ai/components/network-graph.md +27 -42
  423. package/docs/ai/components/notification-center.md +31 -33
  424. package/docs/ai/components/order-tracker.md +36 -27
  425. package/docs/ai/components/org-chart.md +36 -31
  426. package/docs/ai/components/pagination.md +34 -26
  427. package/docs/ai/components/paint.md +53 -91
  428. package/docs/ai/components/pdf-viewer.md +35 -36
  429. package/docs/ai/components/permission-matrix.md +26 -31
  430. package/docs/ai/components/podcast-player.md +64 -70
  431. package/docs/ai/components/pricing-table.md +37 -48
  432. package/docs/ai/components/product-card.md +58 -41
  433. package/docs/ai/components/progress-ring.md +20 -24
  434. package/docs/ai/components/progress.md +28 -45
  435. package/docs/ai/components/qr-code.md +25 -27
  436. package/docs/ai/components/qr-reader.md +20 -23
  437. package/docs/ai/components/radio.md +17 -15
  438. package/docs/ai/components/range-slider.md +22 -11
  439. package/docs/ai/components/rating.md +29 -33
  440. package/docs/ai/components/receipt.md +50 -127
  441. package/docs/ai/components/recipe.md +44 -42
  442. package/docs/ai/components/sankey.md +21 -30
  443. package/docs/ai/components/scheduler.md +29 -41
  444. package/docs/ai/components/segmented-control.md +11 -15
  445. package/docs/ai/components/select.md +58 -102
  446. package/docs/ai/components/skeleton.md +16 -30
  447. package/docs/ai/components/slider.md +26 -20
  448. package/docs/ai/components/sortable.md +25 -27
  449. package/docs/ai/components/sparkline.md +21 -17
  450. package/docs/ai/components/spinner.md +9 -5
  451. package/docs/ai/components/split-button.md +10 -13
  452. package/docs/ai/components/split-pane.md +19 -14
  453. package/docs/ai/components/spotlight.md +31 -26
  454. package/docs/ai/components/spreadsheet.md +51 -97
  455. package/docs/ai/components/stat-group.md +9 -19
  456. package/docs/ai/components/step-input.md +17 -15
  457. package/docs/ai/components/stepper.md +14 -15
  458. package/docs/ai/components/switch.md +15 -9
  459. package/docs/ai/components/table.md +24 -84
  460. package/docs/ai/components/tabs.md +18 -10
  461. package/docs/ai/components/tag-input.md +18 -29
  462. package/docs/ai/components/tag.md +10 -22
  463. package/docs/ai/components/terminal.md +9 -9
  464. package/docs/ai/components/testimonial.md +9 -19
  465. package/docs/ai/components/textarea.md +15 -16
  466. package/docs/ai/components/theme.md +3 -3
  467. package/docs/ai/components/time-picker.md +30 -49
  468. package/docs/ai/components/time-range-picker.md +16 -15
  469. package/docs/ai/components/timeline.md +5 -4
  470. package/docs/ai/components/timer.md +8 -8
  471. package/docs/ai/components/toast.md +24 -18
  472. package/docs/ai/components/tooltip.md +11 -22
  473. package/docs/ai/components/tree.md +9 -9
  474. package/docs/ai/components/treemap.md +14 -13
  475. package/docs/ai/components/user-card.md +21 -27
  476. package/docs/ai/components/video-player.md +35 -52
  477. package/docs/ai/components/virtual-scroller.md +1 -1
  478. package/docs/ai/components/waterfall.md +17 -16
  479. package/docs/ai/components/weather.md +19 -34
  480. package/docs/ai/components/work-order.md +58 -134
  481. package/docs/ai/patterns.md +63 -0
  482. package/docs/components/accordion.md +72 -151
  483. package/docs/components/action-bar.md +185 -0
  484. package/docs/components/activity-feed.md +9 -14
  485. package/docs/components/alert.md +17 -109
  486. package/docs/components/app-tiles.md +58 -43
  487. package/docs/components/approval-flow.md +8 -14
  488. package/docs/components/audio-recorder.md +45 -51
  489. package/docs/components/availability.md +30 -45
  490. package/docs/components/avatar-group.md +34 -14
  491. package/docs/components/avatar.md +20 -55
  492. package/docs/components/badge.md +53 -470
  493. package/docs/components/banner.md +44 -30
  494. package/docs/components/binpack.md +208 -0
  495. package/docs/components/book.md +78 -57
  496. package/docs/components/booking.md +35 -87
  497. package/docs/components/breadcrumbs.md +74 -448
  498. package/docs/components/button.md +72 -603
  499. package/docs/components/calendar.md +77 -261
  500. package/docs/components/camera-annotate.md +44 -96
  501. package/docs/components/camera.md +94 -333
  502. package/docs/components/candlestick.md +79 -116
  503. package/docs/components/card.md +51 -689
  504. package/docs/components/carousel.md +29 -76
  505. package/docs/components/cart.md +44 -136
  506. package/docs/components/chart.md +95 -438
  507. package/docs/components/chat.md +175 -439
  508. package/docs/components/checkbox.md +52 -609
  509. package/docs/components/chip.md +45 -574
  510. package/docs/components/code-block.md +157 -421
  511. package/docs/components/color-display.md +45 -54
  512. package/docs/components/color-picker.md +103 -36
  513. package/docs/components/command-palette.md +98 -92
  514. package/docs/components/comments.md +16 -10
  515. package/docs/components/countdown.md +15 -20
  516. package/docs/components/cropper.md +14 -16
  517. package/docs/components/data-card.md +16 -15
  518. package/docs/components/date-picker.md +45 -25
  519. package/docs/components/date-range-picker.md +140 -87
  520. package/docs/components/date-time-picker.md +25 -28
  521. package/docs/components/diff.md +22 -17
  522. package/docs/components/divider.md +18 -20
  523. package/docs/components/doc.md +105 -197
  524. package/docs/components/draw.md +117 -223
  525. package/docs/components/drawer.md +113 -478
  526. package/docs/components/empty-state.md +13 -29
  527. package/docs/components/estimate.md +58 -118
  528. package/docs/components/file-gallery.md +123 -495
  529. package/docs/components/file-upload.md +36 -123
  530. package/docs/components/flip-card.md +30 -34
  531. package/docs/components/flow.md +74 -89
  532. package/docs/components/form-builder.md +59 -86
  533. package/docs/components/form-layout.md +21 -31
  534. package/docs/components/funnel.md +21 -22
  535. package/docs/components/gantt.md +5 -5
  536. package/docs/components/gauge.md +5 -23
  537. package/docs/components/heatmap.md +13 -55
  538. package/docs/components/image.md +28 -32
  539. package/docs/components/input.md +25 -14
  540. package/docs/components/invoice.md +34 -33
  541. package/docs/components/kanban.md +99 -394
  542. package/docs/components/key-value.md +22 -12
  543. package/docs/components/kpi.md +41 -112
  544. package/docs/components/layout.md +7 -13
  545. package/docs/components/leaderboard.md +52 -76
  546. package/docs/components/link-preview.md +20 -16
  547. package/docs/components/link.md +22 -19
  548. package/docs/components/list.md +44 -26
  549. package/docs/components/location.md +9 -13
  550. package/docs/components/login.md +42 -36
  551. package/docs/components/map.md +24 -46
  552. package/docs/components/markdown.md +14 -25
  553. package/docs/components/masonry.md +15 -13
  554. package/docs/components/mentions.md +36 -25
  555. package/docs/components/menu.md +39 -46
  556. package/docs/components/message-strip.md +15 -51
  557. package/docs/components/metric-table.md +50 -72
  558. package/docs/components/modal.md +32 -43
  559. package/docs/components/music-player.md +41 -49
  560. package/docs/components/nav.md +23 -13
  561. package/docs/components/network-graph.md +14 -13
  562. package/docs/components/notification-center.md +68 -172
  563. package/docs/components/order-tracker.md +72 -117
  564. package/docs/components/org-chart.md +58 -207
  565. package/docs/components/pagination.md +67 -89
  566. package/docs/components/paint.md +86 -172
  567. package/docs/components/pdf-viewer.md +46 -151
  568. package/docs/components/permission-matrix.md +61 -112
  569. package/docs/components/podcast-player.md +41 -119
  570. package/docs/components/pricing-table.md +104 -147
  571. package/docs/components/product-card.md +94 -197
  572. package/docs/components/progress-ring.md +29 -32
  573. package/docs/components/progress.md +30 -61
  574. package/docs/components/qr-code.md +53 -61
  575. package/docs/components/qr-reader.md +53 -42
  576. package/docs/components/radio.md +42 -40
  577. package/docs/components/range-slider.md +41 -30
  578. package/docs/components/rating.md +50 -84
  579. package/docs/components/receipt.md +91 -129
  580. package/docs/components/recipe.md +107 -216
  581. package/docs/components/sankey.md +47 -83
  582. package/docs/components/scheduler.md +81 -184
  583. package/docs/components/segmented-control.md +48 -40
  584. package/docs/components/select.md +107 -129
  585. package/docs/components/skeleton.md +33 -47
  586. package/docs/components/slider.md +49 -53
  587. package/docs/components/sortable.md +43 -186
  588. package/docs/components/sparkline.md +26 -25
  589. package/docs/components/spinner.md +32 -37
  590. package/docs/components/split-button.md +43 -23
  591. package/docs/components/split-pane.md +41 -58
  592. package/docs/components/spotlight.md +53 -145
  593. package/docs/components/spreadsheet.md +84 -307
  594. package/docs/components/stat-group.md +27 -61
  595. package/docs/components/step-input.md +44 -41
  596. package/docs/components/stepper.md +55 -89
  597. package/docs/components/switch.md +39 -39
  598. package/docs/components/table.md +27 -32
  599. package/docs/components/tabs.md +36 -27
  600. package/docs/components/tag-input.md +50 -176
  601. package/docs/components/tag.md +12 -50
  602. package/docs/components/terminal.md +32 -37
  603. package/docs/components/testimonial.md +24 -81
  604. package/docs/components/textarea.md +9 -14
  605. package/docs/components/theme.md +10 -23
  606. package/docs/components/time-picker.md +48 -72
  607. package/docs/components/time-range-picker.md +22 -41
  608. package/docs/components/timeline.md +7 -14
  609. package/docs/components/timer.md +16 -32
  610. package/docs/components/toast.md +19 -45
  611. package/docs/components/tooltip.md +13 -115
  612. package/docs/components/tree.md +2 -19
  613. package/docs/components/treemap.md +19 -43
  614. package/docs/components/user-card.md +13 -22
  615. package/docs/components/video-player.md +53 -227
  616. package/docs/components/virtual-scroller.md +11 -44
  617. package/docs/components/waterfall.md +58 -137
  618. package/docs/components/weather.md +94 -153
  619. package/docs/components/work-order.md +56 -143
  620. package/docs/plans/2026-03-09-action-bar-design.md +104 -0
  621. package/docs/plans/2026-03-09-action-bar-plan.md +676 -0
  622. package/docs/plans/2026-03-10-react-integration-design.md +166 -0
  623. package/docs/request-response.md +77 -0
  624. package/package.json +20 -10
@@ -1,19 +1,18 @@
1
- <!-- AI: For a low-token version of this doc, use docs/ai/components/badge.md instead -->
1
+ <!-- AI: For the AI-optimized version of this doc, see docs/ai/components/badge.md -->
2
2
 
3
3
  # Badge Component
4
+ `<snice-badge>`
4
5
 
5
6
  The badge component displays notification indicators, status markers, and counts. It can be positioned on other elements or used inline, with support for custom colors, sizes, and animations.
6
7
 
7
8
  ## Table of Contents
8
9
  - [Properties](#properties)
9
10
  - [Methods](#methods)
11
+ - [Slots](#slots)
10
12
  - [CSS Parts](#css-parts)
11
13
  - [Basic Usage](#basic-usage)
12
14
  - [Examples](#examples)
13
15
  - [Accessibility](#accessibility)
14
- - [Browser Support](#browser-support)
15
- - [Common Patterns](#common-patterns)
16
- - [Variant Colors](#variant-colors)
17
16
 
18
17
  ## Properties
19
18
 
@@ -32,38 +31,21 @@ The badge component displays notification indicators, status markers, and counts
32
31
 
33
32
  ## Methods
34
33
 
35
- #### `setBadgeContent(content: string): void`
36
- Set the badge to display text content.
34
+ | Method | Arguments | Description |
35
+ |--------|-----------|-------------|
36
+ | `setBadgeContent()` | `content: string` | Set the badge to display text content |
37
+ | `setBadgeCount()` | `count: number` | Set the badge to display a numeric count |
38
+ | `showDot()` | -- | Change the badge to dot mode |
39
+ | `hide()` | -- | Hide the badge by clearing all content |
37
40
 
38
- ```typescript
39
- badge.setBadgeContent('New');
40
- ```
41
-
42
- #### `setBadgeCount(count: number): void`
43
- Set the badge to display a numeric count.
44
-
45
- ```typescript
46
- badge.setBadgeCount(5);
47
- ```
41
+ ## Slots
48
42
 
49
- #### `showDot(): void`
50
- Change the badge to dot mode.
51
-
52
- ```typescript
53
- badge.showDot();
54
- ```
55
-
56
- #### `hide(): void`
57
- Hide the badge by clearing all content.
58
-
59
- ```typescript
60
- badge.hide();
61
- ```
43
+ | Name | Description |
44
+ |------|-------------|
45
+ | (default) | Content the badge overlays |
62
46
 
63
47
  ## CSS Parts
64
48
 
65
- Style internal elements from outside the shadow DOM using `::part()`.
66
-
67
49
  | Part | Element | Description |
68
50
  |------|---------|-------------|
69
51
  | `base` | `<div>` | Outer wrapper element |
@@ -82,42 +64,27 @@ snice-badge::part(base) {
82
64
 
83
65
  ## Basic Usage
84
66
 
85
- ```html
86
- <!-- Simple text badge -->
87
- <snice-badge content="New"></snice-badge>
88
-
89
- <!-- Count badge -->
90
- <snice-badge count="5"></snice-badge>
91
-
92
- <!-- Dot indicator -->
93
- <snice-badge dot></snice-badge>
94
- ```
95
-
96
67
  ```typescript
97
68
  import 'snice/components/badge/snice-badge';
98
69
  ```
99
70
 
100
- ## Examples
101
-
102
- ### Basic Badges
103
-
104
71
  ```html
105
- <!-- Text content -->
72
+ <!-- Simple text badge -->
106
73
  <snice-badge content="New"></snice-badge>
107
- <snice-badge content="Pro"></snice-badge>
108
- <snice-badge content="Beta"></snice-badge>
109
74
 
110
- <!-- Numeric count -->
75
+ <!-- Count badge -->
111
76
  <snice-badge count="5"></snice-badge>
112
- <snice-badge count="23"></snice-badge>
113
- <snice-badge count="150" max="99"></snice-badge>
114
77
 
115
78
  <!-- Dot indicator -->
116
79
  <snice-badge dot></snice-badge>
117
80
  ```
118
81
 
82
+ ## Examples
83
+
119
84
  ### Color Variants
120
85
 
86
+ Use the `variant` attribute to set the badge color.
87
+
121
88
  ```html
122
89
  <snice-badge content="Default" variant="default"></snice-badge>
123
90
  <snice-badge content="Primary" variant="primary"></snice-badge>
@@ -129,420 +96,84 @@ import 'snice/components/badge/snice-badge';
129
96
 
130
97
  ### Badge on Elements
131
98
 
99
+ Wrap an element with the badge to overlay it.
100
+
132
101
  ```html
133
- <style>
134
- .badge-container {
135
- position: relative;
136
- display: inline-block;
137
- }
138
- </style>
139
-
140
- <!-- On button -->
141
- <div class="badge-container">
102
+ <snice-badge count="3" variant="error">
142
103
  <button>Messages</button>
143
- <snice-badge count="3" variant="error"></snice-badge>
144
- </div>
145
-
146
- <!-- On icon -->
147
- <div class="badge-container">
148
- <svg width="24" height="24" viewBox="0 0 24 24">
149
- <path d="M12 22c1.1 0 2-.9 2-2h-4c0 1.1.9 2 2 2zm6-6v-5c0-3.07-1.63-5.64-4.5-6.32V4c0-.83-.67-1.5-1.5-1.5s-1.5.67-1.5 1.5v.68C7.64 5.36 6 7.92 6 11v5l-2 2v1h16v-1l-2-2zm-2 1H8v-6c0-2.48 1.51-4.5 4-4.5s4 2.02 4 4.5v6z"/>
150
- </svg>
151
- <snice-badge count="12" variant="primary"></snice-badge>
152
- </div>
153
-
154
- <!-- On avatar -->
155
- <div class="badge-container">
104
+ </snice-badge>
105
+
106
+ <snice-badge dot pulse variant="success">
156
107
  <img src="avatar.jpg" alt="User" style="width: 48px; height: 48px; border-radius: 50%;">
157
- <snice-badge dot pulse variant="success"></snice-badge>
158
- </div>
108
+ </snice-badge>
159
109
  ```
160
110
 
161
111
  ### Different Positions
162
112
 
113
+ Use the `position` attribute to place the badge at different corners.
114
+
163
115
  ```html
164
- <style>
165
- .position-demo {
166
- position: relative;
167
- display: inline-block;
168
- margin: 2rem;
169
- }
170
-
171
- .demo-box {
172
- width: 60px;
173
- height: 60px;
174
- background: #e5e7eb;
175
- border-radius: 8px;
176
- }
177
- </style>
178
-
179
- <!-- Top right (default) -->
180
- <div class="position-demo">
181
- <div class="demo-box"></div>
182
- <snice-badge count="5" position="top-right"></snice-badge>
183
- </div>
184
-
185
- <!-- Top left -->
186
- <div class="position-demo">
187
- <div class="demo-box"></div>
188
- <snice-badge count="5" position="top-left"></snice-badge>
189
- </div>
190
-
191
- <!-- Bottom right -->
192
- <div class="position-demo">
193
- <div class="demo-box"></div>
194
- <snice-badge count="5" position="bottom-right"></snice-badge>
195
- </div>
196
-
197
- <!-- Bottom left -->
198
- <div class="position-demo">
199
- <div class="demo-box"></div>
200
- <snice-badge count="5" position="bottom-left"></snice-badge>
201
- </div>
116
+ <snice-badge count="5" position="top-right">...</snice-badge>
117
+ <snice-badge count="5" position="top-left">...</snice-badge>
118
+ <snice-badge count="5" position="bottom-right">...</snice-badge>
119
+ <snice-badge count="5" position="bottom-left">...</snice-badge>
202
120
  ```
203
121
 
204
122
  ### Inline Badges
205
123
 
124
+ Use the `inline` attribute to display badges inline with text.
125
+
206
126
  ```html
207
- <p>
208
- Status: <snice-badge inline content="Active" variant="success"></snice-badge>
209
- </p>
210
-
211
- <p>
212
- Plan: <snice-badge inline content="Pro" variant="primary"></snice-badge>
213
- </p>
214
-
215
- <h3>
216
- Documentation
217
- <snice-badge inline content="Beta" variant="warning" size="small"></snice-badge>
218
- </h3>
127
+ <p>Status: <snice-badge inline content="Active" variant="success"></snice-badge></p>
128
+ <h3>Documentation <snice-badge inline content="Beta" variant="warning" size="small"></snice-badge></h3>
219
129
  ```
220
130
 
221
131
  ### Different Sizes
222
132
 
223
133
  ```html
224
- <!-- Small -->
225
134
  <snice-badge content="Small" size="small"></snice-badge>
226
- <snice-badge count="5" size="small" variant="error"></snice-badge>
227
- <snice-badge dot size="small" variant="primary"></snice-badge>
228
-
229
- <!-- Medium (default) -->
230
135
  <snice-badge content="Medium" size="medium"></snice-badge>
231
- <snice-badge count="15" size="medium" variant="warning"></snice-badge>
232
- <snice-badge dot size="medium" variant="success"></snice-badge>
233
-
234
- <!-- Large -->
235
136
  <snice-badge content="Large" size="large"></snice-badge>
236
- <snice-badge count="99+" size="large" variant="info"></snice-badge>
237
- <snice-badge dot size="large" variant="error" pulse></snice-badge>
238
137
  ```
239
138
 
240
139
  ### Pulse Animation
241
140
 
141
+ Use the `pulse` attribute for attention-drawing animation.
142
+
242
143
  ```html
243
- <!-- Pulse with dot -->
244
144
  <snice-badge dot pulse variant="success"></snice-badge>
245
145
  <snice-badge dot pulse variant="error"></snice-badge>
246
- <snice-badge dot pulse variant="warning"></snice-badge>
247
-
248
- <!-- Pulse with count -->
249
- <snice-badge count="3" pulse variant="primary"></snice-badge>
250
-
251
- <!-- Pulse with content -->
252
146
  <snice-badge content="Live" pulse variant="error"></snice-badge>
253
147
  ```
254
148
 
255
- ### Notification Counter
256
-
257
- ```html
258
- <style>
259
- .nav-item {
260
- position: relative;
261
- display: inline-block;
262
- margin: 0 1rem;
263
- padding: 0.5rem 1rem;
264
- background: #f3f4f6;
265
- border-radius: 0.375rem;
266
- cursor: pointer;
267
- }
268
- </style>
269
-
270
- <nav>
271
- <div class="nav-item">
272
- Home
273
- </div>
274
-
275
- <div class="nav-item">
276
- Messages
277
- <snice-badge count="5" variant="primary"></snice-badge>
278
- </div>
279
-
280
- <div class="nav-item">
281
- Notifications
282
- <snice-badge count="12" variant="error"></snice-badge>
283
- </div>
284
-
285
- <div class="nav-item">
286
- Updates
287
- <snice-badge dot pulse variant="info"></snice-badge>
288
- </div>
289
- </nav>
290
- ```
149
+ ### Max Count Handling
291
150
 
292
- ### Dynamic Badge Updates
151
+ When `count` exceeds `max`, the badge displays "99+" (or whatever `max` is set to).
293
152
 
294
153
  ```html
295
- <div class="badge-container">
296
- <button id="cart-button">
297
- <svg width="24" height="24" viewBox="0 0 24 24" fill="currentColor">
298
- <path d="M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2H1zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2z"/>
299
- </svg>
300
- Cart
301
- </button>
302
- <snice-badge id="cart-badge" count="0"></snice-badge>
303
- </div>
304
-
305
- <button onclick="addToCart()">Add Item</button>
306
- <button onclick="clearCart()">Clear Cart</button>
154
+ <snice-badge count="150" max="99"></snice-badge>
155
+ <!-- Displays as "99+" -->
307
156
  ```
308
157
 
309
- ```typescript
310
- let cartCount = 0;
311
-
312
- window.addToCart = () => {
313
- cartCount++;
314
- badge.setBadgeCount(cartCount);
315
- };
158
+ ### Custom Offset
316
159
 
317
- window.clearCart = () => {
318
- cartCount = 0;
319
- badge.hide();
320
- };
321
- ```
322
-
323
- ### Status Indicators
160
+ Use the `offset` attribute to adjust the badge position.
324
161
 
325
162
  ```html
326
- <style>
327
- .user-list {
328
- display: flex;
329
- flex-direction: column;
330
- gap: 1rem;
331
- }
332
-
333
- .user-item {
334
- position: relative;
335
- display: inline-flex;
336
- align-items: center;
337
- gap: 1rem;
338
- }
339
-
340
- .user-avatar {
341
- position: relative;
342
- width: 48px;
343
- height: 48px;
344
- border-radius: 50%;
345
- background: #e5e7eb;
346
- display: flex;
347
- align-items: center;
348
- justify-content: center;
349
- font-weight: 600;
350
- }
351
- </style>
352
-
353
- <div class="user-list">
354
- <div class="user-item">
355
- <div class="user-avatar">
356
- JD
357
- <snice-badge dot variant="success" position="bottom-right"></snice-badge>
358
- </div>
359
- <span>John Doe (Online)</span>
360
- </div>
361
-
362
- <div class="user-item">
363
- <div class="user-avatar">
364
- JS
365
- <snice-badge dot variant="warning" position="bottom-right"></snice-badge>
366
- </div>
367
- <span>Jane Smith (Away)</span>
368
- </div>
369
-
370
- <div class="user-item">
371
- <div class="user-avatar">
372
- AB
373
- <snice-badge dot variant="error" position="bottom-right"></snice-badge>
374
- </div>
375
- <span>Alice Brown (Busy)</span>
376
- </div>
377
-
378
- <div class="user-item">
379
- <div class="user-avatar">
380
- CD
381
- </div>
382
- <span>Charlie Davis (Offline)</span>
383
- </div>
384
- </div>
163
+ <snice-badge count="5" variant="error" offset="5">
164
+ <div style="width: 32px; height: 32px; background: #e5e7eb; border-radius: 50%;"></div>
165
+ </snice-badge>
385
166
  ```
386
167
 
387
- ### Max Count Handling
388
-
389
- ```html
390
- <div class="badge-container">
391
- <button>Messages</button>
392
- <snice-badge id="msg-badge" count="0" max="99" variant="error"></snice-badge>
393
- </div>
394
-
395
- <div style="margin-top: 1rem;">
396
- <button onclick="setCount(5)">5 messages</button>
397
- <button onclick="setCount(50)">50 messages</button>
398
- <button onclick="setCount(100)">100 messages</button>
399
- <button onclick="setCount(500)">500 messages</button>
400
- </div>
401
-
402
- ```
168
+ ### Dynamic Badge Updates
403
169
 
404
170
  ```typescript
405
- window.setCount = (count) => {
406
- badge.setBadgeCount(count);
407
- };
408
- ```
409
-
410
- ### Badge with Custom Offset
411
-
412
- ```html
413
- <style>
414
- .icon-container {
415
- position: relative;
416
- display: inline-block;
417
- margin: 2rem;
418
- }
419
- </style>
420
-
421
- <!-- Default offset -->
422
- <div class="icon-container">
423
- <svg width="32" height="32" viewBox="0 0 24 24" fill="currentColor">
424
- <path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z"/>
425
- </svg>
426
- <snice-badge count="5" variant="error"></snice-badge>
427
- </div>
428
-
429
- <!-- With offset -->
430
- <div class="icon-container">
431
- <svg width="32" height="32" viewBox="0 0 24 24" fill="currentColor">
432
- <path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z"/>
433
- </svg>
434
- <snice-badge count="5" variant="error" offset="5"></snice-badge>
435
- </div>
436
- ```
437
-
438
- ### Feature Badges
439
-
440
- ```html
441
- <style>
442
- .feature-card {
443
- padding: 1.5rem;
444
- border: 1px solid #e5e7eb;
445
- border-radius: 0.5rem;
446
- max-width: 20rem;
447
- }
448
-
449
- .feature-title {
450
- display: flex;
451
- align-items: center;
452
- gap: 0.5rem;
453
- margin-bottom: 0.5rem;
454
- }
455
- </style>
456
-
457
- <div class="feature-card">
458
- <h3 class="feature-title">
459
- Advanced Analytics
460
- <snice-badge inline content="New" variant="primary" size="small"></snice-badge>
461
- </h3>
462
- <p>Get detailed insights into your data with our new analytics dashboard.</p>
463
- </div>
464
-
465
- <div class="feature-card">
466
- <h3 class="feature-title">
467
- API Access
468
- <snice-badge inline content="Pro" variant="warning" size="small"></snice-badge>
469
- </h3>
470
- <p>Integrate with your applications using our REST API.</p>
471
- </div>
472
-
473
- <div class="feature-card">
474
- <h3 class="feature-title">
475
- Custom Domains
476
- <snice-badge inline content="Beta" variant="info" size="small"></snice-badge>
477
- </h3>
478
- <p>Use your own domain name for your hosted content.</p>
479
- </div>
480
- ```
481
-
482
- ### Unread Messages Indicator
171
+ const badge = document.querySelector('snice-badge');
483
172
 
484
- ```html
485
- <style>
486
- .message-thread {
487
- display: flex;
488
- align-items: center;
489
- gap: 1rem;
490
- padding: 1rem;
491
- border-bottom: 1px solid #e5e7eb;
492
- cursor: pointer;
493
- }
494
-
495
- .message-thread:hover {
496
- background: #f9fafb;
497
- }
498
-
499
- .thread-avatar {
500
- position: relative;
501
- width: 40px;
502
- height: 40px;
503
- border-radius: 50%;
504
- background: #3b82f6;
505
- color: white;
506
- display: flex;
507
- align-items: center;
508
- justify-content: center;
509
- font-weight: 600;
510
- }
511
-
512
- .thread-content {
513
- flex: 1;
514
- }
515
- </style>
516
-
517
- <div class="message-thread">
518
- <div class="thread-avatar">
519
- A
520
- <snice-badge count="3" variant="error" size="small"></snice-badge>
521
- </div>
522
- <div class="thread-content">
523
- <strong>Alice</strong>
524
- <p style="margin: 0; color: #6b7280;">Hey, are you available for a call?</p>
525
- </div>
526
- </div>
527
-
528
- <div class="message-thread">
529
- <div class="thread-avatar">
530
- B
531
- <snice-badge count="1" variant="error" size="small"></snice-badge>
532
- </div>
533
- <div class="thread-content">
534
- <strong>Bob</strong>
535
- <p style="margin: 0; color: #6b7280;">I've sent you the files.</p>
536
- </div>
537
- </div>
538
-
539
- <div class="message-thread">
540
- <div class="thread-avatar">C</div>
541
- <div class="thread-content">
542
- <strong>Charlie</strong>
543
- <p style="margin: 0; color: #9ca3af;">Thanks for your help!</p>
544
- </div>
545
- </div>
173
+ badge.setBadgeCount(5); // Show count
174
+ badge.setBadgeContent('New'); // Show text
175
+ badge.showDot(); // Show dot
176
+ badge.hide(); // Hide badge
546
177
  ```
547
178
 
548
179
  ## Accessibility
@@ -551,51 +182,3 @@ window.setCount = (count) => {
551
182
  - **ARIA label**: Descriptive labels for badge content
552
183
  - **Color contrast**: All variants meet WCAG AA standards
553
184
  - **Screen reader friendly**: Content is properly announced
554
-
555
- ## Browser Support
556
-
557
- - Modern browsers (Chrome, Firefox, Safari, Edge)
558
- - Requires Custom Elements v1 and Shadow DOM support
559
-
560
- ## Common Patterns
561
-
562
- ### Notification Badge
563
- ```html
564
- <div class="badge-container">
565
- <button>Notifications</button>
566
- <snice-badge count="5" variant="error"></snice-badge>
567
- </div>
568
- ```
569
-
570
- ### Status Indicator
571
- ```html
572
- <div class="badge-container">
573
- <img src="avatar.jpg" alt="User">
574
- <snice-badge dot variant="success"></snice-badge>
575
- </div>
576
- ```
577
-
578
- ### Feature Label
579
- ```html
580
- <h3>
581
- Premium Feature
582
- <snice-badge inline content="Pro" variant="warning" size="small"></snice-badge>
583
- </h3>
584
- ```
585
-
586
- ### Count with Max
587
- ```html
588
- <snice-badge count="150" max="99"></snice-badge>
589
- <!-- Displays as "99+" -->
590
- ```
591
-
592
- ## Variant Colors
593
-
594
- | Variant | Color Scheme | Use Case |
595
- |---------|-------------|----------|
596
- | `default` | Gray | Neutral information |
597
- | `primary` | Blue | Primary actions, branding |
598
- | `success` | Green | Positive status, confirmations |
599
- | `warning` | Orange | Warnings, important notices |
600
- | `error` | Red | Errors, urgent notifications |
601
- | `info` | Light blue | Informational content |