xertica-ui 2.3.0 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (534) hide show
  1. package/CHANGELOG.md +564 -552
  2. package/README.md +417 -406
  3. package/assets/xertica-logo.svg +37 -37
  4. package/assets/xertica-x-logo.svg +20 -20
  5. package/bin/cli.ts +1244 -1155
  6. package/bin/language-config.ts +358 -361
  7. package/components/assistant/code-block/CodeBlock.tsx +268 -268
  8. package/components/assistant/formatted-document/FormattedDocument.tsx +147 -147
  9. package/components/assistant/modern-chat-input/ModernChatInput.tsx +564 -554
  10. package/components/assistant/xertica-assistant/parts/AssistantCollapsedView.tsx +99 -99
  11. package/components/assistant/xertica-assistant/parts/AssistantConversationList.tsx +104 -106
  12. package/components/assistant/xertica-assistant/parts/AssistantDocumentEditor.tsx +81 -81
  13. package/components/assistant/xertica-assistant/parts/AssistantFeedbackDialog.tsx +88 -78
  14. package/components/assistant/xertica-assistant/parts/AssistantHeader.tsx +75 -75
  15. package/components/assistant/xertica-assistant/parts/AssistantMessageBubble.tsx +564 -560
  16. package/components/assistant/xertica-assistant/parts/AssistantTabBar.tsx +67 -67
  17. package/components/assistant/xertica-assistant/parts/AssistantWelcomeScreen.tsx +103 -103
  18. package/components/assistant/xertica-assistant/use-assistant.ts +615 -615
  19. package/components/assistant/xertica-assistant/xertica-assistant.tsx +611 -613
  20. package/components/blocks/card-patterns/ActivityCard.tsx +100 -100
  21. package/components/blocks/card-patterns/ActivityCardSkeleton.tsx +56 -56
  22. package/components/blocks/card-patterns/FeatureCardSkeleton.tsx +58 -63
  23. package/components/blocks/card-patterns/NotificationCard.tsx +140 -140
  24. package/components/blocks/card-patterns/NotificationCardSkeleton.tsx +81 -81
  25. package/components/blocks/card-patterns/ProfileCard.tsx +112 -114
  26. package/components/blocks/card-patterns/ProfileCardSkeleton.tsx +69 -69
  27. package/components/blocks/card-patterns/ProjectCard.tsx +123 -123
  28. package/components/blocks/card-patterns/ProjectCardSkeleton.tsx +67 -72
  29. package/components/blocks/card-patterns/QuickActionCardSkeleton.tsx +44 -44
  30. package/components/blocks/card-patterns/card-patterns.stories.tsx +594 -594
  31. package/components/blocks/card-patterns/index.ts +29 -29
  32. package/components/brand/language-selector/LanguageSelector.tsx +102 -102
  33. package/components/brand/language-selector/language-selector.stories.tsx +111 -114
  34. package/components/brand/language-selector/language-selector.test.tsx +101 -101
  35. package/components/brand/theme-toggle/ThemeToggle.tsx +74 -70
  36. package/components/brand/xertica-provider/XerticaProvider.tsx +109 -112
  37. package/components/brand/xertica-provider/xertica-provider.mdx +61 -61
  38. package/components/index.ts +86 -90
  39. package/components/layout/sidebar/sidebar.mdx +1 -1
  40. package/components/layout/sidebar/sidebar.tsx +1079 -1073
  41. package/components/media/FloatingMediaWrapper.tsx +371 -371
  42. package/components/media/audio-player/AudioPlayer.tsx +768 -766
  43. package/components/media/video-player/VideoPlayer.tsx +310 -310
  44. package/components/pages/forgot-password-page/ForgotPasswordPage.tsx +1 -1
  45. package/components/pages/home-content/HomeContent.tsx +120 -120
  46. package/components/pages/home-content/home-content.mdx +62 -62
  47. package/components/pages/home-page/HomePage.tsx +78 -74
  48. package/components/pages/home-page/home-page.mdx +53 -53
  49. package/components/pages/login-page/LoginPage.tsx +218 -216
  50. package/components/pages/reset-password-page/ResetPasswordPage.tsx +243 -239
  51. package/components/pages/template-content/TemplateContent.tsx +1354 -1235
  52. package/components/pages/template-content/template-content.mdx +61 -61
  53. package/components/pages/template-page/template-page.mdx +53 -53
  54. package/components/pages/verify-email-page/VerifyEmailPage.tsx +206 -206
  55. package/components/shared/error-boundary.stories.tsx +4 -22
  56. package/components/shared/error-boundary.tsx +1 -5
  57. package/components/shared/error-fallbacks.tsx +4 -8
  58. package/components/ui/accordion/accordion.mdx +8 -8
  59. package/components/ui/alert/alert.mdx +8 -8
  60. package/components/ui/alert-dialog/alert-dialog.mdx +8 -8
  61. package/components/ui/aspect-ratio/aspect-ratio.mdx +8 -8
  62. package/components/ui/assistant-chart/assistant-chart.mdx +8 -8
  63. package/components/ui/avatar/avatar.mdx +8 -8
  64. package/components/ui/badge/badge.mdx +8 -8
  65. package/components/ui/breadcrumb/breadcrumb.mdx +8 -8
  66. package/components/ui/button/button.mdx +8 -8
  67. package/components/ui/calendar/calendar.mdx +8 -8
  68. package/components/ui/card/card.mdx +8 -8
  69. package/components/ui/carousel/carousel.mdx +8 -8
  70. package/components/ui/chart/chart.mdx +8 -8
  71. package/components/ui/checkbox/checkbox.mdx +8 -8
  72. package/components/ui/collapsible/collapsible.mdx +8 -8
  73. package/components/ui/command/command.mdx +8 -8
  74. package/components/ui/context-menu/context-menu.mdx +8 -8
  75. package/components/ui/dialog/dialog.mdx +8 -8
  76. package/components/ui/drawer/drawer.mdx +8 -8
  77. package/components/ui/dropdown-menu/dropdown-menu.mdx +8 -8
  78. package/components/ui/empty/empty.mdx +8 -8
  79. package/components/ui/file-upload/file-upload.mdx +8 -8
  80. package/components/ui/hover-card/hover-card.mdx +8 -8
  81. package/components/ui/input/input.mdx +8 -8
  82. package/components/ui/input-otp/input-otp.mdx +8 -8
  83. package/components/ui/label/label.mdx +8 -8
  84. package/components/ui/map/map.mdx +8 -8
  85. package/components/ui/menubar/menubar.mdx +8 -8
  86. package/components/ui/navigation-menu/navigation-menu.mdx +8 -8
  87. package/components/ui/notification-badge/notification-badge.mdx +8 -8
  88. package/components/ui/pagination/pagination.mdx +8 -8
  89. package/components/ui/popover/popover.mdx +8 -8
  90. package/components/ui/progress/progress.mdx +8 -8
  91. package/components/ui/radio-group/radio-group.mdx +8 -8
  92. package/components/ui/rating/rating.mdx +8 -8
  93. package/components/ui/resizable/resizable.mdx +8 -8
  94. package/components/ui/route-map/route-map.mdx +8 -8
  95. package/components/ui/scroll-area/scroll-area.mdx +8 -8
  96. package/components/ui/search/search.mdx +8 -8
  97. package/components/ui/select/select.mdx +8 -8
  98. package/components/ui/separator/separator.mdx +8 -8
  99. package/components/ui/sheet/sheet.mdx +8 -8
  100. package/components/ui/simple-map/simple-map.mdx +8 -8
  101. package/components/ui/skeleton/skeleton.mdx +8 -8
  102. package/components/ui/slider/slider.mdx +8 -8
  103. package/components/ui/sonner/sonner.mdx +8 -8
  104. package/components/ui/stats-card/index.ts +2 -2
  105. package/components/ui/stats-card/stats-card-skeleton.tsx +60 -62
  106. package/components/ui/stats-card/stats-card.mdx +8 -8
  107. package/components/ui/stats-card/stats-card.stories.tsx +99 -99
  108. package/components/ui/stepper/stepper.mdx +8 -8
  109. package/components/ui/switch/switch.mdx +8 -8
  110. package/components/ui/table/table.mdx +8 -8
  111. package/components/ui/tabs/tabs.mdx +8 -8
  112. package/components/ui/textarea/textarea.mdx +8 -8
  113. package/components/ui/timeline/timeline.mdx +8 -8
  114. package/components/ui/toggle/toggle.mdx +8 -8
  115. package/components/ui/toggle-group/toggle-group.mdx +8 -8
  116. package/components/ui/tooltip/tooltip.mdx +8 -8
  117. package/components/ui/tree-view/tree-view.mdx +8 -8
  118. package/components.json +892 -892
  119. package/contexts/AuthContext.tsx +11 -8
  120. package/contexts/LanguageContext.test.tsx +121 -121
  121. package/contexts/LanguageContext.tsx +250 -251
  122. package/dist/{AssistantChart-DoZCyS5r.cjs → AssistantChart-9w31gdAb.cjs} +4 -4
  123. package/dist/{AssistantChart-CldVCVDe.cjs → AssistantChart-BAudAfne.cjs} +5 -5
  124. package/dist/{AssistantChart-Bdd44uBn.cjs → AssistantChart-BAx9VQvb.cjs} +127 -388
  125. package/dist/{AssistantChart-Cu3m7RBo.js → AssistantChart-BP8upjMk.js} +5 -5
  126. package/dist/{AssistantChart-CFhDdGyU.js → AssistantChart-CVko2A1W.js} +130 -391
  127. package/dist/{AssistantChart-C_hwFRRr.js → AssistantChart-CVzmmhx4.js} +4 -4
  128. package/dist/{AudioPlayer-IAU5q5T1.cjs → AudioPlayer-1ypwE2Wh.cjs} +1 -1
  129. package/dist/{AudioPlayer-CGRUtUdN.js → AudioPlayer-DuKXrCfy.js} +1 -1
  130. package/dist/{LanguageContext-CS14yCpi.js → LanguageContext-BwhwC3G2.js} +2 -2
  131. package/dist/{LanguageContext-B_KFTCzT.cjs → LanguageContext-DvUt5jBg.cjs} +2 -2
  132. package/dist/{ThemeContext-C2EwAPDt.js → ThemeContext-BbBNoFTG.js} +2 -2
  133. package/dist/{ThemeContext-Bmod0Cg2.cjs → ThemeContext-BblcjQup.cjs} +13 -8
  134. package/dist/{ThemeContext-BWq9ACPo.js → ThemeContext-Bo-W2WZH.js} +13 -8
  135. package/dist/{ThemeContext-j5aGtPky.cjs → ThemeContext-CP3a0jxy.cjs} +193 -262
  136. package/dist/{ThemeContext-vTjumZeM.cjs → ThemeContext-Cmr8Ex8H.cjs} +2 -2
  137. package/dist/ThemeContext-CpqYShLq.cjs +324 -0
  138. package/dist/{ThemeContext-CQSo4Iwc.js → ThemeContext-D3LzacmG.js} +8 -1
  139. package/dist/ThemeContext-Du2nE1PL.js +325 -0
  140. package/dist/ThemeContext-GeEBTJ3q.cjs +1621 -0
  141. package/dist/ThemeContext-JyLK9B1o.js +1622 -0
  142. package/dist/{ThemeContext-CGk3KK0k.cjs → ThemeContext-U4dEYc6C.cjs} +8 -1
  143. package/dist/{ThemeContext-BXjrgUjW.js → ThemeContext-ept8jhXI.js} +200 -261
  144. package/dist/{VerifyEmailPage-C0c2e5n0.js → VerifyEmailPage-BE-L9mB7.js} +7 -7
  145. package/dist/{VerifyEmailPage-DSBMRHtl.js → VerifyEmailPage-BIBOKV7Z.js} +41 -36
  146. package/dist/{VerifyEmailPage-DgIid028.js → VerifyEmailPage-BJjAMUTW.js} +4 -4
  147. package/dist/{VerifyEmailPage--1Vurewl.cjs → VerifyEmailPage-BRSP-Pwt.cjs} +3 -3
  148. package/dist/{VerifyEmailPage-Cwi3kbol.cjs → VerifyEmailPage-Bae2cBXT.cjs} +7 -7
  149. package/dist/{VerifyEmailPage-De6bQjrz.cjs → VerifyEmailPage-BiRm7Nh4.cjs} +41 -36
  150. package/dist/{VerifyEmailPage-ByerOcm4.cjs → VerifyEmailPage-Bv8Ah_TK.cjs} +23 -20
  151. package/dist/VerifyEmailPage-Bvfv8HVQ.js +3214 -0
  152. package/dist/{VerifyEmailPage-BComraR7.cjs → VerifyEmailPage-CR7kb5df.cjs} +22 -12
  153. package/dist/{VerifyEmailPage-MTD7AG1Z.js → VerifyEmailPage-C_ihbcth.js} +4 -4
  154. package/dist/{VerifyEmailPage-1WwWczAn.js → VerifyEmailPage-CbgjOF0v.js} +22 -12
  155. package/dist/{VerifyEmailPage-DvMLZgFt.js → VerifyEmailPage-CdYPSJoO.js} +1 -1
  156. package/dist/{VerifyEmailPage-By3Jf__L.cjs → VerifyEmailPage-CkBYfsNy.cjs} +4 -4
  157. package/dist/{VerifyEmailPage-CJLz3jrn.js → VerifyEmailPage-Cyl55sJb.js} +23 -20
  158. package/dist/VerifyEmailPage-D-FRj5TU.cjs +3213 -0
  159. package/dist/VerifyEmailPage-DF2ilhum.cjs +3210 -0
  160. package/dist/{VerifyEmailPage-CYXtbKi3.cjs → VerifyEmailPage-DMBh4NM9.cjs} +1 -1
  161. package/dist/{VerifyEmailPage-CgMxRb4z.js → VerifyEmailPage-DTtFfC-J.js} +3 -3
  162. package/dist/{VerifyEmailPage-CFLMls1p.cjs → VerifyEmailPage-Dt7zgA4w.cjs} +4 -4
  163. package/dist/VerifyEmailPage-EhudUdqF.js +3211 -0
  164. package/dist/{VerifyEmailPage-C5TNQTBa.js → VerifyEmailPage-X14vhdyl.js} +148 -75
  165. package/dist/VerifyEmailPage-hdB8JQGv.cjs +3213 -0
  166. package/dist/{VerifyEmailPage-B4peJjAT.cjs → VerifyEmailPage-u_Dn7t1U.cjs} +148 -75
  167. package/dist/VerifyEmailPage-vYHbYK3q.js +3214 -0
  168. package/dist/{XerticaProvider-CBGc4EMA.cjs → XerticaProvider-AChwphCO.cjs} +4 -4
  169. package/dist/{XerticaProvider-BIrqfZ-i.cjs → XerticaProvider-AbWlr7Af.cjs} +8 -11
  170. package/dist/{XerticaProvider-D-yNhF94.cjs → XerticaProvider-B8CaV7xu.cjs} +1 -1
  171. package/dist/{XerticaProvider-DDuiIcKo.js → XerticaProvider-BErr83Bg.js} +14 -11
  172. package/dist/{XerticaProvider-CEoWMTxu.js → XerticaProvider-BITjgC5p.js} +2 -2
  173. package/dist/{XerticaProvider-CllrbMEJ.cjs → XerticaProvider-By8q3Roe.cjs} +2 -2
  174. package/dist/{XerticaProvider-C1DKnvLh.js → XerticaProvider-CUYJZc32.js} +4 -4
  175. package/dist/{XerticaProvider-ET0ihewn.cjs → XerticaProvider-CW9hpCdF.cjs} +2 -2
  176. package/dist/{XerticaProvider-Dt5HEzbQ.js → XerticaProvider-CWgby5mY.js} +10 -10
  177. package/dist/XerticaProvider-CWs6EwNa.js +49 -0
  178. package/dist/XerticaProvider-CjQAQPcn.cjs +48 -0
  179. package/dist/XerticaProvider-CwOkHxiT.cjs +44 -0
  180. package/dist/XerticaProvider-D5lLumH-.js +49 -0
  181. package/dist/{XerticaProvider-DYq4JWtg.js → XerticaProvider-DQtvJU7m.js} +1 -1
  182. package/dist/XerticaProvider-qQUDop71.cjs +48 -0
  183. package/dist/{XerticaProvider-B7EVH-NF.js → XerticaProvider-siSt9uG2.js} +2 -2
  184. package/dist/{XerticaXLogo-Zw2B276b.cjs → XerticaXLogo-8TTzBjHw.cjs} +1 -1
  185. package/dist/{XerticaXLogo-B7xQ5dhi.js → XerticaXLogo-BWaag64t.js} +1 -1
  186. package/dist/{XerticaXLogo-DZbo4vOE.js → XerticaXLogo-BX3ueACh.js} +5 -2
  187. package/dist/XerticaXLogo-CFuIlYFH.js +252 -0
  188. package/dist/XerticaXLogo-CU-U-GP4.cjs +251 -0
  189. package/dist/XerticaXLogo-ChryA6xj.js +252 -0
  190. package/dist/{XerticaXLogo-CQUUjXoH.cjs → XerticaXLogo-CziKMQil.cjs} +8 -8
  191. package/dist/XerticaXLogo-DHz5SugF.js +252 -0
  192. package/dist/XerticaXLogo-DTee_y8X.cjs +251 -0
  193. package/dist/{XerticaXLogo-Cmsp-Eey.js → XerticaXLogo-DfUvz-lD.js} +9 -9
  194. package/dist/XerticaXLogo-kslQ8Tk_.cjs +251 -0
  195. package/dist/{XerticaXLogo-bvZSgwGF.cjs → XerticaXLogo-qBPhwK3g.cjs} +5 -2
  196. package/dist/{alert-dialog-s-vmNkJ_.js → alert-dialog-iDe5VE5o.js} +3 -3
  197. package/dist/{alert-dialog-DSKByiKZ.cjs → alert-dialog-yckpaOpy.cjs} +3 -3
  198. package/dist/assistant.cjs.js +1 -1
  199. package/dist/assistant.es.js +1 -1
  200. package/dist/brand.cjs.js +2 -2
  201. package/dist/brand.es.js +2 -2
  202. package/dist/cli.js +90 -37
  203. package/dist/components/brand/theme-toggle/ThemeToggle.d.ts +1 -1
  204. package/dist/components/index.d.ts +1 -1
  205. package/dist/{google-maps-loader-Y-QkD-Li.cjs → google-maps-loader-BqsYL48U.cjs} +0 -5
  206. package/dist/{google-maps-loader-CTYySAun.js → google-maps-loader-t2IlYBzw.js} +0 -4
  207. package/dist/index-CkTUgOwX.js +8 -0
  208. package/dist/{index-COtD8bRW.cjs → index-D3RLKRAs.cjs} +1 -1
  209. package/dist/index.cjs.js +5 -5
  210. package/dist/index.es.js +5 -5
  211. package/dist/index.umd.js +454 -1027
  212. package/dist/layout.cjs.js +1 -1
  213. package/dist/layout.es.js +1 -1
  214. package/dist/pages.cjs.js +1 -1
  215. package/dist/pages.es.js +1 -1
  216. package/dist/{sidebar-DAaY8bRU.cjs → sidebar-B3EYhli0.cjs} +33 -24
  217. package/dist/{sidebar-B6SlKZYN.js → sidebar-B4ZWaMrE.js} +1 -1
  218. package/dist/{sidebar-DQj1z3jG.cjs → sidebar-B9NR0lCe.cjs} +269 -227
  219. package/dist/{sidebar-nzPoVHBQ.cjs → sidebar-BS1p2V7t.cjs} +1 -1
  220. package/dist/sidebar-BvF5I2Ue.cjs +800 -0
  221. package/dist/{sidebar-q7P2Godd.cjs → sidebar-C5B_LHek.cjs} +1 -1
  222. package/dist/{sidebar-CrQDDdcz.js → sidebar-CA6_ek3f.js} +33 -24
  223. package/dist/{sidebar-BxGXsDAd.cjs → sidebar-CVUGHOS_.cjs} +8 -16
  224. package/dist/{sidebar-BViy8Eeu.js → sidebar-CmvwjnVb.js} +9 -17
  225. package/dist/sidebar-CplprZpM.js +801 -0
  226. package/dist/{sidebar-BbVIQvlP.js → sidebar-Dz7bd3zP.js} +1 -1
  227. package/dist/sidebar-KIS0C2JH.js +801 -0
  228. package/dist/sidebar-OTO_up7Z.js +801 -0
  229. package/dist/sidebar-zowjejT2.cjs +800 -0
  230. package/dist/{use-audio-player-nv8ZSGa1.js → use-audio-player-Bkh23vQ3.js} +3 -7
  231. package/dist/{use-audio-player-NKsWyjWu.cjs → use-audio-player-Dn1NR9xN.cjs} +3 -7
  232. package/dist/{xertica-assistant-dyP7KHM5.cjs → xertica-assistant-B1IaHXnB.cjs} +388 -529
  233. package/dist/{xertica-assistant-DCsnQyi5.js → xertica-assistant-B1NaSFFj.js} +46 -29
  234. package/dist/{xertica-assistant-ciJaWqm1.js → xertica-assistant-BMqdyRVi.js} +10 -28
  235. package/dist/{xertica-assistant-V_IdW4WF.cjs → xertica-assistant-Bj3vBCq_.cjs} +9 -27
  236. package/dist/{xertica-assistant-CrgTb6Hs.cjs → xertica-assistant-CIaUlbIt.cjs} +47 -22
  237. package/dist/{xertica-assistant-yX1CFBBo.js → xertica-assistant-DPsESB6t.js} +390 -531
  238. package/dist/{CodeBlock-BgfYL_rD.cjs → xertica-assistant-Qp3ydksa.cjs} +51 -263
  239. package/dist/{CodeBlock-BeSt1h5P.js → xertica-assistant-gnCJdcZY.js} +7 -219
  240. package/dist/xertica-ui.css +2 -2
  241. package/docs/architecture-improvements.md +456 -456
  242. package/docs/architecture.md +312 -306
  243. package/docs/components/assistant.md +428 -428
  244. package/docs/components/branding.md +252 -252
  245. package/docs/components/card-patterns.md +447 -445
  246. package/docs/components/error-boundary.md +32 -22
  247. package/docs/components/hooks.md +432 -430
  248. package/docs/components/language-selector.md +176 -172
  249. package/docs/components/pages.md +20 -6
  250. package/docs/doc-audit.md +244 -243
  251. package/docs/getting-started.md +616 -603
  252. package/docs/guidelines.md +330 -328
  253. package/docs/i18n.md +480 -476
  254. package/docs/installation.md +7 -6
  255. package/docs/llms.md +295 -295
  256. package/docs/state-management.md +289 -289
  257. package/guidelines/Guidelines.md +409 -406
  258. package/llms-compact.txt +1 -1
  259. package/llms.txt +1 -1
  260. package/package.json +219 -219
  261. package/styles/xertica/base.css +6 -0
  262. package/templates/.prettierignore +4 -4
  263. package/templates/.prettierrc +10 -10
  264. package/templates/CLAUDE.md +180 -165
  265. package/templates/guidelines/Guidelines.md +577 -553
  266. package/templates/package.json +69 -69
  267. package/templates/src/app/App.tsx +46 -46
  268. package/templates/src/app/components/AuthGuard.tsx +57 -8
  269. package/templates/src/features/assistant/data/mock.ts +75 -75
  270. package/templates/src/features/assistant/hooks/useAssistantConfig.ts +20 -20
  271. package/templates/src/features/assistant/index.ts +5 -5
  272. package/templates/src/features/auth/ui/AuthPageShell.tsx +1 -1
  273. package/templates/src/features/auth/ui/ForgotPasswordContent.tsx +70 -72
  274. package/templates/src/features/auth/ui/LoginContent.tsx +92 -92
  275. package/templates/src/features/auth/ui/ResetPasswordContent.tsx +183 -179
  276. package/templates/src/features/auth/ui/SocialLoginButtons.tsx +78 -78
  277. package/templates/src/features/auth/ui/VerifyEmailContent.tsx +80 -84
  278. package/templates/src/features/home/data/mock.ts +6 -0
  279. package/templates/src/features/home/hooks/useFeatureCards.ts +20 -20
  280. package/templates/src/features/home/index.ts +11 -11
  281. package/templates/src/features/home/ui/HomeContent.tsx +117 -119
  282. package/templates/src/features/template/ui/CrudTemplate.tsx +112 -115
  283. package/templates/src/features/template/ui/DashboardTemplate.tsx +110 -110
  284. package/templates/src/features/template/ui/FormTemplate.tsx +117 -117
  285. package/templates/src/features/template/ui/LoginTemplate.tsx +59 -59
  286. package/templates/src/features/template/ui/TemplateContent.tsx +1322 -1314
  287. package/templates/src/i18n.ts +124 -124
  288. package/templates/src/locales/en/common.json +21 -21
  289. package/templates/src/locales/en/components/activityCard.json +10 -10
  290. package/templates/src/locales/en/components/assistant.json +119 -119
  291. package/templates/src/locales/en/components/media.json +29 -29
  292. package/templates/src/locales/en/components/notificationCard.json +5 -5
  293. package/templates/src/locales/en/components/profileCard.json +8 -8
  294. package/templates/src/locales/en/components/projectCard.json +10 -10
  295. package/templates/src/locales/en/components/sidebar.json +14 -14
  296. package/templates/src/locales/en/components/stats.json +8 -8
  297. package/templates/src/locales/en/components/team.json +14 -14
  298. package/templates/src/locales/en/errors.json +9 -9
  299. package/templates/src/locales/en/languageSelector.json +7 -7
  300. package/templates/src/locales/en/nav.json +6 -6
  301. package/templates/src/locales/en/pages/crudTemplate.json +25 -25
  302. package/templates/src/locales/en/pages/dashboardTemplate.json +20 -20
  303. package/templates/src/locales/en/pages/forgotPassword.json +10 -10
  304. package/templates/src/locales/en/pages/formTemplate.json +16 -16
  305. package/templates/src/locales/en/pages/home.json +7 -7
  306. package/templates/src/locales/en/pages/login.json +15 -15
  307. package/templates/src/locales/en/pages/loginTemplate.json +9 -9
  308. package/templates/src/locales/en/pages/resetPassword.json +18 -18
  309. package/templates/src/locales/en/pages/templates.json +317 -317
  310. package/templates/src/locales/en/pages/verifyEmail.json +12 -12
  311. package/templates/src/locales/en/themeToggle.json +6 -6
  312. package/templates/src/locales/es/common.json +21 -21
  313. package/templates/src/locales/es/components/activityCard.json +10 -10
  314. package/templates/src/locales/es/components/assistant.json +119 -119
  315. package/templates/src/locales/es/components/media.json +29 -29
  316. package/templates/src/locales/es/components/notificationCard.json +5 -5
  317. package/templates/src/locales/es/components/profileCard.json +8 -8
  318. package/templates/src/locales/es/components/projectCard.json +10 -10
  319. package/templates/src/locales/es/components/sidebar.json +14 -14
  320. package/templates/src/locales/es/components/stats.json +8 -8
  321. package/templates/src/locales/es/components/team.json +14 -14
  322. package/templates/src/locales/es/errors.json +9 -9
  323. package/templates/src/locales/es/languageSelector.json +7 -7
  324. package/templates/src/locales/es/nav.json +6 -6
  325. package/templates/src/locales/es/pages/crudTemplate.json +25 -25
  326. package/templates/src/locales/es/pages/dashboardTemplate.json +20 -20
  327. package/templates/src/locales/es/pages/forgotPassword.json +10 -10
  328. package/templates/src/locales/es/pages/formTemplate.json +16 -16
  329. package/templates/src/locales/es/pages/home.json +7 -7
  330. package/templates/src/locales/es/pages/login.json +15 -15
  331. package/templates/src/locales/es/pages/loginTemplate.json +9 -9
  332. package/templates/src/locales/es/pages/resetPassword.json +18 -18
  333. package/templates/src/locales/es/pages/templates.json +317 -317
  334. package/templates/src/locales/es/pages/verifyEmail.json +12 -12
  335. package/templates/src/locales/es/themeToggle.json +6 -6
  336. package/templates/src/locales/pt-BR/common.json +21 -21
  337. package/templates/src/locales/pt-BR/components/activityCard.json +10 -10
  338. package/templates/src/locales/pt-BR/components/assistant.json +119 -119
  339. package/templates/src/locales/pt-BR/components/media.json +29 -29
  340. package/templates/src/locales/pt-BR/components/notificationCard.json +5 -5
  341. package/templates/src/locales/pt-BR/components/profileCard.json +8 -8
  342. package/templates/src/locales/pt-BR/components/projectCard.json +10 -10
  343. package/templates/src/locales/pt-BR/components/sidebar.json +14 -14
  344. package/templates/src/locales/pt-BR/components/stats.json +8 -8
  345. package/templates/src/locales/pt-BR/components/team.json +14 -14
  346. package/templates/src/locales/pt-BR/errors.json +9 -9
  347. package/templates/src/locales/pt-BR/languageSelector.json +7 -7
  348. package/templates/src/locales/pt-BR/nav.json +6 -6
  349. package/templates/src/locales/pt-BR/pages/crudTemplate.json +25 -25
  350. package/templates/src/locales/pt-BR/pages/dashboardTemplate.json +20 -20
  351. package/templates/src/locales/pt-BR/pages/forgotPassword.json +10 -10
  352. package/templates/src/locales/pt-BR/pages/formTemplate.json +16 -16
  353. package/templates/src/locales/pt-BR/pages/home.json +7 -7
  354. package/templates/src/locales/pt-BR/pages/login.json +15 -15
  355. package/templates/src/locales/pt-BR/pages/loginTemplate.json +9 -9
  356. package/templates/src/locales/pt-BR/pages/resetPassword.json +18 -18
  357. package/templates/src/locales/pt-BR/pages/templates.json +317 -317
  358. package/templates/src/locales/pt-BR/pages/verifyEmail.json +12 -12
  359. package/templates/src/locales/pt-BR/themeToggle.json +6 -6
  360. package/templates/src/pages/AssistantPage.tsx +470 -464
  361. package/templates/src/pages/HomePage.tsx +53 -49
  362. package/templates/src/shared/error-boundary.tsx +1 -5
  363. package/templates/src/shared/error-fallbacks.tsx +4 -8
  364. package/templates/vite.config.js +20 -20
  365. package/templates/vite.config.ts +55 -52
  366. package/dist/AssistantChart-CxGjH7Qk.js +0 -3477
  367. package/dist/AssistantChart-DIpshm3i.js +0 -4784
  368. package/dist/AssistantChart-D_PTeu8P.cjs +0 -3503
  369. package/dist/AssistantChart-zjsy2GaZ.cjs +0 -4810
  370. package/dist/AudioPlayer-B1lt5cPl.cjs +0 -989
  371. package/dist/AudioPlayer-BZ7bibzU.cjs +0 -982
  372. package/dist/AudioPlayer-BpRPS4-1.cjs +0 -1277
  373. package/dist/AudioPlayer-C12BjQBV.cjs +0 -997
  374. package/dist/AudioPlayer-CFeV8t-5.cjs +0 -936
  375. package/dist/AudioPlayer-Coly3q5R.js +0 -1278
  376. package/dist/AudioPlayer-CySJIyvL.js +0 -937
  377. package/dist/AudioPlayer-DMcG_c7L.js +0 -990
  378. package/dist/AudioPlayer-DcFKRJE_.js +0 -998
  379. package/dist/AudioPlayer-e8LfNoqO.js +0 -983
  380. package/dist/BrandColorsContext-565dDHd5.js +0 -660
  381. package/dist/BrandColorsContext-BcJbtkqn.cjs +0 -659
  382. package/dist/CodeBlock-7TTgmdGG.cjs +0 -2094
  383. package/dist/CodeBlock-BlcqlA9M.cjs +0 -2094
  384. package/dist/CodeBlock-Bnmeu5ez.cjs +0 -2094
  385. package/dist/CodeBlock-BtfPlbAI.js +0 -2078
  386. package/dist/CodeBlock-CIySIuYr.js +0 -2078
  387. package/dist/CodeBlock-CuPtUM-7.cjs +0 -2094
  388. package/dist/CodeBlock-D6ffWXgc.js +0 -2078
  389. package/dist/CodeBlock-D8dcwbit.cjs +0 -2094
  390. package/dist/CodeBlock-DMZrFnlw.cjs +0 -2094
  391. package/dist/CodeBlock-DlBehYN8.js +0 -2078
  392. package/dist/CodeBlock-DnYNI8rQ.js +0 -2078
  393. package/dist/CodeBlock-DvKWbSnE.cjs +0 -2094
  394. package/dist/CodeBlock-DwMCfkFY.js +0 -2078
  395. package/dist/CodeBlock-Dy6CNYyj.js +0 -2078
  396. package/dist/CodeBlock-U1pPOQI7.cjs +0 -2094
  397. package/dist/CodeBlock-f_GpNhEB.js +0 -2078
  398. package/dist/CodeBlock-oB6u8nI1.js +0 -2078
  399. package/dist/CodeBlock-tZC31B73.cjs +0 -2094
  400. package/dist/FeatureCard-CxC-7C-C.cjs +0 -300
  401. package/dist/FeatureCard-DbHWCb4E.js +0 -301
  402. package/dist/ImageWithFallback-CGtidP6B.cjs +0 -4542
  403. package/dist/ImageWithFallback-lsg3pdFg.js +0 -4508
  404. package/dist/LanguageSelector-B5YfbHra.js +0 -231
  405. package/dist/LanguageSelector-D6uacAIM.cjs +0 -230
  406. package/dist/LayoutContext-B45-e9DI.cjs +0 -93
  407. package/dist/LayoutContext-BAql6ZRY.js +0 -97
  408. package/dist/LayoutContext-Bav3UMEA.js +0 -94
  409. package/dist/LayoutContext-BvK-ggDa.cjs +0 -96
  410. package/dist/ThemeContext-BoH4NLfN.js +0 -734
  411. package/dist/ThemeContext-r69W20Xg.cjs +0 -733
  412. package/dist/VerifyEmailPage-COiyNl1y.js +0 -2825
  413. package/dist/VerifyEmailPage-CqKsR2v8.js +0 -2827
  414. package/dist/VerifyEmailPage-DjQKRlUS.cjs +0 -2824
  415. package/dist/VerifyEmailPage-s-1X3LDJ.cjs +0 -2826
  416. package/dist/XerticaOrbe-KL1RBHzw.cjs +0 -1354
  417. package/dist/XerticaOrbe-zwS1p2a8.js +0 -1355
  418. package/dist/XerticaProvider-6btlAlzc.js +0 -17
  419. package/dist/XerticaProvider-BNoNOxQ5.cjs +0 -16
  420. package/dist/XerticaProvider-BlY2limY.cjs +0 -38
  421. package/dist/XerticaProvider-cI9hSs27.cjs +0 -38
  422. package/dist/XerticaProvider-hSwhNQex.js +0 -39
  423. package/dist/alert-dialog-BOje--vD.js +0 -847
  424. package/dist/alert-dialog-BtEuQqrg.cjs +0 -870
  425. package/dist/breadcrumb-CqJ7bHY5.js +0 -161
  426. package/dist/breadcrumb-m9Hb2_XN.cjs +0 -177
  427. package/dist/components/assistant/xertica-assistant/hooks/index.d.ts +0 -6
  428. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-conversations.d.ts +0 -21
  429. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-messages.d.ts +0 -49
  430. package/dist/components/assistant/xertica-assistant/hooks/use-assistant-suggestions.d.ts +0 -16
  431. package/dist/components/blocks/audio-player/AudioPlayer.d.ts +0 -35
  432. package/dist/components/blocks/audio-player/index.d.ts +0 -1
  433. package/dist/components/blocks/document-editor/DocumentEditor.d.ts +0 -26
  434. package/dist/components/blocks/document-editor/index.d.ts +0 -1
  435. package/dist/components/blocks/podcast-player/PodcastPlayer.d.ts +0 -41
  436. package/dist/components/blocks/podcast-player/index.d.ts +0 -1
  437. package/dist/components/ui/chart/parts/chart-dashboard.d.ts +0 -113
  438. package/dist/components/ui/chart/parts/chart-metric.d.ts +0 -118
  439. package/dist/components/ui/chart/parts/chart-primitives.d.ts +0 -101
  440. package/dist/components/ui/chart/parts/chart-shared.d.ts +0 -20
  441. package/dist/components/ui/chart/parts/chart-utils.d.ts +0 -12
  442. package/dist/components/ui/chart/parts/index.d.ts +0 -5
  443. package/dist/dropdown-menu-BDB5CmQs.cjs +0 -247
  444. package/dist/dropdown-menu-DQidbKBD.js +0 -231
  445. package/dist/google-maps-loader-BFWp6VPd.js +0 -287
  446. package/dist/google-maps-loader-BKcdgFbu.cjs +0 -312
  447. package/dist/google-maps-loader-CumCNXeG.js +0 -312
  448. package/dist/google-maps-loader-eS3uQ5TA.cjs +0 -287
  449. package/dist/header-Cgy6vYPk.cjs +0 -731
  450. package/dist/header-DRlT4jgI.js +0 -715
  451. package/dist/header-Dux00SI4.cjs +0 -731
  452. package/dist/header-EkGKXPsD.js +0 -715
  453. package/dist/header-WfEywpyc.cjs +0 -731
  454. package/dist/header-tifNQn2U.js +0 -715
  455. package/dist/index-BhapVLVj.js +0 -8
  456. package/dist/index-D6fxYEY8.cjs +0 -7
  457. package/dist/index-DAIp0_HK.js +0 -8
  458. package/dist/index-DW5tYe26.js +0 -8
  459. package/dist/index-GA__GvnG.cjs +0 -7
  460. package/dist/input-2R4loU86.js +0 -127
  461. package/dist/input-DWANSKGb.cjs +0 -145
  462. package/dist/progress-DPtzoVV8.js +0 -175
  463. package/dist/progress-EeaoqqUs.cjs +0 -191
  464. package/dist/rich-text-editor-0mraWT5y.cjs +0 -2376
  465. package/dist/rich-text-editor-B-IkcPD0.js +0 -2874
  466. package/dist/rich-text-editor-B6jMRLzk.cjs +0 -1939
  467. package/dist/rich-text-editor-B8_oYcIR.js +0 -1730
  468. package/dist/rich-text-editor-B9UbSXNb.js +0 -1203
  469. package/dist/rich-text-editor-BYuRBNBU.js +0 -2373
  470. package/dist/rich-text-editor-Bb9pySTs.cjs +0 -2374
  471. package/dist/rich-text-editor-BcL6L3cm.cjs +0 -2374
  472. package/dist/rich-text-editor-BoVZYtTs.cjs +0 -2391
  473. package/dist/rich-text-editor-Bp3zQqMC.js +0 -2954
  474. package/dist/rich-text-editor-CMgSN_w2.js +0 -1189
  475. package/dist/rich-text-editor-CPV1lEPH.cjs +0 -1748
  476. package/dist/rich-text-editor-CeucBdIv.cjs +0 -2971
  477. package/dist/rich-text-editor-CoKqbCtu.cjs +0 -1799
  478. package/dist/rich-text-editor-Cw56T_mB.js +0 -2356
  479. package/dist/rich-text-editor-Cyt8qs2b.js +0 -1921
  480. package/dist/rich-text-editor-D6H84OcX.cjs +0 -1220
  481. package/dist/rich-text-editor-D76gD-QI.js +0 -2328
  482. package/dist/rich-text-editor-DKkokOnA.js +0 -1781
  483. package/dist/rich-text-editor-DNsdpN64.cjs +0 -2359
  484. package/dist/rich-text-editor-DfG8bCyY.js +0 -2358
  485. package/dist/rich-text-editor-Dxjw31Z4.js +0 -2341
  486. package/dist/rich-text-editor-DzP0Epmb.js +0 -2356
  487. package/dist/rich-text-editor-bRkNoeZY.cjs +0 -2891
  488. package/dist/rich-text-editor-lyYE2ZG5.cjs +0 -1207
  489. package/dist/rich-text-editor-skplNlBM.cjs +0 -2345
  490. package/dist/select-Bkbr0f-Z.cjs +0 -162
  491. package/dist/select-CvIVdX2n.js +0 -145
  492. package/dist/sidebar-CK_0ZQHj.cjs +0 -803
  493. package/dist/sidebar-CUuOvYhK.js +0 -787
  494. package/dist/sidebar-Djn5syhi.cjs +0 -786
  495. package/dist/sidebar-LluMXfam.js +0 -759
  496. package/dist/sidebar-_rT7rBMk.js +0 -787
  497. package/dist/slider-Bc5Hd0y1.js +0 -56
  498. package/dist/slider-N7hFFj6X.cjs +0 -73
  499. package/dist/tooltip-Ded96neP.cjs +0 -137
  500. package/dist/tooltip-HDOoD2-0.js +0 -120
  501. package/dist/use-audio-player-B31J-aqh.cjs +0 -187
  502. package/dist/use-audio-player-BkmEmj8Q.js +0 -185
  503. package/dist/use-audio-player-CLFTWFW1.cjs +0 -184
  504. package/dist/use-audio-player-CLLn00I6.js +0 -188
  505. package/dist/use-file-upload-BcjEo2S5.js +0 -404
  506. package/dist/use-file-upload-CRJR68Tj.cjs +0 -403
  507. package/dist/use-mobile-B0hNy_Y6.cjs +0 -4303
  508. package/dist/use-mobile-BXuYROXM.js +0 -4202
  509. package/dist/use-mobile-Bbd51ASU.cjs +0 -4392
  510. package/dist/use-mobile-Bk6CX-TC.js +0 -4359
  511. package/dist/use-mobile-BvYdisLP.js +0 -4202
  512. package/dist/use-mobile-BzuxjzNX.cjs +0 -4392
  513. package/dist/use-mobile-CG2-SdXV.cjs +0 -4235
  514. package/dist/use-mobile-CKb5pqTs.js +0 -4269
  515. package/dist/use-mobile-CYuAuGDl.js +0 -4202
  516. package/dist/use-mobile-CaENcqm-.js +0 -4508
  517. package/dist/use-mobile-CbrYgJGJ.js +0 -4203
  518. package/dist/use-mobile-Cd4xPrKq.cjs +0 -46
  519. package/dist/use-mobile-DMOvImGQ.cjs +0 -4542
  520. package/dist/use-mobile-DRB3BQgD.cjs +0 -4235
  521. package/dist/use-mobile-DZvv7QMR.js +0 -4359
  522. package/dist/use-mobile-DdI_TXam.cjs +0 -4235
  523. package/dist/use-mobile-DlceKf8a.js +0 -4359
  524. package/dist/use-mobile-DsOnow1o.cjs +0 -4236
  525. package/dist/use-mobile-Kcj6jSnK.cjs +0 -4392
  526. package/dist/use-mobile-bnKcua_i.js +0 -4202
  527. package/dist/use-mobile-j4w2Jrf1.js +0 -30
  528. package/dist/use-mobile-ncXBeE2z.cjs +0 -4235
  529. package/dist/use-rich-text-editor-DjiddBGv.js +0 -282
  530. package/dist/use-rich-text-editor-lpeswbCs.cjs +0 -281
  531. package/dist/xertica-assistant-BdiZag0h.js +0 -2187
  532. package/dist/xertica-assistant-DUBpmEgo.cjs +0 -2186
  533. package/dist/{rich-text-editor-DgF8s7xW.js → rich-text-editor-BmsjY03B.js} +26 -26
  534. package/dist/{rich-text-editor-mWoaSCE4.cjs → rich-text-editor-GS2kpTAK.cjs} +26 -26
