xertica-ui 2.2.0 → 2.3.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 (1057) hide show
  1. package/CHANGELOG.md +28 -1
  2. package/README.md +27 -3
  3. package/assets/xertica-logo.svg +37 -37
  4. package/assets/xertica-x-logo.svg +20 -20
  5. package/bin/cli.ts +477 -70
  6. package/bin/generate-tokens.ts +262 -262
  7. package/bin/language-config.ts +361 -361
  8. package/components/assets/xertica-orbe-animation.ts +1162 -1162
  9. package/components/assistant/code-block/code-block.stories.tsx +57 -57
  10. package/components/assistant/code-block/code-block.test.tsx +44 -44
  11. package/components/assistant/code-block/index.ts +1 -1
  12. package/components/assistant/formatted-document/formatted-document.stories.tsx +51 -51
  13. package/components/assistant/formatted-document/formatted-document.test.tsx +42 -42
  14. package/components/assistant/formatted-document/index.ts +1 -1
  15. package/components/assistant/index.ts +6 -6
  16. package/components/assistant/markdown-message/MarkdownMessage.tsx +152 -152
  17. package/components/assistant/markdown-message/index.ts +1 -1
  18. package/components/assistant/markdown-message/markdown-message.stories.tsx +50 -50
  19. package/components/assistant/markdown-message/markdown-message.test.tsx +33 -33
  20. package/components/assistant/modern-chat-input/ModernChatInput.tsx +554 -554
  21. package/components/assistant/modern-chat-input/index.ts +1 -1
  22. package/components/assistant/modern-chat-input/modern-chat-input.stories.tsx +131 -131
  23. package/components/assistant/modern-chat-input/modern-chat-input.test.tsx +79 -79
  24. package/components/assistant/xertica-assistant/index.ts +3 -3
  25. package/components/assistant/xertica-assistant/parts/AssistantTypingIndicator.tsx +41 -41
  26. package/components/assistant/xertica-assistant/parts/index.ts +16 -16
  27. package/components/assistant/xertica-assistant/types.ts +134 -134
  28. package/components/assistant/xertica-assistant/xertica-assistant.stories.tsx +407 -407
  29. package/components/assistant/xertica-assistant/xertica-assistant.test.tsx +65 -65
  30. package/components/blocks/card-patterns/ActivityCardSkeleton.tsx +56 -56
  31. package/components/blocks/card-patterns/FeatureCard.tsx +109 -109
  32. package/components/blocks/card-patterns/FeatureCardSkeleton.tsx +63 -63
  33. package/components/blocks/card-patterns/NotificationCardSkeleton.tsx +81 -81
  34. package/components/blocks/card-patterns/ProfileCardSkeleton.tsx +69 -69
  35. package/components/blocks/card-patterns/ProjectCardSkeleton.tsx +72 -72
  36. package/components/blocks/card-patterns/QuickActionCard.tsx +68 -68
  37. package/components/blocks/card-patterns/QuickActionCardSkeleton.tsx +44 -44
  38. package/components/blocks/card-patterns/card-patterns.mdx +123 -123
  39. package/components/blocks/index.ts +1 -1
  40. package/components/brand/branding/branding.stories.tsx +57 -57
  41. package/components/brand/index.ts +6 -6
  42. package/components/brand/language-selector/LanguageSelector.tsx +102 -102
  43. package/components/brand/language-selector/index.ts +1 -1
  44. package/components/brand/language-selector/language-selector.mdx +126 -126
  45. package/components/brand/language-selector/language-selector.stories.tsx +114 -114
  46. package/components/brand/language-selector/language-selector.test.tsx +101 -101
  47. package/components/brand/theme-toggle/index.ts +1 -1
  48. package/components/brand/theme-toggle/theme-toggle.stories.tsx +34 -34
  49. package/components/brand/theme-toggle/theme-toggle.test.tsx +34 -34
  50. package/components/brand/xertica-logo/XerticaLogo.stories.tsx +82 -82
  51. package/components/brand/xertica-logo/XerticaLogo.tsx +104 -104
  52. package/components/brand/xertica-logo/index.ts +1 -1
  53. package/components/brand/xertica-logo/xertica-logo.test.tsx +26 -26
  54. package/components/brand/xertica-orbe/XerticaOrbe.tsx +1927 -1927
  55. package/components/brand/xertica-orbe/index.ts +1 -1
  56. package/components/brand/xertica-orbe/xertica-orbe.stories.tsx +40 -40
  57. package/components/brand/xertica-orbe/xertica-orbe.test.tsx +19 -19
  58. package/components/brand/xertica-provider/XerticaProvider.tsx +112 -112
  59. package/components/brand/xertica-provider/index.ts +1 -1
  60. package/components/brand/xertica-provider/xertica-provider.mdx +61 -61
  61. package/components/brand/xertica-provider/xertica-provider.test.tsx +74 -74
  62. package/components/brand/xertica-xlogo/XerticaXLogo.stories.tsx +79 -79
  63. package/components/brand/xertica-xlogo/XerticaXLogo.tsx +65 -65
  64. package/components/brand/xertica-xlogo/index.ts +1 -1
  65. package/components/brand/xertica-xlogo/xertica-xlogo.test.tsx +16 -16
  66. package/components/examples/ApiKeyMapExample.tsx +71 -71
  67. package/components/examples/DrawingMapExample.tsx +565 -565
  68. package/components/examples/FilterableMapExample.tsx +393 -393
  69. package/components/examples/LocationPickerExample.tsx +348 -348
  70. package/components/examples/MapExamples.tsx +268 -268
  71. package/components/examples/MapGmpExample.tsx +169 -169
  72. package/components/examples/MapShowcase.tsx +471 -471
  73. package/components/examples/RouteMapExamples.tsx +329 -329
  74. package/components/examples/SidebarLogoExample.tsx +65 -65
  75. package/components/examples/SimpleFilterableMap.tsx +219 -219
  76. package/components/examples/index.ts +45 -45
  77. package/components/figma/ImageWithFallback.tsx +27 -27
  78. package/components/hooks/index.ts +13 -13
  79. package/components/hooks/use-layout-shortcuts.ts +43 -43
  80. package/components/layout/header/header.stories.tsx +204 -204
  81. package/components/layout/header/header.test.tsx +75 -75
  82. package/components/layout/header/header.tsx +349 -349
  83. package/components/layout/header/index.ts +1 -1
  84. package/components/layout/index.ts +2 -2
  85. package/components/layout/sidebar/index.ts +3 -3
  86. package/components/layout/sidebar/sidebar.mdx +1 -1
  87. package/components/layout/sidebar/sidebar.stories.tsx +586 -586
  88. package/components/layout/sidebar/sidebar.test.tsx +76 -76
  89. package/components/layout/sidebar/use-sidebar.ts +104 -104
  90. package/components/media/audio-player/AudioPlayer.stories.tsx +124 -124
  91. package/components/media/audio-player/AudioPlayer.test.tsx +106 -106
  92. package/components/media/audio-player/AudioPlayer.tsx +1 -1
  93. package/components/media/audio-player/index.ts +1 -1
  94. package/components/media/audio-player/use-audio-player.ts +312 -312
  95. package/components/media/index.ts +3 -3
  96. package/components/media/video-player/VideoPlayer.stories.tsx +98 -98
  97. package/components/media/video-player/VideoPlayer.test.tsx +73 -73
  98. package/components/media/video-player/index.ts +1 -1
  99. package/components/pages/forgot-password-page/ForgotPasswordPage.stories.tsx +24 -24
  100. package/components/pages/forgot-password-page/ForgotPasswordPage.tsx +188 -188
  101. package/components/pages/forgot-password-page/forgot-password-page.test.tsx +45 -45
  102. package/components/pages/forgot-password-page/index.ts +1 -1
  103. package/components/pages/home-content/HomeContent.stories.tsx +43 -43
  104. package/components/pages/home-content/HomeContent.tsx +1 -1
  105. package/components/pages/home-content/home-content.mdx +62 -62
  106. package/components/pages/home-content/index.ts +1 -1
  107. package/components/pages/home-page/HomePage.stories.tsx +39 -39
  108. package/components/pages/home-page/home-page.mdx +53 -53
  109. package/components/pages/home-page/home-page.test.tsx +53 -53
  110. package/components/pages/home-page/index.ts +1 -1
  111. package/components/pages/index.ts +8 -8
  112. package/components/pages/login-page/LoginPage.stories.tsx +39 -39
  113. package/components/pages/login-page/index.ts +1 -1
  114. package/components/pages/login-page/login-page.test.tsx +63 -63
  115. package/components/pages/reset-password-page/ResetPasswordPage.stories.tsx +24 -24
  116. package/components/pages/reset-password-page/index.ts +1 -1
  117. package/components/pages/template-content/TemplateContent.stories.tsx +43 -43
  118. package/components/pages/template-content/TemplateContent.tsx +1 -1
  119. package/components/pages/template-content/index.ts +1 -1
  120. package/components/pages/template-content/template-content.mdx +61 -61
  121. package/components/pages/template-page/TemplatePage.stories.tsx +39 -39
  122. package/components/pages/template-page/TemplatePage.tsx +62 -62
  123. package/components/pages/template-page/index.ts +1 -1
  124. package/components/pages/template-page/template-page.mdx +53 -53
  125. package/components/pages/template-page/template-page.test.tsx +52 -52
  126. package/components/pages/verify-email-page/VerifyEmailPage.stories.tsx +41 -41
  127. package/components/pages/verify-email-page/index.ts +1 -1
  128. package/components/public-api-smoke.test.tsx +52 -52
  129. package/components/shared/CustomTooltipContent.tsx +48 -48
  130. package/components/shared/assistant-utils.test.ts +16 -16
  131. package/components/shared/assistant-utils.ts +225 -225
  132. package/components/shared/error-boundary.stories.tsx +132 -132
  133. package/components/shared/error-boundary.tsx +154 -154
  134. package/components/shared/error-fallbacks.tsx +226 -226
  135. package/components/shared/layout-constants.ts +8 -8
  136. package/components/shared/navigation.ts +35 -35
  137. package/components/shared/use-mobile.test.ts +16 -16
  138. package/components/shared/use-mobile.ts +36 -36
  139. package/components/shared/utils.test.ts +14 -14
  140. package/components/shared/utils.ts +6 -6
  141. package/components/ui/accordion/accordion.mdx +8 -8
  142. package/components/ui/accordion/accordion.stories.tsx +105 -105
  143. package/components/ui/accordion/accordion.test.tsx +59 -59
  144. package/components/ui/accordion/accordion.tsx +77 -77
  145. package/components/ui/accordion/index.ts +1 -1
  146. package/components/ui/alert/alert.mdx +8 -8
  147. package/components/ui/alert/alert.stories.tsx +86 -86
  148. package/components/ui/alert/alert.test.tsx +53 -53
  149. package/components/ui/alert/alert.tsx +93 -93
  150. package/components/ui/alert/index.ts +1 -1
  151. package/components/ui/alert-dialog/alert-dialog.mdx +8 -8
  152. package/components/ui/alert-dialog/alert-dialog.stories.tsx +84 -84
  153. package/components/ui/alert-dialog/alert-dialog.test.tsx +70 -70
  154. package/components/ui/alert-dialog/alert-dialog.tsx +149 -149
  155. package/components/ui/alert-dialog/index.ts +1 -1
  156. package/components/ui/aspect-ratio/aspect-ratio.mdx +8 -8
  157. package/components/ui/aspect-ratio/aspect-ratio.stories.tsx +46 -46
  158. package/components/ui/aspect-ratio/aspect-ratio.test.tsx +28 -28
  159. package/components/ui/aspect-ratio/aspect-ratio.tsx +20 -20
  160. package/components/ui/aspect-ratio/index.ts +1 -1
  161. package/components/ui/assistant-chart/AssistantChart.tsx +64 -64
  162. package/components/ui/assistant-chart/assistant-chart.mdx +8 -8
  163. package/components/ui/assistant-chart/assistant-chart.stories.tsx +44 -44
  164. package/components/ui/assistant-chart/assistant-chart.test.tsx +46 -46
  165. package/components/ui/assistant-chart/index.ts +1 -1
  166. package/components/ui/avatar/avatar.mdx +8 -8
  167. package/components/ui/avatar/avatar.stories.tsx +86 -86
  168. package/components/ui/avatar/avatar.test.tsx +55 -55
  169. package/components/ui/avatar/avatar.tsx +71 -71
  170. package/components/ui/avatar/index.ts +1 -1
  171. package/components/ui/badge/badge.mdx +8 -8
  172. package/components/ui/badge/badge.stories.tsx +72 -72
  173. package/components/ui/badge/badge.test.tsx +40 -40
  174. package/components/ui/badge/badge.tsx +58 -58
  175. package/components/ui/badge/index.ts +1 -1
  176. package/components/ui/breadcrumb/breadcrumb.mdx +8 -8
  177. package/components/ui/breadcrumb/breadcrumb.stories.tsx +123 -123
  178. package/components/ui/breadcrumb/breadcrumb.test.tsx +70 -70
  179. package/components/ui/breadcrumb/breadcrumb.tsx +114 -114
  180. package/components/ui/breadcrumb/index.ts +1 -1
  181. package/components/ui/button/button.mdx +8 -8
  182. package/components/ui/button/button.stories.tsx +183 -183
  183. package/components/ui/button/button.test.tsx +64 -64
  184. package/components/ui/button/button.tsx +98 -98
  185. package/components/ui/button/index.ts +1 -1
  186. package/components/ui/calendar/calendar.mdx +8 -8
  187. package/components/ui/calendar/calendar.stories.tsx +108 -108
  188. package/components/ui/calendar/calendar.test.tsx +53 -53
  189. package/components/ui/calendar/calendar.tsx +230 -230
  190. package/components/ui/calendar/index.ts +1 -1
  191. package/components/ui/card/card.mdx +8 -8
  192. package/components/ui/card/card.stories.tsx +301 -301
  193. package/components/ui/card/card.test.tsx +55 -55
  194. package/components/ui/card/card.tsx +83 -83
  195. package/components/ui/card/index.ts +1 -1
  196. package/components/ui/carousel/carousel.mdx +8 -8
  197. package/components/ui/carousel/carousel.stories.tsx +80 -80
  198. package/components/ui/carousel/carousel.test.tsx +75 -75
  199. package/components/ui/carousel/carousel.tsx +242 -242
  200. package/components/ui/carousel/index.ts +1 -1
  201. package/components/ui/chart/chart.mdx +8 -8
  202. package/components/ui/chart/chart.stories.tsx +1328 -1328
  203. package/components/ui/chart/chart.test.tsx +178 -178
  204. package/components/ui/chart/chart.tsx +2232 -2232
  205. package/components/ui/chart/index.ts +1 -1
  206. package/components/ui/checkbox/checkbox.mdx +8 -8
  207. package/components/ui/checkbox/checkbox.stories.tsx +109 -109
  208. package/components/ui/checkbox/checkbox.test.tsx +49 -49
  209. package/components/ui/checkbox/checkbox.tsx +68 -68
  210. package/components/ui/checkbox/index.ts +1 -1
  211. package/components/ui/collapsible/collapsible.mdx +8 -8
  212. package/components/ui/collapsible/collapsible.stories.tsx +45 -45
  213. package/components/ui/collapsible/collapsible.test.tsx +51 -51
  214. package/components/ui/collapsible/collapsible.tsx +32 -32
  215. package/components/ui/collapsible/index.ts +1 -1
  216. package/components/ui/command/command.mdx +8 -8
  217. package/components/ui/command/command.stories.tsx +134 -134
  218. package/components/ui/command/command.test.tsx +48 -48
  219. package/components/ui/command/command.tsx +163 -163
  220. package/components/ui/command/index.ts +1 -1
  221. package/components/ui/context-menu/context-menu.mdx +8 -8
  222. package/components/ui/context-menu/context-menu.stories.tsx +76 -76
  223. package/components/ui/context-menu/context-menu.test.tsx +61 -61
  224. package/components/ui/context-menu/context-menu.tsx +236 -236
  225. package/components/ui/context-menu/index.ts +1 -1
  226. package/components/ui/dialog/dialog.mdx +8 -8
  227. package/components/ui/dialog/dialog.stories.tsx +174 -174
  228. package/components/ui/dialog/dialog.test.tsx +78 -78
  229. package/components/ui/dialog/dialog.tsx +189 -189
  230. package/components/ui/dialog/index.ts +1 -1
  231. package/components/ui/drawer/drawer.mdx +8 -8
  232. package/components/ui/drawer/drawer.stories.tsx +71 -71
  233. package/components/ui/drawer/drawer.test.tsx +67 -67
  234. package/components/ui/drawer/drawer.tsx +146 -146
  235. package/components/ui/drawer/index.ts +1 -1
  236. package/components/ui/dropdown-menu/dropdown-menu.mdx +8 -8
  237. package/components/ui/dropdown-menu/dropdown-menu.stories.tsx +156 -156
  238. package/components/ui/dropdown-menu/dropdown-menu.test.tsx +62 -62
  239. package/components/ui/dropdown-menu/dropdown-menu.tsx +240 -240
  240. package/components/ui/dropdown-menu/index.ts +1 -1
  241. package/components/ui/empty/empty.mdx +8 -8
  242. package/components/ui/empty/empty.stories.tsx +85 -85
  243. package/components/ui/empty/empty.test.tsx +31 -31
  244. package/components/ui/empty/empty.tsx +88 -88
  245. package/components/ui/empty/index.ts +1 -1
  246. package/components/ui/file-upload/file-upload.mdx +8 -8
  247. package/components/ui/file-upload/file-upload.stories.tsx +144 -144
  248. package/components/ui/file-upload/file-upload.test.tsx +65 -65
  249. package/components/ui/file-upload/file-upload.tsx +142 -142
  250. package/components/ui/file-upload/index.ts +2 -2
  251. package/components/ui/file-upload/use-file-upload.ts +177 -177
  252. package/components/ui/form/form.stories.tsx +85 -85
  253. package/components/ui/form/form.test.tsx +75 -75
  254. package/components/ui/form/form.tsx +163 -163
  255. package/components/ui/form/index.ts +1 -1
  256. package/components/ui/google-maps-loader/google-maps-loader.test.tsx +35 -35
  257. package/components/ui/google-maps-loader/google-maps-loader.tsx +465 -465
  258. package/components/ui/google-maps-loader/index.ts +1 -1
  259. package/components/ui/hover-card/hover-card.mdx +8 -8
  260. package/components/ui/hover-card/hover-card.stories.tsx +61 -61
  261. package/components/ui/hover-card/hover-card.test.tsx +48 -48
  262. package/components/ui/hover-card/hover-card.tsx +50 -50
  263. package/components/ui/hover-card/index.ts +1 -1
  264. package/components/ui/index.ts +400 -400
  265. package/components/ui/input/index.ts +1 -1
  266. package/components/ui/input/input.mdx +8 -8
  267. package/components/ui/input/input.stories.tsx +153 -153
  268. package/components/ui/input/input.test.tsx +47 -47
  269. package/components/ui/input/input.tsx +57 -57
  270. package/components/ui/input-otp/index.ts +1 -1
  271. package/components/ui/input-otp/input-otp.mdx +8 -8
  272. package/components/ui/input-otp/input-otp.stories.tsx +120 -120
  273. package/components/ui/input-otp/input-otp.test.tsx +74 -74
  274. package/components/ui/input-otp/input-otp.tsx +101 -101
  275. package/components/ui/label/index.ts +1 -1
  276. package/components/ui/label/label.mdx +8 -8
  277. package/components/ui/label/label.stories.tsx +74 -74
  278. package/components/ui/label/label.test.tsx +45 -45
  279. package/components/ui/label/label.tsx +53 -53
  280. package/components/ui/map/index.ts +1 -1
  281. package/components/ui/map/map.mdx +8 -8
  282. package/components/ui/map/map.stories.tsx +86 -86
  283. package/components/ui/map/map.test.tsx +82 -82
  284. package/components/ui/map/map.tsx +506 -506
  285. package/components/ui/map/mock.test.tsx +13 -13
  286. package/components/ui/map-config/index.ts +1 -1
  287. package/components/ui/map-config/map-config.ts +18 -18
  288. package/components/ui/map-layers/index.ts +1 -1
  289. package/components/ui/map-layers/map-layers.test.tsx +48 -48
  290. package/components/ui/map-layers/map-layers.tsx +126 -126
  291. package/components/ui/map.exports/index.ts +1 -1
  292. package/components/ui/map.exports/map.exports.ts +31 -31
  293. package/components/ui/menubar/index.ts +1 -1
  294. package/components/ui/menubar/menubar.mdx +8 -8
  295. package/components/ui/menubar/menubar.stories.tsx +130 -130
  296. package/components/ui/menubar/menubar.test.tsx +53 -53
  297. package/components/ui/menubar/menubar.tsx +265 -265
  298. package/components/ui/navigation-menu/index.ts +1 -1
  299. package/components/ui/navigation-menu/navigation-menu.mdx +8 -8
  300. package/components/ui/navigation-menu/navigation-menu.stories.tsx +126 -126
  301. package/components/ui/navigation-menu/navigation-menu.test.tsx +47 -47
  302. package/components/ui/navigation-menu/navigation-menu.tsx +165 -165
  303. package/components/ui/notification-badge/index.ts +1 -1
  304. package/components/ui/notification-badge/notification-badge.mdx +8 -8
  305. package/components/ui/notification-badge/notification-badge.stories.tsx +66 -66
  306. package/components/ui/notification-badge/notification-badge.test.tsx +61 -61
  307. package/components/ui/notification-badge/notification-badge.tsx +91 -91
  308. package/components/ui/page-header/index.ts +1 -1
  309. package/components/ui/page-header/page-header.stories.tsx +69 -69
  310. package/components/ui/page-header/page-header.test.tsx +37 -37
  311. package/components/ui/page-header/page-header.tsx +124 -124
  312. package/components/ui/pagination/index.ts +3 -3
  313. package/components/ui/pagination/pagination.mdx +8 -8
  314. package/components/ui/pagination/pagination.stories.tsx +210 -210
  315. package/components/ui/pagination/pagination.test.tsx +63 -63
  316. package/components/ui/pagination/pagination.tsx +140 -140
  317. package/components/ui/pagination/use-pagination.ts +173 -173
  318. package/components/ui/popover/index.ts +1 -1
  319. package/components/ui/popover/popover.mdx +8 -8
  320. package/components/ui/popover/popover.stories.tsx +73 -73
  321. package/components/ui/popover/popover.test.tsx +48 -48
  322. package/components/ui/popover/popover.tsx +54 -54
  323. package/components/ui/progress/index.ts +1 -1
  324. package/components/ui/progress/progress.mdx +8 -8
  325. package/components/ui/progress/progress.stories.tsx +55 -55
  326. package/components/ui/progress/progress.test.tsx +23 -23
  327. package/components/ui/progress/progress.tsx +68 -68
  328. package/components/ui/radio-group/index.ts +1 -1
  329. package/components/ui/radio-group/radio-group.mdx +8 -8
  330. package/components/ui/radio-group/radio-group.stories.tsx +114 -114
  331. package/components/ui/radio-group/radio-group.test.tsx +78 -78
  332. package/components/ui/radio-group/radio-group.tsx +93 -93
  333. package/components/ui/rating/index.ts +1 -1
  334. package/components/ui/rating/rating.mdx +8 -8
  335. package/components/ui/rating/rating.stories.tsx +50 -50
  336. package/components/ui/rating/rating.test.tsx +48 -48
  337. package/components/ui/rating/rating.tsx +145 -145
  338. package/components/ui/resizable/index.ts +1 -1
  339. package/components/ui/resizable/resizable.mdx +8 -8
  340. package/components/ui/resizable/resizable.stories.tsx +88 -88
  341. package/components/ui/resizable/resizable.test.tsx +61 -61
  342. package/components/ui/resizable/resizable.tsx +452 -452
  343. package/components/ui/rich-text-editor/index.ts +7 -7
  344. package/components/ui/rich-text-editor/rich-text-editor.stories.tsx +290 -290
  345. package/components/ui/rich-text-editor/rich-text-editor.test.tsx +86 -86
  346. package/components/ui/rich-text-editor/rich-text-editor.tsx +634 -634
  347. package/components/ui/rich-text-editor/use-rich-text-editor.ts +453 -453
  348. package/components/ui/route-map/index.ts +1 -1
  349. package/components/ui/route-map/route-map.mdx +8 -8
  350. package/components/ui/route-map/route-map.stories.tsx +48 -48
  351. package/components/ui/route-map/route-map.test.tsx +108 -108
  352. package/components/ui/route-map/route-map.tsx +349 -349
  353. package/components/ui/scroll-area/index.ts +1 -1
  354. package/components/ui/scroll-area/scroll-area.mdx +8 -8
  355. package/components/ui/scroll-area/scroll-area.stories.tsx +31 -31
  356. package/components/ui/scroll-area/scroll-area.test.tsx +27 -27
  357. package/components/ui/scroll-area/scroll-area.tsx +70 -70
  358. package/components/ui/search/index.ts +1 -1
  359. package/components/ui/search/search.mdx +8 -8
  360. package/components/ui/search/search.stories.tsx +107 -107
  361. package/components/ui/search/search.test.tsx +67 -67
  362. package/components/ui/search/search.tsx +141 -141
  363. package/components/ui/select/index.ts +1 -1
  364. package/components/ui/select/select.mdx +8 -8
  365. package/components/ui/select/select.stories.tsx +163 -163
  366. package/components/ui/select/select.test.tsx +99 -99
  367. package/components/ui/select/select.tsx +195 -195
  368. package/components/ui/separator/index.ts +1 -1
  369. package/components/ui/separator/separator.mdx +8 -8
  370. package/components/ui/separator/separator.stories.tsx +55 -55
  371. package/components/ui/separator/separator.test.tsx +23 -23
  372. package/components/ui/separator/separator.tsx +39 -39
  373. package/components/ui/sheet/index.ts +1 -1
  374. package/components/ui/sheet/sheet.mdx +8 -8
  375. package/components/ui/sheet/sheet.stories.tsx +93 -93
  376. package/components/ui/sheet/sheet.test.tsx +62 -62
  377. package/components/ui/sheet/sheet.tsx +149 -149
  378. package/components/ui/simple-map/index.ts +1 -1
  379. package/components/ui/simple-map/simple-map.mdx +8 -8
  380. package/components/ui/simple-map/simple-map.stories.tsx +44 -44
  381. package/components/ui/simple-map/simple-map.test.tsx +36 -36
  382. package/components/ui/simple-map/simple-map.tsx +92 -92
  383. package/components/ui/skeleton/index.ts +1 -1
  384. package/components/ui/skeleton/skeleton.mdx +8 -8
  385. package/components/ui/skeleton/skeleton.stories.tsx +36 -36
  386. package/components/ui/skeleton/skeleton.test.tsx +19 -19
  387. package/components/ui/skeleton/skeleton.tsx +25 -25
  388. package/components/ui/slider/index.ts +1 -1
  389. package/components/ui/slider/slider.mdx +8 -8
  390. package/components/ui/slider/slider.stories.tsx +44 -44
  391. package/components/ui/slider/slider.test.tsx +25 -25
  392. package/components/ui/slider/slider.tsx +66 -66
  393. package/components/ui/sonner/index.ts +1 -1
  394. package/components/ui/sonner/sonner.mdx +8 -8
  395. package/components/ui/sonner/sonner.stories.tsx +41 -41
  396. package/components/ui/sonner/sonner.test.tsx +24 -24
  397. package/components/ui/sonner/sonner.tsx +74 -74
  398. package/components/ui/stats-card/stats-card-skeleton.tsx +62 -62
  399. package/components/ui/stats-card/stats-card.mdx +8 -8
  400. package/components/ui/stats-card/stats-card.test.tsx +34 -34
  401. package/components/ui/stats-card/stats-card.tsx +93 -93
  402. package/components/ui/stepper/index.ts +3 -3
  403. package/components/ui/stepper/stepper.mdx +8 -8
  404. package/components/ui/stepper/stepper.stories.tsx +171 -171
  405. package/components/ui/stepper/stepper.test.tsx +47 -47
  406. package/components/ui/stepper/stepper.tsx +190 -190
  407. package/components/ui/stepper/use-stepper.ts +139 -139
  408. package/components/ui/switch/index.ts +1 -1
  409. package/components/ui/switch/switch.mdx +8 -8
  410. package/components/ui/switch/switch.stories.tsx +93 -93
  411. package/components/ui/switch/switch.test.tsx +44 -44
  412. package/components/ui/switch/switch.tsx +70 -70
  413. package/components/ui/table/index.ts +1 -1
  414. package/components/ui/table/table.mdx +8 -8
  415. package/components/ui/table/table.stories.tsx +114 -114
  416. package/components/ui/table/table.test.tsx +43 -43
  417. package/components/ui/table/table.tsx +104 -104
  418. package/components/ui/tabs/index.ts +1 -1
  419. package/components/ui/tabs/tabs.mdx +8 -8
  420. package/components/ui/tabs/tabs.stories.tsx +140 -140
  421. package/components/ui/tabs/tabs.test.tsx +50 -50
  422. package/components/ui/tabs/tabs.tsx +66 -66
  423. package/components/ui/textarea/index.ts +1 -1
  424. package/components/ui/textarea/textarea.mdx +8 -8
  425. package/components/ui/textarea/textarea.stories.tsx +69 -69
  426. package/components/ui/textarea/textarea.test.tsx +41 -41
  427. package/components/ui/textarea/textarea.tsx +61 -61
  428. package/components/ui/timeline/index.ts +1 -1
  429. package/components/ui/timeline/timeline.mdx +8 -8
  430. package/components/ui/timeline/timeline.stories.tsx +97 -97
  431. package/components/ui/timeline/timeline.test.tsx +53 -53
  432. package/components/ui/timeline/timeline.tsx +124 -124
  433. package/components/ui/toggle/index.ts +1 -1
  434. package/components/ui/toggle/toggle.mdx +8 -8
  435. package/components/ui/toggle/toggle.stories.tsx +56 -56
  436. package/components/ui/toggle/toggle.test.tsx +32 -32
  437. package/components/ui/toggle/toggle.tsx +55 -55
  438. package/components/ui/toggle-group/index.ts +1 -1
  439. package/components/ui/toggle-group/toggle-group.mdx +8 -8
  440. package/components/ui/toggle-group/toggle-group.stories.tsx +66 -66
  441. package/components/ui/toggle-group/toggle-group.test.tsx +47 -47
  442. package/components/ui/toggle-group/toggle-group.tsx +79 -79
  443. package/components/ui/tooltip/index.ts +1 -1
  444. package/components/ui/tooltip/tooltip.mdx +8 -8
  445. package/components/ui/tooltip/tooltip.stories.tsx +83 -83
  446. package/components/ui/tooltip/tooltip.test.tsx +39 -39
  447. package/components/ui/tooltip/tooltip.tsx +69 -69
  448. package/components/ui/tree-view/index.ts +4 -4
  449. package/components/ui/tree-view/tree-view.mdx +8 -8
  450. package/components/ui/tree-view/tree-view.stories.tsx +154 -154
  451. package/components/ui/tree-view/tree-view.test.tsx +58 -58
  452. package/components/ui/tree-view/tree-view.tsx +171 -171
  453. package/components/ui/tree-view/use-tree-view.ts +237 -237
  454. package/contexts/ApiKeyContext.test.tsx +26 -26
  455. package/contexts/ApiKeyContext.tsx +196 -196
  456. package/contexts/AssistenteContext.test.tsx +17 -17
  457. package/contexts/AssistenteContext.tsx +113 -113
  458. package/contexts/AuthContext.tsx +118 -118
  459. package/contexts/BrandColorsContext.test.tsx +21 -21
  460. package/contexts/BrandColorsContext.tsx +251 -251
  461. package/contexts/LanguageContext.test.tsx +121 -121
  462. package/contexts/LanguageContext.tsx +251 -251
  463. package/contexts/LayoutContext.test.tsx +29 -29
  464. package/contexts/LayoutContext.tsx +140 -140
  465. package/contexts/ThemeContext.test.tsx +38 -38
  466. package/contexts/ThemeContext.tsx +111 -111
  467. package/contexts/index.ts +8 -8
  468. package/contexts/theme-data.ts +340 -340
  469. package/dist/{AssistantChart-BAx9VQvb.cjs → AssistantChart-Bdd44uBn.cjs} +388 -127
  470. package/dist/{AssistantChart-CVko2A1W.js → AssistantChart-CFhDdGyU.js} +391 -130
  471. package/dist/AssistantChart-COGiOV-g.cjs +3541 -0
  472. package/dist/AssistantChart-CWX1OWNM.js +3373 -0
  473. package/dist/{AssistantChart-CVzmmhx4.js → AssistantChart-C_hwFRRr.js} +4 -4
  474. package/dist/{AssistantChart-BAudAfne.cjs → AssistantChart-CldVCVDe.cjs} +5 -5
  475. package/dist/{AssistantChart-BP8upjMk.js → AssistantChart-Cu3m7RBo.js} +5 -5
  476. package/dist/AssistantChart-CxGjH7Qk.js +3477 -0
  477. package/dist/AssistantChart-DIpshm3i.js +4784 -0
  478. package/dist/AssistantChart-D_PTeu8P.cjs +3503 -0
  479. package/dist/{AssistantChart-9w31gdAb.cjs → AssistantChart-DoZCyS5r.cjs} +4 -4
  480. package/dist/AssistantChart-zjsy2GaZ.cjs +4810 -0
  481. package/dist/AudioPlayer-9psiEucT.cjs +1282 -0
  482. package/dist/AudioPlayer-B1lt5cPl.cjs +989 -0
  483. package/dist/AudioPlayer-BZ7bibzU.cjs +982 -0
  484. package/dist/AudioPlayer-BpRPS4-1.cjs +1277 -0
  485. package/dist/AudioPlayer-C12BjQBV.cjs +997 -0
  486. package/dist/{AudioPlayer-1ypwE2Wh.cjs → AudioPlayer-CFeV8t-5.cjs} +1 -1
  487. package/dist/{AudioPlayer-DuKXrCfy.js → AudioPlayer-CGRUtUdN.js} +1 -1
  488. package/dist/AudioPlayer-Coly3q5R.js +1278 -0
  489. package/dist/AudioPlayer-CySJIyvL.js +937 -0
  490. package/dist/AudioPlayer-DMcG_c7L.js +990 -0
  491. package/dist/AudioPlayer-DcFKRJE_.js +998 -0
  492. package/dist/AudioPlayer-Dp2bD1Gk.js +1278 -0
  493. package/dist/AudioPlayer-IAU5q5T1.cjs +936 -0
  494. package/dist/AudioPlayer-e8LfNoqO.js +983 -0
  495. package/dist/BrandColorsContext-565dDHd5.js +660 -0
  496. package/dist/BrandColorsContext-BcJbtkqn.cjs +659 -0
  497. package/dist/BrandColorsContext-DZT7JjeD.js +659 -0
  498. package/dist/BrandColorsContext-awnBCmC4.cjs +666 -0
  499. package/dist/{xertica-assistant-Qp3ydksa.cjs → CodeBlock-7TTgmdGG.cjs} +263 -51
  500. package/dist/{xertica-assistant-gnCJdcZY.js → CodeBlock-BeSt1h5P.js} +219 -7
  501. package/dist/CodeBlock-BgfYL_rD.cjs +2094 -0
  502. package/dist/CodeBlock-BlcqlA9M.cjs +2094 -0
  503. package/dist/CodeBlock-Bnmeu5ez.cjs +2094 -0
  504. package/dist/CodeBlock-BtfPlbAI.js +2078 -0
  505. package/dist/CodeBlock-CIySIuYr.js +2078 -0
  506. package/dist/CodeBlock-CuPtUM-7.cjs +2094 -0
  507. package/dist/CodeBlock-D6ffWXgc.js +2078 -0
  508. package/dist/CodeBlock-D8dcwbit.cjs +2094 -0
  509. package/dist/CodeBlock-DMZrFnlw.cjs +2094 -0
  510. package/dist/CodeBlock-DYkTfR0f.js +221 -0
  511. package/dist/CodeBlock-DlBehYN8.js +2078 -0
  512. package/dist/CodeBlock-DnYNI8rQ.js +2078 -0
  513. package/dist/CodeBlock-DvKWbSnE.cjs +2094 -0
  514. package/dist/CodeBlock-DwMCfkFY.js +2078 -0
  515. package/dist/CodeBlock-Dy6CNYyj.js +2078 -0
  516. package/dist/CodeBlock-EOvp9cVu.cjs +223 -0
  517. package/dist/CodeBlock-U1pPOQI7.cjs +2094 -0
  518. package/dist/CodeBlock-f_GpNhEB.js +2078 -0
  519. package/dist/CodeBlock-oB6u8nI1.js +2078 -0
  520. package/dist/CodeBlock-tZC31B73.cjs +2094 -0
  521. package/dist/CustomTooltipContent-BhdIeBEg.cjs +54 -0
  522. package/dist/CustomTooltipContent-CNbVB2NS.js +33 -0
  523. package/dist/FeatureCard-BZ4CYxFf.cjs +497 -0
  524. package/dist/FeatureCard-CxC-7C-C.cjs +300 -0
  525. package/dist/FeatureCard-DNycVGwT.js +485 -0
  526. package/dist/FeatureCard-DbHWCb4E.js +301 -0
  527. package/dist/FeatureCardSkeleton-DZqc96mt.js +27 -0
  528. package/dist/FeatureCardSkeleton-pTa0YNKP.cjs +29 -0
  529. package/dist/ImageWithFallback-CGtidP6B.cjs +4542 -0
  530. package/dist/ImageWithFallback-lsg3pdFg.js +4508 -0
  531. package/dist/{LanguageContext-DvUt5jBg.cjs → LanguageContext-B_KFTCzT.cjs} +2 -2
  532. package/dist/{LanguageContext-BwhwC3G2.js → LanguageContext-CS14yCpi.js} +2 -2
  533. package/dist/LanguageSelector-B5YfbHra.js +231 -0
  534. package/dist/LanguageSelector-D6uacAIM.cjs +230 -0
  535. package/dist/LayoutContext-B45-e9DI.cjs +93 -0
  536. package/dist/LayoutContext-BAql6ZRY.js +97 -0
  537. package/dist/LayoutContext-BEq_-n98.cjs +96 -0
  538. package/dist/LayoutContext-Bav3UMEA.js +94 -0
  539. package/dist/LayoutContext-BvK-ggDa.cjs +96 -0
  540. package/dist/LayoutContext-DNl1xSoX.js +92 -0
  541. package/dist/{ThemeContext-ept8jhXI.js → ThemeContext-BWq9ACPo.js} +8 -13
  542. package/dist/ThemeContext-BXjrgUjW.js +1917 -0
  543. package/dist/{ThemeContext-Bo-W2WZH.js → ThemeContext-BgclCB35.js} +3 -3
  544. package/dist/{ThemeContext-CP3a0jxy.cjs → ThemeContext-Bmod0Cg2.cjs} +8 -13
  545. package/dist/ThemeContext-BoH4NLfN.js +734 -0
  546. package/dist/{ThemeContext-BbBNoFTG.js → ThemeContext-C2EwAPDt.js} +2 -2
  547. package/dist/{ThemeContext-U4dEYc6C.cjs → ThemeContext-CGk3KK0k.cjs} +1 -8
  548. package/dist/ThemeContext-CMD3z2Dz.cjs +1930 -0
  549. package/dist/{ThemeContext-D3LzacmG.js → ThemeContext-CQSo4Iwc.js} +1 -8
  550. package/dist/{ThemeContext-BblcjQup.cjs → ThemeContext-DQUOeziy.cjs} +3 -3
  551. package/dist/ThemeContext-j5aGtPky.cjs +1924 -0
  552. package/dist/ThemeContext-r69W20Xg.cjs +733 -0
  553. package/dist/{ThemeContext-Cmr8Ex8H.cjs → ThemeContext-vTjumZeM.cjs} +2 -2
  554. package/dist/ThemeContext-x_F2zsnv.js +1923 -0
  555. package/dist/{VerifyEmailPage-BRSP-Pwt.cjs → VerifyEmailPage--1Vurewl.cjs} +3 -3
  556. package/dist/{VerifyEmailPage-BE-L9mB7.js → VerifyEmailPage-1WwWczAn.js} +12 -22
  557. package/dist/{VerifyEmailPage-DF2ilhum.cjs → VerifyEmailPage-B4peJjAT.cjs} +356 -334
  558. package/dist/{VerifyEmailPage-CR7kb5df.cjs → VerifyEmailPage-BComraR7.cjs} +12 -22
  559. package/dist/{VerifyEmailPage-BiRm7Nh4.cjs → VerifyEmailPage-By3Jf__L.cjs} +348 -329
  560. package/dist/VerifyEmailPage-ByerOcm4.cjs +3232 -0
  561. package/dist/{VerifyEmailPage-CbgjOF0v.js → VerifyEmailPage-C0c2e5n0.js} +7 -7
  562. package/dist/{VerifyEmailPage-EhudUdqF.js → VerifyEmailPage-C5TNQTBa.js} +355 -343
  563. package/dist/{VerifyEmailPage-Dt7zgA4w.cjs → VerifyEmailPage-CFLMls1p.cjs} +4 -4
  564. package/dist/{VerifyEmailPage-vYHbYK3q.js → VerifyEmailPage-CJLz3jrn.js} +347 -338
  565. package/dist/VerifyEmailPage-COiyNl1y.js +2825 -0
  566. package/dist/{VerifyEmailPage-DMBh4NM9.cjs → VerifyEmailPage-CYXtbKi3.cjs} +1 -1
  567. package/dist/{VerifyEmailPage-DTtFfC-J.js → VerifyEmailPage-CgMxRb4z.js} +3 -3
  568. package/dist/VerifyEmailPage-CqKsR2v8.js +2827 -0
  569. package/dist/{VerifyEmailPage-Bae2cBXT.cjs → VerifyEmailPage-Cwi3kbol.cjs} +7 -7
  570. package/dist/{VerifyEmailPage-BIBOKV7Z.js → VerifyEmailPage-DSBMRHtl.js} +36 -41
  571. package/dist/{VerifyEmailPage-hdB8JQGv.cjs → VerifyEmailPage-De6bQjrz.cjs} +36 -41
  572. package/dist/VerifyEmailPage-DgIid028.js +3223 -0
  573. package/dist/VerifyEmailPage-DjQKRlUS.cjs +2824 -0
  574. package/dist/{VerifyEmailPage-CdYPSJoO.js → VerifyEmailPage-DvMLZgFt.js} +1 -1
  575. package/dist/{VerifyEmailPage-C_ihbcth.js → VerifyEmailPage-MTD7AG1Z.js} +4 -4
  576. package/dist/{VerifyEmailPage-Bvfv8HVQ.js → VerifyEmailPage-RrUApqBN.js} +3 -3
  577. package/dist/{VerifyEmailPage-D-FRj5TU.cjs → VerifyEmailPage-VoMI7MYH.cjs} +3 -3
  578. package/dist/VerifyEmailPage-s-1X3LDJ.cjs +2826 -0
  579. package/dist/XerticaOrbe-KL1RBHzw.cjs +1354 -0
  580. package/dist/XerticaOrbe-Uk2JML1-.cjs +1927 -0
  581. package/dist/XerticaOrbe-jA5T2iOk.js +1925 -0
  582. package/dist/XerticaOrbe-zwS1p2a8.js +1355 -0
  583. package/dist/XerticaProvider-6btlAlzc.js +17 -0
  584. package/dist/{XerticaProvider-siSt9uG2.js → XerticaProvider-B7EVH-NF.js} +2 -2
  585. package/dist/{XerticaProvider-CjQAQPcn.cjs → XerticaProvider-BIrqfZ-i.cjs} +11 -8
  586. package/dist/XerticaProvider-BNoNOxQ5.cjs +16 -0
  587. package/dist/{XerticaProvider-CWgby5mY.js → XerticaProvider-BSyFrmC0.js} +1 -1
  588. package/dist/XerticaProvider-BlY2limY.cjs +38 -0
  589. package/dist/{XerticaProvider-CWs6EwNa.js → XerticaProvider-C1DKnvLh.js} +4 -4
  590. package/dist/{XerticaProvider-AbWlr7Af.cjs → XerticaProvider-CBGc4EMA.cjs} +4 -4
  591. package/dist/{XerticaProvider-BITjgC5p.js → XerticaProvider-CEoWMTxu.js} +2 -2
  592. package/dist/{XerticaProvider-AChwphCO.cjs → XerticaProvider-CiNKjMx1.cjs} +1 -1
  593. package/dist/{XerticaProvider-By8q3Roe.cjs → XerticaProvider-CllrbMEJ.cjs} +2 -2
  594. package/dist/{XerticaProvider-B8CaV7xu.cjs → XerticaProvider-D-yNhF94.cjs} +1 -1
  595. package/dist/XerticaProvider-DDuiIcKo.js +39 -0
  596. package/dist/{XerticaProvider-D5lLumH-.js → XerticaProvider-DUOJg9iX.js} +10 -10
  597. package/dist/{XerticaProvider-DQtvJU7m.js → XerticaProvider-DYq4JWtg.js} +1 -1
  598. package/dist/{XerticaProvider-qQUDop71.cjs → XerticaProvider-Dl_b72_l.cjs} +11 -8
  599. package/dist/{XerticaProvider-CUYJZc32.js → XerticaProvider-Dt5HEzbQ.js} +10 -10
  600. package/dist/{XerticaProvider-CW9hpCdF.cjs → XerticaProvider-ET0ihewn.cjs} +2 -2
  601. package/dist/XerticaProvider-cI9hSs27.cjs +38 -0
  602. package/dist/XerticaProvider-hSwhNQex.js +39 -0
  603. package/dist/{XerticaXLogo-8TTzBjHw.cjs → XerticaXLogo-B2svDGZh.cjs} +1 -1
  604. package/dist/{XerticaXLogo-ChryA6xj.js → XerticaXLogo-B7xQ5dhi.js} +1 -1
  605. package/dist/{XerticaXLogo-CziKMQil.cjs → XerticaXLogo-CQUUjXoH.cjs} +8 -8
  606. package/dist/{XerticaXLogo-DfUvz-lD.js → XerticaXLogo-Cmsp-Eey.js} +9 -9
  607. package/dist/{XerticaXLogo-CFuIlYFH.js → XerticaXLogo-CowGv7BC.js} +1 -1
  608. package/dist/{XerticaXLogo-DHz5SugF.js → XerticaXLogo-DZbo4vOE.js} +12 -12
  609. package/dist/{XerticaXLogo-kslQ8Tk_.cjs → XerticaXLogo-Zw2B276b.cjs} +1 -1
  610. package/dist/{XerticaXLogo-CU-U-GP4.cjs → XerticaXLogo-bvZSgwGF.cjs} +13 -7
  611. package/dist/{XerticaXLogo-BWaag64t.js → XerticaXLogo-mqjoBiLI.js} +12 -12
  612. package/dist/{XerticaXLogo-DTee_y8X.cjs → XerticaXLogo-uQgwns_E.cjs} +13 -7
  613. package/dist/alert-dialog-BOje--vD.js +847 -0
  614. package/dist/alert-dialog-BtEuQqrg.cjs +870 -0
  615. package/dist/{alert-dialog-yckpaOpy.cjs → alert-dialog-DSKByiKZ.cjs} +3 -3
  616. package/dist/alert-dialog-DhwPioBa.cjs +885 -0
  617. package/dist/alert-dialog-DqlRW_An.js +831 -0
  618. package/dist/{alert-dialog-iDe5VE5o.js → alert-dialog-s-vmNkJ_.js} +3 -3
  619. package/dist/assistant.cjs.js +8 -4
  620. package/dist/assistant.es.js +5 -11
  621. package/dist/avatar-3kO2Anrp.js +54 -0
  622. package/dist/avatar-BCM7YQRC.cjs +77 -0
  623. package/dist/blocks.cjs.js +9 -4
  624. package/dist/blocks.es.js +2 -16
  625. package/dist/brand.cjs.js +10 -5
  626. package/dist/brand.es.js +3 -11
  627. package/dist/breadcrumb-BKtHF4gk.cjs +98 -0
  628. package/dist/breadcrumb-CqJ7bHY5.js +161 -0
  629. package/dist/breadcrumb-ifNsA7Zl.js +90 -0
  630. package/dist/breadcrumb-m9Hb2_XN.cjs +177 -0
  631. package/dist/button-0BlA47It.cjs +85 -0
  632. package/dist/button-DZHzN1Gd.js +62 -0
  633. package/dist/cli.js +391 -66
  634. package/dist/components/assistant/xertica-assistant/hooks/index.d.ts +6 -0
  635. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-conversations.d.ts +21 -0
  636. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-messages.d.ts +49 -0
  637. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-suggestions.d.ts +16 -0
  638. package/dist/components/blocks/audio-player/AudioPlayer.d.ts +35 -0
  639. package/dist/components/blocks/audio-player/index.d.ts +1 -0
  640. package/dist/components/blocks/document-editor/DocumentEditor.d.ts +26 -0
  641. package/dist/components/blocks/document-editor/index.d.ts +1 -0
  642. package/dist/components/blocks/podcast-player/PodcastPlayer.d.ts +41 -0
  643. package/dist/components/blocks/podcast-player/index.d.ts +1 -0
  644. package/dist/components/ui/chart/parts/chart-dashboard.d.ts +113 -0
  645. package/dist/components/ui/chart/parts/chart-metric.d.ts +118 -0
  646. package/dist/components/ui/chart/parts/chart-primitives.d.ts +101 -0
  647. package/dist/components/ui/chart/parts/chart-shared.d.ts +20 -0
  648. package/dist/components/ui/chart/parts/chart-utils.d.ts +12 -0
  649. package/dist/components/ui/chart/parts/index.d.ts +5 -0
  650. package/dist/dropdown-menu-BDB5CmQs.cjs +247 -0
  651. package/dist/dropdown-menu-BMcykFDf.cjs +225 -0
  652. package/dist/dropdown-menu-DQidbKBD.js +231 -0
  653. package/dist/dropdown-menu-Dn_eV2Xb.js +190 -0
  654. package/dist/google-maps-loader-BCe58h9D.js +308 -0
  655. package/dist/google-maps-loader-BFWp6VPd.js +287 -0
  656. package/dist/google-maps-loader-BKcdgFbu.cjs +312 -0
  657. package/dist/{google-maps-loader-t2IlYBzw.js → google-maps-loader-CTYySAun.js} +4 -0
  658. package/dist/google-maps-loader-CumCNXeG.js +312 -0
  659. package/dist/{google-maps-loader-BqsYL48U.cjs → google-maps-loader-Y-QkD-Li.cjs} +5 -0
  660. package/dist/google-maps-loader-casMyxlo.cjs +316 -0
  661. package/dist/google-maps-loader-eS3uQ5TA.cjs +287 -0
  662. package/dist/header-Cgy6vYPk.cjs +731 -0
  663. package/dist/header-DRlT4jgI.js +715 -0
  664. package/dist/header-Dux00SI4.cjs +731 -0
  665. package/dist/header-EkGKXPsD.js +715 -0
  666. package/dist/header-WfEywpyc.cjs +731 -0
  667. package/dist/header-tifNQn2U.js +715 -0
  668. package/dist/hooks.cjs.js +12 -8
  669. package/dist/hooks.es.js +10 -27
  670. package/dist/index-9GWd0qxq.cjs +12 -0
  671. package/dist/index-BabBx2pa.js +6 -0
  672. package/dist/index-BhapVLVj.js +8 -0
  673. package/dist/{index-D3RLKRAs.cjs → index-COtD8bRW.cjs} +1 -1
  674. package/dist/index-D6fxYEY8.cjs +7 -0
  675. package/dist/index-DAIp0_HK.js +8 -0
  676. package/dist/index-DW5tYe26.js +8 -0
  677. package/dist/index-GA__GvnG.cjs +7 -0
  678. package/dist/index.cjs.js +37 -32
  679. package/dist/index.es.js +30 -363
  680. package/dist/index.umd.js +1043 -470
  681. package/dist/input-2R4loU86.js +127 -0
  682. package/dist/input-C_UiS2Py.cjs +152 -0
  683. package/dist/input-DWANSKGb.cjs +145 -0
  684. package/dist/input-cc-PTD4R.js +123 -0
  685. package/dist/layout.cjs.js +10 -6
  686. package/dist/layout.es.js +7 -9
  687. package/dist/media.cjs.js +8 -3
  688. package/dist/media.es.js +1 -6
  689. package/dist/pages.cjs.js +8 -3
  690. package/dist/pages.es.js +1 -11
  691. package/dist/progress-C7Lti5wo.js +80 -0
  692. package/dist/progress-Cqwxbqs1.cjs +103 -0
  693. package/dist/progress-DPtzoVV8.js +175 -0
  694. package/dist/progress-EeaoqqUs.cjs +191 -0
  695. package/dist/rich-text-editor-0mraWT5y.cjs +2376 -0
  696. package/dist/rich-text-editor-B-IkcPD0.js +2874 -0
  697. package/dist/rich-text-editor-B6jMRLzk.cjs +1939 -0
  698. package/dist/rich-text-editor-B8_oYcIR.js +1730 -0
  699. package/dist/rich-text-editor-B9UbSXNb.js +1203 -0
  700. package/dist/rich-text-editor-BYuRBNBU.js +2373 -0
  701. package/dist/rich-text-editor-Bb9pySTs.cjs +2374 -0
  702. package/dist/rich-text-editor-BcL6L3cm.cjs +2374 -0
  703. package/dist/rich-text-editor-BoVZYtTs.cjs +2391 -0
  704. package/dist/rich-text-editor-Bp3zQqMC.js +2954 -0
  705. package/dist/rich-text-editor-CMgSN_w2.js +1189 -0
  706. package/dist/rich-text-editor-CPV1lEPH.cjs +1748 -0
  707. package/dist/rich-text-editor-CeucBdIv.cjs +2971 -0
  708. package/dist/rich-text-editor-CoKqbCtu.cjs +1799 -0
  709. package/dist/rich-text-editor-Cw56T_mB.js +2356 -0
  710. package/dist/rich-text-editor-Cyt8qs2b.js +1921 -0
  711. package/dist/rich-text-editor-D6H84OcX.cjs +1220 -0
  712. package/dist/rich-text-editor-D76gD-QI.js +2328 -0
  713. package/dist/rich-text-editor-DKkokOnA.js +1781 -0
  714. package/dist/rich-text-editor-DNsdpN64.cjs +2359 -0
  715. package/dist/rich-text-editor-DfG8bCyY.js +2358 -0
  716. package/dist/rich-text-editor-DqLICivI.js +2832 -0
  717. package/dist/rich-text-editor-DxO1Hz3a.cjs +2903 -0
  718. package/dist/rich-text-editor-Dxjw31Z4.js +2341 -0
  719. package/dist/rich-text-editor-DzP0Epmb.js +2356 -0
  720. package/dist/rich-text-editor-bRkNoeZY.cjs +2891 -0
  721. package/dist/rich-text-editor-lyYE2ZG5.cjs +1207 -0
  722. package/dist/rich-text-editor-skplNlBM.cjs +2345 -0
  723. package/dist/select-Bkbr0f-Z.cjs +162 -0
  724. package/dist/select-CH6v_KcQ.cjs +161 -0
  725. package/dist/select-CvIVdX2n.js +145 -0
  726. package/dist/select-D-xvCZK2.js +130 -0
  727. package/dist/{sidebar-CplprZpM.js → sidebar-3XyzjVBw.js} +40 -49
  728. package/dist/{sidebar-OTO_up7Z.js → sidebar-B6SlKZYN.js} +40 -49
  729. package/dist/{sidebar-CmvwjnVb.js → sidebar-BViy8Eeu.js} +17 -9
  730. package/dist/{sidebar-Dz7bd3zP.js → sidebar-BbVIQvlP.js} +1 -1
  731. package/dist/{sidebar-CVUGHOS_.cjs → sidebar-BxGXsDAd.cjs} +16 -8
  732. package/dist/sidebar-CK_0ZQHj.cjs +803 -0
  733. package/dist/{sidebar-KIS0C2JH.js → sidebar-CRMiBtAi.js} +1 -1
  734. package/dist/sidebar-CUuOvYhK.js +787 -0
  735. package/dist/{sidebar-zowjejT2.cjs → sidebar-CZ2mWaMM.cjs} +1 -1
  736. package/dist/{sidebar-CA6_ek3f.js → sidebar-CrQDDdcz.js} +24 -33
  737. package/dist/{sidebar-BvF5I2Ue.cjs → sidebar-DAaY8bRU.cjs} +24 -33
  738. package/dist/sidebar-DQj1z3jG.cjs +758 -0
  739. package/dist/sidebar-Djn5syhi.cjs +786 -0
  740. package/dist/{sidebar-B3EYhli0.cjs → sidebar-DyYvgyBj.cjs} +41 -46
  741. package/dist/sidebar-LluMXfam.js +759 -0
  742. package/dist/sidebar-_rT7rBMk.js +787 -0
  743. package/dist/{sidebar-B9NR0lCe.cjs → sidebar-nzPoVHBQ.cjs} +41 -46
  744. package/dist/{sidebar-C5B_LHek.cjs → sidebar-q7P2Godd.cjs} +1 -1
  745. package/dist/skeleton-DjiHerJn.cjs +87 -0
  746. package/dist/skeleton-DtR5tkYe.js +78 -0
  747. package/dist/slider-B00b9SVK.cjs +78 -0
  748. package/dist/slider-Bc5Hd0y1.js +56 -0
  749. package/dist/slider-DQCNUUMj.js +56 -0
  750. package/dist/slider-N7hFFj6X.cjs +73 -0
  751. package/dist/sonner-B-jWlik1.cjs +68 -0
  752. package/dist/sonner-C9tiqj4f.js +47 -0
  753. package/dist/tooltip-D8n9UYoU.cjs +72 -0
  754. package/dist/tooltip-Ded96neP.cjs +137 -0
  755. package/dist/tooltip-HDOoD2-0.js +120 -0
  756. package/dist/tooltip-RtbSmPYJ.js +48 -0
  757. package/dist/ui.cjs.js +23 -18
  758. package/dist/ui.es.js +16 -303
  759. package/dist/use-audio-player-B31J-aqh.cjs +187 -0
  760. package/dist/use-audio-player-B78fd2ct.js +188 -0
  761. package/dist/use-audio-player-BkmEmj8Q.js +185 -0
  762. package/dist/use-audio-player-CLFTWFW1.cjs +184 -0
  763. package/dist/use-audio-player-CLLn00I6.js +188 -0
  764. package/dist/use-audio-player-DGvhPrgR.cjs +190 -0
  765. package/dist/{use-audio-player-Dn1NR9xN.cjs → use-audio-player-NKsWyjWu.cjs} +7 -3
  766. package/dist/{use-audio-player-Bkh23vQ3.js → use-audio-player-nv8ZSGa1.js} +7 -3
  767. package/dist/use-file-upload-BcjEo2S5.js +404 -0
  768. package/dist/use-file-upload-CRJR68Tj.cjs +403 -0
  769. package/dist/use-mobile-B0hNy_Y6.cjs +4303 -0
  770. package/dist/use-mobile-BXuYROXM.js +4202 -0
  771. package/dist/use-mobile-Bbd51ASU.cjs +4392 -0
  772. package/dist/use-mobile-BdXTRb0Z.cjs +51 -0
  773. package/dist/use-mobile-Bk6CX-TC.js +4359 -0
  774. package/dist/use-mobile-BvYdisLP.js +4202 -0
  775. package/dist/use-mobile-BzuxjzNX.cjs +4392 -0
  776. package/dist/use-mobile-CG2-SdXV.cjs +4235 -0
  777. package/dist/use-mobile-CKb5pqTs.js +4269 -0
  778. package/dist/use-mobile-CYuAuGDl.js +4202 -0
  779. package/dist/use-mobile-CaENcqm-.js +4508 -0
  780. package/dist/use-mobile-CbrYgJGJ.js +4203 -0
  781. package/dist/use-mobile-Cd4xPrKq.cjs +46 -0
  782. package/dist/use-mobile-Ce2cBAQe.js +29 -0
  783. package/dist/use-mobile-DMOvImGQ.cjs +4542 -0
  784. package/dist/use-mobile-DRB3BQgD.cjs +4235 -0
  785. package/dist/use-mobile-DZvv7QMR.js +4359 -0
  786. package/dist/use-mobile-DdI_TXam.cjs +4235 -0
  787. package/dist/use-mobile-DlceKf8a.js +4359 -0
  788. package/dist/use-mobile-DsOnow1o.cjs +4236 -0
  789. package/dist/use-mobile-Kcj6jSnK.cjs +4392 -0
  790. package/dist/use-mobile-bnKcua_i.js +4202 -0
  791. package/dist/use-mobile-j4w2Jrf1.js +30 -0
  792. package/dist/use-mobile-ncXBeE2z.cjs +4235 -0
  793. package/dist/use-rich-text-editor-DjiddBGv.js +282 -0
  794. package/dist/use-rich-text-editor-lpeswbCs.cjs +281 -0
  795. package/dist/xertica-assistant-B687qEPU.js +2165 -0
  796. package/dist/xertica-assistant-BdiZag0h.js +2187 -0
  797. package/dist/xertica-assistant-CrgTb6Hs.cjs +2155 -0
  798. package/dist/xertica-assistant-DCsnQyi5.js +2156 -0
  799. package/dist/xertica-assistant-DUBpmEgo.cjs +2186 -0
  800. package/dist/{xertica-assistant-Bj3vBCq_.cjs → xertica-assistant-V_IdW4WF.cjs} +27 -9
  801. package/dist/{xertica-assistant-BMqdyRVi.js → xertica-assistant-ciJaWqm1.js} +28 -10
  802. package/dist/{xertica-assistant-B1IaHXnB.cjs → xertica-assistant-dyP7KHM5.cjs} +533 -392
  803. package/dist/xertica-assistant-sOHwTgIP.cjs +2172 -0
  804. package/dist/{xertica-assistant-DPsESB6t.js → xertica-assistant-yX1CFBBo.js} +535 -394
  805. package/dist/xertica-ui.css +2 -2
  806. package/docs/ai-usage.md +195 -195
  807. package/docs/components/accordion.md +109 -109
  808. package/docs/components/alert-dialog.md +127 -127
  809. package/docs/components/alert.md +106 -106
  810. package/docs/components/aspect-ratio.md +58 -58
  811. package/docs/components/assistant-chart.md +47 -47
  812. package/docs/components/assistant.md +2 -0
  813. package/docs/components/audio-player.md +167 -167
  814. package/docs/components/avatar.md +101 -101
  815. package/docs/components/badge.md +84 -84
  816. package/docs/components/breadcrumb.md +104 -104
  817. package/docs/components/button.md +156 -156
  818. package/docs/components/calendar.md +141 -141
  819. package/docs/components/card.md +245 -245
  820. package/docs/components/carousel.md +100 -100
  821. package/docs/components/chart.md +638 -638
  822. package/docs/components/checkbox.md +88 -88
  823. package/docs/components/code-block.md +105 -105
  824. package/docs/components/collapsible.md +86 -86
  825. package/docs/components/command.md +113 -113
  826. package/docs/components/context-menu.md +81 -81
  827. package/docs/components/dialog.md +198 -198
  828. package/docs/components/drawer.md +105 -105
  829. package/docs/components/dropdown-menu.md +127 -127
  830. package/docs/components/empty.md +127 -127
  831. package/docs/components/error-boundary.md +191 -191
  832. package/docs/components/file-upload.md +189 -189
  833. package/docs/components/floating-media-wrapper.md +63 -63
  834. package/docs/components/form.md +177 -177
  835. package/docs/components/formatted-document.md +105 -105
  836. package/docs/components/google-maps-loader.md +44 -44
  837. package/docs/components/header.md +177 -177
  838. package/docs/components/hover-card.md +86 -86
  839. package/docs/components/image-with-fallback.md +107 -107
  840. package/docs/components/input-otp.md +95 -95
  841. package/docs/components/input.md +130 -130
  842. package/docs/components/label.md +69 -69
  843. package/docs/components/language-selector.md +172 -172
  844. package/docs/components/map-layers.md +138 -138
  845. package/docs/components/map.md +84 -84
  846. package/docs/components/markdown-message.md +47 -47
  847. package/docs/components/menubar.md +89 -89
  848. package/docs/components/modern-chat-input.md +164 -164
  849. package/docs/components/navigation-menu.md +83 -83
  850. package/docs/components/notification-badge.md +78 -78
  851. package/docs/components/page-header.md +93 -93
  852. package/docs/components/pages.md +309 -309
  853. package/docs/components/pagination.md +334 -334
  854. package/docs/components/popover.md +116 -116
  855. package/docs/components/progress.md +103 -103
  856. package/docs/components/radio-group.md +133 -133
  857. package/docs/components/rating.md +77 -77
  858. package/docs/components/resizable.md +84 -84
  859. package/docs/components/rich-text-editor.md +255 -255
  860. package/docs/components/route-map.md +124 -124
  861. package/docs/components/scroll-area.md +58 -58
  862. package/docs/components/search.md +87 -87
  863. package/docs/components/select.md +144 -144
  864. package/docs/components/separator.md +58 -58
  865. package/docs/components/sheet.md +122 -122
  866. package/docs/components/sidebar.md +314 -314
  867. package/docs/components/simple-map.md +51 -51
  868. package/docs/components/skeleton.md +99 -99
  869. package/docs/components/slider.md +84 -84
  870. package/docs/components/sonner.md +115 -115
  871. package/docs/components/stats-card.md +120 -120
  872. package/docs/components/stepper.md +268 -268
  873. package/docs/components/switch.md +106 -106
  874. package/docs/components/table.md +138 -138
  875. package/docs/components/tabs.md +117 -117
  876. package/docs/components/textarea.md +86 -86
  877. package/docs/components/theme-toggle.md +73 -73
  878. package/docs/components/timeline.md +121 -121
  879. package/docs/components/toggle-group.md +68 -68
  880. package/docs/components/toggle.md +62 -62
  881. package/docs/components/tooltip.md +116 -116
  882. package/docs/components/tree-view.md +238 -238
  883. package/docs/components/use-mobile.md +96 -96
  884. package/docs/components/video-player.md +68 -68
  885. package/docs/components/xertica-logo.md +36 -36
  886. package/docs/components/xertica-orbe.md +35 -35
  887. package/docs/components/xertica-provider.md +65 -65
  888. package/docs/components/xertica-xlogo.md +35 -35
  889. package/docs/decision-tree.md +293 -293
  890. package/docs/form-sizing.md +162 -162
  891. package/docs/getting-started.md +24 -12
  892. package/docs/i18n.md +476 -476
  893. package/docs/installation.md +267 -267
  894. package/docs/layout.md +143 -143
  895. package/docs/patterns/analytics.md +194 -194
  896. package/docs/patterns/crud.md +149 -149
  897. package/docs/patterns/dashboard.md +138 -138
  898. package/docs/patterns/detail-page.md +296 -296
  899. package/docs/patterns/form.md +241 -241
  900. package/docs/patterns/login.md +156 -156
  901. package/docs/patterns/settings.md +368 -368
  902. package/docs/patterns/wizard.md +213 -213
  903. package/hooks/useTheme.test.tsx +16 -16
  904. package/hooks/useTheme.ts +4 -4
  905. package/imports/Podcast.tsx +540 -540
  906. package/imports/XerticaAi.tsx +46 -46
  907. package/imports/XerticaX.tsx +15 -15
  908. package/imports/svg-aueiaqngck.ts +20 -20
  909. package/imports/svg-v9krss1ozd.ts +23 -23
  910. package/imports/svg-vhrdofe3qe.ts +6 -6
  911. package/llms-compact.txt +2 -1
  912. package/llms.txt +2 -1
  913. package/mcp/resources.json +22 -22
  914. package/mcp/tools.json +35 -35
  915. package/package.json +10 -4
  916. package/scripts/ai-validator.ts +91 -91
  917. package/scripts/cleanup-case-dupes.ts +62 -62
  918. package/scripts/generate-ai-manifests.ts +107 -107
  919. package/styles/globals.css +13 -13
  920. package/styles/xertica/app-overrides/chat.css +61 -61
  921. package/styles/xertica/app-overrides/scrollbar.css +33 -33
  922. package/styles/xertica/base.css +84 -71
  923. package/styles/xertica/integrations/google-maps.css +76 -76
  924. package/styles/xertica/integrations/sonner.css +73 -73
  925. package/styles/xertica/theme-map.css +102 -99
  926. package/styles/xertica/tokens.css +240 -236
  927. package/templates/.prettierignore +4 -4
  928. package/templates/.prettierrc +10 -10
  929. package/templates/CLAUDE.md +116 -131
  930. package/templates/eslint.config.js +26 -26
  931. package/templates/package.json +3 -3
  932. package/templates/postcss.config.js +6 -6
  933. package/templates/src/app/components/AppLayout.tsx +55 -55
  934. package/templates/src/app/components/AuthGuard.tsx +82 -82
  935. package/templates/src/app/context/AuthContext.tsx +108 -108
  936. package/templates/src/features/assistant/data/mock.ts +75 -75
  937. package/templates/src/features/assistant/hooks/useAssistantConfig.ts +20 -20
  938. package/templates/src/features/auth/index.ts +4 -4
  939. package/templates/src/features/auth/ui/AuthPageShell.tsx +32 -32
  940. package/templates/src/features/auth/ui/ForgotPasswordContent.tsx +9 -7
  941. package/templates/src/features/auth/ui/LoginContent.tsx +10 -8
  942. package/templates/src/features/auth/ui/ResetPasswordContent.tsx +17 -15
  943. package/templates/src/features/auth/ui/SocialLoginButtons.tsx +9 -4
  944. package/templates/src/features/auth/ui/VerifyEmailContent.tsx +11 -9
  945. package/templates/src/features/home/data/mock.ts +35 -35
  946. package/templates/src/features/home/hooks/useFeatureCards.ts +20 -20
  947. package/templates/src/features/home/store/dashboardStore.ts +25 -25
  948. package/templates/src/features/home/ui/HomeContent.tsx +1 -1
  949. package/templates/src/features/template/index.ts +5 -5
  950. package/templates/src/features/template/ui/CrudTemplate.tsx +115 -115
  951. package/templates/src/features/template/ui/DashboardTemplate.tsx +110 -110
  952. package/templates/src/features/template/ui/FormTemplate.tsx +117 -117
  953. package/templates/src/features/template/ui/LoginTemplate.tsx +59 -59
  954. package/templates/src/features/template/ui/TemplateContent.tsx +1314 -1314
  955. package/templates/src/i18n.ts +124 -124
  956. package/templates/src/locales/en/common.json +21 -21
  957. package/templates/src/locales/en/components/activityCard.json +10 -10
  958. package/templates/src/locales/en/components/assistant.json +119 -105
  959. package/templates/src/locales/en/components/media.json +29 -29
  960. package/templates/src/locales/en/components/notificationCard.json +5 -5
  961. package/templates/src/locales/en/components/profileCard.json +8 -8
  962. package/templates/src/locales/en/components/projectCard.json +10 -10
  963. package/templates/src/locales/en/components/sidebar.json +14 -14
  964. package/templates/src/locales/en/components/stats.json +8 -8
  965. package/templates/src/locales/en/components/team.json +14 -14
  966. package/templates/src/locales/en/errors.json +9 -9
  967. package/templates/src/locales/en/languageSelector.json +7 -7
  968. package/templates/src/locales/en/nav.json +6 -6
  969. package/templates/src/locales/en/pages/crudTemplate.json +25 -25
  970. package/templates/src/locales/en/pages/dashboardTemplate.json +20 -20
  971. package/templates/src/locales/en/pages/forgotPassword.json +10 -0
  972. package/templates/src/locales/en/pages/formTemplate.json +16 -16
  973. package/templates/src/locales/en/pages/home.json +7 -7
  974. package/templates/src/locales/en/pages/login.json +15 -15
  975. package/templates/src/locales/en/pages/loginTemplate.json +9 -9
  976. package/templates/src/locales/en/pages/resetPassword.json +18 -18
  977. package/templates/src/locales/en/pages/templates.json +317 -317
  978. package/templates/src/locales/en/pages/verifyEmail.json +12 -12
  979. package/templates/src/locales/en/themeToggle.json +6 -6
  980. package/templates/src/locales/es/common.json +21 -21
  981. package/templates/src/locales/es/components/activityCard.json +10 -10
  982. package/templates/src/locales/es/components/assistant.json +119 -105
  983. package/templates/src/locales/es/components/media.json +29 -29
  984. package/templates/src/locales/es/components/notificationCard.json +5 -5
  985. package/templates/src/locales/es/components/profileCard.json +8 -8
  986. package/templates/src/locales/es/components/projectCard.json +10 -10
  987. package/templates/src/locales/es/components/sidebar.json +14 -14
  988. package/templates/src/locales/es/components/stats.json +8 -8
  989. package/templates/src/locales/es/components/team.json +14 -14
  990. package/templates/src/locales/es/errors.json +9 -9
  991. package/templates/src/locales/es/languageSelector.json +7 -7
  992. package/templates/src/locales/es/nav.json +6 -6
  993. package/templates/src/locales/es/pages/crudTemplate.json +25 -25
  994. package/templates/src/locales/es/pages/dashboardTemplate.json +20 -20
  995. package/templates/src/locales/es/pages/forgotPassword.json +10 -0
  996. package/templates/src/locales/es/pages/formTemplate.json +16 -16
  997. package/templates/src/locales/es/pages/home.json +7 -7
  998. package/templates/src/locales/es/pages/login.json +15 -15
  999. package/templates/src/locales/es/pages/loginTemplate.json +9 -9
  1000. package/templates/src/locales/es/pages/resetPassword.json +18 -18
  1001. package/templates/src/locales/es/pages/templates.json +317 -317
  1002. package/templates/src/locales/es/pages/verifyEmail.json +12 -12
  1003. package/templates/src/locales/es/themeToggle.json +6 -6
  1004. package/templates/src/locales/pt-BR/common.json +21 -21
  1005. package/templates/src/locales/pt-BR/components/activityCard.json +10 -10
  1006. package/templates/src/locales/pt-BR/components/assistant.json +119 -105
  1007. package/templates/src/locales/pt-BR/components/media.json +29 -29
  1008. package/templates/src/locales/pt-BR/components/notificationCard.json +5 -5
  1009. package/templates/src/locales/pt-BR/components/profileCard.json +8 -8
  1010. package/templates/src/locales/pt-BR/components/projectCard.json +10 -10
  1011. package/templates/src/locales/pt-BR/components/sidebar.json +14 -14
  1012. package/templates/src/locales/pt-BR/components/stats.json +8 -8
  1013. package/templates/src/locales/pt-BR/components/team.json +14 -14
  1014. package/templates/src/locales/pt-BR/errors.json +9 -9
  1015. package/templates/src/locales/pt-BR/languageSelector.json +7 -7
  1016. package/templates/src/locales/pt-BR/nav.json +6 -6
  1017. package/templates/src/locales/pt-BR/pages/crudTemplate.json +25 -25
  1018. package/templates/src/locales/pt-BR/pages/dashboardTemplate.json +20 -20
  1019. package/templates/src/locales/pt-BR/pages/forgotPassword.json +10 -0
  1020. package/templates/src/locales/pt-BR/pages/formTemplate.json +16 -16
  1021. package/templates/src/locales/pt-BR/pages/home.json +7 -7
  1022. package/templates/src/locales/pt-BR/pages/login.json +15 -15
  1023. package/templates/src/locales/pt-BR/pages/loginTemplate.json +9 -9
  1024. package/templates/src/locales/pt-BR/pages/resetPassword.json +18 -18
  1025. package/templates/src/locales/pt-BR/pages/templates.json +317 -317
  1026. package/templates/src/locales/pt-BR/pages/verifyEmail.json +12 -12
  1027. package/templates/src/locales/pt-BR/themeToggle.json +6 -6
  1028. package/templates/src/main.tsx +11 -11
  1029. package/templates/src/pages/AssistantPage.tsx +37 -36
  1030. package/templates/src/pages/ForgotPasswordPage.tsx +6 -6
  1031. package/templates/src/pages/LoginPage.tsx +10 -10
  1032. package/templates/src/pages/ResetPasswordPage.tsx +6 -6
  1033. package/templates/src/pages/TemplatePage.tsx +28 -28
  1034. package/templates/src/pages/VerifyEmailPage.tsx +6 -6
  1035. package/templates/src/shared/config/navigation.ts +19 -19
  1036. package/templates/src/shared/error-boundary.tsx +154 -154
  1037. package/templates/src/shared/error-fallbacks.tsx +226 -226
  1038. package/templates/src/shared/lib/auth.ts +20 -20
  1039. package/templates/src/shared/types/auth.ts +3 -3
  1040. package/templates/src/styles/index.css +95 -95
  1041. package/templates/src/styles/xertica/tokens.css +240 -236
  1042. package/templates/tsconfig.json +25 -25
  1043. package/templates/tsconfig.node.json +12 -12
  1044. package/templates/vite-env.d.ts +1 -1
  1045. package/templates/vite.config.ts +1 -1
  1046. package/utils/color-utils.ts +72 -72
  1047. package/utils/demo-responses.test.ts +10 -10
  1048. package/utils/demo-responses.ts +151 -151
  1049. package/utils/gemini.test.ts +25 -25
  1050. package/utils/gemini.ts +155 -155
  1051. package/dist/ThemeContext-CpqYShLq.cjs +0 -324
  1052. package/dist/ThemeContext-Du2nE1PL.js +0 -325
  1053. package/dist/ThemeContext-GeEBTJ3q.cjs +0 -1621
  1054. package/dist/ThemeContext-JyLK9B1o.js +0 -1622
  1055. package/dist/index-CkTUgOwX.js +0 -8
  1056. package/dist/{rich-text-editor-BmsjY03B.js → rich-text-editor-DgF8s7xW.js} +26 -26
  1057. package/dist/{rich-text-editor-GS2kpTAK.cjs → rich-text-editor-mWoaSCE4.cjs} +26 -26
