snice 4.28.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 (618) 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 +1 -1
  43. package/dist/cdn/badge/snice-badge.min.js +1 -1
  44. package/dist/cdn/banner/snice-banner.js +1 -1
  45. package/dist/cdn/banner/snice-banner.min.js +1 -1
  46. package/dist/cdn/binpack/README.md +27 -0
  47. package/dist/cdn/binpack/snice-binpack.js +1037 -0
  48. package/dist/cdn/binpack/snice-binpack.js.map +1 -0
  49. package/dist/cdn/binpack/snice-binpack.min.js +13 -0
  50. package/dist/cdn/binpack/snice-binpack.min.js.map +1 -0
  51. package/dist/cdn/book/snice-book.js +1 -1
  52. package/dist/cdn/book/snice-book.min.js +1 -1
  53. package/dist/cdn/booking/snice-booking.js +1 -1
  54. package/dist/cdn/booking/snice-booking.min.js +1 -1
  55. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +1 -1
  56. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +1 -1
  57. package/dist/cdn/button/README.md +1 -1
  58. package/dist/cdn/button/snice-button.js +2 -2
  59. package/dist/cdn/button/snice-button.js.map +1 -1
  60. package/dist/cdn/button/snice-button.min.js +2 -2
  61. package/dist/cdn/button/snice-button.min.js.map +1 -1
  62. package/dist/cdn/calendar/snice-calendar.js +1 -1
  63. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  64. package/dist/cdn/camera/snice-camera.js +1 -1
  65. package/dist/cdn/camera/snice-camera.min.js +1 -1
  66. package/dist/cdn/camera-annotate/snice-camera-annotate.js +1 -1
  67. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +1 -1
  68. package/dist/cdn/candlestick/snice-candlestick.js +1 -1
  69. package/dist/cdn/candlestick/snice-candlestick.min.js +1 -1
  70. package/dist/cdn/card/snice-card.js +1 -1
  71. package/dist/cdn/card/snice-card.min.js +1 -1
  72. package/dist/cdn/carousel/snice-carousel.js +1 -1
  73. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  74. package/dist/cdn/cart/snice-cart.js +1 -1
  75. package/dist/cdn/cart/snice-cart.min.js +1 -1
  76. package/dist/cdn/chart/snice-chart.js +1 -1
  77. package/dist/cdn/chart/snice-chart.min.js +1 -1
  78. package/dist/cdn/chat/snice-chat.js +1 -1
  79. package/dist/cdn/chat/snice-chat.min.js +1 -1
  80. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  81. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  82. package/dist/cdn/chip/snice-chip.js +1 -1
  83. package/dist/cdn/chip/snice-chip.min.js +1 -1
  84. package/dist/cdn/code-block/snice-code-block.js +1 -1
  85. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  86. package/dist/cdn/color-display/snice-color-display.js +1 -1
  87. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  88. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  89. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  90. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  91. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  92. package/dist/cdn/comments/snice-comments.js +1 -1
  93. package/dist/cdn/comments/snice-comments.min.js +1 -1
  94. package/dist/cdn/countdown/snice-countdown.js +1 -1
  95. package/dist/cdn/countdown/snice-countdown.min.js +1 -1
  96. package/dist/cdn/cropper/snice-cropper.js +1 -1
  97. package/dist/cdn/cropper/snice-cropper.min.js +1 -1
  98. package/dist/cdn/data-card/snice-data-card.js +1 -1
  99. package/dist/cdn/data-card/snice-data-card.min.js +1 -1
  100. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  101. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  102. package/dist/cdn/date-range-picker/snice-date-range-picker.js +1 -1
  103. package/dist/cdn/date-range-picker/snice-date-range-picker.min.js +1 -1
  104. package/dist/cdn/date-time-picker/snice-date-time-picker.js +1 -1
  105. package/dist/cdn/date-time-picker/snice-date-time-picker.min.js +1 -1
  106. package/dist/cdn/diff/snice-diff.js +1 -1
  107. package/dist/cdn/diff/snice-diff.min.js +1 -1
  108. package/dist/cdn/divider/snice-divider.js +1 -1
  109. package/dist/cdn/divider/snice-divider.min.js +1 -1
  110. package/dist/cdn/doc/snice-doc.js +1 -1
  111. package/dist/cdn/doc/snice-doc.min.js +1 -1
  112. package/dist/cdn/draw/snice-draw.js +1 -1
  113. package/dist/cdn/draw/snice-draw.min.js +1 -1
  114. package/dist/cdn/drawer/snice-drawer.js +1 -1
  115. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  116. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  117. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  118. package/dist/cdn/estimate/snice-estimate.js +1 -1
  119. package/dist/cdn/estimate/snice-estimate.min.js +1 -1
  120. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  121. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  122. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  123. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  124. package/dist/cdn/flip-card/snice-flip-card.js +1 -1
  125. package/dist/cdn/flip-card/snice-flip-card.min.js +1 -1
  126. package/dist/cdn/flow/snice-flow.js +1 -1
  127. package/dist/cdn/flow/snice-flow.min.js +1 -1
  128. package/dist/cdn/form-layout/snice-form-layout.js +1 -1
  129. package/dist/cdn/form-layout/snice-form-layout.min.js +1 -1
  130. package/dist/cdn/funnel/snice-funnel.js +1 -1
  131. package/dist/cdn/funnel/snice-funnel.min.js +1 -1
  132. package/dist/cdn/gantt/snice-gantt.js +1 -1
  133. package/dist/cdn/gantt/snice-gantt.min.js +1 -1
  134. package/dist/cdn/gauge/snice-gauge.js +1 -1
  135. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  136. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  137. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  138. package/dist/cdn/image/snice-image.js +1 -1
  139. package/dist/cdn/image/snice-image.min.js +1 -1
  140. package/dist/cdn/input/snice-input.js +1 -1
  141. package/dist/cdn/input/snice-input.min.js +1 -1
  142. package/dist/cdn/invoice/snice-invoice.js +1 -1
  143. package/dist/cdn/invoice/snice-invoice.min.js +1 -1
  144. package/dist/cdn/kanban/snice-kanban.js +1 -1
  145. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  146. package/dist/cdn/key-value/snice-key-value.js +1 -1
  147. package/dist/cdn/key-value/snice-key-value.min.js +1 -1
  148. package/dist/cdn/kpi/snice-kpi.js +1 -1
  149. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  150. package/dist/cdn/layout/snice-layout.js +1 -1
  151. package/dist/cdn/layout/snice-layout.min.js +1 -1
  152. package/dist/cdn/leaderboard/snice-leaderboard.js +1 -1
  153. package/dist/cdn/leaderboard/snice-leaderboard.min.js +1 -1
  154. package/dist/cdn/link/snice-link.js +1 -1
  155. package/dist/cdn/link/snice-link.min.js +1 -1
  156. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  157. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  158. package/dist/cdn/list/snice-list.js +1 -1
  159. package/dist/cdn/list/snice-list.min.js +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/README.md +2 -2
  163. package/dist/cdn/login/snice-login.js +2 -2
  164. package/dist/cdn/login/snice-login.js.map +1 -1
  165. package/dist/cdn/login/snice-login.min.js +2 -2
  166. package/dist/cdn/login/snice-login.min.js.map +1 -1
  167. package/dist/cdn/map/snice-map.js +1 -1
  168. package/dist/cdn/map/snice-map.min.js +1 -1
  169. package/dist/cdn/markdown/snice-markdown.js +1 -1
  170. package/dist/cdn/markdown/snice-markdown.min.js +1 -1
  171. package/dist/cdn/masonry/snice-masonry.js +1 -1
  172. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  173. package/dist/cdn/menu/snice-menu.js +1 -1
  174. package/dist/cdn/menu/snice-menu.min.js +1 -1
  175. package/dist/cdn/message-strip/snice-message-strip.js +1 -1
  176. package/dist/cdn/message-strip/snice-message-strip.min.js +1 -1
  177. package/dist/cdn/metric-table/snice-metric-table.js +1 -1
  178. package/dist/cdn/metric-table/snice-metric-table.min.js +1 -1
  179. package/dist/cdn/modal/snice-modal.js +1 -1
  180. package/dist/cdn/modal/snice-modal.min.js +1 -1
  181. package/dist/cdn/music-player/snice-music-player.js +1 -1
  182. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  183. package/dist/cdn/nav/snice-nav.js +1 -1
  184. package/dist/cdn/nav/snice-nav.min.js +1 -1
  185. package/dist/cdn/network-graph/snice-network-graph.js +1 -1
  186. package/dist/cdn/network-graph/snice-network-graph.min.js +1 -1
  187. package/dist/cdn/notification-center/snice-notification-center.js +1 -1
  188. package/dist/cdn/notification-center/snice-notification-center.min.js +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/snice-product-card.js +1 -1
  206. package/dist/cdn/product-card/snice-product-card.min.js +1 -1
  207. package/dist/cdn/progress/snice-progress.js +1 -1
  208. package/dist/cdn/progress/snice-progress.min.js +1 -1
  209. package/dist/cdn/progress-ring/snice-progress-ring.js +1 -1
  210. package/dist/cdn/progress-ring/snice-progress-ring.min.js +1 -1
  211. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  212. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  213. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  214. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  215. package/dist/cdn/radio/snice-radio.js +1 -1
  216. package/dist/cdn/radio/snice-radio.min.js +1 -1
  217. package/dist/cdn/range-slider/snice-range-slider.js +1 -1
  218. package/dist/cdn/range-slider/snice-range-slider.min.js +1 -1
  219. package/dist/cdn/rating/snice-rating.js +1 -1
  220. package/dist/cdn/rating/snice-rating.min.js +1 -1
  221. package/dist/cdn/receipt/snice-receipt.js +1 -1
  222. package/dist/cdn/receipt/snice-receipt.min.js +1 -1
  223. package/dist/cdn/recipe/snice-recipe.js +1 -1
  224. package/dist/cdn/recipe/snice-recipe.min.js +1 -1
  225. package/dist/cdn/runtime/README.md +2 -2
  226. package/dist/cdn/runtime/snice-runtime.esm.js +73 -5
  227. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  228. package/dist/cdn/runtime/snice-runtime.esm.min.js +8 -8
  229. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  230. package/dist/cdn/runtime/snice-runtime.js +73 -4
  231. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  232. package/dist/cdn/runtime/snice-runtime.min.js +7 -7
  233. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  234. package/dist/cdn/sankey/snice-sankey.js +1 -1
  235. package/dist/cdn/sankey/snice-sankey.min.js +1 -1
  236. package/dist/cdn/segmented-control/snice-segmented-control.js +1 -1
  237. package/dist/cdn/segmented-control/snice-segmented-control.min.js +1 -1
  238. package/dist/cdn/select/snice-select.js +1 -1
  239. package/dist/cdn/select/snice-select.min.js +1 -1
  240. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  241. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  242. package/dist/cdn/slider/snice-slider.js +1 -1
  243. package/dist/cdn/slider/snice-slider.min.js +1 -1
  244. package/dist/cdn/sortable/snice-sortable.js +1 -1
  245. package/dist/cdn/sortable/snice-sortable.min.js +1 -1
  246. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  247. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  248. package/dist/cdn/spinner/snice-spinner.js +1 -1
  249. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  250. package/dist/cdn/split-button/snice-split-button.js +1 -1
  251. package/dist/cdn/split-button/snice-split-button.min.js +1 -1
  252. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  253. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  254. package/dist/cdn/spotlight/snice-spotlight.js +1 -1
  255. package/dist/cdn/spotlight/snice-spotlight.min.js +1 -1
  256. package/dist/cdn/spreadsheet/snice-spreadsheet.js +1 -1
  257. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js +1 -1
  258. package/dist/cdn/stat-group/snice-stat-group.js +1 -1
  259. package/dist/cdn/stat-group/snice-stat-group.min.js +1 -1
  260. package/dist/cdn/step-input/snice-step-input.js +1 -1
  261. package/dist/cdn/step-input/snice-step-input.min.js +1 -1
  262. package/dist/cdn/stepper/snice-stepper.js +1 -1
  263. package/dist/cdn/stepper/snice-stepper.min.js +1 -1
  264. package/dist/cdn/switch/snice-switch.js +1 -1
  265. package/dist/cdn/switch/snice-switch.min.js +1 -1
  266. package/dist/cdn/table/README.md +1 -1
  267. package/dist/cdn/table/snice-table.js +2 -2
  268. package/dist/cdn/table/snice-table.js.map +1 -1
  269. package/dist/cdn/table/snice-table.min.js +2 -2
  270. package/dist/cdn/table/snice-table.min.js.map +1 -1
  271. package/dist/cdn/tabs/snice-tabs.js +1 -1
  272. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  273. package/dist/cdn/tag/snice-tag.js +1 -1
  274. package/dist/cdn/tag/snice-tag.min.js +1 -1
  275. package/dist/cdn/tag-input/snice-tag-input.js +1 -1
  276. package/dist/cdn/tag-input/snice-tag-input.min.js +1 -1
  277. package/dist/cdn/terminal/snice-terminal.js +1 -1
  278. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  279. package/dist/cdn/testimonial/snice-testimonial.js +1 -1
  280. package/dist/cdn/testimonial/snice-testimonial.min.js +1 -1
  281. package/dist/cdn/textarea/snice-textarea.js +1 -1
  282. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  283. package/dist/cdn/time-picker/snice-time-picker.js +1 -1
  284. package/dist/cdn/time-picker/snice-time-picker.min.js +1 -1
  285. package/dist/cdn/time-range-picker/snice-time-range-picker.js +1 -1
  286. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +1 -1
  287. package/dist/cdn/timeline/snice-timeline.js +1 -1
  288. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  289. package/dist/cdn/timer/snice-timer.js +1 -1
  290. package/dist/cdn/timer/snice-timer.min.js +1 -1
  291. package/dist/cdn/toast/snice-toast.js +1 -1
  292. package/dist/cdn/toast/snice-toast.min.js +1 -1
  293. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  294. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  295. package/dist/cdn/tree/snice-tree.js +1 -1
  296. package/dist/cdn/tree/snice-tree.min.js +1 -1
  297. package/dist/cdn/treemap/snice-treemap.js +1 -1
  298. package/dist/cdn/treemap/snice-treemap.min.js +1 -1
  299. package/dist/cdn/user-card/snice-user-card.js +1 -1
  300. package/dist/cdn/user-card/snice-user-card.min.js +1 -1
  301. package/dist/cdn/video-player/snice-video-player.js +1 -1
  302. package/dist/cdn/video-player/snice-video-player.min.js +1 -1
  303. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +1 -1
  304. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +1 -1
  305. package/dist/cdn/waterfall/snice-waterfall.js +1 -1
  306. package/dist/cdn/waterfall/snice-waterfall.min.js +1 -1
  307. package/dist/cdn/weather/snice-weather.js +1 -1
  308. package/dist/cdn/weather/snice-weather.min.js +1 -1
  309. package/dist/cdn/work-order/snice-work-order.js +1 -1
  310. package/dist/cdn/work-order/snice-work-order.min.js +1 -1
  311. package/dist/components/action-bar/snice-action-bar.d.ts +22 -0
  312. package/dist/components/action-bar/snice-action-bar.js +182 -0
  313. package/dist/components/action-bar/snice-action-bar.js.map +1 -0
  314. package/dist/components/action-bar/snice-action-bar.types.d.ts +17 -0
  315. package/dist/components/binpack/snice-binpack.d.ts +82 -0
  316. package/dist/components/binpack/snice-binpack.js +970 -0
  317. package/dist/components/binpack/snice-binpack.js.map +1 -0
  318. package/dist/components/binpack/snice-binpack.types.d.ts +52 -0
  319. package/dist/components/button/snice-button.js +1 -1
  320. package/dist/components/button/snice-button.js.map +1 -1
  321. package/dist/create-request-handler.d.ts +42 -0
  322. package/dist/index.cjs +70 -1
  323. package/dist/index.cjs.map +1 -1
  324. package/dist/index.d.ts +2 -0
  325. package/dist/index.esm.js +70 -2
  326. package/dist/index.esm.js.map +1 -1
  327. package/dist/index.iife.js +70 -1
  328. package/dist/index.iife.js.map +1 -1
  329. package/dist/react/useRequestHandler.d.ts +56 -0
  330. package/dist/react/useRequestHandler.js +103 -0
  331. package/dist/react/useRequestHandler.js.map +1 -0
  332. package/dist/symbols.cjs +1 -1
  333. package/dist/symbols.esm.js +1 -1
  334. package/dist/transitions.cjs +1 -1
  335. package/dist/transitions.esm.js +1 -1
  336. package/docs/ai/DEVELOPMENT.md +1 -1
  337. package/docs/ai/components/accordion.md +46 -80
  338. package/docs/ai/components/action-bar.md +75 -0
  339. package/docs/ai/components/activity-feed.md +7 -7
  340. package/docs/ai/components/alert.md +26 -44
  341. package/docs/ai/components/app-tiles.md +34 -39
  342. package/docs/ai/components/approval-flow.md +1 -1
  343. package/docs/ai/components/audio-recorder.md +35 -67
  344. package/docs/ai/components/availability.md +13 -34
  345. package/docs/ai/components/avatar-group.md +26 -13
  346. package/docs/ai/components/avatar.md +52 -36
  347. package/docs/ai/components/badge.md +21 -32
  348. package/docs/ai/components/banner.md +21 -43
  349. package/docs/ai/components/binpack.md +89 -0
  350. package/docs/ai/components/book.md +25 -23
  351. package/docs/ai/components/booking.md +31 -36
  352. package/docs/ai/components/breadcrumbs.md +36 -11
  353. package/docs/ai/components/button.md +33 -44
  354. package/docs/ai/components/calendar.md +37 -70
  355. package/docs/ai/components/camera-annotate.md +31 -64
  356. package/docs/ai/components/camera.md +38 -120
  357. package/docs/ai/components/candlestick.md +32 -52
  358. package/docs/ai/components/card.md +20 -30
  359. package/docs/ai/components/carousel.md +32 -32
  360. package/docs/ai/components/cart.md +24 -29
  361. package/docs/ai/components/chart.md +29 -114
  362. package/docs/ai/components/chat.md +38 -75
  363. package/docs/ai/components/checkbox.md +22 -41
  364. package/docs/ai/components/chip.md +18 -54
  365. package/docs/ai/components/code-block.md +57 -178
  366. package/docs/ai/components/color-display.md +12 -32
  367. package/docs/ai/components/color-picker.md +17 -39
  368. package/docs/ai/components/command-palette.md +49 -71
  369. package/docs/ai/components/comments.md +55 -36
  370. package/docs/ai/components/countdown.md +28 -30
  371. package/docs/ai/components/cropper.md +33 -33
  372. package/docs/ai/components/data-card.md +20 -14
  373. package/docs/ai/components/date-picker.md +40 -47
  374. package/docs/ai/components/date-range-picker.md +31 -15
  375. package/docs/ai/components/date-time-picker.md +23 -46
  376. package/docs/ai/components/diff.md +30 -31
  377. package/docs/ai/components/divider.md +17 -47
  378. package/docs/ai/components/doc.md +43 -68
  379. package/docs/ai/components/draw.md +35 -87
  380. package/docs/ai/components/drawer.md +48 -77
  381. package/docs/ai/components/empty-state.md +10 -44
  382. package/docs/ai/components/estimate.md +33 -58
  383. package/docs/ai/components/file-gallery.md +48 -100
  384. package/docs/ai/components/file-upload.md +17 -53
  385. package/docs/ai/components/flip-card.md +31 -23
  386. package/docs/ai/components/flow.md +37 -65
  387. package/docs/ai/components/form-builder.md +35 -75
  388. package/docs/ai/components/form-layout.md +10 -20
  389. package/docs/ai/components/funnel.md +33 -48
  390. package/docs/ai/components/gantt.md +27 -23
  391. package/docs/ai/components/gauge.md +16 -17
  392. package/docs/ai/components/heatmap.md +21 -21
  393. package/docs/ai/components/image.md +7 -13
  394. package/docs/ai/components/input.md +38 -70
  395. package/docs/ai/components/invoice.md +35 -36
  396. package/docs/ai/components/kanban.md +32 -61
  397. package/docs/ai/components/key-value.md +32 -16
  398. package/docs/ai/components/kpi.md +38 -73
  399. package/docs/ai/components/layout.md +29 -23
  400. package/docs/ai/components/leaderboard.md +28 -37
  401. package/docs/ai/components/link-preview.md +12 -18
  402. package/docs/ai/components/link.md +10 -7
  403. package/docs/ai/components/list.md +21 -5
  404. package/docs/ai/components/location.md +21 -25
  405. package/docs/ai/components/login.md +14 -9
  406. package/docs/ai/components/map.md +27 -33
  407. package/docs/ai/components/markdown.md +20 -24
  408. package/docs/ai/components/masonry.md +10 -14
  409. package/docs/ai/components/mentions.md +26 -12
  410. package/docs/ai/components/menu.md +54 -52
  411. package/docs/ai/components/message-strip.md +20 -20
  412. package/docs/ai/components/metric-table.md +14 -21
  413. package/docs/ai/components/modal.md +27 -18
  414. package/docs/ai/components/music-player.md +49 -41
  415. package/docs/ai/components/nav.md +34 -31
  416. package/docs/ai/components/network-graph.md +27 -42
  417. package/docs/ai/components/notification-center.md +31 -33
  418. package/docs/ai/components/order-tracker.md +36 -27
  419. package/docs/ai/components/org-chart.md +36 -31
  420. package/docs/ai/components/pagination.md +34 -26
  421. package/docs/ai/components/paint.md +53 -91
  422. package/docs/ai/components/pdf-viewer.md +35 -36
  423. package/docs/ai/components/permission-matrix.md +26 -31
  424. package/docs/ai/components/podcast-player.md +64 -70
  425. package/docs/ai/components/pricing-table.md +37 -48
  426. package/docs/ai/components/product-card.md +58 -41
  427. package/docs/ai/components/progress-ring.md +20 -24
  428. package/docs/ai/components/progress.md +28 -45
  429. package/docs/ai/components/qr-code.md +25 -27
  430. package/docs/ai/components/qr-reader.md +20 -23
  431. package/docs/ai/components/radio.md +17 -15
  432. package/docs/ai/components/range-slider.md +22 -11
  433. package/docs/ai/components/rating.md +29 -33
  434. package/docs/ai/components/receipt.md +50 -127
  435. package/docs/ai/components/recipe.md +44 -42
  436. package/docs/ai/components/sankey.md +21 -30
  437. package/docs/ai/components/scheduler.md +29 -41
  438. package/docs/ai/components/segmented-control.md +11 -15
  439. package/docs/ai/components/select.md +58 -102
  440. package/docs/ai/components/skeleton.md +16 -30
  441. package/docs/ai/components/slider.md +26 -20
  442. package/docs/ai/components/sortable.md +25 -27
  443. package/docs/ai/components/sparkline.md +21 -17
  444. package/docs/ai/components/spinner.md +9 -5
  445. package/docs/ai/components/split-button.md +10 -13
  446. package/docs/ai/components/split-pane.md +19 -14
  447. package/docs/ai/components/spotlight.md +31 -26
  448. package/docs/ai/components/spreadsheet.md +51 -97
  449. package/docs/ai/components/stat-group.md +9 -19
  450. package/docs/ai/components/step-input.md +17 -15
  451. package/docs/ai/components/stepper.md +14 -15
  452. package/docs/ai/components/switch.md +15 -9
  453. package/docs/ai/components/table.md +24 -84
  454. package/docs/ai/components/tabs.md +18 -10
  455. package/docs/ai/components/tag-input.md +18 -29
  456. package/docs/ai/components/tag.md +10 -22
  457. package/docs/ai/components/terminal.md +9 -9
  458. package/docs/ai/components/testimonial.md +9 -19
  459. package/docs/ai/components/textarea.md +15 -16
  460. package/docs/ai/components/theme.md +3 -3
  461. package/docs/ai/components/time-picker.md +30 -49
  462. package/docs/ai/components/time-range-picker.md +16 -15
  463. package/docs/ai/components/timeline.md +5 -4
  464. package/docs/ai/components/timer.md +8 -8
  465. package/docs/ai/components/toast.md +24 -18
  466. package/docs/ai/components/tooltip.md +11 -22
  467. package/docs/ai/components/tree.md +9 -9
  468. package/docs/ai/components/treemap.md +14 -13
  469. package/docs/ai/components/user-card.md +21 -27
  470. package/docs/ai/components/video-player.md +35 -52
  471. package/docs/ai/components/virtual-scroller.md +1 -1
  472. package/docs/ai/components/waterfall.md +17 -16
  473. package/docs/ai/components/weather.md +19 -34
  474. package/docs/ai/components/work-order.md +58 -134
  475. package/docs/ai/patterns.md +63 -0
  476. package/docs/components/accordion.md +72 -151
  477. package/docs/components/action-bar.md +185 -0
  478. package/docs/components/activity-feed.md +9 -14
  479. package/docs/components/alert.md +17 -109
  480. package/docs/components/app-tiles.md +58 -43
  481. package/docs/components/approval-flow.md +8 -14
  482. package/docs/components/audio-recorder.md +45 -51
  483. package/docs/components/availability.md +30 -45
  484. package/docs/components/avatar-group.md +34 -14
  485. package/docs/components/avatar.md +20 -55
  486. package/docs/components/badge.md +53 -470
  487. package/docs/components/banner.md +44 -30
  488. package/docs/components/binpack.md +208 -0
  489. package/docs/components/book.md +78 -57
  490. package/docs/components/booking.md +35 -87
  491. package/docs/components/breadcrumbs.md +74 -448
  492. package/docs/components/button.md +72 -603
  493. package/docs/components/calendar.md +77 -261
  494. package/docs/components/camera-annotate.md +44 -96
  495. package/docs/components/camera.md +94 -333
  496. package/docs/components/candlestick.md +79 -116
  497. package/docs/components/card.md +51 -689
  498. package/docs/components/carousel.md +29 -76
  499. package/docs/components/cart.md +44 -136
  500. package/docs/components/chart.md +95 -438
  501. package/docs/components/chat.md +175 -439
  502. package/docs/components/checkbox.md +52 -609
  503. package/docs/components/chip.md +45 -574
  504. package/docs/components/code-block.md +157 -421
  505. package/docs/components/color-display.md +45 -54
  506. package/docs/components/color-picker.md +103 -36
  507. package/docs/components/command-palette.md +98 -92
  508. package/docs/components/comments.md +16 -10
  509. package/docs/components/countdown.md +15 -20
  510. package/docs/components/cropper.md +14 -16
  511. package/docs/components/data-card.md +16 -15
  512. package/docs/components/date-picker.md +45 -25
  513. package/docs/components/date-range-picker.md +140 -87
  514. package/docs/components/date-time-picker.md +25 -28
  515. package/docs/components/diff.md +22 -17
  516. package/docs/components/divider.md +18 -20
  517. package/docs/components/doc.md +105 -197
  518. package/docs/components/draw.md +117 -223
  519. package/docs/components/drawer.md +113 -478
  520. package/docs/components/empty-state.md +13 -29
  521. package/docs/components/estimate.md +58 -118
  522. package/docs/components/file-gallery.md +123 -495
  523. package/docs/components/file-upload.md +36 -123
  524. package/docs/components/flip-card.md +30 -34
  525. package/docs/components/flow.md +74 -89
  526. package/docs/components/form-builder.md +59 -86
  527. package/docs/components/form-layout.md +21 -31
  528. package/docs/components/funnel.md +21 -22
  529. package/docs/components/gantt.md +5 -5
  530. package/docs/components/gauge.md +5 -23
  531. package/docs/components/heatmap.md +13 -55
  532. package/docs/components/image.md +28 -32
  533. package/docs/components/input.md +25 -14
  534. package/docs/components/invoice.md +34 -33
  535. package/docs/components/kanban.md +99 -394
  536. package/docs/components/key-value.md +22 -12
  537. package/docs/components/kpi.md +41 -112
  538. package/docs/components/layout.md +7 -13
  539. package/docs/components/leaderboard.md +52 -76
  540. package/docs/components/link-preview.md +20 -16
  541. package/docs/components/link.md +22 -19
  542. package/docs/components/list.md +44 -26
  543. package/docs/components/location.md +9 -13
  544. package/docs/components/login.md +42 -36
  545. package/docs/components/map.md +24 -46
  546. package/docs/components/markdown.md +14 -25
  547. package/docs/components/masonry.md +15 -13
  548. package/docs/components/mentions.md +36 -25
  549. package/docs/components/menu.md +39 -46
  550. package/docs/components/message-strip.md +15 -51
  551. package/docs/components/metric-table.md +50 -72
  552. package/docs/components/modal.md +32 -43
  553. package/docs/components/music-player.md +41 -49
  554. package/docs/components/nav.md +23 -13
  555. package/docs/components/network-graph.md +14 -13
  556. package/docs/components/notification-center.md +68 -172
  557. package/docs/components/order-tracker.md +72 -117
  558. package/docs/components/org-chart.md +58 -207
  559. package/docs/components/pagination.md +67 -89
  560. package/docs/components/paint.md +86 -172
  561. package/docs/components/pdf-viewer.md +46 -151
  562. package/docs/components/permission-matrix.md +61 -112
  563. package/docs/components/podcast-player.md +41 -119
  564. package/docs/components/pricing-table.md +104 -147
  565. package/docs/components/product-card.md +94 -197
  566. package/docs/components/progress-ring.md +29 -32
  567. package/docs/components/progress.md +30 -61
  568. package/docs/components/qr-code.md +53 -61
  569. package/docs/components/qr-reader.md +53 -42
  570. package/docs/components/radio.md +42 -40
  571. package/docs/components/range-slider.md +41 -30
  572. package/docs/components/rating.md +50 -84
  573. package/docs/components/receipt.md +91 -129
  574. package/docs/components/recipe.md +107 -216
  575. package/docs/components/sankey.md +47 -83
  576. package/docs/components/scheduler.md +81 -184
  577. package/docs/components/segmented-control.md +48 -40
  578. package/docs/components/select.md +107 -129
  579. package/docs/components/skeleton.md +33 -47
  580. package/docs/components/slider.md +49 -53
  581. package/docs/components/sortable.md +43 -186
  582. package/docs/components/sparkline.md +26 -25
  583. package/docs/components/spinner.md +32 -37
  584. package/docs/components/split-button.md +43 -23
  585. package/docs/components/split-pane.md +41 -58
  586. package/docs/components/spotlight.md +53 -145
  587. package/docs/components/spreadsheet.md +84 -307
  588. package/docs/components/stat-group.md +27 -61
  589. package/docs/components/step-input.md +44 -41
  590. package/docs/components/stepper.md +55 -89
  591. package/docs/components/switch.md +39 -39
  592. package/docs/components/table.md +27 -32
  593. package/docs/components/tabs.md +36 -27
  594. package/docs/components/tag-input.md +50 -176
  595. package/docs/components/tag.md +12 -50
  596. package/docs/components/terminal.md +32 -37
  597. package/docs/components/testimonial.md +24 -81
  598. package/docs/components/textarea.md +9 -14
  599. package/docs/components/theme.md +10 -23
  600. package/docs/components/time-picker.md +48 -72
  601. package/docs/components/time-range-picker.md +22 -41
  602. package/docs/components/timeline.md +7 -14
  603. package/docs/components/timer.md +16 -32
  604. package/docs/components/toast.md +19 -45
  605. package/docs/components/tooltip.md +13 -115
  606. package/docs/components/tree.md +2 -19
  607. package/docs/components/treemap.md +19 -43
  608. package/docs/components/user-card.md +13 -22
  609. package/docs/components/video-player.md +53 -227
  610. package/docs/components/virtual-scroller.md +11 -44
  611. package/docs/components/waterfall.md +58 -137
  612. package/docs/components/weather.md +94 -153
  613. package/docs/components/work-order.md +56 -143
  614. package/docs/plans/2026-03-09-action-bar-design.md +104 -0
  615. package/docs/plans/2026-03-09-action-bar-plan.md +676 -0
  616. package/docs/plans/2026-03-10-react-integration-design.md +166 -0
  617. package/docs/request-response.md +77 -0
  618. package/package.json +1 -1
