xertica-ui 2.5.0 → 2.5.2

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 (536) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/README.md +56 -17
  3. package/assets/xertica-logo.svg +37 -37
  4. package/assets/xertica-x-logo.svg +20 -20
  5. package/bin/cli.ts +14 -2
  6. package/bin/generate-tokens.ts +262 -262
  7. package/bin/language-config.ts +359 -358
  8. package/components/assistant/code-block/CodeBlock.tsx +268 -268
  9. package/components/assistant/formatted-document/FormattedDocument.tsx +147 -147
  10. package/components/assistant/modern-chat-input/ModernChatInput.tsx +564 -564
  11. package/components/assistant/xertica-assistant/parts/AssistantCollapsedView.tsx +99 -99
  12. package/components/assistant/xertica-assistant/parts/AssistantConversationList.tsx +104 -104
  13. package/components/assistant/xertica-assistant/parts/AssistantDocumentEditor.tsx +81 -81
  14. package/components/assistant/xertica-assistant/parts/AssistantFeedbackDialog.tsx +88 -88
  15. package/components/assistant/xertica-assistant/parts/AssistantHeader.tsx +75 -75
  16. package/components/assistant/xertica-assistant/parts/AssistantMessageBubble.tsx +564 -564
  17. package/components/assistant/xertica-assistant/parts/AssistantTabBar.tsx +67 -67
  18. package/components/assistant/xertica-assistant/parts/AssistantWelcomeScreen.tsx +103 -103
  19. package/components/assistant/xertica-assistant/use-assistant.ts +615 -615
  20. package/components/assistant/xertica-assistant/xertica-assistant.tsx +611 -611
  21. package/components/blocks/card-patterns/ActivityCard.tsx +100 -100
  22. package/components/blocks/card-patterns/ActivityCardSkeleton.tsx +56 -56
  23. package/components/blocks/card-patterns/FeatureCardSkeleton.tsx +58 -58
  24. package/components/blocks/card-patterns/NotificationCard.tsx +140 -140
  25. package/components/blocks/card-patterns/NotificationCardSkeleton.tsx +81 -81
  26. package/components/blocks/card-patterns/ProfileCard.tsx +112 -112
  27. package/components/blocks/card-patterns/ProfileCardSkeleton.tsx +69 -69
  28. package/components/blocks/card-patterns/ProjectCard.tsx +123 -123
  29. package/components/blocks/card-patterns/ProjectCardSkeleton.tsx +67 -67
  30. package/components/blocks/card-patterns/QuickActionCardSkeleton.tsx +44 -44
  31. package/components/blocks/card-patterns/card-patterns.stories.tsx +594 -594
  32. package/components/blocks/card-patterns/index.ts +29 -29
  33. package/components/brand/language-selector/LanguageSelector.tsx +102 -102
  34. package/components/brand/language-selector/language-selector.stories.tsx +111 -111
  35. package/components/brand/language-selector/language-selector.test.tsx +101 -101
  36. package/components/brand/theme-toggle/ThemeToggle.tsx +74 -74
  37. package/components/brand/xertica-provider/xertica-provider.mdx +61 -61
  38. package/components/index.ts +86 -86
  39. package/components/layout/sidebar/sidebar.mdx +1 -1
  40. package/components/layout/sidebar/sidebar.stories.tsx +1033 -787
  41. package/components/layout/sidebar/sidebar.tsx +338 -1
  42. package/components/media/FloatingMediaWrapper.tsx +371 -371
  43. package/components/media/audio-player/AudioPlayer.tsx +768 -768
  44. package/components/media/video-player/VideoPlayer.tsx +310 -310
  45. package/components/pages/home-content/HomeContent.tsx +120 -120
  46. package/components/pages/home-content/home-content.mdx +62 -62
  47. package/components/pages/home-page/HomePage.tsx +78 -78
  48. package/components/pages/home-page/home-page.mdx +53 -53
  49. package/components/pages/template-content/TemplateContent.tsx +1354 -1354
  50. package/components/pages/template-content/template-content.mdx +61 -61
  51. package/components/pages/template-page/TemplatePage.stories.tsx +32 -32
  52. package/components/pages/template-page/template-page.mdx +53 -53
  53. package/components/shared/error-boundary.stories.tsx +114 -114
  54. package/components/shared/error-boundary.tsx +150 -150
  55. package/components/shared/error-fallbacks.tsx +222 -222
  56. package/components/ui/accordion/accordion.mdx +8 -8
  57. package/components/ui/alert/alert.mdx +8 -8
  58. package/components/ui/alert-dialog/alert-dialog.mdx +8 -8
  59. package/components/ui/aspect-ratio/aspect-ratio.mdx +8 -8
  60. package/components/ui/assistant-chart/assistant-chart.mdx +8 -8
  61. package/components/ui/avatar/avatar.mdx +8 -8
  62. package/components/ui/badge/badge.mdx +8 -8
  63. package/components/ui/breadcrumb/breadcrumb.mdx +8 -8
  64. package/components/ui/button/button.mdx +8 -8
  65. package/components/ui/calendar/calendar.mdx +8 -8
  66. package/components/ui/card/card.mdx +8 -8
  67. package/components/ui/carousel/carousel.mdx +8 -8
  68. package/components/ui/chart/chart.mdx +8 -8
  69. package/components/ui/chart/chart.test.tsx +178 -178
  70. package/components/ui/chart/chart.tsx +2245 -2239
  71. package/components/ui/checkbox/checkbox.mdx +8 -8
  72. package/components/ui/collapsible/collapsible.mdx +8 -8
  73. package/components/ui/command/command.mdx +8 -8
  74. package/components/ui/context-menu/context-menu.mdx +8 -8
  75. package/components/ui/dialog/dialog.mdx +8 -8
  76. package/components/ui/drawer/drawer.mdx +8 -8
  77. package/components/ui/dropdown-menu/dropdown-menu.mdx +8 -8
  78. package/components/ui/empty/empty.mdx +8 -8
  79. package/components/ui/file-upload/file-upload.mdx +8 -8
  80. package/components/ui/hover-card/hover-card.mdx +8 -8
  81. package/components/ui/input/input.mdx +8 -8
  82. package/components/ui/input-otp/input-otp.mdx +8 -8
  83. package/components/ui/label/label.mdx +8 -8
  84. package/components/ui/map/map.mdx +8 -8
  85. package/components/ui/menubar/menubar.mdx +8 -8
  86. package/components/ui/navigation-menu/navigation-menu.mdx +8 -8
  87. package/components/ui/notification-badge/notification-badge.mdx +8 -8
  88. package/components/ui/pagination/pagination.mdx +8 -8
  89. package/components/ui/popover/popover.mdx +8 -8
  90. package/components/ui/progress/progress.mdx +8 -8
  91. package/components/ui/radio-group/radio-group.mdx +8 -8
  92. package/components/ui/rating/rating.mdx +8 -8
  93. package/components/ui/resizable/resizable.mdx +8 -8
  94. package/components/ui/route-map/route-map.mdx +8 -8
  95. package/components/ui/scroll-area/scroll-area.mdx +8 -8
  96. package/components/ui/search/search.mdx +8 -8
  97. package/components/ui/select/select.mdx +8 -8
  98. package/components/ui/separator/separator.mdx +8 -8
  99. package/components/ui/sheet/sheet.mdx +8 -8
  100. package/components/ui/simple-map/simple-map.mdx +8 -8
  101. package/components/ui/skeleton/skeleton.mdx +8 -8
  102. package/components/ui/slider/slider.mdx +8 -8
  103. package/components/ui/sonner/sonner.mdx +8 -8
  104. package/components/ui/stats-card/index.ts +2 -2
  105. package/components/ui/stats-card/stats-card-skeleton.tsx +60 -60
  106. package/components/ui/stats-card/stats-card.mdx +8 -8
  107. package/components/ui/stats-card/stats-card.tsx +109 -109
  108. package/components/ui/stepper/stepper.mdx +8 -8
  109. package/components/ui/switch/switch.mdx +8 -8
  110. package/components/ui/table/table.mdx +8 -8
  111. package/components/ui/tabs/tabs.mdx +8 -8
  112. package/components/ui/textarea/textarea.mdx +8 -8
  113. package/components/ui/timeline/timeline.mdx +8 -8
  114. package/components/ui/toggle/toggle.mdx +8 -8
  115. package/components/ui/toggle-group/toggle-group.mdx +8 -8
  116. package/components/ui/tooltip/tooltip.mdx +8 -8
  117. package/components/ui/tree-view/tree-view.mdx +8 -8
  118. package/components.json +511 -511
  119. package/contexts/AuthContext.tsx +121 -121
  120. package/contexts/BrandColorsContext.tsx +282 -282
  121. package/contexts/LanguageContext.test.tsx +121 -121
  122. package/contexts/LanguageContext.tsx +250 -250
  123. package/contexts/theme-data.ts +391 -391
  124. package/dist/{AssistantChart-DoZCyS5r.cjs → AssistantChart-9w31gdAb.cjs} +4 -4
  125. package/dist/{AssistantChart-CldVCVDe.cjs → AssistantChart-BAudAfne.cjs} +5 -5
  126. package/dist/{AssistantChart-Bdd44uBn.cjs → AssistantChart-BAx9VQvb.cjs} +127 -388
  127. package/dist/{AssistantChart-Cu3m7RBo.js → AssistantChart-BP8upjMk.js} +5 -5
  128. package/dist/{AssistantChart-CFhDdGyU.js → AssistantChart-CVko2A1W.js} +130 -391
  129. package/dist/{AssistantChart-C_hwFRRr.js → AssistantChart-CVzmmhx4.js} +4 -4
  130. package/dist/{AudioPlayer-IAU5q5T1.cjs → AudioPlayer-1ypwE2Wh.cjs} +1 -1
  131. package/dist/{AudioPlayer-CGRUtUdN.js → AudioPlayer-DuKXrCfy.js} +1 -1
  132. package/dist/{LanguageContext-CS14yCpi.js → LanguageContext-BwhwC3G2.js} +2 -2
  133. package/dist/{LanguageContext-B_KFTCzT.cjs → LanguageContext-DvUt5jBg.cjs} +2 -2
  134. package/dist/{ThemeContext-C2EwAPDt.js → ThemeContext-BbBNoFTG.js} +2 -2
  135. package/dist/{ThemeContext-Bmod0Cg2.cjs → ThemeContext-BblcjQup.cjs} +13 -8
  136. package/dist/{ThemeContext-BWq9ACPo.js → ThemeContext-Bo-W2WZH.js} +13 -8
  137. package/dist/{ThemeContext-j5aGtPky.cjs → ThemeContext-CP3a0jxy.cjs} +193 -262
  138. package/dist/{ThemeContext-vTjumZeM.cjs → ThemeContext-Cmr8Ex8H.cjs} +2 -2
  139. package/dist/ThemeContext-CpqYShLq.cjs +324 -0
  140. package/dist/{ThemeContext-CQSo4Iwc.js → ThemeContext-D3LzacmG.js} +8 -1
  141. package/dist/ThemeContext-Du2nE1PL.js +325 -0
  142. package/dist/ThemeContext-GeEBTJ3q.cjs +1621 -0
  143. package/dist/ThemeContext-JyLK9B1o.js +1622 -0
  144. package/dist/{ThemeContext-CGk3KK0k.cjs → ThemeContext-U4dEYc6C.cjs} +8 -1
  145. package/dist/{ThemeContext-BXjrgUjW.js → ThemeContext-ept8jhXI.js} +200 -261
  146. package/dist/{VerifyEmailPage-CGIwmWrm.js → VerifyEmailPage-B31mCrMc.js} +1 -1
  147. package/dist/{VerifyEmailPage-C0c2e5n0.js → VerifyEmailPage-BE-L9mB7.js} +7 -7
  148. package/dist/{VerifyEmailPage-DSBMRHtl.js → VerifyEmailPage-BIBOKV7Z.js} +41 -36
  149. package/dist/{VerifyEmailPage-DgIid028.js → VerifyEmailPage-BJjAMUTW.js} +4 -4
  150. package/dist/{VerifyEmailPage--1Vurewl.cjs → VerifyEmailPage-BRSP-Pwt.cjs} +3 -3
  151. package/dist/{VerifyEmailPage-Cwi3kbol.cjs → VerifyEmailPage-Bae2cBXT.cjs} +7 -7
  152. package/dist/{VerifyEmailPage-De6bQjrz.cjs → VerifyEmailPage-BiRm7Nh4.cjs} +41 -36
  153. package/dist/{VerifyEmailPage-ByerOcm4.cjs → VerifyEmailPage-Bv8Ah_TK.cjs} +23 -20
  154. package/dist/VerifyEmailPage-Bvfv8HVQ.js +3214 -0
  155. package/dist/{VerifyEmailPage-BComraR7.cjs → VerifyEmailPage-CR7kb5df.cjs} +22 -12
  156. package/dist/{VerifyEmailPage-CpqqpLpo.cjs → VerifyEmailPage-C_Zk6Gen.cjs} +1 -1
  157. package/dist/{VerifyEmailPage-MTD7AG1Z.js → VerifyEmailPage-C_ihbcth.js} +4 -4
  158. package/dist/{VerifyEmailPage-1WwWczAn.js → VerifyEmailPage-CbgjOF0v.js} +22 -12
  159. package/dist/{VerifyEmailPage-DvMLZgFt.js → VerifyEmailPage-CdYPSJoO.js} +1 -1
  160. package/dist/{VerifyEmailPage-By3Jf__L.cjs → VerifyEmailPage-CkBYfsNy.cjs} +4 -4
  161. package/dist/{VerifyEmailPage-CJLz3jrn.js → VerifyEmailPage-Cyl55sJb.js} +23 -20
  162. package/dist/VerifyEmailPage-D-FRj5TU.cjs +3213 -0
  163. package/dist/{VerifyEmailPage-B4peJjAT.cjs → VerifyEmailPage-DF2ilhum.cjs} +334 -356
  164. package/dist/{VerifyEmailPage-CYXtbKi3.cjs → VerifyEmailPage-DMBh4NM9.cjs} +1 -1
  165. package/dist/{VerifyEmailPage-CgMxRb4z.js → VerifyEmailPage-DTtFfC-J.js} +3 -3
  166. package/dist/{VerifyEmailPage-CFLMls1p.cjs → VerifyEmailPage-Dt7zgA4w.cjs} +4 -4
  167. package/dist/{VerifyEmailPage-C5TNQTBa.js → VerifyEmailPage-EhudUdqF.js} +343 -355
  168. package/dist/{VerifyEmailPage-DGhuIqkb.js → VerifyEmailPage-X14vhdyl.js} +4 -4
  169. package/dist/VerifyEmailPage-hdB8JQGv.cjs +3213 -0
  170. package/dist/{VerifyEmailPage-Bp1XXl3H.cjs → VerifyEmailPage-u_Dn7t1U.cjs} +4 -4
  171. package/dist/VerifyEmailPage-vYHbYK3q.js +3214 -0
  172. package/dist/{XerticaProvider-CBGc4EMA.cjs → XerticaProvider-AChwphCO.cjs} +4 -4
  173. package/dist/{XerticaProvider-BIrqfZ-i.cjs → XerticaProvider-AbWlr7Af.cjs} +8 -11
  174. package/dist/{XerticaProvider-D-yNhF94.cjs → XerticaProvider-B8CaV7xu.cjs} +1 -1
  175. package/dist/{XerticaProvider-CEoWMTxu.js → XerticaProvider-BITjgC5p.js} +2 -2
  176. package/dist/{XerticaProvider-CllrbMEJ.cjs → XerticaProvider-By8q3Roe.cjs} +2 -2
  177. package/dist/{XerticaProvider-C1DKnvLh.js → XerticaProvider-CUYJZc32.js} +4 -4
  178. package/dist/{XerticaProvider-ET0ihewn.cjs → XerticaProvider-CW9hpCdF.cjs} +2 -2
  179. package/dist/{XerticaProvider-Dt5HEzbQ.js → XerticaProvider-CWgby5mY.js} +10 -10
  180. package/dist/XerticaProvider-CWs6EwNa.js +49 -0
  181. package/dist/XerticaProvider-CjQAQPcn.cjs +48 -0
  182. package/dist/XerticaProvider-D5lLumH-.js +49 -0
  183. package/dist/{XerticaProvider-DYq4JWtg.js → XerticaProvider-DQtvJU7m.js} +1 -1
  184. package/dist/XerticaProvider-qQUDop71.cjs +48 -0
  185. package/dist/{XerticaProvider-B7EVH-NF.js → XerticaProvider-siSt9uG2.js} +2 -2
  186. package/dist/{XerticaXLogo-Zw2B276b.cjs → XerticaXLogo-8TTzBjHw.cjs} +1 -1
  187. package/dist/{XerticaXLogo-B7xQ5dhi.js → XerticaXLogo-BWaag64t.js} +1 -1
  188. package/dist/{XerticaXLogo-DZbo4vOE.js → XerticaXLogo-CFuIlYFH.js} +12 -12
  189. package/dist/{XerticaXLogo-bvZSgwGF.cjs → XerticaXLogo-CU-U-GP4.cjs} +7 -13
  190. package/dist/XerticaXLogo-ChryA6xj.js +252 -0
  191. package/dist/{XerticaXLogo-CQUUjXoH.cjs → XerticaXLogo-CziKMQil.cjs} +8 -8
  192. package/dist/XerticaXLogo-DHz5SugF.js +252 -0
  193. package/dist/XerticaXLogo-DTee_y8X.cjs +251 -0
  194. package/dist/{XerticaXLogo-Cmsp-Eey.js → XerticaXLogo-DfUvz-lD.js} +9 -9
  195. package/dist/XerticaXLogo-kslQ8Tk_.cjs +251 -0
  196. package/dist/{alert-dialog-s-vmNkJ_.js → alert-dialog-iDe5VE5o.js} +3 -3
  197. package/dist/{alert-dialog-DSKByiKZ.cjs → alert-dialog-yckpaOpy.cjs} +3 -3
  198. package/dist/cli.js +16 -6
  199. package/dist/components/ui/chart/chart.d.ts +7 -5
  200. package/dist/{google-maps-loader-Y-QkD-Li.cjs → google-maps-loader-BqsYL48U.cjs} +0 -5
  201. package/dist/{google-maps-loader-CTYySAun.js → google-maps-loader-t2IlYBzw.js} +0 -4
  202. package/dist/index-CkTUgOwX.js +8 -0
  203. package/dist/{index-COtD8bRW.cjs → index-D3RLKRAs.cjs} +1 -1
  204. package/dist/index.cjs.js +2 -2
  205. package/dist/index.es.js +2 -2
  206. package/dist/index.umd.js +454 -1027
  207. package/dist/layout.cjs.js +1 -1
  208. package/dist/layout.es.js +1 -1
  209. package/dist/pages.cjs.js +1 -1
  210. package/dist/pages.es.js +1 -1
  211. package/dist/{sidebar-DAaY8bRU.cjs → sidebar-B3EYhli0.cjs} +33 -24
  212. package/dist/{sidebar-nzPoVHBQ.cjs → sidebar-B9NR0lCe.cjs} +46 -41
  213. package/dist/{sidebar-CeTMuzOx.cjs → sidebar-BvF5I2Ue.cjs} +47 -128
  214. package/dist/{sidebar-q7P2Godd.cjs → sidebar-C5B_LHek.cjs} +1 -1
  215. package/dist/{sidebar-CrQDDdcz.js → sidebar-CA6_ek3f.js} +33 -24
  216. package/dist/sidebar-CLmIjgNd.cjs +1136 -0
  217. package/dist/{sidebar-BxGXsDAd.cjs → sidebar-CVUGHOS_.cjs} +8 -16
  218. package/dist/{sidebar-BViy8Eeu.js → sidebar-CmvwjnVb.js} +9 -17
  219. package/dist/{sidebar-B6SlKZYN.js → sidebar-CplprZpM.js} +49 -40
  220. package/dist/sidebar-Duermn32.js +1133 -0
  221. package/dist/{sidebar-BbVIQvlP.js → sidebar-Dz7bd3zP.js} +1 -1
  222. package/dist/{sidebar-0ocFLSks.js → sidebar-KIS0C2JH.js} +50 -127
  223. package/dist/sidebar-OTO_up7Z.js +801 -0
  224. package/dist/sidebar-zowjejT2.cjs +800 -0
  225. package/dist/{use-audio-player-nv8ZSGa1.js → use-audio-player-Bkh23vQ3.js} +3 -7
  226. package/dist/{use-audio-player-NKsWyjWu.cjs → use-audio-player-Dn1NR9xN.cjs} +3 -7
  227. package/dist/{xertica-assistant-dyP7KHM5.cjs → xertica-assistant-B1IaHXnB.cjs} +388 -529
  228. package/dist/{xertica-assistant-ciJaWqm1.js → xertica-assistant-BMqdyRVi.js} +10 -28
  229. package/dist/{xertica-assistant-V_IdW4WF.cjs → xertica-assistant-Bj3vBCq_.cjs} +9 -27
  230. package/dist/{xertica-assistant-yX1CFBBo.js → xertica-assistant-DPsESB6t.js} +390 -531
  231. package/dist/{CodeBlock-7TTgmdGG.cjs → xertica-assistant-Qp3ydksa.cjs} +51 -263
  232. package/dist/{CodeBlock-BeSt1h5P.js → xertica-assistant-gnCJdcZY.js} +7 -219
  233. package/dist/xertica-ui.css +2 -2
  234. package/docs/architecture-improvements.md +456 -456
  235. package/docs/architecture.md +312 -312
  236. package/docs/components/assistant.md +428 -428
  237. package/docs/components/branding.md +252 -252
  238. package/docs/components/card-patterns.md +447 -447
  239. package/docs/components/error-boundary.md +201 -201
  240. package/docs/components/hooks.md +432 -432
  241. package/docs/components/language-selector.md +176 -176
  242. package/docs/components/pages.md +323 -323
  243. package/docs/components/sidebar.md +331 -331
  244. package/docs/components/stats-card.md +138 -138
  245. package/docs/doc-audit.md +244 -244
  246. package/docs/getting-started.md +616 -616
  247. package/docs/guidelines.md +330 -330
  248. package/docs/i18n.md +480 -480
  249. package/docs/installation.md +268 -268
  250. package/docs/llms.md +295 -295
  251. package/docs/state-management.md +289 -289
  252. package/guidelines/Guidelines.md +409 -409
  253. package/llms-compact.txt +1 -1
  254. package/llms-full.txt +10688 -10688
  255. package/llms.txt +1 -1
  256. package/package.json +1 -1
  257. package/styles/xertica/base.css +90 -90
  258. package/styles/xertica/tokens.css +240 -240
  259. package/templates/.prettierignore +4 -4
  260. package/templates/.prettierrc +10 -10
  261. package/templates/CLAUDE.md +180 -180
  262. package/templates/package.json +2 -2
  263. package/templates/src/app/App.tsx +46 -46
  264. package/templates/src/app/components/AuthGuard.tsx +131 -131
  265. package/templates/src/features/assistant/data/mock.ts +75 -75
  266. package/templates/src/features/assistant/hooks/useAssistantConfig.ts +20 -20
  267. package/templates/src/features/assistant/index.ts +5 -5
  268. package/templates/src/features/auth/ui/ForgotPasswordContent.tsx +70 -70
  269. package/templates/src/features/auth/ui/LoginContent.tsx +92 -92
  270. package/templates/src/features/auth/ui/ResetPasswordContent.tsx +183 -183
  271. package/templates/src/features/auth/ui/SocialLoginButtons.tsx +78 -78
  272. package/templates/src/features/auth/ui/VerifyEmailContent.tsx +80 -80
  273. package/templates/src/features/home/data/mock.ts +41 -41
  274. package/templates/src/features/home/hooks/useFeatureCards.ts +20 -20
  275. package/templates/src/features/home/index.ts +11 -11
  276. package/templates/src/features/home/ui/HomeContent.tsx +117 -117
  277. package/templates/src/features/template/ui/CrudTemplate.tsx +112 -112
  278. package/templates/src/features/template/ui/DashboardTemplate.tsx +110 -110
  279. package/templates/src/features/template/ui/FormTemplate.tsx +117 -117
  280. package/templates/src/features/template/ui/LoginTemplate.tsx +59 -59
  281. package/templates/src/features/template/ui/TemplateContent.tsx +1322 -1322
  282. package/templates/src/i18n.ts +124 -124
  283. package/templates/src/locales/en/common.json +21 -21
  284. package/templates/src/locales/en/components/activityCard.json +10 -10
  285. package/templates/src/locales/en/components/assistant.json +119 -119
  286. package/templates/src/locales/en/components/media.json +29 -29
  287. package/templates/src/locales/en/components/notificationCard.json +5 -5
  288. package/templates/src/locales/en/components/profileCard.json +8 -8
  289. package/templates/src/locales/en/components/projectCard.json +10 -10
  290. package/templates/src/locales/en/components/sidebar.json +14 -14
  291. package/templates/src/locales/en/components/stats.json +8 -8
  292. package/templates/src/locales/en/components/team.json +14 -14
  293. package/templates/src/locales/en/errors.json +9 -9
  294. package/templates/src/locales/en/languageSelector.json +7 -7
  295. package/templates/src/locales/en/nav.json +6 -6
  296. package/templates/src/locales/en/pages/crudTemplate.json +25 -25
  297. package/templates/src/locales/en/pages/dashboardTemplate.json +20 -20
  298. package/templates/src/locales/en/pages/forgotPassword.json +10 -10
  299. package/templates/src/locales/en/pages/formTemplate.json +16 -16
  300. package/templates/src/locales/en/pages/home.json +7 -7
  301. package/templates/src/locales/en/pages/login.json +15 -15
  302. package/templates/src/locales/en/pages/loginTemplate.json +9 -9
  303. package/templates/src/locales/en/pages/resetPassword.json +18 -18
  304. package/templates/src/locales/en/pages/templates.json +317 -317
  305. package/templates/src/locales/en/pages/verifyEmail.json +12 -12
  306. package/templates/src/locales/en/themeToggle.json +6 -6
  307. package/templates/src/locales/es/common.json +21 -21
  308. package/templates/src/locales/es/components/activityCard.json +10 -10
  309. package/templates/src/locales/es/components/assistant.json +119 -119
  310. package/templates/src/locales/es/components/media.json +29 -29
  311. package/templates/src/locales/es/components/notificationCard.json +5 -5
  312. package/templates/src/locales/es/components/profileCard.json +8 -8
  313. package/templates/src/locales/es/components/projectCard.json +10 -10
  314. package/templates/src/locales/es/components/sidebar.json +14 -14
  315. package/templates/src/locales/es/components/stats.json +8 -8
  316. package/templates/src/locales/es/components/team.json +14 -14
  317. package/templates/src/locales/es/errors.json +9 -9
  318. package/templates/src/locales/es/languageSelector.json +7 -7
  319. package/templates/src/locales/es/nav.json +6 -6
  320. package/templates/src/locales/es/pages/crudTemplate.json +25 -25
  321. package/templates/src/locales/es/pages/dashboardTemplate.json +20 -20
  322. package/templates/src/locales/es/pages/forgotPassword.json +10 -10
  323. package/templates/src/locales/es/pages/formTemplate.json +16 -16
  324. package/templates/src/locales/es/pages/home.json +7 -7
  325. package/templates/src/locales/es/pages/login.json +15 -15
  326. package/templates/src/locales/es/pages/loginTemplate.json +9 -9
  327. package/templates/src/locales/es/pages/resetPassword.json +18 -18
  328. package/templates/src/locales/es/pages/templates.json +317 -317
  329. package/templates/src/locales/es/pages/verifyEmail.json +12 -12
  330. package/templates/src/locales/es/themeToggle.json +6 -6
  331. package/templates/src/locales/pt-BR/common.json +21 -21
  332. package/templates/src/locales/pt-BR/components/activityCard.json +10 -10
  333. package/templates/src/locales/pt-BR/components/assistant.json +119 -119
  334. package/templates/src/locales/pt-BR/components/media.json +29 -29
  335. package/templates/src/locales/pt-BR/components/notificationCard.json +5 -5
  336. package/templates/src/locales/pt-BR/components/profileCard.json +8 -8
  337. package/templates/src/locales/pt-BR/components/projectCard.json +10 -10
  338. package/templates/src/locales/pt-BR/components/sidebar.json +14 -14
  339. package/templates/src/locales/pt-BR/components/stats.json +8 -8
  340. package/templates/src/locales/pt-BR/components/team.json +14 -14
  341. package/templates/src/locales/pt-BR/errors.json +9 -9
  342. package/templates/src/locales/pt-BR/languageSelector.json +7 -7
  343. package/templates/src/locales/pt-BR/nav.json +6 -6
  344. package/templates/src/locales/pt-BR/pages/crudTemplate.json +25 -25
  345. package/templates/src/locales/pt-BR/pages/dashboardTemplate.json +20 -20
  346. package/templates/src/locales/pt-BR/pages/forgotPassword.json +10 -10
  347. package/templates/src/locales/pt-BR/pages/formTemplate.json +16 -16
  348. package/templates/src/locales/pt-BR/pages/home.json +7 -7
  349. package/templates/src/locales/pt-BR/pages/login.json +15 -15
  350. package/templates/src/locales/pt-BR/pages/loginTemplate.json +9 -9
  351. package/templates/src/locales/pt-BR/pages/resetPassword.json +18 -18
  352. package/templates/src/locales/pt-BR/pages/templates.json +317 -317
  353. package/templates/src/locales/pt-BR/pages/verifyEmail.json +12 -12
  354. package/templates/src/locales/pt-BR/themeToggle.json +6 -6
  355. package/templates/src/pages/AssistantPage.tsx +470 -470
  356. package/templates/src/pages/HomePage.tsx +53 -53
  357. package/templates/src/shared/error-boundary.tsx +150 -150
  358. package/templates/src/shared/error-fallbacks.tsx +222 -222
  359. package/templates/src/styles/xertica/tokens.css +240 -240
  360. package/templates/vite.config.js +20 -20
  361. package/templates/vite.config.ts +55 -55
  362. package/dist/AssistantChart-BKVtGUKF.js +0 -3383
  363. package/dist/AssistantChart-CxGjH7Qk.js +0 -3477
  364. package/dist/AssistantChart-DIpshm3i.js +0 -4784
  365. package/dist/AssistantChart-D_PTeu8P.cjs +0 -3503
  366. package/dist/AssistantChart-WeycT5Pd.cjs +0 -3551
  367. package/dist/AssistantChart-zjsy2GaZ.cjs +0 -4810
  368. package/dist/AudioPlayer-B1lt5cPl.cjs +0 -989
  369. package/dist/AudioPlayer-BZ7bibzU.cjs +0 -982
  370. package/dist/AudioPlayer-BpRPS4-1.cjs +0 -1277
  371. package/dist/AudioPlayer-C12BjQBV.cjs +0 -997
  372. package/dist/AudioPlayer-CFeV8t-5.cjs +0 -936
  373. package/dist/AudioPlayer-Coly3q5R.js +0 -1278
  374. package/dist/AudioPlayer-CySJIyvL.js +0 -937
  375. package/dist/AudioPlayer-DMcG_c7L.js +0 -990
  376. package/dist/AudioPlayer-DcFKRJE_.js +0 -998
  377. package/dist/AudioPlayer-e8LfNoqO.js +0 -983
  378. package/dist/BrandColorsContext-565dDHd5.js +0 -660
  379. package/dist/BrandColorsContext-BcJbtkqn.cjs +0 -659
  380. package/dist/CodeBlock-BgfYL_rD.cjs +0 -2094
  381. package/dist/CodeBlock-BlcqlA9M.cjs +0 -2094
  382. package/dist/CodeBlock-Bnmeu5ez.cjs +0 -2094
  383. package/dist/CodeBlock-BtfPlbAI.js +0 -2078
  384. package/dist/CodeBlock-CIySIuYr.js +0 -2078
  385. package/dist/CodeBlock-CuPtUM-7.cjs +0 -2094
  386. package/dist/CodeBlock-D6ffWXgc.js +0 -2078
  387. package/dist/CodeBlock-D8dcwbit.cjs +0 -2094
  388. package/dist/CodeBlock-DMZrFnlw.cjs +0 -2094
  389. package/dist/CodeBlock-DlBehYN8.js +0 -2078
  390. package/dist/CodeBlock-DnYNI8rQ.js +0 -2078
  391. package/dist/CodeBlock-DvKWbSnE.cjs +0 -2094
  392. package/dist/CodeBlock-DwMCfkFY.js +0 -2078
  393. package/dist/CodeBlock-Dy6CNYyj.js +0 -2078
  394. package/dist/CodeBlock-U1pPOQI7.cjs +0 -2094
  395. package/dist/CodeBlock-f_GpNhEB.js +0 -2078
  396. package/dist/CodeBlock-oB6u8nI1.js +0 -2078
  397. package/dist/CodeBlock-tZC31B73.cjs +0 -2094
  398. package/dist/FeatureCard-CxC-7C-C.cjs +0 -300
  399. package/dist/FeatureCard-DbHWCb4E.js +0 -301
  400. package/dist/ImageWithFallback-CGtidP6B.cjs +0 -4542
  401. package/dist/ImageWithFallback-lsg3pdFg.js +0 -4508
  402. package/dist/LanguageSelector-B5YfbHra.js +0 -231
  403. package/dist/LanguageSelector-D6uacAIM.cjs +0 -230
  404. package/dist/LayoutContext-B45-e9DI.cjs +0 -93
  405. package/dist/LayoutContext-BAql6ZRY.js +0 -97
  406. package/dist/LayoutContext-Bav3UMEA.js +0 -94
  407. package/dist/LayoutContext-BvK-ggDa.cjs +0 -96
  408. package/dist/ThemeContext-BoH4NLfN.js +0 -734
  409. package/dist/ThemeContext-r69W20Xg.cjs +0 -733
  410. package/dist/VerifyEmailPage-COiyNl1y.js +0 -2825
  411. package/dist/VerifyEmailPage-CqKsR2v8.js +0 -2827
  412. package/dist/VerifyEmailPage-DjQKRlUS.cjs +0 -2824
  413. package/dist/VerifyEmailPage-s-1X3LDJ.cjs +0 -2826
  414. package/dist/XerticaOrbe-KL1RBHzw.cjs +0 -1354
  415. package/dist/XerticaOrbe-zwS1p2a8.js +0 -1355
  416. package/dist/XerticaProvider-6btlAlzc.js +0 -17
  417. package/dist/XerticaProvider-BNoNOxQ5.cjs +0 -16
  418. package/dist/XerticaProvider-BlY2limY.cjs +0 -38
  419. package/dist/XerticaProvider-DDuiIcKo.js +0 -39
  420. package/dist/XerticaProvider-cI9hSs27.cjs +0 -38
  421. package/dist/XerticaProvider-hSwhNQex.js +0 -39
  422. package/dist/alert-dialog-BOje--vD.js +0 -847
  423. package/dist/alert-dialog-BtEuQqrg.cjs +0 -870
  424. package/dist/breadcrumb-CqJ7bHY5.js +0 -161
  425. package/dist/breadcrumb-m9Hb2_XN.cjs +0 -177
  426. package/dist/components/assistant/xertica-assistant/hooks/index.d.ts +0 -6
  427. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-conversations.d.ts +0 -21
  428. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-messages.d.ts +0 -49
  429. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-suggestions.d.ts +0 -16
  430. package/dist/components/blocks/audio-player/AudioPlayer.d.ts +0 -35
  431. package/dist/components/blocks/audio-player/index.d.ts +0 -1
  432. package/dist/components/blocks/document-editor/DocumentEditor.d.ts +0 -26
  433. package/dist/components/blocks/document-editor/index.d.ts +0 -1
  434. package/dist/components/blocks/podcast-player/PodcastPlayer.d.ts +0 -41
  435. package/dist/components/blocks/podcast-player/index.d.ts +0 -1
  436. package/dist/components/ui/chart/parts/chart-dashboard.d.ts +0 -113
  437. package/dist/components/ui/chart/parts/chart-metric.d.ts +0 -118
  438. package/dist/components/ui/chart/parts/chart-primitives.d.ts +0 -101
  439. package/dist/components/ui/chart/parts/chart-shared.d.ts +0 -20
  440. package/dist/components/ui/chart/parts/chart-utils.d.ts +0 -12
  441. package/dist/components/ui/chart/parts/index.d.ts +0 -5
  442. package/dist/dropdown-menu-BDB5CmQs.cjs +0 -247
  443. package/dist/dropdown-menu-DQidbKBD.js +0 -231
  444. package/dist/google-maps-loader-BFWp6VPd.js +0 -287
  445. package/dist/google-maps-loader-BKcdgFbu.cjs +0 -312
  446. package/dist/google-maps-loader-CumCNXeG.js +0 -312
  447. package/dist/google-maps-loader-eS3uQ5TA.cjs +0 -287
  448. package/dist/header-Cgy6vYPk.cjs +0 -731
  449. package/dist/header-DRlT4jgI.js +0 -715
  450. package/dist/header-Dux00SI4.cjs +0 -731
  451. package/dist/header-EkGKXPsD.js +0 -715
  452. package/dist/header-WfEywpyc.cjs +0 -731
  453. package/dist/header-tifNQn2U.js +0 -715
  454. package/dist/index-BhapVLVj.js +0 -8
  455. package/dist/index-D6fxYEY8.cjs +0 -7
  456. package/dist/index-DAIp0_HK.js +0 -8
  457. package/dist/index-DW5tYe26.js +0 -8
  458. package/dist/index-GA__GvnG.cjs +0 -7
  459. package/dist/input-2R4loU86.js +0 -127
  460. package/dist/input-DWANSKGb.cjs +0 -145
  461. package/dist/progress-DPtzoVV8.js +0 -175
  462. package/dist/progress-EeaoqqUs.cjs +0 -191
  463. package/dist/rich-text-editor-0mraWT5y.cjs +0 -2376
  464. package/dist/rich-text-editor-B-IkcPD0.js +0 -2874
  465. package/dist/rich-text-editor-B6jMRLzk.cjs +0 -1939
  466. package/dist/rich-text-editor-B8_oYcIR.js +0 -1730
  467. package/dist/rich-text-editor-B9UbSXNb.js +0 -1203
  468. package/dist/rich-text-editor-BYuRBNBU.js +0 -2373
  469. package/dist/rich-text-editor-Bb9pySTs.cjs +0 -2374
  470. package/dist/rich-text-editor-BcL6L3cm.cjs +0 -2374
  471. package/dist/rich-text-editor-BoVZYtTs.cjs +0 -2391
  472. package/dist/rich-text-editor-Bp3zQqMC.js +0 -2954
  473. package/dist/rich-text-editor-CMgSN_w2.js +0 -1189
  474. package/dist/rich-text-editor-CPV1lEPH.cjs +0 -1748
  475. package/dist/rich-text-editor-CeucBdIv.cjs +0 -2971
  476. package/dist/rich-text-editor-CoKqbCtu.cjs +0 -1799
  477. package/dist/rich-text-editor-Cw56T_mB.js +0 -2356
  478. package/dist/rich-text-editor-Cyt8qs2b.js +0 -1921
  479. package/dist/rich-text-editor-D6H84OcX.cjs +0 -1220
  480. package/dist/rich-text-editor-D76gD-QI.js +0 -2328
  481. package/dist/rich-text-editor-DKkokOnA.js +0 -1781
  482. package/dist/rich-text-editor-DNsdpN64.cjs +0 -2359
  483. package/dist/rich-text-editor-DfG8bCyY.js +0 -2358
  484. package/dist/rich-text-editor-Dxjw31Z4.js +0 -2341
  485. package/dist/rich-text-editor-DzP0Epmb.js +0 -2356
  486. package/dist/rich-text-editor-bRkNoeZY.cjs +0 -2891
  487. package/dist/rich-text-editor-lyYE2ZG5.cjs +0 -1207
  488. package/dist/rich-text-editor-skplNlBM.cjs +0 -2345
  489. package/dist/select-Bkbr0f-Z.cjs +0 -162
  490. package/dist/select-CvIVdX2n.js +0 -145
  491. package/dist/sidebar-CK_0ZQHj.cjs +0 -803
  492. package/dist/sidebar-CUuOvYhK.js +0 -787
  493. package/dist/sidebar-DQj1z3jG.cjs +0 -758
  494. package/dist/sidebar-Djn5syhi.cjs +0 -786
  495. package/dist/sidebar-LluMXfam.js +0 -759
  496. package/dist/sidebar-_rT7rBMk.js +0 -787
  497. package/dist/slider-Bc5Hd0y1.js +0 -56
  498. package/dist/slider-N7hFFj6X.cjs +0 -73
  499. package/dist/tooltip-Ded96neP.cjs +0 -137
  500. package/dist/tooltip-HDOoD2-0.js +0 -120
  501. package/dist/use-audio-player-B31J-aqh.cjs +0 -187
  502. package/dist/use-audio-player-BkmEmj8Q.js +0 -185
  503. package/dist/use-audio-player-CLFTWFW1.cjs +0 -184
  504. package/dist/use-audio-player-CLLn00I6.js +0 -188
  505. package/dist/use-file-upload-BcjEo2S5.js +0 -404
  506. package/dist/use-file-upload-CRJR68Tj.cjs +0 -403
  507. package/dist/use-mobile-B0hNy_Y6.cjs +0 -4303
  508. package/dist/use-mobile-BXuYROXM.js +0 -4202
  509. package/dist/use-mobile-Bbd51ASU.cjs +0 -4392
  510. package/dist/use-mobile-Bk6CX-TC.js +0 -4359
  511. package/dist/use-mobile-BvYdisLP.js +0 -4202
  512. package/dist/use-mobile-BzuxjzNX.cjs +0 -4392
  513. package/dist/use-mobile-CG2-SdXV.cjs +0 -4235
  514. package/dist/use-mobile-CKb5pqTs.js +0 -4269
  515. package/dist/use-mobile-CYuAuGDl.js +0 -4202
  516. package/dist/use-mobile-CaENcqm-.js +0 -4508
  517. package/dist/use-mobile-CbrYgJGJ.js +0 -4203
  518. package/dist/use-mobile-Cd4xPrKq.cjs +0 -46
  519. package/dist/use-mobile-DMOvImGQ.cjs +0 -4542
  520. package/dist/use-mobile-DRB3BQgD.cjs +0 -4235
  521. package/dist/use-mobile-DZvv7QMR.js +0 -4359
  522. package/dist/use-mobile-DdI_TXam.cjs +0 -4235
  523. package/dist/use-mobile-DlceKf8a.js +0 -4359
  524. package/dist/use-mobile-DsOnow1o.cjs +0 -4236
  525. package/dist/use-mobile-Kcj6jSnK.cjs +0 -4392
  526. package/dist/use-mobile-bnKcua_i.js +0 -4202
  527. package/dist/use-mobile-j4w2Jrf1.js +0 -30
  528. package/dist/use-mobile-ncXBeE2z.cjs +0 -4235
  529. package/dist/use-rich-text-editor-DjiddBGv.js +0 -282
  530. package/dist/use-rich-text-editor-lpeswbCs.cjs +0 -281
  531. package/dist/xertica-assistant-BdiZag0h.js +0 -2187
  532. package/dist/xertica-assistant-CrgTb6Hs.cjs +0 -2155
  533. package/dist/xertica-assistant-DCsnQyi5.js +0 -2156
  534. package/dist/xertica-assistant-DUBpmEgo.cjs +0 -2186
  535. package/dist/{rich-text-editor-DgF8s7xW.js → rich-text-editor-BmsjY03B.js} +26 -26
  536. package/dist/{rich-text-editor-mWoaSCE4.cjs → rich-text-editor-GS2kpTAK.cjs} +26 -26
