xertica-ui 2.3.0 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (534) hide show
  1. package/CHANGELOG.md +564 -552
  2. package/README.md +417 -406
  3. package/assets/xertica-logo.svg +37 -37
  4. package/assets/xertica-x-logo.svg +20 -20
  5. package/bin/cli.ts +1244 -1155
  6. package/bin/language-config.ts +358 -361
  7. package/components/assistant/code-block/CodeBlock.tsx +268 -268
  8. package/components/assistant/formatted-document/FormattedDocument.tsx +147 -147
  9. package/components/assistant/modern-chat-input/ModernChatInput.tsx +564 -554
  10. package/components/assistant/xertica-assistant/parts/AssistantCollapsedView.tsx +99 -99
  11. package/components/assistant/xertica-assistant/parts/AssistantConversationList.tsx +104 -106
  12. package/components/assistant/xertica-assistant/parts/AssistantDocumentEditor.tsx +81 -81
  13. package/components/assistant/xertica-assistant/parts/AssistantFeedbackDialog.tsx +88 -78
  14. package/components/assistant/xertica-assistant/parts/AssistantHeader.tsx +75 -75
  15. package/components/assistant/xertica-assistant/parts/AssistantMessageBubble.tsx +564 -560
  16. package/components/assistant/xertica-assistant/parts/AssistantTabBar.tsx +67 -67
  17. package/components/assistant/xertica-assistant/parts/AssistantWelcomeScreen.tsx +103 -103
  18. package/components/assistant/xertica-assistant/use-assistant.ts +615 -615
  19. package/components/assistant/xertica-assistant/xertica-assistant.tsx +611 -613
  20. package/components/blocks/card-patterns/ActivityCard.tsx +100 -100
  21. package/components/blocks/card-patterns/ActivityCardSkeleton.tsx +56 -56
  22. package/components/blocks/card-patterns/FeatureCardSkeleton.tsx +58 -63
  23. package/components/blocks/card-patterns/NotificationCard.tsx +140 -140
  24. package/components/blocks/card-patterns/NotificationCardSkeleton.tsx +81 -81
  25. package/components/blocks/card-patterns/ProfileCard.tsx +112 -114
  26. package/components/blocks/card-patterns/ProfileCardSkeleton.tsx +69 -69
  27. package/components/blocks/card-patterns/ProjectCard.tsx +123 -123
  28. package/components/blocks/card-patterns/ProjectCardSkeleton.tsx +67 -72
  29. package/components/blocks/card-patterns/QuickActionCardSkeleton.tsx +44 -44
  30. package/components/blocks/card-patterns/card-patterns.stories.tsx +594 -594
  31. package/components/blocks/card-patterns/index.ts +29 -29
  32. package/components/brand/language-selector/LanguageSelector.tsx +102 -102
  33. package/components/brand/language-selector/language-selector.stories.tsx +111 -114
  34. package/components/brand/language-selector/language-selector.test.tsx +101 -101
  35. package/components/brand/theme-toggle/ThemeToggle.tsx +74 -70
  36. package/components/brand/xertica-provider/XerticaProvider.tsx +109 -112
  37. package/components/brand/xertica-provider/xertica-provider.mdx +61 -61
  38. package/components/index.ts +86 -90
  39. package/components/layout/sidebar/sidebar.mdx +1 -1
  40. package/components/layout/sidebar/sidebar.tsx +1079 -1073
  41. package/components/media/FloatingMediaWrapper.tsx +371 -371
  42. package/components/media/audio-player/AudioPlayer.tsx +768 -766
  43. package/components/media/video-player/VideoPlayer.tsx +310 -310
  44. package/components/pages/forgot-password-page/ForgotPasswordPage.tsx +1 -1
  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 -74
  48. package/components/pages/home-page/home-page.mdx +53 -53
  49. package/components/pages/login-page/LoginPage.tsx +218 -216
  50. package/components/pages/reset-password-page/ResetPasswordPage.tsx +243 -239
  51. package/components/pages/template-content/TemplateContent.tsx +1354 -1235
  52. package/components/pages/template-content/template-content.mdx +61 -61
  53. package/components/pages/template-page/template-page.mdx +53 -53
  54. package/components/pages/verify-email-page/VerifyEmailPage.tsx +206 -206
  55. package/components/shared/error-boundary.stories.tsx +4 -22
  56. package/components/shared/error-boundary.tsx +1 -5
  57. package/components/shared/error-fallbacks.tsx +4 -8
  58. package/components/ui/accordion/accordion.mdx +8 -8
  59. package/components/ui/alert/alert.mdx +8 -8
  60. package/components/ui/alert-dialog/alert-dialog.mdx +8 -8
  61. package/components/ui/aspect-ratio/aspect-ratio.mdx +8 -8
  62. package/components/ui/assistant-chart/assistant-chart.mdx +8 -8
  63. package/components/ui/avatar/avatar.mdx +8 -8
  64. package/components/ui/badge/badge.mdx +8 -8
  65. package/components/ui/breadcrumb/breadcrumb.mdx +8 -8
  66. package/components/ui/button/button.mdx +8 -8
  67. package/components/ui/calendar/calendar.mdx +8 -8
  68. package/components/ui/card/card.mdx +8 -8
  69. package/components/ui/carousel/carousel.mdx +8 -8
  70. package/components/ui/chart/chart.mdx +8 -8
  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 -62
  106. package/components/ui/stats-card/stats-card.mdx +8 -8
  107. package/components/ui/stats-card/stats-card.stories.tsx +99 -99
  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 +892 -892
  119. package/contexts/AuthContext.tsx +11 -8
  120. package/contexts/LanguageContext.test.tsx +121 -121
  121. package/contexts/LanguageContext.tsx +250 -251
  122. package/dist/{AssistantChart-DoZCyS5r.cjs → AssistantChart-9w31gdAb.cjs} +4 -4
  123. package/dist/{AssistantChart-CldVCVDe.cjs → AssistantChart-BAudAfne.cjs} +5 -5
  124. package/dist/{AssistantChart-Bdd44uBn.cjs → AssistantChart-BAx9VQvb.cjs} +127 -388
  125. package/dist/{AssistantChart-Cu3m7RBo.js → AssistantChart-BP8upjMk.js} +5 -5
  126. package/dist/{AssistantChart-CFhDdGyU.js → AssistantChart-CVko2A1W.js} +130 -391
  127. package/dist/{AssistantChart-C_hwFRRr.js → AssistantChart-CVzmmhx4.js} +4 -4
  128. package/dist/{AudioPlayer-IAU5q5T1.cjs → AudioPlayer-1ypwE2Wh.cjs} +1 -1
  129. package/dist/{AudioPlayer-CGRUtUdN.js → AudioPlayer-DuKXrCfy.js} +1 -1
  130. package/dist/{LanguageContext-CS14yCpi.js → LanguageContext-BwhwC3G2.js} +2 -2
  131. package/dist/{LanguageContext-B_KFTCzT.cjs → LanguageContext-DvUt5jBg.cjs} +2 -2
  132. package/dist/{ThemeContext-C2EwAPDt.js → ThemeContext-BbBNoFTG.js} +2 -2
  133. package/dist/{ThemeContext-Bmod0Cg2.cjs → ThemeContext-BblcjQup.cjs} +13 -8
  134. package/dist/{ThemeContext-BWq9ACPo.js → ThemeContext-Bo-W2WZH.js} +13 -8
  135. package/dist/{ThemeContext-j5aGtPky.cjs → ThemeContext-CP3a0jxy.cjs} +193 -262
  136. package/dist/{ThemeContext-vTjumZeM.cjs → ThemeContext-Cmr8Ex8H.cjs} +2 -2
  137. package/dist/ThemeContext-CpqYShLq.cjs +324 -0
  138. package/dist/{ThemeContext-CQSo4Iwc.js → ThemeContext-D3LzacmG.js} +8 -1
  139. package/dist/ThemeContext-Du2nE1PL.js +325 -0
  140. package/dist/ThemeContext-GeEBTJ3q.cjs +1621 -0
  141. package/dist/ThemeContext-JyLK9B1o.js +1622 -0
  142. package/dist/{ThemeContext-CGk3KK0k.cjs → ThemeContext-U4dEYc6C.cjs} +8 -1
  143. package/dist/{ThemeContext-BXjrgUjW.js → ThemeContext-ept8jhXI.js} +200 -261
  144. package/dist/{VerifyEmailPage-C0c2e5n0.js → VerifyEmailPage-BE-L9mB7.js} +7 -7
  145. package/dist/{VerifyEmailPage-DSBMRHtl.js → VerifyEmailPage-BIBOKV7Z.js} +41 -36
  146. package/dist/{VerifyEmailPage-DgIid028.js → VerifyEmailPage-BJjAMUTW.js} +4 -4
  147. package/dist/{VerifyEmailPage--1Vurewl.cjs → VerifyEmailPage-BRSP-Pwt.cjs} +3 -3
  148. package/dist/{VerifyEmailPage-Cwi3kbol.cjs → VerifyEmailPage-Bae2cBXT.cjs} +7 -7
  149. package/dist/{VerifyEmailPage-De6bQjrz.cjs → VerifyEmailPage-BiRm7Nh4.cjs} +41 -36
  150. package/dist/{VerifyEmailPage-ByerOcm4.cjs → VerifyEmailPage-Bv8Ah_TK.cjs} +23 -20
  151. package/dist/VerifyEmailPage-Bvfv8HVQ.js +3214 -0
  152. package/dist/{VerifyEmailPage-BComraR7.cjs → VerifyEmailPage-CR7kb5df.cjs} +22 -12
  153. package/dist/{VerifyEmailPage-MTD7AG1Z.js → VerifyEmailPage-C_ihbcth.js} +4 -4
  154. package/dist/{VerifyEmailPage-1WwWczAn.js → VerifyEmailPage-CbgjOF0v.js} +22 -12
  155. package/dist/{VerifyEmailPage-DvMLZgFt.js → VerifyEmailPage-CdYPSJoO.js} +1 -1
  156. package/dist/{VerifyEmailPage-By3Jf__L.cjs → VerifyEmailPage-CkBYfsNy.cjs} +4 -4
  157. package/dist/{VerifyEmailPage-CJLz3jrn.js → VerifyEmailPage-Cyl55sJb.js} +23 -20
  158. package/dist/VerifyEmailPage-D-FRj5TU.cjs +3213 -0
  159. package/dist/VerifyEmailPage-DF2ilhum.cjs +3210 -0
  160. package/dist/{VerifyEmailPage-CYXtbKi3.cjs → VerifyEmailPage-DMBh4NM9.cjs} +1 -1
  161. package/dist/{VerifyEmailPage-CgMxRb4z.js → VerifyEmailPage-DTtFfC-J.js} +3 -3
  162. package/dist/{VerifyEmailPage-CFLMls1p.cjs → VerifyEmailPage-Dt7zgA4w.cjs} +4 -4
  163. package/dist/VerifyEmailPage-EhudUdqF.js +3211 -0
  164. package/dist/{VerifyEmailPage-C5TNQTBa.js → VerifyEmailPage-X14vhdyl.js} +148 -75
  165. package/dist/VerifyEmailPage-hdB8JQGv.cjs +3213 -0
  166. package/dist/{VerifyEmailPage-B4peJjAT.cjs → VerifyEmailPage-u_Dn7t1U.cjs} +148 -75
  167. package/dist/VerifyEmailPage-vYHbYK3q.js +3214 -0
  168. package/dist/{XerticaProvider-CBGc4EMA.cjs → XerticaProvider-AChwphCO.cjs} +4 -4
  169. package/dist/{XerticaProvider-BIrqfZ-i.cjs → XerticaProvider-AbWlr7Af.cjs} +8 -11
  170. package/dist/{XerticaProvider-D-yNhF94.cjs → XerticaProvider-B8CaV7xu.cjs} +1 -1
  171. package/dist/{XerticaProvider-DDuiIcKo.js → XerticaProvider-BErr83Bg.js} +14 -11
  172. package/dist/{XerticaProvider-CEoWMTxu.js → XerticaProvider-BITjgC5p.js} +2 -2
  173. package/dist/{XerticaProvider-CllrbMEJ.cjs → XerticaProvider-By8q3Roe.cjs} +2 -2
  174. package/dist/{XerticaProvider-C1DKnvLh.js → XerticaProvider-CUYJZc32.js} +4 -4
  175. package/dist/{XerticaProvider-ET0ihewn.cjs → XerticaProvider-CW9hpCdF.cjs} +2 -2
  176. package/dist/{XerticaProvider-Dt5HEzbQ.js → XerticaProvider-CWgby5mY.js} +10 -10
  177. package/dist/XerticaProvider-CWs6EwNa.js +49 -0
  178. package/dist/XerticaProvider-CjQAQPcn.cjs +48 -0
  179. package/dist/XerticaProvider-CwOkHxiT.cjs +44 -0
  180. package/dist/XerticaProvider-D5lLumH-.js +49 -0
  181. package/dist/{XerticaProvider-DYq4JWtg.js → XerticaProvider-DQtvJU7m.js} +1 -1
  182. package/dist/XerticaProvider-qQUDop71.cjs +48 -0
  183. package/dist/{XerticaProvider-B7EVH-NF.js → XerticaProvider-siSt9uG2.js} +2 -2
  184. package/dist/{XerticaXLogo-Zw2B276b.cjs → XerticaXLogo-8TTzBjHw.cjs} +1 -1
  185. package/dist/{XerticaXLogo-B7xQ5dhi.js → XerticaXLogo-BWaag64t.js} +1 -1
  186. package/dist/{XerticaXLogo-DZbo4vOE.js → XerticaXLogo-BX3ueACh.js} +5 -2
  187. package/dist/XerticaXLogo-CFuIlYFH.js +252 -0
  188. package/dist/XerticaXLogo-CU-U-GP4.cjs +251 -0
  189. package/dist/XerticaXLogo-ChryA6xj.js +252 -0
  190. package/dist/{XerticaXLogo-CQUUjXoH.cjs → XerticaXLogo-CziKMQil.cjs} +8 -8
  191. package/dist/XerticaXLogo-DHz5SugF.js +252 -0
  192. package/dist/XerticaXLogo-DTee_y8X.cjs +251 -0
  193. package/dist/{XerticaXLogo-Cmsp-Eey.js → XerticaXLogo-DfUvz-lD.js} +9 -9
  194. package/dist/XerticaXLogo-kslQ8Tk_.cjs +251 -0
  195. package/dist/{XerticaXLogo-bvZSgwGF.cjs → XerticaXLogo-qBPhwK3g.cjs} +5 -2
  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/assistant.cjs.js +1 -1
  199. package/dist/assistant.es.js +1 -1
  200. package/dist/brand.cjs.js +2 -2
  201. package/dist/brand.es.js +2 -2
  202. package/dist/cli.js +90 -37
  203. package/dist/components/brand/theme-toggle/ThemeToggle.d.ts +1 -1
  204. package/dist/components/index.d.ts +1 -1
  205. package/dist/{google-maps-loader-Y-QkD-Li.cjs → google-maps-loader-BqsYL48U.cjs} +0 -5
  206. package/dist/{google-maps-loader-CTYySAun.js → google-maps-loader-t2IlYBzw.js} +0 -4
  207. package/dist/index-CkTUgOwX.js +8 -0
  208. package/dist/{index-COtD8bRW.cjs → index-D3RLKRAs.cjs} +1 -1
  209. package/dist/index.cjs.js +5 -5
  210. package/dist/index.es.js +5 -5
  211. package/dist/index.umd.js +454 -1027
  212. package/dist/layout.cjs.js +1 -1
  213. package/dist/layout.es.js +1 -1
  214. package/dist/pages.cjs.js +1 -1
  215. package/dist/pages.es.js +1 -1
  216. package/dist/{sidebar-DAaY8bRU.cjs → sidebar-B3EYhli0.cjs} +33 -24
  217. package/dist/{sidebar-B6SlKZYN.js → sidebar-B4ZWaMrE.js} +1 -1
  218. package/dist/{sidebar-DQj1z3jG.cjs → sidebar-B9NR0lCe.cjs} +269 -227
  219. package/dist/{sidebar-nzPoVHBQ.cjs → sidebar-BS1p2V7t.cjs} +1 -1
  220. package/dist/sidebar-BvF5I2Ue.cjs +800 -0
  221. package/dist/{sidebar-q7P2Godd.cjs → sidebar-C5B_LHek.cjs} +1 -1
  222. package/dist/{sidebar-CrQDDdcz.js → sidebar-CA6_ek3f.js} +33 -24
  223. package/dist/{sidebar-BxGXsDAd.cjs → sidebar-CVUGHOS_.cjs} +8 -16
  224. package/dist/{sidebar-BViy8Eeu.js → sidebar-CmvwjnVb.js} +9 -17
  225. package/dist/sidebar-CplprZpM.js +801 -0
  226. package/dist/{sidebar-BbVIQvlP.js → sidebar-Dz7bd3zP.js} +1 -1
  227. package/dist/sidebar-KIS0C2JH.js +801 -0
  228. package/dist/sidebar-OTO_up7Z.js +801 -0
  229. package/dist/sidebar-zowjejT2.cjs +800 -0
  230. package/dist/{use-audio-player-nv8ZSGa1.js → use-audio-player-Bkh23vQ3.js} +3 -7
  231. package/dist/{use-audio-player-NKsWyjWu.cjs → use-audio-player-Dn1NR9xN.cjs} +3 -7
  232. package/dist/{xertica-assistant-dyP7KHM5.cjs → xertica-assistant-B1IaHXnB.cjs} +388 -529
  233. package/dist/{xertica-assistant-DCsnQyi5.js → xertica-assistant-B1NaSFFj.js} +46 -29
  234. package/dist/{xertica-assistant-ciJaWqm1.js → xertica-assistant-BMqdyRVi.js} +10 -28
  235. package/dist/{xertica-assistant-V_IdW4WF.cjs → xertica-assistant-Bj3vBCq_.cjs} +9 -27
  236. package/dist/{xertica-assistant-CrgTb6Hs.cjs → xertica-assistant-CIaUlbIt.cjs} +47 -22
  237. package/dist/{xertica-assistant-yX1CFBBo.js → xertica-assistant-DPsESB6t.js} +390 -531
  238. package/dist/{CodeBlock-BgfYL_rD.cjs → xertica-assistant-Qp3ydksa.cjs} +51 -263
  239. package/dist/{CodeBlock-BeSt1h5P.js → xertica-assistant-gnCJdcZY.js} +7 -219
  240. package/dist/xertica-ui.css +2 -2
  241. package/docs/architecture-improvements.md +456 -456
  242. package/docs/architecture.md +312 -306
  243. package/docs/components/assistant.md +428 -428
  244. package/docs/components/branding.md +252 -252
  245. package/docs/components/card-patterns.md +447 -445
  246. package/docs/components/error-boundary.md +32 -22
  247. package/docs/components/hooks.md +432 -430
  248. package/docs/components/language-selector.md +176 -172
  249. package/docs/components/pages.md +20 -6
  250. package/docs/doc-audit.md +244 -243
  251. package/docs/getting-started.md +616 -603
  252. package/docs/guidelines.md +330 -328
  253. package/docs/i18n.md +480 -476
  254. package/docs/installation.md +7 -6
  255. package/docs/llms.md +295 -295
  256. package/docs/state-management.md +289 -289
  257. package/guidelines/Guidelines.md +409 -406
  258. package/llms-compact.txt +1 -1
  259. package/llms.txt +1 -1
  260. package/package.json +219 -219
  261. package/styles/xertica/base.css +6 -0
  262. package/templates/.prettierignore +4 -4
  263. package/templates/.prettierrc +10 -10
  264. package/templates/CLAUDE.md +180 -165
  265. package/templates/guidelines/Guidelines.md +577 -553
  266. package/templates/package.json +69 -69
  267. package/templates/src/app/App.tsx +46 -46
  268. package/templates/src/app/components/AuthGuard.tsx +57 -8
  269. package/templates/src/features/assistant/data/mock.ts +75 -75
  270. package/templates/src/features/assistant/hooks/useAssistantConfig.ts +20 -20
  271. package/templates/src/features/assistant/index.ts +5 -5
  272. package/templates/src/features/auth/ui/AuthPageShell.tsx +1 -1
  273. package/templates/src/features/auth/ui/ForgotPasswordContent.tsx +70 -72
  274. package/templates/src/features/auth/ui/LoginContent.tsx +92 -92
  275. package/templates/src/features/auth/ui/ResetPasswordContent.tsx +183 -179
  276. package/templates/src/features/auth/ui/SocialLoginButtons.tsx +78 -78
  277. package/templates/src/features/auth/ui/VerifyEmailContent.tsx +80 -84
  278. package/templates/src/features/home/data/mock.ts +6 -0
  279. package/templates/src/features/home/hooks/useFeatureCards.ts +20 -20
  280. package/templates/src/features/home/index.ts +11 -11
  281. package/templates/src/features/home/ui/HomeContent.tsx +117 -119
  282. package/templates/src/features/template/ui/CrudTemplate.tsx +112 -115
  283. package/templates/src/features/template/ui/DashboardTemplate.tsx +110 -110
  284. package/templates/src/features/template/ui/FormTemplate.tsx +117 -117
  285. package/templates/src/features/template/ui/LoginTemplate.tsx +59 -59
  286. package/templates/src/features/template/ui/TemplateContent.tsx +1322 -1314
  287. package/templates/src/i18n.ts +124 -124
  288. package/templates/src/locales/en/common.json +21 -21
  289. package/templates/src/locales/en/components/activityCard.json +10 -10
  290. package/templates/src/locales/en/components/assistant.json +119 -119
  291. package/templates/src/locales/en/components/media.json +29 -29
  292. package/templates/src/locales/en/components/notificationCard.json +5 -5
  293. package/templates/src/locales/en/components/profileCard.json +8 -8
  294. package/templates/src/locales/en/components/projectCard.json +10 -10
  295. package/templates/src/locales/en/components/sidebar.json +14 -14
  296. package/templates/src/locales/en/components/stats.json +8 -8
  297. package/templates/src/locales/en/components/team.json +14 -14
  298. package/templates/src/locales/en/errors.json +9 -9
  299. package/templates/src/locales/en/languageSelector.json +7 -7
  300. package/templates/src/locales/en/nav.json +6 -6
  301. package/templates/src/locales/en/pages/crudTemplate.json +25 -25
  302. package/templates/src/locales/en/pages/dashboardTemplate.json +20 -20
  303. package/templates/src/locales/en/pages/forgotPassword.json +10 -10
  304. package/templates/src/locales/en/pages/formTemplate.json +16 -16
  305. package/templates/src/locales/en/pages/home.json +7 -7
  306. package/templates/src/locales/en/pages/login.json +15 -15
  307. package/templates/src/locales/en/pages/loginTemplate.json +9 -9
  308. package/templates/src/locales/en/pages/resetPassword.json +18 -18
  309. package/templates/src/locales/en/pages/templates.json +317 -317
  310. package/templates/src/locales/en/pages/verifyEmail.json +12 -12
  311. package/templates/src/locales/en/themeToggle.json +6 -6
  312. package/templates/src/locales/es/common.json +21 -21
  313. package/templates/src/locales/es/components/activityCard.json +10 -10
  314. package/templates/src/locales/es/components/assistant.json +119 -119
  315. package/templates/src/locales/es/components/media.json +29 -29
  316. package/templates/src/locales/es/components/notificationCard.json +5 -5
  317. package/templates/src/locales/es/components/profileCard.json +8 -8
  318. package/templates/src/locales/es/components/projectCard.json +10 -10
  319. package/templates/src/locales/es/components/sidebar.json +14 -14
  320. package/templates/src/locales/es/components/stats.json +8 -8
  321. package/templates/src/locales/es/components/team.json +14 -14
  322. package/templates/src/locales/es/errors.json +9 -9
  323. package/templates/src/locales/es/languageSelector.json +7 -7
  324. package/templates/src/locales/es/nav.json +6 -6
  325. package/templates/src/locales/es/pages/crudTemplate.json +25 -25
  326. package/templates/src/locales/es/pages/dashboardTemplate.json +20 -20
  327. package/templates/src/locales/es/pages/forgotPassword.json +10 -10
  328. package/templates/src/locales/es/pages/formTemplate.json +16 -16
  329. package/templates/src/locales/es/pages/home.json +7 -7
  330. package/templates/src/locales/es/pages/login.json +15 -15
  331. package/templates/src/locales/es/pages/loginTemplate.json +9 -9
  332. package/templates/src/locales/es/pages/resetPassword.json +18 -18
  333. package/templates/src/locales/es/pages/templates.json +317 -317
  334. package/templates/src/locales/es/pages/verifyEmail.json +12 -12
  335. package/templates/src/locales/es/themeToggle.json +6 -6
  336. package/templates/src/locales/pt-BR/common.json +21 -21
  337. package/templates/src/locales/pt-BR/components/activityCard.json +10 -10
  338. package/templates/src/locales/pt-BR/components/assistant.json +119 -119
  339. package/templates/src/locales/pt-BR/components/media.json +29 -29
  340. package/templates/src/locales/pt-BR/components/notificationCard.json +5 -5
  341. package/templates/src/locales/pt-BR/components/profileCard.json +8 -8
  342. package/templates/src/locales/pt-BR/components/projectCard.json +10 -10
  343. package/templates/src/locales/pt-BR/components/sidebar.json +14 -14
  344. package/templates/src/locales/pt-BR/components/stats.json +8 -8
  345. package/templates/src/locales/pt-BR/components/team.json +14 -14
  346. package/templates/src/locales/pt-BR/errors.json +9 -9
  347. package/templates/src/locales/pt-BR/languageSelector.json +7 -7
  348. package/templates/src/locales/pt-BR/nav.json +6 -6
  349. package/templates/src/locales/pt-BR/pages/crudTemplate.json +25 -25
  350. package/templates/src/locales/pt-BR/pages/dashboardTemplate.json +20 -20
  351. package/templates/src/locales/pt-BR/pages/forgotPassword.json +10 -10
  352. package/templates/src/locales/pt-BR/pages/formTemplate.json +16 -16
  353. package/templates/src/locales/pt-BR/pages/home.json +7 -7
  354. package/templates/src/locales/pt-BR/pages/login.json +15 -15
  355. package/templates/src/locales/pt-BR/pages/loginTemplate.json +9 -9
  356. package/templates/src/locales/pt-BR/pages/resetPassword.json +18 -18
  357. package/templates/src/locales/pt-BR/pages/templates.json +317 -317
  358. package/templates/src/locales/pt-BR/pages/verifyEmail.json +12 -12
  359. package/templates/src/locales/pt-BR/themeToggle.json +6 -6
  360. package/templates/src/pages/AssistantPage.tsx +470 -464
  361. package/templates/src/pages/HomePage.tsx +53 -49
  362. package/templates/src/shared/error-boundary.tsx +1 -5
  363. package/templates/src/shared/error-fallbacks.tsx +4 -8
  364. package/templates/vite.config.js +20 -20
  365. package/templates/vite.config.ts +55 -52
  366. package/dist/AssistantChart-CxGjH7Qk.js +0 -3477
  367. package/dist/AssistantChart-DIpshm3i.js +0 -4784
  368. package/dist/AssistantChart-D_PTeu8P.cjs +0 -3503
  369. package/dist/AssistantChart-zjsy2GaZ.cjs +0 -4810
  370. package/dist/AudioPlayer-B1lt5cPl.cjs +0 -989
  371. package/dist/AudioPlayer-BZ7bibzU.cjs +0 -982
  372. package/dist/AudioPlayer-BpRPS4-1.cjs +0 -1277
  373. package/dist/AudioPlayer-C12BjQBV.cjs +0 -997
  374. package/dist/AudioPlayer-CFeV8t-5.cjs +0 -936
  375. package/dist/AudioPlayer-Coly3q5R.js +0 -1278
  376. package/dist/AudioPlayer-CySJIyvL.js +0 -937
  377. package/dist/AudioPlayer-DMcG_c7L.js +0 -990
  378. package/dist/AudioPlayer-DcFKRJE_.js +0 -998
  379. package/dist/AudioPlayer-e8LfNoqO.js +0 -983
  380. package/dist/BrandColorsContext-565dDHd5.js +0 -660
  381. package/dist/BrandColorsContext-BcJbtkqn.cjs +0 -659
  382. package/dist/CodeBlock-7TTgmdGG.cjs +0 -2094
  383. package/dist/CodeBlock-BlcqlA9M.cjs +0 -2094
  384. package/dist/CodeBlock-Bnmeu5ez.cjs +0 -2094
  385. package/dist/CodeBlock-BtfPlbAI.js +0 -2078
  386. package/dist/CodeBlock-CIySIuYr.js +0 -2078
  387. package/dist/CodeBlock-CuPtUM-7.cjs +0 -2094
  388. package/dist/CodeBlock-D6ffWXgc.js +0 -2078
  389. package/dist/CodeBlock-D8dcwbit.cjs +0 -2094
  390. package/dist/CodeBlock-DMZrFnlw.cjs +0 -2094
  391. package/dist/CodeBlock-DlBehYN8.js +0 -2078
  392. package/dist/CodeBlock-DnYNI8rQ.js +0 -2078
  393. package/dist/CodeBlock-DvKWbSnE.cjs +0 -2094
  394. package/dist/CodeBlock-DwMCfkFY.js +0 -2078
  395. package/dist/CodeBlock-Dy6CNYyj.js +0 -2078
  396. package/dist/CodeBlock-U1pPOQI7.cjs +0 -2094
  397. package/dist/CodeBlock-f_GpNhEB.js +0 -2078
  398. package/dist/CodeBlock-oB6u8nI1.js +0 -2078
  399. package/dist/CodeBlock-tZC31B73.cjs +0 -2094
  400. package/dist/FeatureCard-CxC-7C-C.cjs +0 -300
  401. package/dist/FeatureCard-DbHWCb4E.js +0 -301
  402. package/dist/ImageWithFallback-CGtidP6B.cjs +0 -4542
  403. package/dist/ImageWithFallback-lsg3pdFg.js +0 -4508
  404. package/dist/LanguageSelector-B5YfbHra.js +0 -231
  405. package/dist/LanguageSelector-D6uacAIM.cjs +0 -230
  406. package/dist/LayoutContext-B45-e9DI.cjs +0 -93
  407. package/dist/LayoutContext-BAql6ZRY.js +0 -97
  408. package/dist/LayoutContext-Bav3UMEA.js +0 -94
  409. package/dist/LayoutContext-BvK-ggDa.cjs +0 -96
  410. package/dist/ThemeContext-BoH4NLfN.js +0 -734
  411. package/dist/ThemeContext-r69W20Xg.cjs +0 -733
  412. package/dist/VerifyEmailPage-COiyNl1y.js +0 -2825
  413. package/dist/VerifyEmailPage-CqKsR2v8.js +0 -2827
  414. package/dist/VerifyEmailPage-DjQKRlUS.cjs +0 -2824
  415. package/dist/VerifyEmailPage-s-1X3LDJ.cjs +0 -2826
  416. package/dist/XerticaOrbe-KL1RBHzw.cjs +0 -1354
  417. package/dist/XerticaOrbe-zwS1p2a8.js +0 -1355
  418. package/dist/XerticaProvider-6btlAlzc.js +0 -17
  419. package/dist/XerticaProvider-BNoNOxQ5.cjs +0 -16
  420. package/dist/XerticaProvider-BlY2limY.cjs +0 -38
  421. package/dist/XerticaProvider-cI9hSs27.cjs +0 -38
  422. package/dist/XerticaProvider-hSwhNQex.js +0 -39
  423. package/dist/alert-dialog-BOje--vD.js +0 -847
  424. package/dist/alert-dialog-BtEuQqrg.cjs +0 -870
  425. package/dist/breadcrumb-CqJ7bHY5.js +0 -161
  426. package/dist/breadcrumb-m9Hb2_XN.cjs +0 -177
  427. package/dist/components/assistant/xertica-assistant/hooks/index.d.ts +0 -6
  428. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-conversations.d.ts +0 -21
  429. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-messages.d.ts +0 -49
  430. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-suggestions.d.ts +0 -16
  431. package/dist/components/blocks/audio-player/AudioPlayer.d.ts +0 -35
  432. package/dist/components/blocks/audio-player/index.d.ts +0 -1
  433. package/dist/components/blocks/document-editor/DocumentEditor.d.ts +0 -26
  434. package/dist/components/blocks/document-editor/index.d.ts +0 -1
  435. package/dist/components/blocks/podcast-player/PodcastPlayer.d.ts +0 -41
  436. package/dist/components/blocks/podcast-player/index.d.ts +0 -1
  437. package/dist/components/ui/chart/parts/chart-dashboard.d.ts +0 -113
  438. package/dist/components/ui/chart/parts/chart-metric.d.ts +0 -118
  439. package/dist/components/ui/chart/parts/chart-primitives.d.ts +0 -101
  440. package/dist/components/ui/chart/parts/chart-shared.d.ts +0 -20
  441. package/dist/components/ui/chart/parts/chart-utils.d.ts +0 -12
  442. package/dist/components/ui/chart/parts/index.d.ts +0 -5
  443. package/dist/dropdown-menu-BDB5CmQs.cjs +0 -247
  444. package/dist/dropdown-menu-DQidbKBD.js +0 -231
  445. package/dist/google-maps-loader-BFWp6VPd.js +0 -287
  446. package/dist/google-maps-loader-BKcdgFbu.cjs +0 -312
  447. package/dist/google-maps-loader-CumCNXeG.js +0 -312
  448. package/dist/google-maps-loader-eS3uQ5TA.cjs +0 -287
  449. package/dist/header-Cgy6vYPk.cjs +0 -731
  450. package/dist/header-DRlT4jgI.js +0 -715
  451. package/dist/header-Dux00SI4.cjs +0 -731
  452. package/dist/header-EkGKXPsD.js +0 -715
  453. package/dist/header-WfEywpyc.cjs +0 -731
  454. package/dist/header-tifNQn2U.js +0 -715
  455. package/dist/index-BhapVLVj.js +0 -8
  456. package/dist/index-D6fxYEY8.cjs +0 -7
  457. package/dist/index-DAIp0_HK.js +0 -8
  458. package/dist/index-DW5tYe26.js +0 -8
  459. package/dist/index-GA__GvnG.cjs +0 -7
  460. package/dist/input-2R4loU86.js +0 -127
  461. package/dist/input-DWANSKGb.cjs +0 -145
  462. package/dist/progress-DPtzoVV8.js +0 -175
  463. package/dist/progress-EeaoqqUs.cjs +0 -191
  464. package/dist/rich-text-editor-0mraWT5y.cjs +0 -2376
  465. package/dist/rich-text-editor-B-IkcPD0.js +0 -2874
  466. package/dist/rich-text-editor-B6jMRLzk.cjs +0 -1939
  467. package/dist/rich-text-editor-B8_oYcIR.js +0 -1730
  468. package/dist/rich-text-editor-B9UbSXNb.js +0 -1203
  469. package/dist/rich-text-editor-BYuRBNBU.js +0 -2373
  470. package/dist/rich-text-editor-Bb9pySTs.cjs +0 -2374
  471. package/dist/rich-text-editor-BcL6L3cm.cjs +0 -2374
  472. package/dist/rich-text-editor-BoVZYtTs.cjs +0 -2391
  473. package/dist/rich-text-editor-Bp3zQqMC.js +0 -2954
  474. package/dist/rich-text-editor-CMgSN_w2.js +0 -1189
  475. package/dist/rich-text-editor-CPV1lEPH.cjs +0 -1748
  476. package/dist/rich-text-editor-CeucBdIv.cjs +0 -2971
  477. package/dist/rich-text-editor-CoKqbCtu.cjs +0 -1799
  478. package/dist/rich-text-editor-Cw56T_mB.js +0 -2356
  479. package/dist/rich-text-editor-Cyt8qs2b.js +0 -1921
  480. package/dist/rich-text-editor-D6H84OcX.cjs +0 -1220
  481. package/dist/rich-text-editor-D76gD-QI.js +0 -2328
  482. package/dist/rich-text-editor-DKkokOnA.js +0 -1781
  483. package/dist/rich-text-editor-DNsdpN64.cjs +0 -2359
  484. package/dist/rich-text-editor-DfG8bCyY.js +0 -2358
  485. package/dist/rich-text-editor-Dxjw31Z4.js +0 -2341
  486. package/dist/rich-text-editor-DzP0Epmb.js +0 -2356
  487. package/dist/rich-text-editor-bRkNoeZY.cjs +0 -2891
  488. package/dist/rich-text-editor-lyYE2ZG5.cjs +0 -1207
  489. package/dist/rich-text-editor-skplNlBM.cjs +0 -2345
  490. package/dist/select-Bkbr0f-Z.cjs +0 -162
  491. package/dist/select-CvIVdX2n.js +0 -145
  492. package/dist/sidebar-CK_0ZQHj.cjs +0 -803
  493. package/dist/sidebar-CUuOvYhK.js +0 -787
  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-DUBpmEgo.cjs +0 -2186
  533. package/dist/{rich-text-editor-DgF8s7xW.js → rich-text-editor-BmsjY03B.js} +26 -26
  534. package/dist/{rich-text-editor-mWoaSCE4.cjs → rich-text-editor-GS2kpTAK.cjs} +26 -26