@@ -4,29 +4,29 @@ Full-featured audio player with playlist, shuffle, repeat, and volume control.
4
4
 
5
5
  ## Properties
6
6
 
7
- ```typescript
8
- tracks: Track[] = [];
9
- currentTrackIndex: number = 0;
10
- currentTrack: string = ''; // reflected attribute, track ID
11
- currentTime: number = 0; // read-only, use seek()
12
- duration: number = 0;
7
+ ```ts
8
+ tracks: Track[] = []; // JS only
9
+ currentTrackIndex: number = 0; // attr: current-track-index
10
+ currentTrack: string = ''; // attr: current-track, track ID
13
11
  volume: number = 1;
14
12
  muted: boolean = false;
15
13
  shuffle: boolean = false;
16
14
  repeat: 'off'|'all'|'one' = 'off';
17
15
  state: 'playing'|'paused'|'stopped'|'loading'|'error' = 'stopped';
18
16
  autoplay: boolean = false;
19
- showPlaylist: boolean = true; // attr: show-playlist
20
- showControls: boolean = true; // attr: show-controls
21
- showVolume: boolean = true; // attr: show-volume
22
- showArtwork: boolean = true; // attr: show-artwork
23
- showTrackInfo: boolean = true; // attr: show-track-info
17
+ showPlaylist: boolean = true; // attr: show-playlist
18
+ showControls: boolean = true; // attr: show-controls
19
+ showVolume: boolean = true; // attr: show-volume
20
+ showArtwork: boolean = true; // attr: show-artwork
21
+ showTrackInfo: boolean = true; // attr: show-track-info
24
22
  compact: boolean = false;
