@flamingo-stack/openframe-frontend-core 0.0.213 → 0.0.214

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 (745) hide show
  1. package/dist/{chunk-3JWIJJ44.js → chunk-5OWDOFKK.js} +2 -2
  2. package/dist/{chunk-IK2X5YJU.js → chunk-HWY35EAK.js} +2 -2
  3. package/dist/{chunk-OTKJASSX.cjs → chunk-IZL2KEH6.cjs} +24 -24
  4. package/dist/{chunk-OTKJASSX.cjs.map → chunk-IZL2KEH6.cjs.map} +1 -1
  5. package/dist/{chunk-35XIT2CF.cjs → chunk-KDNGUYZM.cjs} +17 -17
  6. package/dist/{chunk-35XIT2CF.cjs.map → chunk-KDNGUYZM.cjs.map} +1 -1
  7. package/dist/{chunk-ZTJVRSN5.js → chunk-UKND27XC.js} +2 -2
  8. package/dist/chunk-UKND27XC.js.map +1 -0
  9. package/dist/{chunk-ZDF6F7ED.cjs → chunk-YZUUFTIK.cjs} +2 -2
  10. package/dist/chunk-YZUUFTIK.cjs.map +1 -0
  11. package/dist/components/chat/index.cjs +2 -2
  12. package/dist/components/chat/index.js +1 -1
  13. package/dist/components/contact/index.cjs +3 -3
  14. package/dist/components/contact/index.js +2 -2
  15. package/dist/components/features/index.cjs +2 -2
  16. package/dist/components/features/index.js +1 -1
  17. package/dist/components/index.cjs +49 -49
  18. package/dist/components/index.js +2 -2
  19. package/dist/components/navigation/index.cjs +2 -2
  20. package/dist/components/navigation/index.js +1 -1
  21. package/dist/components/tickets/index.cjs +61 -61
  22. package/dist/components/tickets/index.js +3 -3
  23. package/dist/components/ui/index.cjs +2 -2
  24. package/dist/components/ui/index.js +1 -1
  25. package/dist/index.cjs +2 -2
  26. package/dist/index.js +1 -1
  27. package/package.json +1 -1
  28. package/src/.index.md +36 -34
  29. package/src/components/.alert-dialog.md +27 -23
  30. package/src/components/.announcement-bar.md +26 -21
  31. package/src/components/.breadcrumb.md +19 -15
  32. package/src/components/.calendar.md +24 -19
  33. package/src/components/.categories-cart.md +29 -24
  34. package/src/components/.checkbox.md +23 -25
  35. package/src/components/.chevron-button.md +37 -32
  36. package/src/components/.comment-card.md +32 -62
  37. package/src/components/.dialog.md +26 -26
  38. package/src/components/.dynamic-skeleton.md +54 -57
  39. package/src/components/.empty-state.md +42 -51
  40. package/src/components/.faq-accordion.md +27 -21
  41. package/src/components/.filter-chip.md +41 -24
  42. package/src/components/.flamingo-logo.md +20 -23
  43. package/src/components/.footer-waitlist-button.md +29 -22
  44. package/src/components/.footer.md +32 -32
  45. package/src/components/.icons-block.md +27 -17
  46. package/src/components/.image-cropper.md +41 -32
  47. package/src/components/.index.md +33 -39
  48. package/src/components/.input.md +31 -35
  49. package/src/components/.logs-list.md +31 -20
  50. package/src/components/.media-carousel.md +35 -36
  51. package/src/components/.open-source-features.md +33 -16
  52. package/src/components/.pagination.md +52 -51
  53. package/src/components/.provider-button.md +21 -23
  54. package/src/components/.select.md +31 -20
  55. package/src/components/.sidebar.md +34 -24
  56. package/src/components/.smooth-accordion.md +29 -24
  57. package/src/components/.social-icon-row.md +36 -32
  58. package/src/components/.textarea.md +25 -31
  59. package/src/components/.tool-icon.md +24 -26
  60. package/src/components/.unified-filter-logic.md +37 -30
  61. package/src/components/.unified-pagination.md +23 -22
  62. package/src/components/.user-summary-stub.md +38 -22
  63. package/src/components/.vendor-display-button.md +25 -25
  64. package/src/components/.vendor-icon.md +33 -25
  65. package/src/components/.why-it-matters.md +28 -25
  66. package/src/components/chat/.approval-batch-message.md +51 -0
  67. package/src/components/chat/.approval-request-message.md +35 -34
  68. package/src/components/chat/.chat-attachment-bar.md +64 -0
  69. package/src/components/chat/.chat-container.md +36 -18
  70. package/src/components/chat/.chat-input.md +37 -20
  71. package/src/components/chat/.chat-message-enhanced.md +30 -49
  72. package/src/components/chat/.chat-message-list.md +45 -32
  73. package/src/components/chat/.chat-message-skeleton.md +26 -22
  74. package/src/components/chat/.chat-panel-context.md +52 -0
  75. package/src/components/chat/.chat-ref.types.md +42 -0
  76. package/src/components/chat/.chat-sidebar-skeleton.md +34 -25
  77. package/src/components/chat/.chat-sidebar.md +31 -26
  78. package/src/components/chat/.chat-ticket-list.md +39 -0
  79. package/src/components/chat/.context-compaction-display.md +36 -0
  80. package/src/components/chat/.cycling-phrase.md +52 -0
  81. package/src/components/chat/.embeddable-chat.md +48 -0
  82. package/src/components/chat/.expand-chevron.md +24 -0
  83. package/src/components/chat/.index.md +31 -35
  84. package/src/components/chat/.mingo-onboarding-card-skeleton.md +44 -0
  85. package/src/components/chat/.mingo-onboarding-card.md +62 -0
  86. package/src/components/chat/.model-display.md +32 -30
  87. package/src/components/chat/.nav-link-anchor-via-runtime.md +40 -0
  88. package/src/components/chat/.remark-card-links.md +38 -0
  89. package/src/components/chat/.slash-command-suggestions.md +47 -0
  90. package/src/components/chat/.source-action-button.md +48 -0
  91. package/src/components/chat/.thinking-display.md +42 -0
  92. package/src/components/chat/.tool-call-blocks.md +45 -0
  93. package/src/components/chat/.tool-execution-display.md +44 -36
  94. package/src/components/chat/chat-container.tsx +1 -1
  95. package/src/components/chat/entity-cards/.admin-content-card.md +43 -0
  96. package/src/components/chat/entity-cards/.block-card.md +47 -0
  97. package/src/components/chat/entity-cards/.blog-card.md +52 -0
  98. package/src/components/chat/entity-cards/.blog-image-placeholder.md +39 -0
  99. package/src/components/chat/entity-cards/.campaign-card-admin.md +47 -0
  100. package/src/components/chat/entity-cards/.case-study-card.md +58 -0
  101. package/src/components/chat/entity-cards/.chat-ticket-item.md +40 -0
  102. package/src/components/chat/entity-cards/.chat-video-entity-card.md +43 -0
  103. package/src/components/chat/entity-cards/.customer-interview-card.md +53 -0
  104. package/src/components/chat/entity-cards/.data-room-doc-card.md +47 -0
  105. package/src/components/chat/entity-cards/.dispatch.md +39 -0
  106. package/src/components/chat/entity-cards/.entity-author-card.md +51 -0
  107. package/src/components/chat/entity-cards/.generic-entity-card.md +62 -0
  108. package/src/components/chat/entity-cards/.github-activity-card.md +61 -0
  109. package/src/components/chat/entity-cards/.hubspot-ticket-card.md +53 -0
  110. package/src/components/chat/entity-cards/.index.md +66 -0
  111. package/src/components/chat/entity-cards/.investor-update-card.md +47 -0
  112. package/src/components/chat/entity-cards/.onboarding-guide-card.md +58 -0
  113. package/src/components/chat/entity-cards/.product-release-card-defaults.md +31 -0
  114. package/src/components/chat/entity-cards/.product-release-card.md +29 -0
  115. package/src/components/chat/entity-cards/.program-card-defaults.md +41 -0
  116. package/src/components/chat/entity-cards/.program-card.md +59 -0
  117. package/src/components/chat/entity-cards/.roadmap-card.md +46 -0
  118. package/src/components/chat/entity-cards/.roadmap-vote-button.md +52 -0
  119. package/src/components/chat/entity-cards/.slack-message-card.md +48 -0
  120. package/src/components/chat/entity-cards/.task-type-icon.md +47 -0
  121. package/src/components/chat/hooks/.index.md +36 -21
  122. package/src/components/chat/hooks/.use-chat-attachment-image-gallery.md +51 -0
  123. package/src/components/chat/hooks/.use-chat-attachments.md +48 -0
  124. package/src/components/chat/hooks/.use-chat-card-item.md +39 -0
  125. package/src/components/chat/hooks/.use-chat-identity.md +45 -0
  126. package/src/components/chat/hooks/.use-chat.md +58 -0
  127. package/src/components/chat/hooks/.use-chunk-catchup.md +46 -48
  128. package/src/components/chat/hooks/.use-close-on-navigation.md +44 -0
  129. package/src/components/chat/hooks/.use-collapsible.md +48 -0
  130. package/src/components/chat/hooks/.use-embedded-chat.md +32 -0
  131. package/src/components/chat/hooks/.use-jetstream-dialog-subscription.md +40 -0
  132. package/src/components/chat/hooks/.use-nats-chat-adapter.md +52 -0
  133. package/src/components/chat/hooks/.use-nats-dialog-subscription.md +49 -30
  134. package/src/components/chat/hooks/.use-proxied-image-url.md +40 -0
  135. package/src/components/chat/hooks/.use-realtime-chunk-processor.md +43 -40
  136. package/src/components/chat/hooks/.use-slash-commands.md +46 -0
  137. package/src/components/chat/hooks/.use-sse-chat-adapter.md +34 -0
  138. package/src/components/chat/hooks/.use-sse.md +60 -0
  139. package/src/components/chat/hooks/.use-unified-chat.md +57 -0
  140. package/src/components/chat/types/.api.types.md +52 -38
  141. package/src/components/chat/types/.chat.types.md +43 -34
  142. package/src/components/chat/types/.component.types.md +47 -48
  143. package/src/components/chat/types/.index.md +20 -27
  144. package/src/components/chat/types/.message.types.md +58 -48
  145. package/src/components/chat/types/.network.types.md +57 -31
  146. package/src/components/chat/types/.processing.types.md +49 -31
  147. package/src/components/chat/types/.unified-chat-state.types.md +41 -0
  148. package/src/components/chat/types/entities/.blog.md +43 -0
  149. package/src/components/chat/types/entities/.case-study.md +26 -0
  150. package/src/components/chat/types/entities/.content-ref.md +41 -0
  151. package/src/components/chat/types/entities/.customer-interview.md +28 -0
  152. package/src/components/chat/types/entities/.data-room-doc.md +36 -0
  153. package/src/components/chat/types/entities/.github-activity.md +43 -0
  154. package/src/components/chat/types/entities/.hubspot-ticket.md +53 -0
  155. package/src/components/chat/types/entities/.index.md +42 -0
  156. package/src/components/chat/types/entities/.investor-update.md +45 -0
  157. package/src/components/chat/types/entities/.onboarding-guide.md +50 -0
  158. package/src/components/chat/types/entities/.program-types.md +57 -0
  159. package/src/components/chat/types/entities/.roadmap-item.md +58 -0
  160. package/src/components/chat/types/entities/.slack-message.md +35 -0
  161. package/src/components/chat/utils/.agent-status-message.md +45 -0
  162. package/src/components/chat/utils/.auto-continuation-directive.md +58 -0
  163. package/src/components/chat/utils/.chat-attachment-markdown.md +54 -0
  164. package/src/components/chat/utils/.chat-authed-fetch.md +25 -0
  165. package/src/components/chat/utils/.chat-nav-resolution.md +46 -0
  166. package/src/components/chat/utils/.chat-proxy-auth-storage.md +38 -0
  167. package/src/components/chat/utils/.chip-action-class.md +34 -0
  168. package/src/components/chat/utils/.chip-styles.md +46 -0
  169. package/src/components/chat/utils/.chunk-parser.md +38 -28
  170. package/src/components/chat/utils/.clickup-task-type-utils.md +48 -0
  171. package/src/components/chat/utils/.compact-card-classes.md +62 -0
  172. package/src/components/chat/utils/.decide-new-tab.md +51 -0
  173. package/src/components/chat/utils/.external-app-urls.md +29 -0
  174. package/src/components/chat/utils/.extract-incomplete-message-state.md +25 -29
  175. package/src/components/chat/utils/.flatten-assistant-content.md +34 -0
  176. package/src/components/chat/utils/.icon-registry.md +46 -0
  177. package/src/components/chat/utils/.index.md +37 -32
  178. package/src/components/chat/utils/.is-cross-origin-url.md +35 -0
  179. package/src/components/chat/utils/.message-segment-accumulator.md +25 -34
  180. package/src/components/chat/utils/.nav-anchor-props.md +44 -0
  181. package/src/components/chat/utils/.nav-click-handler.md +47 -0
  182. package/src/components/chat/utils/.onboarding-icons.md +28 -0
  183. package/src/components/chat/utils/.process-historical-messages.md +46 -35
  184. package/src/components/chat/utils/.scroll-anchor.md +40 -0
  185. package/src/components/chat/utils/.slash-dispatch-utils.md +44 -0
  186. package/src/components/chat/utils/.source-icons.md +35 -0
  187. package/src/components/chat/utils/.source-row-cta.md +54 -0
  188. package/src/components/chat/utils/.tool-call-helpers.md +42 -0
  189. package/src/components/contact/.contact-form.md +43 -0
  190. package/src/components/contact/.index.md +27 -0
  191. package/src/components/features/.array-entry-manager.md +36 -45
  192. package/src/components/features/.changelog-manager.md +47 -21
  193. package/src/components/features/.changelog-sections-manager.md +21 -26
  194. package/src/components/features/.command-box.md +31 -28
  195. package/src/components/features/.entity-summary-editor.md +46 -0
  196. package/src/components/features/.entity-video-section.md +51 -0
  197. package/src/components/features/.figma-prototype-viewer.md +48 -29
  198. package/src/components/features/.filters-dropdown.md +33 -46
  199. package/src/components/features/.highlight-config-section.md +42 -0
  200. package/src/components/features/.highlight-generation-section.md +46 -0
  201. package/src/components/features/.highlight-video-combined-section.md +47 -0
  202. package/src/components/features/.highlight-video-preview.md +44 -0
  203. package/src/components/features/.highlight-video-section.md +47 -0
  204. package/src/components/features/.index.md +40 -66
  205. package/src/components/features/.media-gallery-manager.md +48 -38
  206. package/src/components/features/.more-about-button.md +22 -19
  207. package/src/components/features/.og-editor-preview.md +40 -36
  208. package/src/components/features/.parallax-image-showcase.md +33 -26
  209. package/src/components/features/.paths-display.md +42 -43
  210. package/src/components/features/.platform-badge.md +37 -36
  211. package/src/components/features/.platform-filter.md +23 -16
  212. package/src/components/features/.policy-configuration-panel.md +48 -56
  213. package/src/components/features/.provider-button.md +33 -36
  214. package/src/components/features/.push-button-selector.md +40 -29
  215. package/src/components/features/.release-media-manager.md +46 -31
  216. package/src/components/features/.section-selector.md +26 -31
  217. package/src/components/features/.select-button.md +35 -25
  218. package/src/components/features/.seo-editor-preview.md +41 -44
  219. package/src/components/features/.social-links-manager.md +25 -19
  220. package/src/components/features/.start-with-openframe-button.md +37 -29
  221. package/src/components/features/.status-filter-component.md +36 -20
  222. package/src/components/features/.tags-selector.md +40 -24
  223. package/src/components/features/.transcribe-and-summarize-combined-section.md +45 -0
  224. package/src/components/features/.transcribe-summarize-section.md +48 -0
  225. package/src/components/features/.transcript-summary-editor.md +53 -0
  226. package/src/components/features/.video-bites-display.md +46 -0
  227. package/src/components/features/.video-clips-section.md +41 -0
  228. package/src/components/features/.video-ratio-tabs.md +56 -0
  229. package/src/components/features/.video-source-selector.md +60 -0
  230. package/src/components/features/.video.md +44 -0
  231. package/src/components/features/.waitlist-form.md +60 -0
  232. package/src/components/features/ai-enrich/.AIEnrichButton.md +30 -27
  233. package/src/components/features/ai-enrich/.AIEnrichSection.md +46 -42
  234. package/src/components/features/board/.board-column-header.md +38 -0
  235. package/src/components/features/board/.board-column.md +43 -0
  236. package/src/components/features/board/.board.md +51 -0
  237. package/src/components/features/board/.color-utils.md +26 -0
  238. package/src/components/features/board/.index.md +56 -0
  239. package/src/components/features/board/.ticket-card-skeleton.md +38 -0
  240. package/src/components/features/board/.ticket-card.md +47 -0
  241. package/src/components/features/board/.types.md +45 -0
  242. package/src/components/features/board/.use-board-collapse.md +34 -0
  243. package/src/components/features/notifications/.index.md +57 -0
  244. package/src/components/features/notifications/.notification-drawer.md +34 -0
  245. package/src/components/features/notifications/.notification-tile.md +39 -0
  246. package/src/components/features/notifications/.notifications-context.md +73 -0
  247. package/src/components/features/notifications/.types.md +45 -0
  248. package/src/components/icons/.about-icon.md +20 -28
  249. package/src/components/icons/.ai-robot-icon.md +15 -17
  250. package/src/components/icons/.bash-icon.md +16 -23
  251. package/src/components/icons/.buildings-icon.md +10 -24
  252. package/src/components/icons/.capterra-icon.md +30 -26
  253. package/src/components/icons/.carta-icon.md +29 -0
  254. package/src/components/icons/.clickup-icon.md +26 -0
  255. package/src/components/icons/.cmd-icon.md +15 -22
  256. package/src/components/icons/.coins-icon.md +17 -25
  257. package/src/components/icons/.community-hub-icon.md +19 -25
  258. package/src/components/icons/.community-icon.md +24 -21
  259. package/src/components/icons/.compare-icon.md +32 -19
  260. package/src/components/icons/.copy-icon.md +29 -15
  261. package/src/components/icons/.custom-external-link-icon.md +19 -17
  262. package/src/components/icons/.custom-fork-icon.md +32 -21
  263. package/src/components/icons/.custom-license-icon.md +29 -25
  264. package/src/components/icons/.custom-star-icon.md +20 -28
  265. package/src/components/icons/.custom-time-icon.md +21 -22
  266. package/src/components/icons/.cut-vendor-costs-icon.md +6 -19
  267. package/src/components/icons/.dashboard-icon.md +13 -18
  268. package/src/components/icons/.deno-icon.md +16 -23
  269. package/src/components/icons/.donut-icon.md +12 -23
  270. package/src/components/icons/.double-chevron-icon.md +28 -36
  271. package/src/components/icons/.elestio-logo.md +13 -23
  272. package/src/components/icons/.empty-vendor-icon.md +16 -18
  273. package/src/components/icons/.explore-categories-icon.md +18 -29
  274. package/src/components/icons/.eye-icon.md +16 -26
  275. package/src/components/icons/.facebook-icon.md +9 -20
  276. package/src/components/icons/.figma-icon.md +8 -17
  277. package/src/components/icons/.filter-icon.md +15 -17
  278. package/src/components/icons/.flamingo-logo.md +28 -27
  279. package/src/components/icons/.folder-shield-icon.md +28 -19
  280. package/src/components/icons/.g2-icon.md +22 -21
  281. package/src/components/icons/.getapp-icon.md +25 -21
  282. package/src/components/icons/.github-icon.md +13 -25
  283. package/src/components/icons/.globe-icon.md +14 -19
  284. package/src/components/icons/.google-gemini-icon.md +16 -19
  285. package/src/components/icons/.google-logo.md +15 -21
  286. package/src/components/icons/.grid-view-icon.md +30 -19
  287. package/src/components/icons/.hamburger-icon.md +22 -20
  288. package/src/components/icons/.hand-dollar-icon.md +24 -34
  289. package/src/components/icons/.hotel-icon.md +27 -21
  290. package/src/components/icons/.icon-utils.md +28 -29
  291. package/src/components/icons/.image-icon.md +15 -22
  292. package/src/components/icons/.index.md +25 -28
  293. package/src/components/icons/.info-circle-icon.md +29 -30
  294. package/src/components/icons/.instagram-icon.md +10 -24
  295. package/src/components/icons/.jump-in-icon.md +18 -18
  296. package/src/components/icons/.linux-icon.md +18 -18
  297. package/src/components/icons/.log-out-icon.md +15 -23
  298. package/src/components/icons/.logs-icon.md +14 -23
  299. package/src/components/icons/.margin-crisis-icon.md +21 -20
  300. package/src/components/icons/.menu-icon.md +18 -19
  301. package/src/components/icons/.miami-cyber-gang-logo-face-only.md +18 -21
  302. package/src/components/icons/.miami-cyber-gang-logo.md +22 -14
  303. package/src/components/icons/.mlg-logo.md +18 -16
  304. package/src/components/icons/.moon-icon.md +32 -22
  305. package/src/components/icons/.ms-icon.md +30 -19
  306. package/src/components/icons/.nushell-icon.md +7 -21
  307. package/src/components/icons/.open-source-icon.md +19 -23
  308. package/src/components/icons/.openai-icon.md +9 -24
  309. package/src/components/icons/.openframe-ai-icons.md +25 -26
  310. package/src/components/icons/.openframe-logo.md +28 -22
  311. package/src/components/icons/.openframe-text.md +24 -27
  312. package/src/components/icons/.openmsp-logo.md +26 -23
  313. package/src/components/icons/.pilot-icon.md +23 -0
  314. package/src/components/icons/.powershell-icon.md +17 -22
  315. package/src/components/icons/.python-icon.md +16 -23
  316. package/src/components/icons/.queries-icon.md +13 -21
  317. package/src/components/icons/.reddit-icon.md +28 -24
  318. package/src/components/icons/.remote-control-icon.md +13 -17
  319. package/src/components/icons/.script-icon.md +27 -19
  320. package/src/components/icons/.search-icon.md +21 -21
  321. package/src/components/icons/.send-icon.md +14 -16
  322. package/src/components/icons/.settings-icon.md +30 -19
  323. package/src/components/icons/.shape-circle-dash-icon.md +16 -21
  324. package/src/components/icons/.shell-icon.md +15 -19
  325. package/src/components/icons/.shield-check-icon.md +18 -31
  326. package/src/components/icons/.shield-key-icon.md +25 -25
  327. package/src/components/icons/.shield-lock-icon.md +8 -18
  328. package/src/components/icons/.slack-icon.md +28 -32
  329. package/src/components/icons/.sparkles-icon.md +18 -23
  330. package/src/components/icons/.sso-configuration-icon.md +29 -16
  331. package/src/components/icons/.sun-icon.md +20 -18
  332. package/src/components/icons/.table-view-icon.md +17 -19
  333. package/src/components/icons/.telegram-icon.md +8 -22
  334. package/src/components/icons/.thumbs-down-icon.md +10 -19
  335. package/src/components/icons/.thumbs-up-icon.md +8 -17
  336. package/src/components/icons/.tool-directory-icons.md +24 -28
  337. package/src/components/icons/.trustpilot-icon.md +25 -22
  338. package/src/components/icons/.user-icon.md +26 -28
  339. package/src/components/icons/.users-group-icon.md +28 -24
  340. package/src/components/icons/.vendor-showcase-icons.md +21 -29
  341. package/src/components/icons/.vendors-icon.md +18 -22
  342. package/src/components/icons/.whatsapp-icon.md +30 -14
  343. package/src/components/icons/.x-icon.md +18 -23
  344. package/src/components/icons/.x-logo.md +13 -38
  345. package/src/components/icons/.youtube-icon.md +8 -19
  346. package/src/components/icons/device-type-icons/.get-device-type-icon.md +26 -34
  347. package/src/components/icons-v2-generated/.index.md +52 -0
  348. package/src/components/icons-v2-generated/alphabet/.index.md +33 -0
  349. package/src/components/icons-v2-generated/arrows/.index.md +39 -0
  350. package/src/components/icons-v2-generated/audio-and-visual/.index.md +40 -0
  351. package/src/components/icons-v2-generated/brand-logos/.elestio-logo-icon.md +40 -0
  352. package/src/components/icons-v2-generated/brand-logos/.gemini-logo-icon.md +37 -0
  353. package/src/components/icons-v2-generated/brand-logos/.google-gemini-logo-icon.md +33 -0
  354. package/src/components/icons-v2-generated/brand-logos/.index.md +38 -0
  355. package/src/components/icons-v2-generated/brand-logos/.meshcentral-logo-grey-icon.md +35 -0
  356. package/src/components/icons-v2-generated/brand-logos/.meshcentral-logo-icon.md +36 -0
  357. package/src/components/icons-v2-generated/buildings/.index.md +48 -0
  358. package/src/components/icons-v2-generated/charts/.index.md +40 -0
  359. package/src/components/icons-v2-generated/clothes/.index.md +48 -0
  360. package/src/components/icons-v2-generated/coding/.index.md +42 -0
  361. package/src/components/icons-v2-generated/communication/.index.md +39 -0
  362. package/src/components/icons-v2-generated/date-and-time/.index.md +29 -0
  363. package/src/components/icons-v2-generated/design/.index.md +39 -0
  364. package/src/components/icons-v2-generated/devices/.index.md +38 -0
  365. package/src/components/icons-v2-generated/documents/.index.md +38 -0
  366. package/src/components/icons-v2-generated/finance/.index.md +34 -0
  367. package/src/components/icons-v2-generated/food-and-drinks/.index.md +34 -0
  368. package/src/components/icons-v2-generated/food-and-drinks/.leafy-green-icon.md +36 -0
  369. package/src/components/icons-v2-generated/food-and-drinks/.strawberry-icon.md +39 -0
  370. package/src/components/icons-v2-generated/health/.index.md +40 -0
  371. package/src/components/icons-v2-generated/household/.index.md +45 -0
  372. package/src/components/icons-v2-generated/interface/.index.md +36 -0
  373. package/src/components/icons-v2-generated/map-and-travel/.index.md +41 -0
  374. package/src/components/icons-v2-generated/media-playback/.index.md +51 -0
  375. package/src/components/icons-v2-generated/number/.index.md +41 -0
  376. package/src/components/icons-v2-generated/school/.index.md +37 -0
  377. package/src/components/icons-v2-generated/security/.fingerprint-icon.md +38 -0
  378. package/src/components/icons-v2-generated/security/.index.md +39 -0
  379. package/src/components/icons-v2-generated/shopping/.index.md +42 -0
  380. package/src/components/icons-v2-generated/signs-and-symbols/.index.md +32 -0
  381. package/src/components/icons-v2-generated/sort-and-filter/.index.md +35 -0
  382. package/src/components/icons-v2-generated/sport/.index.md +41 -0
  383. package/src/components/icons-v2-generated/text-editor/.index.md +44 -0
  384. package/src/components/icons-v2-generated/users/.index.md +45 -0
  385. package/src/components/icons-v2-generated/vehicles-and-delivery/.index.md +36 -0
  386. package/src/components/icons-v2-generated/weather-and-nature/.flower-sakura-icon.md +36 -0
  387. package/src/components/icons-v2-generated/weather-and-nature/.index.md +34 -0
  388. package/src/components/layout/.article-detail-layout.md +43 -0
  389. package/src/components/layout/.back-button.md +40 -0
  390. package/src/components/layout/.list-page-layout.md +35 -26
  391. package/src/components/layout/.page-container.md +27 -38
  392. package/src/components/layout/.page-layout.md +50 -0
  393. package/src/components/layout/.title-block.md +42 -0
  394. package/src/components/loading/.card-skeleton.md +38 -29
  395. package/src/components/loading/.device-card-skeleton.md +29 -25
  396. package/src/components/loading/.index.md +39 -46
  397. package/src/components/loading/.margin-report-skeleton.md +45 -34
  398. package/src/components/loading/.organization-card-skeleton.md +39 -44
  399. package/src/components/loading/.page-layout-skeleton.md +34 -45
  400. package/src/components/loading/.unified-skeleton.md +62 -36
  401. package/src/components/navigation/.app-header.md +40 -29
  402. package/src/components/navigation/.app-layout.md +25 -26
  403. package/src/components/navigation/.header-global-search.md +34 -37
  404. package/src/components/navigation/.header-organization-filter.md +23 -22
  405. package/src/components/navigation/.header.md +31 -35
  406. package/src/components/navigation/.mobile-burger-menu.md +39 -47
  407. package/src/components/navigation/.mobile-nav-panel.md +51 -32
  408. package/src/components/navigation/.navigation-sidebar-header.md +36 -0
  409. package/src/components/navigation/.navigation-sidebar-item.md +45 -0
  410. package/src/components/navigation/.navigation-sidebar-toggle.md +38 -0
  411. package/src/components/navigation/.navigation-sidebar.md +33 -34
  412. package/src/components/navigation/.sliding-sidebar.md +52 -41
  413. package/src/components/navigation/.sticky-section-nav.md +56 -48
  414. package/src/components/platform/.ScriptArguments.md +39 -25
  415. package/src/components/platform/.ScriptInfoSection.md +30 -26
  416. package/src/components/platform/.ShellTypeBadge.md +18 -13
  417. package/src/components/platform/.SoftwareInfo.md +23 -27
  418. package/src/components/platform/.SoftwareSourceBadge.md +28 -19
  419. package/src/components/platform/.ToolBadge.md +25 -26
  420. package/src/components/providers/.theme-provider.md +52 -0
  421. package/src/components/shared/delivery/.delivery-lists.md +39 -0
  422. package/src/components/shared/delivery/.delivery-row.md +41 -0
  423. package/src/components/shared/delivery/.delivery-table.md +41 -0
  424. package/src/components/shared/delivery/.index.md +38 -0
  425. package/src/components/shared/dev-section/.dev-card-row.md +60 -0
  426. package/src/components/shared/dev-section/.dev-section-page.md +48 -0
  427. package/src/components/shared/dev-section/.dev-section-view.md +43 -0
  428. package/src/components/shared/dev-section/.index.md +38 -0
  429. package/src/components/shared/legal-document/.index.md +40 -0
  430. package/src/components/shared/legal-document/.legal-document-page.md +50 -0
  431. package/src/components/shared/legal-document/.use-legal-docs.md +42 -0
  432. package/src/components/shared/onboarding/.onboarding-step-card.md +32 -31
  433. package/src/components/shared/onboarding/.onboarding-walkthrough.md +39 -43
  434. package/src/components/shared/product-release/.index.md +28 -30
  435. package/src/components/shared/product-release/.product-release-card-skeleton.md +28 -28
  436. package/src/components/shared/product-release/.product-release-card.md +45 -27
  437. package/src/components/shared/product-release/.release-detail-page.md +23 -24
  438. package/src/components/shared/roadmap/.index.md +37 -0
  439. package/src/components/shared/roadmap/.roadmap-grid-skeleton.md +39 -0
  440. package/src/components/shared/roadmap/.roadmap-grid.md +66 -0
  441. package/src/components/shared/roadmap/.use-roadmap-voting.md +68 -0
  442. package/src/components/tickets/.help-center-card.md +51 -0
  443. package/src/components/tickets/.help-center-create-form.md +38 -0
  444. package/src/components/tickets/.help-center-list.md +40 -0
  445. package/src/components/tickets/.index.md +65 -0
  446. package/src/components/tickets/.ticket-center.md +51 -0
  447. package/src/components/tickets/.ticket-detail-drawer.md +48 -0
  448. package/src/components/tickets/.ticket-linked-delivery-card.md +36 -0
  449. package/src/components/tickets/.ticket-open-form.md +50 -0
  450. package/src/components/tickets/.ticket-row.md +30 -0
  451. package/src/components/tickets/.types.md +57 -0
  452. package/src/components/tickets/hooks/.use-ticket-actions.md +77 -0
  453. package/src/components/tickets/hooks/.use-ticket-engagements.md +42 -0
  454. package/src/components/tickets/hooks/.use-tickets-list.md +54 -0
  455. package/src/components/ui/.actions-menu.md +66 -41
  456. package/src/components/ui/.alert-dialog.md +29 -26
  457. package/src/components/ui/.allowed-domains-input.md +29 -21
  458. package/src/components/ui/.assignee-dropdown.md +45 -0
  459. package/src/components/ui/.autocomplete.md +47 -41
  460. package/src/components/ui/.benefit-card.md +51 -36
  461. package/src/components/ui/.brand-association-card.md +30 -27
  462. package/src/components/ui/.breadcrumb.md +17 -15
  463. package/src/components/ui/.checkbox-block.md +39 -35
  464. package/src/components/ui/.checkbox-with-description.md +23 -16
  465. package/src/components/ui/.checkbox.md +31 -23
  466. package/src/components/ui/.circular-progress.md +49 -19
  467. package/src/components/ui/.content-loader.md +32 -20
  468. package/src/components/ui/.cursor-pagination.md +41 -52
  469. package/src/components/ui/.dashboard-info-card.md +33 -26
  470. package/src/components/ui/.date-picker.md +27 -25
  471. package/src/components/ui/.device-card-compact.md +28 -29
  472. package/src/components/ui/.device-card.md +27 -27
  473. package/src/components/ui/.dialog.md +25 -16
  474. package/src/components/ui/.drawer.md +86 -0
  475. package/src/components/ui/.dropdown-button.md +45 -0
  476. package/src/components/ui/.entity-image.md +46 -0
  477. package/src/components/ui/.error-state.md +41 -28
  478. package/src/components/ui/.feature-card.md +35 -31
  479. package/src/components/ui/.feature-list.md +48 -0
  480. package/src/components/ui/.field-wrapper.md +47 -0
  481. package/src/components/ui/.file-upload.md +42 -0
  482. package/src/components/ui/.filter-checkbox-item.md +43 -0
  483. package/src/components/ui/.filter-list.md +57 -0
  484. package/src/components/ui/.filter-modal.md +59 -0
  485. package/src/components/ui/.floating-tooltip.md +43 -26
  486. package/src/components/ui/.hidden-tags-popup.md +49 -0
  487. package/src/components/ui/.hover-dropdown.md +54 -0
  488. package/src/components/ui/.image-gallery-modal.md +41 -34
  489. package/src/components/ui/.image-uploader.md +53 -0
  490. package/src/components/ui/.index.md +40 -34
  491. package/src/components/ui/.info-card.md +31 -31
  492. package/src/components/ui/.info-row.md +31 -27
  493. package/src/components/ui/.input-trigger.md +44 -0
  494. package/src/components/ui/.input.md +37 -31
  495. package/src/components/ui/.markdown-editor.md +57 -0
  496. package/src/components/ui/.modal-v2.md +51 -0
  497. package/src/components/ui/.modal.md +32 -31
  498. package/src/components/ui/.more-actions-menu.md +45 -38
  499. package/src/components/ui/.organization-card.md +31 -37
  500. package/src/components/ui/.page-actions.md +44 -54
  501. package/src/components/ui/.phone-input.md +54 -0
  502. package/src/components/ui/.progress-bar.md +35 -27
  503. package/src/components/ui/.radio-group.md +39 -27
  504. package/src/components/ui/.release-changelog-section.md +34 -34
  505. package/src/components/ui/.search-input.md +48 -0
  506. package/src/components/ui/.select.md +54 -34
  507. package/src/components/ui/.service-card.md +42 -40
  508. package/src/components/ui/.sheet.md +27 -18
  509. package/src/components/ui/.simple-markdown-renderer.md +29 -31
  510. package/src/components/ui/.sort-column-item.md +42 -0
  511. package/src/components/ui/.square-avatar.md +34 -24
  512. package/src/components/ui/.status-badge.md +26 -38
  513. package/src/components/ui/.switch.md +22 -35
  514. package/src/components/ui/.tab-navigation.md +56 -53
  515. package/src/components/ui/.tab-selector.md +40 -0
  516. package/src/components/ui/.tag-key-value-filter.md +56 -0
  517. package/src/components/ui/.tag-search-input.md +53 -0
  518. package/src/components/ui/.tag.md +49 -31
  519. package/src/components/ui/.tags-manager.md +60 -0
  520. package/src/components/ui/.textarea.md +44 -34
  521. package/src/components/ui/.ticket-attachments-list.md +45 -0
  522. package/src/components/ui/.ticket-detail-section.md +29 -0
  523. package/src/components/ui/.ticket-info-section.md +56 -0
  524. package/src/components/ui/.ticket-note-card.md +53 -0
  525. package/src/components/ui/.ticket-notes-section.md +54 -0
  526. package/src/components/ui/.ticket-status-tag.md +49 -0
  527. package/src/components/ui/.title-content-block.md +25 -26
  528. package/src/components/ui/.toaster.md +40 -28
  529. package/src/components/ui/.tooltip.md +22 -11
  530. package/src/components/ui/.truncate-text.md +39 -0
  531. package/src/components/ui/button/.button-styles.md +35 -0
  532. package/src/components/ui/button/.button.md +53 -0
  533. package/src/components/ui/button/.split-button.md +48 -0
  534. package/src/components/ui/data-table/.data-table-body.md +48 -0
  535. package/src/components/ui/data-table/.data-table-column-filter.md +45 -0
  536. package/src/components/ui/data-table/.data-table-cursor-footer.md +45 -0
  537. package/src/components/ui/data-table/.data-table-empty.md +43 -0
  538. package/src/components/ui/data-table/.data-table-header.md +55 -0
  539. package/src/components/ui/data-table/.data-table-infinite-footer.md +44 -0
  540. package/src/components/ui/data-table/.data-table-row-count.md +43 -0
  541. package/src/components/ui/data-table/.data-table-row.md +47 -0
  542. package/src/components/ui/data-table/.data-table-skeleton.md +42 -0
  543. package/src/components/ui/data-table/.data-table.md +47 -0
  544. package/src/components/ui/data-table/.index.md +55 -0
  545. package/src/components/ui/data-table/.types.md +54 -0
  546. package/src/components/ui/data-table/.use-data-table.md +45 -0
  547. package/src/components/ui/data-table/.utils.md +38 -0
  548. package/src/components/ui/file-manager/.file-manager-action-bar.md +39 -30
  549. package/src/components/ui/file-manager/.file-manager-breadcrumb.md +29 -27
  550. package/src/components/ui/file-manager/.file-manager-context-menu.md +38 -42
  551. package/src/components/ui/file-manager/.file-manager-empty.md +26 -39
  552. package/src/components/ui/file-manager/.file-manager-table-row.md +33 -41
  553. package/src/components/ui/file-manager/.file-manager.md +35 -31
  554. package/src/components/ui/query-report-table/.index.md +43 -0
  555. package/src/components/ui/query-report-table/.query-report-table-header.md +36 -0
  556. package/src/components/ui/query-report-table/.query-report-table-row.md +40 -0
  557. package/src/components/ui/query-report-table/.query-report-table-skeleton.md +44 -0
  558. package/src/components/ui/query-report-table/.query-report-table.md +47 -0
  559. package/src/components/ui/query-report-table/.types.md +41 -0
  560. package/src/components/ui/query-report-table/.utils.md +35 -0
  561. package/src/components/ui/table/.index.md +27 -48
  562. package/src/components/ui/table/.table-cell.md +18 -27
  563. package/src/components/ui/table/.table-column-filter-dropdown.md +40 -0
  564. package/src/components/ui/table/.table-description-cell.md +24 -14
  565. package/src/components/ui/table/.table-empty-state.md +21 -22
  566. package/src/components/ui/table/.table-header.md +25 -40
  567. package/src/components/ui/table/.table-row.md +22 -40
  568. package/src/components/ui/table/.table-skeleton.md +33 -26
  569. package/src/components/ui/table/.table-timestamp-cell.md +26 -16
  570. package/src/components/ui/table/.table.md +39 -59
  571. package/src/components/ui/table/.types.md +44 -36
  572. package/src/components/ui/table/.utils.md +18 -20
  573. package/src/contexts/.chat-runtime-context.md +54 -0
  574. package/src/contexts/.endpoints-runtime-context.md +58 -0
  575. package/src/contexts/.index.md +53 -0
  576. package/src/contexts/.use-outer-or-default.md +36 -0
  577. package/src/embed-shims/.index.md +45 -0
  578. package/src/embed-shims/.next-dynamic.md +43 -0
  579. package/src/embed-shims/.next-image.md +45 -0
  580. package/src/embed-shims/.next-link.md +59 -0
  581. package/src/embed-shims/.next-navigation.md +59 -0
  582. package/src/hooks/.index.md +34 -29
  583. package/src/hooks/.use-access-code-integration.md +49 -0
  584. package/src/hooks/.use-contact-submission.md +37 -26
  585. package/src/hooks/.use-copy-to-clipboard.md +42 -0
  586. package/src/hooks/.use-near-viewport.md +44 -0
  587. package/src/hooks/.use-og-placeholder.md +51 -0
  588. package/src/hooks/.use-toast.md +36 -35
  589. package/src/hooks/state/.use-api-params.md +29 -46
  590. package/src/hooks/state/.use-query-params.md +37 -33
  591. package/src/hooks/ui/.index.md +33 -32
  592. package/src/hooks/ui/.use-auto-limit-tags.md +54 -0
  593. package/src/hooks/ui/.use-horizontal-scrollbar.md +74 -0
  594. package/src/hooks/ui/.use-image-edge-color.md +42 -0
  595. package/src/hooks/ui/.use-media-query.md +33 -25
  596. package/src/hooks/ui/.use-search.md +51 -0
  597. package/src/nats/.nats.md +49 -28
  598. package/src/schemas/.contact-schema.md +45 -0
  599. package/src/stories/.AnnouncementBar.stories.md +45 -0
  600. package/src/stories/.AppLayout.stories.md +20 -21
  601. package/src/stories/.Autocomplete.stories.md +48 -34
  602. package/src/stories/.Board.stories.md +35 -0
  603. package/src/stories/.Button.stories.md +36 -33
  604. package/src/stories/.ChatTicketList.stories.md +33 -0
  605. package/src/stories/.CheckboxBlock.stories.md +40 -28
  606. package/src/stories/.ContentLoader.stories.md +47 -0
  607. package/src/stories/.DashboardInfoCard.stories.md +57 -0
  608. package/src/stories/.DataTable.stories.md +41 -0
  609. package/src/stories/.DatePicker.stories.md +66 -52
  610. package/src/stories/.DeviceCard.stories.md +41 -40
  611. package/src/stories/.DeviceCardCompact.stories.md +41 -0
  612. package/src/stories/.DotsLoaderIcon.stories.md +36 -0
  613. package/src/stories/.Drawer.stories.md +58 -0
  614. package/src/stories/.EmbeddableChat.stories.md +41 -0
  615. package/src/stories/.FileManager.stories.md +41 -0
  616. package/src/stories/.FileManagerActionBar.stories.md +38 -0
  617. package/src/stories/.FileUpload.stories.md +53 -0
  618. package/src/stories/.FilterList.stories.md +54 -0
  619. package/src/stories/.FilterModal.stories.md +72 -0
  620. package/src/stories/.FiltersDropdown.stories.md +57 -0
  621. package/src/stories/.Header.stories.md +48 -0
  622. package/src/stories/.ImageUploader.stories.md +49 -0
  623. package/src/stories/.InfoCard.stories.md +54 -0
  624. package/src/stories/.Input.stories.md +48 -30
  625. package/src/stories/.ListPageLayout.stories.md +56 -43
  626. package/src/stories/.MingoOnboardingCard.stories.md +42 -0
  627. package/src/stories/.MingoOnboardingCardSkeleton.stories.md +35 -0
  628. package/src/stories/.Modal.stories.md +40 -31
  629. package/src/stories/.NotificationDrawer.stories.md +55 -0
  630. package/src/stories/.OnboardingStepCard.stories.md +41 -0
  631. package/src/stories/.OrganizationCard.stories.md +61 -0
  632. package/src/stories/.PageActions.stories.md +52 -49
  633. package/src/stories/.PageContainer.stories.md +41 -35
  634. package/src/stories/.PageLayout.stories.md +60 -0
  635. package/src/stories/.ParallaxImageShowcase.stories.md +49 -0
  636. package/src/stories/.PhoneInput.stories.md +53 -0
  637. package/src/stories/.QueryReportTable.stories.md +44 -0
  638. package/src/stories/.RadioGroup.stories.md +46 -0
  639. package/src/stories/.RadioGroupBlock.stories.md +45 -0
  640. package/src/stories/.Select.stories.md +29 -15
  641. package/src/stories/.SlashCommandSuggestions.stories.md +41 -0
  642. package/src/stories/.SplitButton.stories.md +62 -0
  643. package/src/stories/.TabNavigation.stories.md +47 -38
  644. package/src/stories/.TabSelector.stories.md +65 -0
  645. package/src/stories/.Table.stories.md +38 -46
  646. package/src/stories/.TableColumnFilterDropdown.stories.md +46 -0
  647. package/src/stories/.Tag.stories.md +43 -32
  648. package/src/stories/.TagKeyValueFilter.stories.md +44 -0
  649. package/src/stories/.TagSearchInput.stories.md +61 -0
  650. package/src/stories/.Textarea.stories.md +49 -26
  651. package/src/stories/.Theme.stories.md +41 -0
  652. package/src/stories/.TicketAttachmentsList.stories.md +39 -0
  653. package/src/stories/.TicketDescriptionViewer.stories.md +39 -0
  654. package/src/stories/.TicketInfoSection.stories.md +40 -0
  655. package/src/stories/.TicketKnowledgeBaseList.stories.md +36 -0
  656. package/src/stories/.TicketNotesSection.stories.md +50 -0
  657. package/src/stories/.Toaster.stories.md +40 -0
  658. package/src/stories/.ToolExecutionDisplay.stories.md +41 -0
  659. package/src/stories/.Tooltip.stories.md +41 -0
  660. package/src/stories/.UserSummary.stories.md +41 -0
  661. package/src/stories/.WaitlistForm.stories.md +42 -0
  662. package/src/stories/BlogCard.stories.tsx +61 -0
  663. package/src/stories/CampaignCardAdmin.stories.tsx +52 -0
  664. package/src/stories/CaseStudyCard.stories.tsx +42 -0
  665. package/src/stories/ChatContainer.stories.tsx +186 -0
  666. package/src/stories/ChatInlineVideoPill.stories.tsx +63 -0
  667. package/src/stories/CustomerInterviewCard.stories.tsx +42 -0
  668. package/src/stories/DataRoomDocCard.stories.tsx +52 -0
  669. package/src/stories/GenericEntityCard.stories.tsx +66 -0
  670. package/src/stories/GitHubActivityCard.stories.tsx +61 -0
  671. package/src/stories/HubspotTicketCard.stories.tsx +98 -0
  672. package/src/stories/InvestorUpdateCard.stories.tsx +42 -0
  673. package/src/stories/OnboardingGuideCard.stories.tsx +52 -0
  674. package/src/stories/ProductReleaseCard.stories.tsx +61 -0
  675. package/src/stories/ProgramCard.stories.tsx +79 -0
  676. package/src/stories/RoadmapCard.stories.tsx +75 -0
  677. package/src/stories/SlackMessageCard.stories.tsx +41 -0
  678. package/src/stories/__fixtures__/chat-cards.ts +604 -0
  679. package/src/types/.blog.md +53 -29
  680. package/src/types/.case-study.md +44 -27
  681. package/src/types/.customer-interview.md +66 -44
  682. package/src/types/.delivery.md +40 -0
  683. package/src/types/.employee.md +24 -30
  684. package/src/types/.index.md +33 -47
  685. package/src/types/.marketing.md +49 -44
  686. package/src/types/.navigation.md +33 -25
  687. package/src/types/.os.types.md +32 -27
  688. package/src/types/.platform.md +31 -28
  689. package/src/types/.product-release.md +65 -38
  690. package/src/types/.supabase.md +37 -29
  691. package/src/types/.team.md +41 -33
  692. package/src/types/.video-processing.md +54 -0
  693. package/src/types/.waitlist.md +40 -36
  694. package/src/utils/.access-code-client.md +37 -36
  695. package/src/utils/.cn.md +31 -23
  696. package/src/utils/.color-analysis.md +35 -0
  697. package/src/utils/.country-phone-utils.md +39 -0
  698. package/src/utils/.date-formatters.md +19 -18
  699. package/src/utils/.embed-authed-fetch.md +39 -0
  700. package/src/utils/.embed-proxy-auth-storage.md +38 -0
  701. package/src/utils/.fetch-priority.md +41 -0
  702. package/src/utils/.format.md +74 -25
  703. package/src/utils/.generic-domain-utils.md +42 -0
  704. package/src/utils/.image-proxy.md +59 -23
  705. package/src/utils/.index.md +42 -49
  706. package/src/utils/.local-storage-adapter.md +50 -0
  707. package/src/utils/.ods-color-utils.md +55 -38
  708. package/src/utils/.platform-config.md +45 -25
  709. package/src/utils/.scroll-into-view.md +40 -0
  710. package/src/utils/.source-icons.md +53 -0
  711. package/src/utils/.sse-decision-frame.md +46 -0
  712. package/src/utils/dev-sections/.index.md +34 -0
  713. package/src/utils/dev-sections/.openframe-dev-sections.md +49 -0
  714. package/dist/chunk-ZDF6F7ED.cjs.map +0 -1
  715. package/dist/chunk-ZTJVRSN5.js.map +0 -1
  716. package/src/components/.card.md +0 -42
  717. package/src/components/.contact-button.md +0 -30
  718. package/src/components/.drawer.md +0 -46
  719. package/src/components/.fixed-layout-container.md +0 -47
  720. package/src/components/.footer-waitlist-card.md +0 -29
  721. package/src/components/.join-waitlist-cta.md +0 -29
  722. package/src/components/.sheet.md +0 -47
  723. package/src/components/.sliding-panel.md +0 -48
  724. package/src/components/.tooltip.md +0 -48
  725. package/src/components/.use-mobile.md +0 -42
  726. package/src/components/.vendor-compact-card.md +0 -66
  727. package/src/components/.x-button.md +0 -42
  728. package/src/components/features/.github-repo-button.md +0 -40
  729. package/src/components/features/.organization-icon.md +0 -47
  730. package/src/components/features/.organization-selector.md +0 -45
  731. package/src/components/icons/.fleet-icon.md +0 -39
  732. package/src/components/icons/.meshcentral-icon.md +0 -35
  733. package/src/components/icons/.refresh-icon.md +0 -34
  734. package/src/components/icons/.tactical-icon.md +0 -35
  735. package/src/components/ui/.button.md +0 -69
  736. package/src/components/ui/.log-table-row.md +0 -47
  737. package/src/components/ui/.selectable-device-card.md +0 -46
  738. package/src/hooks/.api-hooks-stub.md +0 -45
  739. package/src/hooks/api/.use-product-releases.md +0 -53
  740. package/src/stories/.OrganizationSelector.stories.md +0 -42
  741. package/src/stories/.SelectableDeviceCard.stories.md +0 -30
  742. package/src/utils/.lite-youtube-embed-stub.md +0 -37
  743. package/src/utils/.lite-youtube-embed.md +0 -33
  744. /package/dist/{chunk-3JWIJJ44.js.map → chunk-5OWDOFKK.js.map} +0 -0
  745. /package/dist/{chunk-IK2X5YJU.js.map → chunk-HWY35EAK.js.map} +0 -0