@@ -1,1278 +0,0 @@
1
- import { jsxs, Fragment, jsx } from "react/jsx-runtime";
2
- import { useState, useEffect, useRef, useCallback } from "react";
3
- import { useTranslation } from "react-i18next";
4
- import { Maximize2, GripHorizontal, X, Play, Pause, VolumeX, Volume2, Maximize, PictureInPicture, Radio, ExternalLink, PauseCircle, PlayCircle, RotateCcw, Info, Gauge, Download, MoreHorizontal, MoreVertical } from "lucide-react";
5
- import { S as Slider } from "./slider-Pay3fka2.js";
6
- import { B as Button, c as cn } from "./button-C6uvh0rV.js";
7
- import { createPortal } from "react-dom";
8
- import { b as TooltipProvider, T as Tooltip, c as TooltipTrigger, a as TooltipContent } from "./tooltip-D-OrYnKO.js";
9
- import { D as DropdownMenu, n as DropdownMenuTrigger, b as DropdownMenuContent, d as DropdownMenuItem, i as DropdownMenuSeparator } from "./dropdown-menu-CFuCssWA.js";
10
- import { u as useAudioPlayer } from "./use-audio-player-CLLn00I6.js";
11
- function FloatingMediaWrapper({
12
- children,
13
- isFloating,
14
- setIsFloating,
15
- title,
16
- onClose,
17
- onCloseMedia,
18
- aspectRatio = 16 / 9,
19
- className,
20
- minWidth = 320,
21
- minHeight = 110,
22
- colorVariant = "default",
23
- playerId = "default",
24
- enablePadding = false
25
- }) {
26
- const { t } = useTranslation();
27
- const [isMounted, setIsMounted] = useState(false);
28
- useEffect(() => {
29
- setIsMounted(true);
30
- return () => setIsMounted(false);
31
- }, []);
32
- if (isFloating) {
33
- return /* @__PURE__ */ jsxs(Fragment, { children: [
34
- /* @__PURE__ */ jsxs(
35
- "div",
36
- {
37
- className: cn(
38
- "w-full rounded-[var(--radius-card)] bg-muted/20 border border-dashed border-muted-foreground/20 flex items-center justify-center flex-col gap-2 p-8 text-muted-foreground transition-all",
39
- className
40
- ),
41
- style: { aspectRatio },
42
- children: [
43
- /* @__PURE__ */ jsx(Maximize2, { className: "w-8 h-8 opacity-50" }),
44
- /* @__PURE__ */ jsx("p", { className: "text-sm font-medium", children: t("media.playingFloating") }),
45
- /* @__PURE__ */ jsx(Button, { variant: "outline", size: "sm", onClick: () => setIsFloating(false), children: t("media.restoreToPage") })
46
- ]
47
- }
48
- ),
49
- isMounted && createPortal(
50
- /* @__PURE__ */ jsx(
51
- FloatingContainer,
52
- {
53
- setIsFloating,
54
- onClose,
55
- onCloseMedia,
56
- title,
57
- aspectRatio,
58
- minWidth,
59
- minHeight,
60
- colorVariant,
61
- playerId,
62
- enablePadding,
63
- children
64
- }
65
- ),
66
- document.body
67
- )
68
- ] });
69
- }
70
- return /* @__PURE__ */ jsx("div", { className: cn("relative w-full overflow-hidden rounded-[var(--radius-card)]", className), children });
71
- }
72
- function FloatingContainer({
73
- children,
74
- setIsFloating,
75
- onClose,
76
- onCloseMedia,
77
- title,
78
- aspectRatio,
79
- minWidth,
80
- minHeight,
81
- colorVariant,
82
- playerId = "default",
83
- enablePadding = false
84
- }) {
85
- const { t } = useTranslation();
86
- const minPlayerHeight = minWidth / aspectRatio;
87
- const containerRef = useRef(null);
88
- const resizeHandleRef = useRef(null);
89
- const getInitialState = useCallback(() => {
90
- const storageKey = `xertica-media-player-${playerId}`;
91
- const stored = typeof window !== "undefined" ? window.localStorage?.getItem(storageKey) : null;
92
- if (stored) {
93
- try {
94
- return JSON.parse(stored);
95
- } catch {
96
- }
97
- }
98
- return {
99
- position: {
100
- x: typeof window !== "undefined" ? window.innerWidth - minWidth - 24 : 0,
101
- y: typeof window !== "undefined" ? window.innerHeight - minPlayerHeight - 24 : 0
102
- },
103
- size: {
104
- width: minWidth,
105
- height: minPlayerHeight
106
- }
107
- };
108
- }, [minWidth, minPlayerHeight, playerId]);
109
- const [state, setState] = useState(getInitialState);
110
- const { position, size } = state;
111
- const [isDragging, setIsDragging] = useState(false);
112
- const [isResizing, setIsResizing] = useState(false);
113
- const dragStartPos = useRef({ x: 0, y: 0 });
114
- const dragStartOffset = useRef({ x: 0, y: 0 });
115
- const resizeStartState = useRef({ position: { x: 0, y: 0 }, size: { width: 0, height: 0 } });
116
- const saveState = useCallback(
117
- (newPosition, newSize) => {
118
- if (typeof window === "undefined") return;
119
- const storageKey = `xertica-media-player-${playerId}`;
120
- window.localStorage?.setItem(
121
- storageKey,
122
- JSON.stringify({ position: newPosition, size: newSize })
123
- );
124
- },
125
- [playerId]
126
- );
127
- const handleMouseDown = (e) => {
128
- setIsDragging(true);
129
- dragStartPos.current = { x: e.clientX, y: e.clientY };
130
- dragStartOffset.current = { x: position.x, y: position.y };
131
- };
132
- const handleResizeStart = (e, direction) => {
133
- e.stopPropagation();
134
- setIsResizing(true);
135
- resizeHandleRef.current = direction;
136
- dragStartPos.current = { x: e.clientX, y: e.clientY };
137
- resizeStartState.current = { position: { ...position }, size: { ...size } };
138
- };
139
- const handleMouseMove = useCallback(
140
- (e) => {
141
- if (isDragging) {
142
- const deltaX = e.clientX - dragStartPos.current.x;
143
- const deltaY = e.clientY - dragStartPos.current.y;
144
- const newPos = {
145
- x: dragStartOffset.current.x + deltaX,
146
- y: dragStartOffset.current.y + deltaY
147
- };
148
- setState((prev) => ({ ...prev, position: newPos }));
149
- saveState(newPos, state.size);
150
- }
151
- if (isResizing && resizeHandleRef.current) {
152
- const deltaX = e.clientX - dragStartPos.current.x;
153
- const deltaY = e.clientY - dragStartPos.current.y;
154
- const direction = resizeHandleRef.current;
155
- let newPos = { ...resizeStartState.current.position };
156
- let newSize = { ...resizeStartState.current.size };
157
- if (direction.includes("right")) {
158
- newSize.width = Math.max(minWidth, resizeStartState.current.size.width + deltaX);
159
- }
160
- if (direction.includes("left")) {
161
- const newW = Math.max(minWidth, resizeStartState.current.size.width - deltaX);
162
- newPos.x = resizeStartState.current.position.x + (resizeStartState.current.size.width - newW);
163
- newSize.width = newW;
164
- }
165
- if (direction.includes("bottom")) {
166
- newSize.height = Math.max(minHeight, resizeStartState.current.size.height + deltaY);
167
- }
168
- if (direction.includes("top")) {
169
- const newH = Math.max(minHeight, resizeStartState.current.size.height - deltaY);
170
- newPos.y = resizeStartState.current.position.y + (resizeStartState.current.size.height - newH);
171
- newSize.height = newH;
172
- }
173
- setState({ position: newPos, size: newSize });
174
- saveState(newPos, newSize);
175
- }
176
- },
177
- [isDragging, isResizing, state.size, minWidth, minHeight, saveState]
178
- );
179
- const handleMouseUp = useCallback(() => {
180
- setIsDragging(false);
181
- setIsResizing(false);
182
- resizeHandleRef.current = null;
183
- }, []);
184
- useEffect(() => {
185
- if (!isDragging && !isResizing) return;
186
- document.addEventListener("mousemove", handleMouseMove);
187
- document.addEventListener("mouseup", handleMouseUp);
188
- return () => {
189
- document.removeEventListener("mousemove", handleMouseMove);
190
- document.removeEventListener("mouseup", handleMouseUp);
191
- };
192
- }, [isDragging, isResizing, handleMouseMove, handleMouseUp]);
193
- return /* @__PURE__ */ jsx("div", { className: "fixed inset-0 pointer-events-none z-50 overflow-hidden", children: /* @__PURE__ */ jsx(
194
- "div",
195
- {
196
- ref: containerRef,
197
- className: "pointer-events-auto absolute",
198
- style: {
199
- transform: `translate(${position.x}px, ${position.y}px)`,
200
- width: size.width,
201
- height: size.height
202
- },
203
- role: "dialog",
204
- "aria-label": title || t("media.playingMedia"),
205
- children: /* @__PURE__ */ jsxs(
206
- "div",
207
- {
208
- className: cn(
209
- "shadow-2xl rounded-[var(--radius-card)] overflow-hidden border backdrop-blur-sm",
210
- colorVariant === "primary" ? "bg-primary border-primary-foreground/20 text-primary-foreground" : "border-border bg-card/95 text-card-foreground"
211
- ),
212
- children: [
213
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col h-full w-full", children: [
214
- /* @__PURE__ */ jsxs(
215
- "div",
216
- {
217
- className: cn(
218
- "h-9 backdrop-blur-sm border-b flex items-center justify-between px-2 cursor-move select-none",
219
- colorVariant === "primary" ? "bg-primary-foreground/10 border-primary-foreground/10" : "bg-muted/20 border-border/40"
220
- ),
221
- onMouseDown: handleMouseDown,
222
- style: { touchAction: "none", userSelect: "none" },
223
- children: [
224
- /* @__PURE__ */ jsxs(
225
- "div",
226
- {
227
- className: cn(
228
- "flex items-center gap-2 text-[10px] uppercase tracking-wider font-bold truncate flex-1",
229
- colorVariant === "primary" ? "text-primary-foreground" : "text-muted-foreground"
230
- ),
231
- children: [
232
- /* @__PURE__ */ jsx(GripHorizontal, { className: "w-3.5 h-3.5" }),
233
- /* @__PURE__ */ jsx("span", { className: "truncate max-w-[150px]", children: title || t("media.playingMedia") })
234
- ]
235
- }
236
- ),
237
- /* @__PURE__ */ jsx("div", { className: "flex items-center gap-1", children: /* @__PURE__ */ jsx(
238
- Button,
239
- {
240
- variant: "ghost",
241
- size: "icon",
242
- className: cn(
243
- "h-7 w-7 rounded-full transition-colors",
244
- colorVariant === "primary" ? "text-primary-foreground/70 hover:bg-destructive/20 hover:text-destructive-foreground" : "text-muted-foreground hover:bg-destructive/10 hover:text-destructive"
245
- ),
246
- onClick: onCloseMedia || onClose,
247
- title: t("common.close"),
248
- "aria-label": t("media.closePlayer"),
249
- children: /* @__PURE__ */ jsx(X, { className: "w-4 h-4" })
250
- }
251
- ) })
252
- ]
253
- }
254
- ),
255
- /* @__PURE__ */ jsx(
256
- "div",
257
- {
258
- className: cn(
259
- "flex-1 relative overflow-hidden group",
260
- enablePadding && "p-2",
261
- colorVariant === "primary" ? "bg-primary" : "bg-card"
262
- ),
263
- children
264
- }
265
- )
266
- ] }),
267
- /* @__PURE__ */ jsx(
268
- "div",
269
- {
270
- "aria-hidden": "true",
271
- className: "absolute top-0 left-0 w-2 h-full cursor-ew-resize hover:bg-primary/20 transition-colors",
272
- onMouseDown: (e) => handleResizeStart(e, "left")
273
- }
274
- ),
275
- /* @__PURE__ */ jsx(
276
- "div",
277
- {
278
- "aria-hidden": "true",
279
- className: "absolute top-0 right-0 w-2 h-full cursor-ew-resize hover:bg-primary/20 transition-colors",
280
- onMouseDown: (e) => handleResizeStart(e, "right")
281
- }
282
- ),
283
- /* @__PURE__ */ jsx(
284
- "div",
285
- {
286
- "aria-hidden": "true",
287
- className: "absolute top-0 left-0 w-full h-2 cursor-ns-resize hover:bg-primary/20 transition-colors",
288
- onMouseDown: (e) => handleResizeStart(e, "top")
289
- }
290
- ),
291
- /* @__PURE__ */ jsx(
292
- "div",
293
- {
294
- "aria-hidden": "true",
295
- className: "absolute bottom-0 left-0 w-full h-2 cursor-ns-resize hover:bg-primary/20 transition-colors",
296
- onMouseDown: (e) => handleResizeStart(e, "bottom")
297
- }
298
- ),
299
- /* @__PURE__ */ jsx(
300
- "div",
301
- {
302
- "aria-hidden": "true",
303
- className: "absolute top-0 left-0 w-4 h-4 cursor-nwse-resize hover:bg-primary/20 transition-colors",
304
- onMouseDown: (e) => handleResizeStart(e, "top-left")
305
- }
306
- ),
307
- /* @__PURE__ */ jsx(
308
- "div",
309
- {
310
- "aria-hidden": "true",
311
- className: "absolute top-0 right-0 w-4 h-4 cursor-nesw-resize hover:bg-primary/20 transition-colors",
312
- onMouseDown: (e) => handleResizeStart(e, "top-right")
313
- }
314
- ),
315
- /* @__PURE__ */ jsx(
316
- "div",
317
- {
318
- "aria-hidden": "true",
319
- className: "absolute bottom-0 left-0 w-4 h-4 cursor-nesw-resize hover:bg-primary/20 transition-colors",
320
- onMouseDown: (e) => handleResizeStart(e, "bottom-left")
321
- }
322
- ),
323
- /* @__PURE__ */ jsx(
324
- "div",
325
- {
326
- "aria-hidden": "true",
327
- className: "absolute bottom-0 right-0 w-4 h-4 cursor-nwse-resize hover:bg-primary/20 transition-colors",
328
- onMouseDown: (e) => handleResizeStart(e, "bottom-right")
329
- }
330
- )
331
- ]
332
- }
333
- )
334
- }
335
- ) });
336
- }
337
- function VideoPlayer({
338
- src,
339
- poster,
340
- title,
341
- autoPlay = false,
342
- enableAutoFloat = true,
343
- className
344
- }) {
345
- const { t } = useTranslation();
346
- const videoRef = useRef(null);
347
- const containerRef = useRef(null);
348
- const [isPlaying, setIsPlaying] = useState(false);
349
- const [progress, setProgress] = useState(0);
350
- const [volume, setVolume] = useState(1);
351
- const [isMuted, setIsMuted] = useState(false);
352
- const [currentTime, setCurrentTime] = useState(0);
353
- const [duration, setDuration] = useState(0);
354
- const [isFloating, setIsFloating] = useState(false);
355
- const [isManualFloating, setIsManualFloating] = useState(false);
356
- const [showControls, setShowControls] = useState(true);
357
- const [enableAutoFloatLocal, setEnableAutoFloatLocal] = useState(enableAutoFloat);
358
- let controlsTimeout;
359
- const handleSetFloating = (floating) => {
360
- if (videoRef.current) {
361
- setCurrentTime(videoRef.current.currentTime);
362
- }
363
- setIsFloating(floating);
364
- if (!floating) {
365
- setIsManualFloating(false);
366
- }
367
- };
368
- useEffect(() => {
369
- const video = videoRef.current;
370
- if (video) {
371
- if (Math.abs(video.currentTime - currentTime) > 0.5) {
372
- video.currentTime = currentTime;
373
- }
374
- if (isPlaying) {
375
- const playPromise = video.play();
376
- if (playPromise !== void 0) {
377
- playPromise.catch((error) => {
378
- console.log("Playback interrupted during switch:", error);
379
- });
380
- }
381
- }
382
- }
383
- }, [isFloating]);
384
- useEffect(() => {
385
- const container = containerRef.current;
386
- if (!container || !enableAutoFloatLocal) return;
387
- const observer = new IntersectionObserver(
388
- (entries) => {
389
- const entry = entries[0];
390
- if (!entry) return;
391
- if (isPlaying && !entry.isIntersecting && !isFloating) {
392
- if (videoRef.current) setCurrentTime(videoRef.current.currentTime);
393
- setIsFloating(true);
394
- } else if (entry.isIntersecting && isFloating && !isManualFloating) {
395
- if (videoRef.current) setCurrentTime(videoRef.current.currentTime);
396
- handleSetFloating(false);
397
- }
398
- },
399
- { threshold: 0.2 }
400
- );
401
- observer.observe(container);
402
- return () => observer.disconnect();
403
- }, [isPlaying, isFloating, isManualFloating, enableAutoFloatLocal]);
404
- useEffect(() => {
405
- const video = videoRef.current;
406
- if (!video) return;
407
- const updateTime = () => {
408
- setCurrentTime(video.currentTime);
409
- };
410
- const updateDuration = () => setDuration(video.duration);
411
- const onPlay = () => setIsPlaying(true);
412
- const onPause = () => setIsPlaying(false);
413
- video.addEventListener("timeupdate", updateTime);
414
- video.addEventListener("loadedmetadata", updateDuration);
415
- video.addEventListener("play", onPlay);
416
- video.addEventListener("pause", onPause);
417
- video.volume = volume;
418
- video.muted = isMuted;
419
- return () => {
420
- video.removeEventListener("timeupdate", updateTime);
421
- video.removeEventListener("loadedmetadata", updateDuration);
422
- video.removeEventListener("play", onPlay);
423
- video.removeEventListener("pause", onPause);
424
- };
425
- }, [isFloating]);
426
- const togglePlay = () => {
427
- if (videoRef.current) {
428
- if (isPlaying) {
429
- videoRef.current.pause();
430
- } else {
431
- videoRef.current.play();
432
- }
433
- }
434
- };
435
- const handleSeek = (value) => {
436
- if (videoRef.current) {
437
- videoRef.current.currentTime = value[0];
438
- setCurrentTime(value[0]);
439
- }
440
- };
441
- const handleVolumeChange = (value) => {
442
- const newVolume = value[0];
443
- if (videoRef.current) {
444
- videoRef.current.volume = newVolume;
445
- setVolume(newVolume);
446
- setIsMuted(newVolume === 0);
447
- }
448
- };
449
- const toggleMute = () => {
450
- if (videoRef.current) {
451
- const newMutedState = !isMuted;
452
- videoRef.current.muted = newMutedState;
453
- setIsMuted(newMutedState);
454
- if (newMutedState) {
455
- setVolume(0);
456
- } else {
457
- setVolume(1);
458
- videoRef.current.volume = 1;
459
- }
460
- }
461
- };
462
- const handleMouseMove = () => {
463
- setShowControls(true);
464
- clearTimeout(controlsTimeout);
465
- controlsTimeout = setTimeout(() => {
466
- if (isPlaying) setShowControls(false);
467
- }, 2500);
468
- };
469
- const formatTime = (time) => {
470
- const minutes = Math.floor(time / 60);
471
- const seconds = Math.floor(time % 60);
472
- return `${minutes}:${seconds < 10 ? "0" : ""}${seconds}`;
473
- };
474
- return /* @__PURE__ */ jsx("div", { ref: containerRef, className, children: /* @__PURE__ */ jsx(
475
- FloatingMediaWrapper,
476
- {
477
- isFloating,
478
- setIsFloating: handleSetFloating,
479
- onClose: () => handleSetFloating(false),
480
- onCloseMedia: () => {
481
- setIsFloating(false);
482
- setEnableAutoFloatLocal(false);
483
- },
484
- title: title || t("media.untitledVideo"),
485
- aspectRatio: 16 / 9,
486
- className: "w-full h-full",
487
- playerId: "video-player",
488
- children: /* @__PURE__ */ jsxs(
489
- "div",
490
- {
491
- className: "relative w-full h-full bg-black group overflow-hidden",
492
- onMouseMove: handleMouseMove,
493
- onMouseLeave: () => isPlaying && setShowControls(false),
494
- children: [
495
- /* @__PURE__ */ jsx(
496
- "video",
497
- {
498
- ref: videoRef,
499
- src,
500
- poster,
501
- className: "w-full h-full object-contain",
502
- onClick: togglePlay,
503
- autoPlay,
504
- title: title || t("media.video")
505
- }
506
- ),
507
- !isPlaying && /* @__PURE__ */ jsx("div", { className: "absolute inset-0 flex items-center justify-center pointer-events-none", children: /* @__PURE__ */ jsx("div", { className: "w-16 h-16 rounded-full bg-black/40 backdrop-blur-sm flex items-center justify-center border border-white/20 shadow-2xl", children: /* @__PURE__ */ jsx(Play, { className: "w-8 h-8 text-white ml-1", fill: "white" }) }) }),
508
- /* @__PURE__ */ jsxs(
509
- "div",
510
- {
511
- className: cn(
512
- "absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/60 via-black/30 to-transparent pt-12 pb-4 px-4 transition-opacity duration-300",
513
- showControls ? "opacity-100" : "opacity-0"
514
- ),
515
- children: [
516
- /* @__PURE__ */ jsx("div", { className: "mb-4 group/slider", children: /* @__PURE__ */ jsx(
517
- Slider,
518
- {
519
- value: [currentTime],
520
- max: duration || 100,
521
- step: 1,
522
- onValueChange: handleSeek,
523
- className: "cursor-pointer [&_[data-slot=slider-track]]:bg-white/30 [&_[data-slot=slider-range]]:bg-white [&_[data-slot=slider-thumb]]:bg-white [&_[data-slot=slider-thumb]]:border-white",
524
- "aria-label": t("media.videoProgress")
525
- }
526
- ) }),
527
- /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
528
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-4", children: [
529
- /* @__PURE__ */ jsx(
530
- Button,
531
- {
532
- variant: "ghost",
533
- size: "icon",
534
- className: "text-white hover:text-white hover:bg-black/50 h-8 w-8",
535
- onClick: togglePlay,
536
- "aria-label": isPlaying ? t("media.pause") : t("media.play"),
537
- children: isPlaying ? /* @__PURE__ */ jsx(Pause, { className: "w-5 h-5", fill: "currentColor" }) : /* @__PURE__ */ jsx(Play, { className: "w-5 h-5", fill: "currentColor" })
538
- }
539
- ),
540
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 group/vol", children: [
541
- /* @__PURE__ */ jsx(
542
- Button,
543
- {
544
- variant: "ghost",
545
- size: "icon",
546
- className: "text-white hover:text-white hover:bg-black/50 h-8 w-8",
547
- onClick: toggleMute,
548
- "aria-label": isMuted || volume === 0 ? t("media.unmute") : t("media.mute"),
549
- children: isMuted || volume === 0 ? /* @__PURE__ */ jsx(VolumeX, { className: "w-5 h-5" }) : /* @__PURE__ */ jsx(Volume2, { className: "w-5 h-5" })
550
- }
551
- ),
552
- /* @__PURE__ */ jsx("div", { className: "w-0 overflow-hidden group-hover/vol:w-20 transition-all duration-300", children: /* @__PURE__ */ jsx(
553
- Slider,
554
- {
555
- value: [isMuted ? 0 : volume],
556
- max: 1,
557
- step: 0.01,
558
- onValueChange: handleVolumeChange,
559
- className: "w-20 [&_[data-slot=slider-track]]:bg-white/30 [&_[data-slot=slider-range]]:bg-white [&_[data-slot=slider-thumb]]:bg-white [&_[data-slot=slider-thumb]]:border-white",
560
- "aria-label": t("media.volume")
561
- }
562
- ) })
563
- ] }),
564
- /* @__PURE__ */ jsxs("div", { className: "text-white text-xs font-medium tabular-nums select-none drop-shadow-md", children: [
565
- formatTime(currentTime),
566
- " / ",
567
- formatTime(duration)
568
- ] })
569
- ] }),
570
- /* @__PURE__ */ jsx("div", { className: "flex items-center gap-2", children: /* @__PURE__ */ jsx(
571
- Button,
572
- {
573
- variant: "ghost",
574
- size: "icon",
575
- className: "text-white hover:text-white hover:bg-black/50 h-8 w-8",
576
- onClick: () => {
577
- setEnableAutoFloatLocal(true);
578
- if (!isFloating) setIsManualFloating(true);
579
- handleSetFloating(!isFloating);
580
- },
581
- title: isFloating ? t("media.restore") : t("media.popOut"),
582
- "aria-label": isFloating ? t("media.restore") : t("media.popOut"),
583
- children: isFloating ? /* @__PURE__ */ jsx(Maximize, { className: "w-4 h-4" }) : /* @__PURE__ */ jsx(PictureInPicture, { className: "w-4 h-4" })
584
- }
585
- ) })
586
- ] })
587
- ]
588
- }
589
- )
590
- ]
591
- }
592
- )
593
- }
594
- ) });
595
- }
596
- function AudioPlayer({
597
- src,
598
- title,
599
- artist,
600
- subtitle,
601
- autoPlay = false,
602
- className,
603
- variant = "card",
604
- isOpen = true,
605
- onClose,
606
- duration: initialDuration,
607
- currentTime: initialTime = 0,
608
- colorVariant = "default",
609
- enableAutoFloat = true,
610
- onCloseFloating
611
- }) {
612
- const { t } = useTranslation();
613
- const {
614
- audioRef,
615
- containerRef,
616
- isPlaying,
617
- currentTime,
618
- duration,
619
- volume,
620
- isMuted,
621
- playbackSpeed,
622
- isFloating,
623
- isManualFloating,
624
- isVisible,
625
- isMobile,
626
- enableAutoFloatLocal,
627
- sidebarExpanded,
628
- sidebarWidth,
629
- assistenteExpanded,
630
- togglePlay,
631
- toggleMute,
632
- handleSeek,
633
- handleVolumeChange,
634
- handleSetFloating,
635
- handleEnableManualFloat,
636
- setPlaybackSpeed,
637
- resetAudio,
638
- formatTime,
639
- onPlay,
640
- onPause,
641
- onEnded,
642
- onTimeUpdate,
643
- onLoadedMetadata
644
- } = useAudioPlayer({
645
- src,
646
- autoPlay,
647
- initialTime,
648
- initialDuration,
649
- variant,
650
- isOpen,
651
- enableAutoFloat,
652
- onCloseFloating
653
- });
654
- const audioElement = /* @__PURE__ */ jsx(
655
- "audio",
656
- {
657
- ref: audioRef,
658
- src,
659
- autoPlay,
660
- className: "hidden",
661
- onTimeUpdate,
662
- onLoadedMetadata,
663
- onPlay,
664
- onPause,
665
- onEnded
666
- }
667
- );
668
- const desktopLayout = /* @__PURE__ */ jsxs(
669
- "div",
670
- {
671
- className: cn(
672
- "px-6 flex items-center justify-between gap-4",
673
- colorVariant === "primary" ? "h-[80px] gap-6" : "h-[80px]"
674
- ),
675
- children: [
676
- /* @__PURE__ */ jsxs(
677
- "div",
678
- {
679
- className: cn(
680
- "flex flex-col min-w-0 shrink-0 relative z-10",
681
- colorVariant === "primary" ? "w-[280px]" : "w-[280px]"
682
- ),
683
- children: [
684
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 mb-0.5", children: [
685
- colorVariant === "primary" ? /* @__PURE__ */ jsx("div", { className: "w-2 h-2 rounded-full bg-[var(--chart-4)] animate-pulse shrink-0" }) : /* @__PURE__ */ jsx(Radio, { className: "w-3 h-3 text-[var(--chart-4)] animate-pulse shrink-0" }),
686
- /* @__PURE__ */ jsx(
687
- "h4",
688
- {
689
- className: cn(
690
- "truncate",
691
- colorVariant === "primary" ? "font-semibold text-base tracking-tight" : "font-medium text-base"
692
- ),
693
- title: title || t("media.audioTitle"),
694
- children: title || t("media.audioTitle")
695
- }
696
- )
697
- ] }),
698
- /* @__PURE__ */ jsxs(
699
- "div",
700
- {
701
- className: cn(
702
- "flex items-center gap-1 text-xs text-muted-foreground",
703
- colorVariant === "primary" && "opacity-80"
704
- ),
705
- children: [
706
- /* @__PURE__ */ jsx("span", { className: "truncate", children: subtitle || artist }),
707
- /* @__PURE__ */ jsx(
708
- ExternalLink,
709
- {
710
- className: cn(
711
- "w-3 h-3 cursor-pointer hover:text-foreground ml-1 transition-opacity",
712
- colorVariant === "primary" ? "opacity-60 hover:opacity-100" : "opacity-70 hover:opacity-100"
713
- )
714
- }
715
- )
716
- ]
717
- }
718
- )
719
- ]
720
- }
721
- ),
722
- /* @__PURE__ */ jsxs(
723
- "div",
724
- {
725
- className: cn(
726
- "flex-1 flex items-center justify-center gap-4 min-w-0 max-w-xl relative z-10",
727
- colorVariant === "primary" && "gap-4"
728
- ),
729
- children: [
730
- /* @__PURE__ */ jsx(
731
- "button",
732
- {
733
- onClick: togglePlay,
734
- "aria-label": isPlaying ? t("media.pause") : t("media.play"),
735
- className: cn(
736
- "transition-all focus:outline-none shrink-0",
737
- colorVariant === "primary" ? "hover:scale-110" : "text-muted-foreground hover:text-foreground hover:scale-110 active:scale-95 transform duration-100"
738
- ),
739
- children: isPlaying ? /* @__PURE__ */ jsx(
740
- PauseCircle,
741
- {
742
- className: cn(colorVariant === "primary" ? "w-12 h-12" : "w-10 h-10"),
743
- strokeWidth: colorVariant === "primary" ? 1 : 1.5
744
- }
745
- ) : /* @__PURE__ */ jsx(
746
- PlayCircle,
747
- {
748
- className: cn(colorVariant === "primary" ? "w-12 h-12" : "w-10 h-10"),
749
- strokeWidth: colorVariant === "primary" ? 1 : 1.5
750
- }
751
- )
752
- }
753
- ),
754
- /* @__PURE__ */ jsxs("div", { className: "flex-1 flex items-center gap-3 max-w-lg", children: [
755
- /* @__PURE__ */ jsx(
756
- "span",
757
- {
758
- className: cn(
759
- "text-xs font-mono shrink-0 w-10 text-right",
760
- colorVariant === "primary" ? "text-[11px] w-12 opacity-80" : "text-muted-foreground"
761
- ),
762
- children: formatTime(currentTime)
763
- }
764
- ),
765
- /* @__PURE__ */ jsx(
766
- Slider,
767
- {
768
- value: [currentTime],
769
- max: duration || 100,
770
- onValueChange: handleSeek,
771
- className: "cursor-pointer"
772
- }
773
- ),
774
- /* @__PURE__ */ jsx(
775
- "span",
776
- {
777
- className: cn(
778
- "text-xs font-mono shrink-0 w-10",
779
- colorVariant === "primary" ? "text-[11px] w-12 opacity-80" : "text-muted-foreground"
780
- ),
781
- children: formatTime(duration)
782
- }
783
- )
784
- ] })
785
- ]
786
- }
787
- ),
788
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 shrink-0 relative z-10", children: [
789
- /* @__PURE__ */ jsxs("div", { className: "hidden lg:flex items-center gap-2 w-28 mr-2 group", children: [
790
- /* @__PURE__ */ jsx(
791
- "button",
792
- {
793
- onClick: toggleMute,
794
- className: "text-muted-foreground hover:text-foreground",
795
- "aria-label": isMuted || volume === 0 ? t("media.unmute") : t("media.mute"),
796
- children: isMuted || volume === 0 ? /* @__PURE__ */ jsx(VolumeX, { className: "w-5 h-5" }) : /* @__PURE__ */ jsx(Volume2, { className: "w-5 h-5" })
797
- }
798
- ),
799
- /* @__PURE__ */ jsx(
800
- Slider,
801
- {
802
- value: [isMuted ? 0 : volume * 100],
803
- max: 100,
804
- onValueChange: (val) => handleVolumeChange([val[0] / 100]),
805
- className: "w-full opacity-60 group-hover:opacity-100 transition-opacity"
806
- }
807
- )
808
- ] }),
809
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
810
- /* @__PURE__ */ jsxs("div", { className: "hidden md:flex", children: [
811
- /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [
812
- /* @__PURE__ */ jsx(TooltipTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
813
- Button,
814
- {
815
- variant: "ghost",
816
- size: "icon",
817
- className: "rounded-full h-9 w-9",
818
- onClick: resetAudio,
819
- "aria-label": t("media.restart"),
820
- children: /* @__PURE__ */ jsx(RotateCcw, { className: "w-4 h-4" })
821
- }
822
- ) }),
823
- /* @__PURE__ */ jsx(TooltipContent, { className: "z-[1001]", children: t("media.restart") })
824
- ] }) }),
825
- /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [
826
- /* @__PURE__ */ jsx(TooltipTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
827
- Button,
828
- {
829
- variant: "ghost",
830
- size: "icon",
831
- className: "text-[var(--chart-3)] hover:bg-accent rounded-full h-9 w-9",
832
- "aria-label": t("media.audioInfo"),
833
- children: /* @__PURE__ */ jsx(Info, { className: "w-4 h-4 fill-current" })
834
- }
835
- ) }),
836
- /* @__PURE__ */ jsx(TooltipContent, { className: "z-[1001]", children: t("media.info") })
837
- ] }) })
838
- ] }),
839
- /* @__PURE__ */ jsxs("div", { className: "hidden xl:flex items-center gap-1", children: [
840
- /* @__PURE__ */ jsxs(DropdownMenu, { children: [
841
- /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
842
- Button,
843
- {
844
- variant: "ghost",
845
- size: "icon",
846
- className: "rounded-full h-9 w-9",
847
- "aria-label": t("media.selectSpeed"),
848
- children: /* @__PURE__ */ jsx(Gauge, { className: "w-4 h-4" })
849
- }
850
- ) }),
851
- /* @__PURE__ */ jsx(DropdownMenuContent, { align: "center", className: "w-32 z-[1001]", children: [0.5, 1, 1.5, 2].map((speed) => /* @__PURE__ */ jsxs(
852
- DropdownMenuItem,
853
- {
854
- onClick: () => setPlaybackSpeed(speed),
855
- className: cn(
856
- "cursor-pointer",
857
- playbackSpeed === speed && "bg-accent font-bold"
858
- ),
859
- children: [
860
- speed,
861
- "x"
862
- ]
863
- },
864
- speed
865
- )) })
866
- ] }),
867
- /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [
868
- /* @__PURE__ */ jsx(TooltipTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
869
- Button,
870
- {
871
- variant: "ghost",
872
- size: "icon",
873
- className: "rounded-full h-9 w-9",
874
- "aria-label": t("media.downloadAudio"),
875
- children: /* @__PURE__ */ jsx(Download, { className: "w-4 h-4" })
876
- }
877
- ) }),
878
- /* @__PURE__ */ jsx(TooltipContent, { className: "z-[1001]", children: t("media.downloadAudio") })
879
- ] }) })
880
- ] }),
881
- /* @__PURE__ */ jsx("div", { className: "xl:hidden", children: /* @__PURE__ */ jsxs(DropdownMenu, { children: [
882
- /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
883
- Button,
884
- {
885
- variant: "ghost",
886
- size: "icon",
887
- className: "rounded-full h-9 w-9",
888
- "aria-label": t("media.moreOptions"),
889
- children: /* @__PURE__ */ jsx(MoreHorizontal, { className: "w-5 h-5" })
890
- }
891
- ) }),
892
- /* @__PURE__ */ jsxs(DropdownMenuContent, { align: "end", className: "w-56 p-2 z-[1001]", children: [
893
- /* @__PURE__ */ jsxs("div", { className: "lg:hidden", children: [
894
- /* @__PURE__ */ jsxs("div", { className: "px-2 py-3", children: [
895
- /* @__PURE__ */ jsx("div", { className: "flex items-center justify-between mb-3 px-1", children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
896
- isMuted || volume === 0 ? /* @__PURE__ */ jsx(VolumeX, { className: "w-4 h-4 text-muted-foreground" }) : /* @__PURE__ */ jsx(Volume2, { className: "w-4 h-4 text-muted-foreground" }),
897
- /* @__PURE__ */ jsx("span", { className: "text-[11px] font-medium uppercase tracking-wider text-muted-foreground/70", children: "Volume" })
898
- ] }) }),
899
- /* @__PURE__ */ jsx(
900
- Slider,
901
- {
902
- value: [isMuted ? 0 : volume * 100],
903
- max: 100,
904
- onValueChange: (val) => handleVolumeChange([val[0] / 100])
905
- }
906
- )
907
- ] }),
908
- /* @__PURE__ */ jsx(DropdownMenuSeparator, { className: "my-1" })
909
- ] }),
910
- /* @__PURE__ */ jsxs("div", { className: "md:hidden", children: [
911
- /* @__PURE__ */ jsxs(DropdownMenuItem, { onClick: resetAudio, className: "cursor-pointer py-2.5", children: [
912
- /* @__PURE__ */ jsx(RotateCcw, { className: "w-4 h-4 mr-3 text-muted-foreground" }),
913
- " ",
914
- t("media.restart")
915
- ] }),
916
- /* @__PURE__ */ jsxs(DropdownMenuItem, { className: "cursor-pointer py-2.5", children: [
917
- /* @__PURE__ */ jsx(Info, { className: "w-4 h-4 mr-3 text-muted-foreground" }),
918
- " ",
919
- t("media.info")
920
- ] }),
921
- /* @__PURE__ */ jsx(DropdownMenuSeparator, { className: "my-1" })
922
- ] }),
923
- /* @__PURE__ */ jsxs("div", { className: "xl:hidden", children: [
924
- /* @__PURE__ */ jsxs("div", { className: "px-3 py-2 flex flex-col gap-2", children: [
925
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
926
- /* @__PURE__ */ jsx(Gauge, { className: "w-4 h-4 text-muted-foreground" }),
927
- /* @__PURE__ */ jsx("span", { className: "text-sm font-medium", children: t("media.speed") })
928
- ] }),
929
- /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-1", children: [0.5, 1, 1.5, 2].map((speed) => /* @__PURE__ */ jsxs(
930
- "button",
931
- {
932
- onClick: () => setPlaybackSpeed(speed),
933
- className: cn(
934
- "px-2 py-0.5 text-[10px] rounded border transition-colors",
935
- playbackSpeed === speed ? "bg-primary text-primary-foreground border-primary" : "bg-transparent border-border hover:bg-accent"
936
- ),
937
- children: [
938
- speed,
939
- "x"
940
- ]
941
- },
942
- speed
943
- )) })
944
- ] }),
945
- /* @__PURE__ */ jsx(DropdownMenuSeparator, { className: "my-1" }),
946
- /* @__PURE__ */ jsxs(DropdownMenuItem, { className: "cursor-pointer py-2.5", children: [
947
- /* @__PURE__ */ jsx(Download, { className: "w-4 h-4 mr-3 text-muted-foreground" }),
948
- " ",
949
- t("media.downloadAudio")
950
- ] })
951
- ] })
952
- ] })
953
- ] }) }),
954
- /* @__PURE__ */ jsx("div", { className: "w-px h-8 bg-border mx-1" }),
955
- /* @__PURE__ */ jsx(
956
- Button,
957
- {
958
- onClick: onClose,
959
- variant: "ghost",
960
- size: "icon",
961
- className: "rounded-full h-9 w-9",
962
- "aria-label": t("media.closePlayer"),
963
- children: /* @__PURE__ */ jsx(X, { className: "w-5 h-5" })
964
- }
965
- )
966
- ] })
967
- ] })
968
- ]
969
- }
970
- );
971
- const mobileLayout = /* @__PURE__ */ jsxs(
972
- "div",
973
- {
974
- className: cn(
975
- "flex flex-col py-3 px-4 gap-3",
976
- colorVariant === "primary" && "py-4 px-5 gap-4"
977
- ),
978
- children: [
979
- /* @__PURE__ */ jsxs("div", { className: "flex items-start justify-between gap-3", children: [
980
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-w-0 flex-1", children: [
981
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 mb-1", children: [
982
- colorVariant === "primary" ? /* @__PURE__ */ jsx("div", { className: "w-2 h-2 rounded-full bg-[var(--chart-4)] animate-pulse shrink-0" }) : /* @__PURE__ */ jsx(Radio, { className: "w-3 h-3 text-[var(--chart-4)] animate-pulse shrink-0" }),
983
- /* @__PURE__ */ jsx(
984
- "h4",
985
- {
986
- className: cn(
987
- "truncate",
988
- colorVariant === "primary" ? "font-semibold text-sm tracking-tight" : "font-medium text-sm"
989
- ),
990
- children: title
991
- }
992
- )
993
- ] }),
994
- /* @__PURE__ */ jsx(
995
- "div",
996
- {
997
- className: cn(
998
- "flex items-center gap-1.5 text-xs text-muted-foreground",
999
- colorVariant === "primary" && "opacity-70"
1000
- ),
1001
- children: /* @__PURE__ */ jsx("span", { className: "truncate", children: subtitle || artist })
1002
- }
1003
- )
1004
- ] }),
1005
- /* @__PURE__ */ jsx(
1006
- Button,
1007
- {
1008
- onClick: onClose,
1009
- variant: "ghost",
1010
- size: "icon",
1011
- className: "rounded-full h-8 w-8 shrink-0",
1012
- "aria-label": t("media.closePlayer"),
1013
- children: /* @__PURE__ */ jsx(X, { className: "w-4 h-4" })
1014
- }
1015
- )
1016
- ] }),
1017
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3", children: [
1018
- /* @__PURE__ */ jsx(
1019
- "button",
1020
- {
1021
- onClick: togglePlay,
1022
- "aria-label": isPlaying ? t("media.pause") : t("media.play"),
1023
- className: "shrink-0 transition-transform active:scale-95",
1024
- children: isPlaying ? /* @__PURE__ */ jsx(
1025
- PauseCircle,
1026
- {
1027
- className: cn(colorVariant === "primary" ? "w-12 h-12" : "w-10 h-10"),
1028
- strokeWidth: colorVariant === "primary" ? 1 : 1.5
1029
- }
1030
- ) : /* @__PURE__ */ jsx(
1031
- PlayCircle,
1032
- {
1033
- className: cn(colorVariant === "primary" ? "w-12 h-12" : "w-10 h-10"),
1034
- strokeWidth: colorVariant === "primary" ? 1 : 1.5
1035
- }
1036
- )
1037
- }
1038
- ),
1039
- /* @__PURE__ */ jsx("div", { className: "flex-1 flex items-center gap-2", children: /* @__PURE__ */ jsx(
1040
- Slider,
1041
- {
1042
- value: [currentTime],
1043
- max: duration || 100,
1044
- onValueChange: handleSeek,
1045
- className: "cursor-pointer",
1046
- "aria-label": t("media.playbackProgress")
1047
- }
1048
- ) }),
1049
- /* @__PURE__ */ jsxs(DropdownMenu, { children: [
1050
- /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
1051
- Button,
1052
- {
1053
- variant: "ghost",
1054
- size: "icon",
1055
- className: "h-9 w-9 rounded-full",
1056
- "aria-label": t("media.moreOptions"),
1057
- children: /* @__PURE__ */ jsx(MoreVertical, { className: "w-5 h-5" })
1058
- }
1059
- ) }),
1060
- /* @__PURE__ */ jsxs(DropdownMenuContent, { align: "end", className: "w-56 p-2 z-[1001]", children: [
1061
- /* @__PURE__ */ jsx(DropdownMenuItem, { onClick: resetAudio, children: t("media.restart") }),
1062
- /* @__PURE__ */ jsx(DropdownMenuItem, { children: t("media.speedLabel", { speed: playbackSpeed }) })
1063
- ] })
1064
- ] })
1065
- ] })
1066
- ]
1067
- }
1068
- );
1069
- const desktopLayoutCompact = /* @__PURE__ */ jsxs(
1070
- "div",
1071
- {
1072
- className: cn(
1073
- "flex items-center gap-3 w-full",
1074
- isFloating ? "px-3 py-1 text-foreground" : "px-4 py-3"
1075
- ),
1076
- children: [
1077
- /* @__PURE__ */ jsx(
1078
- Button,
1079
- {
1080
- onClick: togglePlay,
1081
- size: "icon",
1082
- variant: "outline",
1083
- className: cn(
1084
- "shrink-0 rounded-full border-border text-foreground hover:bg-accent transition-colors",
1085
- colorVariant === "primary" && "border-primary-foreground/20 hover:bg-primary-foreground/10 text-primary-foreground",
1086
- isFloating ? "h-8 w-8" : "h-10 w-10"
1087
- ),
1088
- "aria-label": isPlaying ? t("media.pause") : t("media.play"),
1089
- children: isPlaying ? /* @__PURE__ */ jsx(Pause, { className: cn(isFloating ? "w-3 h-3" : "w-4 h-4", "fill-current") }) : /* @__PURE__ */ jsx(Play, { className: cn(isFloating ? "w-3 h-3" : "w-4 h-4", "fill-current ml-0.5") })
1090
- }
1091
- ),
1092
- /* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0 flex flex-col justify-center gap-1.5", children: [
1093
- /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between text-xs leading-none", children: [
1094
- /* @__PURE__ */ jsx(
1095
- "span",
1096
- {
1097
- className: cn(
1098
- "font-medium truncate",
1099
- colorVariant === "primary" ? "text-primary-foreground" : "text-foreground"
1100
- ),
1101
- children: title
1102
- }
1103
- ),
1104
- /* @__PURE__ */ jsxs(
1105
- "span",
1106
- {
1107
- className: cn(
1108
- "font-medium tabular-nums text-[10px] sm:text-xs",
1109
- colorVariant === "primary" ? "text-primary-foreground/70" : "text-muted-foreground"
1110
- ),
1111
- children: [
1112
- formatTime(currentTime),
1113
- " / ",
1114
- formatTime(duration)
1115
- ]
1116
- }
1117
- )
1118
- ] }),
1119
- /* @__PURE__ */ jsx(
1120
- Slider,
1121
- {
1122
- value: [currentTime],
1123
- max: duration || 100,
1124
- step: 1,
1125
- onValueChange: handleSeek,
1126
- className: "w-full",
1127
- "aria-label": t("media.playbackProgress")
1128
- }
1129
- )
1130
- ] }),
1131
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 shrink-0", children: [
1132
- /* @__PURE__ */ jsxs(DropdownMenu, { children: [
1133
- /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
1134
- Button,
1135
- {
1136
- variant: "ghost",
1137
- size: "icon",
1138
- className: cn(
1139
- "rounded-full",
1140
- colorVariant === "primary" ? "text-primary-foreground/80 hover:text-primary-foreground hover:bg-primary-foreground/10" : "text-muted-foreground hover:text-foreground",
1141
- isFloating ? "h-7 w-7" : "h-8 w-8"
1142
- ),
1143
- "aria-label": "Mais opções",
1144
- children: /* @__PURE__ */ jsx(MoreVertical, { className: isFloating ? "w-4 h-4" : "w-5 h-5" })
1145
- }
1146
- ) }),
1147
- /* @__PURE__ */ jsxs(DropdownMenuContent, { align: "end", className: "w-56 p-2 z-[1001]", children: [
1148
- /* @__PURE__ */ jsxs("div", { className: "px-2 py-3", children: [
1149
- /* @__PURE__ */ jsx("div", { className: "flex items-center justify-between mb-3 px-1", children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
1150
- isMuted || volume === 0 ? /* @__PURE__ */ jsx(VolumeX, { className: "w-4 h-4 text-muted-foreground" }) : /* @__PURE__ */ jsx(Volume2, { className: "w-4 h-4 text-muted-foreground" }),
1151
- /* @__PURE__ */ jsx("span", { className: "text-[11px] font-medium uppercase tracking-wider text-muted-foreground/70", children: "Volume" })
1152
- ] }) }),
1153
- /* @__PURE__ */ jsx(
1154
- Slider,
1155
- {
1156
- value: [isMuted ? 0 : volume * 100],
1157
- max: 100,
1158
- onValueChange: (val) => handleVolumeChange([val[0] / 100]),
1159
- "aria-label": "Volume"
1160
- }
1161
- )
1162
- ] }),
1163
- /* @__PURE__ */ jsx(DropdownMenuSeparator, { className: "my-2" }),
1164
- /* @__PURE__ */ jsxs("div", { className: "px-2 py-1 flex flex-col gap-2", children: [
1165
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
1166
- /* @__PURE__ */ jsx(Gauge, { className: "w-4 h-4 text-muted-foreground" }),
1167
- /* @__PURE__ */ jsx("span", { className: "text-sm font-medium", children: t("media.speed") })
1168
- ] }),
1169
- /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-1", children: [0.5, 1, 1.5, 2].map((speed) => /* @__PURE__ */ jsxs(
1170
- "button",
1171
- {
1172
- onClick: () => setPlaybackSpeed(speed),
1173
- className: cn(
1174
- "px-2 py-1 text-[10px] rounded border transition-colors",
1175
- playbackSpeed === speed ? "bg-primary text-primary-foreground border-primary" : "bg-transparent border-border hover:bg-accent"
1176
- ),
1177
- children: [
1178
- speed,
1179
- "x"
1180
- ]
1181
- },
1182
- speed
1183
- )) })
1184
- ] }),
1185
- /* @__PURE__ */ jsx(DropdownMenuSeparator, { className: "my-2" }),
1186
- /* @__PURE__ */ jsxs(DropdownMenuItem, { onClick: resetAudio, className: "cursor-pointer py-2.5", children: [
1187
- /* @__PURE__ */ jsx(RotateCcw, { className: "w-4 h-4 mr-3 text-muted-foreground" }),
1188
- /* @__PURE__ */ jsx("span", { className: "text-sm", children: t("media.restart") })
1189
- ] }),
1190
- /* @__PURE__ */ jsxs(DropdownMenuItem, { className: "cursor-pointer py-2.5", children: [
1191
- /* @__PURE__ */ jsx(Download, { className: "w-4 h-4 mr-3 text-muted-foreground" }),
1192
- /* @__PURE__ */ jsx("span", { className: "text-sm", children: t("media.downloadFile") })
1193
- ] })
1194
- ] })
1195
- ] }),
1196
- !isFloating && /* @__PURE__ */ jsx(
1197
- Button,
1198
- {
1199
- variant: "ghost",
1200
- size: "icon",
1201
- className: cn(
1202
- "h-8 w-8",
1203
- colorVariant === "primary" ? "text-primary-foreground/80 hover:text-primary-foreground hover:bg-primary-foreground/10" : "text-muted-foreground hover:text-foreground"
1204
- ),
1205
- onClick: handleEnableManualFloat,
1206
- title: t("media.floatingMode"),
1207
- "aria-label": t("media.openFloatingMode"),
1208
- children: /* @__PURE__ */ jsx(Maximize2, { className: "w-4 h-4" })
1209
- }
1210
- )
1211
- ] })
1212
- ]
1213
- }
1214
- );
1215
- if (!isVisible) return null;
1216
- if (variant === "bar" && isVisible && typeof document !== "undefined") {
1217
- return createPortal(
1218
- /* @__PURE__ */ jsxs(
1219
- "div",
1220
- {
1221
- className: cn(
1222
- "fixed bottom-0 z-[100] border-t transition-all duration-300 ease-in-out",
1223
- colorVariant === "primary" ? "bg-primary/95 text-primary-foreground border-primary/20 backdrop-blur-sm [&_.text-muted-foreground]:text-primary-foreground/70 [&_.text-foreground]:text-primary-foreground [&_button]:text-primary-foreground [&_[data-slot=slider-track]]:bg-primary-foreground/30 [&_[data-slot=slider-range]]:bg-primary-foreground [&_[data-slot=slider-thumb]]:border-primary-foreground [&_[data-slot=slider-thumb]]:bg-primary-foreground" : "bg-card/95 text-card-foreground border-border backdrop-blur-md shadow-[var(--elevation-sm)]",
1224
- isOpen ? "translate-y-0 opacity-100" : "translate-y-full opacity-0",
1225
- className
1226
- ),
1227
- style: {
1228
- left: isMobile ? 0 : sidebarExpanded ? sidebarWidth : 80,
1229
- right: isMobile ? 0 : assistenteExpanded ? 420 : 80
1230
- },
1231
- children: [
1232
- audioElement,
1233
- !isMobile ? desktopLayout : mobileLayout
1234
- ]
1235
- }
1236
- ),
1237
- document.body
1238
- );
1239
- }
1240
- return /* @__PURE__ */ jsxs("div", { ref: containerRef, className, children: [
1241
- audioElement,
1242
- /* @__PURE__ */ jsx(
1243
- FloatingMediaWrapper,
1244
- {
1245
- isFloating,
1246
- setIsFloating: handleSetFloating,
1247
- onClose: () => handleSetFloating(false),
1248
- onCloseMedia: () => {
1249
- handleSetFloating(false);
1250
- },
1251
- title: t("media.playingMedia"),
1252
- aspectRatio: 320 / 110,
1253
- minHeight: 110,
1254
- minWidth: 320,
1255
- colorVariant,
1256
- className: "w-full",
1257
- playerId: "audio-player",
1258
- enablePadding: true,
1259
- children: /* @__PURE__ */ jsx(
1260
- "div",
1261
- {
1262
- className: cn(
1263
- "w-full overflow-hidden flex flex-col justify-center",
1264
- colorVariant === "primary" ? "bg-primary text-primary-foreground [&_[data-slot=slider-track]]:bg-white/20 [&_[data-slot=slider-range]]:bg-white [&_[data-slot=slider-thumb]]:border-white [&_[data-slot=slider-thumb]]:bg-white" : "bg-card text-card-foreground",
1265
- isFloating ? "h-full bg-transparent" : "border rounded-md shadow-sm"
1266
- ),
1267
- children: desktopLayoutCompact
1268
- }
1269
- )
1270
- }
1271
- )
1272
- ] });
1273
- }
1274
- export {
1275
- AudioPlayer as A,
1276
- FloatingMediaWrapper as F,
1277
- VideoPlayer as V
1278
- };