25
23
  ```
26
24
 
27
- ## Track Interface
25
+ > `currentTime` and `duration` are plain class fields, not `@property`. Use `seek()` to set position.
28
26
 
29
- ```typescript
27
+ ## Types
28
+
29
+ ```ts
30
30
  interface Track {
31
31
  id: string;
32
32
  title: string;
@@ -36,42 +36,50 @@ interface Track {
36
36
  src: string;
37
37
  duration?: number;
38
38
  }
39
+
40
+ type RepeatMode = 'off' | 'all' | 'one';
41
+ type PlayerState = 'playing' | 'paused' | 'stopped' | 'loading' | 'error';
39
42
  ```
40
43
 
41
44
  ## Methods
42
45
 
43
- - `play()` - Start/resume playback (async)
44
- - `pause()` - Pause playback
45
- - `stop()` - Stop and reset position
46
- - `next()` - Skip to next track
47
- - `previous()` - Skip to previous track
48
- - `seek(time: number)` - Seek to time in seconds
49
- - `setVolume(volume: number)` - Set volume (0-1)
50
- - `toggleShuffle()` - Toggle shuffle mode
51
- - `setRepeat(mode: 'off'|'all'|'one')` - Set repeat mode
52
- - `loadTrack(index: number)` - Load track by index (async)
53
- - `getCurrentTrack()` - Returns current Track or null
46
+ - `play()` Start/resume (async)
47
+ - `pause()` Pause
48
+ - `stop()` Stop and reset position
49
+ - `next()` Next track
50
+ - `previous()` Previous track (restarts if >3s in)
51
+ - `seek(time)` Seek to seconds
52
+ - `setVolume(volume)` Set volume (0-1)
53
+ - `toggleShuffle()` Toggle shuffle
54
+ - `setRepeat(mode)` Set repeat mode
55
+ - `loadTrack(index)` Load track by index (async)
56
+ - `getCurrentTrack()` Current Track or null
54
57
 