@@ -1,38 +1,41 @@
1
- <!-- source-hash: 081b5c3b13b2ad86e0cfa2882aaec148 -->
2
- A React component that renders a brand association card with an icon, title, description, and external link button. It handles both React component icons and React element icons through a flexible rendering system.
1
+ <!-- source-hash: d0a2530b7492095645c20b724f126d0d -->
2
+ A client-side React card component that displays a brand association item with an icon, title, description, and an external link button.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **BrandAssociationItem**: Interface defining the card's data structure with icon, title, description, button text, and link
7
- - **BrandAssociationCardProps**: Props interface accepting an item and optional className
8
- - **BrandAssociationCard**: Main component that renders the card with responsive styling and icon handling
9
- - **renderIcon()**: Helper function that safely renders both component-type and element-type icons
6
+ ### Interfaces
7
+
8
+ | Interface | Description |
9
+ |-----------|-------------|
10
+ | `BrandAssociationItem` | Data model for a single card — accepts a React component or element as icon, plus title, description, button text, and link URL |
11
+ | `BrandAssociationCardProps` | Props for the card component; wraps `BrandAssociationItem` with an optional `className` |
12
+
13
+ ### `BrandAssociationCard`
14
+
15
+ The primary exported component. Renders a styled card with:
16
+
17
+ - **Icon** — handles both raw `React.ReactElement` and `React.ComponentType` via an internal `renderIcon()` helper
18
+ - **Title** — displayed as an `h3` with ODS primary text styling
19
+ - **Description** — secondary text using DM Sans font
20
+ - **CTA Button** — an outline `Button` with an `ExternalLink` icon that opens the provided `link` in a new tab
10
21
 
