snice 4.9.0 → 4.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (733) hide show
  1. package/adapters/react/app-tiles.d.ts +28 -0
  2. package/adapters/react/app-tiles.d.ts.map +1 -0
  3. package/adapters/react/app-tiles.js +24 -0
  4. package/adapters/react/app-tiles.js.map +1 -0
  5. package/adapters/react/app-tiles.tsx +36 -0
  6. package/adapters/react/book.d.ts +28 -0
  7. package/adapters/react/book.d.ts.map +1 -0
  8. package/adapters/react/book.js +24 -0
  9. package/adapters/react/book.js.map +1 -0
  10. package/adapters/react/book.tsx +36 -0
  11. package/adapters/react/comments.d.ts +29 -0
  12. package/adapters/react/comments.d.ts.map +1 -0
  13. package/adapters/react/comments.js +24 -0
  14. package/adapters/react/comments.js.map +1 -0
  15. package/adapters/react/comments.tsx +37 -0
  16. package/adapters/react/components.d.ts +52 -0
  17. package/adapters/react/components.d.ts.map +1 -1
  18. package/adapters/react/components.js +26 -0
  19. package/adapters/react/components.js.map +1 -1
  20. package/adapters/react/components.ts +52 -0
  21. package/adapters/react/countdown.d.ts +31 -0
  22. package/adapters/react/countdown.d.ts.map +1 -0
  23. package/adapters/react/countdown.js +24 -0
  24. package/adapters/react/countdown.js.map +1 -0
  25. package/adapters/react/countdown.tsx +39 -0
  26. package/adapters/react/cropper.d.ts +29 -0
  27. package/adapters/react/cropper.d.ts.map +1 -0
  28. package/adapters/react/cropper.js +24 -0
  29. package/adapters/react/cropper.js.map +1 -0
  30. package/adapters/react/cropper.tsx +37 -0
  31. package/adapters/react/diff.d.ts +31 -0
  32. package/adapters/react/diff.d.ts.map +1 -0
  33. package/adapters/react/diff.js +24 -0
  34. package/adapters/react/diff.js.map +1 -0
  35. package/adapters/react/diff.tsx +39 -0
  36. package/adapters/react/flip-card.d.ts +28 -0
  37. package/adapters/react/flip-card.d.ts.map +1 -0
  38. package/adapters/react/flip-card.js +24 -0
  39. package/adapters/react/flip-card.js.map +1 -0
  40. package/adapters/react/flip-card.tsx +36 -0
  41. package/adapters/react/flow.d.ts +32 -0
  42. package/adapters/react/flow.d.ts.map +1 -0
  43. package/adapters/react/flow.js +24 -0
  44. package/adapters/react/flow.js.map +1 -0
  45. package/adapters/react/flow.tsx +40 -0
  46. package/adapters/react/gantt.d.ts +27 -0
  47. package/adapters/react/gantt.d.ts.map +1 -0
  48. package/adapters/react/gantt.js +24 -0
  49. package/adapters/react/gantt.js.map +1 -0
  50. package/adapters/react/gantt.tsx +35 -0
  51. package/adapters/react/map.d.ts +30 -0
  52. package/adapters/react/map.d.ts.map +1 -0
  53. package/adapters/react/map.js +24 -0
  54. package/adapters/react/map.js.map +1 -0
  55. package/adapters/react/map.tsx +38 -0
  56. package/adapters/react/markdown.d.ts +26 -0
  57. package/adapters/react/markdown.d.ts.map +1 -0
  58. package/adapters/react/markdown.js +24 -0
  59. package/adapters/react/markdown.js.map +1 -0
  60. package/adapters/react/markdown.tsx +34 -0
  61. package/adapters/react/notification-center.d.ts +26 -0
  62. package/adapters/react/notification-center.d.ts.map +1 -0
  63. package/adapters/react/notification-center.js +24 -0
  64. package/adapters/react/notification-center.js.map +1 -0
  65. package/adapters/react/notification-center.tsx +34 -0
  66. package/adapters/react/org-chart.d.ts +28 -0
  67. package/adapters/react/org-chart.d.ts.map +1 -0
  68. package/adapters/react/org-chart.js +24 -0
  69. package/adapters/react/org-chart.js.map +1 -0
  70. package/adapters/react/org-chart.tsx +36 -0
  71. package/adapters/react/pdf-viewer.d.ts +28 -0
  72. package/adapters/react/pdf-viewer.d.ts.map +1 -0
  73. package/adapters/react/pdf-viewer.js +24 -0
  74. package/adapters/react/pdf-viewer.js.map +1 -0
  75. package/adapters/react/pdf-viewer.tsx +36 -0
  76. package/adapters/react/podcast-player.d.ts +40 -0
  77. package/adapters/react/podcast-player.d.ts.map +1 -0
  78. package/adapters/react/podcast-player.js +24 -0
  79. package/adapters/react/podcast-player.js.map +1 -0
  80. package/adapters/react/podcast-player.tsx +48 -0
  81. package/adapters/react/pricing-table.d.ts +27 -0
  82. package/adapters/react/pricing-table.d.ts.map +1 -0
  83. package/adapters/react/pricing-table.js +24 -0
  84. package/adapters/react/pricing-table.js.map +1 -0
  85. package/adapters/react/pricing-table.tsx +35 -0
  86. package/adapters/react/rating.d.ts +30 -0
  87. package/adapters/react/rating.d.ts.map +1 -0
  88. package/adapters/react/rating.js +24 -0
  89. package/adapters/react/rating.js.map +1 -0
  90. package/adapters/react/rating.tsx +38 -0
  91. package/adapters/react/recipe.d.ts +43 -0
  92. package/adapters/react/recipe.d.ts.map +1 -0
  93. package/adapters/react/recipe.js +24 -0
  94. package/adapters/react/recipe.js.map +1 -0
  95. package/adapters/react/recipe.tsx +51 -0
  96. package/adapters/react/sortable.d.ts +28 -0
  97. package/adapters/react/sortable.d.ts.map +1 -0
  98. package/adapters/react/sortable.js +24 -0
  99. package/adapters/react/sortable.js.map +1 -0
  100. package/adapters/react/sortable.tsx +36 -0
  101. package/adapters/react/spotlight.d.ts +27 -0
  102. package/adapters/react/spotlight.d.ts.map +1 -0
  103. package/adapters/react/spotlight.js +24 -0
  104. package/adapters/react/spotlight.js.map +1 -0
  105. package/adapters/react/spotlight.tsx +35 -0
  106. package/adapters/react/spreadsheet.d.ts +27 -0
  107. package/adapters/react/spreadsheet.d.ts.map +1 -0
  108. package/adapters/react/spreadsheet.js +24 -0
  109. package/adapters/react/spreadsheet.js.map +1 -0
  110. package/adapters/react/spreadsheet.tsx +35 -0
  111. package/adapters/react/tag-input.d.ts +33 -0
  112. package/adapters/react/tag-input.d.ts.map +1 -0
  113. package/adapters/react/tag-input.js +24 -0
  114. package/adapters/react/tag-input.js.map +1 -0
  115. package/adapters/react/tag-input.tsx +41 -0
  116. package/adapters/react/testimonial.d.ts +31 -0
  117. package/adapters/react/testimonial.d.ts.map +1 -0
  118. package/adapters/react/testimonial.js +24 -0
  119. package/adapters/react/testimonial.js.map +1 -0
  120. package/adapters/react/testimonial.tsx +39 -0
  121. package/adapters/react/video-player.d.ts +34 -0
  122. package/adapters/react/video-player.d.ts.map +1 -0
  123. package/adapters/react/video-player.js +24 -0
  124. package/adapters/react/video-player.js.map +1 -0
  125. package/adapters/react/video-player.tsx +42 -0
  126. package/adapters/react/waterfall.d.ts +29 -0
  127. package/adapters/react/waterfall.d.ts.map +1 -0
  128. package/adapters/react/waterfall.js +24 -0
  129. package/adapters/react/waterfall.js.map +1 -0
  130. package/adapters/react/waterfall.tsx +37 -0
  131. package/adapters/react/weather.d.ts +27 -0
  132. package/adapters/react/weather.d.ts.map +1 -0
  133. package/adapters/react/weather.js +24 -0
  134. package/adapters/react/weather.js.map +1 -0
  135. package/adapters/react/weather.tsx +35 -0
  136. package/dist/cdn/accordion/snice-accordion.js +1 -1
  137. package/dist/cdn/accordion/snice-accordion.min.js +1 -1
  138. package/dist/cdn/alert/snice-alert.js +1 -1
  139. package/dist/cdn/alert/snice-alert.min.js +1 -1
  140. package/dist/cdn/app-tiles/README.md +27 -0
  141. package/dist/cdn/app-tiles/snice-app-tiles.js +333 -0
  142. package/dist/cdn/app-tiles/snice-app-tiles.js.map +1 -0
  143. package/dist/cdn/app-tiles/snice-app-tiles.min.js +11 -0
  144. package/dist/cdn/app-tiles/snice-app-tiles.min.js.map +1 -0
  145. package/dist/cdn/audio-recorder/snice-audio-recorder.js +1 -1
  146. package/dist/cdn/audio-recorder/snice-audio-recorder.min.js +1 -1
  147. package/dist/cdn/avatar/snice-avatar.js +1 -1
  148. package/dist/cdn/avatar/snice-avatar.min.js +1 -1
  149. package/dist/cdn/badge/snice-badge.js +1 -1
  150. package/dist/cdn/badge/snice-badge.min.js +1 -1
  151. package/dist/cdn/banner/snice-banner.js +1 -1
  152. package/dist/cdn/banner/snice-banner.min.js +1 -1
  153. package/dist/cdn/book/README.md +27 -0
  154. package/dist/cdn/book/snice-book.js +353 -0
  155. package/dist/cdn/book/snice-book.js.map +1 -0
  156. package/dist/cdn/book/snice-book.min.js +13 -0
  157. package/dist/cdn/book/snice-book.min.js.map +1 -0
  158. package/dist/cdn/breadcrumbs/snice-breadcrumbs.js +1 -1
  159. package/dist/cdn/breadcrumbs/snice-breadcrumbs.min.js +1 -1
  160. package/dist/cdn/button/snice-button.js +1 -1
  161. package/dist/cdn/button/snice-button.min.js +1 -1
  162. package/dist/cdn/calendar/snice-calendar.js +1 -1
  163. package/dist/cdn/calendar/snice-calendar.min.js +1 -1
  164. package/dist/cdn/camera/snice-camera.js +1 -1
  165. package/dist/cdn/camera/snice-camera.min.js +1 -1
  166. package/dist/cdn/camera-annotate/snice-camera-annotate.js +1 -1
  167. package/dist/cdn/camera-annotate/snice-camera-annotate.min.js +1 -1
  168. package/dist/cdn/candlestick/snice-candlestick.js +1 -1
  169. package/dist/cdn/candlestick/snice-candlestick.min.js +1 -1
  170. package/dist/cdn/card/snice-card.js +1 -1
  171. package/dist/cdn/card/snice-card.min.js +1 -1
  172. package/dist/cdn/carousel/snice-carousel.js +1 -1
  173. package/dist/cdn/carousel/snice-carousel.min.js +1 -1
  174. package/dist/cdn/chart/snice-chart.js +1 -1
  175. package/dist/cdn/chart/snice-chart.min.js +1 -1
  176. package/dist/cdn/chat/snice-chat.js +1 -1
  177. package/dist/cdn/chat/snice-chat.min.js +1 -1
  178. package/dist/cdn/checkbox/snice-checkbox.js +1 -1
  179. package/dist/cdn/checkbox/snice-checkbox.min.js +1 -1
  180. package/dist/cdn/chip/snice-chip.js +1 -1
  181. package/dist/cdn/chip/snice-chip.min.js +1 -1
  182. package/dist/cdn/code-block/snice-code-block.js +1 -1
  183. package/dist/cdn/code-block/snice-code-block.min.js +1 -1
  184. package/dist/cdn/color-display/snice-color-display.js +1 -1
  185. package/dist/cdn/color-display/snice-color-display.min.js +1 -1
  186. package/dist/cdn/color-picker/snice-color-picker.js +1 -1
  187. package/dist/cdn/color-picker/snice-color-picker.min.js +1 -1
  188. package/dist/cdn/command-palette/snice-command-palette.js +1 -1
  189. package/dist/cdn/command-palette/snice-command-palette.min.js +1 -1
  190. package/dist/cdn/comments/README.md +27 -0
  191. package/dist/cdn/comments/snice-comments.js +544 -0
  192. package/dist/cdn/comments/snice-comments.js.map +1 -0
  193. package/dist/cdn/comments/snice-comments.min.js +100 -0
  194. package/dist/cdn/comments/snice-comments.min.js.map +1 -0
  195. package/dist/cdn/countdown/README.md +27 -0
  196. package/dist/cdn/countdown/snice-countdown.js +235 -0
  197. package/dist/cdn/countdown/snice-countdown.js.map +1 -0
  198. package/dist/cdn/countdown/snice-countdown.min.js +14 -0
  199. package/dist/cdn/countdown/snice-countdown.min.js.map +1 -0
  200. package/dist/cdn/cropper/README.md +27 -0
  201. package/dist/cdn/cropper/snice-cropper.js +352 -0
  202. package/dist/cdn/cropper/snice-cropper.js.map +1 -0
  203. package/dist/cdn/cropper/snice-cropper.min.js +25 -0
  204. package/dist/cdn/cropper/snice-cropper.min.js.map +1 -0
  205. package/dist/cdn/date-picker/snice-date-picker.js +1 -1
  206. package/dist/cdn/date-picker/snice-date-picker.min.js +1 -1
  207. package/dist/cdn/diff/README.md +27 -0
  208. package/dist/cdn/diff/snice-diff.js +441 -0
  209. package/dist/cdn/diff/snice-diff.js.map +1 -0
  210. package/dist/cdn/diff/snice-diff.min.js +54 -0
  211. package/dist/cdn/diff/snice-diff.min.js.map +1 -0
  212. package/dist/cdn/divider/snice-divider.js +1 -1
  213. package/dist/cdn/divider/snice-divider.min.js +1 -1
  214. package/dist/cdn/doc/snice-doc.js +1 -1
  215. package/dist/cdn/doc/snice-doc.min.js +1 -1
  216. package/dist/cdn/draw/snice-draw.js +1 -1
  217. package/dist/cdn/draw/snice-draw.min.js +1 -1
  218. package/dist/cdn/drawer/snice-drawer.js +1 -1
  219. package/dist/cdn/drawer/snice-drawer.min.js +1 -1
  220. package/dist/cdn/empty-state/snice-empty-state.js +1 -1
  221. package/dist/cdn/empty-state/snice-empty-state.min.js +1 -1
  222. package/dist/cdn/file-gallery/snice-file-gallery.js +1 -1
  223. package/dist/cdn/file-gallery/snice-file-gallery.min.js +1 -1
  224. package/dist/cdn/file-upload/snice-file-upload.js +1 -1
  225. package/dist/cdn/file-upload/snice-file-upload.min.js +1 -1
  226. package/dist/cdn/flip-card/README.md +27 -0
  227. package/dist/cdn/flip-card/snice-flip-card.js +183 -0
  228. package/dist/cdn/flip-card/snice-flip-card.js.map +1 -0
  229. package/dist/cdn/flip-card/snice-flip-card.min.js +22 -0
  230. package/dist/cdn/flip-card/snice-flip-card.min.js.map +1 -0
  231. package/dist/cdn/flow/README.md +27 -0
  232. package/dist/cdn/flow/snice-flow.js +822 -0
  233. package/dist/cdn/flow/snice-flow.js.map +1 -0
  234. package/dist/cdn/flow/snice-flow.min.js +17 -0
  235. package/dist/cdn/flow/snice-flow.min.js.map +1 -0
  236. package/dist/cdn/funnel/snice-funnel.js +1 -1
  237. package/dist/cdn/funnel/snice-funnel.min.js +1 -1
  238. package/dist/cdn/gantt/README.md +27 -0
  239. package/dist/cdn/gantt/snice-gantt.js +436 -0
  240. package/dist/cdn/gantt/snice-gantt.js.map +1 -0
  241. package/dist/cdn/gantt/snice-gantt.min.js +60 -0
  242. package/dist/cdn/gantt/snice-gantt.min.js.map +1 -0
  243. package/dist/cdn/gauge/snice-gauge.js +1 -1
  244. package/dist/cdn/gauge/snice-gauge.min.js +1 -1
  245. package/dist/cdn/heatmap/snice-heatmap.js +1 -1
  246. package/dist/cdn/heatmap/snice-heatmap.min.js +1 -1
  247. package/dist/cdn/image/snice-image.js +1 -1
  248. package/dist/cdn/image/snice-image.min.js +1 -1
  249. package/dist/cdn/input/snice-input.js +1 -1
  250. package/dist/cdn/input/snice-input.min.js +1 -1
  251. package/dist/cdn/kanban/snice-kanban.js +1 -1
  252. package/dist/cdn/kanban/snice-kanban.min.js +1 -1
  253. package/dist/cdn/kpi/snice-kpi.js +1 -1
  254. package/dist/cdn/kpi/snice-kpi.min.js +1 -1
  255. package/dist/cdn/layout/snice-layout.js +1 -1
  256. package/dist/cdn/layout/snice-layout.min.js +1 -1
  257. package/dist/cdn/link/snice-link.js +1 -1
  258. package/dist/cdn/link/snice-link.min.js +1 -1
  259. package/dist/cdn/link-preview/snice-link-preview.js +1 -1
  260. package/dist/cdn/link-preview/snice-link-preview.min.js +1 -1
  261. package/dist/cdn/list/snice-list.js +1 -1
  262. package/dist/cdn/list/snice-list.min.js +1 -1
  263. package/dist/cdn/location/snice-location.js +1 -1
  264. package/dist/cdn/location/snice-location.min.js +1 -1
  265. package/dist/cdn/login/snice-login.js +1 -1
  266. package/dist/cdn/login/snice-login.min.js +1 -1
  267. package/dist/cdn/map/README.md +27 -0
  268. package/dist/cdn/map/snice-map.js +415 -0
  269. package/dist/cdn/map/snice-map.js.map +1 -0
  270. package/dist/cdn/map/snice-map.min.js +52 -0
  271. package/dist/cdn/map/snice-map.min.js.map +1 -0
  272. package/dist/cdn/markdown/README.md +27 -0
  273. package/dist/cdn/markdown/snice-markdown.js +317 -0
  274. package/dist/cdn/markdown/snice-markdown.js.map +1 -0
  275. package/dist/cdn/markdown/snice-markdown.min.js +11 -0
  276. package/dist/cdn/markdown/snice-markdown.min.js.map +1 -0
  277. package/dist/cdn/masonry/snice-masonry.js +1 -1
  278. package/dist/cdn/masonry/snice-masonry.min.js +1 -1
  279. package/dist/cdn/menu/snice-menu.js +1 -1
  280. package/dist/cdn/menu/snice-menu.min.js +1 -1
  281. package/dist/cdn/modal/snice-modal.js +1 -1
  282. package/dist/cdn/modal/snice-modal.min.js +1 -1
  283. package/dist/cdn/music-player/snice-music-player.js +1 -1
  284. package/dist/cdn/music-player/snice-music-player.min.js +1 -1
  285. package/dist/cdn/nav/snice-nav.js +1 -1
  286. package/dist/cdn/nav/snice-nav.min.js +1 -1
  287. package/dist/cdn/network-graph/snice-network-graph.js +1 -1
  288. package/dist/cdn/network-graph/snice-network-graph.min.js +1 -1
  289. package/dist/cdn/notification-center/README.md +27 -0
  290. package/dist/cdn/notification-center/snice-notification-center.js +204 -0
  291. package/dist/cdn/notification-center/snice-notification-center.js.map +1 -0
  292. package/dist/cdn/notification-center/snice-notification-center.min.js +33 -0
  293. package/dist/cdn/notification-center/snice-notification-center.min.js.map +1 -0
  294. package/dist/cdn/org-chart/README.md +27 -0
  295. package/dist/cdn/org-chart/snice-org-chart.js +294 -0
  296. package/dist/cdn/org-chart/snice-org-chart.js.map +1 -0
  297. package/dist/cdn/org-chart/snice-org-chart.min.js +32 -0
  298. package/dist/cdn/org-chart/snice-org-chart.min.js.map +1 -0
  299. package/dist/cdn/pagination/snice-pagination.js +1 -1
  300. package/dist/cdn/pagination/snice-pagination.min.js +1 -1
  301. package/dist/cdn/paint/snice-paint.js +1 -1
  302. package/dist/cdn/paint/snice-paint.min.js +1 -1
  303. package/dist/cdn/pdf-viewer/README.md +27 -0
  304. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js +594 -0
  305. package/dist/cdn/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  306. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js +88 -0
  307. package/dist/cdn/pdf-viewer/snice-pdf-viewer.min.js.map +1 -0
  308. package/dist/cdn/podcast-player/README.md +27 -0
  309. package/dist/cdn/podcast-player/snice-podcast-player.js +835 -0
  310. package/dist/cdn/podcast-player/snice-podcast-player.js.map +1 -0
  311. package/dist/cdn/podcast-player/snice-podcast-player.min.js +209 -0
  312. package/dist/cdn/podcast-player/snice-podcast-player.min.js.map +1 -0
  313. package/dist/cdn/pricing-table/README.md +27 -0
  314. package/dist/cdn/pricing-table/snice-pricing-table.js +491 -0
  315. package/dist/cdn/pricing-table/snice-pricing-table.js.map +1 -0
  316. package/dist/cdn/pricing-table/snice-pricing-table.min.js +141 -0
  317. package/dist/cdn/pricing-table/snice-pricing-table.min.js.map +1 -0
  318. package/dist/cdn/progress/snice-progress.js +1 -1
  319. package/dist/cdn/progress/snice-progress.min.js +1 -1
  320. package/dist/cdn/qr-code/snice-qr-code.js +1 -1
  321. package/dist/cdn/qr-code/snice-qr-code.min.js +1 -1
  322. package/dist/cdn/qr-reader/snice-qr-reader.js +1 -1
  323. package/dist/cdn/qr-reader/snice-qr-reader.min.js +1 -1
  324. package/dist/cdn/radio/snice-radio.js +1 -1
  325. package/dist/cdn/radio/snice-radio.min.js +1 -1
  326. package/dist/cdn/rating/README.md +27 -0
  327. package/dist/cdn/rating/snice-rating.js +210 -0
  328. package/dist/cdn/rating/snice-rating.js.map +1 -0
  329. package/dist/cdn/rating/snice-rating.min.js +25 -0
  330. package/dist/cdn/rating/snice-rating.min.js.map +1 -0
  331. package/dist/cdn/recipe/README.md +27 -0
  332. package/dist/cdn/recipe/snice-recipe.js +619 -0
  333. package/dist/cdn/recipe/snice-recipe.js.map +1 -0
  334. package/dist/cdn/recipe/snice-recipe.min.js +185 -0
  335. package/dist/cdn/recipe/snice-recipe.min.js.map +1 -0
  336. package/dist/cdn/runtime/snice-runtime.esm.js +3 -3
  337. package/dist/cdn/runtime/snice-runtime.esm.js.map +1 -1
  338. package/dist/cdn/runtime/snice-runtime.esm.min.js +3 -3
  339. package/dist/cdn/runtime/snice-runtime.esm.min.js.map +1 -1
  340. package/dist/cdn/runtime/snice-runtime.js +3 -3
  341. package/dist/cdn/runtime/snice-runtime.js.map +1 -1
  342. package/dist/cdn/runtime/snice-runtime.min.js +3 -3
  343. package/dist/cdn/runtime/snice-runtime.min.js.map +1 -1
  344. package/dist/cdn/sankey/snice-sankey.js +1 -1
  345. package/dist/cdn/sankey/snice-sankey.min.js +1 -1
  346. package/dist/cdn/select/snice-select.js +1 -1
  347. package/dist/cdn/select/snice-select.min.js +1 -1
  348. package/dist/cdn/skeleton/snice-skeleton.js +1 -1
  349. package/dist/cdn/skeleton/snice-skeleton.min.js +1 -1
  350. package/dist/cdn/slider/snice-slider.js +1 -1
  351. package/dist/cdn/slider/snice-slider.min.js +1 -1
  352. package/dist/cdn/sortable/README.md +27 -0
  353. package/dist/cdn/sortable/snice-sortable.js +254 -0
  354. package/dist/cdn/sortable/snice-sortable.js.map +1 -0
  355. package/dist/cdn/sortable/snice-sortable.min.js +12 -0
  356. package/dist/cdn/sortable/snice-sortable.min.js.map +1 -0
  357. package/dist/cdn/sparkline/snice-sparkline.js +1 -1
  358. package/dist/cdn/sparkline/snice-sparkline.min.js +1 -1
  359. package/dist/cdn/spinner/snice-spinner.js +1 -1
  360. package/dist/cdn/spinner/snice-spinner.min.js +1 -1
  361. package/dist/cdn/split-pane/snice-split-pane.js +1 -1
  362. package/dist/cdn/split-pane/snice-split-pane.min.js +1 -1
  363. package/dist/cdn/spotlight/README.md +27 -0
  364. package/dist/cdn/spotlight/snice-spotlight.js +397 -0
  365. package/dist/cdn/spotlight/snice-spotlight.js.map +1 -0
  366. package/dist/cdn/spotlight/snice-spotlight.min.js +8 -0
  367. package/dist/cdn/spotlight/snice-spotlight.min.js.map +1 -0
  368. package/dist/cdn/spreadsheet/README.md +27 -0
  369. package/dist/cdn/spreadsheet/snice-spreadsheet.js +1171 -0
  370. package/dist/cdn/spreadsheet/snice-spreadsheet.js.map +1 -0
  371. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js +30 -0
  372. package/dist/cdn/spreadsheet/snice-spreadsheet.min.js.map +1 -0
  373. package/dist/cdn/stepper/snice-stepper.js +1 -1
  374. package/dist/cdn/stepper/snice-stepper.min.js +1 -1
  375. package/dist/cdn/switch/snice-switch.js +1 -1
  376. package/dist/cdn/switch/snice-switch.min.js +1 -1
  377. package/dist/cdn/table/snice-table.js +1 -1
  378. package/dist/cdn/table/snice-table.min.js +1 -1
  379. package/dist/cdn/tabs/snice-tabs.js +1 -1
  380. package/dist/cdn/tabs/snice-tabs.min.js +1 -1
  381. package/dist/cdn/tag-input/README.md +27 -0
  382. package/dist/cdn/tag-input/snice-tag-input.js +387 -0
  383. package/dist/cdn/tag-input/snice-tag-input.js.map +1 -0
  384. package/dist/cdn/tag-input/snice-tag-input.min.js +65 -0
  385. package/dist/cdn/tag-input/snice-tag-input.min.js.map +1 -0
  386. package/dist/cdn/terminal/snice-terminal.js +1 -1
  387. package/dist/cdn/terminal/snice-terminal.min.js +1 -1
  388. package/dist/cdn/testimonial/README.md +27 -0
  389. package/dist/cdn/testimonial/snice-testimonial.js +187 -0
  390. package/dist/cdn/testimonial/snice-testimonial.js.map +1 -0
  391. package/dist/cdn/testimonial/snice-testimonial.min.js +21 -0
  392. package/dist/cdn/testimonial/snice-testimonial.min.js.map +1 -0
  393. package/dist/cdn/textarea/snice-textarea.js +1 -1
  394. package/dist/cdn/textarea/snice-textarea.min.js +1 -1
  395. package/dist/cdn/time-range-picker/snice-time-range-picker.js +1 -1
  396. package/dist/cdn/time-range-picker/snice-time-range-picker.min.js +1 -1
  397. package/dist/cdn/timeline/snice-timeline.js +1 -1
  398. package/dist/cdn/timeline/snice-timeline.min.js +1 -1
  399. package/dist/cdn/timer/snice-timer.js +1 -1
  400. package/dist/cdn/timer/snice-timer.min.js +1 -1
  401. package/dist/cdn/toast/snice-toast.js +1 -1
  402. package/dist/cdn/toast/snice-toast.min.js +1 -1
  403. package/dist/cdn/tooltip/snice-tooltip.js +1 -1
  404. package/dist/cdn/tooltip/snice-tooltip.min.js +1 -1
  405. package/dist/cdn/tree/snice-tree.js +1 -1
  406. package/dist/cdn/tree/snice-tree.min.js +1 -1
  407. package/dist/cdn/treemap/snice-treemap.js +1 -1
  408. package/dist/cdn/treemap/snice-treemap.min.js +1 -1
  409. package/dist/cdn/video-player/README.md +27 -0
  410. package/dist/cdn/video-player/snice-video-player.js +721 -0
  411. package/dist/cdn/video-player/snice-video-player.js.map +1 -0
  412. package/dist/cdn/video-player/snice-video-player.min.js +153 -0
  413. package/dist/cdn/video-player/snice-video-player.min.js.map +1 -0
  414. package/dist/cdn/virtual-scroller/snice-virtual-scroller.js +1 -1
  415. package/dist/cdn/virtual-scroller/snice-virtual-scroller.min.js +1 -1
  416. package/dist/cdn/waterfall/README.md +27 -0
  417. package/dist/cdn/waterfall/snice-waterfall.js +292 -0
  418. package/dist/cdn/waterfall/snice-waterfall.js.map +1 -0
  419. package/dist/cdn/waterfall/snice-waterfall.min.js +12 -0
  420. package/dist/cdn/waterfall/snice-waterfall.min.js.map +1 -0
  421. package/dist/cdn/weather/README.md +27 -0
  422. package/dist/cdn/weather/snice-weather.js +194 -0
  423. package/dist/cdn/weather/snice-weather.js.map +1 -0
  424. package/dist/cdn/weather/snice-weather.min.js +42 -0
  425. package/dist/cdn/weather/snice-weather.min.js.map +1 -0
  426. package/dist/components/app-tiles/snice-app-tiles.d.ts +36 -0
  427. package/dist/components/app-tiles/snice-app-tiles.js +265 -0
  428. package/dist/components/app-tiles/snice-app-tiles.js.map +1 -0
  429. package/dist/components/app-tiles/snice-app-tiles.types.d.ts +22 -0
  430. package/dist/components/book/snice-book.d.ts +46 -0
  431. package/dist/components/book/snice-book.js +285 -0
  432. package/dist/components/book/snice-book.js.map +1 -0
  433. package/dist/components/book/snice-book.types.d.ts +21 -0
  434. package/dist/components/comments/snice-comments.d.ts +62 -0
  435. package/dist/components/comments/snice-comments.js +476 -0
  436. package/dist/components/comments/snice-comments.js.map +1 -0
  437. package/dist/components/comments/snice-comments.types.d.ts +64 -0
  438. package/dist/components/countdown/snice-countdown.d.ts +21 -0
  439. package/dist/components/countdown/snice-countdown.js +168 -0
  440. package/dist/components/countdown/snice-countdown.js.map +1 -0
  441. package/dist/components/countdown/snice-countdown.types.d.ts +18 -0
  442. package/dist/components/cropper/snice-cropper.d.ts +32 -0
  443. package/dist/components/cropper/snice-cropper.js +285 -0
  444. package/dist/components/cropper/snice-cropper.js.map +1 -0
  445. package/dist/components/cropper/snice-cropper.types.d.ts +26 -0
  446. package/dist/components/diff/snice-diff.d.ts +32 -0
  447. package/dist/components/diff/snice-diff.js +374 -0
  448. package/dist/components/diff/snice-diff.js.map +1 -0
  449. package/dist/components/diff/snice-diff.types.d.ts +26 -0
  450. package/dist/components/flip-card/snice-flip-card.d.ts +15 -0
  451. package/dist/components/flip-card/snice-flip-card.js +116 -0
  452. package/dist/components/flip-card/snice-flip-card.js.map +1 -0
  453. package/dist/components/flip-card/snice-flip-card.types.d.ts +16 -0
  454. package/dist/components/flow/snice-flow.d.ts +91 -0
  455. package/dist/components/flow/snice-flow.js +755 -0
  456. package/dist/components/flow/snice-flow.js.map +1 -0
  457. package/dist/components/flow/snice-flow.types.d.ts +64 -0
  458. package/dist/components/gantt/snice-gantt.d.ts +34 -0
  459. package/dist/components/gantt/snice-gantt.js +369 -0
  460. package/dist/components/gantt/snice-gantt.js.map +1 -0
  461. package/dist/components/gantt/snice-gantt.types.d.ts +37 -0
  462. package/dist/components/map/snice-map.d.ts +44 -0
  463. package/dist/components/map/snice-map.js +348 -0
  464. package/dist/components/map/snice-map.js.map +1 -0
  465. package/dist/components/map/snice-map.types.d.ts +41 -0
  466. package/dist/components/markdown/snice-markdown.d.ts +24 -0
  467. package/dist/components/markdown/snice-markdown.js +250 -0
  468. package/dist/components/markdown/snice-markdown.js.map +1 -0
  469. package/dist/components/markdown/snice-markdown.types.d.ts +16 -0
  470. package/dist/components/notification-center/snice-notification-center.d.ts +18 -0
  471. package/dist/components/notification-center/snice-notification-center.js +137 -0
  472. package/dist/components/notification-center/snice-notification-center.js.map +1 -0
  473. package/dist/components/notification-center/snice-notification-center.types.d.ts +24 -0
  474. package/dist/components/org-chart/snice-org-chart.d.ts +28 -0
  475. package/dist/components/org-chart/snice-org-chart.js +227 -0
  476. package/dist/components/org-chart/snice-org-chart.js.map +1 -0
  477. package/dist/components/org-chart/snice-org-chart.types.d.ts +28 -0
  478. package/dist/components/pdf-viewer/pdf.min.mjs +21 -0
  479. package/dist/components/pdf-viewer/pdf.worker.min.mjs +21 -0
  480. package/dist/components/pdf-viewer/snice-pdf-viewer.d.ts +59 -0
  481. package/dist/components/pdf-viewer/snice-pdf-viewer.js +527 -0
  482. package/dist/components/pdf-viewer/snice-pdf-viewer.js.map +1 -0
  483. package/dist/components/pdf-viewer/snice-pdf-viewer.types.d.ts +25 -0
  484. package/dist/components/podcast-player/snice-podcast-player.d.ts +72 -0
  485. package/dist/components/podcast-player/snice-podcast-player.js +768 -0
  486. package/dist/components/podcast-player/snice-podcast-player.js.map +1 -0
  487. package/dist/components/podcast-player/snice-podcast-player.types.d.ts +79 -0
  488. package/dist/components/pricing-table/snice-pricing-table.d.ts +51 -0
  489. package/dist/components/pricing-table/snice-pricing-table.js +422 -0
  490. package/dist/components/pricing-table/snice-pricing-table.js.map +1 -0
  491. package/dist/components/pricing-table/snice-pricing-table.types.d.ts +49 -0
  492. package/dist/components/rating/snice-rating.d.ts +15 -0
  493. package/dist/components/rating/snice-rating.js +143 -0
  494. package/dist/components/rating/snice-rating.js.map +1 -0
  495. package/dist/components/rating/snice-rating.types.d.ts +15 -0
  496. package/dist/components/recipe/snice-recipe.d.ts +53 -0
  497. package/dist/components/recipe/snice-recipe.js +552 -0
  498. package/dist/components/recipe/snice-recipe.js.map +1 -0
  499. package/dist/components/recipe/snice-recipe.types.d.ts +56 -0
  500. package/dist/components/sortable/snice-sortable.d.ts +24 -0
  501. package/dist/components/sortable/snice-sortable.js +187 -0
  502. package/dist/components/sortable/snice-sortable.js.map +1 -0
  503. package/dist/components/sortable/snice-sortable.types.d.ts +20 -0
  504. package/dist/components/spotlight/snice-spotlight.d.ts +42 -0
  505. package/dist/components/spotlight/snice-spotlight.js +330 -0
  506. package/dist/components/spotlight/snice-spotlight.js.map +1 -0
  507. package/dist/components/spotlight/snice-spotlight.types.d.ts +26 -0
  508. package/dist/components/spreadsheet/snice-spreadsheet.d.ts +102 -0
  509. package/dist/components/spreadsheet/snice-spreadsheet.js +1104 -0
  510. package/dist/components/spreadsheet/snice-spreadsheet.js.map +1 -0
  511. package/dist/components/spreadsheet/snice-spreadsheet.types.d.ts +54 -0
  512. package/dist/components/tag-input/snice-tag-input.d.ts +40 -0
  513. package/dist/components/tag-input/snice-tag-input.js +320 -0
  514. package/dist/components/tag-input/snice-tag-input.js.map +1 -0
  515. package/dist/components/tag-input/snice-tag-input.types.d.ts +29 -0
  516. package/dist/components/testimonial/snice-testimonial.d.ts +15 -0
  517. package/dist/components/testimonial/snice-testimonial.js +120 -0
  518. package/dist/components/testimonial/snice-testimonial.js.map +1 -0
  519. package/dist/components/testimonial/snice-testimonial.types.d.ts +10 -0
  520. package/dist/components/video-player/snice-video-player.d.ts +78 -0
  521. package/dist/components/video-player/snice-video-player.js +654 -0
  522. package/dist/components/video-player/snice-video-player.js.map +1 -0
  523. package/dist/components/video-player/snice-video-player.types.d.ts +47 -0
  524. package/dist/components/waterfall/snice-waterfall.d.ts +30 -0
  525. package/dist/components/waterfall/snice-waterfall.js +225 -0
  526. package/dist/components/waterfall/snice-waterfall.js.map +1 -0
  527. package/dist/components/waterfall/snice-waterfall.types.d.ts +23 -0
  528. package/dist/components/weather/snice-weather.d.ts +10 -0
  529. package/dist/components/weather/snice-weather.js +127 -0
  530. package/dist/components/weather/snice-weather.js.map +1 -0
  531. package/dist/components/weather/snice-weather.types.d.ts +22 -0
  532. package/dist/index.cjs +1 -1
  533. package/dist/index.esm.js +1 -1
  534. package/dist/index.iife.js +1 -1
  535. package/dist/symbols.cjs +1 -1
  536. package/dist/symbols.esm.js +1 -1
  537. package/dist/transitions.cjs +1 -1
  538. package/dist/transitions.esm.js +1 -1
  539. package/docs/ai/DEVELOPMENT.md +1 -1
  540. package/docs/ai/api.md +6 -3
  541. package/docs/ai/components/accordion.md +0 -34
  542. package/docs/ai/components/app-tiles.md +77 -0
  543. package/docs/ai/components/audio-recorder.md +2 -0
  544. package/docs/ai/components/badge.md +7 -0
  545. package/docs/ai/components/book.md +78 -0
  546. package/docs/ai/components/button.md +5 -0
  547. package/docs/ai/components/chart.md +0 -24
  548. package/docs/ai/components/chat.md +7 -95
  549. package/docs/ai/components/code-block.md +3 -82
  550. package/docs/ai/components/color-display.md +3 -3
  551. package/docs/ai/components/color-picker.md +4 -4
  552. package/docs/ai/components/comments.md +75 -0
  553. package/docs/ai/components/countdown.md +54 -0
  554. package/docs/ai/components/cropper.md +57 -0
  555. package/docs/ai/components/date-picker.md +15 -9
  556. package/docs/ai/components/diff.md +66 -0
  557. package/docs/ai/components/divider.md +1 -1
  558. package/docs/ai/components/draw.md +5 -5
  559. package/docs/ai/components/drawer.md +5 -5
  560. package/docs/ai/components/empty-state.md +2 -2
  561. package/docs/ai/components/file-gallery.md +16 -87
  562. package/docs/ai/components/file-upload.md +6 -6
  563. package/docs/ai/components/flip-card.md +52 -0
  564. package/docs/ai/components/flow.md +104 -0
  565. package/docs/ai/components/funnel.md +3 -3
  566. package/docs/ai/components/gantt.md +63 -0
  567. package/docs/ai/components/gauge.md +1 -1
  568. package/docs/ai/components/heatmap.md +5 -5
  569. package/docs/ai/components/input.md +20 -18
  570. package/docs/ai/components/kanban.md +2 -2
  571. package/docs/ai/components/kpi.md +4 -53
  572. package/docs/ai/components/layout.md +10 -235
  573. package/docs/ai/components/link-preview.md +20 -29
  574. package/docs/ai/components/link.md +27 -47
  575. package/docs/ai/components/list.md +51 -31
  576. package/docs/ai/components/location.md +15 -27
  577. package/docs/ai/components/login.md +43 -94
  578. package/docs/ai/components/map.md +72 -0
  579. package/docs/ai/components/markdown.md +63 -0
  580. package/docs/ai/components/masonry.md +10 -6
  581. package/docs/ai/components/menu.md +40 -72
  582. package/docs/ai/components/modal.md +25 -42
  583. package/docs/ai/components/music-player.md +37 -89
  584. package/docs/ai/components/nav.md +25 -39
  585. package/docs/ai/components/network-graph.md +39 -43
  586. package/docs/ai/components/notification-center.md +79 -0
  587. package/docs/ai/components/org-chart.md +62 -0
  588. package/docs/ai/components/pagination.md +16 -18
  589. package/docs/ai/components/pdf-viewer.md +57 -0
  590. package/docs/ai/components/podcast-player.md +94 -0
  591. package/docs/ai/components/pricing-table.md +87 -0
  592. package/docs/ai/components/progress.md +23 -39
  593. package/docs/ai/components/qr-code.md +37 -84
  594. package/docs/ai/components/qr-reader.md +51 -61
  595. package/docs/ai/components/radio.md +27 -39
  596. package/docs/ai/components/rating.md +56 -0
  597. package/docs/ai/components/recipe.md +90 -0
  598. package/docs/ai/components/skeleton.md +0 -8
  599. package/docs/ai/components/slider.md +10 -50
  600. package/docs/ai/components/sortable.md +57 -0
  601. package/docs/ai/components/sparkline.md +26 -152
  602. package/docs/ai/components/spinner.md +0 -21
  603. package/docs/ai/components/split-pane.md +16 -38
  604. package/docs/ai/components/spotlight.md +61 -0
  605. package/docs/ai/components/spreadsheet.md +138 -0
  606. package/docs/ai/components/stepper.md +37 -183
  607. package/docs/ai/components/switch.md +28 -35
  608. package/docs/ai/components/table.md +43 -172
  609. package/docs/ai/components/tabs.md +31 -52
  610. package/docs/ai/components/tag-input.md +70 -0
  611. package/docs/ai/components/terminal.md +34 -116
  612. package/docs/ai/components/testimonial.md +56 -0
  613. package/docs/ai/components/textarea.md +11 -43
  614. package/docs/ai/components/theme.md +120 -0
  615. package/docs/ai/components/time-range-picker.md +17 -49
  616. package/docs/ai/components/timeline.md +7 -46
  617. package/docs/ai/components/timer.md +41 -37
  618. package/docs/ai/components/toast.md +19 -90
  619. package/docs/ai/components/tooltip.md +17 -104
  620. package/docs/ai/components/tree.md +38 -162
  621. package/docs/ai/components/treemap.md +23 -44
  622. package/docs/ai/components/video-player.md +91 -0
  623. package/docs/ai/components/virtual-scroller.md +23 -46
  624. package/docs/ai/components/waterfall.md +56 -0
  625. package/docs/ai/components/weather.md +78 -0
  626. package/docs/ai/decorators.md +25 -3
  627. package/docs/ai/patterns.md +17 -1
  628. package/docs/components/accordion.md +8 -6
  629. package/docs/components/alert.md +2 -0
  630. package/docs/components/app-tiles.md +162 -0
  631. package/docs/components/audio-recorder.md +6 -0
  632. package/docs/components/avatar.md +225 -0
  633. package/docs/components/badge.md +2 -0
  634. package/docs/components/banner.md +2 -0
  635. package/docs/components/book.md +184 -0
  636. package/docs/components/breadcrumbs.md +2 -0
  637. package/docs/components/button.md +15 -0
  638. package/docs/components/calendar.md +2 -0
  639. package/docs/components/camera-annotate.md +2 -0
  640. package/docs/components/camera.md +2 -0
  641. package/docs/components/candlestick.md +2 -0
  642. package/docs/components/card.md +2 -0
  643. package/docs/components/carousel.md +205 -36
  644. package/docs/components/chart.md +2 -0
  645. package/docs/components/chat.md +2 -0
  646. package/docs/components/checkbox.md +2 -0
  647. package/docs/components/chip.md +2 -0
  648. package/docs/components/code-block.md +2 -0
  649. package/docs/components/color-display.md +2 -0
  650. package/docs/components/color-picker.md +6 -4
  651. package/docs/components/command-palette.md +2 -0
  652. package/docs/components/comments.md +235 -0
  653. package/docs/components/countdown.md +121 -0
  654. package/docs/components/cropper.md +152 -0
  655. package/docs/components/date-picker.md +201 -0
  656. package/docs/components/diff.md +177 -0
  657. package/docs/components/divider.md +132 -0
  658. package/docs/components/doc.md +2 -0
  659. package/docs/components/draw.md +2 -0
  660. package/docs/components/drawer.md +2 -0
  661. package/docs/components/empty-state.md +2 -0
  662. package/docs/components/file-gallery.md +2 -0
  663. package/docs/components/file-upload.md +2 -0
  664. package/docs/components/flip-card.md +169 -0
  665. package/docs/components/flow.md +208 -0
  666. package/docs/components/funnel.md +2 -0
  667. package/docs/components/gantt.md +187 -0
  668. package/docs/components/gauge.md +2 -0
  669. package/docs/components/heatmap.md +2 -0
  670. package/docs/components/image.md +2 -0
  671. package/docs/components/input.md +242 -0
  672. package/docs/components/kanban.md +2 -0
  673. package/docs/components/kpi.md +2 -0
  674. package/docs/components/layout.md +84 -0
  675. package/docs/components/link-preview.md +66 -92
  676. package/docs/components/link.md +73 -157
  677. package/docs/components/list.md +140 -44
  678. package/docs/components/location.md +96 -283
  679. package/docs/components/login.md +131 -498
  680. package/docs/components/map.md +203 -0
  681. package/docs/components/markdown.md +220 -0
  682. package/docs/components/masonry.md +57 -102
  683. package/docs/components/menu.md +87 -494
  684. package/docs/components/modal.md +83 -436
  685. package/docs/components/music-player.md +116 -221
  686. package/docs/components/nav.md +107 -170
  687. package/docs/components/network-graph.md +83 -111
  688. package/docs/components/notification-center.md +256 -0
  689. package/docs/components/org-chart.md +275 -0
  690. package/docs/components/pagination.md +75 -218
  691. package/docs/components/paint.md +108 -73
  692. package/docs/components/pdf-viewer.md +204 -0
  693. package/docs/components/podcast-player.md +277 -0
  694. package/docs/components/pricing-table.md +249 -0
  695. package/docs/components/progress.md +169 -0
  696. package/docs/components/qr-code.md +95 -378
  697. package/docs/components/qr-reader.md +83 -258
  698. package/docs/components/radio.md +151 -0
  699. package/docs/components/rating.md +154 -0
  700. package/docs/components/recipe.md +323 -0
  701. package/docs/components/sankey.md +84 -107
  702. package/docs/components/select.md +114 -485
  703. package/docs/components/skeleton.md +96 -0
  704. package/docs/components/slider.md +92 -235
  705. package/docs/components/sortable.md +267 -0
  706. package/docs/components/sparkline.md +76 -222
  707. package/docs/components/spinner.md +37 -18
  708. package/docs/components/split-pane.md +62 -226
  709. package/docs/components/spotlight.md +240 -0
  710. package/docs/components/spreadsheet.md +405 -0
  711. package/docs/components/stepper.md +72 -306
  712. package/docs/components/switch.md +69 -293
  713. package/docs/components/table.md +250 -0
  714. package/docs/components/tabs.md +92 -471
  715. package/docs/components/tag-input.md +257 -0
  716. package/docs/components/terminal.md +87 -391
  717. package/docs/components/testimonial.md +185 -0
  718. package/docs/components/textarea.md +96 -181
  719. package/docs/components/theme.md +216 -0
  720. package/docs/components/time-range-picker.md +99 -151
  721. package/docs/components/timeline.md +67 -115
  722. package/docs/components/timer.md +44 -86
  723. package/docs/components/toast.md +93 -432
  724. package/docs/components/tooltip.md +75 -419
  725. package/docs/components/tree.md +110 -436
  726. package/docs/components/treemap.md +86 -129
  727. package/docs/components/video-player.md +336 -0
  728. package/docs/components/virtual-scroller.md +86 -226
  729. package/docs/components/waterfall.md +217 -0
  730. package/docs/components/weather.md +239 -0
  731. package/package.json +1 -1
  732. package/docs/ai/components/popover.md +0 -70
  733. package/docs/components/popover.md +0 -333