55
58
  ## Events
56
59
 
57
- - `player-play` → `{ track }`
58
- - `player-pause` → `{ track }`
60
+ - `player-play` → `{ player, track }`
61
+ - `player-pause` → `{ player, track }`
59
62
  - `player-stop` → `{ player }`
60
- - `player-track-change` → `{ track }`
61
- - `player-track-ended` → `{ track }`
62
- - `player-shuffle-change` → `{ shuffle }`
63
- - `player-repeat-change` → `{ repeat }`
64
- - `player-volume-change` → `{ volume }`
65
- - `player-seek` → `{ time }`
66
- - `player-time-update` → `{ currentTime, duration }`
67
- - `player-error` → `{ error }`
68
-
69
- **CSS Parts:**
70
- - `base` - Outer player container div
71
- - `controls` - Playback controls and progress bar section
72
- - `playlist` - Playlist section with track list
73
-
74
- ## Usage
63
+ - `player-track-change` → `{ player, track }`
64
+ - `player-track-ended` → `{ player, track }`
65
+ - `player-shuffle-change` → `{ player, shuffle }`
66
+ - `player-repeat-change` → `{ player, repeat }`
67
+ - `player-volume-change` → `{ player, volume }`
68
+ - `player-seek` → `{ player, time }`
69
+ - `player-time-update` → `{ player, currentTime, duration }`
70
+ - `player-error` → `{ player, error }`
71
+
72
+ ## CSS Parts
73
+
74
+ - `base` - Outer player container
75
+ - `controls` - Playback controls and progress bar
76
+ - `playlist` - Playlist section
77
+
78
+ ## Basic Usage
79
+
80
+ ```typescript
81
+ import 'snice/components/music-player/snice-music-player';
82
+ ```
75
83
 