11
22
  ## Usage Example
12
23
 
13
24
  ```typescript
14
25
  import { BrandAssociationCard } from './brand-association-card';
15
- import { Github } from 'lucide-react';
16
-
17
- const githubItem = {
18
- icon: Github,
19
- title: "Open Source Projects",
20
- description: "Explore our collection of open source tools and libraries",
21
- buttonText: "GitHub",
22
- link: "https://github.com/company"
26
+ import { ShieldCheck } from 'lucide-react';
27
+
28
+ const item = {
29
+ icon: ShieldCheck,
30
+ title: 'Security Tools',
31
+ description: 'Browse our curated list of security integrations.',
32
+ buttonText: 'Integrations',
33
+ link: 'https://flamingo.run/integrations',
23
34
  };
24
35
 
25
- // Using with a component icon
26
- <BrandAssociationCard item={githubItem} className="rounded-lg" />
27
-
28
- // Using with a React element icon
29
- const elementItem = {
30
- icon: <Github size={120} className="w-20 h-20" />,
31
- title: "Custom Icon",
32
- description: "Example with pre-configured icon element",
33
- buttonText: "Link",
34
- link: "https://example.com"
35
- };
36
+ export default function Page() {
37
+ return <BrandAssociationCard item={item} className="rounded-xl" />;
38
+ }
39
+ ```
36
40
 