package/components.json CHANGED
@@ -1,512 +1,512 @@
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
- },
8
- {
9
- "name": "alert-dialog",
10
- "docPath": "docs/components/alert-dialog.md",
11
- "sourcePath": "components/ui/alert-dialog/index.ts",
12
- "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."
13
- },
14
- {
15
- "name": "alert",
16
- "docPath": "docs/components/alert.md",
17
- "sourcePath": "components/ui/alert/index.ts",
18
- "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."
19
- },
20
- {
21
- "name": "aspect-ratio",
22
- "docPath": "docs/components/aspect-ratio.md",
23
- "sourcePath": "components/ui/aspect-ratio/index.ts",
24
- "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."
25
- },
26
- {
27
- "name": "assistant-chart",
28
- "docPath": "docs/components/assistant-chart.md",
29
- "sourcePath": "components/ui/assistant-chart/index.ts",
30
- "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."
31
- },
32
- {
33
- "name": "assistant",
34
- "docPath": "docs/components/assistant.md",
35
- "sourcePath": "components/ui/assistant.tsx",
36
- "description": "Full-featured AI chat assistant with support for:"
37
- },
38
- {
39
- "name": "audio-player",
40
- "docPath": "docs/components/audio-player.md",
41
- "sourcePath": "components/ui/audio-player.tsx",
42
- "description": "A unified, premium media player designed for both quick audio previews and long-form podcasts. It supports embedded (Card) and global (Bar) layouts, featuring fluid transitions and intelligent responsiveness."
43
- },
44
- {
45
- "name": "avatar",
46
- "docPath": "docs/components/avatar.md",
47
- "sourcePath": "components/ui/avatar/index.ts",
48
- "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."
49
- },
50
- {
51
- "name": "badge",
52
- "docPath": "docs/components/badge.md",
53
- "sourcePath": "components/ui/badge/index.ts",
54
- "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."
55
- },
56
- {
57
- "name": "branding",
58
- "docPath": "docs/components/branding.md",
59
- "sourcePath": "components/ui/branding.tsx",
60
- "description": "The branding system in Xertica UI provides tools for applying, customizing, and switching the visual identity of an application — including color themes, logos, language, and dark/light mode."
61
- },
62
- {
63
- "name": "breadcrumb",
64
- "docPath": "docs/components/breadcrumb.md",
65
- "sourcePath": "components/ui/breadcrumb/index.ts",
66
- "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."
67
- },
68
- {
69
- "name": "button",
70
- "docPath": "docs/components/button.md",
71
- "sourcePath": "components/ui/button/index.ts",
72
- "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."
73
- },
74
- {
75
- "name": "calendar",
76
- "docPath": "docs/components/calendar.md",
77
- "sourcePath": "components/ui/calendar/index.ts",
78
- "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 date input. Supports single date selection, multiple dates, and date ranges. When `captionLayout=\"dropdown\"` is used, the month/year header renders as interactive selectors with input-styled visuals."
79
- },
80
- {
81
- "name": "card-patterns",
82
- "docPath": "docs/components/card-patterns.md",
83
- "sourcePath": "components/blocks/card-patterns/index.ts",
84
- "description": "Pre-composed card blocks for dashboards, project management, and feature pages. Each component is built exclusively from `ui/` primitives — no external dependencies. They live in `components/blocks/card-patterns/` and are available from the root `xertica-ui` import."
85
- },
86
- {
87
- "name": "card",
88
- "docPath": "docs/components/card.md",
89
- "sourcePath": "components/ui/card/index.ts",
90
- "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."
91
- },
92
- {
93
- "name": "carousel",
94
- "docPath": "docs/components/carousel.md",
95
- "sourcePath": "components/ui/carousel/index.ts",
96
- "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."
97
- },
98
- {
99
- "name": "chart",
100
- "docPath": "docs/components/chart.md",
101
- "sourcePath": "components/ui/chart/index.ts",
102
- "description": "Xertica UI provides a `ChartContainer` wrapper and related components built on top of **Recharts** for theme-aware, token-driven chart 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."
103
- },
104
- {
105
- "name": "checkbox",
106
- "docPath": "docs/components/checkbox.md",
107
- "sourcePath": "components/ui/checkbox/index.ts",
108
- "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."
109
- },
110
- {
111
- "name": "code-block",
112
- "docPath": "docs/components/code-block.md",
113
- "sourcePath": "components/assistant/code-block/index.ts",
114
- "description": "A syntax-highlighted code display component with a one-click copy button. Designed for use inside AI chat messages and documentation panels."
115
- },
116
- {
117
- "name": "collapsible",
118
- "docPath": "docs/components/collapsible.md",
119
- "sourcePath": "components/ui/collapsible/index.ts",
120
- "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."
121
- },
122
- {
123
- "name": "command",
124
- "docPath": "docs/components/command.md",
125
- "sourcePath": "components/ui/command/index.ts",
126
- "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`."
127
- },
128
- {
129
- "name": "context-menu",
130
- "docPath": "docs/components/context-menu.md",
131
- "sourcePath": "components/ui/context-menu/index.ts",
132
- "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."
133
- },
134
- {
135
- "name": "dialog",
136
- "docPath": "docs/components/dialog.md",
137
- "sourcePath": "components/ui/dialog/index.ts",
138
- "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."
139
- },
140
- {
141
- "name": "drawer",
142
- "docPath": "docs/components/drawer.md",
143
- "sourcePath": "components/ui/drawer/index.ts",
144
- "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."
145
- },
146
- {
147
- "name": "dropdown-menu",
148
- "docPath": "docs/components/dropdown-menu.md",
149
- "sourcePath": "components/ui/dropdown-menu/index.ts",
150
- "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."
151
- },
152
- {
153
- "name": "empty",
154
- "docPath": "docs/components/empty.md",
155
- "sourcePath": "components/ui/empty/index.ts",
156
- "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."
157
- },
158
- {
159
- "name": "error-boundary",
160
- "docPath": "docs/components/error-boundary.md",
161
- "sourcePath": "components/ui/error-boundary.tsx",
162
- "description": "React Error Boundaries catch JavaScript errors in the component tree, log them, and render a fallback UI instead of crashing the application. Xertica UI ships a single reusable `ErrorBoundary` class with **three pre-configured wrapper variants** covering every granularity of protection."
163
- },
164
- {
165
- "name": "file-upload",
166
- "docPath": "docs/components/file-upload.md",
167
- "sourcePath": "components/ui/file-upload/index.ts",
168
- "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."
169
- },
170
- {
171
- "name": "floating-media-wrapper",
172
- "docPath": "docs/components/floating-media-wrapper.md",
173
- "sourcePath": "components/ui/floating-media-wrapper.tsx",
174
- "description": "A higher-level wrapper for media players (audio/video) that manages floating state, positioning, and transitions."
175
- },
176
- {
177
- "name": "form",
178
- "docPath": "docs/components/form.md",
179
- "sourcePath": "components/ui/form/index.ts",
180
- "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."
181
- },
182
- {
183
- "name": "formatted-document",
184
- "docPath": "docs/components/formatted-document.md",
185
- "sourcePath": "components/assistant/formatted-document/index.ts",
186
- "description": "A lightweight Markdown-to-HTML renderer with a collapsible preview. Designed for displaying AI-generated documents, reports, and structured text inside the assistant panel."
187
- },
188
- {
189
- "name": "google-maps-loader",
190
- "docPath": "docs/components/google-maps-loader.md",
191
- "sourcePath": "components/ui/google-maps-loader/index.ts",
192
- "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`."
193
- },
194
- {
195
- "name": "header",
196
- "docPath": "docs/components/header.md",
197
- "sourcePath": "components/layout/header/index.ts",
198
- "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."
199
- },
200
- {
201
- "name": "hooks",
202
- "docPath": "docs/components/hooks.md",
203
- "sourcePath": "components/ui/hooks.tsx",
204
- "description": "Xertica UI exposes a set of React hooks via the `xertica-ui/hooks` subpath. These hooks provide access to global contexts (theme, language, layout, assistant, API keys, brand colors) and utility behaviors (audio player, keyboard shortcuts, mobile detection)."
205
- },
206
- {
207
- "name": "hover-card",
208
- "docPath": "docs/components/hover-card.md",
209
- "sourcePath": "components/ui/hover-card/index.ts",
210
- "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."
211
- },
212
- {
213
- "name": "image-with-fallback",
214
- "docPath": "docs/components/image-with-fallback.md",
215
- "sourcePath": "components/ui/image-with-fallback.tsx",
216
- "description": "A drop-in replacement for the native `<img>` element that gracefully handles broken or missing image URLs by displaying a placeholder SVG instead of a broken image icon."
217
- },
218
- {
219
- "name": "input-otp",
220
- "docPath": "docs/components/input-otp.md",
221
- "sourcePath": "components/ui/input-otp/index.ts",
222
- "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."
223
- },
224
- {
225
- "name": "input",
226
- "docPath": "docs/components/input.md",
227
- "sourcePath": "components/ui/input/index.ts",
228
- "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."
229
- },
230
- {
231
- "name": "label",
232
- "docPath": "docs/components/label.md",
233
- "sourcePath": "components/ui/label/index.ts",
234
- "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."
235
- },
236
- {
237
- "name": "language-selector",
238
- "docPath": "docs/components/language-selector.md",
239
- "sourcePath": "components/brand/language-selector/index.ts",
240
- "description": "A dropdown component for switching the interface language. It reads the current language from `LanguageContext` and calls `i18n.changeLanguage()` when the user selects a new option — all `useTranslation()` consumers in the app re-render immediately, and the React Query cache is invalidated so data-layer strings refresh too."
241
- },
242
- {
243
- "name": "map-layers",
244
- "docPath": "docs/components/map-layers.md",
245
- "sourcePath": "components/ui/map-layers/index.ts",
246
- "description": "A hook for managing Google Maps native overlay layers (traffic, transit, bicycling) on a map instance. Used internally by the `Map` component via its `layers` prop."
247
- },
248
- {
249
- "name": "map",
250
- "docPath": "docs/components/map.md",
251
- "sourcePath": "components/ui/map/index.ts",
252
- "description": "`Map` renders an interactive Google Map with advanced markers, optional rich info windows, circles, polygons, and native overlay layers. It uses the built-in Xertica Google Maps loader and renders a safe configuration state when no API key is available."
253
- },
254
- {
255
- "name": "markdown-message",
256
- "docPath": "docs/components/markdown-message.md",
257
- "sourcePath": "components/assistant/markdown-message/index.ts",
258
- "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."
259
- },
260
- {
261
- "name": "menubar",
262
- "docPath": "docs/components/menubar.md",
263
- "sourcePath": "components/ui/menubar/index.ts",
264
- "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."
265
- },
266
- {
267
- "name": "modern-chat-input",
268
- "docPath": "docs/components/modern-chat-input.md",
269
- "sourcePath": "components/assistant/modern-chat-input/index.ts",
270
- "description": "An advanced floating chat input with rich action chips, voice recording simulation, and file attachment support. Used as the primary input interface inside `XerticaAssistant`."
271
- },
272
- {
273
- "name": "navigation-menu",
274
- "docPath": "docs/components/navigation-menu.md",
275
- "sourcePath": "components/ui/navigation-menu/index.ts",
276
- "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."
277
- },
278
- {
279
- "name": "notification-badge",
280
- "docPath": "docs/components/notification-badge.md",
281
- "sourcePath": "components/ui/notification-badge/index.ts",
282
- "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)."
283
- },
284
- {
285
- "name": "page-header",
286
- "docPath": "docs/components/page-header.md",
287
- "sourcePath": "components/ui/page-header/index.ts",
288
- "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\")."
289
- },
290
- {
291
- "name": "pages",
292
- "docPath": "docs/components/pages.md",
293
- "sourcePath": "components/ui/pages.tsx",
294
- "description": "Xertica UI ships 8 ready-to-use page templates covering authentication flows, the main dashboard shell, and a fully-featured component showcase. All templates are exported from `xertica-ui/pages`."
295
- },
296
- {
297
- "name": "pagination",
298
- "docPath": "docs/components/pagination.md",
299
- "sourcePath": "components/ui/pagination/index.ts",
300
- "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."
301
- },
302
- {
303
- "name": "popover",
304
- "docPath": "docs/components/popover.md",
305
- "sourcePath": "components/ui/popover/index.ts",
306
- "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."
307
- },
308
- {
309
- "name": "progress",
310
- "docPath": "docs/components/progress.md",
311
- "sourcePath": "components/ui/progress/index.ts",
312
- "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>`."
313
- },
314
- {
315
- "name": "radio-group",
316
- "docPath": "docs/components/radio-group.md",
317
- "sourcePath": "components/ui/radio-group/index.ts",
318
- "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."
319
- },
320
- {
321
- "name": "rating",
322
- "docPath": "docs/components/rating.md",
323
- "sourcePath": "components/ui/rating/index.ts",
324
- "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."
325
- },
326
- {
327
- "name": "resizable",
328
- "docPath": "docs/components/resizable.md",
329
- "sourcePath": "components/ui/resizable/index.ts",
330
- "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."
331
- },
332
- {
333
- "name": "rich-text-editor",
334
- "docPath": "docs/components/rich-text-editor.md",
335
- "sourcePath": "components/ui/rich-text-editor/index.ts",
336
- "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."
337
- },
338
- {
339
- "name": "route-map",
340
- "docPath": "docs/components/route-map.md",
341
- "sourcePath": "components/ui/route-map/index.ts",
342
- "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."
343
- },
344
- {
345
- "name": "scroll-area",
346
- "docPath": "docs/components/scroll-area.md",
347
- "sourcePath": "components/ui/scroll-area/index.ts",
348
- "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)."
349
- },
350
- {
351
- "name": "search",
352
- "docPath": "docs/components/search.md",
353
- "sourcePath": "components/ui/search/index.ts",
354
- "description": "A pre-built search input with a built-in search icon and clear button. A convenience component built on top of `<Input>` that handles the common search field pattern with a consistent size scale."
355
- },
356
- {
357
- "name": "select",
358
- "docPath": "docs/components/select.md",
359
- "sourcePath": "components/ui/select/index.ts",
360
- "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>`."
361
- },
362
- {
363
- "name": "separator",
364
- "docPath": "docs/components/separator.md",
365
- "sourcePath": "components/ui/separator/index.ts",
366
- "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."
367
- },
368
- {
369
- "name": "sheet",
370
- "docPath": "docs/components/sheet.md",
371
- "sourcePath": "components/ui/sheet/index.ts",
372
- "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."
373
- },
374
- {
375
- "name": "sidebar",
376
- "docPath": "docs/components/sidebar.md",
377
- "sourcePath": "components/layout/sidebar/index.ts",
378
- "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."
379
- },
380
- {
381
- "name": "simple-map",
382
- "docPath": "docs/components/simple-map.md",
383
- "sourcePath": "components/ui/simple-map/index.ts",
384
- "description": "A simplified wrapper for common map use cases where you only need a single marker and basic configuration."
385
- },
386
- {
387
- "name": "skeleton",
388
- "docPath": "docs/components/skeleton.md",
389
- "sourcePath": "components/ui/skeleton/index.ts",
390
- "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."
391
- },
392
- {
393
- "name": "slider",
394
- "docPath": "docs/components/slider.md",
395
- "sourcePath": "components/ui/slider/index.ts",
396
- "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."
397
- },
398
- {
399
- "name": "sonner",
400
- "docPath": "docs/components/sonner.md",
401
- "sourcePath": "components/ui/sonner/index.ts",
402
- "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."
403
- },
404
- {
405
- "name": "stats-card",
406
- "docPath": "docs/components/stats-card.md",
407
- "sourcePath": "components/ui/stats-card/index.ts",
408
- "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."
409
- },
410
- {
411
- "name": "stepper",
412
- "docPath": "docs/components/stepper.md",
413
- "sourcePath": "components/ui/stepper/index.ts",
414
- "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."
415
- },
416
- {
417
- "name": "switch",
418
- "docPath": "docs/components/switch.md",
419
- "sourcePath": "components/ui/switch/index.ts",
420
- "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."
421
- },
422
- {
423
- "name": "table",
424
- "docPath": "docs/components/table.md",
425
- "sourcePath": "components/ui/table/index.ts",
426
- "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."
427
- },
428
- {
429
- "name": "tabs",
430
- "docPath": "docs/components/tabs.md",
431
- "sourcePath": "components/ui/tabs/index.ts",
432
- "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."
433
- },
434
- {
435
- "name": "textarea",
436
- "docPath": "docs/components/textarea.md",
437
- "sourcePath": "components/ui/textarea/index.ts",
438
- "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."
439
- },
440
- {
441
- "name": "theme-toggle",
442
- "docPath": "docs/components/theme-toggle.md",
443
- "sourcePath": "components/brand/theme-toggle/index.ts",
444
- "description": "A self-contained light/dark mode toggle button that operates directly on the `document.documentElement` class list."
445
- },
446
- {
447
- "name": "timeline",
448
- "docPath": "docs/components/timeline.md",
449
- "sourcePath": "components/ui/timeline/index.ts",
450
- "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."
451
- },
452
- {
453
- "name": "toggle-group",
454
- "docPath": "docs/components/toggle-group.md",
455
- "sourcePath": "components/ui/toggle-group/index.ts",
456
- "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."
457
- },
458
- {
459
- "name": "toggle",
460
- "docPath": "docs/components/toggle.md",
461
- "sourcePath": "components/ui/toggle/index.ts",
462
- "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."
463
- },
464
- {
465
- "name": "tooltip",
466
- "docPath": "docs/components/tooltip.md",
467
- "sourcePath": "components/ui/tooltip/index.ts",
468
- "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."
469
- },
470
- {
471
- "name": "tree-view",
472
- "docPath": "docs/components/tree-view.md",
473
- "sourcePath": "components/ui/tree-view/index.ts",
474
- "description": "An interactive hierarchical tree component for displaying and navigating nested data structures — file systems, organizational charts, category trees, and recursive navigation menus. Supports keyboard navigation (Arrow keys, Home, End, Space), expand/collapse, and single-node selection."
475
- },
476
- {
477
- "name": "use-mobile",
478
- "docPath": "docs/components/use-mobile.md",
479
- "sourcePath": "components/ui/use-mobile.tsx",
480
- "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."
481
- },
482
- {
483
- "name": "video-player",
484
- "docPath": "docs/components/video-player.md",
485
- "sourcePath": "components/ui/video-player.tsx",
486
- "description": "A feature-rich video player component with floating mode support, custom controls, and automatic state management."
487
- },
488
- {
489
- "name": "xertica-logo",
490
- "docPath": "docs/components/xertica-logo.md",
491
- "sourcePath": "components/brand/xertica-logo/index.ts",
492
- "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."
493
- },
494
- {
495
- "name": "xertica-orbe",
496
- "docPath": "docs/components/xertica-orbe.md",
497
- "sourcePath": "components/brand/xertica-orbe/index.ts",
498
- "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."
499
- },
500
- {
501
- "name": "xertica-provider",
502
- "docPath": "docs/components/xertica-provider.md",
503
- "sourcePath": "components/brand/xertica-provider/index.ts",
504
- "description": "The recommended root wrapper for Xertica UI applications. Most components can render independently with local fallbacks, but the provider centralizes app-wide state, theming, maps, tooltips, assistant state, API keys, and notifications."
505
- },
506
- {
507
- "name": "xertica-xlogo",
508
- "docPath": "docs/components/xertica-xlogo.md",
509
- "sourcePath": "components/brand/xertica-xlogo/index.ts",
510
- "description": "A compact, square variant of the Xertica logo featuring the stylized \"X\" mark. Ideal for favicons, collapsed sidebars, and small profile badges."
511
- }
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
+ },
8
+ {
9
+ "name": "alert-dialog",
10
+ "docPath": "docs/components/alert-dialog.md",
11
+ "sourcePath": "components/ui/alert-dialog/index.ts",
12
+ "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."
13
+ },
14
+ {
15
+ "name": "alert",
16
+ "docPath": "docs/components/alert.md",
17
+ "sourcePath": "components/ui/alert/index.ts",
18
+ "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."
19
+ },
20
+ {
21
+ "name": "aspect-ratio",
22
+ "docPath": "docs/components/aspect-ratio.md",
23
+ "sourcePath": "components/ui/aspect-ratio/index.ts",
24
+ "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."
25
+ },
26
+ {
27
+ "name": "assistant-chart",
28
+ "docPath": "docs/components/assistant-chart.md",
29
+ "sourcePath": "components/ui/assistant-chart/index.ts",
30
+ "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."
31
+ },
32
+ {
33
+ "name": "assistant",
34
+ "docPath": "docs/components/assistant.md",
35
+ "sourcePath": "components/ui/assistant.tsx",
36
+ "description": "Full-featured AI chat assistant with support for:"
37
+ },
38
+ {
39
+ "name": "audio-player",
40
+ "docPath": "docs/components/audio-player.md",
41
+ "sourcePath": "components/ui/audio-player.tsx",
42
+ "description": "A unified, premium media player designed for both quick audio previews and long-form podcasts. It supports embedded (Card) and global (Bar) layouts, featuring fluid transitions and intelligent responsiveness."
43
+ },
44
+ {
45
+ "name": "avatar",
46
+ "docPath": "docs/components/avatar.md",
47
+ "sourcePath": "components/ui/avatar/index.ts",
48
+ "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."
49
+ },
50
+ {
51
+ "name": "badge",
52
+ "docPath": "docs/components/badge.md",
53
+ "sourcePath": "components/ui/badge/index.ts",
54
+ "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."
55
+ },
56
+ {
57
+ "name": "branding",
58
+ "docPath": "docs/components/branding.md",
59
+ "sourcePath": "components/ui/branding.tsx",
60
+ "description": "The branding system in Xertica UI provides tools for applying, customizing, and switching the visual identity of an application — including color themes, logos, language, and dark/light mode."
61
+ },
62
+ {
63
+ "name": "breadcrumb",
64
+ "docPath": "docs/components/breadcrumb.md",
65
+ "sourcePath": "components/ui/breadcrumb/index.ts",
66
+ "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."
67
+ },
68
+ {
69
+ "name": "button",
70
+ "docPath": "docs/components/button.md",
71
+ "sourcePath": "components/ui/button/index.ts",
72
+ "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."
73
+ },
74
+ {
75
+ "name": "calendar",
76
+ "docPath": "docs/components/calendar.md",
77
+ "sourcePath": "components/ui/calendar/index.ts",
78
+ "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 date input. Supports single date selection, multiple dates, and date ranges. When `captionLayout=\"dropdown\"` is used, the month/year header renders as interactive selectors with input-styled visuals."
79
+ },
80
+ {
81
+ "name": "card-patterns",
82
+ "docPath": "docs/components/card-patterns.md",
83
+ "sourcePath": "components/blocks/card-patterns/index.ts",
84
+ "description": "Pre-composed card blocks for dashboards, project management, and feature pages. Each component is built exclusively from `ui/` primitives — no external dependencies. They live in `components/blocks/card-patterns/` and are available from the root `xertica-ui` import."
85
+ },
86
+ {
87
+ "name": "card",
88
+ "docPath": "docs/components/card.md",
89
+ "sourcePath": "components/ui/card/index.ts",
90
+ "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."
91
+ },
92
+ {
93
+ "name": "carousel",
94
+ "docPath": "docs/components/carousel.md",
95
+ "sourcePath": "components/ui/carousel/index.ts",
96
+ "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."
97
+ },
98
+ {
99
+ "name": "chart",
100
+ "docPath": "docs/components/chart.md",
101
+ "sourcePath": "components/ui/chart/index.ts",
102
+ "description": "Xertica UI provides a `ChartContainer` wrapper and related components built on top of **Recharts** for theme-aware, token-driven chart 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."
103
+ },
104
+ {
105
+ "name": "checkbox",
106
+ "docPath": "docs/components/checkbox.md",
107
+ "sourcePath": "components/ui/checkbox/index.ts",
108
+ "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."
109
+ },
110
+ {
111
+ "name": "code-block",
112
+ "docPath": "docs/components/code-block.md",
113
+ "sourcePath": "components/assistant/code-block/index.ts",
114
+ "description": "A syntax-highlighted code display component with a one-click copy button. Designed for use inside AI chat messages and documentation panels."
115
+ },
116
+ {
117
+ "name": "collapsible",
118
+ "docPath": "docs/components/collapsible.md",
119
+ "sourcePath": "components/ui/collapsible/index.ts",
120
+ "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."
121
+ },
122
+ {
123
+ "name": "command",
124
+ "docPath": "docs/components/command.md",
125
+ "sourcePath": "components/ui/command/index.ts",
126
+ "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`."
127
+ },
128
+ {
129
+ "name": "context-menu",
130
+ "docPath": "docs/components/context-menu.md",
131
+ "sourcePath": "components/ui/context-menu/index.ts",
132
+ "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."
133
+ },
134
+ {
135
+ "name": "dialog",
136
+ "docPath": "docs/components/dialog.md",
137
+ "sourcePath": "components/ui/dialog/index.ts",
138
+ "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."
139
+ },
140
+ {
141
+ "name": "drawer",
142
+ "docPath": "docs/components/drawer.md",
143
+ "sourcePath": "components/ui/drawer/index.ts",
144
+ "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."
145
+ },
146
+ {
147
+ "name": "dropdown-menu",
148
+ "docPath": "docs/components/dropdown-menu.md",
149
+ "sourcePath": "components/ui/dropdown-menu/index.ts",
150
+ "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."
151
+ },
152
+ {
153
+ "name": "empty",
154
+ "docPath": "docs/components/empty.md",
155
+ "sourcePath": "components/ui/empty/index.ts",
156
+ "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."
157
+ },
158
+ {
159
+ "name": "error-boundary",
160
+ "docPath": "docs/components/error-boundary.md",
161
+ "sourcePath": "components/ui/error-boundary.tsx",
162
+ "description": "React Error Boundaries catch JavaScript errors in the component tree, log them, and render a fallback UI instead of crashing the application. Xertica UI ships a single reusable `ErrorBoundary` class with **three pre-configured wrapper variants** covering every granularity of protection."
163
+ },
164
+ {
165
+ "name": "file-upload",
166
+ "docPath": "docs/components/file-upload.md",
167
+ "sourcePath": "components/ui/file-upload/index.ts",
168
+ "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."
169
+ },
170
+ {
171
+ "name": "floating-media-wrapper",
172
+ "docPath": "docs/components/floating-media-wrapper.md",
173
+ "sourcePath": "components/ui/floating-media-wrapper.tsx",
174
+ "description": "A higher-level wrapper for media players (audio/video) that manages floating state, positioning, and transitions."
175
+ },
176
+ {
177
+ "name": "form",
178
+ "docPath": "docs/components/form.md",
179
+ "sourcePath": "components/ui/form/index.ts",
180
+ "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."
181
+ },
182
+ {
183
+ "name": "formatted-document",
184
+ "docPath": "docs/components/formatted-document.md",
185
+ "sourcePath": "components/assistant/formatted-document/index.ts",
186
+ "description": "A lightweight Markdown-to-HTML renderer with a collapsible preview. Designed for displaying AI-generated documents, reports, and structured text inside the assistant panel."
187
+ },
188
+ {
189
+ "name": "google-maps-loader",
190
+ "docPath": "docs/components/google-maps-loader.md",
191
+ "sourcePath": "components/ui/google-maps-loader/index.ts",
192
+ "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`."
193
+ },
194
+ {
195
+ "name": "header",
196
+ "docPath": "docs/components/header.md",
197
+ "sourcePath": "components/layout/header/index.ts",
198
+ "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."
199
+ },
200
+ {
201
+ "name": "hooks",
202
+ "docPath": "docs/components/hooks.md",
203
+ "sourcePath": "components/ui/hooks.tsx",
204
+ "description": "Xertica UI exposes a set of React hooks via the `xertica-ui/hooks` subpath. These hooks provide access to global contexts (theme, language, layout, assistant, API keys, brand colors) and utility behaviors (audio player, keyboard shortcuts, mobile detection)."
205
+ },
206
+ {
207
+ "name": "hover-card",
208
+ "docPath": "docs/components/hover-card.md",
209
+ "sourcePath": "components/ui/hover-card/index.ts",
210
+ "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."
211
+ },
212
+ {
213
+ "name": "image-with-fallback",
214
+ "docPath": "docs/components/image-with-fallback.md",
215
+ "sourcePath": "components/ui/image-with-fallback.tsx",
216
+ "description": "A drop-in replacement for the native `<img>` element that gracefully handles broken or missing image URLs by displaying a placeholder SVG instead of a broken image icon."
217
+ },
218
+ {
219
+ "name": "input-otp",
220
+ "docPath": "docs/components/input-otp.md",
221
+ "sourcePath": "components/ui/input-otp/index.ts",
222
+ "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."
223
+ },
224
+ {
225
+ "name": "input",
226
+ "docPath": "docs/components/input.md",
227
+ "sourcePath": "components/ui/input/index.ts",
228
+ "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."
229
+ },
230
+ {
231
+ "name": "label",
232
+ "docPath": "docs/components/label.md",
233
+ "sourcePath": "components/ui/label/index.ts",
234
+ "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."
235
+ },
236
+ {
237
+ "name": "language-selector",
238
+ "docPath": "docs/components/language-selector.md",
239
+ "sourcePath": "components/brand/language-selector/index.ts",
240
+ "description": "A dropdown component for switching the interface language. It reads the current language from `LanguageContext` and calls `i18n.changeLanguage()` when the user selects a new option — all `useTranslation()` consumers in the app re-render immediately, and the React Query cache is invalidated so data-layer strings refresh too."
241
+ },
242
+ {
243
+ "name": "map-layers",
244
+ "docPath": "docs/components/map-layers.md",
245
+ "sourcePath": "components/ui/map-layers/index.ts",
246
+ "description": "A hook for managing Google Maps native overlay layers (traffic, transit, bicycling) on a map instance. Used internally by the `Map` component via its `layers` prop."
247
+ },
248
+ {
249
+ "name": "map",
250
+ "docPath": "docs/components/map.md",
251
+ "sourcePath": "components/ui/map/index.ts",
252
+ "description": "`Map` renders an interactive Google Map with advanced markers, optional rich info windows, circles, polygons, and native overlay layers. It uses the built-in Xertica Google Maps loader and renders a safe configuration state when no API key is available."
253
+ },
254
+ {
255
+ "name": "markdown-message",
256
+ "docPath": "docs/components/markdown-message.md",
257
+ "sourcePath": "components/assistant/markdown-message/index.ts",
258
+ "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."
259
+ },
260
+ {
261
+ "name": "menubar",
262
+ "docPath": "docs/components/menubar.md",
263
+ "sourcePath": "components/ui/menubar/index.ts",
264
+ "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."
265
+ },
266
+ {
267
+ "name": "modern-chat-input",
268
+ "docPath": "docs/components/modern-chat-input.md",
269
+ "sourcePath": "components/assistant/modern-chat-input/index.ts",
270
+ "description": "An advanced floating chat input with rich action chips, voice recording simulation, and file attachment support. Used as the primary input interface inside `XerticaAssistant`."
271
+ },
272
+ {
273
+ "name": "navigation-menu",
274
+ "docPath": "docs/components/navigation-menu.md",
275
+ "sourcePath": "components/ui/navigation-menu/index.ts",
276
+ "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."
277
+ },
278
+ {
279
+ "name": "notification-badge",
280
+ "docPath": "docs/components/notification-badge.md",
281
+ "sourcePath": "components/ui/notification-badge/index.ts",
282
+ "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)."
283
+ },
284
+ {
285
+ "name": "page-header",
286
+ "docPath": "docs/components/page-header.md",
287
+ "sourcePath": "components/ui/page-header/index.ts",
288
+ "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\")."
289
+ },
290
+ {
291
+ "name": "pages",
292
+ "docPath": "docs/components/pages.md",
293
+ "sourcePath": "components/ui/pages.tsx",
294
+ "description": "Xertica UI ships 8 ready-to-use page templates covering authentication flows, the main dashboard shell, and a fully-featured component showcase. All templates are exported from `xertica-ui/pages`."
295
+ },
296
+ {
297
+ "name": "pagination",
298
+ "docPath": "docs/components/pagination.md",
299
+ "sourcePath": "components/ui/pagination/index.ts",
300
+ "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."
301
+ },
302
+ {
303
+ "name": "popover",
304
+ "docPath": "docs/components/popover.md",
305
+ "sourcePath": "components/ui/popover/index.ts",
306
+ "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."
307
+ },
308
+ {
309
+ "name": "progress",
310
+ "docPath": "docs/components/progress.md",
311
+ "sourcePath": "components/ui/progress/index.ts",
312
+ "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>`."
313
+ },
314
+ {
315
+ "name": "radio-group",
316
+ "docPath": "docs/components/radio-group.md",
317
+ "sourcePath": "components/ui/radio-group/index.ts",
318
+ "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."
319
+ },
320
+ {
321
+ "name": "rating",
322
+ "docPath": "docs/components/rating.md",
323
+ "sourcePath": "components/ui/rating/index.ts",
324
+ "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."
325
+ },
326
+ {
327
+ "name": "resizable",
328
+ "docPath": "docs/components/resizable.md",
329
+ "sourcePath": "components/ui/resizable/index.ts",
330
+ "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."
331
+ },
332
+ {
333
+ "name": "rich-text-editor",
334
+ "docPath": "docs/components/rich-text-editor.md",
335
+ "sourcePath": "components/ui/rich-text-editor/index.ts",
336
+ "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."
337
+ },
338
+ {
339
+ "name": "route-map",
340
+ "docPath": "docs/components/route-map.md",
341
+ "sourcePath": "components/ui/route-map/index.ts",
342
+ "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."
343
+ },
344
+ {
345
+ "name": "scroll-area",
346
+ "docPath": "docs/components/scroll-area.md",
347
+ "sourcePath": "components/ui/scroll-area/index.ts",
348
+ "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)."
349
+ },
350
+ {
351
+ "name": "search",
352
+ "docPath": "docs/components/search.md",
353
+ "sourcePath": "components/ui/search/index.ts",
354
+ "description": "A pre-built search input with a built-in search icon and clear button. A convenience component built on top of `<Input>` that handles the common search field pattern with a consistent size scale."
355
+ },
356
+ {
357
+ "name": "select",
358
+ "docPath": "docs/components/select.md",
359
+ "sourcePath": "components/ui/select/index.ts",
360
+ "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>`."
361
+ },
362
+ {
363
+ "name": "separator",
364
+ "docPath": "docs/components/separator.md",
365
+ "sourcePath": "components/ui/separator/index.ts",
366
+ "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."
367
+ },
368
+ {
369
+ "name": "sheet",
370
+ "docPath": "docs/components/sheet.md",
371
+ "sourcePath": "components/ui/sheet/index.ts",
372
+ "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."
373
+ },
374
+ {
375
+ "name": "sidebar",
376
+ "docPath": "docs/components/sidebar.md",
377
+ "sourcePath": "components/layout/sidebar/index.ts",
378
+ "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."
379
+ },
380
+ {
381
+ "name": "simple-map",
382
+ "docPath": "docs/components/simple-map.md",
383
+ "sourcePath": "components/ui/simple-map/index.ts",
384
+ "description": "A simplified wrapper for common map use cases where you only need a single marker and basic configuration."
385
+ },
386
+ {
387
+ "name": "skeleton",
388
+ "docPath": "docs/components/skeleton.md",
389
+ "sourcePath": "components/ui/skeleton/index.ts",
390
+ "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."
391
+ },
392
+ {
393
+ "name": "slider",
394
+ "docPath": "docs/components/slider.md",
395
+ "sourcePath": "components/ui/slider/index.ts",
396
+ "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."
397
+ },
398
+ {
399
+ "name": "sonner",
400
+ "docPath": "docs/components/sonner.md",
401
+ "sourcePath": "components/ui/sonner/index.ts",
402
+ "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."
403
+ },
404
+ {
405
+ "name": "stats-card",
406
+ "docPath": "docs/components/stats-card.md",
407
+ "sourcePath": "components/ui/stats-card/index.ts",
408
+ "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."
409
+ },
410
+ {
411
+ "name": "stepper",
412
+ "docPath": "docs/components/stepper.md",
413
+ "sourcePath": "components/ui/stepper/index.ts",
414
+ "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."
415
+ },
416
+ {
417
+ "name": "switch",
418
+ "docPath": "docs/components/switch.md",
419
+ "sourcePath": "components/ui/switch/index.ts",
420
+ "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."
421
+ },
422
+ {
423
+ "name": "table",
424
+ "docPath": "docs/components/table.md",
425
+ "sourcePath": "components/ui/table/index.ts",
426
+ "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."
427
+ },
428
+ {
429
+ "name": "tabs",
430
+ "docPath": "docs/components/tabs.md",
431
+ "sourcePath": "components/ui/tabs/index.ts",
432
+ "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."
433
+ },
434
+ {
435
+ "name": "textarea",
436
+ "docPath": "docs/components/textarea.md",
437
+ "sourcePath": "components/ui/textarea/index.ts",
438
+ "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."
439
+ },
440
+ {
441
+ "name": "theme-toggle",
442
+ "docPath": "docs/components/theme-toggle.md",
443
+ "sourcePath": "components/brand/theme-toggle/index.ts",
444
+ "description": "A self-contained light/dark mode toggle button that operates directly on the `document.documentElement` class list."
445
+ },
446
+ {
447
+ "name": "timeline",
448
+ "docPath": "docs/components/timeline.md",
449
+ "sourcePath": "components/ui/timeline/index.ts",
450
+ "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."
451
+ },
452
+ {
453
+ "name": "toggle-group",
454
+ "docPath": "docs/components/toggle-group.md",
455
+ "sourcePath": "components/ui/toggle-group/index.ts",
456
+ "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."
457
+ },
458
+ {
459
+ "name": "toggle",
460
+ "docPath": "docs/components/toggle.md",
461
+ "sourcePath": "components/ui/toggle/index.ts",
462
+ "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."
463
+ },
464
+ {
465
+ "name": "tooltip",
466
+ "docPath": "docs/components/tooltip.md",
467
+ "sourcePath": "components/ui/tooltip/index.ts",
468
+ "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."
469
+ },
470
+ {
471
+ "name": "tree-view",
472
+ "docPath": "docs/components/tree-view.md",
473
+ "sourcePath": "components/ui/tree-view/index.ts",
474
+ "description": "An interactive hierarchical tree component for displaying and navigating nested data structures — file systems, organizational charts, category trees, and recursive navigation menus. Supports keyboard navigation (Arrow keys, Home, End, Space), expand/collapse, and single-node selection."
475
+ },
476
+ {
477
+ "name": "use-mobile",
478
+ "docPath": "docs/components/use-mobile.md",
479
+ "sourcePath": "components/ui/use-mobile.tsx",
480
+ "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."
481
+ },
482
+ {
483
+ "name": "video-player",
484
+ "docPath": "docs/components/video-player.md",
485
+ "sourcePath": "components/ui/video-player.tsx",
486
+ "description": "A feature-rich video player component with floating mode support, custom controls, and automatic state management."
487
+ },
488
+ {
489
+ "name": "xertica-logo",
490
+ "docPath": "docs/components/xertica-logo.md",
491
+ "sourcePath": "components/brand/xertica-logo/index.ts",
492
+ "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."
493
+ },
494
+ {
495
+ "name": "xertica-orbe",
496
+ "docPath": "docs/components/xertica-orbe.md",
497
+ "sourcePath": "components/brand/xertica-orbe/index.ts",
498
+ "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."
499
+ },
500
+ {
501
+ "name": "xertica-provider",
502
+ "docPath": "docs/components/xertica-provider.md",
503
+ "sourcePath": "components/brand/xertica-provider/index.ts",
504
+ "description": "The recommended root wrapper for Xertica UI applications. Most components can render independently with local fallbacks, but the provider centralizes app-wide state, theming, maps, tooltips, assistant state, API keys, and notifications."
505
+ },
506
+ {
507
+ "name": "xertica-xlogo",
508
+ "docPath": "docs/components/xertica-xlogo.md",
509
+ "sourcePath": "components/brand/xertica-xlogo/index.ts",
510
+ "description": "A compact, square variant of the Xertica logo featuring the stylized \"X\" mark. Ideal for favicons, collapsed sidebars, and small profile badges."
511
+ }
512
512
  ]