76
84
  ```html
77
85
  <snice-music-player id="player" autoplay shuffle compact show-playlist="false"></snice-music-player>
@@ -14,28 +14,18 @@ isTopLevel: boolean = false; // attr: is-top-level, receive context updates
14
14
 
15
15
  - `update(placards, appContext?, currentRoute?, routeParams?)` - Update nav with placard data
16
16
 
17
- ## Placard Structure
17
+ ## Slots
18
18
 
19
- ```typescript
20
- interface Placard {
21
- name: string; // Route identifier
22
- title: string; // Display text
23
- icon?: string; // Icon character
24
- order?: number; // Sort order
25
- parent?: string; // Parent name (hierarchical)
26
- group?: string; // Group name (grouped)
27
- show?: boolean;
28
- description?: string; // Accessible label/tooltip
29
- tooltip?: string;
30
- hotkeys?: string[];
31
- helpUrl?: string;
32
- searchTerms?: string[];
33
- attributes?: Record<string, any>;
34
- visibleOn?: Function | Function[];
35
- }
36
- ```
19
+ - `(default)` - Additional content after navigation
20
+
21
+ ## CSS Parts
22
+
23
+ - `base` - Outer content wrapper
24
+ - `nav` - Navigation element
25
+ - `link` - Individual nav link
26
+ - `icon` - Nav item icon (img or span)
37
27
 
38
- ## Usage
28
+ ## Basic Usage
39
29
 
40
30
  ```html