37
- <BrandAssociationCard item={elementItem} />
38
- ```
41
+ > **Note:** The `icon` prop accepts either a component type (e.g., a Lucide icon) or a pre-rendered `React.ReactElement`. When passing a component, it is rendered at `120px` size with `w-20 h-20` Tailwind classes applied automatically.
@@ -1,15 +1,17 @@
1
- <!-- source-hash: 17eb20999b7c9f3a5688d1a511823312 -->
2
- A React component library that provides a complete breadcrumb navigation system with accessibility features and customizable styling. Built using Radix UI's Slot component for flexible composition patterns.
1
+ <!-- source-hash: cb8e8ae598fa4e3046aa0545d0ea86b2 -->
2
+ Accessible breadcrumb navigation component built on semantic HTML with full ARIA support, using Radix UI's `Slot` for flexible rendering.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **`Breadcrumb`** - Root navigation wrapper with semantic `nav` element and aria-label
7
- - **`BreadcrumbList`** - Ordered list container with responsive gap styling
8
- - **`BreadcrumbItem`** - Individual breadcrumb item wrapper with flex layout
9
- - **`BreadcrumbLink`** - Clickable breadcrumb link with hover transitions and optional `asChild` prop
10
- - **`BreadcrumbPage`** - Current page indicator with proper ARIA attributes (`aria-current="page"`)
11
- - **`BreadcrumbSeparator`** - Visual separator between items (defaults to ChevronRight icon)
12
- - **`BreadcrumbEllipsis`** - Truncation indicator using MoreHorizontal icon for long breadcrumb chains
6
+ | Export | Type | Description |
7
+ |--------|------|-------------|
8
+ | `Breadcrumb` | `nav` wrapper | Root container with `aria-label="breadcrumb"` |
9
+ | `BreadcrumbList` | `ol` element | Ordered list of breadcrumb items |
10
+ | `BreadcrumbItem` | `li` element | Individual breadcrumb entry wrapper |
11
+ | `BreadcrumbLink` | `a` element | Clickable navigation link; supports `asChild` for custom renderers |
12
+ | `BreadcrumbPage` | `span` element | Current page indicator (`aria-current="page"`, non-interactive) |
13
+ | `BreadcrumbSeparator` | `li` element | Visual divider, defaults to `ChevronRight`; accepts custom children |
14
+ | `BreadcrumbEllipsis` | `span` element | Collapsed items indicator using `MoreHorizontal` icon |
13
15
 
14
16
  ## Usage Example
15
17
 
@@ -22,9 +24,9 @@ import {
22
24
  BreadcrumbPage,
23
25
  BreadcrumbSeparator,
24
26
  BreadcrumbEllipsis,
25
- } from "./breadcrumb"
27
+ } from "@/components/ui/breadcrumb"
26
28
 
27
- export function NavigationBreadcrumb() {
29
+ export function AppBreadcrumb() {
28
30
  return (
29
31
  <Breadcrumb>
30
32
  <BreadcrumbList>
@@ -33,15 +35,15 @@ export function NavigationBreadcrumb() {
33
35
  </BreadcrumbItem>
34
36
  <BreadcrumbSeparator />
35
37
  <BreadcrumbItem>
36
- <BreadcrumbLink href="/products">Products</BreadcrumbLink>
38
+ <BreadcrumbEllipsis />
37
39
  </BreadcrumbItem>
38
40
  <BreadcrumbSeparator />
39
41
  <BreadcrumbItem>
40
- <BreadcrumbEllipsis />
42
+ <BreadcrumbLink href="/settings">Settings</BreadcrumbLink>
41
43
  </BreadcrumbItem>
42
44
  <BreadcrumbSeparator />
43
45
  <BreadcrumbItem>
44
- <BreadcrumbPage>Current Page</BreadcrumbPage>
46
+ <BreadcrumbPage>Profile</BreadcrumbPage>
45
47
  </BreadcrumbItem>
46
48
  </BreadcrumbList>
47
49
  </Breadcrumb>
@@ -49,4 +51,4 @@ export function NavigationBreadcrumb() {
49
51
  }
50
52
  ```