package/README.md CHANGED
@@ -1,406 +1,417 @@
1
- # Xertica UI
2
-
3
- > **Enterprise-grade React design system** built on Tailwind CSS v4, Radix UI, and Lucide Icons — with a robust AI-first documentation layer for precise LLM-driven composition and autonomous agent interaction.
4
-
5
- [![npm version](https://img.shields.io/badge/npm-2.3.0-blue)](https://www.npmjs.com/package/xertica-ui)
6
- [![license](https://img.shields.io/badge/license-proprietary-red)](./LICENSE)
7
-
8
- ---
9
-
10
- ## 🤖 AI-First Single Source of Truth
11
-
12
- Xertica UI is specifically designed to be consumed by AI Agents (LLMs, code assistants, autonomous agents). We provide dedicated entry points for AI context:
13
-
14
- | File | Purpose |
15
- | ---------------------------------------- | ------------------------------------------------------------------------------------------- |
16
- | [`llms.txt`](./llms.txt) | Standard index for AI crawlers and context-aware agents. |
17
- | [`llms-compact.txt`](./llms-compact.txt) | **Compact documentation** of all components in a single file for LLMs with limited context. |
18
- | [`llms-full.txt`](./llms-full.txt) | **Complete documentation** of all components in a single file for LLMs with large-context. |
19
- | `docs/llms.md` | Master index for agents to navigate the documentation folder. |
20
-
21
- ---
22
-
23
- ## 🚀 Quick Start — CLI (Recommended)
24
-
25
- Scaffold a full application with pre-configured routing, layout, and components:
26
-
27
- ```bash
28
- npx xertica-ui@latest init my-app
29
- cd my-app
30
- npm run dev
31
- ```
32
-
33
- During `init`, the CLI walks you through:
34
-
35
- | Prompt | Choices |
36
- |---|---|
37
- | Pages to include | Login, Home, Template (multi-select) |
38
- | **Languages to support** | Português (BR), English, Español — select **1, 2, or 3** |
39
- | Default color theme | Xertica, Slate, Blue, Violet, Rose, Emerald, … |
40
- | **Include AI Assistant** | yes (default) / no |
41
- | Install dependencies automatically | yes / no |
42
-
43
- The CLI generates a tailored project with:
44
-
45
- - Only the locale JSON files for the languages you picked (no orphan files)
46
- - `src/i18n.ts` with imports + `resources` for exactly those languages
47
- - `src/app/App.tsx` with the `availableLanguages` prop on `<XerticaProvider>` (omitted when all 3 defaults are selected)
48
- - A persisted selection in `src/locales/.languages.json` so the `update` command can preserve it
49
- - Feature flags in `.xertica.json` (e.g. `hasAssistant`) so the `update` command can read the current state
50
-
51
- ### Monolingual mode (transparent)
52
-
53
- If you select only one language, the project becomes **monolingual** — the `<LanguageSelector>` automatically renders `null` (there is nothing to switch to). A header comment in the generated `App.tsx` documents this behavior. To force the selector visible anyway, pass `<LanguageSelector showWhenMonolingual />`.
54
-
55
- ### Updating languages later
56
-
57
- ```bash
58
- npx xertica-ui update # then choose "Languages"
59
- ```
60
-
61
- The flow shows your current selection, lets you toggle languages, and on confirmation:
62
- - copies any newly-added locale JSON from `node_modules/xertica-ui/templates/src/locales/`
63
- - removes JSONs of unselected languages
64
- - regenerates `src/i18n.ts` and `src/app/App.tsx`
65
- - updates `src/locales/.languages.json`
66
-
67
- The `update` → **Project files** flow also reads `.languages.json` and preserves your selection — overwrites of `App.tsx` and `i18n.ts` won't reset your languages to defaults.
68
-
69
- ### Adding or removing the AI Assistant later
70
-
71
- ```bash
72
- npx xertica-ui update # then choose "Assistant"
73
- ```
74
-
75
- The flow detects the current state (via `.xertica.json` or file presence) and shows the appropriate action:
76
- - **Add**: copies `src/features/assistant/` and `src/pages/AssistantPage.tsx`, adds the `/assistente` route to `AuthGuard.tsx`, and updates `HomePage.tsx` / `TemplatePage.tsx` to include the assistant panel.
77
- - **Remove**: deletes those files, removes the route, and regenerates the page files without assistant imports.
78
-
79
- Feature flags are persisted in `.xertica.json` at the project root.
80
-
81
- > **Note:** Always use `@latest` with npx. Without it, npx may execute a locally cached older version instead of fetching the latest from the registry.
82
-
83
- ---
84
-
85
- ## 📦 Installation as a Library
86
-
87
- To add Xertica UI to an existing React project:
88
-
89
- ```bash
90
- npm install xertica-ui
91
- ```
92
-
93
- **1. Import the stylesheet** in your entry file (`main.tsx` or `App.tsx`):
94
-
95
- ```tsx
96
- import 'xertica-ui/style.css';
97
- ```
98
-
99
- **2. Import components from the matching subpath**:
100
-
101
- ```tsx
102
- import { Button, Card } from 'xertica-ui/ui';
103
-
104
- export function Example() {
105
- return (
106
- <Card className="p-4">
107
- <Button>Continue</Button>
108
- </Card>
109
- );
110
- }
111
- ```
112
-
113
- **3. Optionally wrap your app** with `XerticaProvider` when you want coordinated theme, layout, assistant, maps, tooltip, API-key, language, and toast services:
114
-
115
- ```tsx
116
- import { XerticaProvider } from 'xertica-ui/brand';
117
-
118
- function App() {
119
- return (
120
- <XerticaProvider>
121
- <YourApp />
122
- </XerticaProvider>
123
- );
124
- }
125
- ```
126
-
127
- **Configuring languages at runtime** — `<XerticaProvider>` accepts `availableLanguages` to override the default set. When only one language is configured, the `LanguageSelector` auto-hides:
128
-
129
- ```tsx
130
- import { XerticaProvider, DEFAULT_LANGUAGES } from 'xertica-ui';
131
- import fr from './locales/fr.json';
132
-
133
- // Monolingual English (no language picker)
134
- <XerticaProvider availableLanguages={[{ code: 'en', label: 'English' }]}>
135
-
136
- // Defaults + a custom locale (bundle auto-registered with i18next)
137
- <XerticaProvider
138
- availableLanguages={[
139
- ...DEFAULT_LANGUAGES,
140
- { code: 'fr', label: 'Français', shortLabel: 'FR', resources: fr },
141
- ]}
142
- >
143
- ```
144
-
145
- See [`docs/i18n.md`](./docs/i18n.md) for the full `LanguageDefinition` and `registerLanguageResource` API.
146
-
147
- ---
148
-
149
- ## 📂 Subpath Imports (FSD/FDA)
150
-
151
- Xertica UI v2 exposes **granular subpath entries** import only what your layer needs without loading the entire library:
152
-
153
- ```tsx
154
- import { Button, Card, Input } from 'xertica-ui/ui'; // shared/ui — primitives
155
- import { QuickActionCard } from 'xertica-ui/blocks'; // composed blocks
156
- import { Sidebar, Header } from 'xertica-ui/layout'; // layout shell
157
- import { XerticaProvider } from 'xertica-ui/brand'; // app-level — providers & brand
158
- import { XerticaAssistant } from 'xertica-ui/assistant'; // feature — AI assistant
159
- import { VideoPlayer, AudioPlayer } from 'xertica-ui/media'; // feature — media players
160
- import { useLayout, useOptionalLayout, useTheme } from 'xertica-ui/hooks'; // shared/lib — hooks & contexts
161
- import { TemplatePage } from 'xertica-ui/pages'; // optional page templates
162
- import 'xertica-ui/style.css'; // styles — import once at root
163
- ```
164
-
165
- The root `from 'xertica-ui'` barrel remains available for full backward compatibility.
166
-
167
- > **TypeScript**: requires `"moduleResolution": "bundler"` (or `"node16"` / `"nodenext"`) in `tsconfig.json` to resolve subpath exports.
168
-
169
- ### Component Independence Contract
170
-
171
- `xertica-ui/style.css` is the only required global import. Public components are designed to render independently whenever possible, so importing one component into a consumer project should also bring the runtime logic that component needs.
172
-
173
- `XerticaProvider` remains the recommended app-level convenience wrapper, but it is not required for most primitives. It composes the library providers for theme, brand colors, language, layout, assistant state, API keys, Google Maps, tooltips, and toasts.
174
-
175
- Components with unavoidable external configuration, such as Google Maps, should render a configuration or error state instead of crashing the app.
176
-
177
- ---
178
-
179
- ## 🛠️ The Layout System
180
-
181
- Xertica UI features an autonomous layout system managed by `LayoutContext`.
182
-
183
- ### Mandatory Page Structure
184
-
185
- Every page **must** use the `<PageHeader>` component for its title and primary actions. Never use raw `h1` or `div` for headers.
186
-
187
- ```tsx
188
- import { PageHeader, PageHeaderHeading, Button } from 'xertica-ui/ui';
189
-
190
- export function MyPage() {
191
- return (
192
- <>
193
- <PageHeader>
194
- <PageHeaderHeading>Dashboard</PageHeaderHeading>
195
- <Button>Action</Button>
196
- </PageHeader>
197
- <div className="p-6">{/* Page Content */}</div>
198
- </>
199
- );
200
- }
201
- ```
202
-
203
- ### `useLayout()` Hook
204
-
205
- Access the sidebar state, width, and toggle functions anywhere in the component tree:
206
-
207
- ```tsx
208
- import { useLayout } from 'xertica-ui/hooks';
209
-
210
- const { sidebarWidth, isSidebarOpen, toggleSidebar } = useLayout();
211
- ```
212
-
213
- Use `useLayout()` when a page must fail early without a layout provider. Use `useOptionalLayout()` inside reusable components that should still render with internal fallbacks when imported in isolation.
214
-
215
- ```tsx
216
- import { useOptionalLayout } from 'xertica-ui/hooks';
217
-
218
- const layout = useOptionalLayout();
219
- const sidebarWidth = layout?.sidebarWidth ?? 0;
220
- ```
221
-
222
- ---
223
-
224
- ## 🏗️ CLI Template FSD/FDA Architecture
225
-
226
- Projects scaffolded with `npx xertica-ui@latest init` follow **Feature-Sliced Design (FSD) + Feature-Driven Architecture (FDA)**:
227
-
228
- ```
229
- src/
230
- app/ ← BrowserRouter, XerticaProvider, AuthGuard, AppLayout
231
- shared/
232
- config/ ← navigation.ts (route definitions)
233
- lib/ ← auth.ts (localStorage helpers)
234
- types/ ← auth.ts (User interface)
235
- features/
236
- auth/ui/ ← LoginContent, ForgotPasswordContent, VerifyEmailContent, ResetPasswordContent
237
- home/
238
- data/mock.ts ← typed fetch + factory functions like getMockRichSuggestions()
239
- hooks/ ← useFeatureCards() — language-aware queryKey
240
- ui/ ← HomeContent
241
- template/ui/ TemplateContent, FormTemplate
242
- assistant/ ← AssistantConfig + useAssistantConfig() (only when AI Assistant is included)
243
- pages/ thin wrappers: LoginPage, HomePage, TemplatePage, AssistantPage, …
244
- styles/ index.css, xertica/tokens.css
245
- i18n.ts generated by CLI — imports/resources for selected languages only
246
- locales/
247
- pt-BR.json
248
- en.json ← only files for the languages you selected
249
- es.json
250
- .languages.json persisted selection (read by `npx xertica-ui update`)
251
- ```
252
-
253
- Each feature only imports from `shared/` or its own domain. Pages only compose features. Server-state hooks (e.g. `useFeatureCards`) include the active **language** in their `queryKey` so locale switching invalidates and refetches automatically. See `templates/guidelines/Guidelines.md` for the full architecture guide.
254
-
255
- ---
256
-
257
- ## 🧩 Component Catalog (100+ Components)
258
-
259
- ### Layout & Navigation
260
-
261
- `Header` · `Sidebar` · `PageHeader` · `Breadcrumb` · `NavigationMenu` · `Tabs` · `Pagination` · `Accordion` · `Collapsible`
262
-
263
- ### Core Surfaces
264
-
265
- `Card` · `Separator` · `ScrollArea` · `AspectRatio` · `Resizable` · `Skeleton` · `Empty`
266
-
267
- ### Forms & Inputs
268
-
269
- `Form` · `Input` · `Textarea` · `RichTextEditor` · `Label` · `Checkbox` · `RadioGroup` · `Switch` · `Select` · `Slider` · `Calendar` · `InputOTP` · `FileUpload` · `Search`
270
-
271
- ### Actions & Data
272
-
273
- `Button` · `Toggle` · `ToggleGroup` · `Rating` · `Table` · `Badge` · `Avatar` · `Progress` · `StatsCard` · `Timeline` · `Stepper` · `TreeView` · `NotificationBadge` · `Chart`
274
-
275
- ### Overlays & Feedback
276
-
277
- `Dialog` · `AlertDialog` · `Sheet` · `Drawer` · `Popover` · `HoverCard` · `Tooltip` · `Alert` · `Sonner (Toast)` · `Command`
278
-
279
- ### Composed Blocks (with matching skeleton variants)
280
-
281
- | Card | Skeleton |
282
- |---|---|
283
- | `FeatureCard` | `FeatureCardSkeleton` |
284
- | `ActivityCard` | `ActivityCardSkeleton` |
285
- | `ProfileCard` | `ProfileCardSkeleton` |
286
- | `ProjectCard` | `ProjectCardSkeleton` |
287
- | `QuickActionCard` | `QuickActionCardSkeleton` |
288
- | `NotificationCard` | `NotificationCardSkeleton` |
289
- | `StatsCard` (in `xertica-ui/ui`) | `StatsCardSkeleton` |
290
-
291
- Each skeleton mirrors its card's visual layout with pulsing placeholders for loading states:
292
-
293
- ```tsx
294
- {isLoading
295
- ? <ActivityCardSkeleton rows={5} />
296
- : <ActivityCard items={items} />}
297
- ```
298
-
299
- ---
300
-
301
- ## 🌟 Specialized Modules
302
-
303
- ### 🤖 AI Assistant
304
-
305
- Integrated AI chat panel with workspace support. Use `demoMode={true}` for mock responses without an API key; pass `demoMode={false}` and a `geminiApiKey` (via `<XerticaProvider apiKey="...">`) for real Gemini integration.
306
-
307
- - `XerticaAssistant` · `MarkdownMessage` · `CodeBlock` · `AssistantChart` · `ModernChatInput` · `FormattedDocument`
308
-
309
- ### 🗺️ Maps & Geolocation
310
-
311
- First-class Google Maps integration.
312
-
313
- - `Map` · `RouteMap` · `SimpleMap` · `GoogleMapsLoader`
314
-
315
- ### 🎙️ Media
316
-
317
- - `AudioPlayer` · `VideoPlayer` · `FloatingMediaWrapper`
318
-
319
- ### 📄 Pages
320
-
321
- - `LoginPage` · `HomePage` · `TemplatePage` · `AssistantPage` · `ForgotPasswordPage` · `ResetPasswordPage` · `VerifyEmailPage`
322
-
323
- ### 🧱 Blocks
324
-
325
- High-level dashboard and product patterns exported from `xertica-ui/blocks` (also re-exported from the root barrel). Every card ships with a matching `*Skeleton` loading-state companion — see the table in **Composed Blocks** above.
326
-
327
- The CLI template includes a small fixed version badge so generated projects can visually identify which `xertica-ui` package version they are using.
328
-
329
- ---
330
-
331
- ## 📚 Storybook Documentation
332
-
333
- Storybook Docs pages use each component's real story variations instead of repeating a single usage example. UI component MDX files now render the story list directly, so docs stay aligned with the component's public stories.
334
-
335
- Map stories use a wider responsive preview frame, making `Map`, `RouteMap`, and related map examples readable in the Docs canvas.
336
-
337
- ---
338
-
339
- ## 🎨 Design Tokens
340
-
341
- Xertica UI uses semantic CSS tokens. **Never use raw colors or generic Tailwind color classes**.
342
-
343
- ### Mobile Content Padding
344
-
345
- The CSS token `--mobile-content-padding` (default `1.25rem`) controls the horizontal padding of content areas on small screens (`< 768px`). To adjust it globally, override it in your project's `src/styles/xertica/tokens.css`:
346
-
347
- ```css
348
- :root {
349
- --mobile-content-padding: 1.5rem; /* increase */
350
- }
351
- ```
352
-
353
- ```
354
- Background: bg-background text-foreground
355
- Card surface: bg-card text-card-foreground
356
- Muted area: bg-muted text-muted-foreground
357
- Primary action: bg-primary text-primary-foreground
358
- Destructive: bg-destructive text-destructive-foreground
359
- Border: border-border
360
- ```
361
-
362
- ---
363
-
364
- ## 🌍 Localization
365
-
366
- Xertica UI is fully internationalized via **`i18next`** + **`react-i18next`**.
367
-
368
- - **UI Components**: Translated out-of-the-box in **Portuguese (pt-BR)**, **English**, and **Español**. Every component uses `useTranslation()` — no hardcoded strings.
369
- - **Runtime extensibility**: Add custom locales (e.g. `fr`, `ja`, `de`) at runtime via `<XerticaProvider availableLanguages={[...]}>` — no source-file edits required.
370
- - **Monolingual mode**: Configure a single language to make the `LanguageSelector` auto-hide.
371
- - **Language-aware React Query**: Hooks include the active language in their `queryKey` so mock/API responses translated via `i18n.t()` refetch automatically when the user switches language. No page reload required.
372
- - **Documentation/Code**: Strictly maintained in **English** for AI Agent compatibility and global developer standard.
373
-
374
- See [`docs/i18n.md`](./docs/i18n.md) for setup, runtime configuration, and adding custom locales.
375
-
376
- ---
377
-
378
- ## 💻 Tech Stack
379
-
380
- | Technology | Version |
381
- | ------------ | ------- |
382
- | React | 18.3 |
383
- | TypeScript | 5.7 |
384
- | Tailwind CSS | 4.0 |
385
- | Vite | 6.0 |
386
- | Radix UI | Latest |
387
- | Lucide React | 0.469+ |
388
- | Vitest | 4.1 |
389
-
390
- ---
391
-
392
- ## 📜 Scripts
393
-
394
- | Command | Description |
395
- | -------------------- | -------------------------------------- |
396
- | `npm run dev` | Start development server |
397
- | `npm run build` | Production bundle |
398
- | `npm run storybook` | Launch component library documentation |
399
- | `npm run test` | Run unit tests via Vitest |
400
- | `npm run type-check` | TypeScript validation |
401
-
402
- ---
403
-
404
- ## ⚖️ License
405
-
406
- Proprietary Xertica.ai Team.
1
+ # Xertica UI
2
+
3
+ > **Enterprise-grade React design system** built on Tailwind CSS v4, Radix UI, and Lucide Icons — with a robust AI-first documentation layer for precise LLM-driven composition and autonomous agent interaction.
4
+
5
+ [![npm version](https://img.shields.io/badge/npm-2.4.0-blue)](https://www.npmjs.com/package/xertica-ui)
6
+ [![license](https://img.shields.io/badge/license-proprietary-red)](./LICENSE)
7
+
8
+ ---
9
+
10
+ ## 🤖 AI-First Single Source of Truth
11
+
12
+ Xertica UI is specifically designed to be consumed by AI Agents (LLMs, code assistants, autonomous agents). We provide dedicated entry points for AI context:
13
+
14
+ | File | Purpose |
15
+ | ---------------------------------------- | ------------------------------------------------------------------------------------------- |
16
+ | [`llms.txt`](./llms.txt) | Standard index for AI crawlers and context-aware agents. |
17
+ | [`llms-compact.txt`](./llms-compact.txt) | **Compact documentation** of all components in a single file for LLMs with limited context. |
18
+ | [`llms-full.txt`](./llms-full.txt) | **Complete documentation** of all components in a single file for LLMs with large-context. |
19
+ | `docs/llms.md` | Master index for agents to navigate the documentation folder. |
20
+
21
+ ---
22
+
23
+ ## 🚀 Quick Start — CLI (Recommended)
24
+
25
+ Scaffold a full application with pre-configured routing, layout, and components:
26
+
27
+ ```bash
28
+ npx xertica-ui@latest init my-app
29
+ cd my-app
30
+ npm run dev
31
+ ```
32
+
33
+ During `init`, the CLI walks you through:
34
+
35
+ | Prompt | Choices |
36
+ | ---------------------------------- | -------------------------------------------------------- |
37
+ | Pages to include | Login, Home, Template (multi-select) |
38
+ | **Languages to support** | Português (BR), English, Español — select **1, 2, or 3** |
39
+ | Default color theme | Xertica, Slate, Blue, Violet, Rose, Emerald, … |
40
+ | **Enable dark mode support?** | yes (default) / no |
41
+ | **Include AI Assistant** | yes (default) / no |
42
+ | Install dependencies automatically | yes / no |
43
+
44
+ The CLI generates a tailored project with:
45
+
46
+ - Only the locale JSON files for the languages you picked (no orphan files)
47
+ - `src/i18n.ts` with imports + `resources` for exactly those languages
48
+ - `src/app/App.tsx` with the `availableLanguages` prop on `<XerticaProvider>` (omitted when all 3 defaults are selected) and `disableDarkMode={true}` if dark mode support was disabled
49
+ - A persisted selection in `src/locales/.languages.json` so the `update` command can preserve it
50
+ - Feature flags in `.xertica.json` (e.g. `hasAssistant`, `disableDarkMode`) so the `update` command can read the current state
51
+
52
+ ### Monolingual mode (transparent)
53
+
54
+ If you select only one language, the project becomes **monolingual** — the `<LanguageSelector>` automatically renders `null` (there is nothing to switch to). A header comment in the generated `App.tsx` documents this behavior. To force the selector visible anyway, pass `<LanguageSelector showWhenMonolingual />`.
55
+
56
+ ### Updating languages later
57
+
58
+ ```bash
59
+ npx xertica-ui update # then choose "Languages"
60
+ ```
61
+
62
+ The flow shows your current selection, lets you toggle languages, and on confirmation:
63
+
64
+ - copies any newly-added locale JSON from `node_modules/xertica-ui/templates/src/locales/`
65
+ - removes JSONs of unselected languages
66
+ - regenerates `src/i18n.ts` and `src/app/App.tsx`
67
+ - updates `src/locales/.languages.json`
68
+
69
+ The `update` **Project files** flow also reads `.languages.json` and preserves your selection — overwrites of `App.tsx` and `i18n.ts` won't reset your languages to defaults.
70
+
71
+ ### Enabling or disabling Dark Mode support later
72
+
73
+ ```bash
74
+ npx xertica-ui update # then choose "Dark Mode"
75
+ ```
76
+
77
+ The flow detects the current state (via `.xertica.json`) and prompts you to enable or disable dark mode. On confirmation, it updates `.xertica.json` and regenerates `App.tsx` with the updated `disableDarkMode` flag (which hides the `ThemeToggle` and template settings tab switch when disabled).
78
+
79
+ ### Adding or removing the AI Assistant later
80
+
81
+ ```bash
82
+ npx xertica-ui update # then choose "Assistant"
83
+ ```
84
+
85
+ The flow detects the current state (via `.xertica.json` or file presence) and shows the appropriate action:
86
+
87
+ - **Add**: copies `src/features/assistant/` and `src/pages/AssistantPage.tsx`, adds the `/assistente` route to `AuthGuard.tsx`, and updates `HomePage.tsx` / `TemplatePage.tsx` to include the assistant panel.
88
+ - **Remove**: deletes those files, removes the route, and regenerates the page files without assistant imports.
89
+
90
+ Feature flags are persisted in `.xertica.json` at the project root.
91
+
92
+ > **Note:** Always use `@latest` with npx. Without it, npx may execute a locally cached older version instead of fetching the latest from the registry.
93
+
94
+ ---
95
+
96
+ ## 📦 Installation as a Library
97
+
98
+ To add Xertica UI to an existing React project:
99
+
100
+ ```bash
101
+ npm install xertica-ui
102
+ ```
103
+
104
+ **1. Import the stylesheet** in your entry file (`main.tsx` or `App.tsx`):
105
+
106
+ ```tsx
107
+ import 'xertica-ui/style.css';
108
+ ```
109
+
110
+ **2. Import components from the matching subpath**:
111
+
112
+ ```tsx
113
+ import { Button, Card } from 'xertica-ui/ui';
114
+
115
+ export function Example() {
116
+ return (
117
+ <Card className="p-4">
118
+ <Button>Continue</Button>
119
+ </Card>
120
+ );
121
+ }
122
+ ```
123
+
124
+ **3. Optionally wrap your app** with `XerticaProvider` when you want coordinated theme, layout, assistant, maps, tooltip, API-key, language, and toast services:
125
+
126
+ ```tsx
127
+ import { XerticaProvider } from 'xertica-ui/brand';
128
+
129
+ function App() {
130
+ return (
131
+ <XerticaProvider>
132
+ <YourApp />
133
+ </XerticaProvider>
134
+ );
135
+ }
136
+ ```
137
+
138
+ **Configuring languages at runtime** — `<XerticaProvider>` accepts `availableLanguages` to override the default set. When only one language is configured, the `LanguageSelector` auto-hides:
139
+
140
+ ```tsx
141
+ import { XerticaProvider, DEFAULT_LANGUAGES } from 'xertica-ui';
142
+ import fr from './locales/fr.json';
143
+
144
+ // Monolingual English (no language picker)
145
+ <XerticaProvider availableLanguages={[{ code: 'en', label: 'English' }]}>
146
+
147
+ // Defaults + a custom locale (bundle auto-registered with i18next)
148
+ <XerticaProvider
149
+ availableLanguages={[
150
+ ...DEFAULT_LANGUAGES,
151
+ { code: 'fr', label: 'Français', shortLabel: 'FR', resources: fr },
152
+ ]}
153
+ >
154
+ ```
155
+
156
+ See [`docs/i18n.md`](./docs/i18n.md) for the full `LanguageDefinition` and `registerLanguageResource` API.
157
+
158
+ ---
159
+
160
+ ## 📂 Subpath Imports (FSD/FDA)
161
+
162
+ Xertica UI v2 exposes **granular subpath entries** — import only what your layer needs without loading the entire library:
163
+
164
+ ```tsx
165
+ import { Button, Card, Input } from 'xertica-ui/ui'; // shared/ui primitives
166
+ import { QuickActionCard } from 'xertica-ui/blocks'; // composed blocks
167
+ import { Sidebar, Header } from 'xertica-ui/layout'; // layout shell
168
+ import { XerticaProvider } from 'xertica-ui/brand'; // app-level — providers & brand
169
+ import { XerticaAssistant } from 'xertica-ui/assistant'; // feature — AI assistant
170
+ import { VideoPlayer, AudioPlayer } from 'xertica-ui/media'; // feature — media players
171
+ import { useLayout, useOptionalLayout, useTheme } from 'xertica-ui/hooks'; // shared/lib hooks & contexts
172
+ import { TemplatePage } from 'xertica-ui/pages'; // optional page templates
173
+ import 'xertica-ui/style.css'; // styles import once at root
174
+ ```
175
+
176
+ The root `from 'xertica-ui'` barrel remains available for full backward compatibility.
177
+
178
+ > **TypeScript**: requires `"moduleResolution": "bundler"` (or `"node16"` / `"nodenext"`) in `tsconfig.json` to resolve subpath exports.
179
+
180
+ ### Component Independence Contract
181
+
182
+ `xertica-ui/style.css` is the only required global import. Public components are designed to render independently whenever possible, so importing one component into a consumer project should also bring the runtime logic that component needs.
183
+
184
+ `XerticaProvider` remains the recommended app-level convenience wrapper, but it is not required for most primitives. It composes the library providers for theme, brand colors, language, layout, assistant state, API keys, Google Maps, tooltips, and toasts.
185
+
186
+ Components with unavoidable external configuration, such as Google Maps, should render a configuration or error state instead of crashing the app.
187
+
188
+ ---
189
+
190
+ ## 🛠️ The Layout System
191
+
192
+ Xertica UI features an autonomous layout system managed by `LayoutContext`.
193
+
194
+ ### Mandatory Page Structure
195
+
196
+ Every page **must** use the `<PageHeader>` component for its title and primary actions. Never use raw `h1` or `div` for headers.
197
+
198
+ ```tsx
199
+ import { PageHeader, PageHeaderHeading, Button } from 'xertica-ui/ui';
200
+
201
+ export function MyPage() {
202
+ return (
203
+ <>
204
+ <PageHeader>
205
+ <PageHeaderHeading>Dashboard</PageHeaderHeading>
206
+ <Button>Action</Button>
207
+ </PageHeader>
208
+ <div className="p-6">{/* Page Content */}</div>
209
+ </>
210
+ );
211
+ }
212
+ ```
213
+
214
+ ### `useLayout()` Hook
215
+
216
+ Access the sidebar state, width, and toggle functions anywhere in the component tree:
217
+
218
+ ```tsx
219
+ import { useLayout } from 'xertica-ui/hooks';
220
+
221
+ const { sidebarWidth, isSidebarOpen, toggleSidebar } = useLayout();
222
+ ```
223
+
224
+ Use `useLayout()` when a page must fail early without a layout provider. Use `useOptionalLayout()` inside reusable components that should still render with internal fallbacks when imported in isolation.
225
+
226
+ ```tsx
227
+ import { useOptionalLayout } from 'xertica-ui/hooks';
228
+
229
+ const layout = useOptionalLayout();
230
+ const sidebarWidth = layout?.sidebarWidth ?? 0;
231
+ ```
232
+
233
+ ---
234
+
235
+ ## 🏗️ CLI Template — FSD/FDA Architecture
236
+
237
+ Projects scaffolded with `npx xertica-ui@latest init` follow **Feature-Sliced Design (FSD) + Feature-Driven Architecture (FDA)**:
238
+
239
+ ```
240
+ src/
241
+ app/ BrowserRouter, XerticaProvider, AuthGuard, AppLayout
242
+ shared/
243
+ config/ navigation.ts (route definitions)
244
+ lib/ auth.ts (localStorage helpers)
245
+ types/ ← auth.ts (User interface)
246
+ features/
247
+ auth/ui/ ← LoginContent, ForgotPasswordContent, VerifyEmailContent, ResetPasswordContent
248
+ home/
249
+ data/mock.ts ← typed fetch + factory functions like getMockRichSuggestions()
250
+ hooks/ useFeatureCards() language-aware queryKey
251
+ ui/ ← HomeContent
252
+ template/ui/ ← TemplateContent, FormTemplate
253
+ assistant/ ← AssistantConfig + useAssistantConfig() (only when AI Assistant is included)
254
+ pages/ ← thin wrappers: LoginPage, HomePage, TemplatePage, AssistantPage, …
255
+ styles/ ← index.css, xertica/tokens.css
256
+ i18n.ts ← generated by CLI — imports/resources for selected languages only
257
+ locales/
258
+ pt-BR.json
259
+ en.json ← only files for the languages you selected
260
+ es.json
261
+ .languages.json persisted selection (read by `npx xertica-ui update`)
262
+ ```
263
+
264
+ Each feature only imports from `shared/` or its own domain. Pages only compose features. Server-state hooks (e.g. `useFeatureCards`) include the active **language** in their `queryKey` so locale switching invalidates and refetches automatically. See `templates/guidelines/Guidelines.md` for the full architecture guide.
265
+
266
+ ---
267
+
268
+ ## 🧩 Component Catalog (100+ Components)
269
+
270
+ ### Layout & Navigation
271
+
272
+ `Header` · `Sidebar` · `PageHeader` · `Breadcrumb` · `NavigationMenu` · `Tabs` · `Pagination` · `Accordion` · `Collapsible`
273
+
274
+ ### Core Surfaces
275
+
276
+ `Card` · `Separator` · `ScrollArea` · `AspectRatio` · `Resizable` · `Skeleton` · `Empty`
277
+
278
+ ### Forms & Inputs
279
+
280
+ `Form` · `Input` · `Textarea` · `RichTextEditor` · `Label` · `Checkbox` · `RadioGroup` · `Switch` · `Select` · `Slider` · `Calendar` · `InputOTP` · `FileUpload` · `Search`
281
+
282
+ ### Actions & Data
283
+
284
+ `Button` · `Toggle` · `ToggleGroup` · `Rating` · `Table` · `Badge` · `Avatar` · `Progress` · `StatsCard` · `Timeline` · `Stepper` · `TreeView` · `NotificationBadge` · `Chart`
285
+
286
+ ### Overlays & Feedback
287
+
288
+ `Dialog` · `AlertDialog` · `Sheet` · `Drawer` · `Popover` · `HoverCard` · `Tooltip` · `Alert` · `Sonner (Toast)` · `Command`
289
+
290
+ ### Composed Blocks (with matching skeleton variants)
291
+
292
+ | Card | Skeleton |
293
+ | -------------------------------- | -------------------------- |
294
+ | `FeatureCard` | `FeatureCardSkeleton` |
295
+ | `ActivityCard` | `ActivityCardSkeleton` |
296
+ | `ProfileCard` | `ProfileCardSkeleton` |
297
+ | `ProjectCard` | `ProjectCardSkeleton` |
298
+ | `QuickActionCard` | `QuickActionCardSkeleton` |
299
+ | `NotificationCard` | `NotificationCardSkeleton` |
300
+ | `StatsCard` (in `xertica-ui/ui`) | `StatsCardSkeleton` |
301
+
302
+ Each skeleton mirrors its card's visual layout with pulsing placeholders for loading states:
303
+
304
+ ```tsx
305
+ {
306
+ isLoading ? <ActivityCardSkeleton rows={5} /> : <ActivityCard items={items} />;
307
+ }
308
+ ```
309
+
310
+ ---
311
+
312
+ ## 🌟 Specialized Modules
313
+
314
+ ### 🤖 AI Assistant
315
+
316
+ Integrated AI chat panel with workspace support. Use `demoMode={true}` for mock responses without an API key; pass `demoMode={false}` and a `geminiApiKey` (via `<XerticaProvider apiKey="...">`) for real Gemini integration.
317
+
318
+ - `XerticaAssistant` · `MarkdownMessage` · `CodeBlock` · `AssistantChart` · `ModernChatInput` · `FormattedDocument`
319
+
320
+ ### 🗺️ Maps & Geolocation
321
+
322
+ First-class Google Maps integration.
323
+
324
+ - `Map` · `RouteMap` · `SimpleMap` · `GoogleMapsLoader`
325
+
326
+ ### 🎙️ Media
327
+
328
+ - `AudioPlayer` · `VideoPlayer` · `FloatingMediaWrapper`
329
+
330
+ ### 📄 Pages
331
+
332
+ - `LoginPage` · `HomePage` · `TemplatePage` · `AssistantPage` · `ForgotPasswordPage` · `ResetPasswordPage` · `VerifyEmailPage`
333
+
334
+ ### 🧱 Blocks
335
+
336
+ High-level dashboard and product patterns exported from `xertica-ui/blocks` (also re-exported from the root barrel). Every card ships with a matching `*Skeleton` loading-state companion — see the table in **Composed Blocks** above.
337
+
338
+ The CLI template includes a small fixed version badge so generated projects can visually identify which `xertica-ui` package version they are using.
339
+
340
+ ---
341
+
342
+ ## 📚 Storybook Documentation
343
+
344
+ Storybook Docs pages use each component's real story variations instead of repeating a single usage example. UI component MDX files now render the story list directly, so docs stay aligned with the component's public stories.
345
+
346
+ Map stories use a wider responsive preview frame, making `Map`, `RouteMap`, and related map examples readable in the Docs canvas.
347
+
348
+ ---
349
+
350
+ ## 🎨 Design Tokens
351
+
352
+ Xertica UI uses semantic CSS tokens. **Never use raw colors or generic Tailwind color classes**.
353
+
354
+ ### Mobile Content Padding
355
+
356
+ The CSS token `--mobile-content-padding` (default `1.25rem`) controls the horizontal padding of content areas on small screens (`< 768px`). To adjust it globally, override it in your project's `src/styles/xertica/tokens.css`:
357
+
358
+ ```css
359
+ :root {
360
+ --mobile-content-padding: 1.5rem; /* increase */
361
+ }
362
+ ```
363
+
364
+ ```
365
+ Background: bg-background text-foreground
366
+ Card surface: bg-card text-card-foreground
367
+ Muted area: bg-muted text-muted-foreground
368
+ Primary action: bg-primary text-primary-foreground
369
+ Destructive: bg-destructive text-destructive-foreground
370
+ Border: border-border
371
+ ```
372
+
373
+ ---
374
+
375
+ ## 🌍 Localization
376
+
377
+ Xertica UI is fully internationalized via **`i18next`** + **`react-i18next`**.
378
+
379
+ - **UI Components**: Translated out-of-the-box in **Portuguese (pt-BR)**, **English**, and **Español**. Every component uses `useTranslation()` — no hardcoded strings.
380
+ - **Runtime extensibility**: Add custom locales (e.g. `fr`, `ja`, `de`) at runtime via `<XerticaProvider availableLanguages={[...]}>` — no source-file edits required.
381
+ - **Monolingual mode**: Configure a single language to make the `LanguageSelector` auto-hide.
382
+ - **Language-aware React Query**: Hooks include the active language in their `queryKey` so mock/API responses translated via `i18n.t()` refetch automatically when the user switches language. No page reload required.
383
+ - **Documentation/Code**: Strictly maintained in **English** for AI Agent compatibility and global developer standard.
384
+
385
+ See [`docs/i18n.md`](./docs/i18n.md) for setup, runtime configuration, and adding custom locales.
386
+
387
+ ---
388
+
389
+ ## 💻 Tech Stack
390
+
391
+ | Technology | Version |
392
+ | ------------ | ------- |
393
+ | React | 18.3 |
394
+ | TypeScript | 5.7 |
395
+ | Tailwind CSS | 4.0 |
396
+ | Vite | 6.0 |
397
+ | Radix UI | Latest |
398
+ | Lucide React | 0.469+ |
399
+ | Vitest | 4.1 |
400
+
401
+ ---
402
+
403
+ ## 📜 Scripts
404
+
405
+ | Command | Description |
406
+ | -------------------- | -------------------------------------- |
407
+ | `npm run dev` | Start development server |
408
+ | `npm run build` | Production bundle |
409
+ | `npm run storybook` | Launch component library documentation |
410
+ | `npm run test` | Run unit tests via Vitest |
411
+ | `npm run type-check` | TypeScript validation |
412
+
413
+ ---
414
+
415
+ ## ⚖️ License
416
+
417
+ Proprietary — Xertica.ai Team.