41
31
  <snice-nav id="nav" variant="flat" orientation="horizontal"></snice-nav>
@@ -51,17 +41,30 @@ nav.update([
51
41
  ], undefined, 'home');
52
42
  ```
53
43
 
54
- **CSS Parts:**
55
- - `base` - Outer content wrapper
56
- - `nav` - Navigation element
57
- - `link` - Individual nav link
58
- - `icon` - Nav item icon (img or span)
44
+ ## Examples
45
+
46
+ ```typescript
47
+ // Hierarchical
48
+ nav.update([
49
+ { name: 'products', title: 'Products', order: 0 },
50
+ { name: 'electronics', title: 'Electronics', parent: 'products', order: 0 },
51
+ ]);
52
+
53
+ // Grouped
54
+ nav.update([
55
+ { name: 'home', title: 'Home', group: 'Main', order: 0 },
56
+ { name: 'profile', title: 'Profile', group: 'Account', order: 0 },
57
+ ]);
58
+
59
+ // Conditional visibility
60
+ nav.update([
61
+ { name: 'admin', title: 'Admin', visibleOn: (ctx) => ctx.user?.isAdmin },
62
+ ], { user: { isAdmin: true } });
63
+ ```
59
64
 
60
- ## Features
65
+ ## Accessibility
61
66
 
62
- - Flat, hierarchical, and grouped variants
63
- - Active route tracking (`.nav__link--active`, `aria-current="page"`)
64
67
  - `role="navigation"` on container
65
- - Hotkeys via `data-hotkeys` attribute
66
- - Conditional visibility via `visibleOn` guards
67
- - Custom attributes via placard `attributes`
68
+ - `aria-current="page"` on active item
69
+ - `aria-label` from placard `description`
70
+ - Focus-visible styles for keyboard navigation
@@ -15,33 +15,6 @@ showLabels: boolean = true; // attr: show-labels
15
15
  animation: boolean = true;
16
16
  ```
17
17
 
18
- ## Types
19
-
20
- ```typescript
21
- interface NetworkGraphData {
22
- nodes: NetworkNode[];
23
- edges: NetworkEdge[];
24
- }
25
-
26
- interface NetworkNode {
27
- id: string;
28
- label?: string;
29
- group?: string; // Auto color-coded
30
- size?: number; // Custom radius
31
- color?: string; // Custom fill
32
- x?: number; // Fixed position (pins node)
33
- y?: number;
34
- }
35
-
36
- interface NetworkEdge {
37
- source: string;
38
- target: string;
39
- label?: string;
40
- weight?: number; // Stroke width
41
- color?: string;
42
- }
43
- ```
44
-
45
18
  ## Events
46
19
 
47
20
  - `node-click` → `{ node: NetworkNode }`