51
53
 
52
- The components use `forwardRef` for proper ref handling and include comprehensive accessibility attributes for screen readers.
54
+ > **`asChild` pattern:** Pass `asChild` to `BreadcrumbLink` to delegate rendering to a child component (e.g., a router `Link`), inheriting all props via Radix UI `Slot`.
@@ -1,42 +1,46 @@
1
- <!-- source-hash: 1c22919d53372a6c9135a3f4f1789493 -->
2
- A full-width checkbox component with label and optional description text, built on Radix UI primitives with dark theme styling optimized for Flamingo's design system.
1
+ <!-- source-hash: 01a25a0740d1f4040be1a2e32f829429 -->
2
+ A styled checkbox component that renders as a full-width interactive block with a label, optional description, and error state built on top of Radix UI's `CheckboxPrimitive`.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **CheckboxBlock**: Main component that renders a full-width checkbox block with label and optional description
7
- - **CheckboxBlockProps**: Interface defining the component's props including `label`, `description`, `checked`, and event handlers
8
- - Uses `@radix-ui/react-checkbox` for accessibility and keyboard navigation
9
- - Integrates with Flamingo's custom `CheckIcon` and `cn` utility for conditional styling
6
+ - **`CheckboxBlock`** A `forwardRef` component wrapping `@radix-ui/react-checkbox` with a card-style block layout
7
+ - **`CheckboxBlockProps`** Interface extending standard checkbox behavior with `label`, `description`, `error`, and `className`
8
+
9
+ | Prop | Type | Description |
10
+ |------|------|-------------|
11
+ | `label` | `string` | Required primary text displayed next to the checkbox |
12
+ | `description` | `React.ReactNode` | Optional secondary text below the label |
13
+ | `error` | `string` | Error message shown below the block; also triggers a red border |
14
+ | `checked` / `defaultChecked` | `boolean` | Controlled/uncontrolled checked state |
15
+ | `onCheckedChange` | `(checked: boolean) => void` | Change handler |
16
+ | `disabled` | `boolean` | Disables interaction and reduces opacity |
10
17
 