@@ -1,18 +1,18 @@
1
- # Menu Components
1
+ [//]: # (AI: For a low-token version of this doc, use docs/ai/components/menu.md instead)
2
2
 
3
- The menu components provide dropdown menus with customizable triggers, placement options, and support for icons and keyboard shortcuts. A `<snice-menu>` container manages `<snice-menu-item>` elements and `<snice-menu-divider>` separators.
3
+ # Menu
4
+ `<snice-menu>`
4
5
 
5
- ## Table of Contents
6
- - [Basic Usage](#basic-usage)
7
- - [Components](#components)
8
- - [Properties](#properties)
9
- - [Methods](#methods)
10
- - [Events](#events)
11
- - [Slots](#slots)
12
- - [Examples](#examples)
6
+ A dropdown menu with composable items, dividers, icons, and keyboard shortcut hints.
13
7
 
14
8
  ## Basic Usage
15
9
 
10
+ ```typescript
11
+ import 'snice/components/menu/snice-menu';
12
+ import 'snice/components/menu/snice-menu-item';
13
+ import 'snice/components/menu/snice-menu-divider';
14
+ ```
15
+
16
16
  ```html
17
17
  <snice-menu>
18
18
  <button slot="trigger">Open Menu</button>
@@ -23,362 +23,137 @@ The menu components provide dropdown menus with customizable triggers, placement
23
23
  </snice-menu>
24
24
  ```
25
25
 
26
+ ## Importing
27
+
28
+ **ESM (bundler)**
26
29
  ```typescript
27
30
  import 'snice/components/menu/snice-menu';
28
31
  import 'snice/components/menu/snice-menu-item';
29
32
  import 'snice/components/menu/snice-menu-divider';
30
33
  ```
31
34
 
32
- ## Components
33
-
34
- ### `<snice-menu>`
35
- Container element that manages the menu panel and trigger behavior.
36
-
37
- ### `<snice-menu-item>`
38
- Individual menu item that can be selected.
39
-
40
- ### `<snice-menu-divider>`
41
- Visual separator between menu items.
42
-
43
- ## Properties
44
-
45
- ### Menu Container
46
-
47
- | Property | Type | Default | Description |
48
- |----------|------|---------|-------------|
49
- | `open` | `boolean` | `false` | Whether the menu is open |
50
- | `placement` | `'bottom-start' \| 'bottom-end' \| 'top-start' \| 'top-end' \| 'right-start' \| 'right-end' \| 'left-start' \| 'left-end'` | `'bottom-start'` | Menu panel placement relative to trigger |
51
- | `trigger` | `'click' \| 'hover' \| 'manual'` | `'click'` | How the menu is triggered |
52
- | `closeOnSelect` | `boolean` | `true` | Whether to close menu when item is selected |
53
- | `distance` | `number` | `4` | Distance (in pixels) from trigger to panel |
54
-
55
- ### Menu Item
56
-
57
- | Property | Type | Default | Description |
58
- |----------|------|---------|-------------|
59
- | `value` | `string` | `''` | Value associated with the menu item |
60
- | `disabled` | `boolean` | `false` | Disable interaction with the item |
61
- | `selected` | `boolean` | `false` | Whether the item is selected |
62
-
63
- ## Methods
64
-
65
- ### Menu Container Methods
66
-
67
- #### `openMenu(): void`
68
- Open the menu panel.
69
-
70
- ```typescript
71
- menu.openMenu();
72
- ```
73
-
74
- #### `closeMenu(): void`
75
- Close the menu panel.
76
-
77
- ```typescript
78
- menu.closeMenu();
79
- ```
80
-
81
- #### `toggleMenu(): void`
82
- Toggle the menu open/closed state.
83
-
84
- ```typescript
85
- menu.toggleMenu();
86
- ```
87
-
88
- ## Events
89
-
90
- ### Container Events
91
-
92
- #### `menu-open`
93
- Fired when the menu is opened.
94
-
95
- **Event Detail:**
96
- ```typescript
97
- {
98
- menu: SniceMenuElement;
99
- }
100
- ```
101
-
102
- **Usage:**
103
- ```typescript
104
- menu.addEventListener('menu-open', (e) => {
105
- console.log('Menu opened');
106
- });
107
- ```
108
-
109
- #### `menu-close`
110
- Fired when the menu is closed.
111
-
112
- **Event Detail:**
113
- ```typescript
114
- {
115
- menu: SniceMenuElement;
116
- }
117
- ```
118
-
119
- ### Item Events
120
-
121
- #### `menu-item-select`
122
- Fired when a menu item is selected.
123
-
124
- **Event Detail:**
125
- ```typescript
126
- {
127
- item: SniceMenuItemElement;
128
- value: string;
129
- }
130
- ```
131
-
132
- **Usage:**
133
- ```typescript
134
- menu.addEventListener('menu-item-select', (e) => {
135
- console.log('Selected item:', e.detail.value);
136
- });
137
- ```
138
-
139
- ## Slots
140
-
141
- ### Menu Slots
142
-
143
- #### `trigger` (named slot)
144
- Element that triggers the menu (required).
145
-
35
+ **CDN**
146
36
  ```html
147
- <snice-menu>
148
- <button slot="trigger">Click me</button>
149
- <!-- menu items -->
150
- </snice-menu>
151
- ```
152
-
153
- #### `image-left` (named slot)
154
- Image or icon to display before the trigger content.
155
-
156
- ```html
157
- <snice-menu>
158
- <img slot="image-left" src="avatar.jpg" alt="User">
159
- <span slot="trigger">User Menu</span>
160
- <!-- menu items -->
161
- </snice-menu>
162
- ```
163
-
164
- #### `image-right` (named slot)
165
- Image or icon to display after the trigger content.
166
-
167
- ```html
168
- <snice-menu>
169
- <span slot="trigger">Settings</span>
170
- <img slot="image-right" src="icon.svg" alt="">
171
- <!-- menu items -->
172
- </snice-menu>
173
- ```
174
-
175
- #### Default slot
176
- Menu items and dividers.
177
-
178
- ### Menu Item Slots
179
-
180
- #### `icon` (named slot)
181
- Icon displayed before the item label.
182
-
183
- ```html
184
- <snice-menu-item value="save">
185
- <span slot="icon">💾</span>
186
- Save
187
- </snice-menu-item>
188
- ```
189
-
190
- #### Default slot
191
- The item label/content.
192
-
193
- #### `shortcut` (named slot)
194
- Keyboard shortcut hint displayed after the label.
195
-
196
- ```html
197
- <snice-menu-item value="save">
198
- Save
199
- <span slot="shortcut">⌘S</span>
200
- </snice-menu-item>
37
+ <script src="snice-runtime.min.js"></script>
38
+ <script src="snice-menu.min.js"></script>
201
39
  ```
202
40
 
203
41
  ## Examples
204
42
 
205
- ### Basic Menu
206
-
207
- ```html
208
- <snice-menu>
209
- <button slot="trigger">File</button>
210
- <snice-menu-item value="new">New</snice-menu-item>
211
- <snice-menu-item value="open">Open</snice-menu-item>
212
- <snice-menu-item value="save">Save</snice-menu-item>
213
- <snice-menu-divider></snice-menu-divider>
214
- <snice-menu-item value="exit">Exit</snice-menu-item>
215
- </snice-menu>
216
- ```
43
+ ### Icons and Shortcuts
217
44
 
218
- ### Menu with Icons and Shortcuts
45
+ Use the `icon` and `shortcut` slots on menu items to add visual cues.
219
46
 
220
47
  ```html
221
48
  <snice-menu>
222
49
  <button slot="trigger">Edit</button>
223
-
224
50
  <snice-menu-item value="undo">
225
51
  <span slot="icon">↩️</span>
226
52
  Undo
227
53
  <span slot="shortcut">⌘Z</span>
228
54
  </snice-menu-item>
229
-
230
- <snice-menu-item value="redo">
231
- <span slot="icon">↪️</span>
232
- Redo
233
- <span slot="shortcut">⌘⇧Z</span>
234
- </snice-menu-item>
235
-
236
- <snice-menu-divider></snice-menu-divider>
237
-
238
55
  <snice-menu-item value="cut">
239
56
  <span slot="icon">✂️</span>
240
57
  Cut
241
58
  <span slot="shortcut">⌘X</span>
242
59
  </snice-menu-item>
243
-
244
60
  <snice-menu-item value="copy">
245
61
  <span slot="icon">📋</span>
246
62
  Copy
247
63
  <span slot="shortcut">⌘C</span>
248
64
  </snice-menu-item>
249
-
250
- <snice-menu-item value="paste">
251
- <span slot="icon">📄</span>
252
- Paste
253
- <span slot="shortcut">⌘V</span>
254
- </snice-menu-item>
255
65
  </snice-menu>
256
66
  ```
257
67
 
258
- ### Different Placements
68
+ ### Placement
69
+
70
+ Use the `placement` attribute to position the menu relative to its trigger.
259
71
 
260
72
  ```html
261
- <!-- Bottom start (default) -->
262
73
  <snice-menu placement="bottom-start">
263
74
  <button slot="trigger">Bottom Start</button>
264
75
  <snice-menu-item value="1">Option 1</snice-menu-item>
265
- <snice-menu-item value="2">Option 2</snice-menu-item>
266
76
  </snice-menu>
267
77
 
268
- <!-- Bottom end -->
269
78
  <snice-menu placement="bottom-end">
270
79
  <button slot="trigger">Bottom End</button>
271
80
  <snice-menu-item value="1">Option 1</snice-menu-item>
272
- <snice-menu-item value="2">Option 2</snice-menu-item>
273
- </snice-menu>
274
-
275
- <!-- Top start -->
276
- <snice-menu placement="top-start">
277
- <button slot="trigger">Top Start</button>
278
- <snice-menu-item value="1">Option 1</snice-menu-item>
279
- <snice-menu-item value="2">Option 2</snice-menu-item>
280
81
  </snice-menu>
281
82
 
282
- <!-- Right side -->
283
83
  <snice-menu placement="right-start">
284
84
  <button slot="trigger">Right</button>
285
85
  <snice-menu-item value="1">Option 1</snice-menu-item>
286
- <snice-menu-item value="2">Option 2</snice-menu-item>
287
86
  </snice-menu>
288
87
  ```
289
88
 
290
89
  ### Hover Trigger
291
90
 
91
+ Set `trigger="hover"` to open the menu on mouse hover.
92
+
292
93
  ```html
293
94
  <snice-menu trigger="hover">
294
95
  <button slot="trigger">Hover Me</button>
295
- <snice-menu-item value="quick1">Quick Action 1</snice-menu-item>
296
- <snice-menu-item value="quick2">Quick Action 2</snice-menu-item>
297
- <snice-menu-item value="quick3">Quick Action 3</snice-menu-item>
96
+ <snice-menu-item value="1">Quick Action 1</snice-menu-item>
97
+ <snice-menu-item value="2">Quick Action 2</snice-menu-item>
298
98
  </snice-menu>
299
99
  ```
300
100
 
301
101
  ### Manual Control
302
102
 
103
+ Set `trigger="manual"` and use methods to control the menu programmatically.
104
+
303
105
  ```html
304
- <snice-menu id="manual-menu" trigger="manual">
305
- <button slot="trigger">Manual Menu</button>
106
+ <snice-menu id="manualMenu" trigger="manual">
107
+ <button slot="trigger">Manual</button>
306
108
  <snice-menu-item value="1">Option 1</snice-menu-item>
307
- <snice-menu-item value="2">Option 2</snice-menu-item>
308
109
  </snice-menu>
309
110
 
310
- <button onclick="document.getElementById('manual-menu').openMenu()">
311
- Open Menu
312
- </button>
111
+ <button onclick="document.getElementById('manualMenu').openMenu()">Open</button>
313
112
  ```
314
113
 
315
114
  ### Disabled Items
316
115
 
116
+ Set the `disabled` attribute on individual menu items.
117
+
317
118
  ```html
318
119
  <snice-menu>
319
120
  <button slot="trigger">Actions</button>
320
121
  <snice-menu-item value="edit">Edit</snice-menu-item>
321
- <snice-menu-item value="delete" disabled>Delete (disabled)</snice-menu-item>
122
+ <snice-menu-item value="delete" disabled>Delete</snice-menu-item>
322
123
  <snice-menu-item value="share">Share</snice-menu-item>
323
124
  </snice-menu>
324
125
  ```
325
126
 
326
127
  ### Keep Open on Select
327
128
 
129
+ Set `close-on-select="false"` for multi-action menus.
130
+
328
131
  ```html
329
- <snice-menu id="multi-menu" close-on-select="false">
330
- <button slot="trigger">Multi-Select</button>
331
- <snice-menu-item value="option1">Option 1</snice-menu-item>
332
- <snice-menu-item value="option2">Option 2</snice-menu-item>
333
- <snice-menu-item value="option3">Option 3</snice-menu-item>
334
- <snice-menu-divider></snice-menu-divider>
335
- <snice-menu-item value="done">Done</snice-menu-item>
132
+ <snice-menu close-on-select="false">
133
+ <button slot="trigger">Filters</button>
134
+ <snice-menu-item value="active">Active</snice-menu-item>
135
+ <snice-menu-item value="pending">Pending</snice-menu-item>
136
+ <snice-menu-item value="archived">Archived</snice-menu-item>
336
137
  </snice-menu>
337
-
338
- <script type="module">
339
- const menu = document.getElementById('multi-menu');
340
- menu.addEventListener('menu-item-select', (e) => {
341
- if (e.detail.value === 'done') {
342
- menu.closeMenu();
343
- }
344
- });
345
- </script>
346
138
  ```
347
139
 
348
140
  ### User Profile Menu
349
141
 
142
+ Use `image-left` and `image-right` slots for avatar menus.
143
+
350
144
  ```html
351
145
  <snice-menu placement="bottom-end">
352
- <img slot="image-left"
353
- src="https://via.placeholder.com/32"
354
- alt="User avatar"
355
- style="width: 32px; height: 32px; border-radius: 50%;">
146
+ <img slot="image-left" src="avatar.jpg" alt="User" style="width:32px;height:32px;border-radius:50%">
356
147
  <span slot="trigger">John Doe</span>
357
-
358
148
  <snice-menu-item value="profile">
359
149
  <span slot="icon">👤</span>
360
- View Profile
150
+ Profile
361
151
  </snice-menu-item>
362
-
363
152
  <snice-menu-item value="settings">
364
153
  <span slot="icon">⚙️</span>
365
154
  Settings
366
155
  </snice-menu-item>
367
-
368
- <snice-menu-item value="billing">
369
- <span slot="icon">💳</span>
370
- Billing
371
- </snice-menu-item>
372
-
373
156
  <snice-menu-divider></snice-menu-divider>
374
-
375
- <snice-menu-item value="help">
376
- <span slot="icon">❓</span>
377
- Help & Support
378
- </snice-menu-item>
379
-
380
- <snice-menu-divider></snice-menu-divider>
381
-
382
157
  <snice-menu-item value="logout">
383
158
  <span slot="icon">🚪</span>
384
159
  Log Out
@@ -386,248 +161,66 @@ Keyboard shortcut hint displayed after the label.
386
161
  </snice-menu>
387
162
  ```
388
163
 
389
- ### Context Menu
390
-
391
- ```html
392
- <div id="content" style="padding: 2rem; border: 1px solid #ccc;">
393
- Right-click me for context menu
394
- </div>
395
-
396
- <snice-menu id="context-menu" trigger="manual">
397
- <div slot="trigger" style="display: none;"></div>
398
-
399
- <snice-menu-item value="copy">Copy</snice-menu-item>
400
- <snice-menu-item value="paste">Paste</snice-menu-item>
401
- <snice-menu-divider></snice-menu-divider>
402
- <snice-menu-item value="delete">Delete</snice-menu-item>
403
- </snice-menu>
404
-
405
- <script type="module">
406
- const content = document.getElementById('content');
407
- const menu = document.getElementById('context-menu');
408
-
409
- content.addEventListener('contextmenu', (e) => {
410
- e.preventDefault();
411
-
412
- // Position menu at cursor
413
- menu.style.position = 'fixed';
414
- menu.style.left = e.clientX + 'px';
415
- menu.style.top = e.clientY + 'px';
416
-
417
- menu.openMenu();
418
- });
419
-
420
- menu.addEventListener('menu-item-select', (e) => {
421
- console.log('Context action:', e.detail.value);
422
- });
423
- </script>
424
- ```
425
-
426
- ### With Event Handling
164
+ ### Event Handling
427
165
 
428
166
  ```typescript
429
- import type { SniceMenuElement } from 'snice/components/menu/snice-menu.types';
430
-
431
- const menu = document.querySelector<SniceMenuElement>('snice-menu');
432
-
433
- menu.addEventListener('menu-open', () => {
434
- console.log('Menu opened');
435
- // Load dynamic content, track analytics, etc.
436
- });
437
-
438
- menu.addEventListener('menu-close', () => {
439
- console.log('Menu closed');
440
- });
167
+ const menu = document.querySelector('snice-menu');
441
168
 
442
169
  menu.addEventListener('menu-item-select', (e) => {
443
170
  console.log('Selected:', e.detail.value);
444
-
445
- switch (e.detail.value) {
446
- case 'save':
447
- saveDocument();
448
- break;
449
- case 'export':
450
- exportData();
451
- break;
452
- case 'delete':
453
- confirmDelete();
454
- break;
455
- }
456
171
  });
457
- ```
458
172
 
459
- ### Dynamic Menu Items
460
-
461
- ```html
462
- <snice-menu id="dynamic-menu">
463
- <button slot="trigger">Recent Files</button>
464
- <!-- Items populated dynamically -->
465
- </snice-menu>
466
-
467
- <script type="module">
468
- import 'snice/components/menu/snice-menu';
469
- import 'snice/components/menu/snice-menu-item';
470
-
471
- const menu = document.getElementById('dynamic-menu');
472
-
473
- // Load recent files
474
- const recentFiles = await fetch('/api/recent-files').then(r => r.json());
475
-
476
- recentFiles.forEach((file, index) => {
477
- const item = document.createElement('snice-menu-item');
478
- item.value = file.id;
479
- item.textContent = file.name;
480
-
481
- const shortcut = document.createElement('span');
482
- shortcut.slot = 'shortcut';
483
- shortcut.textContent = `⌘${index + 1}`;
484
- item.appendChild(shortcut);
485
-
486
- menu.appendChild(item);
487
- });
488
-
489
- menu.addEventListener('menu-item-select', (e) => {
490
- openFile(e.detail.value);
491
- });
492
- </script>
173
+ menu.addEventListener('menu-open', () => console.log('Opened'));
174
+ menu.addEventListener('menu-close', () => console.log('Closed'));
493
175
  ```
494
176
 
495
- ### Nested Menu Actions
177
+ ## Menu Slots
496
178
 
497
- ```html
498
- <snice-menu>
499
- <button slot="trigger">Actions</button>
179
+ | Name | Description |
180
+ |------|-------------|
181
+ | `trigger` | Element that triggers the menu (required) |
182
+ | `image-left` | Image/icon before the trigger |
183
+ | `image-right` | Image/icon after the trigger |
184
+ | (default) | Menu items and dividers |
500
185
 
501
- <snice-menu-item value="new">
502
- <span slot="icon">📄</span>
503
- New Document
504
- </snice-menu-item>
505
-
506
- <snice-menu-item value="import">
507
- <span slot="icon">📥</span>
508
- Import
509
- </snice-menu-item>
510
-
511
- <snice-menu-item value="export">
512
- <span slot="icon">📤</span>
513
- Export
514
- </snice-menu-item>
515
-
516
- <snice-menu-divider></snice-menu-divider>
517
-
518
- <snice-menu-item value="share">
519
- <span slot="icon">🔗</span>
520
- Share
521
- </snice-menu-item>
522
-
523
- <snice-menu-item value="permissions">
524
- <span slot="icon">🔒</span>
525
- Permissions
526
- </snice-menu-item>
527
-
528
- <snice-menu-divider></snice-menu-divider>
529
-
530
- <snice-menu-item value="archive">
531
- <span slot="icon">📦</span>
532
- Archive
533
- </snice-menu-item>
534
-
535
- <snice-menu-item value="delete">
536
- <span slot="icon">🗑️</span>
537
- Delete
538
- </snice-menu-item>
539
- </snice-menu>
540
- ```
541
-
542
- ### Styled Menu
543
-
544
- ```html
545
- <style>
546
- #styled-menu::part(panel) {
547
- border-radius: 12px;
548
- box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1);
549
- min-width: 200px;
550
- }
551
-
552
- #styled-menu::part(trigger) {
553
- background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
554
- color: white;
555
- border: none;
556
- padding: 10px 20px;
557
- border-radius: 8px;
558
- font-weight: 600;
559
- }
560
- </style>
561
-
562
- <snice-menu id="styled-menu">
563
- <button slot="trigger">Styled Menu</button>
564
- <snice-menu-item value="1">Option 1</snice-menu-item>
565
- <snice-menu-item value="2">Option 2</snice-menu-item>
566
- <snice-menu-item value="3">Option 3</snice-menu-item>
567
- </snice-menu>
568
- ```
569
-
570
- ## Accessibility
571
-
572
- - **ARIA roles**: `menu` role on panel, `menuitem` role on items
573
- - **Keyboard support**: Click and keyboard activation of trigger
574
- - **Screen reader friendly**: Proper aria attributes
575
- - **Focus management**: Focus returns to trigger when closed
576
- - **Disabled state**: Items can be disabled with proper aria-disabled
186
+ ## Menu Item Slots
577
187
 
578
- ## Browser Support
188
+ | Name | Description |
189
+ |------|-------------|
190
+ | `icon` | Icon before the item label |
191
+ | (default) | Item label content |
192
+ | `shortcut` | Keyboard shortcut hint |
579
193
 
580
- - Modern browsers (Chrome, Firefox, Safari, Edge)
581
- - Requires Custom Elements v1 and Shadow DOM support
194
+ ## Menu Properties
582
195
 
583
- ## Best Practices
196
+ | Property | Type | Default | Description |
197
+ |----------|------|---------|-------------|
198
+ | `open` | `boolean` | `false` | Whether the menu is open |
199
+ | `placement` | `'bottom-start' \| 'bottom-end' \| 'top-start' \| 'top-end' \| 'right-start' \| 'right-end' \| 'left-start' \| 'left-end'` | `'bottom-start'` | Panel placement |
200
+ | `trigger` | `'click' \| 'hover' \| 'manual'` | `'click'` | Trigger mode |
201
+ | `closeOnSelect` (attr: `close-on-select`) | `boolean` | `true` | Close on item selection |
202
+ | `distance` | `number` | `4` | Distance from trigger to panel (px) |
584
203
 
585
- 1. **Use meaningful values**: Set descriptive `value` attributes on menu items
586
- 2. **Group related items**: Use dividers to separate logical groups
587
- 3. **Keep menus concise**: Limit to 7-10 items per menu for usability
588
- 4. **Use icons sparingly**: Icons should enhance, not clutter
589
- 5. **Position appropriately**: Choose placement based on trigger location
590
- 6. **Handle outside clicks**: Menu automatically closes on outside click
591
- 7. **Provide keyboard shortcuts**: Show shortcuts in the menu when available
592
- 8. **Test on mobile**: Ensure touch interactions work well
593
- 9. **Consider hover carefully**: Hover trigger may not work well on touch devices
594
- 10. **Close after action**: Use `closeOnSelect` for single-action menus
204
+ ## Menu Item Properties
595
205
 
596
- ## Common Patterns
206
+ | Property | Type | Default | Description |
207
+ |----------|------|---------|-------------|
208
+ | `value` | `string` | `''` | Item value |
209
+ | `disabled` | `boolean` | `false` | Disable interaction |
210
+ | `selected` | `boolean` | `false` | Selected state |
597
211
 
598
- ### File Menu Pattern
599
- ```html
600
- <snice-menu>
601
- <button slot="trigger">File</button>
602
- <snice-menu-item value="new">New</snice-menu-item>
603
- <snice-menu-item value="open">Open</snice-menu-item>
604
- <snice-menu-item value="save">Save</snice-menu-item>
605
- </snice-menu>
606
- ```
212
+ ## Events
607
213
 
608
- ### User Menu Pattern
609
- ```html
610
- <snice-menu placement="bottom-end">
611
- <img slot="image-left" src="avatar.jpg">
612
- <span slot="trigger">Username</span>
613
- <snice-menu-item value="profile">Profile</snice-menu-item>
614
- <snice-menu-item value="logout">Logout</snice-menu-item>
615
- </snice-menu>
616
- ```
214
+ | Event | Detail | Description |
215
+ |-------|--------|-------------|
216
+ | `menu-open` | `{ menu: SniceMenuElement }` | Menu opened |
217
+ | `menu-close` | `{ menu: SniceMenuElement }` | Menu closed |
218
+ | `menu-item-select` | `{ item: SniceMenuItemElement, value: string }` | Item selected |
617
219
 
618
- ### Action Menu Pattern
619
- ```html
620
- <snice-menu>
621
- <button slot="trigger">⋮</button>
622
- <snice-menu-item value="edit">Edit</snice-menu-item>
623
- <snice-menu-item value="delete">Delete</snice-menu-item>
624
- </snice-menu>
625
- ```
220
+ ## Methods
626
221
 
627
- ### Multi-Select Pattern
628
- ```html
629
- <snice-menu close-on-select="false">
630
- <button slot="trigger">Filters</button>
631
- <!-- Multiple selections allowed -->
632
- </snice-menu>
633
- ```
222
+ | Method | Arguments | Description |
223
+ |--------|-----------|-------------|
224
+ | `openMenu()` | -- | Open the menu |
225
+ | `closeMenu()` | -- | Close the menu |
226
+ | `toggleMenu()` | -- | Toggle the menu |