@@ -49,7 +22,13 @@ interface NetworkEdge {
49
22
  - `node-drag` → `{ node: NetworkNode, x: number, y: number }`
50
23
  - `graph-zoom` → `{ scale: number, x: number, y: number }`
51
24
 
52
- ## Usage
25
+ ## CSS Parts
26
+
27
+ - `base` - The outer graph container
28
+ - `canvas` - The SVG element
29
+ - `tooltip` - The hover tooltip element
30
+
31
+ ## Basic Usage
53
32
 
54
33
  ```html
55
34
  <snice-network-graph id="graph" layout="force" show-labels style="height:400px"></snice-network-graph>
@@ -69,20 +48,26 @@ graph.data = {
69
48
  graph.addEventListener('node-click', (e) => console.log(e.detail.node));
70
49
  ```
71
50
 
72
- **CSS Parts:**
73
- - `base` - The outer graph container
74
- - `canvas` - The SVG element
75
- - `tooltip` - The hover tooltip element
51
+ ## Examples
52
+
53
+ ```html
54
+ <!-- Static display -->
55
+ <snice-network-graph zoom-enabled="false" drag-enabled="false"></snice-network-graph>
56
+
57
+ <!-- Custom force tuning -->
58
+ <snice-network-graph charge-strength="-500" link-distance="120"></snice-network-graph>
59
+ ```
76
60
 
77
- ## Features
61
+ ## Accessibility
78
62
 
79
- - Force-directed, circular, and grid layouts
80
- - Zoom/pan (mouse wheel + drag background)
81
- - Draggable nodes (pin on drag, double-click to unpin)
82
- - Node sizing by degree or custom `size`
83
- - Color coding by `group` (10-color palette)
84
- - Edge weight as stroke width
85
- - Hover highlighting (connected subgraph)
86
- - Tooltips with label and degree
63
+ - `role="img"` with `aria-label` on container
64
+ - Hover tooltips with label and degree
87
65
  - Responsive via ResizeObserver
88
- - Accessible: role="img" with aria-label
66
+
67
+ ## Types
68
+
69
+ ```typescript
70
+ interface NetworkGraphData { nodes: NetworkNode[]; edges: NetworkEdge[]; }
71
+ interface NetworkNode { id: string; label?: string; group?: string; size?: number; color?: string; x?: number; y?: number; }
72
+ interface NetworkEdge { source: string; target: string; label?: string; weight?: number; color?: string; }
73
+ ```
@@ -4,24 +4,10 @@ Bell icon with dropdown notification panel. Shows unread badge, supports dismiss
4
4
 
5
5
  ## Properties
6
6
 
7
- ```ts
8
- notifications: NotificationItem[] // Array of notification objects
9
- open: boolean // Whether the dropdown panel is visible (default: false)
10
- icon: string // Custom bell icon (URL, image file, emoji) (default: '')
11
- ```
12
-
13
- ### NotificationItem
14
-
15
- ```ts
16
- interface NotificationItem {
17
- id: string;
18
- title: string;
19
- message: string;
20
- timestamp: string;
21
- read?: boolean;
22
- icon?: string; // Emoji/text icon (auto-set by type if omitted)
23
- type?: 'info' | 'success' | 'warning' | 'error';
24
- }
7
+ ```typescript
8
+ notifications: NotificationItem[] = []; // attr: none (JS only)
9
+ open: boolean = false; // Panel visibility
10
+ icon: string = ''; // Custom bell icon (URL, image, emoji)
25
11
  ```
26
12
 
27
13
  ## Methods
@@ -32,8 +18,8 @@ interface NotificationItem {
32
18
 
33
19
  ## Events
34
20
 
35
- - `notification-click` → `{ notification: NotificationItem }` - Notification item clicked
36
- - `notification-dismiss` → `{ id: string }` - Notification dismissed
21
+ - `notification-click` → `{ notification: NotificationItem }` - Item clicked
22
+ - `notification-dismiss` → `{ id: string }` - Item dismissed
37
23
  - `notification-read-all` → `void` - All marked as read
38
24
 
39
25
  ## Slots
@@ -45,13 +31,11 @@ interface NotificationItem {
45
31
  - `trigger` - The bell icon button
46
32
  - `icon` - The bell icon span
47
33
  - `panel` - The dropdown notification panel
48
- - `panel-header` - The panel header with title and mark-all-read action
34
+ - `panel-header` - Panel header with title and mark-all-read action
49
35
 
50
36
  ## CSS Custom Properties
51
37
 
52
38
  ```css
53
- --snice-font-family
54
- --snice-color-text
55
39
  --snice-color-primary /* Mark all read link, unread highlight */
56
40
  --snice-color-primary-subtle /* Unread item background */
57
41
  --snice-color-danger /* Badge background, dismiss hover */
@@ -62,24 +46,17 @@ interface NotificationItem {
62
46
  --snice-color-background /* Panel background */
63
47
  --snice-color-background-element /* Item hover, bell hover */
64
48
  --snice-shadow-lg /* Panel shadow */
65
- --snice-spacing-*
66
- --snice-font-size-sm
67
- --snice-font-size-md
68
- --snice-font-weight-medium
69
- --snice-font-weight-semibold
70
- --snice-font-weight-bold
71
- --snice-border-radius-md
72
- --snice-border-radius-lg
73
- --snice-transition-fast
74
49
  ```
75
50
 
76
- ## Usage
51
+ ## Basic Usage
77
52
 
78
53
  ```html
79
54
  <snice-notification-center></snice-notification-center>
80
55
  ```
81
56
 
82
57
  ```typescript
58
+ import 'snice/components/notification-center/snice-notification-center';
59
+
83
60
  nc.notifications = [
84
61
  { id: '1', title: 'New message', message: 'You have a new message', timestamp: '2 min ago', type: 'info' },
85
62
  { id: '2', title: 'Deployed', message: 'Build succeeded', timestamp: '5 min ago', type: 'success', read: true }
@@ -89,3 +66,24 @@ nc.addEventListener('notification-click', (e) => {
89
66
  console.log('Clicked:', e.detail.notification);
90
67
  });
91
68
  ```
69
+
70
+ ## Accessibility
71
+
72
+ - Bell icon is keyboard-focusable
73
+ - Unread count via badge element
74
+ - Notification items are clickable with dismiss buttons
75
+ - "Mark all as read" action in panel header
76
+
77
+ ## Types
78
+
79
+ ```typescript
80
+ interface NotificationItem {
81
+ id: string;
82
+ title: string;
83
+ message: string;
84
+ timestamp: string;
85
+ read?: boolean;
86
+ icon?: string;
87
+ type?: 'info' | 'success' | 'warning' | 'error';
88
+ }
89
+ ```
@@ -4,48 +4,38 @@ Order status timeline with step indicators, tracking info, timestamps, and descr
4
4
 
5
5
  ## Properties
6
6
 
7
- ```ts
8
- steps: OrderStep[] = []; // Timeline steps
9
- trackingNumber: string = ''; // Tracking number (attr: tracking-number)
10
- carrier: string = ''; // Carrier name
11
- variant: 'horizontal' | 'vertical' = 'horizontal'; // Layout orientation
12
- ```
13
-
14
- ### Types
15
-
16
- ```ts
17
- interface OrderStep {
18
- label: string;
19
- status: 'pending' | 'active' | 'completed';
20
- timestamp?: string;
21
- description?: string;
22
- icon?: string;
23
- }
7
+ ```typescript
8
+ steps: OrderStep[] = []; // attr: none (JS only)
9
+ trackingNumber: string = ''; // attr: tracking-number
10
+ carrier: string = '';
11
+ variant: 'horizontal'|'vertical' = 'horizontal';
24
12
  ```
25
13
 
26
14
  ## Events
27
15
 
28
- - `step-click` -> `{ step: OrderStep; index: number }`
16
+ - `step-click` `{ step: OrderStep, index: number }` - Step clicked
29
17
 
30
18
  ## CSS Parts
31
19
 
32
- `base`, `info`, `steps`, `step`, `step-indicator`, `step-content`
20
+ - `base` - Outer tracker container
21
+ - `info` - Tracking info section (carrier, tracking number)
22
+ - `steps` - Steps container
23
+ - `step` - Individual step
24
+ - `step-indicator` - Step number/check icon
25
+ - `step-content` - Step label, timestamp, description
33
26
 
34
- ## Usage
27
+ ## Basic Usage
35
28
 
36
29
  ```html
37
- <snice-order-tracker
38
- tracking-number="1Z999AA10123456784"
39
- carrier="UPS">
40
- </snice-order-tracker>
30
+ <snice-order-tracker tracking-number="1Z999AA10123456784" carrier="UPS"></snice-order-tracker>
41
31
  ```
42
32
 
43
33
  ```typescript
34
+ import 'snice/components/order-tracker/snice-order-tracker';
35
+
44
36
  tracker.steps = [
45
37
  { label: 'Ordered', status: 'completed', timestamp: 'Feb 20, 2026' },
46
- { label: 'Confirmed', status: 'completed', timestamp: 'Feb 20, 2026' },
47
- { label: 'Shipped', status: 'active', timestamp: 'Feb 22, 2026', description: 'Package left the warehouse' },
48
- { label: 'Out for Delivery', status: 'pending' },
38
+ { label: 'Shipped', status: 'active', timestamp: 'Feb 22, 2026', description: 'Package left warehouse' },
49
39
  { label: 'Delivered', status: 'pending' }
50
40
  ];
51
41
 
@@ -53,3 +43,22 @@ tracker.addEventListener('step-click', (e) => {
53
43
  console.log(e.detail.step.label, e.detail.index);
54
44
  });
55
45
  ```
46
+
47
+ ## Accessibility
48
+
49
+ - Steps use `role="list"` / `role="listitem"`
50
+ - Steps are keyboard-focusable with Enter/Space activation
51
+ - Completed steps show check icons
52
+
53
+ ## Types
54
+
55
+ ```typescript
56
+ type OrderStepStatus = 'pending' | 'active' | 'completed';
57
+ interface OrderStep {
58
+ label: string;
59
+ status: OrderStepStatus;
60
+ timestamp?: string;
61
+ description?: string;
62
+ icon?: string;
63
+ }
64
+ ```
@@ -4,54 +4,42 @@ Hierarchical organizational chart with expand/collapse, avatars, and two layout
4
4
 
5
5
  ## Properties
6
6
 
7
- ```ts
8
- data: OrgChartNode | null // Root node of the tree
9
- direction: 'top-down' | 'left-right' // Layout direction (default: 'top-down')
10
- compact: boolean // Compact node display (default: false)
11
- ```
12
-
13
- ### OrgChartNode
14
-
15
- ```ts
16
- interface OrgChartNode {
17
- id: string;
18
- name: string;
19
- title?: string; // Job title / role
20
- avatar?: string; // Avatar image URL
21
- children?: OrgChartNode[];
22
- }
7
+ ```typescript
8
+ data: OrgChartNode | null = null; // attr: none (JS only)
9
+ direction: 'top-down'|'left-right' = 'top-down';
10
+ compact: boolean = false;
23
11
  ```
24
12
 
25
13
  ## Methods
26
14
 
27
- - `collapseNode(id: string)` -- Collapse a specific node
28
- - `expandNode(id: string)` -- Expand a specific node
29
- - `expandAll()` -- Expand all nodes
30
- - `collapseAll()` -- Collapse all nodes
15
+ - `collapseNode(id: string)` - Collapse a specific node
16
+ - `expandNode(id: string)` - Expand a specific node
17
+ - `expandAll()` - Expand all nodes
18
+ - `collapseAll()` - Collapse all nodes
31
19
 
32
20
  ## Events
33
21
 
34
- - `node-click` -> `{ node: OrgChartNode }` -- Node clicked
35
- - `node-expand` -> `{ node: OrgChartNode }` -- Node expanded
36
- - `node-collapse` -> `{ node: OrgChartNode }` -- Node collapsed
22
+ - `node-click` `{ node: OrgChartNode }` - Node clicked
23
+ - `node-expand` `{ node: OrgChartNode }` - Node expanded
24
+ - `node-collapse` `{ node: OrgChartNode }` - Node collapsed
37
25
 
38
- **CSS Parts:**
39
- - `base` - The outer chart container
40
- - `tree` - The tree layout wrapper
26
+ ## CSS Parts
27
+
28
+ - `base` - Outer chart container
29
+ - `tree` - Tree layout wrapper
41
30
  - `node` - Individual node cards
42
31
 
43
- ## Usage
32
+ ## Basic Usage
44
33
 
45
34
  ```html
46
35
  <snice-org-chart direction="top-down"></snice-org-chart>
47
36
  ```
48
37
 
49
38
  ```typescript
39
+ import 'snice/components/org-chart/snice-org-chart';
40
+
50
41
  chart.data = {
51
- id: 'ceo',
52
- name: 'Jane Smith',
53
- title: 'CEO',
54
- avatar: '/avatars/jane.jpg',
42
+ id: 'ceo', name: 'Jane Smith', title: 'CEO', avatar: '/avatars/jane.jpg',
55
43
  children: [
56
44
  { id: 'cto', name: 'Bob Jones', title: 'CTO', children: [
57
45
  { id: 'dev1', name: 'Alice', title: 'Engineer' }
@@ -64,3 +52,20 @@ chart.addEventListener('node-click', (e) => {
64
52
  console.log('Selected:', e.detail.node.name);
65
53
  });
66
54
  ```
55
+
56
+ ## Accessibility
57
+
58
+ - Nodes are clickable with expand/collapse toggle buttons
59
+ - Avatar placeholders show name initials
60
+
61
+ ## Types
62
+
63
+ ```typescript
64
+ interface OrgChartNode {
65
+ id: string;
66
+ name: string;
67
+ title?: string;
68
+ avatar?: string;
69
+ children?: OrgChartNode[];
70
+ }
71
+ ```
@@ -1,48 +1,35 @@
1
1
  # snice-pagination
2
2
 
3
- Pagination navigation component.
3
+ Pagination navigation component with page numbers, ellipsis, and navigation buttons.
4
4
 
5
5
  ## Properties
6
6
 
7
7
  ```typescript
8
8
  current: number = 1;
9
9
  total: number = 1;
10
- siblings: number = 1; // Pages shown each side of current
11
- showFirst: boolean = true; // attr: show-first
12
- showLast: boolean = true; // attr: show-last
13
- showPrev: boolean = true; // attr: show-prev
14
- showNext: boolean = true; // attr: show-next
10
+ siblings: number = 1; // Pages shown each side of current
11
+ showFirst: boolean = true; // attr: show-first
12
+ showLast: boolean = true; // attr: show-last
13
+ showPrev: boolean = true; // attr: show-prev
14
+ showNext: boolean = true; // attr: show-next
15
15
  size: 'small'|'medium'|'large' = 'medium';
16
16
  variant: 'default'|'rounded'|'text' = 'default';
17
17
  ```
18
18
 
19
19
  ## Methods
20
20
 
21
- - `goToPage(page: number)` - Navigate to page
22
- - `nextPage()` - Next page
23
- - `previousPage()` - Previous page
24
- - `firstPage()` - First page
25
- - `lastPage()` - Last page
21
+ - `goToPage(page: number)` - Navigate to specific page
22
+ - `nextPage()` - Go to next page
23
+ - `previousPage()` - Go to previous page
24
+ - `firstPage()` - Go to first page
25
+ - `lastPage()` - Go to last page
26
26
 
27
27
  ## Events
28
28
 
29
- - `pagination-change` → `{ page, previousPage }`
29
+ - `pagination-change` → `{ page: number, previousPage: number }` - Page changed
30
30
 
31
- ## Usage
31
+ ## CSS Parts
32
32
 
33
- ```html
34
- <snice-pagination current="1" total="10"></snice-pagination>
35
- <snice-pagination total="20" siblings="3" variant="rounded" size="large"></snice-pagination>
36
- ```
37
-
38
- ```typescript
39
- pagination.addEventListener('pagination-change', (e) => {
40
- console.log(e.detail.page);
41
- });
42
- pagination.goToPage(5);
43
- ```
44
-
45
- **CSS Parts:**
46
33
  - `base` - Nav container
47
34
  - `button` - All navigation buttons (shared)
48
35
  - `first-button` - First page button
@@ -61,3 +48,24 @@ pagination.goToPage(5);
61
48
  --pagination-font-size: 14px;
62
49
  --pagination-border-radius: 4px;
63
50
  ```
51
+
52
+ ## Basic Usage
53
+
54
+ ```html
55
+ <snice-pagination current="1" total="10"></snice-pagination>
56
+ ```
57
+
58
+ ```typescript
59
+ import 'snice/components/pagination/snice-pagination';
60
+
61
+ pagination.addEventListener('pagination-change', (e) => {
62
+ console.log('Page:', e.detail.page);
63
+ });
64
+ ```
65
+
66
+ ## Accessibility
67
+
68
+ - Uses `<nav>` with `aria-label="Pagination"`
69
+ - Active page has `aria-current="page"`
70
+ - Navigation buttons have `aria-label` attributes
71
+ - Disabled state for boundary buttons