11
18
  ## Usage Example
12
19
 
13
20
  ```typescript
14
- import { CheckboxBlock } from "./components/ui/checkbox-block"
15
-
16
- export default function SettingsForm() {
17
- const [emailNotifications, setEmailNotifications] = useState(false)
18
- const [pushNotifications, setPushNotifications] = useState(true)
19
-
20
- return (
21
- <div className="space-y-4">
22
- <CheckboxBlock
23
- id="email-notifications"
24
- label="Email Notifications"
25
- description="Receive updates and alerts via email"
26
- checked={emailNotifications}
27
- onCheckedChange={setEmailNotifications}
28
- />
29
-
30
- <CheckboxBlock
31
- id="push-notifications"
32
- label="Push Notifications"
33
- checked={pushNotifications}
34
- onCheckedChange={setPushNotifications}
35
- disabled={!emailNotifications}
36
- />
37
- </div>
38
- )
39
- }
40
- ```
41
-
42
- The component automatically adjusts height based on whether a description is provided (64px with description, 44px/48px without) and includes hover effects, focus management, and disabled states following Flamingo's dark theme palette.
21
+ import { CheckboxBlock } from "./checkbox-block"
22
+
23
+ // Basic usage
24
+ <CheckboxBlock
25
+ id="terms"
26
+ label="Accept Terms & Conditions"
27
+ description="By checking this, you agree to our terms of service."
28
+ onCheckedChange={(checked) => console.log(checked)}
29
+ />
30
+
31
+ // With error state
32
+ <CheckboxBlock
33
+ id="required-field"
34
+ label="Required option"
35
+ error="This field is required"
36
+ checked={false}
37
+ onCheckedChange={handleChange}
38
+ />
39
+
40
+ // Disabled
41
+ <CheckboxBlock
42
+ id="disabled-option"
43
+ label="Unavailable option"
44
+ disabled
45
+ />
46
+ ```
@@ -1,34 +1,41 @@
1
- <!-- source-hash: 8c9ce312478e577919daf49315fc3e44 -->
2
- A React component that renders a checkbox with an associated title and description text, providing a rich form control with clear labeling and accessibility features.
1
+ <!-- source-hash: c1a54005af93850cd2ca67c81ddf2ca7 -->
2
+ A compound checkbox component that pairs a Radix UI checkbox with a title and description, styled with ODS (OpenFrame Design System) tokens.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **CheckboxWithDescription**: Main component that combines a Radix UI checkbox with title and description labels
7
- - **CheckboxWithDescriptionProps**: TypeScript interface defining the component's props including required fields and optional styling
8
- - Uses Radix UI's CheckboxPrimitive for accessible checkbox functionality
9
- - Integrates with a custom Label component and Lucide React icons
6
+ - **`CheckboxWithDescription`** A `forwardRef` component combining a controlled checkbox, label, and descriptive text in a card-style container
7
+ - **`CheckboxWithDescriptionProps`** Interface defining the component's controlled state and content props
8
+
9
+ ### Props
10
+
11
+ | Prop | Type | Required | Description |
12
+ |------|------|----------|-------------|
13
+ | `id` | `string` | ✅ | Links the label `htmlFor` to the checkbox input |
14
+ | `checked` | `boolean` | ✅ | Controlled checked state |
15
+ | `onCheckedChange` | `(checked: boolean) => void` | ✅ | Change handler |
16
+ | `title` | `string` | ✅ | Primary label text |
17
+ | `description` | `string` | ✅ | Secondary descriptive text |
18
+ | `disabled` | `boolean` | ❌ | Disables interaction and dims the container |
19
+ | `className` | `string` | ❌ | Additional classes for the outer wrapper |
10
20
 
11
21
  ## Usage Example
12
22
 
13
23
  ```typescript
