xertica-ui 2.2.1 → 2.4.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 (708) hide show
  1. package/CHANGELOG.md +564 -525
  2. package/README.md +417 -382
  3. package/bin/cli.ts +1244 -748
  4. package/bin/generate-tokens.ts +262 -262
  5. package/bin/language-config.ts +5 -8
  6. package/components/assets/xertica-orbe-animation.ts +1162 -1162
  7. package/components/assistant/code-block/CodeBlock.tsx +268 -268
  8. package/components/assistant/code-block/code-block.stories.tsx +57 -57
  9. package/components/assistant/code-block/code-block.test.tsx +44 -44
  10. package/components/assistant/code-block/index.ts +1 -1
  11. package/components/assistant/formatted-document/FormattedDocument.tsx +147 -147
  12. package/components/assistant/formatted-document/formatted-document.stories.tsx +51 -51
  13. package/components/assistant/formatted-document/formatted-document.test.tsx +42 -42
  14. package/components/assistant/formatted-document/index.ts +1 -1
  15. package/components/assistant/index.ts +6 -6
  16. package/components/assistant/markdown-message/MarkdownMessage.tsx +152 -152
  17. package/components/assistant/markdown-message/index.ts +1 -1
  18. package/components/assistant/markdown-message/markdown-message.stories.tsx +50 -50
  19. package/components/assistant/markdown-message/markdown-message.test.tsx +33 -33
  20. package/components/assistant/modern-chat-input/ModernChatInput.tsx +17 -7
  21. package/components/assistant/modern-chat-input/index.ts +1 -1
  22. package/components/assistant/modern-chat-input/modern-chat-input.stories.tsx +131 -131
  23. package/components/assistant/modern-chat-input/modern-chat-input.test.tsx +79 -79
  24. package/components/assistant/xertica-assistant/index.ts +3 -3
  25. package/components/assistant/xertica-assistant/parts/AssistantCollapsedView.tsx +99 -99
  26. package/components/assistant/xertica-assistant/parts/AssistantConversationList.tsx +104 -106
  27. package/components/assistant/xertica-assistant/parts/AssistantDocumentEditor.tsx +81 -81
  28. package/components/assistant/xertica-assistant/parts/AssistantFeedbackDialog.tsx +88 -78
  29. package/components/assistant/xertica-assistant/parts/AssistantHeader.tsx +75 -75
  30. package/components/assistant/xertica-assistant/parts/AssistantMessageBubble.tsx +564 -560
  31. package/components/assistant/xertica-assistant/parts/AssistantTabBar.tsx +67 -67
  32. package/components/assistant/xertica-assistant/parts/AssistantTypingIndicator.tsx +41 -41
  33. package/components/assistant/xertica-assistant/parts/AssistantWelcomeScreen.tsx +103 -103
  34. package/components/assistant/xertica-assistant/parts/index.ts +16 -16
  35. package/components/assistant/xertica-assistant/types.ts +134 -134
  36. package/components/assistant/xertica-assistant/use-assistant.ts +615 -615
  37. package/components/assistant/xertica-assistant/xertica-assistant.stories.tsx +407 -407
  38. package/components/assistant/xertica-assistant/xertica-assistant.test.tsx +65 -65
  39. package/components/assistant/xertica-assistant/xertica-assistant.tsx +611 -613
  40. package/components/blocks/card-patterns/ActivityCard.tsx +100 -100
  41. package/components/blocks/card-patterns/FeatureCard.tsx +109 -109
  42. package/components/blocks/card-patterns/FeatureCardSkeleton.tsx +1 -6
  43. package/components/blocks/card-patterns/NotificationCard.tsx +140 -140
  44. package/components/blocks/card-patterns/ProfileCard.tsx +112 -114
  45. package/components/blocks/card-patterns/ProjectCard.tsx +123 -123
  46. package/components/blocks/card-patterns/ProjectCardSkeleton.tsx +1 -6
  47. package/components/blocks/card-patterns/QuickActionCard.tsx +68 -68
  48. package/components/blocks/card-patterns/card-patterns.mdx +123 -123
  49. package/components/blocks/card-patterns/card-patterns.stories.tsx +594 -594
  50. package/components/blocks/card-patterns/index.ts +29 -29
  51. package/components/blocks/index.ts +1 -1
  52. package/components/brand/branding/branding.stories.tsx +57 -57
  53. package/components/brand/index.ts +6 -6
  54. package/components/brand/language-selector/index.ts +1 -1
  55. package/components/brand/language-selector/language-selector.mdx +126 -126
  56. package/components/brand/language-selector/language-selector.stories.tsx +1 -4
  57. package/components/brand/theme-toggle/ThemeToggle.tsx +74 -70
  58. package/components/brand/theme-toggle/index.ts +1 -1
  59. package/components/brand/theme-toggle/theme-toggle.stories.tsx +34 -34
  60. package/components/brand/theme-toggle/theme-toggle.test.tsx +34 -34
  61. package/components/brand/xertica-logo/XerticaLogo.stories.tsx +82 -82
  62. package/components/brand/xertica-logo/XerticaLogo.tsx +104 -104
  63. package/components/brand/xertica-logo/index.ts +1 -1
  64. package/components/brand/xertica-logo/xertica-logo.test.tsx +26 -26
  65. package/components/brand/xertica-orbe/XerticaOrbe.tsx +1927 -1927
  66. package/components/brand/xertica-orbe/index.ts +1 -1
  67. package/components/brand/xertica-orbe/xertica-orbe.stories.tsx +40 -40
  68. package/components/brand/xertica-orbe/xertica-orbe.test.tsx +19 -19
  69. package/components/brand/xertica-provider/XerticaProvider.tsx +1 -4
  70. package/components/brand/xertica-provider/index.ts +1 -1
  71. package/components/brand/xertica-provider/xertica-provider.test.tsx +74 -74
  72. package/components/brand/xertica-xlogo/XerticaXLogo.stories.tsx +79 -79
  73. package/components/brand/xertica-xlogo/XerticaXLogo.tsx +65 -65
  74. package/components/brand/xertica-xlogo/index.ts +1 -1
  75. package/components/brand/xertica-xlogo/xertica-xlogo.test.tsx +16 -16
  76. package/components/examples/ApiKeyMapExample.tsx +71 -71
  77. package/components/examples/DrawingMapExample.tsx +565 -565
  78. package/components/examples/FilterableMapExample.tsx +393 -393
  79. package/components/examples/LocationPickerExample.tsx +348 -348
  80. package/components/examples/MapExamples.tsx +268 -268
  81. package/components/examples/MapGmpExample.tsx +169 -169
  82. package/components/examples/MapShowcase.tsx +471 -471
  83. package/components/examples/RouteMapExamples.tsx +329 -329
  84. package/components/examples/SidebarLogoExample.tsx +65 -65
  85. package/components/examples/SimpleFilterableMap.tsx +219 -219
  86. package/components/examples/index.ts +45 -45
  87. package/components/figma/ImageWithFallback.tsx +27 -27
  88. package/components/hooks/index.ts +13 -13
  89. package/components/hooks/use-layout-shortcuts.ts +43 -43
  90. package/components/index.ts +86 -90
  91. package/components/layout/header/header.stories.tsx +204 -204
  92. package/components/layout/header/header.test.tsx +75 -75
  93. package/components/layout/header/header.tsx +349 -349
  94. package/components/layout/header/index.ts +1 -1
  95. package/components/layout/index.ts +2 -2
  96. package/components/layout/sidebar/index.ts +3 -3
  97. package/components/layout/sidebar/sidebar.stories.tsx +586 -586
  98. package/components/layout/sidebar/sidebar.test.tsx +76 -76
  99. package/components/layout/sidebar/sidebar.tsx +1079 -1073
  100. package/components/layout/sidebar/use-sidebar.ts +104 -104
  101. package/components/media/FloatingMediaWrapper.tsx +371 -371
  102. package/components/media/audio-player/AudioPlayer.stories.tsx +124 -124
  103. package/components/media/audio-player/AudioPlayer.test.tsx +106 -106
  104. package/components/media/audio-player/AudioPlayer.tsx +767 -765
  105. package/components/media/audio-player/index.ts +1 -1
  106. package/components/media/audio-player/use-audio-player.ts +312 -312
  107. package/components/media/index.ts +3 -3
  108. package/components/media/video-player/VideoPlayer.stories.tsx +98 -98
  109. package/components/media/video-player/VideoPlayer.test.tsx +73 -73
  110. package/components/media/video-player/VideoPlayer.tsx +310 -310
  111. package/components/media/video-player/index.ts +1 -1
  112. package/components/pages/forgot-password-page/ForgotPasswordPage.stories.tsx +24 -24
  113. package/components/pages/forgot-password-page/ForgotPasswordPage.tsx +188 -188
  114. package/components/pages/forgot-password-page/forgot-password-page.test.tsx +45 -45
  115. package/components/pages/forgot-password-page/index.ts +1 -1
  116. package/components/pages/home-content/HomeContent.stories.tsx +43 -43
  117. package/components/pages/home-content/HomeContent.tsx +120 -120
  118. package/components/pages/home-content/index.ts +1 -1
  119. package/components/pages/home-page/HomePage.stories.tsx +39 -39
  120. package/components/pages/home-page/HomePage.tsx +78 -74
  121. package/components/pages/home-page/home-page.test.tsx +53 -53
  122. package/components/pages/home-page/index.ts +1 -1
  123. package/components/pages/index.ts +8 -8
  124. package/components/pages/login-page/LoginPage.stories.tsx +39 -39
  125. package/components/pages/login-page/LoginPage.tsx +218 -216
  126. package/components/pages/login-page/index.ts +1 -1
  127. package/components/pages/login-page/login-page.test.tsx +63 -63
  128. package/components/pages/reset-password-page/ResetPasswordPage.stories.tsx +24 -24
  129. package/components/pages/reset-password-page/ResetPasswordPage.tsx +243 -239
  130. package/components/pages/reset-password-page/index.ts +1 -1
  131. package/components/pages/template-content/TemplateContent.stories.tsx +43 -43
  132. package/components/pages/template-content/TemplateContent.tsx +1354 -1235
  133. package/components/pages/template-content/index.ts +1 -1
  134. package/components/pages/template-page/TemplatePage.stories.tsx +39 -39
  135. package/components/pages/template-page/TemplatePage.tsx +62 -62
  136. package/components/pages/template-page/index.ts +1 -1
  137. package/components/pages/template-page/template-page.test.tsx +52 -52
  138. package/components/pages/verify-email-page/VerifyEmailPage.stories.tsx +41 -41
  139. package/components/pages/verify-email-page/VerifyEmailPage.tsx +206 -206
  140. package/components/pages/verify-email-page/index.ts +1 -1
  141. package/components/public-api-smoke.test.tsx +52 -52
  142. package/components/shared/CustomTooltipContent.tsx +48 -48
  143. package/components/shared/assistant-utils.test.ts +16 -16
  144. package/components/shared/assistant-utils.ts +225 -225
  145. package/components/shared/error-boundary.stories.tsx +114 -132
  146. package/components/shared/error-boundary.tsx +150 -154
  147. package/components/shared/error-fallbacks.tsx +222 -226
  148. package/components/shared/layout-constants.ts +8 -8
  149. package/components/shared/navigation.ts +35 -35
  150. package/components/shared/use-mobile.test.ts +16 -16
  151. package/components/shared/use-mobile.ts +36 -36
  152. package/components/shared/utils.test.ts +14 -14
  153. package/components/shared/utils.ts +6 -6
  154. package/components/ui/accordion/accordion.stories.tsx +105 -105
  155. package/components/ui/accordion/accordion.test.tsx +59 -59
  156. package/components/ui/accordion/accordion.tsx +77 -77
  157. package/components/ui/accordion/index.ts +1 -1
  158. package/components/ui/alert/alert.stories.tsx +86 -86
  159. package/components/ui/alert/alert.test.tsx +53 -53
  160. package/components/ui/alert/alert.tsx +93 -93
  161. package/components/ui/alert/index.ts +1 -1
  162. package/components/ui/alert-dialog/alert-dialog.stories.tsx +84 -84
  163. package/components/ui/alert-dialog/alert-dialog.test.tsx +70 -70
  164. package/components/ui/alert-dialog/alert-dialog.tsx +149 -149
  165. package/components/ui/alert-dialog/index.ts +1 -1
  166. package/components/ui/aspect-ratio/aspect-ratio.stories.tsx +46 -46
  167. package/components/ui/aspect-ratio/aspect-ratio.test.tsx +28 -28
  168. package/components/ui/aspect-ratio/aspect-ratio.tsx +20 -20
  169. package/components/ui/aspect-ratio/index.ts +1 -1
  170. package/components/ui/assistant-chart/AssistantChart.tsx +64 -64
  171. package/components/ui/assistant-chart/assistant-chart.stories.tsx +44 -44
  172. package/components/ui/assistant-chart/assistant-chart.test.tsx +46 -46
  173. package/components/ui/assistant-chart/index.ts +1 -1
  174. package/components/ui/avatar/avatar.stories.tsx +86 -86
  175. package/components/ui/avatar/avatar.test.tsx +55 -55
  176. package/components/ui/avatar/avatar.tsx +71 -71
  177. package/components/ui/avatar/index.ts +1 -1
  178. package/components/ui/badge/badge.stories.tsx +72 -72
  179. package/components/ui/badge/badge.test.tsx +40 -40
  180. package/components/ui/badge/badge.tsx +58 -58
  181. package/components/ui/badge/index.ts +1 -1
  182. package/components/ui/breadcrumb/breadcrumb.stories.tsx +123 -123
  183. package/components/ui/breadcrumb/breadcrumb.test.tsx +70 -70
  184. package/components/ui/breadcrumb/breadcrumb.tsx +114 -114
  185. package/components/ui/breadcrumb/index.ts +1 -1
  186. package/components/ui/button/button.stories.tsx +183 -183
  187. package/components/ui/button/button.test.tsx +64 -64
  188. package/components/ui/button/button.tsx +98 -98
  189. package/components/ui/button/index.ts +1 -1
  190. package/components/ui/calendar/calendar.stories.tsx +108 -108
  191. package/components/ui/calendar/calendar.test.tsx +53 -53
  192. package/components/ui/calendar/calendar.tsx +230 -230
  193. package/components/ui/calendar/index.ts +1 -1
  194. package/components/ui/card/card.stories.tsx +301 -301
  195. package/components/ui/card/card.test.tsx +55 -55
  196. package/components/ui/card/card.tsx +83 -83
  197. package/components/ui/card/index.ts +1 -1
  198. package/components/ui/carousel/carousel.stories.tsx +80 -80
  199. package/components/ui/carousel/carousel.test.tsx +75 -75
  200. package/components/ui/carousel/carousel.tsx +242 -242
  201. package/components/ui/carousel/index.ts +1 -1
  202. package/components/ui/chart/chart.stories.tsx +1328 -1328
  203. package/components/ui/chart/chart.test.tsx +178 -178
  204. package/components/ui/chart/chart.tsx +2232 -2232
  205. package/components/ui/chart/index.ts +1 -1
  206. package/components/ui/checkbox/checkbox.stories.tsx +109 -109
  207. package/components/ui/checkbox/checkbox.test.tsx +49 -49
  208. package/components/ui/checkbox/checkbox.tsx +68 -68
  209. package/components/ui/checkbox/index.ts +1 -1
  210. package/components/ui/collapsible/collapsible.stories.tsx +45 -45
  211. package/components/ui/collapsible/collapsible.test.tsx +51 -51
  212. package/components/ui/collapsible/collapsible.tsx +32 -32
  213. package/components/ui/collapsible/index.ts +1 -1
  214. package/components/ui/command/command.stories.tsx +134 -134
  215. package/components/ui/command/command.test.tsx +48 -48
  216. package/components/ui/command/command.tsx +163 -163
  217. package/components/ui/command/index.ts +1 -1
  218. package/components/ui/context-menu/context-menu.stories.tsx +76 -76
  219. package/components/ui/context-menu/context-menu.test.tsx +61 -61
  220. package/components/ui/context-menu/context-menu.tsx +236 -236
  221. package/components/ui/context-menu/index.ts +1 -1
  222. package/components/ui/dialog/dialog.stories.tsx +174 -174
  223. package/components/ui/dialog/dialog.test.tsx +78 -78
  224. package/components/ui/dialog/dialog.tsx +189 -189
  225. package/components/ui/dialog/index.ts +1 -1
  226. package/components/ui/drawer/drawer.stories.tsx +71 -71
  227. package/components/ui/drawer/drawer.test.tsx +67 -67
  228. package/components/ui/drawer/drawer.tsx +146 -146
  229. package/components/ui/drawer/index.ts +1 -1
  230. package/components/ui/dropdown-menu/dropdown-menu.stories.tsx +156 -156
  231. package/components/ui/dropdown-menu/dropdown-menu.test.tsx +62 -62
  232. package/components/ui/dropdown-menu/dropdown-menu.tsx +240 -240
  233. package/components/ui/dropdown-menu/index.ts +1 -1
  234. package/components/ui/empty/empty.stories.tsx +85 -85
  235. package/components/ui/empty/empty.test.tsx +31 -31
  236. package/components/ui/empty/empty.tsx +88 -88
  237. package/components/ui/empty/index.ts +1 -1
  238. package/components/ui/file-upload/file-upload.stories.tsx +144 -144
  239. package/components/ui/file-upload/file-upload.test.tsx +65 -65
  240. package/components/ui/file-upload/file-upload.tsx +142 -142
  241. package/components/ui/file-upload/index.ts +2 -2
  242. package/components/ui/file-upload/use-file-upload.ts +177 -177
  243. package/components/ui/form/form.stories.tsx +85 -85
  244. package/components/ui/form/form.test.tsx +75 -75
  245. package/components/ui/form/form.tsx +163 -163
  246. package/components/ui/form/index.ts +1 -1
  247. package/components/ui/google-maps-loader/google-maps-loader.test.tsx +35 -35
  248. package/components/ui/google-maps-loader/google-maps-loader.tsx +465 -465
  249. package/components/ui/google-maps-loader/index.ts +1 -1
  250. package/components/ui/hover-card/hover-card.stories.tsx +61 -61
  251. package/components/ui/hover-card/hover-card.test.tsx +48 -48
  252. package/components/ui/hover-card/hover-card.tsx +50 -50
  253. package/components/ui/hover-card/index.ts +1 -1
  254. package/components/ui/index.ts +400 -400
  255. package/components/ui/input/index.ts +1 -1
  256. package/components/ui/input/input.stories.tsx +153 -153
  257. package/components/ui/input/input.test.tsx +47 -47
  258. package/components/ui/input/input.tsx +57 -57
  259. package/components/ui/input-otp/index.ts +1 -1
  260. package/components/ui/input-otp/input-otp.stories.tsx +120 -120
  261. package/components/ui/input-otp/input-otp.test.tsx +74 -74
  262. package/components/ui/input-otp/input-otp.tsx +101 -101
  263. package/components/ui/label/index.ts +1 -1
  264. package/components/ui/label/label.stories.tsx +74 -74
  265. package/components/ui/label/label.test.tsx +45 -45
  266. package/components/ui/label/label.tsx +53 -53
  267. package/components/ui/map/index.ts +1 -1
  268. package/components/ui/map/map.stories.tsx +86 -86
  269. package/components/ui/map/map.test.tsx +82 -82
  270. package/components/ui/map/map.tsx +506 -506
  271. package/components/ui/map/mock.test.tsx +13 -13
  272. package/components/ui/map-config/index.ts +1 -1
  273. package/components/ui/map-config/map-config.ts +18 -18
  274. package/components/ui/map-layers/index.ts +1 -1
  275. package/components/ui/map-layers/map-layers.test.tsx +48 -48
  276. package/components/ui/map-layers/map-layers.tsx +126 -126
  277. package/components/ui/map.exports/index.ts +1 -1
  278. package/components/ui/map.exports/map.exports.ts +31 -31
  279. package/components/ui/menubar/index.ts +1 -1
  280. package/components/ui/menubar/menubar.stories.tsx +130 -130
  281. package/components/ui/menubar/menubar.test.tsx +53 -53
  282. package/components/ui/menubar/menubar.tsx +265 -265
  283. package/components/ui/navigation-menu/index.ts +1 -1
  284. package/components/ui/navigation-menu/navigation-menu.stories.tsx +126 -126
  285. package/components/ui/navigation-menu/navigation-menu.test.tsx +47 -47
  286. package/components/ui/navigation-menu/navigation-menu.tsx +165 -165
  287. package/components/ui/notification-badge/index.ts +1 -1
  288. package/components/ui/notification-badge/notification-badge.stories.tsx +66 -66
  289. package/components/ui/notification-badge/notification-badge.test.tsx +61 -61
  290. package/components/ui/notification-badge/notification-badge.tsx +91 -91
  291. package/components/ui/page-header/index.ts +1 -1
  292. package/components/ui/page-header/page-header.stories.tsx +69 -69
  293. package/components/ui/page-header/page-header.test.tsx +37 -37
  294. package/components/ui/page-header/page-header.tsx +124 -124
  295. package/components/ui/pagination/index.ts +3 -3
  296. package/components/ui/pagination/pagination.stories.tsx +210 -210
  297. package/components/ui/pagination/pagination.test.tsx +63 -63
  298. package/components/ui/pagination/pagination.tsx +140 -140
  299. package/components/ui/pagination/use-pagination.ts +173 -173
  300. package/components/ui/popover/index.ts +1 -1
  301. package/components/ui/popover/popover.stories.tsx +73 -73
  302. package/components/ui/popover/popover.test.tsx +48 -48
  303. package/components/ui/popover/popover.tsx +54 -54
  304. package/components/ui/progress/index.ts +1 -1
  305. package/components/ui/progress/progress.stories.tsx +55 -55
  306. package/components/ui/progress/progress.test.tsx +23 -23
  307. package/components/ui/progress/progress.tsx +68 -68
  308. package/components/ui/radio-group/index.ts +1 -1
  309. package/components/ui/radio-group/radio-group.stories.tsx +114 -114
  310. package/components/ui/radio-group/radio-group.test.tsx +78 -78
  311. package/components/ui/radio-group/radio-group.tsx +93 -93
  312. package/components/ui/rating/index.ts +1 -1
  313. package/components/ui/rating/rating.stories.tsx +50 -50
  314. package/components/ui/rating/rating.test.tsx +48 -48
  315. package/components/ui/rating/rating.tsx +145 -145
  316. package/components/ui/resizable/index.ts +1 -1
  317. package/components/ui/resizable/resizable.stories.tsx +88 -88
  318. package/components/ui/resizable/resizable.test.tsx +61 -61
  319. package/components/ui/resizable/resizable.tsx +452 -452
  320. package/components/ui/rich-text-editor/index.ts +7 -7
  321. package/components/ui/rich-text-editor/rich-text-editor.stories.tsx +290 -290
  322. package/components/ui/rich-text-editor/rich-text-editor.test.tsx +86 -86
  323. package/components/ui/rich-text-editor/rich-text-editor.tsx +634 -634
  324. package/components/ui/rich-text-editor/use-rich-text-editor.ts +453 -453
  325. package/components/ui/route-map/index.ts +1 -1
  326. package/components/ui/route-map/route-map.stories.tsx +48 -48
  327. package/components/ui/route-map/route-map.test.tsx +108 -108
  328. package/components/ui/route-map/route-map.tsx +349 -349
  329. package/components/ui/scroll-area/index.ts +1 -1
  330. package/components/ui/scroll-area/scroll-area.stories.tsx +31 -31
  331. package/components/ui/scroll-area/scroll-area.test.tsx +27 -27
  332. package/components/ui/scroll-area/scroll-area.tsx +70 -70
  333. package/components/ui/search/index.ts +1 -1
  334. package/components/ui/search/search.stories.tsx +107 -107
  335. package/components/ui/search/search.test.tsx +67 -67
  336. package/components/ui/search/search.tsx +141 -141
  337. package/components/ui/select/index.ts +1 -1
  338. package/components/ui/select/select.stories.tsx +163 -163
  339. package/components/ui/select/select.test.tsx +99 -99
  340. package/components/ui/select/select.tsx +195 -195
  341. package/components/ui/separator/index.ts +1 -1
  342. package/components/ui/separator/separator.stories.tsx +55 -55
  343. package/components/ui/separator/separator.test.tsx +23 -23
  344. package/components/ui/separator/separator.tsx +39 -39
  345. package/components/ui/sheet/index.ts +1 -1
  346. package/components/ui/sheet/sheet.stories.tsx +93 -93
  347. package/components/ui/sheet/sheet.test.tsx +62 -62
  348. package/components/ui/sheet/sheet.tsx +149 -149
  349. package/components/ui/simple-map/index.ts +1 -1
  350. package/components/ui/simple-map/simple-map.stories.tsx +44 -44
  351. package/components/ui/simple-map/simple-map.test.tsx +36 -36
  352. package/components/ui/simple-map/simple-map.tsx +92 -92
  353. package/components/ui/skeleton/index.ts +1 -1
  354. package/components/ui/skeleton/skeleton.stories.tsx +36 -36
  355. package/components/ui/skeleton/skeleton.test.tsx +19 -19
  356. package/components/ui/skeleton/skeleton.tsx +25 -25
  357. package/components/ui/slider/index.ts +1 -1
  358. package/components/ui/slider/slider.stories.tsx +44 -44
  359. package/components/ui/slider/slider.test.tsx +25 -25
  360. package/components/ui/slider/slider.tsx +66 -66
  361. package/components/ui/sonner/index.ts +1 -1
  362. package/components/ui/sonner/sonner.stories.tsx +41 -41
  363. package/components/ui/sonner/sonner.test.tsx +24 -24
  364. package/components/ui/sonner/sonner.tsx +74 -74
  365. package/components/ui/stats-card/index.ts +2 -2
  366. package/components/ui/stats-card/stats-card-skeleton.tsx +1 -3
  367. package/components/ui/stats-card/stats-card.stories.tsx +99 -99
  368. package/components/ui/stats-card/stats-card.test.tsx +34 -34
  369. package/components/ui/stats-card/stats-card.tsx +93 -93
  370. package/components/ui/stepper/index.ts +3 -3
  371. package/components/ui/stepper/stepper.stories.tsx +171 -171
  372. package/components/ui/stepper/stepper.test.tsx +47 -47
  373. package/components/ui/stepper/stepper.tsx +190 -190
  374. package/components/ui/stepper/use-stepper.ts +139 -139
  375. package/components/ui/switch/index.ts +1 -1
  376. package/components/ui/switch/switch.stories.tsx +93 -93
  377. package/components/ui/switch/switch.test.tsx +44 -44
  378. package/components/ui/switch/switch.tsx +70 -70
  379. package/components/ui/table/index.ts +1 -1
  380. package/components/ui/table/table.stories.tsx +114 -114
  381. package/components/ui/table/table.test.tsx +43 -43
  382. package/components/ui/table/table.tsx +104 -104
  383. package/components/ui/tabs/index.ts +1 -1
  384. package/components/ui/tabs/tabs.stories.tsx +140 -140
  385. package/components/ui/tabs/tabs.test.tsx +50 -50
  386. package/components/ui/tabs/tabs.tsx +66 -66
  387. package/components/ui/textarea/index.ts +1 -1
  388. package/components/ui/textarea/textarea.stories.tsx +69 -69
  389. package/components/ui/textarea/textarea.test.tsx +41 -41
  390. package/components/ui/textarea/textarea.tsx +61 -61
  391. package/components/ui/timeline/index.ts +1 -1
  392. package/components/ui/timeline/timeline.stories.tsx +97 -97
  393. package/components/ui/timeline/timeline.test.tsx +53 -53
  394. package/components/ui/timeline/timeline.tsx +124 -124
  395. package/components/ui/toggle/index.ts +1 -1
  396. package/components/ui/toggle/toggle.stories.tsx +56 -56
  397. package/components/ui/toggle/toggle.test.tsx +32 -32
  398. package/components/ui/toggle/toggle.tsx +55 -55
  399. package/components/ui/toggle-group/index.ts +1 -1
  400. package/components/ui/toggle-group/toggle-group.stories.tsx +66 -66
  401. package/components/ui/toggle-group/toggle-group.test.tsx +47 -47
  402. package/components/ui/toggle-group/toggle-group.tsx +79 -79
  403. package/components/ui/tooltip/index.ts +1 -1
  404. package/components/ui/tooltip/tooltip.stories.tsx +83 -83
  405. package/components/ui/tooltip/tooltip.test.tsx +39 -39
  406. package/components/ui/tooltip/tooltip.tsx +69 -69
  407. package/components/ui/tree-view/index.ts +4 -4
  408. package/components/ui/tree-view/tree-view.stories.tsx +154 -154
  409. package/components/ui/tree-view/tree-view.test.tsx +58 -58
  410. package/components/ui/tree-view/tree-view.tsx +171 -171
  411. package/components/ui/tree-view/use-tree-view.ts +237 -237
  412. package/components.json +892 -892
  413. package/contexts/ApiKeyContext.test.tsx +26 -26
  414. package/contexts/ApiKeyContext.tsx +196 -196
  415. package/contexts/AssistenteContext.test.tsx +17 -17
  416. package/contexts/AssistenteContext.tsx +113 -113
  417. package/contexts/AuthContext.tsx +121 -118
  418. package/contexts/BrandColorsContext.test.tsx +21 -21
  419. package/contexts/BrandColorsContext.tsx +251 -251
  420. package/contexts/LanguageContext.tsx +1 -2
  421. package/contexts/LayoutContext.test.tsx +29 -29
  422. package/contexts/LayoutContext.tsx +140 -140
  423. package/contexts/ThemeContext.test.tsx +38 -38
  424. package/contexts/ThemeContext.tsx +111 -111
  425. package/contexts/index.ts +8 -8
  426. package/contexts/theme-data.ts +340 -340
  427. package/dist/AssistantChart-COGiOV-g.cjs +3541 -0
  428. package/dist/AssistantChart-CWX1OWNM.js +3373 -0
  429. package/dist/AudioPlayer-9psiEucT.cjs +1282 -0
  430. package/dist/AudioPlayer-Dp2bD1Gk.js +1278 -0
  431. package/dist/BrandColorsContext-DZT7JjeD.js +659 -0
  432. package/dist/BrandColorsContext-awnBCmC4.cjs +666 -0
  433. package/dist/CodeBlock-DYkTfR0f.js +221 -0
  434. package/dist/CodeBlock-EOvp9cVu.cjs +223 -0
  435. package/dist/CustomTooltipContent-BhdIeBEg.cjs +54 -0
  436. package/dist/CustomTooltipContent-CNbVB2NS.js +33 -0
  437. package/dist/FeatureCard-BZ4CYxFf.cjs +497 -0
  438. package/dist/FeatureCard-DNycVGwT.js +485 -0
  439. package/dist/FeatureCardSkeleton-DZqc96mt.js +27 -0
  440. package/dist/FeatureCardSkeleton-pTa0YNKP.cjs +29 -0
  441. package/dist/LayoutContext-BEq_-n98.cjs +96 -0
  442. package/dist/LayoutContext-DNl1xSoX.js +92 -0
  443. package/dist/ThemeContext-CMD3z2Dz.cjs +1930 -0
  444. package/dist/ThemeContext-x_F2zsnv.js +1923 -0
  445. package/dist/VerifyEmailPage-BJjAMUTW.js +3223 -0
  446. package/dist/VerifyEmailPage-Bv8Ah_TK.cjs +3235 -0
  447. package/dist/VerifyEmailPage-CkBYfsNy.cjs +3232 -0
  448. package/dist/VerifyEmailPage-Cyl55sJb.js +3226 -0
  449. package/dist/VerifyEmailPage-X14vhdyl.js +3296 -0
  450. package/dist/VerifyEmailPage-u_Dn7t1U.cjs +3305 -0
  451. package/dist/XerticaOrbe-Uk2JML1-.cjs +1927 -0
  452. package/dist/XerticaOrbe-jA5T2iOk.js +1925 -0
  453. package/dist/XerticaProvider-BErr83Bg.js +42 -0
  454. package/dist/XerticaProvider-CwOkHxiT.cjs +44 -0
  455. package/dist/XerticaProvider-DUOJg9iX.js +49 -0
  456. package/dist/XerticaProvider-Dl_b72_l.cjs +51 -0
  457. package/dist/XerticaXLogo-BX3ueACh.js +255 -0
  458. package/dist/XerticaXLogo-mqjoBiLI.js +252 -0
  459. package/dist/XerticaXLogo-qBPhwK3g.cjs +260 -0
  460. package/dist/XerticaXLogo-uQgwns_E.cjs +257 -0
  461. package/dist/alert-dialog-DhwPioBa.cjs +885 -0
  462. package/dist/alert-dialog-DqlRW_An.js +831 -0
  463. package/dist/assistant.cjs.js +8 -4
  464. package/dist/assistant.es.js +5 -11
  465. package/dist/avatar-3kO2Anrp.js +54 -0
  466. package/dist/avatar-BCM7YQRC.cjs +77 -0
  467. package/dist/blocks.cjs.js +9 -4
  468. package/dist/blocks.es.js +2 -16
  469. package/dist/brand.cjs.js +10 -5
  470. package/dist/brand.es.js +3 -11
  471. package/dist/breadcrumb-BKtHF4gk.cjs +98 -0
  472. package/dist/breadcrumb-ifNsA7Zl.js +90 -0
  473. package/dist/button-0BlA47It.cjs +85 -0
  474. package/dist/button-DZHzN1Gd.js +62 -0
  475. package/dist/cli.js +471 -93
  476. package/dist/components/brand/theme-toggle/ThemeToggle.d.ts +1 -1
  477. package/dist/components/index.d.ts +1 -1
  478. package/dist/dropdown-menu-BMcykFDf.cjs +225 -0
  479. package/dist/dropdown-menu-Dn_eV2Xb.js +190 -0
  480. package/dist/google-maps-loader-BCe58h9D.js +308 -0
  481. package/dist/google-maps-loader-casMyxlo.cjs +316 -0
  482. package/dist/hooks.cjs.js +12 -8
  483. package/dist/hooks.es.js +10 -27
  484. package/dist/index-9GWd0qxq.cjs +12 -0
  485. package/dist/index-BabBx2pa.js +6 -0
  486. package/dist/index.cjs.js +37 -32
  487. package/dist/index.es.js +30 -363
  488. package/dist/input-C_UiS2Py.cjs +152 -0
  489. package/dist/input-cc-PTD4R.js +123 -0
  490. package/dist/layout.cjs.js +10 -6
  491. package/dist/layout.es.js +7 -9
  492. package/dist/media.cjs.js +8 -3
  493. package/dist/media.es.js +1 -6
  494. package/dist/pages.cjs.js +8 -3
  495. package/dist/pages.es.js +1 -11
  496. package/dist/progress-C7Lti5wo.js +80 -0
  497. package/dist/progress-Cqwxbqs1.cjs +103 -0
  498. package/dist/rich-text-editor-DqLICivI.js +2832 -0
  499. package/dist/rich-text-editor-DxO1Hz3a.cjs +2903 -0
  500. package/dist/select-CH6v_KcQ.cjs +161 -0
  501. package/dist/select-D-xvCZK2.js +130 -0
  502. package/dist/sidebar-3XyzjVBw.js +792 -0
  503. package/dist/sidebar-B4ZWaMrE.js +792 -0
  504. package/dist/sidebar-BS1p2V7t.cjs +795 -0
  505. package/dist/sidebar-DyYvgyBj.cjs +795 -0
  506. package/dist/skeleton-DjiHerJn.cjs +87 -0
  507. package/dist/skeleton-DtR5tkYe.js +78 -0
  508. package/dist/slider-B00b9SVK.cjs +78 -0
  509. package/dist/slider-DQCNUUMj.js +56 -0
  510. package/dist/sonner-B-jWlik1.cjs +68 -0
  511. package/dist/sonner-C9tiqj4f.js +47 -0
  512. package/dist/tooltip-D8n9UYoU.cjs +72 -0
  513. package/dist/tooltip-RtbSmPYJ.js +48 -0
  514. package/dist/ui.cjs.js +23 -18
  515. package/dist/ui.es.js +16 -303
  516. package/dist/use-audio-player-B78fd2ct.js +188 -0
  517. package/dist/use-audio-player-DGvhPrgR.cjs +190 -0
  518. package/dist/use-mobile-BdXTRb0Z.cjs +51 -0
  519. package/dist/use-mobile-Ce2cBAQe.js +29 -0
  520. package/dist/xertica-assistant-B1NaSFFj.js +2173 -0
  521. package/dist/xertica-assistant-B687qEPU.js +2165 -0
  522. package/dist/xertica-assistant-CIaUlbIt.cjs +2180 -0
  523. package/dist/xertica-assistant-sOHwTgIP.cjs +2172 -0
  524. package/dist/xertica-ui.css +1 -1
  525. package/docs/ai-usage.md +195 -195
  526. package/docs/architecture-improvements.md +456 -456
  527. package/docs/architecture.md +312 -306
  528. package/docs/components/accordion.md +109 -109
  529. package/docs/components/alert-dialog.md +127 -127
  530. package/docs/components/alert.md +106 -106
  531. package/docs/components/aspect-ratio.md +58 -58
  532. package/docs/components/assistant-chart.md +47 -47
  533. package/docs/components/assistant.md +428 -426
  534. package/docs/components/audio-player.md +167 -167
  535. package/docs/components/avatar.md +101 -101
  536. package/docs/components/badge.md +84 -84
  537. package/docs/components/branding.md +252 -252
  538. package/docs/components/breadcrumb.md +104 -104
  539. package/docs/components/button.md +156 -156
  540. package/docs/components/calendar.md +141 -141
  541. package/docs/components/card-patterns.md +447 -445
  542. package/docs/components/card.md +245 -245
  543. package/docs/components/carousel.md +100 -100
  544. package/docs/components/chart.md +638 -638
  545. package/docs/components/checkbox.md +88 -88
  546. package/docs/components/code-block.md +105 -105
  547. package/docs/components/collapsible.md +86 -86
  548. package/docs/components/command.md +113 -113
  549. package/docs/components/context-menu.md +81 -81
  550. package/docs/components/dialog.md +198 -198
  551. package/docs/components/drawer.md +105 -105
  552. package/docs/components/dropdown-menu.md +127 -127
  553. package/docs/components/empty.md +127 -127
  554. package/docs/components/error-boundary.md +201 -191
  555. package/docs/components/file-upload.md +189 -189
  556. package/docs/components/floating-media-wrapper.md +63 -63
  557. package/docs/components/form.md +177 -177
  558. package/docs/components/formatted-document.md +105 -105
  559. package/docs/components/google-maps-loader.md +44 -44
  560. package/docs/components/header.md +177 -177
  561. package/docs/components/hooks.md +432 -430
  562. package/docs/components/hover-card.md +86 -86
  563. package/docs/components/image-with-fallback.md +107 -107
  564. package/docs/components/input-otp.md +95 -95
  565. package/docs/components/input.md +130 -130
  566. package/docs/components/label.md +69 -69
  567. package/docs/components/language-selector.md +20 -16
  568. package/docs/components/map-layers.md +138 -138
  569. package/docs/components/map.md +84 -84
  570. package/docs/components/markdown-message.md +47 -47
  571. package/docs/components/menubar.md +89 -89
  572. package/docs/components/modern-chat-input.md +164 -164
  573. package/docs/components/navigation-menu.md +83 -83
  574. package/docs/components/notification-badge.md +78 -78
  575. package/docs/components/page-header.md +93 -93
  576. package/docs/components/pages.md +323 -309
  577. package/docs/components/pagination.md +334 -334
  578. package/docs/components/popover.md +116 -116
  579. package/docs/components/progress.md +103 -103
  580. package/docs/components/radio-group.md +133 -133
  581. package/docs/components/rating.md +77 -77
  582. package/docs/components/resizable.md +84 -84
  583. package/docs/components/rich-text-editor.md +255 -255
  584. package/docs/components/route-map.md +124 -124
  585. package/docs/components/scroll-area.md +58 -58
  586. package/docs/components/search.md +87 -87
  587. package/docs/components/select.md +144 -144
  588. package/docs/components/separator.md +58 -58
  589. package/docs/components/sheet.md +122 -122
  590. package/docs/components/sidebar.md +314 -314
  591. package/docs/components/simple-map.md +51 -51
  592. package/docs/components/skeleton.md +99 -99
  593. package/docs/components/slider.md +84 -84
  594. package/docs/components/sonner.md +115 -115
  595. package/docs/components/stats-card.md +120 -120
  596. package/docs/components/stepper.md +268 -268
  597. package/docs/components/switch.md +106 -106
  598. package/docs/components/table.md +138 -138
  599. package/docs/components/tabs.md +117 -117
  600. package/docs/components/textarea.md +86 -86
  601. package/docs/components/theme-toggle.md +73 -73
  602. package/docs/components/timeline.md +121 -121
  603. package/docs/components/toggle-group.md +68 -68
  604. package/docs/components/toggle.md +62 -62
  605. package/docs/components/tooltip.md +116 -116
  606. package/docs/components/tree-view.md +238 -238
  607. package/docs/components/use-mobile.md +96 -96
  608. package/docs/components/video-player.md +68 -68
  609. package/docs/components/xertica-logo.md +36 -36
  610. package/docs/components/xertica-orbe.md +35 -35
  611. package/docs/components/xertica-provider.md +65 -65
  612. package/docs/components/xertica-xlogo.md +35 -35
  613. package/docs/decision-tree.md +293 -293
  614. package/docs/doc-audit.md +244 -243
  615. package/docs/form-sizing.md +162 -162
  616. package/docs/getting-started.md +616 -591
  617. package/docs/guidelines.md +330 -328
  618. package/docs/i18n.md +61 -57
  619. package/docs/installation.md +268 -267
  620. package/docs/layout.md +143 -143
  621. package/docs/llms.md +295 -295
  622. package/docs/patterns/analytics.md +194 -194
  623. package/docs/patterns/crud.md +149 -149
  624. package/docs/patterns/dashboard.md +138 -138
  625. package/docs/patterns/detail-page.md +296 -296
  626. package/docs/patterns/form.md +241 -241
  627. package/docs/patterns/login.md +156 -156
  628. package/docs/patterns/settings.md +368 -368
  629. package/docs/patterns/wizard.md +213 -213
  630. package/docs/state-management.md +289 -289
  631. package/guidelines/Guidelines.md +409 -406
  632. package/hooks/useTheme.test.tsx +16 -16
  633. package/hooks/useTheme.ts +4 -4
  634. package/imports/Podcast.tsx +540 -540
  635. package/imports/XerticaAi.tsx +46 -46
  636. package/imports/XerticaX.tsx +15 -15
  637. package/imports/svg-aueiaqngck.ts +20 -20
  638. package/imports/svg-v9krss1ozd.ts +23 -23
  639. package/imports/svg-vhrdofe3qe.ts +6 -6
  640. package/llms-compact.txt +2 -1
  641. package/llms.txt +2 -1
  642. package/mcp/resources.json +22 -22
  643. package/mcp/tools.json +35 -35
  644. package/package.json +219 -213
  645. package/scripts/ai-validator.ts +91 -91
  646. package/scripts/cleanup-case-dupes.ts +62 -62
  647. package/scripts/generate-ai-manifests.ts +107 -107
  648. package/styles/globals.css +13 -13
  649. package/styles/xertica/app-overrides/chat.css +61 -61
  650. package/styles/xertica/app-overrides/scrollbar.css +33 -33
  651. package/styles/xertica/base.css +90 -71
  652. package/styles/xertica/integrations/google-maps.css +76 -76
  653. package/styles/xertica/integrations/sonner.css +73 -73
  654. package/styles/xertica/theme-map.css +102 -99
  655. package/styles/xertica/tokens.css +240 -236
  656. package/templates/CLAUDE.md +16 -1
  657. package/templates/eslint.config.js +26 -26
  658. package/templates/guidelines/Guidelines.md +577 -553
  659. package/templates/package.json +69 -69
  660. package/templates/postcss.config.js +6 -6
  661. package/templates/src/app/App.tsx +46 -46
  662. package/templates/src/app/components/AppLayout.tsx +55 -55
  663. package/templates/src/app/components/AuthGuard.tsx +131 -82
  664. package/templates/src/app/context/AuthContext.tsx +108 -108
  665. package/templates/src/features/assistant/index.ts +5 -5
  666. package/templates/src/features/auth/index.ts +4 -4
  667. package/templates/src/features/auth/ui/AuthPageShell.tsx +32 -32
  668. package/templates/src/features/auth/ui/ForgotPasswordContent.tsx +70 -72
  669. package/templates/src/features/auth/ui/LoginContent.tsx +92 -92
  670. package/templates/src/features/auth/ui/ResetPasswordContent.tsx +6 -2
  671. package/templates/src/features/auth/ui/SocialLoginButtons.tsx +78 -78
  672. package/templates/src/features/auth/ui/VerifyEmailContent.tsx +2 -6
  673. package/templates/src/features/home/data/mock.ts +41 -35
  674. package/templates/src/features/home/index.ts +11 -11
  675. package/templates/src/features/home/store/dashboardStore.ts +25 -25
  676. package/templates/src/features/home/ui/HomeContent.tsx +117 -119
  677. package/templates/src/features/template/index.ts +5 -5
  678. package/templates/src/features/template/ui/CrudTemplate.tsx +1 -4
  679. package/templates/src/features/template/ui/LoginTemplate.tsx +1 -1
  680. package/templates/src/features/template/ui/TemplateContent.tsx +29 -21
  681. package/templates/src/locales/en/pages/templates.json +17 -17
  682. package/templates/src/locales/es/pages/templates.json +17 -17
  683. package/templates/src/locales/pt-BR/pages/templates.json +17 -17
  684. package/templates/src/main.tsx +11 -11
  685. package/templates/src/pages/AssistantPage.tsx +26 -20
  686. package/templates/src/pages/ForgotPasswordPage.tsx +6 -6
  687. package/templates/src/pages/HomePage.tsx +53 -49
  688. package/templates/src/pages/LoginPage.tsx +10 -10
  689. package/templates/src/pages/ResetPasswordPage.tsx +6 -6
  690. package/templates/src/pages/TemplatePage.tsx +28 -28
  691. package/templates/src/pages/VerifyEmailPage.tsx +6 -6
  692. package/templates/src/shared/config/navigation.ts +19 -19
  693. package/templates/src/shared/error-boundary.tsx +150 -154
  694. package/templates/src/shared/error-fallbacks.tsx +222 -226
  695. package/templates/src/shared/lib/auth.ts +20 -20
  696. package/templates/src/shared/types/auth.ts +3 -3
  697. package/templates/src/styles/index.css +95 -95
  698. package/templates/src/styles/xertica/tokens.css +240 -236
  699. package/templates/tsconfig.json +25 -25
  700. package/templates/tsconfig.node.json +12 -12
  701. package/templates/vite-env.d.ts +1 -1
  702. package/templates/vite.config.js +20 -20
  703. package/templates/vite.config.ts +54 -51
  704. package/utils/color-utils.ts +72 -72
  705. package/utils/demo-responses.test.ts +10 -10
  706. package/utils/demo-responses.ts +151 -151
  707. package/utils/gemini.test.ts +25 -25
  708. package/utils/gemini.ts +155 -155