@@ -1,554 +1,554 @@
1
- import React, { useRef, useEffect, useState } from 'react';
2
- import { motion, AnimatePresence } from 'framer-motion';
3
- import { Send, Plus, Paperclip, Mic, FileText, Radio, Search, X } from 'lucide-react';
4
- import { useTranslation } from 'react-i18next';
5
- import { Button } from '../../ui/button';
6
- import { Popover, PopoverContent, PopoverTrigger } from '../../ui/popover';
7
- import { toast } from 'sonner';
8
-
9
- /**
10
- * Supported special action types for the chat input.
11
- * - 'document': Triggers document generation workflow.
12
- * - 'podcast': Triggers audio podcast generation.
13
- * - 'search': Triggers a knowledge base search.
14
- */
15
- export type ActionType = 'document' | 'podcast' | 'search' | null;
16
-
17
- /**
18
- * Props for the ModernChatInput component.
19
- */
20
- interface ModernChatInputProps {
21
- /** Current input text value */
22
- value: string;
23
- /** Callback fired on every keystroke */
24
- onChange: (value: string) => void;
25
- /** Callback fired when the user submits (via Enter or click) */
26
- onSubmit: (action?: ActionType) => void;
27
- /** Input placeholder text */
28
- placeholder?: string;
29
- /** Whether the input is disabled */
30
- disabled?: boolean;
31
- /** Callback for file attachment button */
32
- onFileUpload?: () => void;
33
- /** Callback for audio upload button */
34
- onAudioUpload?: () => void;
35
- /** Callback fired when a voice recording is finished and transcribed */
36
- onVoiceRecording?: (transcript: string) => void;
37
- /** Whether the input is being used in a full-page view (affects layout) */
38
- isFullPage?: boolean;
39
- /** Whether to show audio input (voice recording). @default true */
40
- enableAudioInput?: boolean;
41
- /** Whether to show the file attachment button. @default true */
42
- enableFileAttachment?: boolean;
43
- /** Whether to show the "Create document" action. @default true */
44
- enableDocumentCreation?: boolean;
45
- /** Whether to show the "Generate podcast" action. @default true */
46
- enablePodcastGeneration?: boolean;
47
- /** Whether to show the "Search" action. @default true */
48
- enableSearch?: boolean;
49
- }
50
-
51
- /**
52
- * Modern floating chat input with rich actions and voice recording.
53
- *
54
- * @description
55
- * An advanced text input that supports multi-line typing, quick action chips
56
- * (Document, Podcast, Search), file attachments, and simulated voice-to-text recording.
57
- *
58
- * @ai-rules
59
- * 1. Use the `onSubmit` callback to handle both text messages and special actions.
60
- * 2. This component manages its own height dynamically based on content (up to 100px).
61
- * 3. Voice recording is simulated — it returns a random string to the `onVoiceRecording` callback.
62
- */
63
- export function ModernChatInput({
64
- value,
65
- onChange,
66
- onSubmit,
67
- placeholder,
68
- disabled = false,
69
- onFileUpload,
70
- onAudioUpload,
71
- onVoiceRecording,
72
- isFullPage = false,
73
- enableAudioInput = true,
74
- enableFileAttachment = true,
75
- enableDocumentCreation = true,
76
- enablePodcastGeneration = true,
77
- enableSearch = true,
78
- }: ModernChatInputProps) {
79
- const { t } = useTranslation();
80
- const textareaRef = useRef<HTMLTextAreaElement>(null);
81
- const [isFocused, setIsFocused] = useState(false);
82
- const [textareaHeight, setTextareaHeight] = useState(20);
83
- const [selectedAction, setSelectedAction] = useState<ActionType>(null);
84
- const [isPopoverOpen, setIsPopoverOpen] = useState(false);
85
- const [isRecording, setIsRecording] = useState(false);
86
- const [recordingTime, setRecordingTime] = useState(0);
87
- const recordingIntervalRef = useRef<NodeJS.Timeout | null>(null);
88
-
89
- // Resolve placeholder: caller prop takes precedence, then i18n key
90
- const resolvedPlaceholder = placeholder ?? t('assistant.inputPlaceholder');
91
-
92
- const adjustHeight = () => {
93
- const textarea = textareaRef.current;
94
- if (textarea) {
95
- // Reset to minimum height first
96
- textarea.style.height = '20px';
97
-
98
- // Calculate new height based on content
99
- const scrollHeight = textarea.scrollHeight;
100
- const newHeight = Math.min(Math.max(scrollHeight, 20), 100);
101
-
102
- // Apply the new height smoothly
103
- setTextareaHeight(newHeight);
104
- textarea.style.height = newHeight + 'px';
105
- }
106
- };
107
-
108
- // Initialize with proper height on mount
109
- useEffect(() => {
110
- const textarea = textareaRef.current;
111
- if (textarea) {
112
- // Force initial height without content check
113
- textarea.style.height = '20px';
114
- setTextareaHeight(20);
115
-
116
- // If there's initial content, adjust immediately
117
- if (value) {
118
- setTimeout(adjustHeight, 0);
119
- }
120
- }
121
- }, []); // Empty dependency array - only runs on mount
122
-
123
- // Adjust height when value changes
124
- useEffect(() => {
125
- if (value === '') {
126
- // Reset to minimum when empty
127
- const textarea = textareaRef.current;
128
- if (textarea) {
129
- textarea.style.height = '20px';
130
- setTextareaHeight(20);
131
- }
132
- } else {
133
- // Adjust for content
134
- const timeoutId = setTimeout(adjustHeight, 0);
135
- return () => clearTimeout(timeoutId);
136
- }
137
- }, [value]);
138
-
139
- const handleKeyDown = (e: React.KeyboardEvent) => {
140
- if (e.key === 'Enter' && !e.shiftKey) {
141
- e.preventDefault();
142
- if (value.trim() && !disabled) {
143
- onSubmit(selectedAction);
144
- setSelectedAction(null);
145
- }
146
- }
147
- };
148
-
149
- const handleActionSelect = (action: ActionType) => {
150
- setSelectedAction(action);
151
- setIsPopoverOpen(false);
152
- };
153
-
154
- const handleRemoveAction = () => {
155
- setSelectedAction(null);
156
- };
157
-
158
- const handleVoiceRecording = () => {
159
- if (isRecording) {
160
- // Stop recording
161
- if (recordingIntervalRef.current) {
162
- clearInterval(recordingIntervalRef.current);
163
- recordingIntervalRef.current = null;
164
- }
165
-
166
- // Simulate audio transcription — demo strings keyed by i18n
167
- const transcricoes = [
168
- t('assistant.voiceTranscriptions.salesData'),
169
- t('assistant.voiceTranscriptions.performanceReport'),
170
- t('assistant.voiceTranscriptions.marketTrends'),
171
- t('assistant.voiceTranscriptions.customerSatisfaction'),
172
- t('assistant.voiceTranscriptions.teamProductivity'),
173
- t('assistant.voiceTranscriptions.keyMetrics'),
174
- t('assistant.voiceTranscriptions.digitalMarketing'),
175
- t('assistant.voiceTranscriptions.socialEngagement'),
176
- ];
177
-
178
- const transcricaoAleatoria = transcricoes[Math.floor(Math.random() * transcricoes.length)];
179
-
180
- // Call the callback with the transcription
181
- if (onVoiceRecording) {
182
- onVoiceRecording(transcricaoAleatoria);
183
- }
184
-
185
- setIsRecording(false);
186
- setRecordingTime(0);
187
- } else {
188
- // Start recording
189
- setIsRecording(true);
190
- setRecordingTime(0);
191
-
192
- toast.info(t('assistant.recordingStarted'), {
193
- description: t('assistant.recordingDescriptionFull'),
194
- duration: 3000,
195
- });
196
-
197
- recordingIntervalRef.current = setInterval(() => {
198
- setRecordingTime(prev => prev + 1);
199
- }, 1000);
200
- }
201
- };
202
-
203
- // Automatically stop recording after 60 seconds
204
- useEffect(() => {
205
- if (recordingTime >= 60 && isRecording) {
206
- handleVoiceRecording();
207
- }
208
- }, [recordingTime, isRecording]);
209
-
210
- // Clear interval on unmount
211
- useEffect(() => {
212
- return () => {
213
- if (recordingIntervalRef.current) {
214
- clearInterval(recordingIntervalRef.current);
215
- }
216
- };
217
- }, []);
218
-
219
- const getActionInfo = (action: ActionType) => {
220
- switch (action) {
221
- case 'document':
222
- return { label: t('assistant.actions.createDocument'), icon: FileText, color: 'bg-[var(--chart-4)]' };
223
- case 'podcast':
224
- return { label: t('assistant.actions.generatePodcast'), icon: Radio, color: 'bg-[var(--chart-1)]' };
225
- case 'search':
226
- return { label: t('assistant.actions.search'), icon: Search, color: 'bg-[var(--chart-2)]' };
227
- default:
228
- return null;
229
- }
230
- };
231
-
232
- const handleFocus = () => setIsFocused(true);
233
- const handleBlur = () => setIsFocused(false);
234
-
235
- const hasContent = value.trim().length > 0;
236
-
237
- return (
238
- <div className={`p-4 ${isFullPage ? 'mx-auto w-full max-w-6xl' : ''}`}>
239
- {/* Recording Indicator */}
240
- <AnimatePresence>
241
- {isRecording && (
242
- <motion.div
243
- initial={{ opacity: 0, y: 10 }}
244
- animate={{ opacity: 1, y: 0 }}
245
- exit={{ opacity: 0, y: 10 }}
246
- className="mb-3 p-4 bg-destructive/10 border border-destructive/30 rounded-[var(--radius-card)]"
247
- >
248
- <div className="flex items-center justify-between">
249
- <div className="flex items-center gap-3">
250
- {/* Pulsing Dot */}
251
- <motion.div
252
- animate={{
253
- scale: [1, 1.2, 1],
254
- opacity: [1, 0.7, 1],
255
- }}
256
- transition={{
257
- duration: 1.5,
258
- repeat: Infinity,
259
- ease: 'easeInOut',
260
- }}
261
- className="w-3 h-3 bg-destructive rounded-full"
262
- />
263
-
264
- {/* Audio Waves Animation */}
265
- <div className="flex items-center gap-1">
266
- {[0, 1, 2, 3, 4].map(i => (
267
- <motion.div
268
- key={i}
269
- animate={{
270
- height: ['8px', '20px', '8px'],
271
- }}
272
- transition={{
273
- duration: 0.8,
274
- repeat: Infinity,
275
- ease: 'easeInOut',
276
- delay: i * 0.1,
277
- }}
278
- className="w-1 bg-destructive rounded-full h-2"
279
- />
280
- ))}
281
- </div>
282
-
283
- <span className="text-sm font-medium text-destructive">{t('assistant.recordingAudio')}</span>
284
- </div>
285
-
286
- <div className="flex items-center gap-3">
287
- <div className="text-sm text-destructive font-mono tabular-nums">
288
- {Math.floor(recordingTime / 60)}:
289
- {(recordingTime % 60).toString().padStart(2, '0')}
290
- </div>
291
- <Button
292
- onClick={handleVoiceRecording}
293
- size="sm"
294
- variant="outline"
295
- className="h-7 px-3 text-xs border-destructive/30 text-destructive hover:bg-destructive/10 rounded-[var(--radius-button)]"
296
- >
297
- {t('assistant.stopRecording')}
298
- </Button>
299
- </div>
300
- </div>
301
- </motion.div>
302
- )}
303
- </AnimatePresence>
304
-
305
- {/* Modern Input Container */}
306
- <motion.div
307
- className={`relative bg-card rounded-[var(--radius)] border shadow-sm transition-all duration-300 ${
308
- isFocused || hasContent ? 'border-primary shadow-lg shadow-primary/10' : 'border-border'
309
- }`}
310
- initial={false}
311
- animate={{
312
- scale: isFocused ? 1.01 : 1,
313
- }}
314
- transition={{ duration: 0.2, ease: 'easeOut' }}
315
- >
316
- <div className="px-3 py-2 pt-[14px] pr-[10px] pb-[8px] pl-[10px] rounded-[var(--radius)]">
317
- {/* Action Chip */}
318
- <AnimatePresence>
319
- {selectedAction && (
320
- <motion.div
321
- initial={{ opacity: 0, y: -10, height: 0 }}
322
- animate={{ opacity: 1, y: 0, height: 'auto' }}
323
- exit={{ opacity: 0, y: -10, height: 0 }}
324
- transition={{ duration: 0.2 }}
325
- className="mb-2"
326
- >
327
- {(() => {
328
- const actionInfo = getActionInfo(selectedAction);
329
- if (!actionInfo) return null;
330
- const Icon = actionInfo.icon;
331
- return (
332
- <div
333
- className={`inline-flex items-center gap-2 px-3 py-1.5 rounded-full ${actionInfo.color} text-white text-xs font-medium shadow-sm`}
334
- >
335
- <Icon className="w-3.5 h-3.5" />
336
- <span>{actionInfo.label}</span>
337
- <button
338
- onClick={handleRemoveAction}
339
- className="ml-1 hover:bg-white/20 rounded-full p-0.5 transition-colors"
340
- aria-label={t('assistant.removeAction')}
341
- >
342
- <X className="w-3 h-3" />
343
- </button>
344
- </div>
345
- );
346
- })()}
347
- </motion.div>
348
- )}
349
- </AnimatePresence>
350
-
351
- {/* Text Input - Full Width */}
352
- <div className="mb-2">
353
- <textarea
354
- ref={textareaRef}
355
- value={value}
356
- onChange={e => onChange(e.target.value)}
357
- onKeyDown={handleKeyDown}
358
- onFocus={handleFocus}
359
- onBlur={handleBlur}
360
- placeholder={resolvedPlaceholder}
361
- aria-label={resolvedPlaceholder}
362
- disabled={disabled}
363
- className="w-full bg-transparent border-0 outline-none resize-none text-foreground placeholder-muted-foreground text-sm leading-5 min-h-[20px] max-h-[100px] overflow-y-auto scrollbar-thin scrollbar-thumb-border scrollbar-track-transparent"
364
- style={{
365
- height: `${textareaHeight}px`,
366
- minHeight: '20px',
367
- maxHeight: '100px',
368
- }}
369
- rows={1}
370
- />
371
- </div>
372
-
373
- {/* Actions Row - Bottom */}
374
- <div className="flex items-center justify-between">
375
- {/* Left Actions */}
376
- <div className="flex items-center gap-1">
377
- {(enableDocumentCreation || enablePodcastGeneration || enableSearch) && (
378
- <Popover open={isPopoverOpen} onOpenChange={setIsPopoverOpen}>
379
- <PopoverTrigger asChild>
380
- <Button
381
- variant="ghost"
382
- size="sm"
383
- className="h-8 w-8 p-0 rounded-full text-muted-foreground hover:bg-accent hover:text-foreground transition-all duration-200"
384
- aria-label={t('assistant.viewActions')}
385
- >
386
- <motion.div
387
- whileHover={{ scale: 1.05 }}
388
- whileTap={{ scale: 0.95 }}
389
- className="flex items-center justify-center w-full h-full"
390
- >
391
- <Plus className="w-4 h-4" />
392
- </motion.div>
393
- </Button>
394
- </PopoverTrigger>
395
- <PopoverContent className="w-56 p-2" align="start" side="top">
396
- <div className="space-y-1">
397
- {enableDocumentCreation && (
398
- <button
399
- onClick={() => handleActionSelect('document')}
400
- className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
401
- >
402
- <div className="w-8 h-8 rounded-full bg-[var(--chart-4)]/20 flex items-center justify-center group-hover:bg-[var(--chart-4)] transition-colors">
403
- <FileText className="w-4 h-4 text-[var(--chart-4)] group-hover:text-white" />
404
- </div>
405
- <div className="flex-1">
406
- <div>{t('assistant.actions.createDocument')}</div>
407
- <div className="text-xs text-muted-foreground">
408
- {t('assistant.actions.createDocumentDesc')}
409
- </div>
410
- </div>
411
- </button>
412
- )}
413
-
414
- {enablePodcastGeneration && (
415
- <button
416
- onClick={() => handleActionSelect('podcast')}
417
- className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
418
- >
419
- <div className="w-8 h-8 rounded-full bg-[var(--chart-1)]/20 flex items-center justify-center group-hover:bg-[var(--chart-1)] transition-colors">
420
- <Radio className="w-4 h-4 text-[var(--chart-1)] group-hover:text-white" />
421
- </div>
422
- <div className="flex-1">
423
- <div>{t('assistant.actions.generatePodcast')}</div>
424
- <div className="text-xs text-muted-foreground">
425
- {t('assistant.actions.generatePodcastDesc')}
426
- </div>
427
- </div>
428
- </button>
429
- )}
430
-
431
- {enableSearch && (
432
- <button
433
- onClick={() => handleActionSelect('search')}
434
- className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
435
- >
436
- <div className="w-8 h-8 rounded-full bg-[var(--chart-2)]/20 flex items-center justify-center group-hover:bg-[var(--chart-2)] transition-colors">
437
- <Search className="w-4 h-4 text-[var(--chart-2)] group-hover:text-white" />
438
- </div>
439
- <div className="flex-1">
440
- <div>{t('assistant.actions.search')}</div>
441
- <div className="text-xs text-muted-foreground">
442
- {t('assistant.actions.searchDesc')}
443
- </div>
444
- </div>
445
- </button>
446
- )}
447
- </div>
448
- </PopoverContent>
449
- </Popover>
450
- )}
451
-
452
- {enableFileAttachment && (
453
- <motion.div whileHover={{ scale: 1.05 }} whileTap={{ scale: 0.95 }}>
454
- <Button
455
- variant="ghost"
456
- size="sm"
457
- onClick={onFileUpload}
458
- className="h-8 w-8 p-0 rounded-full text-muted-foreground hover:bg-accent hover:text-foreground transition-all duration-200"
459
- aria-label={t('assistant.attachFile')}
460
- >
461
- <Paperclip className="w-4 h-4" />
462
- </Button>
463
- </motion.div>
464
- )}
465
- </div>
466
-
467
- {/* Right Actions */}
468
- <div className="flex items-center gap-1">
469
- {/* Voice Recording Button */}
470
- {enableAudioInput && (
471
- <motion.div whileHover={{ scale: 1.05 }} whileTap={{ scale: 0.95 }}>
472
- <Button
473
- variant="ghost"
474
- size="sm"
475
- onClick={handleVoiceRecording}
476
- className={`h-8 w-8 p-0 rounded-full transition-all duration-200 ${
477
- isRecording
478
- ? 'bg-destructive hover:bg-destructive/90 text-white animate-pulse'
479
- : 'text-muted-foreground hover:bg-accent hover:text-foreground'
480
- }`}
481
- aria-label={isRecording ? t('assistant.stopRecording') : t('assistant.suggestWithVoice')}
482
- >
483
- <Mic className="w-4 h-4" />
484
- </Button>
485
- </motion.div>
486
- )}
487
-
488
- <AnimatePresence mode="wait">
489
- <motion.div
490
- key={hasContent ? 'active' : 'inactive'}
491
- initial={{ scale: 0.8, opacity: 0 }}
492
- animate={{ scale: 1, opacity: 1 }}
493
- exit={{ scale: 0.8, opacity: 0 }}
494
- transition={{ duration: 0.2, ease: 'easeInOut' }}
495
- whileHover={hasContent ? { scale: 1.05 } : {}}
496
- whileTap={hasContent ? { scale: 0.95 } : {}}
497
- >
498
- <Button
499
- onClick={() => {
500
- onSubmit(selectedAction);
501
- setSelectedAction(null);
502
- }}
503
- size="sm"
504
- disabled={!hasContent || disabled}
505
- className={`h-8 w-8 p-0 rounded-full transition-all duration-300 ${
506
- hasContent && !disabled
507
- ? 'bg-primary hover:bg-primary/90 text-primary-foreground shadow-lg shadow-primary/30 hover:shadow-primary/40'
508
- : 'bg-muted text-muted-foreground cursor-not-allowed'
509
- }`}
510
- aria-label={t('assistant.sendMessage')}
511
- >
512
- <motion.div
513
- animate={{
514
- rotate: hasContent ? 0 : -45,
515
- }}
516
- transition={{ duration: 0.2 }}
517
- >
518
- <Send className="w-4 h-4" />
519
- </motion.div>
520
- </Button>
521
- </motion.div>
522
- </AnimatePresence>
523
- </div>
524
- </div>
525
- </div>
526
-
527
- {/* Subtle glow effect when focused */}
528
- <AnimatePresence>
529
- {isFocused && (
530
- <motion.div
531
- className="absolute inset-0 rounded-[var(--radius)] bg-gradient-to-r from-primary/5 via-transparent to-primary/5 pointer-events-none"
532
- initial={{ opacity: 0 }}
533
- animate={{ opacity: 1 }}
534
- exit={{ opacity: 0 }}
535
- transition={{ duration: 0.3 }}
536
- />
537
- )}
538
- </AnimatePresence>
539
- </motion.div>
540
-
541
- {/* Footer Info */}
542
- <motion.div
543
- className="mt-2 text-center"
544
- initial={{ opacity: 0, y: 5 }}
545
- animate={{ opacity: 1, y: 0 }}
546
- transition={{ delay: 0.1 }}
547
- >
548
- <p className="text-xs text-muted-foreground">
549
- {t('assistant.disclaimer')}
550
- </p>
551
- </motion.div>
552
- </div>
553
- );
554
- }
1
+ import React, { useRef, useEffect, useState } from 'react';
2
+ import { motion, AnimatePresence } from 'framer-motion';
3
+ import { Send, Plus, Paperclip, Mic, FileText, Radio, Search, X } from 'lucide-react';
4
+ import { useTranslation } from 'react-i18next';
5
+ import { Button } from '../../ui/button';
6
+ import { Popover, PopoverContent, PopoverTrigger } from '../../ui/popover';
7
+ import { toast } from 'sonner';
8
+
9
+ /**
10
+ * Supported special action types for the chat input.
11
+ * - 'document': Triggers document generation workflow.
12
+ * - 'podcast': Triggers audio podcast generation.
13
+ * - 'search': Triggers a knowledge base search.
14
+ */
15
+ export type ActionType = 'document' | 'podcast' | 'search' | null;
16
+
17
+ /**
18
+ * Props for the ModernChatInput component.
19
+ */
20
+ interface ModernChatInputProps {
21
+ /** Current input text value */
22
+ value: string;
23
+ /** Callback fired on every keystroke */
24
+ onChange: (value: string) => void;
25
+ /** Callback fired when the user submits (via Enter or click) */
26
+ onSubmit: (action?: ActionType) => void;
27
+ /** Input placeholder text */
28
+ placeholder?: string;
29
+ /** Whether the input is disabled */
30
+ disabled?: boolean;
31
+ /** Callback for file attachment button */
32
+ onFileUpload?: () => void;
33
+ /** Callback for audio upload button */
34
+ onAudioUpload?: () => void;
35
+ /** Callback fired when a voice recording is finished and transcribed */
36
+ onVoiceRecording?: (transcript: string) => void;
37
+ /** Whether the input is being used in a full-page view (affects layout) */
38
+ isFullPage?: boolean;
39
+ /** Whether to show audio input (voice recording). @default true */
40
+ enableAudioInput?: boolean;
41
+ /** Whether to show the file attachment button. @default true */
42
+ enableFileAttachment?: boolean;
43
+ /** Whether to show the "Create document" action. @default true */
44
+ enableDocumentCreation?: boolean;
45
+ /** Whether to show the "Generate podcast" action. @default true */
46
+ enablePodcastGeneration?: boolean;
47
+ /** Whether to show the "Search" action. @default true */
48
+ enableSearch?: boolean;
49
+ }
50
+
51
+ /**
52
+ * Modern floating chat input with rich actions and voice recording.
53
+ *
54
+ * @description
55
+ * An advanced text input that supports multi-line typing, quick action chips
56
+ * (Document, Podcast, Search), file attachments, and simulated voice-to-text recording.
57
+ *
58
+ * @ai-rules
59
+ * 1. Use the `onSubmit` callback to handle both text messages and special actions.
60
+ * 2. This component manages its own height dynamically based on content (up to 100px).
61
+ * 3. Voice recording is simulated — it returns a random string to the `onVoiceRecording` callback.
62
+ */
63
+ export function ModernChatInput({
64
+ value,
65
+ onChange,
66
+ onSubmit,
67
+ placeholder,
68
+ disabled = false,
69
+ onFileUpload,
70
+ onAudioUpload,
71
+ onVoiceRecording,
72
+ isFullPage = false,
73
+ enableAudioInput = true,
74
+ enableFileAttachment = true,
75
+ enableDocumentCreation = true,
76
+ enablePodcastGeneration = true,
77
+ enableSearch = true,
78
+ }: ModernChatInputProps) {
79
+ const { t } = useTranslation();
80
+ const textareaRef = useRef<HTMLTextAreaElement>(null);
81
+ const [isFocused, setIsFocused] = useState(false);
82
+ const [textareaHeight, setTextareaHeight] = useState(20);
83
+ const [selectedAction, setSelectedAction] = useState<ActionType>(null);
84
+ const [isPopoverOpen, setIsPopoverOpen] = useState(false);
85
+ const [isRecording, setIsRecording] = useState(false);
86
+ const [recordingTime, setRecordingTime] = useState(0);
87
+ const recordingIntervalRef = useRef<NodeJS.Timeout | null>(null);
88
+
89
+ // Resolve placeholder: caller prop takes precedence, then i18n key
90
+ const resolvedPlaceholder = placeholder ?? t('assistant.inputPlaceholder');
91
+
92
+ const adjustHeight = () => {
93
+ const textarea = textareaRef.current;
94
+ if (textarea) {
95
+ // Reset to minimum height first
96
+ textarea.style.height = '20px';
97
+
98
+ // Calculate new height based on content
99
+ const scrollHeight = textarea.scrollHeight;
100
+ const newHeight = Math.min(Math.max(scrollHeight, 20), 100);
101
+
102
+ // Apply the new height smoothly
103
+ setTextareaHeight(newHeight);
104
+ textarea.style.height = newHeight + 'px';
105
+ }
106
+ };
107
+
108
+ // Initialize with proper height on mount
109
+ useEffect(() => {
110
+ const textarea = textareaRef.current;
111
+ if (textarea) {
112
+ // Force initial height without content check
113
+ textarea.style.height = '20px';
114
+ setTextareaHeight(20);
115
+
116
+ // If there's initial content, adjust immediately
117
+ if (value) {
118
+ setTimeout(adjustHeight, 0);
119
+ }
120
+ }
121
+ }, []); // Empty dependency array - only runs on mount
122
+
123
+ // Adjust height when value changes
124
+ useEffect(() => {
125
+ if (value === '') {
126
+ // Reset to minimum when empty
127
+ const textarea = textareaRef.current;
128
+ if (textarea) {
129
+ textarea.style.height = '20px';
130
+ setTextareaHeight(20);
131
+ }
132
+ } else {
133
+ // Adjust for content
134
+ const timeoutId = setTimeout(adjustHeight, 0);
135
+ return () => clearTimeout(timeoutId);
136
+ }
137
+ }, [value]);
138
+
139
+ const handleKeyDown = (e: React.KeyboardEvent) => {
140
+ if (e.key === 'Enter' && !e.shiftKey) {
141
+ e.preventDefault();
142
+ if (value.trim() && !disabled) {
143
+ onSubmit(selectedAction);
144
+ setSelectedAction(null);
145
+ }
146
+ }
147
+ };
148
+
149
+ const handleActionSelect = (action: ActionType) => {
150
+ setSelectedAction(action);
151
+ setIsPopoverOpen(false);
152
+ };
153
+
154
+ const handleRemoveAction = () => {
155
+ setSelectedAction(null);
156
+ };
157
+
158
+ const handleVoiceRecording = () => {
159
+ if (isRecording) {
160
+ // Stop recording
161
+ if (recordingIntervalRef.current) {
162
+ clearInterval(recordingIntervalRef.current);
163
+ recordingIntervalRef.current = null;
164
+ }
165
+
166
+ // Simulate audio transcription — demo strings keyed by i18n
167
+ const transcricoes = [
168
+ t('assistant.voiceTranscriptions.salesData'),
169
+ t('assistant.voiceTranscriptions.performanceReport'),
170
+ t('assistant.voiceTranscriptions.marketTrends'),
171
+ t('assistant.voiceTranscriptions.customerSatisfaction'),
172
+ t('assistant.voiceTranscriptions.teamProductivity'),
173
+ t('assistant.voiceTranscriptions.keyMetrics'),
174
+ t('assistant.voiceTranscriptions.digitalMarketing'),
175
+ t('assistant.voiceTranscriptions.socialEngagement'),
176
+ ];
177
+
178
+ const transcricaoAleatoria = transcricoes[Math.floor(Math.random() * transcricoes.length)];
179
+
180
+ // Call the callback with the transcription
181
+ if (onVoiceRecording) {
182
+ onVoiceRecording(transcricaoAleatoria);
183
+ }
184
+
185
+ setIsRecording(false);
186
+ setRecordingTime(0);
187
+ } else {
188
+ // Start recording
189
+ setIsRecording(true);
190
+ setRecordingTime(0);
191
+
192
+ toast.info(t('assistant.recordingStarted'), {
193
+ description: t('assistant.recordingDescriptionFull'),
194
+ duration: 3000,
195
+ });
196
+
197
+ recordingIntervalRef.current = setInterval(() => {
198
+ setRecordingTime(prev => prev + 1);
199
+ }, 1000);
200
+ }
201
+ };
202
+
203
+ // Automatically stop recording after 60 seconds
204
+ useEffect(() => {
205
+ if (recordingTime >= 60 && isRecording) {
206
+ handleVoiceRecording();
207
+ }
208
+ }, [recordingTime, isRecording]);
209
+
210
+ // Clear interval on unmount
211
+ useEffect(() => {
212
+ return () => {
213
+ if (recordingIntervalRef.current) {
214
+ clearInterval(recordingIntervalRef.current);
215
+ }
216
+ };
217
+ }, []);
218
+
219
+ const getActionInfo = (action: ActionType) => {
220
+ switch (action) {
221
+ case 'document':
222
+ return { label: t('assistant.actions.createDocument'), icon: FileText, color: 'bg-[var(--chart-4)]' };
223
+ case 'podcast':
224
+ return { label: t('assistant.actions.generatePodcast'), icon: Radio, color: 'bg-[var(--chart-1)]' };
225
+ case 'search':
226
+ return { label: t('assistant.actions.search'), icon: Search, color: 'bg-[var(--chart-2)]' };
227
+ default:
228
+ return null;
229
+ }
230
+ };
231
+
232
+ const handleFocus = () => setIsFocused(true);
233
+ const handleBlur = () => setIsFocused(false);
234
+
235
+ const hasContent = value.trim().length > 0;
236
+
237
+ return (
238
+ <div className={`p-4 ${isFullPage ? 'mx-auto w-full max-w-6xl' : ''}`}>
239
+ {/* Recording Indicator */}
240
+ <AnimatePresence>
241
+ {isRecording && (
242
+ <motion.div
243
+ initial={{ opacity: 0, y: 10 }}
244
+ animate={{ opacity: 1, y: 0 }}
245
+ exit={{ opacity: 0, y: 10 }}
246
+ className="mb-3 p-4 bg-destructive/10 border border-destructive/30 rounded-[var(--radius-card)]"
247
+ >
248
+ <div className="flex items-center justify-between">
249
+ <div className="flex items-center gap-3">
250
+ {/* Pulsing Dot */}
251
+ <motion.div
252
+ animate={{
253
+ scale: [1, 1.2, 1],
254
+ opacity: [1, 0.7, 1],
255
+ }}
256
+ transition={{
257
+ duration: 1.5,
258
+ repeat: Infinity,
259
+ ease: 'easeInOut',
260
+ }}
261
+ className="w-3 h-3 bg-destructive rounded-full"
262
+ />
263
+
264
+ {/* Audio Waves Animation */}
265
+ <div className="flex items-center gap-1">
266
+ {[0, 1, 2, 3, 4].map(i => (
267
+ <motion.div
268
+ key={i}
269
+ animate={{
270
+ height: ['8px', '20px', '8px'],
271
+ }}
272
+ transition={{
273
+ duration: 0.8,
274
+ repeat: Infinity,
275
+ ease: 'easeInOut',
276
+ delay: i * 0.1,
277
+ }}
278
+ className="w-1 bg-destructive rounded-full h-2"
279
+ />
280
+ ))}
281
+ </div>
282
+
283
+ <span className="text-sm font-medium text-destructive">{t('assistant.recordingAudio')}</span>
284
+ </div>
285
+
286
+ <div className="flex items-center gap-3">
287
+ <div className="text-sm text-destructive font-mono tabular-nums">
288
+ {Math.floor(recordingTime / 60)}:
289
+ {(recordingTime % 60).toString().padStart(2, '0')}
290
+ </div>
291
+ <Button
292
+ onClick={handleVoiceRecording}
293
+ size="sm"
294
+ variant="outline"
295
+ className="h-7 px-3 text-xs border-destructive/30 text-destructive hover:bg-destructive/10 rounded-[var(--radius-button)]"
296
+ >
297
+ {t('assistant.stopRecording')}
298
+ </Button>
299
+ </div>
300
+ </div>
301
+ </motion.div>
302
+ )}
303
+ </AnimatePresence>
304
+
305
+ {/* Modern Input Container */}
306
+ <motion.div
307
+ className={`relative bg-card rounded-[var(--radius)] border shadow-sm transition-all duration-300 ${
308
+ isFocused || hasContent ? 'border-primary shadow-lg shadow-primary/10' : 'border-border'
309
+ }`}
310
+ initial={false}
311
+ animate={{
312
+ scale: isFocused ? 1.01 : 1,
313
+ }}
314
+ transition={{ duration: 0.2, ease: 'easeOut' }}
315
+ >
316
+ <div className="px-3 py-2 pt-[14px] pr-[10px] pb-[8px] pl-[10px] rounded-[var(--radius)]">
317
+ {/* Action Chip */}
318
+ <AnimatePresence>
319
+ {selectedAction && (
320
+ <motion.div
321
+ initial={{ opacity: 0, y: -10, height: 0 }}
322
+ animate={{ opacity: 1, y: 0, height: 'auto' }}
323
+ exit={{ opacity: 0, y: -10, height: 0 }}
324
+ transition={{ duration: 0.2 }}
325
+ className="mb-2"
326
+ >
327
+ {(() => {
328
+ const actionInfo = getActionInfo(selectedAction);
329
+ if (!actionInfo) return null;
330
+ const Icon = actionInfo.icon;
331
+ return (
332
+ <div
333
+ className={`inline-flex items-center gap-2 px-3 py-1.5 rounded-full ${actionInfo.color} text-white text-xs font-medium shadow-sm`}
334
+ >
335
+ <Icon className="w-3.5 h-3.5" />
336
+ <span>{actionInfo.label}</span>
337
+ <button
338
+ onClick={handleRemoveAction}
339
+ className="ml-1 hover:bg-white/20 rounded-full p-0.5 transition-colors"
340
+ aria-label={t('assistant.removeAction')}
341
+ >
342
+ <X className="w-3 h-3" />
343
+ </button>
344
+ </div>
345
+ );
346
+ })()}
347
+ </motion.div>
348
+ )}
349
+ </AnimatePresence>
350
+
351
+ {/* Text Input - Full Width */}
352
+ <div className="mb-2">
353
+ <textarea
354
+ ref={textareaRef}
355
+ value={value}
356
+ onChange={e => onChange(e.target.value)}
357
+ onKeyDown={handleKeyDown}
358
+ onFocus={handleFocus}
359
+ onBlur={handleBlur}
360
+ placeholder={resolvedPlaceholder}
361
+ aria-label={resolvedPlaceholder}
362
+ disabled={disabled}
363
+ className="w-full bg-transparent border-0 outline-none resize-none text-foreground placeholder-muted-foreground text-sm leading-5 min-h-[20px] max-h-[100px] overflow-y-auto scrollbar-thin scrollbar-thumb-border scrollbar-track-transparent"
364
+ style={{
365
+ height: `${textareaHeight}px`,
366
+ minHeight: '20px',
367
+ maxHeight: '100px',
368
+ }}
369
+ rows={1}
370
+ />
371
+ </div>
372
+
373
+ {/* Actions Row - Bottom */}
374
+ <div className="flex items-center justify-between">
375
+ {/* Left Actions */}
376
+ <div className="flex items-center gap-1">
377
+ {(enableDocumentCreation || enablePodcastGeneration || enableSearch) && (
378
+ <Popover open={isPopoverOpen} onOpenChange={setIsPopoverOpen}>
379
+ <PopoverTrigger asChild>
380
+ <Button
381
+ variant="ghost"
382
+ size="sm"
383
+ className="h-8 w-8 p-0 rounded-full text-muted-foreground hover:bg-accent hover:text-foreground transition-all duration-200"
384
+ aria-label={t('assistant.viewActions')}
385
+ >
386
+ <motion.div
387
+ whileHover={{ scale: 1.05 }}
388
+ whileTap={{ scale: 0.95 }}
389
+ className="flex items-center justify-center w-full h-full"
390
+ >
391
+ <Plus className="w-4 h-4" />
392
+ </motion.div>
393
+ </Button>
394
+ </PopoverTrigger>
395
+ <PopoverContent className="w-56 p-2" align="start" side="top">
396
+ <div className="space-y-1">
397
+ {enableDocumentCreation && (
398
+ <button
399
+ onClick={() => handleActionSelect('document')}
400
+ className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
401
+ >
402
+ <div className="w-8 h-8 rounded-full bg-[var(--chart-4)]/20 flex items-center justify-center group-hover:bg-[var(--chart-4)] transition-colors">
403
+ <FileText className="w-4 h-4 text-[var(--chart-4)] group-hover:text-white" />
404
+ </div>
405
+ <div className="flex-1">
406
+ <div>{t('assistant.actions.createDocument')}</div>
407
+ <div className="text-xs text-muted-foreground">
408
+ {t('assistant.actions.createDocumentDesc')}
409
+ </div>
410
+ </div>
411
+ </button>
412
+ )}
413
+
414
+ {enablePodcastGeneration && (
415
+ <button
416
+ onClick={() => handleActionSelect('podcast')}
417
+ className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
418
+ >
419
+ <div className="w-8 h-8 rounded-full bg-[var(--chart-1)]/20 flex items-center justify-center group-hover:bg-[var(--chart-1)] transition-colors">
420
+ <Radio className="w-4 h-4 text-[var(--chart-1)] group-hover:text-white" />
421
+ </div>
422
+ <div className="flex-1">
423
+ <div>{t('assistant.actions.generatePodcast')}</div>
424
+ <div className="text-xs text-muted-foreground">
425
+ {t('assistant.actions.generatePodcastDesc')}
426
+ </div>
427
+ </div>
428
+ </button>
429
+ )}
430
+
431
+ {enableSearch && (
432
+ <button
433
+ onClick={() => handleActionSelect('search')}
434
+ className="w-full flex items-center gap-3 px-3 py-2.5 rounded-lg hover:bg-accent transition-colors text-left group"
435
+ >
436
+ <div className="w-8 h-8 rounded-full bg-[var(--chart-2)]/20 flex items-center justify-center group-hover:bg-[var(--chart-2)] transition-colors">
437
+ <Search className="w-4 h-4 text-[var(--chart-2)] group-hover:text-white" />
438
+ </div>
439
+ <div className="flex-1">
440
+ <div>{t('assistant.actions.search')}</div>
441
+ <div className="text-xs text-muted-foreground">
442
+ {t('assistant.actions.searchDesc')}
443
+ </div>
444
+ </div>
445
+ </button>
446
+ )}
447
+ </div>
448
+ </PopoverContent>
449
+ </Popover>
450
+ )}
451
+
452
+ {enableFileAttachment && (
453
+ <motion.div whileHover={{ scale: 1.05 }} whileTap={{ scale: 0.95 }}>
454
+ <Button
455
+ variant="ghost"
456
+ size="sm"
457
+ onClick={onFileUpload}
458
+ className="h-8 w-8 p-0 rounded-full text-muted-foreground hover:bg-accent hover:text-foreground transition-all duration-200"
459
+ aria-label={t('assistant.attachFile')}
460
+ >
461
+ <Paperclip className="w-4 h-4" />
462
+ </Button>
463
+ </motion.div>
464
+ )}
465
+ </div>
466
+
467
+ {/* Right Actions */}
468
+ <div className="flex items-center gap-1">
469
+ {/* Voice Recording Button */}
470
+ {enableAudioInput && (
471
+ <motion.div whileHover={{ scale: 1.05 }} whileTap={{ scale: 0.95 }}>
472
+ <Button
473
+ variant="ghost"
474
+ size="sm"
475
+ onClick={handleVoiceRecording}
476
+ className={`h-8 w-8 p-0 rounded-full transition-all duration-200 ${
477
+ isRecording
478
+ ? 'bg-destructive hover:bg-destructive/90 text-white animate-pulse'
479
+ : 'text-muted-foreground hover:bg-accent hover:text-foreground'
480
+ }`}
481
+ aria-label={isRecording ? t('assistant.stopRecording') : t('assistant.suggestWithVoice')}
482
+ >
483
+ <Mic className="w-4 h-4" />
484
+ </Button>
485
+ </motion.div>
486
+ )}
487
+
488
+ <AnimatePresence mode="wait">
489
+ <motion.div
490
+ key={hasContent ? 'active' : 'inactive'}
491
+ initial={{ scale: 0.8, opacity: 0 }}
492
+ animate={{ scale: 1, opacity: 1 }}
493
+ exit={{ scale: 0.8, opacity: 0 }}
494
+ transition={{ duration: 0.2, ease: 'easeInOut' }}
495
+ whileHover={hasContent ? { scale: 1.05 } : {}}
496
+ whileTap={hasContent ? { scale: 0.95 } : {}}
497
+ >
498
+ <Button
499
+ onClick={() => {
500
+ onSubmit(selectedAction);
501
+ setSelectedAction(null);
502
+ }}
503
+ size="sm"
504
+ disabled={!hasContent || disabled}
505
+ className={`h-8 w-8 p-0 rounded-full transition-all duration-300 ${
506
+ hasContent && !disabled
507
+ ? 'bg-primary hover:bg-primary/90 text-primary-foreground shadow-lg shadow-primary/30 hover:shadow-primary/40'
508
+ : 'bg-muted text-muted-foreground cursor-not-allowed'
509
+ }`}
510
+ aria-label={t('assistant.sendMessage')}
511
+ >
512
+ <motion.div
513
+ animate={{
514
+ rotate: hasContent ? 0 : -45,
515
+ }}
516
+ transition={{ duration: 0.2 }}
517
+ >
518
+ <Send className="w-4 h-4" />
519
+ </motion.div>
520
+ </Button>
521
+ </motion.div>
522
+ </AnimatePresence>
523
+ </div>
524
+ </div>
525
+ </div>
526
+
527
+ {/* Subtle glow effect when focused */}
528
+ <AnimatePresence>
529
+ {isFocused && (
530
+ <motion.div
531
+ className="absolute inset-0 rounded-[var(--radius)] bg-gradient-to-r from-primary/5 via-transparent to-primary/5 pointer-events-none"
532
+ initial={{ opacity: 0 }}
533
+ animate={{ opacity: 1 }}
534
+ exit={{ opacity: 0 }}
535
+ transition={{ duration: 0.3 }}
536
+ />
537
+ )}
538
+ </AnimatePresence>
539
+ </motion.div>
540
+
541
+ {/* Footer Info */}
542
+ <motion.div
543
+ className="mt-2 text-center"
544
+ initial={{ opacity: 0, y: 5 }}
545
+ animate={{ opacity: 1, y: 0 }}
546
+ transition={{ delay: 0.1 }}
547
+ >
548
+ <p className="text-xs text-muted-foreground">
549
+ {t('assistant.disclaimer')}
550
+ </p>
551
+ </motion.div>
552
+ </div>
553
+ );
554
+ }