14
- import { CheckboxWithDescription } from "./checkbox-with-description"
15
- import { useState } from "react"
24
+ import { CheckboxWithDescription } from "@/components/ui/checkbox-with-description"
16
25
 
17
26
  function SettingsForm() {
18
- const [notifications, setNotifications] = useState(false)
27
+ const [enabled, setEnabled] = React.useState(false)
19
28
 
20
29
  return (
21
30
  <CheckboxWithDescription
22
- id="email-notifications"
23
- checked={notifications}
24
- onCheckedChange={setNotifications}
31
+ id="notifications"
32
+ checked={enabled}
33
+ onCheckedChange={setEnabled}
25
34
  title="Email Notifications"
26
- description="Receive updates about new features and important announcements via email"
27
- disabled={false}
28
- className="max-w-md"
35
+ description="Receive alerts when a ticket is updated or assigned to you."
29
36
  />
30
37
  )
31
38
  }
32
39
  ```
33
40
 
34
- The component features a card-like design with proper spacing, hover states, and disabled styling. It uses the ODS (design system) color tokens for consistent theming and includes focus management for accessibility compliance.
41
+ > The outer container becomes visually dimmed (`opacity-50`) and non-interactive (`cursor-not-allowed`) when `disabled` is set, applying consistently to both the checkbox and its label.
@@ -1,37 +1,45 @@
1
- <!-- source-hash: 91a5d16d45866ca53bb2b4d38f02c027 -->
2
- A React checkbox component built on Radix UI primitives with custom ODS (Open Design System) styling and a Lucide React check icon indicator.
1
+ <!-- source-hash: 7fc8fb652b97c38a1cb8496cc92c8f34 -->
2
+ Accessible checkbox component built on Radix UI's `CheckboxPrimitive`, styled with ODS (OpenFrame Design System) tokens and a custom checkmark icon.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **Checkbox** - Main checkbox component that forwards refs and extends Radix UI CheckboxPrimitive.Root
7
- - **CheckboxPrimitive.Root** - Base Radix UI checkbox element with accessibility features
8
- - **CheckboxPrimitive.Indicator** - Container for the check icon that appears when checked
9
- - **Check** - Lucide React check icon used as the visual indicator
6
+ - **`Checkbox`** A `forwardRef` wrapper around `@radix-ui/react-checkbox` Root, with ODS-themed styles for default, checked, focused, and disabled states.
10
7
 
11
8
  ## Usage Example
12
9
 
13
10
  ```typescript
