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,506 +1,506 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import { createRoot } from 'react-dom/client';
3
- import { cn } from '../../shared/utils';
4
- import { useGoogleMapsLoader } from '../google-maps-loader';
5
- import { useMapLayers, MapLayersConfig } from '../map-layers';
6
-
7
- declare global {
8
- namespace JSX {
9
- interface IntrinsicElements {
10
- 'gmp-map': React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement> & {
11
- 'map-id'?: string;
12
- center?: string | google.maps.LatLng | google.maps.LatLngLiteral;
13
- zoom?: number;
14
- };
15
- 'gmp-advanced-marker': React.DetailedHTMLProps<
16
- React.HTMLAttributes<HTMLElement>,
17
- HTMLElement
18
- > & {
19
- title?: string;
20
- position?: string | google.maps.LatLng | google.maps.LatLngLiteral;
21
- };
22
- }
23
- }
24
- }
25
- export interface MapProps extends React.HTMLAttributes<HTMLDivElement> {
26
- center?: { lat: number; lng: number };
27
- zoom?: number;
28
- mapTypeId?: string;
29
- mapId?: string;
30
- markers?: Array<{
31
- position: { lat: number; lng: number };
32
- label?: string;
33
- title?: string;
34
- info?: string;
35
- customColor?: string;
36
- icon?: string;
37
- iconSvg?: string;
38
- iconColor?: string;
39
- infoWindowContent?: string; // Custom HTML content for InfoWindow
40
- richContent?: React.ReactNode; // Custom React component for InfoWindow
41
- }>;
42
- circle?: {
43
- center: { lat: number; lng: number };
44
- radius: number;
45
- fillColor?: string;
46
- strokeColor?: string;
47
- };
48
- polygon?: {
49
- paths: Array<{ lat: number; lng: number }>[];
50
- fillColor?: string;
51
- strokeColor?: string;
52
- };
53
- layers?: MapLayersConfig;
54
- height?: string;
55
- apiKey?: string;
56
- mapContainerClassName?: string;
57
- disableDefaultUI?: boolean;
58
- zoomControl?: boolean;
59
- streetViewControl?: boolean;
60
- mapTypeControl?: boolean;
61
- fullscreenControl?: boolean;
62
- gestureHandling?: 'cooperative' | 'greedy' | 'none' | 'auto';
63
- onMapLoad?: (map: google.maps.Map) => void;
64
- }
65
-
66
- const DEFAULT_CENTER = { lat: -23.5505, lng: -46.6333 };
67
- const DEFAULT_ZOOM = 12;
68
-
69
- const MapContent = React.forwardRef<HTMLDivElement, MapProps & { apiKey: string }>(
70
- ({ apiKey, ...props }, ref) => {
71
- const { isLoaded, loadError, load } = useGoogleMapsLoader();
72
- const {
73
- center = DEFAULT_CENTER,
74
- zoom = DEFAULT_ZOOM,
75
- markers = [],
76
- circle,
77
- polygon,
78
- layers,
79
- height = '400px',
80
- mapContainerClassName,
81
- disableDefaultUI = false,
82
- zoomControl = true,
83
- streetViewControl = false,
84
- mapTypeControl = false,
85
- fullscreenControl = true,
86
- gestureHandling = 'cooperative',
87
- onMapLoad,
88
- className,
89
- ...divProps
90
- } = props;
91
-
92
- const [selectedMarker, setSelectedMarker] = useState<number | null>(null);
93
- const mapRef = useRef<google.maps.Map | null>(null);
94
- const gmpMapRef = useRef<any>(null); // Ref for custom element
95
- const infoWindowRef = useRef<google.maps.InfoWindow | null>(null);
96
- const circleRef = useRef<google.maps.Circle | null>(null);
97
- const polygonRef = useRef<google.maps.Polygon | null>(null);
98
-
99
- // Resolve theme colors for Map shapes (Circle, Polygon)
100
- const [themeColors, setThemeColors] = useState({
101
- primary: '#4F46E5',
102
- chart2: '#10B981',
103
- });
104
-
105
- useEffect(() => {
106
- if (typeof window !== 'undefined') {
107
- const styles = getComputedStyle(document.documentElement);
108
- setThemeColors({
109
- primary: styles.getPropertyValue('--primary').trim() || '#4F46E5',
110
- chart2: styles.getPropertyValue('--chart-2').trim() || '#10B981',
111
- });
112
- }
113
- }, []);
114
-
115
- // Load API Key
116
- useEffect(() => {
117
- if (!isLoaded && apiKey && !loadError && load) {
118
- load(apiKey).catch(console.error);
119
- }
120
- }, [isLoaded, apiKey, loadError, load]);
121
-
122
- // Handle gmp-map initialization
123
- useEffect(() => {
124
- if (!isLoaded || !gmpMapRef.current) return;
125
-
126
- const gmpMap = gmpMapRef.current;
127
-
128
- // Access the underlying map instance
129
- if (gmpMap.innerMap) {
130
- mapRef.current = gmpMap.innerMap;
131
- if (onMapLoad) {
132
- onMapLoad(gmpMap.innerMap);
133
- }
134
- } else {
135
- // Fallback or wait for it to be ready if needed, usually available immediately after upgrade
136
- // Listener for 'gmp-map-load' doesn't exist standardly, but checking availability
137
- const interval = setInterval(() => {
138
- if (gmpMap.innerMap) {
139
- mapRef.current = gmpMap.innerMap;
140
- if (onMapLoad) {
141
- onMapLoad(gmpMap.innerMap);
142
- }
143
- clearInterval(interval);
144
- }
145
- }, 100);
146
- return () => clearInterval(interval);
147
- }
148
-
149
- return () => {
150
- mapRef.current = null;
151
- };
152
- }, [isLoaded]);
153
-
154
- // Sync properties with gmp-map custom element
155
- useEffect(() => {
156
- if (gmpMapRef.current) {
157
- if (center) gmpMapRef.current.center = center;
158
- }
159
- }, [center]);
160
-
161
- useEffect(() => {
162
- if (gmpMapRef.current) {
163
- if (zoom !== undefined) gmpMapRef.current.zoom = zoom;
164
- }
165
- }, [zoom]);
166
-
167
- useEffect(() => {
168
- if (gmpMapRef.current) {
169
- if (props.mapTypeId) gmpMapRef.current.mapTypeId = props.mapTypeId;
170
- }
171
- }, [props.mapTypeId]);
172
-
173
- // mapId is now set declaratively on the gmp-map element
174
-
175
- // Update Circle (Imperative approach still needed for shapes as there are no gmp-circle elements yet)
176
- useEffect(() => {
177
- const map = mapRef.current;
178
- if (!map || !isLoaded) return;
179
-
180
- circleRef.current?.setMap(null);
181
- circleRef.current = null;
182
-
183
- if (circle && circle.center && circle.radius) {
184
- circleRef.current = new google.maps.Circle({
185
- map,
186
- center: circle.center,
187
- radius: circle.radius,
188
- fillColor: circle.fillColor || themeColors.primary,
189
- fillOpacity: 0.2,
190
- strokeColor: circle.strokeColor || themeColors.primary,
191
- strokeOpacity: 0.8,
192
- strokeWeight: 2,
193
- });
194
- }
195
-
196
- return () => {
197
- circleRef.current?.setMap(null);
198
- };
199
- }, [circle, isLoaded, themeColors, mapRef.current]); // Added mapRef.current dependency
200
-
201
- // Update Polygon (Imperative approach still needed)
202
- useEffect(() => {
203
- const map = mapRef.current;
204
- if (!map || !isLoaded) return;
205
-
206
- polygonRef.current?.setMap(null);
207
- polygonRef.current = null;
208
-
209
- if (polygon && polygon.paths) {
210
- polygonRef.current = new google.maps.Polygon({
211
- map,
212
- paths: polygon.paths,
213
- fillColor: polygon.fillColor || themeColors.chart2,
214
- fillOpacity: 0.2,
215
- strokeColor: polygon.strokeColor || themeColors.chart2,
216
- strokeOpacity: 0.8,
217
- strokeWeight: 2,
218
- });
219
- }
220
-
221
- return () => {
222
- polygonRef.current?.setMap(null);
223
- };
224
- }, [polygon, isLoaded, themeColors, mapRef.current]);
225
-
226
- // Layers
227
- useMapLayers(mapRef.current, layers || {});
228
-
229
- // InfoWindow Management
230
- useEffect(() => {
231
- const map = mapRef.current;
232
- if (!map || selectedMarker === null) {
233
- infoWindowRef.current?.close();
234
- return;
235
- }
236
-
237
- const markerData = markers[selectedMarker];
238
- if (!markerData) return;
239
-
240
- // Note: We can't easily attach InfoWindow to gmp-advanced-marker via `anchor` prop in JS API
241
- // because gmp-advanced-marker is an HTMLElement, not an AdvancedMarkerElement instance directly in the same way.
242
- // However, gmp-advanced-marker has an .innerMarker property which IS the AdvancedMarkerElement.
243
-
244
- // We need references to the marker elements.
245
- // Since we are rendering them declaratively, we need to capture their refs or find them.
246
- // A simple way is to query them or use a callback ref approach in the render loop.
247
- // But here, selectedMarker is an index.
248
-
249
- // Let's defer InfoWindow opening to the click handler of the marker itself
250
- }, [selectedMarker, markers]);
251
-
252
- const handleMarkerClick = (index: number, markerElement: any) => {
253
- setSelectedMarker(index);
254
- const map = mapRef.current;
255
- if (!map) return;
256
-
257
- const markerData = markers[index];
258
- if (!markerData) return;
259
-
260
- // Determine content to render
261
- let contentToRender = markerData.richContent;
262
-
263
- // If no richContent but title/info exists, create default standard content
264
- if (!contentToRender && (markerData.title || markerData.info)) {
265
- contentToRender = (
266
- <div className="p-4 pr-8 min-w-[200px] max-w-[300px]">
267
- {markerData.title && (
268
- <h4 className="font-semibold text-base mb-1">{markerData.title}</h4>
269
- )}
270
- {markerData.info && <p className="text-sm text-muted-foreground">{markerData.info}</p>}
271
- </div>
272
- );
273
- }
274
-
275
- if (contentToRender && markerElement.innerMarker) {
276
- if (!infoWindowRef.current) {
277
- infoWindowRef.current = new google.maps.InfoWindow();
278
- }
279
-
280
- const container = document.createElement('div');
281
- const root = createRoot(container);
282
- root.render(contentToRender);
283
-
284
- infoWindowRef.current.setContent(container);
285
- infoWindowRef.current.open({
286
- map,
287
- anchor: markerElement.innerMarker,
288
- });
289
-
290
- const listener = infoWindowRef.current.addListener('closeclick', () => {
291
- setSelectedMarker(null);
292
- setTimeout(() => root.unmount(), 0);
293
- });
294
- // Cleanup logic for previous opens is tricky with this imperativeness mixed with declarative,
295
- // but 'open' usually closes previous one if same instance.
296
- }
297
- };
298
-
299
- if (loadError) {
300
- return (
301
- <div
302
- ref={ref}
303
- className={cn(
304
- 'relative rounded-[var(--radius-card)] border border-destructive/50 overflow-hidden bg-destructive/5',
305
- className
306
- )}
307
- style={{ height }}
308
- {...divProps}
309
- >
310
- <div className="absolute inset-0 flex items-center justify-center">
311
- <div className="text-center space-y-2 p-6">
312
- <div className="text-destructive">
313
- <svg
314
- className="w-12 h-12 mx-auto"
315
- fill="none"
316
- stroke="currentColor"
317
- viewBox="0 0 24 24"
318
- >
319
- <path
320
- strokeLinecap="round"
321
- strokeLinejoin="round"
322
- strokeWidth={2}
323
- d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"
324
- />
325
- </svg>
326
- </div>
327
- <p className="text-sm font-medium text-foreground">Failed to load Google Maps</p>
328
- <p className="text-xs text-muted-foreground">Check API key in Settings</p>
329
- </div>
330
- </div>
331
- </div>
332
- );
333
- }
334
-
335
- if (!isLoaded) {
336
- return (
337
- <div
338
- ref={ref}
339
- className={cn(
340
- 'relative rounded-[var(--radius-card)] border border-border overflow-hidden bg-muted animate-pulse',
341
- className
342
- )}
343
- style={{ height }}
344
- {...divProps}
345
- />
346
- );
347
- }
348
-
349
- return (
350
- <div
351
- ref={ref}
352
- className={cn(
353
- 'relative rounded-[var(--radius-card)] border border-border overflow-hidden',
354
- className
355
- )}
356
- style={{ height }} // Apply height to container
357
- {...divProps}
358
- >
359
- {/* @ts-ignore - gmp-map is a custom element */}
360
- <gmp-map
361
- ref={gmpMapRef}
362
- style={{ height: '100%', width: '100%', display: 'block' }}
363
- map-id={props.mapId || 'DEMO_MAP_ID'}
364
- >
365
- {markers.map((markerData, idx) => {
366
- const markerColor = markerData.customColor || 'var(--primary)';
367
- const iconColor = markerData.iconColor || 'white';
368
-
369
- // Generate icon/content
370
- // Note: gmp-advanced-marker slot content is the custom marker content
371
- return (
372
- // @ts-ignore
373
- <gmp-advanced-marker
374
- key={idx}
375
- title={markerData.title}
376
- ref={(el: any) => {
377
- if (el) {
378
- el.position = markerData.position;
379
- // Remove previous listener if any (useEffect cleanups handle component unmounts,
380
- // but for ref callback we rely on it being called with null on unmount or re-render)
381
- // However, adding listener repeatedly on re-renders might duplicate if not careful.
382
- // React ref callback is called with null then value on updates if inline function changes.
383
- // Ideally we should use a stable ref or effect, but this simple way works if we assume
384
- // the element is recreated or we accept some overhead.
385
- // Better: just add listener. standard addEventListener doesn't dedupe by default but
386
- // with arrow function it will add new one.
387
- // To be safe and simple: just set properties.
388
- // For event listener, it's safer to not add it here if it's already there?
389
- // Actually, let's just use the property 'onclick' if available? No, custom events.
390
- // We will assume the element is fresh or we don't care too much about duplicate listeners for now
391
- // AS LONG AS we don't create memory leaks.
392
- // A better pattern is to use a Map<Element, Handler> to manage listeners but let's stick to simple first.
393
- el.addEventListener('gmp-click', () => handleMarkerClick(idx, el));
394
- }
395
- }}
396
- >
397
- <div
398
- className="flex items-center justify-center w-8 h-8 border-[3px] border-background shadow-lg cursor-pointer origin-center transition-transform duration-200"
399
- style={{
400
- borderRadius: '50% 50% 50% 0',
401
- transform: 'rotate(-45deg)',
402
- backgroundColor: markerColor,
403
- }}
404
- >
405
- <div className="flex items-center justify-center rotate-45">
406
- {markerData.iconSvg ? (
407
- <div
408
- dangerouslySetInnerHTML={{ __html: markerData.iconSvg }}
409
- style={{ color: iconColor, width: 16, height: 16, fill: 'currentColor' }}
410
- />
411
- ) : (
412
- <span className="font-semibold text-sm" style={{ color: iconColor }}>
413
- {markerData.icon || markerData.label || ''}
414
- </span>
415
- )}
416
- </div>
417
- </div>
418
- </gmp-advanced-marker>
419
- );
420
- })}
421
- </gmp-map>
422
- </div>
423
- );
424
- }
425
- );
426
- MapContent.displayName = 'MapContent';
427
-
428
- /**
429
- * Primary Google Maps component.
430
- *
431
- * @description
432
- * Supports Advanced Markers, Circles, Polygons, and custom tile Layers.
433
- * Automatically loads the Google Maps JavaScript API via `useGoogleMapsLoader`.
434
- *
435
- * @ai-rules
436
- * 1. REQUIRED: Provide a valid `apiKey` via prop or the `VITE_GOOGLE_MAPS_API_KEY` environment variable.
437
- * 2. Use the `markers` prop to render points of interest. Supports `richContent` for React-based InfoWindows.
438
- * 3. Always set `height` explicitly (default is 400px) to ensure the map is visible in the layout.
439
- */
440
- export const Map = React.forwardRef<HTMLDivElement, MapProps>((props, ref) => {
441
- const { isLoaded, loadError } = useGoogleMapsLoader();
442
- const effectiveApiKey =
443
- props.apiKey ||
444
- (typeof import.meta !== 'undefined' &&
445
- import.meta.env &&
446
- import.meta.env.VITE_GOOGLE_MAPS_API_KEY) ||
447
- '';
448
-
449
- const isValidKey =
450
- effectiveApiKey &&
451
- effectiveApiKey !== 'YOUR_GOOGLE_MAPS_API_KEY_HERE' &&
452
- effectiveApiKey.startsWith('AIza');
453
-
454
- if (isLoaded || isValidKey || loadError) {
455
- return <MapContent ref={ref} {...props} apiKey={effectiveApiKey} />;
456
- }
457
-
458
- // Check if the script is injected in the DOM (loading via provider)
459
- const isScriptInjected =
460
- typeof document !== 'undefined' &&
461
- !!document.querySelector('script[src*="maps.googleapis.com/maps/api/js"]');
462
-
463
- if (isScriptInjected) {
464
- // Let MapContent show the loading skeleton
465
- return <MapContent ref={ref} {...props} apiKey={effectiveApiKey} />;
466
- }
467
-
468
- return (
469
- <div
470
- ref={ref}
471
- className={cn(
472
- 'relative rounded-[var(--radius-card)] border border-border overflow-hidden bg-muted',
473
- props.className
474
- )}
475
- style={{ height: props.height || '400px' }}
476
- >
477
- <div className="absolute inset-0 flex items-center justify-center bg-muted">
478
- <div className="text-center space-y-3 p-6">
479
- <div className="w-16 h-16 mx-auto bg-primary/10 rounded-full flex items-center justify-center">
480
- <svg
481
- className="w-8 h-8 text-primary"
482
- fill="none"
483
- stroke="currentColor"
484
- viewBox="0 0 24 24"
485
- >
486
- <path
487
- strokeLinecap="round"
488
- strokeLinejoin="round"
489
- strokeWidth={2}
490
- d="M17.657 16.657L13.414 20.9a1.998 1.998 0 01-2.827 0l-4.244-4.243a8 8 0 1111.314 0z"
491
- />
492
- <path
493
- strokeLinecap="round"
494
- strokeLinejoin="round"
495
- strokeWidth={2}
496
- d="M15 11a3 3 0 11-6 0 3 3 0 016 0z"
497
- />
498
- </svg>
499
- </div>
500
- <p className="text-sm text-muted-foreground">Configure Google Maps API Key in Settings</p>
501
- </div>
502
- </div>
503
- </div>
504
- );
505
- });
506
- Map.displayName = 'Map';
1
+ import React, { useEffect, useRef, useState } from 'react';
2
+ import { createRoot } from 'react-dom/client';
3
+ import { cn } from '../../shared/utils';
4
+ import { useGoogleMapsLoader } from '../google-maps-loader';
5
+ import { useMapLayers, MapLayersConfig } from '../map-layers';
6
+
7
+ declare global {
8
+ namespace JSX {
9
+ interface IntrinsicElements {
10
+ 'gmp-map': React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement> & {
11
+ 'map-id'?: string;
12
+ center?: string | google.maps.LatLng | google.maps.LatLngLiteral;
13
+ zoom?: number;
14
+ };
15
+ 'gmp-advanced-marker': React.DetailedHTMLProps<
16
+ React.HTMLAttributes<HTMLElement>,
17
+ HTMLElement
18
+ > & {
19
+ title?: string;
20
+ position?: string | google.maps.LatLng | google.maps.LatLngLiteral;
21
+ };
22
+ }
23
+ }
24
+ }
25
+ export interface MapProps extends React.HTMLAttributes<HTMLDivElement> {
26
+ center?: { lat: number; lng: number };
27
+ zoom?: number;
28
+ mapTypeId?: string;
29
+ mapId?: string;
30
+ markers?: Array<{
31
+ position: { lat: number; lng: number };
32
+ label?: string;
33
+ title?: string;
34
+ info?: string;
35
+ customColor?: string;
36
+ icon?: string;
37
+ iconSvg?: string;
38
+ iconColor?: string;
39
+ infoWindowContent?: string; // Custom HTML content for InfoWindow
40
+ richContent?: React.ReactNode; // Custom React component for InfoWindow
41
+ }>;
42
+ circle?: {
43
+ center: { lat: number; lng: number };
44
+ radius: number;
45
+ fillColor?: string;
46
+ strokeColor?: string;
47
+ };
48
+ polygon?: {
49
+ paths: Array<{ lat: number; lng: number }>[];
50
+ fillColor?: string;
51
+ strokeColor?: string;
52
+ };
53
+ layers?: MapLayersConfig;
54
+ height?: string;
55
+ apiKey?: string;
56
+ mapContainerClassName?: string;
57
+ disableDefaultUI?: boolean;
58
+ zoomControl?: boolean;
59
+ streetViewControl?: boolean;
60
+ mapTypeControl?: boolean;
61
+ fullscreenControl?: boolean;
62
+ gestureHandling?: 'cooperative' | 'greedy' | 'none' | 'auto';
63
+ onMapLoad?: (map: google.maps.Map) => void;
64
+ }
65
+
66
+ const DEFAULT_CENTER = { lat: -23.5505, lng: -46.6333 };
67
+ const DEFAULT_ZOOM = 12;
68
+
69
+ const MapContent = React.forwardRef<HTMLDivElement, MapProps & { apiKey: string }>(
70
+ ({ apiKey, ...props }, ref) => {
71
+ const { isLoaded, loadError, load } = useGoogleMapsLoader();
72
+ const {
73
+ center = DEFAULT_CENTER,
74
+ zoom = DEFAULT_ZOOM,
75
+ markers = [],
76
+ circle,
77
+ polygon,
78
+ layers,
79
+ height = '400px',
80
+ mapContainerClassName,
81
+ disableDefaultUI = false,
82
+ zoomControl = true,
83
+ streetViewControl = false,
84
+ mapTypeControl = false,
85
+ fullscreenControl = true,
86
+ gestureHandling = 'cooperative',
87
+ onMapLoad,
88
+ className,
89
+ ...divProps
90
+ } = props;
91
+
92
+ const [selectedMarker, setSelectedMarker] = useState<number | null>(null);
93
+ const mapRef = useRef<google.maps.Map | null>(null);
94
+ const gmpMapRef = useRef<any>(null); // Ref for custom element
95
+ const infoWindowRef = useRef<google.maps.InfoWindow | null>(null);
96
+ const circleRef = useRef<google.maps.Circle | null>(null);
97
+ const polygonRef = useRef<google.maps.Polygon | null>(null);
98
+
99
+ // Resolve theme colors for Map shapes (Circle, Polygon)
100
+ const [themeColors, setThemeColors] = useState({
101
+ primary: '#4F46E5',
102
+ chart2: '#10B981',
103
+ });
104
+
105
+ useEffect(() => {
106
+ if (typeof window !== 'undefined') {
107
+ const styles = getComputedStyle(document.documentElement);
108
+ setThemeColors({
109
+ primary: styles.getPropertyValue('--primary').trim() || '#4F46E5',
110
+ chart2: styles.getPropertyValue('--chart-2').trim() || '#10B981',
111
+ });
112
+ }
113
+ }, []);
114
+
115
+ // Load API Key
116
+ useEffect(() => {
117
+ if (!isLoaded && apiKey && !loadError && load) {
118
+ load(apiKey).catch(console.error);
119
+ }
120
+ }, [isLoaded, apiKey, loadError, load]);
121
+
122
+ // Handle gmp-map initialization
123
+ useEffect(() => {
124
+ if (!isLoaded || !gmpMapRef.current) return;
125
+
126
+ const gmpMap = gmpMapRef.current;
127
+
128
+ // Access the underlying map instance
129
+ if (gmpMap.innerMap) {
130
+ mapRef.current = gmpMap.innerMap;
131
+ if (onMapLoad) {
132
+ onMapLoad(gmpMap.innerMap);
133
+ }
134
+ } else {
135
+ // Fallback or wait for it to be ready if needed, usually available immediately after upgrade
136
+ // Listener for 'gmp-map-load' doesn't exist standardly, but checking availability
137
+ const interval = setInterval(() => {
138
+ if (gmpMap.innerMap) {
139
+ mapRef.current = gmpMap.innerMap;
140
+ if (onMapLoad) {
141
+ onMapLoad(gmpMap.innerMap);
142
+ }
143
+ clearInterval(interval);
144
+ }
145
+ }, 100);
146
+ return () => clearInterval(interval);
147
+ }
148
+
149
+ return () => {
150
+ mapRef.current = null;
151
+ };
152
+ }, [isLoaded]);
153
+
154
+ // Sync properties with gmp-map custom element
155
+ useEffect(() => {
156
+ if (gmpMapRef.current) {
157
+ if (center) gmpMapRef.current.center = center;
158
+ }
159
+ }, [center]);
160
+
161
+ useEffect(() => {
162
+ if (gmpMapRef.current) {
163
+ if (zoom !== undefined) gmpMapRef.current.zoom = zoom;
164
+ }
165
+ }, [zoom]);
166
+
167
+ useEffect(() => {
168
+ if (gmpMapRef.current) {
169
+ if (props.mapTypeId) gmpMapRef.current.mapTypeId = props.mapTypeId;
170
+ }
171
+ }, [props.mapTypeId]);
172
+
173
+ // mapId is now set declaratively on the gmp-map element
174
+
175
+ // Update Circle (Imperative approach still needed for shapes as there are no gmp-circle elements yet)
176
+ useEffect(() => {
177
+ const map = mapRef.current;
178
+ if (!map || !isLoaded) return;
179
+
180
+ circleRef.current?.setMap(null);
181
+ circleRef.current = null;
182
+
183
+ if (circle && circle.center && circle.radius) {
184
+ circleRef.current = new google.maps.Circle({
185
+ map,
186
+ center: circle.center,
187
+ radius: circle.radius,
188
+ fillColor: circle.fillColor || themeColors.primary,
189
+ fillOpacity: 0.2,
190
+ strokeColor: circle.strokeColor || themeColors.primary,
191
+ strokeOpacity: 0.8,
192
+ strokeWeight: 2,
193
+ });
194
+ }
195
+
196
+ return () => {
197
+ circleRef.current?.setMap(null);
198
+ };
199
+ }, [circle, isLoaded, themeColors, mapRef.current]); // Added mapRef.current dependency
200
+
201
+ // Update Polygon (Imperative approach still needed)
202
+ useEffect(() => {
203
+ const map = mapRef.current;
204
+ if (!map || !isLoaded) return;
205
+
206
+ polygonRef.current?.setMap(null);
207
+ polygonRef.current = null;
208
+
209
+ if (polygon && polygon.paths) {
210
+ polygonRef.current = new google.maps.Polygon({
211
+ map,
212
+ paths: polygon.paths,
213
+ fillColor: polygon.fillColor || themeColors.chart2,
214
+ fillOpacity: 0.2,
215
+ strokeColor: polygon.strokeColor || themeColors.chart2,
216
+ strokeOpacity: 0.8,
217
+ strokeWeight: 2,
218
+ });
219
+ }
220
+
221
+ return () => {
222
+ polygonRef.current?.setMap(null);
223
+ };
224
+ }, [polygon, isLoaded, themeColors, mapRef.current]);
225
+
226
+ // Layers
227
+ useMapLayers(mapRef.current, layers || {});
228
+
229
+ // InfoWindow Management
230
+ useEffect(() => {
231
+ const map = mapRef.current;
232
+ if (!map || selectedMarker === null) {
233
+ infoWindowRef.current?.close();
234
+ return;
235
+ }
236
+
237
+ const markerData = markers[selectedMarker];
238
+ if (!markerData) return;
239
+
240
+ // Note: We can't easily attach InfoWindow to gmp-advanced-marker via `anchor` prop in JS API
241
+ // because gmp-advanced-marker is an HTMLElement, not an AdvancedMarkerElement instance directly in the same way.
242
+ // However, gmp-advanced-marker has an .innerMarker property which IS the AdvancedMarkerElement.
243
+
244
+ // We need references to the marker elements.
245
+ // Since we are rendering them declaratively, we need to capture their refs or find them.
246
+ // A simple way is to query them or use a callback ref approach in the render loop.
247
+ // But here, selectedMarker is an index.
248
+
249
+ // Let's defer InfoWindow opening to the click handler of the marker itself
250
+ }, [selectedMarker, markers]);
251
+
252
+ const handleMarkerClick = (index: number, markerElement: any) => {
253
+ setSelectedMarker(index);
254
+ const map = mapRef.current;
255
+ if (!map) return;
256
+
257
+ const markerData = markers[index];
258
+ if (!markerData) return;
259
+
260
+ // Determine content to render
261
+ let contentToRender = markerData.richContent;
262
+
263
+ // If no richContent but title/info exists, create default standard content
264
+ if (!contentToRender && (markerData.title || markerData.info)) {
265
+ contentToRender = (
266
+ <div className="p-4 pr-8 min-w-[200px] max-w-[300px]">
267
+ {markerData.title && (
268
+ <h4 className="font-semibold text-base mb-1">{markerData.title}</h4>
269
+ )}
270
+ {markerData.info && <p className="text-sm text-muted-foreground">{markerData.info}</p>}
271
+ </div>
272
+ );
273
+ }
274
+
275
+ if (contentToRender && markerElement.innerMarker) {
276
+ if (!infoWindowRef.current) {
277
+ infoWindowRef.current = new google.maps.InfoWindow();
278
+ }
279
+
280
+ const container = document.createElement('div');
281
+ const root = createRoot(container);
282
+ root.render(contentToRender);
283
+
284
+ infoWindowRef.current.setContent(container);
285
+ infoWindowRef.current.open({
286
+ map,
287
+ anchor: markerElement.innerMarker,
288
+ });
289
+
290
+ const listener = infoWindowRef.current.addListener('closeclick', () => {
291
+ setSelectedMarker(null);
292
+ setTimeout(() => root.unmount(), 0);
293
+ });
294
+ // Cleanup logic for previous opens is tricky with this imperativeness mixed with declarative,
295
+ // but 'open' usually closes previous one if same instance.
296
+ }
297
+ };
298
+
299
+ if (loadError) {
300
+ return (
301
+ <div
302
+ ref={ref}
303
+ className={cn(
304
+ 'relative rounded-[var(--radius-card)] border border-destructive/50 overflow-hidden bg-destructive/5',
305
+ className
306
+ )}
307
+ style={{ height }}
308
+ {...divProps}
309
+ >
310
+ <div className="absolute inset-0 flex items-center justify-center">
311
+ <div className="text-center space-y-2 p-6">
312
+ <div className="text-destructive">
313
+ <svg
314
+ className="w-12 h-12 mx-auto"
315
+ fill="none"
316
+ stroke="currentColor"
317
+ viewBox="0 0 24 24"
318
+ >
319
+ <path
320
+ strokeLinecap="round"
321
+ strokeLinejoin="round"
322
+ strokeWidth={2}
323
+ d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"
324
+ />
325
+ </svg>
326
+ </div>
327
+ <p className="text-sm font-medium text-foreground">Failed to load Google Maps</p>
328
+ <p className="text-xs text-muted-foreground">Check API key in Settings</p>
329
+ </div>
330
+ </div>
331
+ </div>
332
+ );
333
+ }
334
+
335
+ if (!isLoaded) {
336
+ return (
337
+ <div
338
+ ref={ref}
339
+ className={cn(
340
+ 'relative rounded-[var(--radius-card)] border border-border overflow-hidden bg-muted animate-pulse',
341
+ className
342
+ )}
343
+ style={{ height }}
344
+ {...divProps}
345
+ />
346
+ );
347
+ }
348
+
349
+ return (
350
+ <div
351
+ ref={ref}
352
+ className={cn(
353
+ 'relative rounded-[var(--radius-card)] border border-border overflow-hidden',
354
+ className
355
+ )}
356
+ style={{ height }} // Apply height to container
357
+ {...divProps}
358
+ >
359
+ {/* @ts-ignore - gmp-map is a custom element */}
360
+ <gmp-map
361
+ ref={gmpMapRef}
362
+ style={{ height: '100%', width: '100%', display: 'block' }}
363
+ map-id={props.mapId || 'DEMO_MAP_ID'}
364
+ >
365
+ {markers.map((markerData, idx) => {
366
+ const markerColor = markerData.customColor || 'var(--primary)';
367
+ const iconColor = markerData.iconColor || 'white';
368
+
369
+ // Generate icon/content
370
+ // Note: gmp-advanced-marker slot content is the custom marker content
371
+ return (
372
+ // @ts-ignore
373
+ <gmp-advanced-marker
374
+ key={idx}
375
+ title={markerData.title}
376
+ ref={(el: any) => {
377
+ if (el) {
378
+ el.position = markerData.position;
379
+ // Remove previous listener if any (useEffect cleanups handle component unmounts,
380
+ // but for ref callback we rely on it being called with null on unmount or re-render)
381
+ // However, adding listener repeatedly on re-renders might duplicate if not careful.
382
+ // React ref callback is called with null then value on updates if inline function changes.
383
+ // Ideally we should use a stable ref or effect, but this simple way works if we assume
384
+ // the element is recreated or we accept some overhead.
385
+ // Better: just add listener. standard addEventListener doesn't dedupe by default but
386
+ // with arrow function it will add new one.
387
+ // To be safe and simple: just set properties.
388
+ // For event listener, it's safer to not add it here if it's already there?
389
+ // Actually, let's just use the property 'onclick' if available? No, custom events.
390
+ // We will assume the element is fresh or we don't care too much about duplicate listeners for now
391
+ // AS LONG AS we don't create memory leaks.
392
+ // A better pattern is to use a Map<Element, Handler> to manage listeners but let's stick to simple first.
393
+ el.addEventListener('gmp-click', () => handleMarkerClick(idx, el));
394
+ }
395
+ }}
396
+ >
397
+ <div
398
+ className="flex items-center justify-center w-8 h-8 border-[3px] border-background shadow-lg cursor-pointer origin-center transition-transform duration-200"
399
+ style={{
400
+ borderRadius: '50% 50% 50% 0',
401
+ transform: 'rotate(-45deg)',
402
+ backgroundColor: markerColor,
403
+ }}
404
+ >
405
+ <div className="flex items-center justify-center rotate-45">
406
+ {markerData.iconSvg ? (
407
+ <div
408
+ dangerouslySetInnerHTML={{ __html: markerData.iconSvg }}
409
+ style={{ color: iconColor, width: 16, height: 16, fill: 'currentColor' }}
410
+ />
411
+ ) : (
412
+ <span className="font-semibold text-sm" style={{ color: iconColor }}>
413
+ {markerData.icon || markerData.label || ''}
414
+ </span>
415
+ )}
416
+ </div>
417
+ </div>
418
+ </gmp-advanced-marker>
419
+ );
420
+ })}
421
+ </gmp-map>
422
+ </div>
423
+ );
424
+ }
425
+ );
426
+ MapContent.displayName = 'MapContent';
427
+
428
+ /**
429
+ * Primary Google Maps component.
430
+ *
431
+ * @description
432
+ * Supports Advanced Markers, Circles, Polygons, and custom tile Layers.
433
+ * Automatically loads the Google Maps JavaScript API via `useGoogleMapsLoader`.
434
+ *
435
+ * @ai-rules
436
+ * 1. REQUIRED: Provide a valid `apiKey` via prop or the `VITE_GOOGLE_MAPS_API_KEY` environment variable.
437
+ * 2. Use the `markers` prop to render points of interest. Supports `richContent` for React-based InfoWindows.
438
+ * 3. Always set `height` explicitly (default is 400px) to ensure the map is visible in the layout.
439
+ */
440
+ export const Map = React.forwardRef<HTMLDivElement, MapProps>((props, ref) => {
441
+ const { isLoaded, loadError } = useGoogleMapsLoader();
442
+ const effectiveApiKey =
443
+ props.apiKey ||
444
+ (typeof import.meta !== 'undefined' &&
445
+ import.meta.env &&
446
+ import.meta.env.VITE_GOOGLE_MAPS_API_KEY) ||
447
+ '';
448
+
449
+ const isValidKey =
450
+ effectiveApiKey &&
451
+ effectiveApiKey !== 'YOUR_GOOGLE_MAPS_API_KEY_HERE' &&
452
+ effectiveApiKey.startsWith('AIza');
453
+
454
+ if (isLoaded || isValidKey || loadError) {
455
+ return <MapContent ref={ref} {...props} apiKey={effectiveApiKey} />;
456
+ }
457
+
458
+ // Check if the script is injected in the DOM (loading via provider)
459
+ const isScriptInjected =
460
+ typeof document !== 'undefined' &&
461
+ !!document.querySelector('script[src*="maps.googleapis.com/maps/api/js"]');
462
+
463
+ if (isScriptInjected) {
464
+ // Let MapContent show the loading skeleton
465
+ return <MapContent ref={ref} {...props} apiKey={effectiveApiKey} />;
466
+ }
467
+
468
+ return (
469
+ <div
470
+ ref={ref}
471
+ className={cn(
472
+ 'relative rounded-[var(--radius-card)] border border-border overflow-hidden bg-muted',
473
+ props.className
474
+ )}
475
+ style={{ height: props.height || '400px' }}
476
+ >
477
+ <div className="absolute inset-0 flex items-center justify-center bg-muted">
478
+ <div className="text-center space-y-3 p-6">
479
+ <div className="w-16 h-16 mx-auto bg-primary/10 rounded-full flex items-center justify-center">
480
+ <svg
481
+ className="w-8 h-8 text-primary"
482
+ fill="none"
483
+ stroke="currentColor"
484
+ viewBox="0 0 24 24"
485
+ >
486
+ <path
487
+ strokeLinecap="round"
488
+ strokeLinejoin="round"
489
+ strokeWidth={2}
490
+ d="M17.657 16.657L13.414 20.9a1.998 1.998 0 01-2.827 0l-4.244-4.243a8 8 0 1111.314 0z"
491
+ />
492
+ <path
493
+ strokeLinecap="round"
494
+ strokeLinejoin="round"
495
+ strokeWidth={2}
496
+ d="M15 11a3 3 0 11-6 0 3 3 0 016 0z"
497
+ />
498
+ </svg>
499
+ </div>
500
+ <p className="text-sm text-muted-foreground">Configure Google Maps API Key in Settings</p>
501
+ </div>
502
+ </div>
503
+ </div>
504
+ );
505
+ });
506
+ Map.displayName = 'Map';