package/components.json CHANGED
@@ -1,892 +1,892 @@
1
- [
2
- {
3
- "name": "accordion",
4
- "docPath": "docs/components/accordion.md",
5
- "sourcePath": "components/ui/accordion/index.ts",
6
- "description": "A vertically stacked set of collapsible sections. Each section has a clickable trigger header that reveals or hides its content. Ideal for FAQs, configuration settings, and dense navigation trees where only one (or a few) section needs to be visible at a time.",
7
- "category": "ui",
8
- "import": "xertica-ui/ui",
9
- "keywords": ["collapse", "expand", "faq", "collapsible-list"],
10
- "relatedComponents": ["collapsible", "tabs"]
11
- },
12
- {
13
- "name": "alert-dialog",
14
- "docPath": "docs/components/alert-dialog.md",
15
- "sourcePath": "components/ui/alert-dialog/index.ts",
16
- "description": "A specialized modal for **irreversible destructive actions** — delete, revoke, reset, permanently disable. Unlike `Dialog`, `AlertDialog` enforces that the user must explicitly confirm or cancel; clicking outside does not dismiss it.",
17
- "category": "ui",
18
- "import": "xertica-ui/ui",
19
- "keywords": ["confirm", "confirmation", "destructive", "delete-confirm"],
20
- "relatedComponents": ["dialog", "button"]
21
- },
22
- {
23
- "name": "alert",
24
- "docPath": "docs/components/alert.md",
25
- "sourcePath": "components/ui/alert/index.ts",
26
- "description": "An inline message banner used to communicate status, feedback, or important contextual information directly within the page content — without interrupting the user flow. Unlike `Sonner` (toast notifications), alerts are persistent and visible at all times.",
27
- "category": "ui",
28
- "import": "xertica-ui/ui",
29
- "keywords": ["banner", "info-banner", "warning-banner", "inline-message"],
30
- "relatedComponents": ["sonner", "alert-dialog"]
31
- },
32
- {
33
- "name": "aspect-ratio",
34
- "docPath": "docs/components/aspect-ratio.md",
35
- "sourcePath": "components/ui/aspect-ratio/index.ts",
36
- "description": "A container that maintains a fixed width-to-height ratio regardless of the available space. Prevents layout shifts when loading images, videos, or charts. Use when content must always fill a specific shape.",
37
- "category": "ui",
38
- "import": "xertica-ui/ui",
39
- "keywords": ["ratio", "media-ratio", "image-container", "16-9"],
40
- "relatedComponents": ["video-player", "card"]
41
- },
42
- {
43
- "name": "assistant-chart",
44
- "docPath": "docs/components/assistant-chart.md",
45
- "sourcePath": "components/ui/assistant-chart/index.ts",
46
- "description": "A specialized data visualization component optimized for display within the AI Assistant panel. It provides a pre-configured responsive BarChart using the library's design system tokens.",
47
- "category": "ui",
48
- "import": "xertica-ui/ui",
49
- "keywords": ["ai-chart", "assistant-visualization", "chat-chart"],
50
- "relatedComponents": ["chart", "xertica-assistant"]
51
- },
52
- {
53
- "name": "audio-player",
54
- "docPath": "docs/components/audio-player.md",
55
- "sourcePath": "components/media/audio-player/index.ts",
56
- "description": "A global, floating audio playback bar designed for process tracking and podcast consumption. It features a responsive layout that automatically adjusts to the state of the sidebar and AI assistant.",
57
- "category": "media",
58
- "import": "xertica-ui/media",
59
- "keywords": ["audio", "podcast", "music", "sound", "playback"],
60
- "relatedComponents": ["video-player", "floating-media-wrapper"]
61
- },
62
- {
63
- "name": "avatar",
64
- "docPath": "docs/components/avatar.md",
65
- "sourcePath": "components/ui/avatar/index.ts",
66
- "description": "Displays a user's identity visually — either as a profile photo or as an initials-based fallback. Used in headers, sidebars, comment threads, and table rows to represent people.",
67
- "category": "ui",
68
- "import": "xertica-ui/ui",
69
- "keywords": ["profile-picture", "user-image", "initials"],
70
- "relatedComponents": ["header", "table"]
71
- },
72
- {
73
- "name": "badge",
74
- "docPath": "docs/components/badge.md",
75
- "sourcePath": "components/ui/badge/index.ts",
76
- "description": "A compact, inline label used to communicate status, category, or count. Badges are always non-interactive by default — they display information, not trigger actions.",
77
- "category": "ui",
78
- "import": "xertica-ui/ui",
79
- "keywords": ["tag", "label", "status", "chip", "pill"],
80
- "relatedComponents": ["notification-badge", "table", "card"]
81
- },
82
- {
83
- "name": "breadcrumb",
84
- "docPath": "docs/components/breadcrumb.md",
85
- "sourcePath": "components/ui/breadcrumb/index.ts",
86
- "description": "A hierarchical navigation trail showing the user's current position in the application's page structure. Rendered in the `Header` component via the `breadcrumbs` prop. Each item in the chain can optionally be a clickable link.",
87
- "category": "ui",
88
- "import": "xertica-ui/ui",
89
- "keywords": ["breadcrumbs", "navigation-path", "location-trail"],
90
- "relatedComponents": ["header", "page-header"]
91
- },
92
- {
93
- "name": "button",
94
- "docPath": "docs/components/button.md",
95
- "sourcePath": "components/ui/button/index.ts",
96
- "description": "The primary interaction trigger. Use `Button` for any user-initiated action: form submission, navigation triggers, dialog openers, and destructive confirmations. It supports multiple visual variants, sizes, icon-only mode, and the `asChild` pattern for composing with router links.",
97
- "category": "ui",
98
- "import": "xertica-ui/ui",
99
- "keywords": ["btn", "action", "click", "submit", "trigger", "cta"],
100
- "relatedComponents": ["alert-dialog", "dialog", "form", "dropdown-menu"]
101
- },
102
- {
103
- "name": "calendar",
104
- "docPath": "docs/components/calendar.md",
105
- "sourcePath": "components/ui/calendar/index.ts",
106
- "description": "A date picker calendar that renders a monthly grid of selectable days. Built on `react-day-picker`. Almost always used inside a `<Popover>` to provide an accessible, accessible date input. Supports single date selection, multiple dates, and date ranges.",
107
- "category": "ui",
108
- "import": "xertica-ui/ui",
109
- "keywords": ["date-picker", "datepicker", "date-input"],
110
- "relatedComponents": ["popover", "input"]
111
- },
112
- {
113
- "name": "card",
114
- "docPath": "docs/components/card.md",
115
- "sourcePath": "components/ui/card/index.ts",
116
- "description": "The primary structural container for all content blocks in the application. `Card` provides elevation (via box shadow), background/border tokens, and a consistent internal padding system. It is the single correct way to create content panels — never recreate it with raw `<div>` utility classes.",
117
- "category": "ui",
118
- "import": "xertica-ui/ui",
119
- "keywords": ["container", "panel", "surface", "box"],
120
- "relatedComponents": ["stats-card", "scroll-area", "separator"]
121
- },
122
- {
123
- "name": "carousel",
124
- "docPath": "docs/components/carousel.md",
125
- "sourcePath": "components/ui/carousel/index.ts",
126
- "description": "A horizontal content slider that lets users navigate through a set of panels or cards one at a time. Built on `embla-carousel-react`. Provides Previous/Next navigation buttons and optional indicator dots.",
127
- "category": "ui",
128
- "import": "xertica-ui/ui",
129
- "keywords": ["slider", "slides", "horizontal-scroll", "embla"],
130
- "relatedComponents": ["card"]
131
- },
132
- {
133
- "name": "chart",
134
- "docPath": "docs/components/chart.md",
135
- "sourcePath": "components/ui/chart/index.ts",
136
- "description": "Xertica UI provides a `ChartContainer` wrapper and dashboard-ready chart components built on top of **Recharts** for theme-aware, token-driven rendering. The chart system uses a `ChartConfig` object to define series labels and colors via CSS variables, ensuring full dark-mode support without hard-coded hex values.",
137
- "category": "ui",
138
- "import": "xertica-ui/ui",
139
- "keywords": [
140
- "graph",
141
- "visualization",
142
- "recharts",
143
- "bar-chart",
144
- "line-chart",
145
- "horizontal-bar-chart",
146
- "dashboard-chart",
147
- "donut-chart",
148
- "combo-chart"
149
- ],
150
- "relatedComponents": ["card", "stats-card"]
151
- },
152
- {
153
- "name": "checkbox",
154
- "docPath": "docs/components/checkbox.md",
155
- "sourcePath": "components/ui/checkbox/index.ts",
156
- "description": "A binary toggle that lets users select or deselect a single option, or mark multiple independent options in a list. Built on Radix UI with accessible keyboard behavior and ARIA roles.",
157
- "category": "ui",
158
- "import": "xertica-ui/ui",
159
- "keywords": ["check", "boolean", "tick", "multi-select"],
160
- "relatedComponents": ["switch", "radio-group", "toggle"]
161
- },
162
- {
163
- "name": "collapsible",
164
- "docPath": "docs/components/collapsible.md",
165
- "sourcePath": "components/ui/collapsible/index.ts",
166
- "description": "A single expandable/collapsible content section with a trigger header. Unlike `<Accordion>`, `Collapsible` is a standalone element — it has no sibling items and no managed \"only one open\" behavior.",
167
- "category": "ui",
168
- "import": "xertica-ui/ui",
169
- "keywords": ["expand", "collapse", "toggle-section"],
170
- "relatedComponents": ["accordion"]
171
- },
172
- {
173
- "name": "command",
174
- "docPath": "docs/components/command.md",
175
- "sourcePath": "components/ui/command/index.ts",
176
- "description": "A command palette for searching and executing actions via keyboard — triggered by `⌘K` / `Ctrl+K`. Provides a searchable, filterable list of commands, navigation items, and quick actions. Built on `cmdk`.",
177
- "category": "ui",
178
- "import": "xertica-ui/ui",
179
- "keywords": ["command-palette", "cmd-k", "spotlight", "keyboard-shortcut"],
180
- "relatedComponents": ["search", "dialog"]
181
- },
182
- {
183
- "name": "context-menu",
184
- "docPath": "docs/components/context-menu.md",
185
- "sourcePath": "components/ui/context-menu/index.ts",
186
- "description": "A menu that appears when the user right-clicks (or long-presses on mobile) a trigger area. Provides a familiar OS-native contextual menu pattern for power-user interactions. Built on Radix UI.",
187
- "category": "ui",
188
- "import": "xertica-ui/ui",
189
- "keywords": ["right-click", "contextmenu", "right-click-menu"],
190
- "relatedComponents": ["dropdown-menu", "menubar"]
191
- },
192
- {
193
- "name": "dialog",
194
- "docPath": "docs/components/dialog.md",
195
- "sourcePath": "components/ui/dialog/index.ts",
196
- "description": "A modal overlay that interrupts the page flow to capture user attention for critical confirmations, data entry, or detailed views. Built on Radix UI Dialog with managed focus trapping, keyboard escape, and backdrop click-to-dismiss.",
197
- "category": "ui",
198
- "import": "xertica-ui/ui",
199
- "keywords": ["modal", "popup", "overlay", "lightbox"],
200
- "relatedComponents": ["alert-dialog", "sheet", "drawer", "popover"]
201
- },
202
- {
203
- "name": "drawer",
204
- "docPath": "docs/components/drawer.md",
205
- "sourcePath": "components/ui/drawer/index.ts",
206
- "description": "A panel that slides in from the bottom edge of the screen — the mobile-optimized equivalent of `<Sheet>`. Drawers are the standard interaction pattern for panels on mobile, providing a more natural bottom-to-top gesture feel.",
207
- "category": "ui",
208
- "import": "xertica-ui/ui",
209
- "keywords": ["bottom-sheet", "mobile-panel", "slide-up"],
210
- "relatedComponents": ["sheet", "dialog"]
211
- },
212
- {
213
- "name": "dropdown-menu",
214
- "docPath": "docs/components/dropdown-menu.md",
215
- "sourcePath": "components/ui/dropdown-menu/index.ts",
216
- "description": "A triggered contextual menu that appears anchored below (or beside) a trigger element. Used for row actions in tables, secondary navigation options, and grouped control menus. Built on Radix UI with full keyboard navigation.",
217
- "category": "ui",
218
- "import": "xertica-ui/ui",
219
- "keywords": ["action-menu", "options-menu", "kebab-menu"],
220
- "relatedComponents": ["context-menu", "button", "table"]
221
- },
222
- {
223
- "name": "empty",
224
- "docPath": "docs/components/empty.md",
225
- "sourcePath": "components/ui/empty/index.ts",
226
- "description": "A structured zero-state container rendered when a list, table, or search returns no results. Uses a composable primitive pattern (`Empty + EmptyIcon + EmptyTitle + EmptyDescription + EmptyAction`) to provide a flexible, consistent empty-state experience.",
227
- "category": "ui",
228
- "import": "xertica-ui/ui",
229
- "keywords": ["empty-state", "zero-state", "no-results", "no-data"],
230
- "relatedComponents": ["skeleton", "table"]
231
- },
232
- {
233
- "name": "file-upload",
234
- "docPath": "docs/components/file-upload.md",
235
- "sourcePath": "components/ui/file-upload/index.ts",
236
- "description": "A drag-and-drop file input component that accepts one or multiple files. Renders a dropzone area with visual feedback on drag, displays selected file names, and validates against allowed MIME types and file size limits.",
237
- "category": "ui",
238
- "import": "xertica-ui/ui",
239
- "keywords": ["drop-zone", "file-input", "drag-drop", "upload"],
240
- "relatedComponents": ["input", "form", "button"]
241
- },
242
- {
243
- "name": "form",
244
- "docPath": "docs/components/form.md",
245
- "sourcePath": "components/ui/form/index.ts",
246
- "description": "`Form` is the integration layer between `react-hook-form` and Xertica UI components. It provides a context-aware set of wrappers (`FormField`, `FormItem`, `FormLabel`, `FormControl`, `FormMessage`, `FormDescription`) that automatically connect to form state, display validation errors, and manage ARIA attributes.",
247
- "category": "ui",
248
- "import": "xertica-ui/ui",
249
- "keywords": ["react-hook-form", "form-validation", "zod", "form-fields"],
250
- "relatedComponents": ["input", "select", "checkbox", "button", "label"]
251
- },
252
- {
253
- "name": "google-maps-loader",
254
- "docPath": "docs/components/google-maps-loader.md",
255
- "sourcePath": "components/ui/google-maps-loader/index.ts",
256
- "description": "The utility provider and hook responsible for the lazy-loading and initialization of the Google Maps JavaScript API. It is automatically managed by the `XerticaProvider`.",
257
- "category": "ui",
258
- "import": "xertica-ui/ui",
259
- "keywords": ["maps-api", "google-maps-api", "maps-provider"],
260
- "relatedComponents": ["map", "xertica-provider"]
261
- },
262
- {
263
- "name": "header",
264
- "docPath": "docs/components/header.md",
265
- "sourcePath": "components/layout/header/index.ts",
266
- "description": "The `Header` is the global application top bar — a fixed-height strip (`64px`) rendered at the top of the application shell. It provides a standardized navigation trail (breadcrumbs) and universal system controls.",
267
- "category": "layout",
268
- "import": "xertica-ui/layout",
269
- "keywords": ["top-bar", "app-bar", "navbar", "topnav"],
270
- "relatedComponents": ["sidebar", "breadcrumb", "page-header"]
271
- },
272
- {
273
- "name": "hover-card",
274
- "docPath": "docs/components/hover-card.md",
275
- "sourcePath": "components/ui/hover-card/index.ts",
276
- "description": "A floating content panel that appears when hovering over a trigger element — designed for previewing additional information without navigating away. Unlike `Tooltip` (short text hints), `HoverCard` can contain rich content: user profiles, link previews, image thumbnails.",
277
- "category": "ui",
278
- "import": "xertica-ui/ui",
279
- "keywords": ["preview-card", "rich-hover", "link-preview"],
280
- "relatedComponents": ["tooltip", "popover"]
281
- },
282
- {
283
- "name": "input-otp",
284
- "docPath": "docs/components/input-otp.md",
285
- "sourcePath": "components/ui/input-otp/index.ts",
286
- "description": "A one-time password / PIN code input that renders a segmented grid of individual character slots. Designed for MFA flows, email verification codes, and any numeric code entry.",
287
- "category": "ui",
288
- "import": "xertica-ui/ui",
289
- "keywords": ["otp", "pin", "mfa", "verification-code"],
290
- "relatedComponents": ["input", "form"]
291
- },
292
- {
293
- "name": "input",
294
- "docPath": "docs/components/input.md",
295
- "sourcePath": "components/ui/input/index.ts",
296
- "description": "The standard text field component. Use it for all single-line text inputs: names, emails, search queries, codes. Integrates seamlessly with `react-hook-form` via the `{...field}` spread pattern.",
297
- "category": "ui",
298
- "import": "xertica-ui/ui",
299
- "keywords": ["text-field", "form-field", "text-input"],
300
- "relatedComponents": ["label", "form", "search", "textarea"]
301
- },
302
- {
303
- "name": "label",
304
- "docPath": "docs/components/label.md",
305
- "sourcePath": "components/ui/label/index.ts",
306
- "description": "An accessible form field label that is always associated with a specific input via `htmlFor`. Automatically applies styling that visually communicates field relationships and disabled states. Used in every form — standalone or via `<FormLabel>` inside the `Form` system.",
307
- "category": "ui",
308
- "import": "xertica-ui/ui",
309
- "keywords": ["form-label", "field-label", "input-label"],
310
- "relatedComponents": ["input", "form", "checkbox"]
311
- },
312
- {
313
- "name": "language-selector",
314
- "docPath": "docs/components/language-selector.md",
315
- "sourcePath": "components/brand/language-selector/index.ts",
316
- "description": "A self-contained dropdown for switching the interface language. Wired to `LanguageContext` and `i18next`: changing the selection persists to localStorage, calls `i18n.changeLanguage`, and invalidates the React Query cache. Auto-hides when only one language is configured. The list of languages is runtime-configurable via the `availableLanguages` prop on `<XerticaProvider>`.",
317
- "category": "brand",
318
- "import": "xertica-ui/brand",
319
- "keywords": ["i18n", "locale", "language", "internationalization"],
320
- "relatedComponents": ["header", "theme-toggle"]
321
- },
322
- {
323
- "name": "map",
324
- "docPath": "docs/components/map.md",
325
- "sourcePath": "components/ui/map/index.ts",
326
- "description": "A Google Maps integration component that renders an interactive map with markers, polygons, and custom controls. Powered by the Google Maps JavaScript API via `@vis.gl/react-google-maps`.",
327
- "category": "ui",
328
- "import": "xertica-ui/ui",
329
- "keywords": ["google-maps", "map-view", "geolocation", "markers"],
330
- "relatedComponents": ["route-map", "simple-map"]
331
- },
332
- {
333
- "name": "markdown-message",
334
- "docPath": "docs/components/markdown-message.md",
335
- "sourcePath": "components/assistant/markdown-message/index.ts",
336
- "description": "The primary renderer for AI-generated text content within the Xertica Assistant. It converts raw Markdown into themed React components with support for syntax highlighting, lists, and tables.",
337
- "category": "assistant",
338
- "import": "xertica-ui/assistant",
339
- "keywords": ["markdown", "md-renderer", "ai-message", "chat-message"],
340
- "relatedComponents": ["xertica-assistant", "code-block"]
341
- },
342
- {
343
- "name": "menubar",
344
- "docPath": "docs/components/menubar.md",
345
- "sourcePath": "components/ui/menubar/index.ts",
346
- "description": "An application-style horizontal menu bar with multiple dropdown menus — similar to the menu bars in desktop applications (File, Edit, View…). Less common in web apps but useful for power-user tools and editors.",
347
- "category": "ui",
348
- "import": "xertica-ui/ui",
349
- "keywords": ["application-menu", "horizontal-menu", "file-edit-view"],
350
- "relatedComponents": ["navigation-menu", "dropdown-menu"]
351
- },
352
- {
353
- "name": "navigation-menu",
354
- "docPath": "docs/components/navigation-menu.md",
355
- "sourcePath": "components/ui/navigation-menu/index.ts",
356
- "description": "A horizontal navigation bar designed for top-level application sections. Supports dropdown sub-menus with rich content panels. Use it as a secondary top navigation when the primary navigation is in the `<Sidebar>`. Built on Radix UI NavigationMenu.",
357
- "category": "ui",
358
- "import": "xertica-ui/ui",
359
- "keywords": ["top-nav", "horizontal-nav", "mega-menu"],
360
- "relatedComponents": ["sidebar", "tabs", "breadcrumb"]
361
- },
362
- {
363
- "name": "notification-badge",
364
- "docPath": "docs/components/notification-badge.md",
365
- "sourcePath": "components/ui/notification-badge/index.ts",
366
- "description": "A small overlay indicator that appears on top of another element (typically an icon button) to communicate an unread count or attention cue. Appears as a colored dot (attention) or a numbered badge (count).",
367
- "category": "ui",
368
- "import": "xertica-ui/ui",
369
- "keywords": ["dot", "counter", "unread", "overlay-badge"],
370
- "relatedComponents": ["badge", "button"]
371
- },
372
- {
373
- "name": "page-header",
374
- "docPath": "docs/components/page-header.md",
375
- "sourcePath": "components/ui/page-header/index.ts",
376
- "description": "The `PageHeader` is a content-level component used to provide immediate context for a specific page or section. It focuses on the page title, subtitle, back navigation, and primary local actions (like \"Create\" or \"Edit\").",
377
- "category": "ui",
378
- "import": "xertica-ui/ui",
379
- "keywords": ["page-title", "heading", "section-header"],
380
- "relatedComponents": ["breadcrumb", "header", "button"]
381
- },
382
- {
383
- "name": "pagination",
384
- "docPath": "docs/components/pagination.md",
385
- "sourcePath": "components/ui/pagination/index.ts",
386
- "description": "A navigation control for moving through pages of a large dataset. Renders Previous/Next buttons, numbered page buttons, and ellipsis for large page counts. Use it below data tables to control which page of records is displayed.",
387
- "category": "ui",
388
- "import": "xertica-ui/ui",
389
- "keywords": ["pages", "paging", "page-navigation", "next-prev"],
390
- "relatedComponents": ["table"]
391
- },
392
- {
393
- "name": "popover",
394
- "docPath": "docs/components/popover.md",
395
- "sourcePath": "components/ui/popover/index.ts",
396
- "description": "A floating panel anchored to a trigger element that presents additional information or controls without navigating away from the current context. Unlike `Tooltip`, Popover content can be interactive — forms, date pickers, settings panels, filter controls.",
397
- "category": "ui",
398
- "import": "xertica-ui/ui",
399
- "keywords": ["floating-panel", "anchored-panel", "overlay-panel"],
400
- "relatedComponents": ["tooltip", "hover-card", "sheet", "dialog"]
401
- },
402
- {
403
- "name": "progress",
404
- "docPath": "docs/components/progress.md",
405
- "sourcePath": "components/ui/progress/index.ts",
406
- "description": "A visual indicator of completion or percentage. Renders a horizontal bar filled to a given percentage. It is purely display-only — for interactive value selection, use `<Slider>`.",
407
- "category": "ui",
408
- "import": "xertica-ui/ui",
409
- "keywords": ["loading-bar", "completion", "percentage"],
410
- "relatedComponents": ["skeleton", "slider"]
411
- },
412
- {
413
- "name": "radio-group",
414
- "docPath": "docs/components/radio-group.md",
415
- "sourcePath": "components/ui/radio-group/index.ts",
416
- "description": "A set of mutually exclusive options where selecting one automatically deselects all others. Built on Radix UI with full keyboard navigation (arrow keys cycle through options). Use when only one choice from a defined set is valid.",
417
- "category": "ui",
418
- "import": "xertica-ui/ui",
419
- "keywords": ["radio", "single-select", "exclusive-choice"],
420
- "relatedComponents": ["select", "checkbox"]
421
- },
422
- {
423
- "name": "rating",
424
- "docPath": "docs/components/rating.md",
425
- "sourcePath": "components/ui/rating/index.ts",
426
- "description": "A star-based rating input that allows users to rate items on a 1–5 (or custom range) scale. Supports both interactive rating input and read-only display modes.",
427
- "category": "ui",
428
- "import": "xertica-ui/ui",
429
- "keywords": ["stars", "star-rating", "review-score"],
430
- "relatedComponents": ["input"]
431
- },
432
- {
433
- "name": "resizable",
434
- "docPath": "docs/components/resizable.md",
435
- "sourcePath": "components/ui/resizable/index.ts",
436
- "description": "A panel splitter that lets users resize adjacent panels by dragging a handle. Used in IDE-style layouts, split-view editors, and any interface where two panels need to share space dynamically.",
437
- "category": "ui",
438
- "import": "xertica-ui/ui",
439
- "keywords": ["split-panel", "resize", "drag-handle", "panel-splitter"],
440
- "relatedComponents": ["sidebar"]
441
- },
442
- {
443
- "name": "rich-text-editor",
444
- "docPath": "docs/components/rich-text-editor.md",
445
- "sourcePath": "components/ui/rich-text-editor/index.ts",
446
- "description": "A lightweight, native WYSIWYG (What You See Is What You Get) document text editor built into the Xertica UI framework. It utilizes the browser's native `contentEditable` architecture and `document.execCommand` under the hood to provide essential text formatting without the overhead of massive third-party rendering engines.",
447
- "category": "ui",
448
- "import": "xertica-ui/ui",
449
- "keywords": ["wysiwyg", "editor", "text-editor"],
450
- "relatedComponents": ["textarea", "form"]
451
- },
452
- {
453
- "name": "route-map",
454
- "docPath": "docs/components/route-map.md",
455
- "sourcePath": "components/ui/route-map/index.ts",
456
- "description": "A specialized Google Maps component that calculates and renders a route between an origin and destination point, with support for intermediate waypoints and multiple travel modes. The route is drawn on the map using the Google Directions Service, and optionally returns the calculated distance and duration.",
457
- "category": "ui",
458
- "import": "xertica-ui/ui",
459
- "keywords": ["directions", "route", "navigation-map", "waypoints"],
460
- "relatedComponents": ["map", "simple-map"]
461
- },
462
- {
463
- "name": "scroll-area",
464
- "docPath": "docs/components/scroll-area.md",
465
- "sourcePath": "components/ui/scroll-area/index.ts",
466
- "description": "A cross-browser, themeable scrollable container with custom scrollbar styling. Use instead of native `overflow-y-auto` when the scrollbar needs to match the application's design system (instead of the OS default scrollbar).",
467
- "category": "ui",
468
- "import": "xertica-ui/ui",
469
- "keywords": ["scrollbar", "overflow", "custom-scroll"],
470
- "relatedComponents": ["card", "sidebar"]
471
- },
472
- {
473
- "name": "search",
474
- "docPath": "docs/components/search.md",
475
- "sourcePath": "components/ui/search/index.ts",
476
- "description": "A pre-built search input with a built-in search icon and clear button. Supports `sm`, `md`, `lg` size variants matching the Input scale. Handles Escape-to-clear and exposes `onSearch` for simple string callbacks.",
477
- "category": "ui",
478
- "import": "xertica-ui/ui",
479
- "keywords": ["search-input", "filter", "query", "find"],
480
- "relatedComponents": ["input", "command", "table"]
481
- },
482
- {
483
- "name": "select",
484
- "docPath": "docs/components/select.md",
485
- "sourcePath": "components/ui/select/index.ts",
486
- "description": "A styled dropdown for selecting a single option from a list. Built on Radix UI, it provides a fully accessible combobox with keyboard navigation, portaled content, and proper ARIA semantics. Always use `<Select>` from `xertica-ui` — never use native `<select>`.",
487
- "category": "ui",
488
- "import": "xertica-ui/ui",
489
- "keywords": ["dropdown", "combobox", "picker", "chooser"],
490
- "relatedComponents": ["radio-group", "command", "input"]
491
- },
492
- {
493
- "name": "separator",
494
- "docPath": "docs/components/separator.md",
495
- "sourcePath": "components/ui/separator/index.ts",
496
- "description": "A thin horizontal (or vertical) line that visually divides sections of content. Primarily decorative but semantically meaningful as an `<hr>` element. Used to create visual breathing room between logically distinct sections.",
497
- "category": "ui",
498
- "import": "xertica-ui/ui",
499
- "keywords": ["divider", "hr", "horizontal-rule", "line"],
500
- "relatedComponents": ["card"]
501
- },
502
- {
503
- "name": "sheet",
504
- "docPath": "docs/components/sheet.md",
505
- "sourcePath": "components/ui/sheet/index.ts",
506
- "description": "An edge-anchored slide-in panel that overlays the current page from one side — top, right, bottom, or left. Like `Dialog` but more suitable for forms or detail views that benefit from more vertical space, or for secondary navigation and controls on mobile.",
507
- "category": "ui",
508
- "import": "xertica-ui/ui",
509
- "keywords": ["side-panel", "slide-in", "panel"],
510
- "relatedComponents": ["dialog", "drawer", "popover"]
511
- },
512
- {
513
- "name": "sidebar",
514
- "docPath": "docs/components/sidebar.md",
515
- "sourcePath": "components/layout/sidebar/index.ts",
516
- "description": "The `Sidebar` is the primary vertical navigation panel of the application shell. It manages the app's hierarchy, supporting simple lists, grouped items, and an advanced \"Assistant\" mode for AI-driven or data-rich interfaces.",
517
- "category": "layout",
518
- "import": "xertica-ui/layout",
519
- "keywords": ["nav", "navigation", "menu", "side-nav", "vertical-nav"],
520
- "relatedComponents": ["header", "navigation-menu"]
521
- },
522
- {
523
- "name": "simple-map",
524
- "docPath": "docs/components/simple-map.md",
525
- "sourcePath": "components/ui/simple-map/index.ts",
526
- "description": "A simplified wrapper for common map use cases where you only need a single marker and basic configuration.",
527
- "category": "ui",
528
- "import": "xertica-ui/ui",
529
- "keywords": ["basic-map", "single-marker", "map-pin"],
530
- "relatedComponents": ["map", "route-map"]
531
- },
532
- {
533
- "name": "skeleton",
534
- "docPath": "docs/components/skeleton.md",
535
- "sourcePath": "components/ui/skeleton/index.ts",
536
- "description": "A loading placeholder that mimics the shape and dimensions of content while it's being fetched. Use it to provide visual continuity and reduce perceived load time — never leave blank white space while content is loading.",
537
- "category": "ui",
538
- "import": "xertica-ui/ui",
539
- "keywords": ["loading-placeholder", "shimmer", "placeholder"],
540
- "relatedComponents": ["progress", "empty"]
541
- },
542
- {
543
- "name": "slider",
544
- "docPath": "docs/components/slider.md",
545
- "sourcePath": "components/ui/slider/index.ts",
546
- "description": "A range input control that lets users select a numeric value by dragging a thumb along a track. Used for quantity selectors, volume controls, percentage settings, and any value within a continuous range.",
547
- "category": "ui",
548
- "import": "xertica-ui/ui",
549
- "keywords": ["range", "range-input", "volume", "scrubber"],
550
- "relatedComponents": ["progress", "input"]
551
- },
552
- {
553
- "name": "sonner",
554
- "docPath": "docs/components/sonner.md",
555
- "sourcePath": "components/ui/sonner/index.ts",
556
- "description": "Sonner is the toast notification system. It displays ephemeral feedback messages that appear at a fixed position on screen (top-right by default), auto-dismiss after a few seconds, and can be dismissed manually. `<Toaster>` is auto-injected by `<XerticaProvider>` — you never need to render it manually.",
557
- "category": "ui",
558
- "import": "xertica-ui/ui",
559
- "keywords": ["toast", "notification", "snackbar", "alert-message"],
560
- "relatedComponents": ["alert", "dialog"]
561
- },
562
- {
563
- "name": "stats-card",
564
- "docPath": "docs/components/stats-card.md",
565
- "sourcePath": "components/ui/stats-card/index.ts",
566
- "description": "A pre-built KPI (Key Performance Indicator) card for dashboard overview pages. Renders a metric title, a large value, an optional trend indicator with automatic up/down/neutral icon, and an optional icon.",
567
- "category": "ui",
568
- "import": "xertica-ui/ui",
569
- "keywords": ["kpi", "metric", "counter", "dashboard-card"],
570
- "relatedComponents": ["card", "chart"]
571
- },
572
- {
573
- "name": "stepper",
574
- "docPath": "docs/components/stepper.md",
575
- "sourcePath": "components/ui/stepper/index.ts",
576
- "description": "A visual multi-step progress indicator that shows the user's current position within a sequential process. Uses a composable primitive pattern: `<Stepper>` wraps one or more `<Step>` children, automatically inferring the total number of steps.",
577
- "category": "ui",
578
- "import": "xertica-ui/ui",
579
- "keywords": ["wizard", "multi-step", "progress-steps", "onboarding"],
580
- "relatedComponents": ["progress", "tabs"]
581
- },
582
- {
583
- "name": "switch",
584
- "docPath": "docs/components/switch.md",
585
- "sourcePath": "components/ui/switch/index.ts",
586
- "description": "A binary toggle control that represents an on/off state — similar to a physical light switch. More prominent and visually expressive than a `<Checkbox>`. Used for feature toggles, notification settings, accessibility preferences, and any prominent boolean setting.",
587
- "category": "ui",
588
- "import": "xertica-ui/ui",
589
- "keywords": ["toggle", "on-off", "boolean", "feature-flag"],
590
- "relatedComponents": ["checkbox", "toggle"]
591
- },
592
- {
593
- "name": "table",
594
- "docPath": "docs/components/table.md",
595
- "sourcePath": "components/ui/table/index.ts",
596
- "description": "Structured tabular data display. Provides semantic HTML table elements wrapped in accessible, styled components. Used in CRUD list pages, reports, and any data-heavy view where rows represent records and columns represent attributes.",
597
- "category": "ui",
598
- "import": "xertica-ui/ui",
599
- "keywords": ["data-table", "grid", "list", "rows", "columns", "crud"],
600
- "relatedComponents": ["pagination", "badge", "dropdown-menu", "empty"]
601
- },
602
- {
603
- "name": "tabs",
604
- "docPath": "docs/components/tabs.md",
605
- "sourcePath": "components/ui/tabs/index.ts",
606
- "description": "A content switcher that organizes related views under labelled tab triggers. One tab is active at a time. Used for multi-view dashboards, analytics pages, settings sections, and any context where content is segmented but logically related.",
607
- "category": "ui",
608
- "import": "xertica-ui/ui",
609
- "keywords": ["tab-bar", "tab-panel", "switcher", "tabbed-content"],
610
- "relatedComponents": ["navigation-menu", "accordion"]
611
- },
612
- {
613
- "name": "textarea",
614
- "docPath": "docs/components/textarea.md",
615
- "sourcePath": "components/ui/textarea/index.ts",
616
- "description": "A multi-line text input for longer content: descriptions, notes, messages, and rich text fields. Automatically resizable or fixed, depending on the `resize` CSS class applied.",
617
- "category": "ui",
618
- "import": "xertica-ui/ui",
619
- "keywords": ["multi-line", "text-area", "description-field", "notes"],
620
- "relatedComponents": ["input", "form", "rich-text-editor"]
621
- },
622
- {
623
- "name": "theme-toggle",
624
- "docPath": "docs/components/theme-toggle.md",
625
- "sourcePath": "components/brand/theme-toggle/index.ts",
626
- "description": "A self-contained light/dark mode toggle button that operates directly on the `document.documentElement` class list.",
627
- "category": "brand",
628
- "import": "xertica-ui/brand",
629
- "keywords": ["dark-mode", "light-mode", "color-scheme"],
630
- "relatedComponents": ["header", "sidebar"]
631
- },
632
- {
633
- "name": "timeline",
634
- "docPath": "docs/components/timeline.md",
635
- "sourcePath": "components/ui/timeline/index.ts",
636
- "description": "A vertical sequence of events displayed chronologically, each with a timestamp, title, and optional description. Used in activity logs, audit trails, case histories, and notification feeds.",
637
- "category": "ui",
638
- "import": "xertica-ui/ui",
639
- "keywords": ["activity-log", "history", "event-log", "audit-trail"],
640
- "relatedComponents": ["table", "card"]
641
- },
642
- {
643
- "name": "toggle-group",
644
- "docPath": "docs/components/toggle-group.md",
645
- "sourcePath": "components/ui/toggle-group/index.ts",
646
- "description": "A set of related `<Toggle>` buttons that operate together — either allowing only one selection at a time (`type=\"single\"`) or multiple simultaneous selections (`type=\"multiple\"`). Used for mutually exclusive view modes, filter groups, and formatting toolbars.",
647
- "category": "ui",
648
- "import": "xertica-ui/ui",
649
- "keywords": ["segmented-control", "exclusive-toggle", "multi-toggle"],
650
- "relatedComponents": ["toggle", "tabs"]
651
- },
652
- {
653
- "name": "toggle",
654
- "docPath": "docs/components/toggle.md",
655
- "sourcePath": "components/ui/toggle/index.ts",
656
- "description": "A pressable button that maintains an on/off state visually, similar to a keyboard key that stays pressed. Used in toolbars for formatting, view switching, and feature activation.",
657
- "category": "ui",
658
- "import": "xertica-ui/ui",
659
- "keywords": ["pressable", "pressed-state", "toolbar-toggle"],
660
- "relatedComponents": ["switch", "checkbox", "toggle-group"]
661
- },
662
- {
663
- "name": "tooltip",
664
- "docPath": "docs/components/tooltip.md",
665
- "sourcePath": "components/ui/tooltip/index.ts",
666
- "description": "A small floating label that appears on hover (or focus) over a trigger element, providing a short contextual explanation — typically for icon-only buttons, abbreviated text, or any element where the visual label alone isn't sufficient.",
667
- "category": "ui",
668
- "import": "xertica-ui/ui",
669
- "keywords": ["hint", "title", "help-text", "hover-text"],
670
- "relatedComponents": ["hover-card", "popover"]
671
- },
672
- {
673
- "name": "tree-view",
674
- "docPath": "docs/components/tree-view.md",
675
- "sourcePath": "components/ui/tree-view/index.ts",
676
- "description": "An interactive hierarchical tree component for displaying and navigating nested data structures — file systems, organizational charts, category trees, and recursive navigation menus.",
677
- "category": "ui",
678
- "import": "xertica-ui/ui",
679
- "keywords": ["tree", "hierarchy", "nested-list", "file-tree"],
680
- "relatedComponents": ["accordion", "sidebar"]
681
- },
682
- {
683
- "name": "use-mobile",
684
- "docPath": "docs/components/use-mobile.md",
685
- "sourcePath": "components/shared/use-mobile.ts",
686
- "description": "Two hooks that detect whether the current viewport is a mobile-width screen. Useful for conditionally rendering mobile-specific layouts, swapping components (e.g., `Drawer` vs `Sheet`), or hiding/showing content based on screen size.",
687
- "category": "hooks",
688
- "import": "xertica-ui/hooks",
689
- "keywords": ["responsive", "mobile-detection", "breakpoint", "isMobile"],
690
- "relatedComponents": []
691
- },
692
- {
693
- "name": "xertica-logo",
694
- "docPath": "docs/components/xertica-logo.md",
695
- "sourcePath": "components/brand/xertica-logo/index.ts",
696
- "description": "The official full horizontal logotype for Xertica. It is a vector-based SVG component that ensures brand consistency across all application headers and splash screens.",
697
- "category": "brand",
698
- "import": "xertica-ui/brand",
699
- "keywords": ["logo", "brand", "logotype"],
700
- "relatedComponents": ["xertica-xlogo", "xertica-orbe"]
701
- },
702
- {
703
- "name": "xertica-orbe",
704
- "docPath": "docs/components/xertica-orbe.md",
705
- "sourcePath": "components/brand/xertica-orbe/index.ts",
706
- "description": "An animated, decorative brand element representing the Xertica \"Orbe\". It features CSS-based pulse and rotation animations to provide a premium, dynamic feel to hero sections and loading screens.",
707
- "category": "brand",
708
- "import": "xertica-ui/brand",
709
- "keywords": ["orb", "animated-logo", "brand-animation"],
710
- "relatedComponents": ["xertica-logo"]
711
- },
712
- {
713
- "name": "xertica-provider",
714
- "docPath": "docs/components/xertica-provider.md",
715
- "sourcePath": "components/brand/xertica-provider/index.ts",
716
- "description": "The mandatory root wrapper for all Xertica UI applications. It synchronizes global configurations and injects essential context providers for layout, tooltips, maps, and notifications.",
717
- "category": "brand",
718
- "import": "xertica-ui/brand",
719
- "keywords": ["provider", "root", "context", "app-wrapper"],
720
- "relatedComponents": []
721
- },
722
- {
723
- "name": "xertica-xlogo",
724
- "docPath": "docs/components/xertica-xlogo.md",
725
- "sourcePath": "components/brand/xertica-xlogo/index.ts",
726
- "description": "A compact, square variant of the Xertica logo featuring the stylized \"X\" mark. Ideal for favicons, collapsed sidebars, and small profile badges.",
727
- "category": "brand",
728
- "import": "xertica-ui/brand",
729
- "keywords": ["x-logo", "compact-logo", "icon-logo", "favicon"],
730
- "relatedComponents": ["xertica-logo", "sidebar"]
731
- },
732
- {
733
- "name": "video-player",
734
- "docPath": "docs/components/video-player.md",
735
- "sourcePath": "components/media/video-player/index.ts",
736
- "description": "A feature-rich video player with custom controls, progress bar, volume, and floating mode support. Built on HTML5 video with React state management.",
737
- "category": "media",
738
- "import": "xertica-ui/media",
739
- "keywords": ["video", "player", "media", "playback"],
740
- "relatedComponents": ["audio-player", "floating-media-wrapper"]
741
- },
742
- {
743
- "name": "code-block",
744
- "docPath": "docs/components/assistant.md",
745
- "sourcePath": "components/assistant/code-block/index.ts",
746
- "description": "A syntax-highlighted code block component for the Xertica Assistant. It renders code snippets with language detection and copy-to-clipboard functionality.",
747
- "category": "assistant",
748
- "import": "xertica-ui/assistant",
749
- "keywords": ["syntax-highlight", "code", "snippet", "copy-code"],
750
- "relatedComponents": ["markdown-message", "xertica-assistant"]
751
- },
752
- {
753
- "name": "formatted-document",
754
- "docPath": "docs/components/assistant.md",
755
- "sourcePath": "components/assistant/formatted-document/index.ts",
756
- "description": "A structured document renderer for displaying AI-generated content with headings, paragraphs, lists, and rich formatting support.",
757
- "category": "assistant",
758
- "import": "xertica-ui/assistant",
759
- "keywords": ["formatted document"],
760
- "relatedComponents": []
761
- },
762
- {
763
- "name": "modern-chat-input",
764
- "docPath": "docs/components/assistant.md",
765
- "sourcePath": "components/assistant/modern-chat-input/index.ts",
766
- "description": "A chat input component for the AI Assistant with multi-line support, auto-resize, and keyboard shortcuts. Used as the primary input in the assistant interface.",
767
- "category": "assistant",
768
- "import": "xertica-ui/assistant",
769
- "keywords": ["modern chat input"],
770
- "relatedComponents": []
771
- },
772
- {
773
- "name": "xertica-assistant",
774
- "docPath": "docs/components/assistant.md",
775
- "sourcePath": "components/assistant/xertica-assistant/index.ts",
776
- "description": "A conversational AI assistant panel that integrates with the application. Provides chat interface, message rendering, suggestions, and file attachments.",
777
- "category": "assistant",
778
- "import": "xertica-ui/assistant",
779
- "keywords": ["ai-chat", "chatbot", "ai-panel", "assistant", "llm-chat"],
780
- "relatedComponents": ["markdown-message", "code-block"]
781
- },
782
- {
783
- "name": "login-page",
784
- "docPath": "docs/getting-started.md",
785
- "sourcePath": "components/pages/login-page/index.ts",
786
- "description": "A complete login page template with email/password fields, theme toggle, and language selector integration.",
787
- "category": "pages",
788
- "import": "xertica-ui",
789
- "keywords": ["login page"],
790
- "relatedComponents": []
791
- },
792
- {
793
- "name": "forgot-password-page",
794
- "docPath": "docs/getting-started.md",
795
- "sourcePath": "components/pages/forgot-password-page/index.ts",
796
- "description": "A forgot password page template with email input and reset flow integration.",
797
- "category": "pages",
798
- "import": "xertica-ui",
799
- "keywords": ["forgot password page"],
800
- "relatedComponents": []
801
- },
802
- {
803
- "name": "reset-password-page",
804
- "docPath": "docs/getting-started.md",
805
- "sourcePath": "components/pages/reset-password-page/index.ts",
806
- "description": "A reset password page template with new password and confirmation fields.",
807
- "category": "pages",
808
- "import": "xertica-ui",
809
- "keywords": ["reset password page"],
810
- "relatedComponents": []
811
- },
812
- {
813
- "name": "verify-email-page",
814
- "docPath": "docs/getting-started.md",
815
- "sourcePath": "components/pages/verify-email-page/index.ts",
816
- "description": "A verify email page template with OTP code input for email verification.",
817
- "category": "pages",
818
- "import": "xertica-ui",
819
- "keywords": ["verify email page"],
820
- "relatedComponents": []
821
- },
822
- {
823
- "name": "home-page",
824
- "docPath": "docs/getting-started.md",
825
- "sourcePath": "components/pages/home-page/index.ts",
826
- "description": "A home page template with sidebar navigation, header, and content area. The base layout for application pages.",
827
- "category": "pages",
828
- "import": "xertica-ui",
829
- "keywords": ["home page"],
830
- "relatedComponents": []
831
- },
832
- {
833
- "name": "home-content",
834
- "docPath": "docs/getting-started.md",
835
- "sourcePath": "components/pages/home-content/index.ts",
836
- "description": "The content area component for home pages, providing a flexible container for page-specific content.",
837
- "category": "pages",
838
- "import": "xertica-ui",
839
- "keywords": ["home content"],
840
- "relatedComponents": []
841
- },
842
- {
843
- "name": "template-page",
844
- "docPath": "docs/getting-started.md",
845
- "sourcePath": "components/pages/template-page/index.ts",
846
- "description": "A flexible page template component that wraps the layout system with configurable header, sidebar, and content areas.",
847
- "category": "pages",
848
- "import": "xertica-ui",
849
- "keywords": ["template page"],
850
- "relatedComponents": []
851
- },
852
- {
853
- "name": "template-content",
854
- "docPath": "docs/getting-started.md",
855
- "sourcePath": "components/pages/template-content/index.ts",
856
- "description": "A content wrapper component for template pages, providing consistent padding and layout behavior.",
857
- "category": "pages",
858
- "import": "xertica-ui",
859
- "keywords": ["template content"],
860
- "relatedComponents": []
861
- },
862
- {
863
- "name": "map-layers",
864
- "docPath": "docs/components/map.md",
865
- "sourcePath": "components/ui/map-layers/index.ts",
866
- "description": "A utility for managing Google Maps layers including traffic, transit, bicycling, and weather layers with theme-aware styling.",
867
- "category": "ui",
868
- "import": "xertica-ui/ui",
869
- "keywords": ["map layers"],
870
- "relatedComponents": []
871
- },
872
- {
873
- "name": "map-config",
874
- "docPath": "docs/components/map.md",
875
- "sourcePath": "components/ui/map-config/index.ts",
876
- "description": "Configuration utility for Google Maps shared settings and theme-based styling.",
877
- "category": "ui",
878
- "import": "xertica-ui/ui",
879
- "keywords": ["map config"],
880
- "relatedComponents": []
881
- },
882
- {
883
- "name": "floating-media-wrapper",
884
- "docPath": "docs/components/floating-media-wrapper.md",
885
- "sourcePath": "components/media/FloatingMediaWrapper.tsx",
886
- "description": "A higher-level wrapper for media players (audio/video) that manages floating state, positioning, and transitions.",
887
- "category": "media",
888
- "import": "xertica-ui/media",
889
- "keywords": ["floating", "draggable", "portal", "picture-in-picture"],
890
- "relatedComponents": ["video-player", "audio-player"]
891
- }
892
- ]
1
+ [
2
+ {
3
+ "name": "accordion",
4
+ "docPath": "docs/components/accordion.md",
5
+ "sourcePath": "components/ui/accordion/index.ts",
6
+ "description": "A vertically stacked set of collapsible sections. Each section has a clickable trigger header that reveals or hides its content. Ideal for FAQs, configuration settings, and dense navigation trees where only one (or a few) section needs to be visible at a time.",
7
+ "category": "ui",
8
+ "import": "xertica-ui/ui",
9
+ "keywords": ["collapse", "expand", "faq", "collapsible-list"],
10
+ "relatedComponents": ["collapsible", "tabs"]
11
+ },
12
+ {
13
+ "name": "alert-dialog",
14
+ "docPath": "docs/components/alert-dialog.md",
15
+ "sourcePath": "components/ui/alert-dialog/index.ts",
16
+ "description": "A specialized modal for **irreversible destructive actions** — delete, revoke, reset, permanently disable. Unlike `Dialog`, `AlertDialog` enforces that the user must explicitly confirm or cancel; clicking outside does not dismiss it.",
17
+ "category": "ui",
18
+ "import": "xertica-ui/ui",
19
+ "keywords": ["confirm", "confirmation", "destructive", "delete-confirm"],
20
+ "relatedComponents": ["dialog", "button"]
21
+ },
22
+ {
23
+ "name": "alert",
24
+ "docPath": "docs/components/alert.md",
25
+ "sourcePath": "components/ui/alert/index.ts",
26
+ "description": "An inline message banner used to communicate status, feedback, or important contextual information directly within the page content — without interrupting the user flow. Unlike `Sonner` (toast notifications), alerts are persistent and visible at all times.",
27
+ "category": "ui",
28
+ "import": "xertica-ui/ui",
29
+ "keywords": ["banner", "info-banner", "warning-banner", "inline-message"],
30
+ "relatedComponents": ["sonner", "alert-dialog"]
31
+ },
32
+ {
33
+ "name": "aspect-ratio",
34
+ "docPath": "docs/components/aspect-ratio.md",
35
+ "sourcePath": "components/ui/aspect-ratio/index.ts",
36
+ "description": "A container that maintains a fixed width-to-height ratio regardless of the available space. Prevents layout shifts when loading images, videos, or charts. Use when content must always fill a specific shape.",
37
+ "category": "ui",
38
+ "import": "xertica-ui/ui",
39
+ "keywords": ["ratio", "media-ratio", "image-container", "16-9"],
40
+ "relatedComponents": ["video-player", "card"]
41
+ },
42
+ {
43
+ "name": "assistant-chart",
44
+ "docPath": "docs/components/assistant-chart.md",
45
+ "sourcePath": "components/ui/assistant-chart/index.ts",
46
+ "description": "A specialized data visualization component optimized for display within the AI Assistant panel. It provides a pre-configured responsive BarChart using the library's design system tokens.",
47
+ "category": "ui",
48
+ "import": "xertica-ui/ui",
49
+ "keywords": ["ai-chart", "assistant-visualization", "chat-chart"],
50
+ "relatedComponents": ["chart", "xertica-assistant"]
51
+ },
52
+ {
53
+ "name": "audio-player",
54
+ "docPath": "docs/components/audio-player.md",
55
+ "sourcePath": "components/media/audio-player/index.ts",
56
+ "description": "A global, floating audio playback bar designed for process tracking and podcast consumption. It features a responsive layout that automatically adjusts to the state of the sidebar and AI assistant.",
57
+ "category": "media",
58
+ "import": "xertica-ui/media",
59
+ "keywords": ["audio", "podcast", "music", "sound", "playback"],
60
+ "relatedComponents": ["video-player", "floating-media-wrapper"]
61
+ },
62
+ {
63
+ "name": "avatar",
64
+ "docPath": "docs/components/avatar.md",
65
+ "sourcePath": "components/ui/avatar/index.ts",
66
+ "description": "Displays a user's identity visually — either as a profile photo or as an initials-based fallback. Used in headers, sidebars, comment threads, and table rows to represent people.",
67
+ "category": "ui",
68
+ "import": "xertica-ui/ui",
69
+ "keywords": ["profile-picture", "user-image", "initials"],
70
+ "relatedComponents": ["header", "table"]
71
+ },
72
+ {
73
+ "name": "badge",
74
+ "docPath": "docs/components/badge.md",
75
+ "sourcePath": "components/ui/badge/index.ts",
76
+ "description": "A compact, inline label used to communicate status, category, or count. Badges are always non-interactive by default — they display information, not trigger actions.",
77
+ "category": "ui",
78
+ "import": "xertica-ui/ui",
79
+ "keywords": ["tag", "label", "status", "chip", "pill"],
80
+ "relatedComponents": ["notification-badge", "table", "card"]
81
+ },
82
+ {
83
+ "name": "breadcrumb",
84
+ "docPath": "docs/components/breadcrumb.md",
85
+ "sourcePath": "components/ui/breadcrumb/index.ts",
86
+ "description": "A hierarchical navigation trail showing the user's current position in the application's page structure. Rendered in the `Header` component via the `breadcrumbs` prop. Each item in the chain can optionally be a clickable link.",
87
+ "category": "ui",
88
+ "import": "xertica-ui/ui",
89
+ "keywords": ["breadcrumbs", "navigation-path", "location-trail"],
90
+ "relatedComponents": ["header", "page-header"]
91
+ },
92
+ {
93
+ "name": "button",
94
+ "docPath": "docs/components/button.md",
95
+ "sourcePath": "components/ui/button/index.ts",
96
+ "description": "The primary interaction trigger. Use `Button` for any user-initiated action: form submission, navigation triggers, dialog openers, and destructive confirmations. It supports multiple visual variants, sizes, icon-only mode, and the `asChild` pattern for composing with router links.",
97
+ "category": "ui",
98
+ "import": "xertica-ui/ui",
99
+ "keywords": ["btn", "action", "click", "submit", "trigger", "cta"],
100
+ "relatedComponents": ["alert-dialog", "dialog", "form", "dropdown-menu"]
101
+ },
102
+ {
103
+ "name": "calendar",
104
+ "docPath": "docs/components/calendar.md",
105
+ "sourcePath": "components/ui/calendar/index.ts",
106
+ "description": "A date picker calendar that renders a monthly grid of selectable days. Built on `react-day-picker`. Almost always used inside a `<Popover>` to provide an accessible, accessible date input. Supports single date selection, multiple dates, and date ranges.",
107
+ "category": "ui",
108
+ "import": "xertica-ui/ui",
109
+ "keywords": ["date-picker", "datepicker", "date-input"],
110
+ "relatedComponents": ["popover", "input"]
111
+ },
112
+ {
113
+ "name": "card",
114
+ "docPath": "docs/components/card.md",
115
+ "sourcePath": "components/ui/card/index.ts",
116
+ "description": "The primary structural container for all content blocks in the application. `Card` provides elevation (via box shadow), background/border tokens, and a consistent internal padding system. It is the single correct way to create content panels — never recreate it with raw `<div>` utility classes.",
117
+ "category": "ui",
118
+ "import": "xertica-ui/ui",
119
+ "keywords": ["container", "panel", "surface", "box"],
120
+ "relatedComponents": ["stats-card", "scroll-area", "separator"]
121
+ },
122
+ {
123
+ "name": "carousel",
124
+ "docPath": "docs/components/carousel.md",
125
+ "sourcePath": "components/ui/carousel/index.ts",
126
+ "description": "A horizontal content slider that lets users navigate through a set of panels or cards one at a time. Built on `embla-carousel-react`. Provides Previous/Next navigation buttons and optional indicator dots.",
127
+ "category": "ui",
128
+ "import": "xertica-ui/ui",
129
+ "keywords": ["slider", "slides", "horizontal-scroll", "embla"],
130
+ "relatedComponents": ["card"]
131
+ },
132
+ {
133
+ "name": "chart",
134
+ "docPath": "docs/components/chart.md",
135
+ "sourcePath": "components/ui/chart/index.ts",
136
+ "description": "Xertica UI provides a `ChartContainer` wrapper and dashboard-ready chart components built on top of **Recharts** for theme-aware, token-driven rendering. The chart system uses a `ChartConfig` object to define series labels and colors via CSS variables, ensuring full dark-mode support without hard-coded hex values.",
137
+ "category": "ui",
138
+ "import": "xertica-ui/ui",
139
+ "keywords": [
140
+ "graph",
141
+ "visualization",
142
+ "recharts",
143
+ "bar-chart",
144
+ "line-chart",
145
+ "horizontal-bar-chart",
146
+ "dashboard-chart",
147
+ "donut-chart",
148
+ "combo-chart"
149
+ ],
150
+ "relatedComponents": ["card", "stats-card"]
151
+ },
152
+ {
153
+ "name": "checkbox",
154
+ "docPath": "docs/components/checkbox.md",
155
+ "sourcePath": "components/ui/checkbox/index.ts",
156
+ "description": "A binary toggle that lets users select or deselect a single option, or mark multiple independent options in a list. Built on Radix UI with accessible keyboard behavior and ARIA roles.",
157
+ "category": "ui",
158
+ "import": "xertica-ui/ui",
159
+ "keywords": ["check", "boolean", "tick", "multi-select"],
160
+ "relatedComponents": ["switch", "radio-group", "toggle"]
161
+ },
162
+ {
163
+ "name": "collapsible",
164
+ "docPath": "docs/components/collapsible.md",
165
+ "sourcePath": "components/ui/collapsible/index.ts",
166
+ "description": "A single expandable/collapsible content section with a trigger header. Unlike `<Accordion>`, `Collapsible` is a standalone element — it has no sibling items and no managed \"only one open\" behavior.",
167
+ "category": "ui",
168
+ "import": "xertica-ui/ui",
169
+ "keywords": ["expand", "collapse", "toggle-section"],
170
+ "relatedComponents": ["accordion"]
171
+ },
172
+ {
173
+ "name": "command",
174
+ "docPath": "docs/components/command.md",
175
+ "sourcePath": "components/ui/command/index.ts",
176
+ "description": "A command palette for searching and executing actions via keyboard — triggered by `⌘K` / `Ctrl+K`. Provides a searchable, filterable list of commands, navigation items, and quick actions. Built on `cmdk`.",
177
+ "category": "ui",
178
+ "import": "xertica-ui/ui",
179
+ "keywords": ["command-palette", "cmd-k", "spotlight", "keyboard-shortcut"],
180
+ "relatedComponents": ["search", "dialog"]
181
+ },
182
+ {
183
+ "name": "context-menu",
184
+ "docPath": "docs/components/context-menu.md",
185
+ "sourcePath": "components/ui/context-menu/index.ts",
186
+ "description": "A menu that appears when the user right-clicks (or long-presses on mobile) a trigger area. Provides a familiar OS-native contextual menu pattern for power-user interactions. Built on Radix UI.",
187
+ "category": "ui",
188
+ "import": "xertica-ui/ui",
189
+ "keywords": ["right-click", "contextmenu", "right-click-menu"],
190
+ "relatedComponents": ["dropdown-menu", "menubar"]
191
+ },
192
+ {
193
+ "name": "dialog",
194
+ "docPath": "docs/components/dialog.md",
195
+ "sourcePath": "components/ui/dialog/index.ts",
196
+ "description": "A modal overlay that interrupts the page flow to capture user attention for critical confirmations, data entry, or detailed views. Built on Radix UI Dialog with managed focus trapping, keyboard escape, and backdrop click-to-dismiss.",
197
+ "category": "ui",
198
+ "import": "xertica-ui/ui",
199
+ "keywords": ["modal", "popup", "overlay", "lightbox"],
200
+ "relatedComponents": ["alert-dialog", "sheet", "drawer", "popover"]
201
+ },
202
+ {
203
+ "name": "drawer",
204
+ "docPath": "docs/components/drawer.md",
205
+ "sourcePath": "components/ui/drawer/index.ts",
206
+ "description": "A panel that slides in from the bottom edge of the screen — the mobile-optimized equivalent of `<Sheet>`. Drawers are the standard interaction pattern for panels on mobile, providing a more natural bottom-to-top gesture feel.",
207
+ "category": "ui",
208
+ "import": "xertica-ui/ui",
209
+ "keywords": ["bottom-sheet", "mobile-panel", "slide-up"],
210
+ "relatedComponents": ["sheet", "dialog"]
211
+ },
212
+ {
213
+ "name": "dropdown-menu",
214
+ "docPath": "docs/components/dropdown-menu.md",
215
+ "sourcePath": "components/ui/dropdown-menu/index.ts",
216
+ "description": "A triggered contextual menu that appears anchored below (or beside) a trigger element. Used for row actions in tables, secondary navigation options, and grouped control menus. Built on Radix UI with full keyboard navigation.",
217
+ "category": "ui",
218
+ "import": "xertica-ui/ui",
219
+ "keywords": ["action-menu", "options-menu", "kebab-menu"],
220
+ "relatedComponents": ["context-menu", "button", "table"]
221
+ },
222
+ {
223
+ "name": "empty",
224
+ "docPath": "docs/components/empty.md",
225
+ "sourcePath": "components/ui/empty/index.ts",
226
+ "description": "A structured zero-state container rendered when a list, table, or search returns no results. Uses a composable primitive pattern (`Empty + EmptyIcon + EmptyTitle + EmptyDescription + EmptyAction`) to provide a flexible, consistent empty-state experience.",
227
+ "category": "ui",
228
+ "import": "xertica-ui/ui",
229
+ "keywords": ["empty-state", "zero-state", "no-results", "no-data"],
230
+ "relatedComponents": ["skeleton", "table"]
231
+ },
232
+ {
233
+ "name": "file-upload",
234
+ "docPath": "docs/components/file-upload.md",
235
+ "sourcePath": "components/ui/file-upload/index.ts",
236
+ "description": "A drag-and-drop file input component that accepts one or multiple files. Renders a dropzone area with visual feedback on drag, displays selected file names, and validates against allowed MIME types and file size limits.",
237
+ "category": "ui",
238
+ "import": "xertica-ui/ui",
239
+ "keywords": ["drop-zone", "file-input", "drag-drop", "upload"],
240
+ "relatedComponents": ["input", "form", "button"]
241
+ },
242
+ {
243
+ "name": "form",
244
+ "docPath": "docs/components/form.md",
245
+ "sourcePath": "components/ui/form/index.ts",
246
+ "description": "`Form` is the integration layer between `react-hook-form` and Xertica UI components. It provides a context-aware set of wrappers (`FormField`, `FormItem`, `FormLabel`, `FormControl`, `FormMessage`, `FormDescription`) that automatically connect to form state, display validation errors, and manage ARIA attributes.",
247
+ "category": "ui",
248
+ "import": "xertica-ui/ui",
249
+ "keywords": ["react-hook-form", "form-validation", "zod", "form-fields"],
250
+ "relatedComponents": ["input", "select", "checkbox", "button", "label"]
251
+ },
252
+ {
253
+ "name": "google-maps-loader",
254
+ "docPath": "docs/components/google-maps-loader.md",
255
+ "sourcePath": "components/ui/google-maps-loader/index.ts",
256
+ "description": "The utility provider and hook responsible for the lazy-loading and initialization of the Google Maps JavaScript API. It is automatically managed by the `XerticaProvider`.",
257
+ "category": "ui",
258
+ "import": "xertica-ui/ui",
259
+ "keywords": ["maps-api", "google-maps-api", "maps-provider"],
260
+ "relatedComponents": ["map", "xertica-provider"]
261
+ },
262
+ {
263
+ "name": "header",
264
+ "docPath": "docs/components/header.md",
265
+ "sourcePath": "components/layout/header/index.ts",
266
+ "description": "The `Header` is the global application top bar — a fixed-height strip (`64px`) rendered at the top of the application shell. It provides a standardized navigation trail (breadcrumbs) and universal system controls.",
267
+ "category": "layout",
268
+ "import": "xertica-ui/layout",
269
+ "keywords": ["top-bar", "app-bar", "navbar", "topnav"],
270
+ "relatedComponents": ["sidebar", "breadcrumb", "page-header"]
271
+ },
272
+ {
273
+ "name": "hover-card",
274
+ "docPath": "docs/components/hover-card.md",
275
+ "sourcePath": "components/ui/hover-card/index.ts",
276
+ "description": "A floating content panel that appears when hovering over a trigger element — designed for previewing additional information without navigating away. Unlike `Tooltip` (short text hints), `HoverCard` can contain rich content: user profiles, link previews, image thumbnails.",
277
+ "category": "ui",
278
+ "import": "xertica-ui/ui",
279
+ "keywords": ["preview-card", "rich-hover", "link-preview"],
280
+ "relatedComponents": ["tooltip", "popover"]
281
+ },
282
+ {
283
+ "name": "input-otp",
284
+ "docPath": "docs/components/input-otp.md",
285
+ "sourcePath": "components/ui/input-otp/index.ts",
286
+ "description": "A one-time password / PIN code input that renders a segmented grid of individual character slots. Designed for MFA flows, email verification codes, and any numeric code entry.",
287
+ "category": "ui",
288
+ "import": "xertica-ui/ui",
289
+ "keywords": ["otp", "pin", "mfa", "verification-code"],
290
+ "relatedComponents": ["input", "form"]
291
+ },
292
+ {
293
+ "name": "input",
294
+ "docPath": "docs/components/input.md",
295
+ "sourcePath": "components/ui/input/index.ts",
296
+ "description": "The standard text field component. Use it for all single-line text inputs: names, emails, search queries, codes. Integrates seamlessly with `react-hook-form` via the `{...field}` spread pattern.",
297
+ "category": "ui",
298
+ "import": "xertica-ui/ui",
299
+ "keywords": ["text-field", "form-field", "text-input"],
300
+ "relatedComponents": ["label", "form", "search", "textarea"]
301
+ },
302
+ {
303
+ "name": "label",
304
+ "docPath": "docs/components/label.md",
305
+ "sourcePath": "components/ui/label/index.ts",
306
+ "description": "An accessible form field label that is always associated with a specific input via `htmlFor`. Automatically applies styling that visually communicates field relationships and disabled states. Used in every form — standalone or via `<FormLabel>` inside the `Form` system.",
307
+ "category": "ui",
308
+ "import": "xertica-ui/ui",
309
+ "keywords": ["form-label", "field-label", "input-label"],
310
+ "relatedComponents": ["input", "form", "checkbox"]
311
+ },
312
+ {
313
+ "name": "language-selector",
314
+ "docPath": "docs/components/language-selector.md",
315
+ "sourcePath": "components/brand/language-selector/index.ts",
316
+ "description": "A self-contained dropdown for switching the interface language. Wired to `LanguageContext` and `i18next`: changing the selection persists to localStorage, calls `i18n.changeLanguage`, and invalidates the React Query cache. Auto-hides when only one language is configured. The list of languages is runtime-configurable via the `availableLanguages` prop on `<XerticaProvider>`.",
317
+ "category": "brand",
318
+ "import": "xertica-ui/brand",
319
+ "keywords": ["i18n", "locale", "language", "internationalization"],
320
+ "relatedComponents": ["header", "theme-toggle"]
321
+ },
322
+ {
323
+ "name": "map",
324
+ "docPath": "docs/components/map.md",
325
+ "sourcePath": "components/ui/map/index.ts",
326
+ "description": "A Google Maps integration component that renders an interactive map with markers, polygons, and custom controls. Powered by the Google Maps JavaScript API via `@vis.gl/react-google-maps`.",
327
+ "category": "ui",
328
+ "import": "xertica-ui/ui",
329
+ "keywords": ["google-maps", "map-view", "geolocation", "markers"],
330
+ "relatedComponents": ["route-map", "simple-map"]
331
+ },
332
+ {
333
+ "name": "markdown-message",
334
+ "docPath": "docs/components/markdown-message.md",
335
+ "sourcePath": "components/assistant/markdown-message/index.ts",
336
+ "description": "The primary renderer for AI-generated text content within the Xertica Assistant. It converts raw Markdown into themed React components with support for syntax highlighting, lists, and tables.",
337
+ "category": "assistant",
338
+ "import": "xertica-ui/assistant",
339
+ "keywords": ["markdown", "md-renderer", "ai-message", "chat-message"],
340
+ "relatedComponents": ["xertica-assistant", "code-block"]
341
+ },
342
+ {
343
+ "name": "menubar",
344
+ "docPath": "docs/components/menubar.md",
345
+ "sourcePath": "components/ui/menubar/index.ts",
346
+ "description": "An application-style horizontal menu bar with multiple dropdown menus — similar to the menu bars in desktop applications (File, Edit, View…). Less common in web apps but useful for power-user tools and editors.",
347
+ "category": "ui",
348
+ "import": "xertica-ui/ui",
349
+ "keywords": ["application-menu", "horizontal-menu", "file-edit-view"],
350
+ "relatedComponents": ["navigation-menu", "dropdown-menu"]
351
+ },
352
+ {
353
+ "name": "navigation-menu",
354
+ "docPath": "docs/components/navigation-menu.md",
355
+ "sourcePath": "components/ui/navigation-menu/index.ts",
356
+ "description": "A horizontal navigation bar designed for top-level application sections. Supports dropdown sub-menus with rich content panels. Use it as a secondary top navigation when the primary navigation is in the `<Sidebar>`. Built on Radix UI NavigationMenu.",
357
+ "category": "ui",
358
+ "import": "xertica-ui/ui",
359
+ "keywords": ["top-nav", "horizontal-nav", "mega-menu"],
360
+ "relatedComponents": ["sidebar", "tabs", "breadcrumb"]
361
+ },
362
+ {
363
+ "name": "notification-badge",
364
+ "docPath": "docs/components/notification-badge.md",
365
+ "sourcePath": "components/ui/notification-badge/index.ts",
366
+ "description": "A small overlay indicator that appears on top of another element (typically an icon button) to communicate an unread count or attention cue. Appears as a colored dot (attention) or a numbered badge (count).",
367
+ "category": "ui",
368
+ "import": "xertica-ui/ui",
369
+ "keywords": ["dot", "counter", "unread", "overlay-badge"],
370
+ "relatedComponents": ["badge", "button"]
371
+ },
372
+ {
373
+ "name": "page-header",
374
+ "docPath": "docs/components/page-header.md",
375
+ "sourcePath": "components/ui/page-header/index.ts",
376
+ "description": "The `PageHeader` is a content-level component used to provide immediate context for a specific page or section. It focuses on the page title, subtitle, back navigation, and primary local actions (like \"Create\" or \"Edit\").",
377
+ "category": "ui",
378
+ "import": "xertica-ui/ui",
379
+ "keywords": ["page-title", "heading", "section-header"],
380
+ "relatedComponents": ["breadcrumb", "header", "button"]
381
+ },
382
+ {
383
+ "name": "pagination",
384
+ "docPath": "docs/components/pagination.md",
385
+ "sourcePath": "components/ui/pagination/index.ts",
386
+ "description": "A navigation control for moving through pages of a large dataset. Renders Previous/Next buttons, numbered page buttons, and ellipsis for large page counts. Use it below data tables to control which page of records is displayed.",
387
+ "category": "ui",
388
+ "import": "xertica-ui/ui",
389
+ "keywords": ["pages", "paging", "page-navigation", "next-prev"],
390
+ "relatedComponents": ["table"]
391
+ },
392
+ {
393
+ "name": "popover",
394
+ "docPath": "docs/components/popover.md",
395
+ "sourcePath": "components/ui/popover/index.ts",
396
+ "description": "A floating panel anchored to a trigger element that presents additional information or controls without navigating away from the current context. Unlike `Tooltip`, Popover content can be interactive — forms, date pickers, settings panels, filter controls.",
397
+ "category": "ui",
398
+ "import": "xertica-ui/ui",
399
+ "keywords": ["floating-panel", "anchored-panel", "overlay-panel"],
400
+ "relatedComponents": ["tooltip", "hover-card", "sheet", "dialog"]
401
+ },
402
+ {
403
+ "name": "progress",
404
+ "docPath": "docs/components/progress.md",
405
+ "sourcePath": "components/ui/progress/index.ts",
406
+ "description": "A visual indicator of completion or percentage. Renders a horizontal bar filled to a given percentage. It is purely display-only — for interactive value selection, use `<Slider>`.",
407
+ "category": "ui",
408
+ "import": "xertica-ui/ui",
409
+ "keywords": ["loading-bar", "completion", "percentage"],
410
+ "relatedComponents": ["skeleton", "slider"]
411
+ },
412
+ {
413
+ "name": "radio-group",
414
+ "docPath": "docs/components/radio-group.md",
415
+ "sourcePath": "components/ui/radio-group/index.ts",
416
+ "description": "A set of mutually exclusive options where selecting one automatically deselects all others. Built on Radix UI with full keyboard navigation (arrow keys cycle through options). Use when only one choice from a defined set is valid.",
417
+ "category": "ui",
418
+ "import": "xertica-ui/ui",
419
+ "keywords": ["radio", "single-select", "exclusive-choice"],
420
+ "relatedComponents": ["select", "checkbox"]
421
+ },
422
+ {
423
+ "name": "rating",
424
+ "docPath": "docs/components/rating.md",
425
+ "sourcePath": "components/ui/rating/index.ts",
426
+ "description": "A star-based rating input that allows users to rate items on a 1–5 (or custom range) scale. Supports both interactive rating input and read-only display modes.",
427
+ "category": "ui",
428
+ "import": "xertica-ui/ui",
429
+ "keywords": ["stars", "star-rating", "review-score"],
430
+ "relatedComponents": ["input"]
431
+ },
432
+ {
433
+ "name": "resizable",
434
+ "docPath": "docs/components/resizable.md",
435
+ "sourcePath": "components/ui/resizable/index.ts",
436
+ "description": "A panel splitter that lets users resize adjacent panels by dragging a handle. Used in IDE-style layouts, split-view editors, and any interface where two panels need to share space dynamically.",
437
+ "category": "ui",
438
+ "import": "xertica-ui/ui",
439
+ "keywords": ["split-panel", "resize", "drag-handle", "panel-splitter"],
440
+ "relatedComponents": ["sidebar"]
441
+ },
442
+ {
443
+ "name": "rich-text-editor",
444
+ "docPath": "docs/components/rich-text-editor.md",
445
+ "sourcePath": "components/ui/rich-text-editor/index.ts",
446
+ "description": "A lightweight, native WYSIWYG (What You See Is What You Get) document text editor built into the Xertica UI framework. It utilizes the browser's native `contentEditable` architecture and `document.execCommand` under the hood to provide essential text formatting without the overhead of massive third-party rendering engines.",
447
+ "category": "ui",
448
+ "import": "xertica-ui/ui",
449
+ "keywords": ["wysiwyg", "editor", "text-editor"],
450
+ "relatedComponents": ["textarea", "form"]
451
+ },
452
+ {
453
+ "name": "route-map",
454
+ "docPath": "docs/components/route-map.md",
455
+ "sourcePath": "components/ui/route-map/index.ts",
456
+ "description": "A specialized Google Maps component that calculates and renders a route between an origin and destination point, with support for intermediate waypoints and multiple travel modes. The route is drawn on the map using the Google Directions Service, and optionally returns the calculated distance and duration.",
457
+ "category": "ui",
458
+ "import": "xertica-ui/ui",
459
+ "keywords": ["directions", "route", "navigation-map", "waypoints"],
460
+ "relatedComponents": ["map", "simple-map"]
461
+ },
462
+ {
463
+ "name": "scroll-area",
464
+ "docPath": "docs/components/scroll-area.md",
465
+ "sourcePath": "components/ui/scroll-area/index.ts",
466
+ "description": "A cross-browser, themeable scrollable container with custom scrollbar styling. Use instead of native `overflow-y-auto` when the scrollbar needs to match the application's design system (instead of the OS default scrollbar).",
467
+ "category": "ui",
468
+ "import": "xertica-ui/ui",
469
+ "keywords": ["scrollbar", "overflow", "custom-scroll"],
470
+ "relatedComponents": ["card", "sidebar"]
471
+ },
472
+ {
473
+ "name": "search",
474
+ "docPath": "docs/components/search.md",
475
+ "sourcePath": "components/ui/search/index.ts",
476
+ "description": "A pre-built search input with a built-in search icon and clear button. Supports `sm`, `md`, `lg` size variants matching the Input scale. Handles Escape-to-clear and exposes `onSearch` for simple string callbacks.",
477
+ "category": "ui",
478
+ "import": "xertica-ui/ui",
479
+ "keywords": ["search-input", "filter", "query", "find"],
480
+ "relatedComponents": ["input", "command", "table"]
481
+ },
482
+ {
483
+ "name": "select",
484
+ "docPath": "docs/components/select.md",
485
+ "sourcePath": "components/ui/select/index.ts",
486
+ "description": "A styled dropdown for selecting a single option from a list. Built on Radix UI, it provides a fully accessible combobox with keyboard navigation, portaled content, and proper ARIA semantics. Always use `<Select>` from `xertica-ui` — never use native `<select>`.",
487
+ "category": "ui",
488
+ "import": "xertica-ui/ui",
489
+ "keywords": ["dropdown", "combobox", "picker", "chooser"],
490
+ "relatedComponents": ["radio-group", "command", "input"]
491
+ },
492
+ {
493
+ "name": "separator",
494
+ "docPath": "docs/components/separator.md",
495
+ "sourcePath": "components/ui/separator/index.ts",
496
+ "description": "A thin horizontal (or vertical) line that visually divides sections of content. Primarily decorative but semantically meaningful as an `<hr>` element. Used to create visual breathing room between logically distinct sections.",
497
+ "category": "ui",
498
+ "import": "xertica-ui/ui",
499
+ "keywords": ["divider", "hr", "horizontal-rule", "line"],
500
+ "relatedComponents": ["card"]
501
+ },
502
+ {
503
+ "name": "sheet",
504
+ "docPath": "docs/components/sheet.md",
505
+ "sourcePath": "components/ui/sheet/index.ts",
506
+ "description": "An edge-anchored slide-in panel that overlays the current page from one side — top, right, bottom, or left. Like `Dialog` but more suitable for forms or detail views that benefit from more vertical space, or for secondary navigation and controls on mobile.",
507
+ "category": "ui",
508
+ "import": "xertica-ui/ui",
509
+ "keywords": ["side-panel", "slide-in", "panel"],
510
+ "relatedComponents": ["dialog", "drawer", "popover"]
511
+ },
512
+ {
513
+ "name": "sidebar",
514
+ "docPath": "docs/components/sidebar.md",
515
+ "sourcePath": "components/layout/sidebar/index.ts",
516
+ "description": "The `Sidebar` is the primary vertical navigation panel of the application shell. It manages the app's hierarchy, supporting simple lists, grouped items, and an advanced \"Assistant\" mode for AI-driven or data-rich interfaces.",
517
+ "category": "layout",
518
+ "import": "xertica-ui/layout",
519
+ "keywords": ["nav", "navigation", "menu", "side-nav", "vertical-nav"],
520
+ "relatedComponents": ["header", "navigation-menu"]
521
+ },
522
+ {
523
+ "name": "simple-map",
524
+ "docPath": "docs/components/simple-map.md",
525
+ "sourcePath": "components/ui/simple-map/index.ts",
526
+ "description": "A simplified wrapper for common map use cases where you only need a single marker and basic configuration.",
527
+ "category": "ui",
528
+ "import": "xertica-ui/ui",
529
+ "keywords": ["basic-map", "single-marker", "map-pin"],
530
+ "relatedComponents": ["map", "route-map"]
531
+ },
532
+ {
533
+ "name": "skeleton",
534
+ "docPath": "docs/components/skeleton.md",
535
+ "sourcePath": "components/ui/skeleton/index.ts",
536
+ "description": "A loading placeholder that mimics the shape and dimensions of content while it's being fetched. Use it to provide visual continuity and reduce perceived load time — never leave blank white space while content is loading.",
537
+ "category": "ui",
538
+ "import": "xertica-ui/ui",
539
+ "keywords": ["loading-placeholder", "shimmer", "placeholder"],
540
+ "relatedComponents": ["progress", "empty"]
541
+ },
542
+ {
543
+ "name": "slider",
544
+ "docPath": "docs/components/slider.md",
545
+ "sourcePath": "components/ui/slider/index.ts",
546
+ "description": "A range input control that lets users select a numeric value by dragging a thumb along a track. Used for quantity selectors, volume controls, percentage settings, and any value within a continuous range.",
547
+ "category": "ui",
548
+ "import": "xertica-ui/ui",
549
+ "keywords": ["range", "range-input", "volume", "scrubber"],
550
+ "relatedComponents": ["progress", "input"]
551
+ },
552
+ {
553
+ "name": "sonner",
554
+ "docPath": "docs/components/sonner.md",
555
+ "sourcePath": "components/ui/sonner/index.ts",
556
+ "description": "Sonner is the toast notification system. It displays ephemeral feedback messages that appear at a fixed position on screen (top-right by default), auto-dismiss after a few seconds, and can be dismissed manually. `<Toaster>` is auto-injected by `<XerticaProvider>` — you never need to render it manually.",
557
+ "category": "ui",
558
+ "import": "xertica-ui/ui",
559
+ "keywords": ["toast", "notification", "snackbar", "alert-message"],
560
+ "relatedComponents": ["alert", "dialog"]
561
+ },
562
+ {
563
+ "name": "stats-card",
564
+ "docPath": "docs/components/stats-card.md",
565
+ "sourcePath": "components/ui/stats-card/index.ts",
566
+ "description": "A pre-built KPI (Key Performance Indicator) card for dashboard overview pages. Renders a metric title, a large value, an optional trend indicator with automatic up/down/neutral icon, and an optional icon.",
567
+ "category": "ui",
568
+ "import": "xertica-ui/ui",
569
+ "keywords": ["kpi", "metric", "counter", "dashboard-card"],
570
+ "relatedComponents": ["card", "chart"]
571
+ },
572
+ {
573
+ "name": "stepper",
574
+ "docPath": "docs/components/stepper.md",
575
+ "sourcePath": "components/ui/stepper/index.ts",
576
+ "description": "A visual multi-step progress indicator that shows the user's current position within a sequential process. Uses a composable primitive pattern: `<Stepper>` wraps one or more `<Step>` children, automatically inferring the total number of steps.",
577
+ "category": "ui",
578
+ "import": "xertica-ui/ui",
579
+ "keywords": ["wizard", "multi-step", "progress-steps", "onboarding"],
580
+ "relatedComponents": ["progress", "tabs"]
581
+ },
582
+ {
583
+ "name": "switch",
584
+ "docPath": "docs/components/switch.md",
585
+ "sourcePath": "components/ui/switch/index.ts",
586
+ "description": "A binary toggle control that represents an on/off state — similar to a physical light switch. More prominent and visually expressive than a `<Checkbox>`. Used for feature toggles, notification settings, accessibility preferences, and any prominent boolean setting.",
587
+ "category": "ui",
588
+ "import": "xertica-ui/ui",
589
+ "keywords": ["toggle", "on-off", "boolean", "feature-flag"],
590
+ "relatedComponents": ["checkbox", "toggle"]
591
+ },
592
+ {
593
+ "name": "table",
594
+ "docPath": "docs/components/table.md",
595
+ "sourcePath": "components/ui/table/index.ts",
596
+ "description": "Structured tabular data display. Provides semantic HTML table elements wrapped in accessible, styled components. Used in CRUD list pages, reports, and any data-heavy view where rows represent records and columns represent attributes.",
597
+ "category": "ui",
598
+ "import": "xertica-ui/ui",
599
+ "keywords": ["data-table", "grid", "list", "rows", "columns", "crud"],
600
+ "relatedComponents": ["pagination", "badge", "dropdown-menu", "empty"]
601
+ },
602
+ {
603
+ "name": "tabs",
604
+ "docPath": "docs/components/tabs.md",
605
+ "sourcePath": "components/ui/tabs/index.ts",
606
+ "description": "A content switcher that organizes related views under labelled tab triggers. One tab is active at a time. Used for multi-view dashboards, analytics pages, settings sections, and any context where content is segmented but logically related.",
607
+ "category": "ui",
608
+ "import": "xertica-ui/ui",
609
+ "keywords": ["tab-bar", "tab-panel", "switcher", "tabbed-content"],
610
+ "relatedComponents": ["navigation-menu", "accordion"]
611
+ },
612
+ {
613
+ "name": "textarea",
614
+ "docPath": "docs/components/textarea.md",
615
+ "sourcePath": "components/ui/textarea/index.ts",
616
+ "description": "A multi-line text input for longer content: descriptions, notes, messages, and rich text fields. Automatically resizable or fixed, depending on the `resize` CSS class applied.",
617
+ "category": "ui",
618
+ "import": "xertica-ui/ui",
619
+ "keywords": ["multi-line", "text-area", "description-field", "notes"],
620
+ "relatedComponents": ["input", "form", "rich-text-editor"]
621
+ },
622
+ {
623
+ "name": "theme-toggle",
624
+ "docPath": "docs/components/theme-toggle.md",
625
+ "sourcePath": "components/brand/theme-toggle/index.ts",
626
+ "description": "A self-contained light/dark mode toggle button that operates directly on the `document.documentElement` class list.",
627
+ "category": "brand",
628
+ "import": "xertica-ui/brand",
629
+ "keywords": ["dark-mode", "light-mode", "color-scheme"],
630
+ "relatedComponents": ["header", "sidebar"]
631
+ },
632
+ {
633
+ "name": "timeline",
634
+ "docPath": "docs/components/timeline.md",
635
+ "sourcePath": "components/ui/timeline/index.ts",
636
+ "description": "A vertical sequence of events displayed chronologically, each with a timestamp, title, and optional description. Used in activity logs, audit trails, case histories, and notification feeds.",
637
+ "category": "ui",
638
+ "import": "xertica-ui/ui",
639
+ "keywords": ["activity-log", "history", "event-log", "audit-trail"],
640
+ "relatedComponents": ["table", "card"]
641
+ },
642
+ {
643
+ "name": "toggle-group",
644
+ "docPath": "docs/components/toggle-group.md",
645
+ "sourcePath": "components/ui/toggle-group/index.ts",
646
+ "description": "A set of related `<Toggle>` buttons that operate together — either allowing only one selection at a time (`type=\"single\"`) or multiple simultaneous selections (`type=\"multiple\"`). Used for mutually exclusive view modes, filter groups, and formatting toolbars.",
647
+ "category": "ui",
648
+ "import": "xertica-ui/ui",
649
+ "keywords": ["segmented-control", "exclusive-toggle", "multi-toggle"],
650
+ "relatedComponents": ["toggle", "tabs"]
651
+ },
652
+ {
653
+ "name": "toggle",
654
+ "docPath": "docs/components/toggle.md",
655
+ "sourcePath": "components/ui/toggle/index.ts",
656
+ "description": "A pressable button that maintains an on/off state visually, similar to a keyboard key that stays pressed. Used in toolbars for formatting, view switching, and feature activation.",
657
+ "category": "ui",
658
+ "import": "xertica-ui/ui",
659
+ "keywords": ["pressable", "pressed-state", "toolbar-toggle"],
660
+ "relatedComponents": ["switch", "checkbox", "toggle-group"]
661
+ },
662
+ {
663
+ "name": "tooltip",
664
+ "docPath": "docs/components/tooltip.md",
665
+ "sourcePath": "components/ui/tooltip/index.ts",
666
+ "description": "A small floating label that appears on hover (or focus) over a trigger element, providing a short contextual explanation — typically for icon-only buttons, abbreviated text, or any element where the visual label alone isn't sufficient.",
667
+ "category": "ui",
668
+ "import": "xertica-ui/ui",
669
+ "keywords": ["hint", "title", "help-text", "hover-text"],
670
+ "relatedComponents": ["hover-card", "popover"]
671
+ },
672
+ {
673
+ "name": "tree-view",
674
+ "docPath": "docs/components/tree-view.md",
675
+ "sourcePath": "components/ui/tree-view/index.ts",
676
+ "description": "An interactive hierarchical tree component for displaying and navigating nested data structures — file systems, organizational charts, category trees, and recursive navigation menus.",
677
+ "category": "ui",
678
+ "import": "xertica-ui/ui",
679
+ "keywords": ["tree", "hierarchy", "nested-list", "file-tree"],
680
+ "relatedComponents": ["accordion", "sidebar"]
681
+ },
682
+ {
683
+ "name": "use-mobile",
684
+ "docPath": "docs/components/use-mobile.md",
685
+ "sourcePath": "components/shared/use-mobile.ts",
686
+ "description": "Two hooks that detect whether the current viewport is a mobile-width screen. Useful for conditionally rendering mobile-specific layouts, swapping components (e.g., `Drawer` vs `Sheet`), or hiding/showing content based on screen size.",
687
+ "category": "hooks",
688
+ "import": "xertica-ui/hooks",
689
+ "keywords": ["responsive", "mobile-detection", "breakpoint", "isMobile"],
690
+ "relatedComponents": []
691
+ },
692
+ {
693
+ "name": "xertica-logo",
694
+ "docPath": "docs/components/xertica-logo.md",
695
+ "sourcePath": "components/brand/xertica-logo/index.ts",
696
+ "description": "The official full horizontal logotype for Xertica. It is a vector-based SVG component that ensures brand consistency across all application headers and splash screens.",
697
+ "category": "brand",
698
+ "import": "xertica-ui/brand",
699
+ "keywords": ["logo", "brand", "logotype"],
700
+ "relatedComponents": ["xertica-xlogo", "xertica-orbe"]
701
+ },
702
+ {
703
+ "name": "xertica-orbe",
704
+ "docPath": "docs/components/xertica-orbe.md",
705
+ "sourcePath": "components/brand/xertica-orbe/index.ts",
706
+ "description": "An animated, decorative brand element representing the Xertica \"Orbe\". It features CSS-based pulse and rotation animations to provide a premium, dynamic feel to hero sections and loading screens.",
707
+ "category": "brand",
708
+ "import": "xertica-ui/brand",
709
+ "keywords": ["orb", "animated-logo", "brand-animation"],
710
+ "relatedComponents": ["xertica-logo"]
711
+ },
712
+ {
713
+ "name": "xertica-provider",
714
+ "docPath": "docs/components/xertica-provider.md",
715
+ "sourcePath": "components/brand/xertica-provider/index.ts",
716
+ "description": "The mandatory root wrapper for all Xertica UI applications. It synchronizes global configurations and injects essential context providers for layout, tooltips, maps, and notifications.",
717
+ "category": "brand",
718
+ "import": "xertica-ui/brand",
719
+ "keywords": ["provider", "root", "context", "app-wrapper"],
720
+ "relatedComponents": []
721
+ },
722
+ {
723
+ "name": "xertica-xlogo",
724
+ "docPath": "docs/components/xertica-xlogo.md",
725
+ "sourcePath": "components/brand/xertica-xlogo/index.ts",
726
+ "description": "A compact, square variant of the Xertica logo featuring the stylized \"X\" mark. Ideal for favicons, collapsed sidebars, and small profile badges.",
727
+ "category": "brand",
728
+ "import": "xertica-ui/brand",
729
+ "keywords": ["x-logo", "compact-logo", "icon-logo", "favicon"],
730
+ "relatedComponents": ["xertica-logo", "sidebar"]
731
+ },
732
+ {
733
+ "name": "video-player",
734
+ "docPath": "docs/components/video-player.md",
735
+ "sourcePath": "components/media/video-player/index.ts",
736
+ "description": "A feature-rich video player with custom controls, progress bar, volume, and floating mode support. Built on HTML5 video with React state management.",
737
+ "category": "media",
738
+ "import": "xertica-ui/media",
739
+ "keywords": ["video", "player", "media", "playback"],
740
+ "relatedComponents": ["audio-player", "floating-media-wrapper"]
741
+ },
742
+ {
743
+ "name": "code-block",
744
+ "docPath": "docs/components/assistant.md",
745
+ "sourcePath": "components/assistant/code-block/index.ts",
746
+ "description": "A syntax-highlighted code block component for the Xertica Assistant. It renders code snippets with language detection and copy-to-clipboard functionality.",
747
+ "category": "assistant",
748
+ "import": "xertica-ui/assistant",
749
+ "keywords": ["syntax-highlight", "code", "snippet", "copy-code"],
750
+ "relatedComponents": ["markdown-message", "xertica-assistant"]
751
+ },
752
+ {
753
+ "name": "formatted-document",
754
+ "docPath": "docs/components/assistant.md",
755
+ "sourcePath": "components/assistant/formatted-document/index.ts",
756
+ "description": "A structured document renderer for displaying AI-generated content with headings, paragraphs, lists, and rich formatting support.",
757
+ "category": "assistant",
758
+ "import": "xertica-ui/assistant",
759
+ "keywords": ["formatted document"],
760
+ "relatedComponents": []
761
+ },
762
+ {
763
+ "name": "modern-chat-input",
764
+ "docPath": "docs/components/assistant.md",
765
+ "sourcePath": "components/assistant/modern-chat-input/index.ts",
766
+ "description": "A chat input component for the AI Assistant with multi-line support, auto-resize, and keyboard shortcuts. Used as the primary input in the assistant interface.",
767
+ "category": "assistant",
768
+ "import": "xertica-ui/assistant",
769
+ "keywords": ["modern chat input"],
770
+ "relatedComponents": []
771
+ },
772
+ {
773
+ "name": "xertica-assistant",
774
+ "docPath": "docs/components/assistant.md",
775
+ "sourcePath": "components/assistant/xertica-assistant/index.ts",
776
+ "description": "A conversational AI assistant panel that integrates with the application. Provides chat interface, message rendering, suggestions, and file attachments.",
777
+ "category": "assistant",
778
+ "import": "xertica-ui/assistant",
779
+ "keywords": ["ai-chat", "chatbot", "ai-panel", "assistant", "llm-chat"],
780
+ "relatedComponents": ["markdown-message", "code-block"]
781
+ },
782
+ {
783
+ "name": "login-page",
784
+ "docPath": "docs/getting-started.md",
785
+ "sourcePath": "components/pages/login-page/index.ts",
786
+ "description": "A complete login page template with email/password fields, theme toggle, and language selector integration.",
787
+ "category": "pages",
788
+ "import": "xertica-ui",
789
+ "keywords": ["login page"],
790
+ "relatedComponents": []
791
+ },
792
+ {
793
+ "name": "forgot-password-page",
794
+ "docPath": "docs/getting-started.md",
795
+ "sourcePath": "components/pages/forgot-password-page/index.ts",
796
+ "description": "A forgot password page template with email input and reset flow integration.",
797
+ "category": "pages",
798
+ "import": "xertica-ui",
799
+ "keywords": ["forgot password page"],
800
+ "relatedComponents": []
801
+ },
802
+ {
803
+ "name": "reset-password-page",
804
+ "docPath": "docs/getting-started.md",
805
+ "sourcePath": "components/pages/reset-password-page/index.ts",
806
+ "description": "A reset password page template with new password and confirmation fields.",
807
+ "category": "pages",
808
+ "import": "xertica-ui",
809
+ "keywords": ["reset password page"],
810
+ "relatedComponents": []
811
+ },
812
+ {
813
+ "name": "verify-email-page",
814
+ "docPath": "docs/getting-started.md",
815
+ "sourcePath": "components/pages/verify-email-page/index.ts",
816
+ "description": "A verify email page template with OTP code input for email verification.",
817
+ "category": "pages",
818
+ "import": "xertica-ui",
819
+ "keywords": ["verify email page"],
820
+ "relatedComponents": []
821
+ },
822
+ {
823
+ "name": "home-page",
824
+ "docPath": "docs/getting-started.md",
825
+ "sourcePath": "components/pages/home-page/index.ts",
826
+ "description": "A home page template with sidebar navigation, header, and content area. The base layout for application pages.",
827
+ "category": "pages",
828
+ "import": "xertica-ui",
829
+ "keywords": ["home page"],
830
+ "relatedComponents": []
831
+ },
832
+ {
833
+ "name": "home-content",
834
+ "docPath": "docs/getting-started.md",
835
+ "sourcePath": "components/pages/home-content/index.ts",
836
+ "description": "The content area component for home pages, providing a flexible container for page-specific content.",
837
+ "category": "pages",
838
+ "import": "xertica-ui",
839
+ "keywords": ["home content"],
840
+ "relatedComponents": []
841
+ },
842
+ {
843
+ "name": "template-page",
844
+ "docPath": "docs/getting-started.md",
845
+ "sourcePath": "components/pages/template-page/index.ts",
846
+ "description": "A flexible page template component that wraps the layout system with configurable header, sidebar, and content areas.",
847
+ "category": "pages",
848
+ "import": "xertica-ui",
849
+ "keywords": ["template page"],
850
+ "relatedComponents": []
851
+ },
852
+ {
853
+ "name": "template-content",
854
+ "docPath": "docs/getting-started.md",
855
+ "sourcePath": "components/pages/template-content/index.ts",
856
+ "description": "A content wrapper component for template pages, providing consistent padding and layout behavior.",
857
+ "category": "pages",
858
+ "import": "xertica-ui",
859
+ "keywords": ["template content"],
860
+ "relatedComponents": []
861
+ },
862
+ {
863
+ "name": "map-layers",
864
+ "docPath": "docs/components/map.md",
865
+ "sourcePath": "components/ui/map-layers/index.ts",
866
+ "description": "A utility for managing Google Maps layers including traffic, transit, bicycling, and weather layers with theme-aware styling.",
867
+ "category": "ui",
868
+ "import": "xertica-ui/ui",
869
+ "keywords": ["map layers"],
870
+ "relatedComponents": []
871
+ },
872
+ {
873
+ "name": "map-config",
874
+ "docPath": "docs/components/map.md",
875
+ "sourcePath": "components/ui/map-config/index.ts",
876
+ "description": "Configuration utility for Google Maps shared settings and theme-based styling.",
877
+ "category": "ui",
878
+ "import": "xertica-ui/ui",
879
+ "keywords": ["map config"],
880
+ "relatedComponents": []
881
+ },
882
+ {
883
+ "name": "floating-media-wrapper",
884
+ "docPath": "docs/components/floating-media-wrapper.md",
885
+ "sourcePath": "components/media/FloatingMediaWrapper.tsx",
886
+ "description": "A higher-level wrapper for media players (audio/video) that manages floating state, positioning, and transitions.",
887
+ "category": "media",
888
+ "import": "xertica-ui/media",
889
+ "keywords": ["floating", "draggable", "portal", "picture-in-picture"],
890
+ "relatedComponents": ["video-player", "audio-player"]
891
+ }
892
+ ]