14
- import { Checkbox } from "./components/ui/checkbox"
15
-
16
- function MyForm() {
17
- const [isChecked, setIsChecked] = React.useState(false)
11
+ import { Checkbox } from "@/components/ui/checkbox"
18
12
 
13
+ export function AcceptTerms() {
19
14
  return (
20
- <div className="flex items-center space-x-2">
21
- <Checkbox
22
- id="terms"
23
- checked={isChecked}
24
- onCheckedChange={setIsChecked}
25
- />
26
- <label
27
- htmlFor="terms"
28
- className="text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"
29
- >
30
- Accept terms and conditions
31
- </label>
15
+ <div className="flex items-center gap-2">
16
+ <Checkbox id="terms" defaultChecked={false} />
17
+ <label htmlFor="terms">Accept terms and conditions</label>
32
18
  </div>
33
19
  )
34
20
  }
21
+
22
+ // Controlled usage
23
+ export function ControlledCheckbox() {
24
+ const [checked, setChecked] = React.useState(false)
25
+
26
+ return (
27
+ <Checkbox
28
+ checked={checked}
29
+ onCheckedChange={(value) => setChecked(!!value)}
30
+ disabled={false}
31
+ />
32
+ )
33
+ }
35
34
  ```
36
35
 
37
- The component uses ODS design tokens for consistent theming (`ods-border`, `ods-card`, `ods-accent`, `ods-bg`) and includes focus states, disabled states, and proper accessibility support through Radix UI's primitives.
36
+ ## States & Styling
37
+
38
+ | State | Behavior |
39
+ |-------|----------|
40
+ | Default | `border-ods-border`, `bg-ods-card` background |
41
+ | Checked | `bg-ods-accent`, `border-ods-accent` with `CheckboxCheckmarkIcon` (10px) |
42
+ | Focus | `ring-2` with `ods-accent` ring and 2px offset |
43
+ | Disabled | `opacity-50`, `cursor-not-allowed` |
44
+
45
+ All props from `@radix-ui/react-checkbox` Root are forwarded, including `checked`, `defaultChecked`, `onCheckedChange`, and `disabled`.
@@ -1,36 +1,66 @@
1
- <!-- source-hash: 048e0df81b3ecac07325042985354730 -->
2
- A React component that renders an animated circular progress indicator using SVG with customizable styling and smooth transitions.
1
+ <!-- source-hash: b3367d6791779cace17c9e0ea0b291bc -->
2
+ A React SVG-based circular progress ring component with configurable variants, sizes, and overflow behavior for displaying percentage values.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **CircularProgress**: Main component that renders a circular progress ring
7
- - **CircularProgressProps**: Interface defining component properties including percentage, size, colors, and styling options
8
- - **SVG-based rendering**: Uses two overlapping circles to create the progress effect with stroke-dasharray animation
6
+ ### Types
7
+
8
+ | Type | Values | Description |
9
+ |------|--------|-------------|
10
+ | `CircularProgressVariant` | `success` \| `warning` \| `error` \| `info` \| `accent` | Color theme for the progress ring |
11
+ | `CircularProgressOverflow` | `clamp` \| `wrap` | How to handle percentages exceeding 100 |
12
+
13
+ ### Props (`CircularProgressProps`)
14
+
15
+ | Prop | Default | Description |
16
+ |------|---------|-------------|
17
+ | `percentage` | — | Progress value (0–100 in clamp; unbounded in wrap) |
18
+ | `variant` | `'success'` | Color variant using ODS design tokens |
19
+ | `size` | `56` | Diameter in pixels |
20
+ | `strokeWidth` | `10` | Ring stroke thickness in pixels |
21
+ | `showLabel` | `true` | Renders percentage text in the center |
22
+ | `labelFormat` | `'percent'` | `'percent'` → `"70%"`, `'value'` → `"70"` |
23
+ | `overflow` | `'clamp'` | Overflow handling strategy |
24
+
25
+ ### `CircularProgress` (exported component)
26
+
27
+ Renders a two-circle SVG (track + progress arc) rotated -90° so progress starts at the top. The progress arc is animated via `strokeDashoffset`.
9
28
 
10
29
  ## Usage Example
11
30
 
12
31
  ```typescript
13
- import { CircularProgress } from './components/ui/circular-progress'
32
+ // Basic usage
33
+ <CircularProgress percentage={72} />
14
34
 
15
- // Basic usage with default styling
16
- <CircularProgress percentage={75} />
35
+ // Overage warning with wrap mode
36
+ <CircularProgress
37
+ percentage={130}
38
+ variant="warning"
39
+ overflow="wrap"
40
+ />
41
+ // Ring shows 30%, label shows 130%
17
42
 
18
- // Customized progress indicator
19
- <CircularProgress
43
+ // Custom size, no label, accent variant
44
+ <CircularProgress
20
45
  percentage={45}
46
+ variant="accent"
21
47
  size={80}
22
48
  strokeWidth={8}
23
- color="#3b82f6"
24
- trackColor="#e5e7eb"
25
- className="mb-4"
49
+ showLabel={false}
26
50
  />
27
51
 
28
- // Small progress indicator
29
- <CircularProgress
30
- percentage={90}
31
- size={32}
32
- strokeWidth={4}
52
+ // Raw value label (no % suffix)
53
+ <CircularProgress
54
+ percentage={88}
55
+ labelFormat="value"
56
+ variant="info"
33
57
  />
34
58
  ```
35
59
 
36
- The component automatically clamps percentage values between 0-100, rotates the SVG -90 degrees to start from the top, and includes smooth CSS transitions. The center displays the percentage value as text, and all visual aspects (size, colors, stroke width) are fully customizable through props.
60
+ ## Overflow Behavior
61
+
62
+ ```text
63
+ clamp mode: percentage=130 → ring=100%, label="100%"
64
+ wrap mode: percentage=130 → ring=30%, label="130%"
65
+ wrap mode: percentage=200 → ring=100%, label="200%" (exact lap = full ring)
66
+ ```
@@ -1,31 +1,43 @@
1
- <!-- source-hash: 8e5f6a030893b139e570cdef3cee4834 -->
2
- A unified React loading skeleton component that provides consistent loading states across different content types using ODS design tokens. Replaces duplicate loading patterns with a single, configurable component.
1
+ <!-- source-hash: f80d7f61d9427dcf715215adf596f271 -->
2
+ A unified skeleton loading component that replaces duplicate loading patterns across the UI, using ODS design tokens for consistent theming.
3
3
 
4
4
  ## Key Components
5
5
 
6
- - **ContentLoader** - Main component with variant-based rendering (`card`, `form`, `detail`, `list`)
7
- - **ContentLoaderProps** - TypeScript interface for component configuration
8
- - **Specialized Exports** - Pre-configured variants (`CardLoader`, `FormLoader`, `DetailLoader`, `ListLoader`)
6
+ **`ContentLoader`** Main export. Renders an animated pulse skeleton based on the selected `variant`.
7
+
8
+ **`ContentLoaderProps`**
9
+
10
+ | Prop | Type | Default | Description |
11
+ |------|------|---------|-------------|
12
+ | `variant` | `'card' \| 'form' \| 'detail' \| 'list'` | `'card'` | Skeleton layout type |
13
+ | `items` | `number` | `4` | Number of repeated skeleton items |
14
+ | `showTitle` | `boolean` | `true` | Renders a title placeholder bar |
15
+ | `className` | `string` | — | Inner wrapper CSS classes |
16
+ | `containerClassName` | `string` | — | Outer container CSS classes |
17
+
18
+ **Convenience exports** — Pre-bound variants for direct use:
19
+ - `CardLoader` — stat/metric card layout
20
+ - `FormLoader` — labeled input fields layout
21
+ - `DetailLoader` — two-column detail/sidebar layout
22
+ - `ListLoader` — icon + text row list layout
9
23
 
10
24
  ## Usage Example
11
25
 
12
26
  ```typescript
13
- import { ContentLoader, CardLoader, FormLoader } from './content-loader'
27
+ // Generic usage
28
+ import { ContentLoader } from './content-loader';
29
+
30
+ <ContentLoader variant="list" items={6} showTitle={false} />
14
31
 
15
- // Generic usage with variants
16
- <ContentLoader variant="card" items={3} showTitle={true} />
17
- <ContentLoader variant="list" items={5} className="custom-spacing" />
32
+ // Convenience variants
33
+ import { FormLoader, DetailLoader, ListLoader } from './content-loader';
18
34
 
19
- // Pre-configured variants
20
- <CardLoader items={4} showTitle={false} />
21
- <FormLoader items={6} containerClassName="bg-gray-50" />
35
+ // Form skeleton with 3 fields
36
+ <FormLoader items={3} />
22
37
 
23
- // Custom styling
24
- <ContentLoader
25
- variant="detail"
26
- className="my-custom-styles"
27
- containerClassName="p-8"
28
- />
29
- ```
38
+ // Detail page skeleton
39
+ <DetailLoader containerClassName="max-w-4xl" />
30
40
 
31
- The component uses Tailwind CSS classes with ODS design tokens (`bg-bg-surface`, `border-border-primary`) and includes responsive layouts. Each variant renders appropriate skeleton structures - cards show grid layouts, forms display input fields, details use column layouts, and lists show repeated items with avatars and metadata placeholders.
41
+ // List with custom container
42
+ <ListLoader items={8} showTitle={false} containerClassName="px-0" />
43
+ ```
@@ -1,63 +1,52 @@
1
- <!-- source-hash: c39440d94420da7eb66c732ad6e6ba11 -->
2
- A React component library providing cursor-based pagination controls with flexible display options and navigation callbacks for GraphQL-style paginated data.
1
+ <!-- source-hash: 0e65f8e03b416890c9d63ba33ba86a8e -->
2
+ Cursor-based pagination UI components for navigating relay-style paginated data using start/end cursors instead of page numbers.
3
3
 
4
4
  ## Key Components
5
5
 
6
6
  ### `CursorPagination`
7
- Main pagination component with full feature set including:
8
- - **Navigation**: Previous/Next buttons with cursor-based navigation
9
- - **Reset functionality**: Optional first page reset with customizable icon
10
- - **Display options**: Item counts, totals, and responsive layouts
11
- - **Accessibility**: Proper ARIA labels and keyboard navigation
12
- - **States**: Loading, disabled, and compact mode support
7
+ Full-featured pagination bar with optional info text, Previous/Next navigation, and a reset-to-first-page button. Supports both compact and standard layouts.
13
8
 
14
9
  ### `CursorPaginationSimple`
15
- Minimal icon-only pagination variant with:
16
- - **Compact design**: Icon-only buttons for space-constrained layouts
17
- - **Essential navigation**: Basic previous/next/reset functionality
18
- - **Consistent styling**: Ghost button variant with hover states
10
+ Minimal icon-only variant using transparent buttons — ideal for inline or space-constrained contexts like table toolbars.
11
+
12
+ ### `CursorPaginationProps`
13
+ Full interface supporting:
14
+
15
+ | Prop | Type | Description |
16
+ |------|------|-------------|
17
+ | `hasNextPage` | `boolean` | Required. Enables/disables Next button |
18
+ | `hasPreviousPage` | `boolean` | Enables/disables Previous button |
19
+ | `isFirstPage` | `boolean` | Disables reset button when already on page 1 |
20
+ | `startCursor` / `endCursor` | `string \| null` | Relay-style cursors passed back on navigation |
21
+ | `totalCount` / `currentCount` | `number` | Drives the info display text |
22
+ | `onNext` / `onPrevious` / `onReset` | `(cursor) => void` | Navigation callbacks |
23
+ | `compact` | `boolean` | Reduces padding; hides button labels on mobile |
24
+ | `resetButtonIcon` | `'home' \| 'rotate'` | Icon shown on the first-page reset button |
19
25
 
20
26
  ## Usage Example
21
27
 
22
28
  ```typescript
23
- import { CursorPagination } from './cursor-pagination'
24
-
25
- // Full-featured pagination
26
- function DataTable() {
27
- const [pageInfo, setPageInfo] = useState({
28
- hasNextPage: true,
29
- hasPreviousPage: false,
30
- startCursor: null,
31
- endCursor: 'cursor123'
32
- })
33
-
34
- return (
35
- <CursorPagination
36
- hasNextPage={pageInfo.hasNextPage}
37
- hasPreviousPage={pageInfo.hasPreviousPage}
38
- startCursor={pageInfo.startCursor}
39
- endCursor={pageInfo.endCursor}
40
- currentCount={10}
41
- totalCount={100}
42
- itemName="users"
43
- onNext={(cursor) => fetchNextPage(cursor)}
44
- onPrevious={(cursor) => fetchPreviousPage(cursor)}
45
- onReset={() => resetToFirstPage()}
46
- showInfo={true}
47
- compact={false}
48
- />
49
- )
50
- }
51
-
52
- // Minimal pagination
53
- function CompactTable() {
54
- return (
55
- <CursorPaginationSimple
56
- hasNextPage={true}
57
- hasPreviousPage={false}
58
- onNext={() => goToNext()}
59
- onReset={() => resetPagination()}
60
- />
61
- )
62
- }
29
+ import { CursorPagination, CursorPaginationSimple } from './cursor-pagination'
30
+
31
+ // Full pagination bar
32
+ <CursorPagination
33
+ hasNextPage={pageInfo.hasNextPage}
34
+ hasPreviousPage={pageInfo.hasPreviousPage}
35
+ startCursor={pageInfo.startCursor}
36
+ endCursor={pageInfo.endCursor}
37
+ currentCount={items.length}
38
+ totalCount={totalCount}
39
+ itemName="tickets"
40
+ onNext={(cursor) => fetchPage({ after: cursor })}
41
+ onReset={() => fetchPage({})}
42
+ compact
43
+ />
44
+
45
+ // Icon-only minimal variant
46
+ <CursorPaginationSimple
47
+ hasNextPage={pageInfo.hasNextPage}
48
+ onNext={() => fetchPage({ after: pageInfo.endCursor })}
49
+ onReset={() => fetchPage({})}
50
+ isFirstPage={isFirstPage}
51
+ />
63
52
  ```