@acedatacloud/nexior 3.138.0 → 3.140.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 (248) hide show
  1. package/dist/assets/{Auth-ce3rdRmZ.js → Auth-_LymSVHY.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-jDf8T7ol.js → BotPlaceholder-BJ5FbY4i.js} +1 -1
  3. package/dist/assets/{Callback-DpIhEpMc.js → Callback-D8VLVbwT.js} +1 -1
  4. package/dist/assets/{Console-D5Wc8XjW.js → Console-CG2HSHPy.js} +1 -1
  5. package/dist/assets/{Consumption-F9vhwk03.js → Consumption-DbcJR769.js} +1 -1
  6. package/dist/assets/{Conversation-DP1owmgR.css → Conversation-8QQpKxQ2.css} +1 -1
  7. package/dist/assets/Conversation-qiP7Ljvl.js +25 -0
  8. package/dist/assets/{CopyToClipboard-UjbBZ_ac.js → CopyToClipboard-SvDri6QJ.js} +1 -1
  9. package/dist/assets/{Detail-DeALY2Ko.js → Detail-CaZ-hDL7.js} +2 -2
  10. package/dist/assets/{EditArray-CQCTrb4Y.js → EditArray-CbQP4S-F.js} +1 -1
  11. package/dist/assets/{Extra-DuPu2cIH.js → Extra-BULn0zDY.js} +1 -1
  12. package/dist/assets/{FilePreview-LbYKIcSs.js → FilePreview-Cwpu3SIj.js} +1 -1
  13. package/dist/assets/{History-o0EcSv3q.js → History-CtH_1ws4.js} +1 -1
  14. package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-4YLqaqth.js → IconPark.vue_vue_type_script_setup_true_lang-CgTVojOA.js} +1 -1
  15. package/dist/assets/{ImagePreview-CLAIXPcM.js → ImagePreview-BO9qxdtw.js} +1 -1
  16. package/dist/assets/{ImageWrapper-C8ang_Wj.js → ImageWrapper-B52RJa5L.js} +1 -1
  17. package/dist/assets/{Index-CJ29A5rX.js → Index-1KACE6bz.js} +1 -1
  18. package/dist/assets/{Index-JE5YYUMV.js → Index-B69Ve09b.js} +1 -1
  19. package/dist/assets/{Index-D25PMiYa.js → Index-B7rY2idV.js} +1 -1
  20. package/dist/assets/{Index-CeBegiSh.js → Index-BYcvXPty.js} +1 -1
  21. package/dist/assets/{Index-DDhCYbL9.js → Index-Bl5aio-K.js} +1 -1
  22. package/dist/assets/{Index-Cy5DS50I.js → Index-Bw1M_Jfd.js} +1 -1
  23. package/dist/assets/{Index-DzFcIN7G.js → Index-C8eA4wu8.js} +1 -1
  24. package/dist/assets/{Index-D8duFiej.js → Index-CMBHe-G0.js} +1 -1
  25. package/dist/assets/{Index-BURfwB3I.js → Index-Ce_F15ff.js} +1 -1
  26. package/dist/assets/{Index-DMsHr9rJ.js → Index-D5G8wpCZ.js} +1 -1
  27. package/dist/assets/{Index-Bbmtgx3l.js → Index-D8cI9nhp.js} +1 -1
  28. package/dist/assets/{Index-DRPyyBix.js → Index-DG70VeAA.js} +1 -1
  29. package/dist/assets/{Index-TiP24BFQ.js → Index-DTXHqDrW.js} +1 -1
  30. package/dist/assets/{Index-D6IAh2bo.js → Index-DmMs4bpd.js} +1 -1
  31. package/dist/assets/{Index-CEv6yGxY.js → Index-DrFuy0Sc.js} +1 -1
  32. package/dist/assets/{Index-D9ASCqPb.js → Index-Dy7i1mMI.js} +1 -1
  33. package/dist/assets/{Index-Bbv5JR8H.js → Index-FS0NwQFu.js} +1 -1
  34. package/dist/assets/{Index-Dy5wg0fw.js → Index-IOQUEktk.js} +1 -1
  35. package/dist/assets/{Index-BkdZj0oV.js → Index-ZW0l-gSU.js} +1 -1
  36. package/dist/assets/{Index-CbHYW1tI.js → Index-eTuQDUed.js} +1 -1
  37. package/dist/assets/{Index-BYspsqa3.js → Index-iDsCEz7i.js} +1 -1
  38. package/dist/assets/{Index-F8wnRAUn.js → Index-oD07FM19.js} +1 -1
  39. package/dist/assets/{Index-C1KDpY6C.js → Index-plSIOh0T.js} +1 -1
  40. package/dist/assets/{Index-BQnGFOKH.js → Index-whALR0m6.js} +1 -1
  41. package/dist/assets/{Invitees-B5ed4KTr.js → Invitees-D7z44jFi.js} +1 -1
  42. package/dist/assets/{List-C7vv74f_.js → List-8YQXVuQf.js} +1 -1
  43. package/dist/assets/{List-C8qcs0Hp.js → List-BIj3Qdm4.js} +1 -1
  44. package/dist/assets/{List-lxOJoJK4.js → List-BaUq86Oo.js} +1 -1
  45. package/dist/assets/{Main-BIzlwttm.js → Main-C1JQ53J6.js} +1 -1
  46. package/dist/assets/{Navigator-CZjanqUK.js → Navigator-4m9v9-V1.js} +1 -1
  47. package/dist/assets/{NoTasks-sYq9Zr2G.js → NoTasks-B3OHHyLX.js} +1 -1
  48. package/dist/assets/{NotFound-BtNPwVRy.js → NotFound-DKHombag.js} +1 -1
  49. package/dist/assets/{OAuthCallback-CtMLctuA.js → OAuthCallback-DWXJd5LX.js} +1 -1
  50. package/dist/assets/{Pagination-Ph0T0Z8v.js → Pagination-CE1vXzka.js} +1 -1
  51. package/dist/assets/{ScrollList-COWNfBjK.js → ScrollList-BdIMpJr2.js} +1 -1
  52. package/dist/assets/{Status-RsS_AjOU.js → Status-Zg7HPSWQ.js} +1 -1
  53. package/dist/assets/{Subscribe-CLzay7tc.js → Subscribe-uUIr88Kf.js} +1 -1
  54. package/dist/assets/{TransportWebHID-_Z-zoQ7l.js → TransportWebHID-BcFo5JW0.js} +1 -1
  55. package/dist/assets/{VideoPlayer-CzcMT9AZ.js → VideoPlayer-DLau3K08.js} +1 -1
  56. package/dist/assets/{_Uint8Array-DYoXPfzZ.js → _Uint8Array-d0PfytAk.js} +1 -1
  57. package/dist/assets/{_baseClone-BHq6vhwI.js → _baseClone-fTTPu5Nv.js} +1 -1
  58. package/dist/assets/{_baseIteratee-CCpRH0CC.js → _baseIteratee-CbQQ2vi2.js} +1 -1
  59. package/dist/assets/{_initCloneObject-D8dKrUgV.js → _initCloneObject-BrlQCApt.js} +1 -1
  60. package/dist/assets/{add-BGXMA_8T.js → add-B93qtnGy.js} +1 -1
  61. package/dist/assets/{all-wallets-DCYmLWJE.js → all-wallets-DNoBZlZA.js} +1 -1
  62. package/dist/assets/{app-store-DcNXK_08.js → app-store-D9AI4Dxh.js} +1 -1
  63. package/dist/assets/{apple--YwSBZ1p.js → apple-BYjbzrtS.js} +1 -1
  64. package/dist/assets/{arrow-bottom-BWJcxbY1.js → arrow-bottom-BKepjcWR.js} +1 -1
  65. package/dist/assets/{arrow-bottom-circle-CfhDDcRG.js → arrow-bottom-circle-GkX0k7HO.js} +1 -1
  66. package/dist/assets/{arrow-left-BZ9eYo63.js → arrow-left-B0sBDTr7.js} +1 -1
  67. package/dist/assets/{arrow-right-Ce2Q2tqR.js → arrow-right-C1278OeZ.js} +1 -1
  68. package/dist/assets/{arrow-top-agqLmKzp.js → arrow-top-yFQQo-bC.js} +1 -1
  69. package/dist/assets/{avatar-C5rMPMQA.js → avatar-C9rdhiY6.js} +1 -1
  70. package/dist/assets/{bank-DazleBXQ.js → bank-Bk9B55lW.js} +1 -1
  71. package/dist/assets/{basic-BEd45NJt.js → basic-CpXv-Ouc.js} +1 -1
  72. package/dist/assets/{browser-CAJChiMD.js → browser-C72wDNfD.js} +1 -1
  73. package/dist/assets/{byokCredential-DHAgK6la.js → byokCredential-COoNuDGk.js} +1 -1
  74. package/dist/assets/{card-BN1OJOl7.js → card-ijgyk8uK.js} +1 -1
  75. package/dist/assets/{castArray-kDnnxK3Y.js → castArray-B4IZIXMJ.js} +1 -1
  76. package/dist/assets/{chat-DSQB5EZd.js → chat-BreiLx2Y.js} +1 -1
  77. package/dist/assets/{chat-CSWRFf4v.js → chat-CEFfFUFV.js} +1 -1
  78. package/dist/assets/chat-hszNYhcY.js +2 -0
  79. package/dist/assets/{checkmark-DI3hWSni.js → checkmark-BC_u9LvK.js} +1 -1
  80. package/dist/assets/{checkmark-bold-Wx3_nn8v.js → checkmark-bold-CJTeENay.js} +1 -1
  81. package/dist/assets/{chevron-bottom-CNHfS4XU.js → chevron-bottom-BLAb99fm.js} +1 -1
  82. package/dist/assets/{chevron-left-33wOwNSY.js → chevron-left-C-KaZ8Ii.js} +1 -1
  83. package/dist/assets/{chevron-right-DXC2DAp1.js → chevron-right-CW7obEBt.js} +1 -1
  84. package/dist/assets/{chevron-top-C6b9DzK6.js → chevron-top-Gwhy1WXI.js} +1 -1
  85. package/dist/assets/{chrome-store-c28WhCBV.js → chrome-store-D6C_VxZP.js} +1 -1
  86. package/dist/assets/{clock-DSFmzL5w.js → clock-BZzsJnBh.js} +1 -1
  87. package/dist/assets/{close-DKeW9KpM.js → close-D5AUrs1t.js} +1 -1
  88. package/dist/assets/{coinPlaceholder-B06ZmATh.js → coinPlaceholder-Betr_qsF.js} +1 -1
  89. package/dist/assets/{compass-ESre6PfN.js → compass-C1XwaPjY.js} +1 -1
  90. package/dist/assets/{copy-CYlCEN_q.js → copy-BRLdvVl1.js} +1 -1
  91. package/dist/assets/{cursor-N1JE2Bw0.js → cursor-Csz4ImSz.js} +1 -1
  92. package/dist/assets/{cursor-transparent-CSFf2ehP.js → cursor-transparent-BAeup_qF.js} +1 -1
  93. package/dist/assets/{debounce-B3qQloOM.js → debounce-BA7XqfxN.js} +1 -1
  94. package/dist/assets/{desktop-DBhXcxk0.js → desktop-B5qQ-34S.js} +1 -1
  95. package/dist/assets/{disconnect-C59zYEFS.js → disconnect-ITeinKwI.js} +1 -1
  96. package/dist/assets/{discord-DXIBRlvC.js → discord-CQuq4CF0.js} +1 -1
  97. package/dist/assets/{distribution-DT9fOzPO.js → distribution-CrhODU4b.js} +1 -1
  98. package/dist/assets/{dropdown-CMUX2QKQ.js → dropdown-CNDQXnop.js} +1 -1
  99. package/dist/assets/{etherscan-DB3HK--R.js → etherscan-DraWsHGP.js} +1 -1
  100. package/dist/assets/{exclamation-triangle-C1lRCtWt.js → exclamation-triangle-D8XUY8Dn.js} +1 -1
  101. package/dist/assets/{extension-BOZrGfQI.js → extension-CV4hDiKR.js} +1 -1
  102. package/dist/assets/{external-link-Cj3_kBJO.js → external-link-Rd2NH-lT.js} +1 -1
  103. package/dist/assets/{facebook-D6l_0ap0.js → facebook-Do0kYthD.js} +1 -1
  104. package/dist/assets/{farcaster-ChEQZGBw.js → farcaster-tacff7nd.js} +1 -1
  105. package/dist/assets/{filters-LpZcVQBi.js → filters-BBkb4u6P.js} +1 -1
  106. package/dist/assets/{flux-CPR5vnEI.js → flux-6wSvMgLC.js} +1 -1
  107. package/dist/assets/{github-0Rkb_QWC.js → github-CpcxQW5n.js} +1 -1
  108. package/dist/assets/{google-DbVZ6Fqy.js → google-C9RSC2CH.js} +1 -1
  109. package/dist/assets/{hailuo-BLJIV_7y.js → hailuo-BU4hGWPk.js} +1 -1
  110. package/dist/assets/{headshots-Bx_UIc8L.js → headshots-B7u83Q7g.js} +1 -1
  111. package/dist/assets/{help-circle-Dmmd_SNC.js → help-circle-CY06i_BS.js} +1 -1
  112. package/dist/assets/{id-D4BuZaYx.js → id-DaHsBZvc.js} +1 -1
  113. package/dist/assets/{image-Dx-DY7U2.js → image-DQ4sXWI0.js} +1 -1
  114. package/dist/assets/{index-DJTe9ay4.js → index-0whYJzw3.js} +1 -1
  115. package/dist/assets/{index-wOnlnU-2.js → index-31IXHWou.js} +1 -1
  116. package/dist/assets/{index-D4_8u5Xr.js → index-B2lOppkd.js} +1 -1
  117. package/dist/assets/{index-BeptfZWv.js → index-B34AK5IJ.js} +1 -1
  118. package/dist/assets/{index-DKlUKxnB.js → index-B5VThxFx.js} +4 -4
  119. package/dist/assets/{index-B2zgIuN-.js → index-B8HUVpGf.js} +1 -1
  120. package/dist/assets/{index-DCjTjFFq.js → index-BC_JWoDT.js} +1 -1
  121. package/dist/assets/{index-g1qbc9hT.js → index-BG8woF1-.js} +1 -1
  122. package/dist/assets/{index-DD7PDhJt.js → index-BIKYfCNm.js} +1 -1
  123. package/dist/assets/{index-JFdmI4KS.js → index-BILP-M8E.js} +1 -1
  124. package/dist/assets/{index-CDb5I0Er.js → index-BOQt7rnX.js} +1 -1
  125. package/dist/assets/{index-DFSMTET3.js → index-BUq14ZPa.js} +1 -1
  126. package/dist/assets/{index-Bk7uGYgD.js → index-B_dZSh1V.js} +1 -1
  127. package/dist/assets/{index-DWRzkHl-.js → index-B_ur4XP_.js} +1 -1
  128. package/dist/assets/{index-DEerCStc.js → index-Ba8GdmXg.js} +1 -1
  129. package/dist/assets/{index-D9-nLyZk.js → index-BcFuJFD4.js} +1 -1
  130. package/dist/assets/{index-QRqt1QsU.js → index-Bcez2XRv.js} +1 -1
  131. package/dist/assets/{index-C5k5XrNd.js → index-Be_dGkoS.js} +1 -1
  132. package/dist/assets/{index-CU7Tkmoe.js → index-Bguan4wd.js} +1 -1
  133. package/dist/assets/{index-Dyd6KG-o.js → index-Bsa0Z5HA.js} +1 -1
  134. package/dist/assets/{index-B_59vVR6.js → index-BthUaHYA.js} +1 -1
  135. package/dist/assets/{index-KYiQ64-R.js → index-Bz6BMWRu.js} +1 -1
  136. package/dist/assets/{index-mIRybi7_.js → index-C-CXdBJG.js} +1 -1
  137. package/dist/assets/{index-CDP5BcG3.js → index-C2xIzhRm.js} +1 -1
  138. package/dist/assets/{index-BeJ6JfNM.js → index-C6VAcwnH.js} +1 -1
  139. package/dist/assets/{index-4dcAEEAI.js → index-C7Ek_Jhd.js} +1 -1
  140. package/dist/assets/{index-DugzSlEH.js → index-CAk1ZtSG.js} +1 -1
  141. package/dist/assets/{index-DP0aQPsL.js → index-CDqYmEPq.js} +1 -1
  142. package/dist/assets/{index-ByzOFVtn.js → index-CKXwdWS1.js} +1 -1
  143. package/dist/assets/{index-CW2ML0Zo.js → index-CPQzwH96.js} +1 -1
  144. package/dist/assets/{index-DldHTE2z.js → index-CUIaVEEQ.js} +1 -1
  145. package/dist/assets/{index-vn4ig8tm.js → index-CWieNN1E.js} +1 -1
  146. package/dist/assets/{index-DFloj7qj.js → index-C_u-Xh_j.js} +1 -1
  147. package/dist/assets/{index-BMDbvDvb.js → index-CcP0tlvX.js} +1 -1
  148. package/dist/assets/{index-k1IBAXDd.js → index-Cci1tT0O.js} +1 -1
  149. package/dist/assets/{index-BMRSApyp.js → index-CdSLN7HB.js} +1 -1
  150. package/dist/assets/{index-Ci2kDHK1.js → index-CixKTx1D.js} +1 -1
  151. package/dist/assets/{index-B3xHboRT.js → index-D5oeXKkE.js} +1 -1
  152. package/dist/assets/{index-CMrxr9s5.js → index-D8fds_1u.js} +1 -1
  153. package/dist/assets/{index-CrrePoOF.js → index-DH9G37nk.js} +1 -1
  154. package/dist/assets/{index-B6wCkhcv.js → index-DInwVxS4.js} +1 -1
  155. package/dist/assets/{index-GRDTUL4i.js → index-DNp_zr5x.js} +1 -1
  156. package/dist/assets/{index-y8_Rqhz8.js → index-DWBo0ly2.js} +1 -1
  157. package/dist/assets/{index-5lJZrwJi.css → index-DZIBVLbD.css} +1 -1
  158. package/dist/assets/{index-z4KYoIkr.js → index-DfEh6JbL.js} +1 -1
  159. package/dist/assets/{index-BnFifvyP.js → index-DlU-8lli.js} +1 -1
  160. package/dist/assets/{index-D3IlXm3d.js → index-DoWnluw7.js} +1 -1
  161. package/dist/assets/{index-PP8LGD_B.js → index-DswOcPEa.js} +1 -1
  162. package/dist/assets/{index-CJJYXPH3.js → index-DxPLAFH3.js} +6 -6
  163. package/dist/assets/{index-7HuuBLDY.js → index-DxoEG6lW.js} +1 -1
  164. package/dist/assets/{index-D9fXTOdx.js → index-DxxbHbIm.js} +1 -1
  165. package/dist/assets/{index-tL2fvVMN.js → index-Dy0qED3w.js} +3 -3
  166. package/dist/assets/{index-CroNukia.js → index-Egbcg_-M.js} +1 -1
  167. package/dist/assets/{index-BiWHgAHp.js → index-Mv1rryhx.js} +1 -1
  168. package/dist/assets/{index-SNhtZZZY.js → index-N-6pnqez.js} +1 -1
  169. package/dist/assets/{index-BVrGyG9B.js → index-Y6Hpp21c.js} +1 -1
  170. package/dist/assets/{index-DTZY5KH9.js → index-Z1E1odYA.js} +1 -1
  171. package/dist/assets/{index-DrmqP8Ga.js → index-_smvFLQP.js} +1 -1
  172. package/dist/assets/{index-CudWSSy4.js → index-dRUpg9As.js} +1 -1
  173. package/dist/assets/{index-B4Ov55Re.js → index-jKSTpmaL.js} +1 -1
  174. package/dist/assets/{index-BRTqKX2j.js → index-oU9_V6oJ.js} +1 -1
  175. package/dist/assets/{index-CFRgclbH.js → index-osFi-BCF.js} +1 -1
  176. package/dist/assets/{index-Dxtss4Aw.js → index-y2mM1cgT.js} +1 -1
  177. package/dist/assets/{index.browser.esm-C4XPCfcW.js → index.browser.esm-DZx_8qLl.js} +1 -1
  178. package/dist/assets/{index.es-DWP0WL9I.js → index.es-B8_8wmrH.js} +1 -1
  179. package/dist/assets/{info-DDbQ9AB9.js → info-Bj4o9GoD.js} +1 -1
  180. package/dist/assets/{info-circle-PMuT3QMW.js → info-circle-CBE6UHzd.js} +1 -1
  181. package/dist/assets/{isEqual-DGwqaOMZ.js → isEqual-BvJig0uU.js} +1 -1
  182. package/dist/assets/{isPlainObject-CzIy6uEw.js → isPlainObject-C9zmKCkE.js} +1 -1
  183. package/dist/assets/{kling-BIWAA77k.js → kling-DWJvDB11.js} +1 -1
  184. package/dist/assets/{lightbulb-Duxr4J7a.js → lightbulb-xdtRWsiI.js} +1 -1
  185. package/dist/assets/{luma-vgv1N1AU.js → luma-BQ8tyV3i.js} +1 -1
  186. package/dist/assets/{mail-C-bKcDjS.js → mail-CE8DuNsx.js} +1 -1
  187. package/dist/assets/{midjourney-DFmIRaLT.js → midjourney-Cddrv9Xo.js} +1 -1
  188. package/dist/assets/{mobile-DrQqOJxz.js → mobile-Cv7uklzk.js} +1 -1
  189. package/dist/assets/{more-wHNaoE-o.js → more-CvrKWk4v.js} +1 -1
  190. package/dist/assets/{nanobanana-Czv7NSZ9.js → nanobanana-DSIlRYud.js} +1 -1
  191. package/dist/assets/{network-placeholder-CdEfBd7w.js → network-placeholder-BSbY-_5z.js} +1 -1
  192. package/dist/assets/{nftPlaceholder-BfhBj2DU.js → nftPlaceholder-D-NECGNr.js} +1 -1
  193. package/dist/assets/{off-B6Giq2oS.js → off-DpR4B8lE.js} +1 -1
  194. package/dist/assets/{openaiimage-CPL-k0ta.js → openaiimage-B9UxqgmS.js} +1 -1
  195. package/dist/assets/{order-C8mb3rj3.js → order-ClaX22ro.js} +1 -1
  196. package/dist/assets/{pika-BIeozJai.js → pika-v05SyYq8.js} +1 -1
  197. package/dist/assets/{pixverse-D-aoq3eL.js → pixverse-DjSyVx-S.js} +1 -1
  198. package/dist/assets/{play-store-DLbZCRda.js → play-store-BugAN8rJ.js} +1 -1
  199. package/dist/assets/{plus-uG-Jnl_X.js → plus-BhaipuHz.js} +1 -1
  200. package/dist/assets/{price-BLWWDZIp.js → price-D-PQQgbY.js} +1 -1
  201. package/dist/assets/{producer-D59483ZS.js → producer-BY35pUwo.js} +1 -1
  202. package/dist/assets/{qr-code-C-mIdQB9.js → qr-code-CFDziJ7e.js} +1 -1
  203. package/dist/assets/{qrart-D3KRo_eW.js → qrart-AFGt2xmM.js} +1 -1
  204. package/dist/assets/{recycle-horizontal-xhmF_zJB.js → recycle-horizontal-DptpMyQ_.js} +1 -1
  205. package/dist/assets/{refresh-DXIBzwQQ.js → refresh-DsMBrtLt.js} +1 -1
  206. package/dist/assets/{reown-logo-0hj7lfvM.js → reown-logo-CggG85vM.js} +1 -1
  207. package/dist/assets/{search-D8BPON0e.js → search-kXX3d3ZC.js} +1 -1
  208. package/dist/assets/{secp256k1-BYnnD9dN.js → secp256k1-BQNrEMrg.js} +1 -1
  209. package/dist/assets/{secp256k1-DQVVKY0l.js → secp256k1-D72bvHEY.js} +1 -1
  210. package/dist/assets/{seedance-hnQutmCk.js → seedance-DCDhpgtJ.js} +1 -1
  211. package/dist/assets/{seedream-MX_il-6f.js → seedream-Cmgunzu1.js} +1 -1
  212. package/dist/assets/{send-Caw5detS.js → send-CR0294Ci.js} +1 -1
  213. package/dist/assets/{service-BOZ_G8ev.js → service-CAd9yoJh.js} +1 -1
  214. package/dist/assets/{solana-wallets-qwTlbPkW.js → solana-wallets-DHVNhXnl.js} +2 -2
  215. package/dist/assets/{solana-wallets-vue-yTedoLeg.js → solana-wallets-vue-dS1vBppj.js} +1 -1
  216. package/dist/assets/{solanaEmbed.esm-CPiwcJGn.js → solanaEmbed.esm-B_3uUCzY.js} +1 -1
  217. package/dist/assets/{sora-CQJ9mlK7.js → sora-CXr-RfWX.js} +1 -1
  218. package/dist/assets/{string_decoder-jRfZl5dK.js → string_decoder-Bv1TnyvQ.js} +1 -1
  219. package/dist/assets/{suno-CX8Vb7de.js → suno-fOp1B614.js} +1 -1
  220. package/dist/assets/{swapHorizontal-CUwiHAuo.js → swapHorizontal-Bxo1zohh.js} +1 -1
  221. package/dist/assets/{swapHorizontalBold-CzStE7sA.js → swapHorizontalBold-BoS8aZC6.js} +1 -1
  222. package/dist/assets/{swapHorizontalMedium-m0KKrGJo.js → swapHorizontalMedium-CFhfc9Gm.js} +1 -1
  223. package/dist/assets/{swapHorizontalRoundedBold-N3YLtR6L.js → swapHorizontalRoundedBold-Ev1g03EH.js} +1 -1
  224. package/dist/assets/{swapVertical-QfKCnEff.js → swapVertical-iPxCqeqj.js} +1 -1
  225. package/dist/assets/{telegram-BomdT1Pr.js → telegram-Dl9BvNpd.js} +1 -1
  226. package/dist/assets/{three-dots-BX4pRDU5.js → three-dots-Cak17HyR.js} +1 -1
  227. package/dist/assets/{twitch-DUyuvUlT.js → twitch-CCZ1y_XY.js} +1 -1
  228. package/dist/assets/{twitterIcon-BbQNR1PA.js → twitterIcon-YEXNg-1W.js} +1 -1
  229. package/dist/assets/{typescript-DEARewO1.js → typescript-Ch72LBtj.js} +1 -1
  230. package/dist/assets/{use-form-item-BR1a3Xvf.js → use-form-item-DOEGLSGe.js} +1 -1
  231. package/dist/assets/validator-DgDQ8pCz.js +1 -0
  232. package/dist/assets/{veo-B0_jjzRC.js → veo-IaIv3GnY.js} +1 -1
  233. package/dist/assets/{verify-3Lisxc3k.js → verify-D_sPvM-I.js} +1 -1
  234. package/dist/assets/{verify-filled-DDZUFx8U.js → verify-filled-CwgDxfrN.js} +1 -1
  235. package/dist/assets/{w3m-modal-ZorJACpV.js → w3m-modal-E6_oVWC8.js} +1 -1
  236. package/dist/assets/{wallet-B7s267s2.js → wallet-bvnR7pdh.js} +1 -1
  237. package/dist/assets/{wallet-placeholder-DA03mR05.js → wallet-placeholder-D0ikURGc.js} +1 -1
  238. package/dist/assets/{walletconnect-DPcUXR0J.js → walletconnect-O8ZXqM5K.js} +1 -1
  239. package/dist/assets/{wan-CrFiliGM.js → wan-CMwds55r.js} +1 -1
  240. package/dist/assets/{warning-circle-z9GWBh3-.js → warning-circle-Ds_ecbxX.js} +1 -1
  241. package/dist/assets/{web-BfsiDNlq.js → web-BaZ2l6QY.js} +1 -1
  242. package/dist/assets/{web-D42Ugk3p.js → web-DRdhM3qM.js} +1 -1
  243. package/dist/assets/{x-Buebc_Mi.js → x-BcZzviI5.js} +1 -1
  244. package/dist/index.html +2 -2
  245. package/package.json +1 -1
  246. package/dist/assets/Conversation-BOhG8w7f.js +0 -25
  247. package/dist/assets/chat-DMv_1H1X.js +0 -2
  248. package/dist/assets/validator-395EcdVg.js +0 -1
@@ -1 +1 @@
1
- import{F as D}from"./index.es-DWP0WL9I.js";import{E as W}from"./index-DD7PDhJt.js";import{E as oe}from"./index-CMrxr9s5.js";import{d as b,H as c,E as o,z as B,C as s,y as d,D as r,q as n,F as a,O as G,N as q,J as f,x as v,I as E,G as R,K as H,M as P,u as A,c as T,w as se,L as ne}from"./vendor-vue-NSDaktjZ.js";import{E as V,b7 as re,ec as Y,ed as Q,S as K,H as ie,aw as L,ee as Z,ef as ae,cd as le,a7 as ce}from"./index-DKlUKxnB.js";import{a as de}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-D59483ZS.js";import{b as ue}from"./producer-DP85fuAq.js";import{E as pe}from"./index-g1qbc9hT.js";import{E as me,a as fe}from"./index-D9-nLyZk.js";import{I as F,S as he}from"./ScrollList-COWNfBjK.js";import{E as _e}from"./index-DTZY5KH9.js";import{E as w}from"./index-Ci2kDHK1.js";import{E as z}from"./index-Dyd6KG-o.js";import{u as j,F as $e,O as ge,_ as ee,P as ve,a as ye,V as ke,E as be}from"./IconPark.vue_vue_type_script_setup_true_lang-4YLqaqth.js";import{E as X}from"./index-Bk7uGYgD.js";import{E as N}from"./index-B_59vVR6.js";import{E as we,a as Ce}from"./index-BMDbvDvb.js";import{E as x}from"./index-PP8LGD_B.js";import{E as Ve,a as Se}from"./index-SNhtZZZY.js";import{C as Ee}from"./Consumption-F9vhwk03.js";import{a as Ue}from"./price-BLWWDZIp.js";import{E as Pe,b as Ae,a as Te}from"./index-BiWHgAHp.js";import{E as Fe}from"./index-CW2ML0Zo.js";import{E as Ie}from"./index-DugzSlEH.js";import{N as Le}from"./NoTasks-sYq9Zr2G.js";import{a as Ge,E as je}from"./index-BVrGyG9B.js";import{l as De}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-BR1a3Xvf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-395EcdVg.js";import"./index-B4Ov55Re.js";import"./index-QRqt1QsU.js";import"./typescript-DEARewO1.js";import"./strings-beZM2Y-f.js";import"./isEqual-DGwqaOMZ.js";import"./_Uint8Array-DYoXPfzZ.js";import"./castArray-kDnnxK3Y.js";import"./debounce-B3qQloOM.js";import"./_baseIteratee-CCpRH0CC.js";import"./index-BMRSApyp.js";import"./index-BeJ6JfNM.js";import"./_baseClone-BHq6vhwI.js";import"./_initCloneObject-D8dKrUgV.js";import"./index-DFloj7qj.js";import"./index-Cu41y2Fl.js";import"./index-BeptfZWv.js";import"./dropdown-CMUX2QKQ.js";const Re=b({name:"LayoutProducer",components:{ElDrawer:oe,ElButton:W,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),Ze={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ne={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Me={class:"preview h-full w-[300px] flex flex-col"};function Oe(e,t,l,i,h,p){const u=r("font-awesome-icon"),m=r("el-button"),_=r("el-drawer");return n(),c("div",Ze,[o("div",ze,[B(e.$slots,"config",{},void 0,!0)]),o("div",Ne,[B(e.$slots,"result",{},void 0,!0)]),o("div",Me,[B(e.$slots,"preview",{},void 0,!0)]),s(m,{circle:"",class:"menu",onClick:t[0]||(t[0]=$=>e.drawer=!0)},{default:d(()=>[s(u,{icon:"fa-solid fa-magic"})]),_:1}),s(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:d(()=>[B(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Be=V(Re,[["render",Oe],["__scopeId","data-v-7453886f"]]),qe=b({name:"TypeSelector",components:{ElSelect:fe,ElOption:me,ElSwitch:pe},data(){return{options:[{label:"FUZZ-2.0 Pro",value:"FUZZ-2.0 Pro",info:"8 min"},{label:"FUZZ-2.0",value:"FUZZ-2.0",info:"8 min"},{label:"FUZZ-2.0 Raw",value:"FUZZ-2.0 Raw",info:"8 min"},{label:"FUZZ-1.1 Pro",value:"FUZZ-1.1 Pro",info:"4 min"},{label:"FUZZ-1.0 Pro",value:"FUZZ-1.0 Pro",info:"4 min"},{label:"FUZZ-1.1",value:"FUZZ-1.1",info:"4 min"},{label:"FUZZ-1.0",value:"FUZZ-1.0",info:"2 min"},{label:"FUZZ-0.8",value:"FUZZ-0.8",info:"2 min"}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||(this.model=ue)}}),We={class:"flex items-center justify-between mb-3"},He={class:"text-sm font-bold"},Ke={class:"mb-3"},Je={class:"flex items-center mb-1"},Ye={class:"text-sm font-bold"},Qe={class:"flex items-center justify-between w-full"},Xe={class:"text-xs text-[var(--el-text-color-placeholder)]"},xe={key:0,class:"flex items-center justify-between mb-3"},et={class:"text-sm font-bold"};function tt(e,t,l,i,h,p){const u=r("el-switch"),m=r("el-option"),_=r("el-select");return n(),c("div",null,[o("div",We,[o("span",He,a(e.$t("producer.name.type")),1),s(u,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=$=>e.custom=$)},null,8,["modelValue"])]),o("div",Ke,[o("div",Je,[o("span",Ye,a(e.$t("producer.name.model")),1)]),s(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=$=>e.model=$),class:"w-full",size:"default",placeholder:e.$t("producer.placeholder.select")},{default:d(()=>[(n(!0),c(G,null,q(e.options,$=>(n(),v(m,{key:$.value,label:$.label,value:$.value},{default:d(()=>[o("div",Qe,[o("span",null,a($.label),1),o("span",Xe,a($.info),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),c("div",xe,[o("span",et,a(e.$t("producer.name.instrumental")),1),s(u,{modelValue:e.instrumental,"onUpdate:modelValue":t[2]||(t[2]=$=>e.instrumental=$)},null,8,["modelValue"])])):f("",!0)])}const ot=V(qe,[["render",tt]]),st=b({name:"UploadAudio",components:{ElUpload:_e,ElButton:W,InfoIcon:F,FontAwesomeIcon:D},emits:["change"],data(){return{fileList:[],uploadUrl:re()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.producer?.config?.audio_id},set(){}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){w.warning(this.$t("producer.message.uploadReferencesExceed"))},onError(){w.error(this.$t("producer.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},l=this.credential?.token;if(!l){console.error("no token specified");return}w.info(this.$t("producer.message.startingUploadAudio")),I.upload(t,{token:l}).then(i=>{console.debug("get upload music success",i.data);const h=i.data?.data.audio_id;this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,audio_id:h,action:"upload_extend"}),w.success(this.$t("producer.message.startUploadAudioSuccess"))}).catch(i=>{w.error(i?.response?.data?.error?.message||this.$t("producer.message.startUploadAudioFailed"))})},onSetAudio(){}}}),nt={class:"relative"},rt={class:"flex justify-between"},it={class:"flex justify-start items-center"},at={class:"text-sm font-bold"};function lt(e,t,l,i,h,p){const u=r("info-icon"),m=r("font-awesome-icon"),_=r("el-button"),$=r("el-upload");return n(),c("div",nt,[o("div",rt,[o("div",it,[o("span",at,a(e.$t("producer.name.referenceAudios")),1),s(u,{content:e.$t("producer.description.uploadAudios")},null,8,["content"])])]),s($,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=k=>e.fileList=k),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:d(()=>[s(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),E(" "+a(e.$t("producer.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ct=V(st,[["render",lt],["__scopeId","data-v-e4cd0467"]]),dt="",ut=b({name:"PromptInput",components:{ElInput:z,InfoIcon:F},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=dt)}}),pt={class:"field"},mt={class:"flex items-center mb-1"},ft={class:"text-sm font-bold"};function ht(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",pt,[o("div",mt,[o("span",ft,a(e.$t("producer.name.songDescription")),1),s(u,{content:e.$t("producer.description.prompt")},null,8,["content"])]),s(m,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),rows:4,type:"textarea",placeholder:e.$t("producer.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const _t=V(ut,[["render",ht]]),$t="",gt=b({name:"LyricInput",components:{ElInput:z,ElButton:W,FontAwesomeIcon:D,InfoIcon:F},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||(this.lyric=$t)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,w.info(this.$t("producer.message.generatingLyrics"));try{const i=(await I.lyric({prompt:t},{token:e})).data?.data;i?.text&&(this.lyric=i.text,i?.title&&!this.config?.title&&this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:i.text,title:i.title}),w.success(this.$t("producer.message.generateLyricsSuccess")))}catch{w.error(this.$t("producer.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),vt={class:"field"},yt={class:"flex items-center justify-between mb-1"},kt={class:"flex items-center"},bt={class:"text-sm font-bold"};function wt(e,t,l,i,h,p){const u=r("info-icon"),m=r("font-awesome-icon"),_=r("el-button"),$=r("el-input");return n(),c("div",vt,[o("div",yt,[o("div",kt,[o("span",bt,a(e.$t("producer.name.lyrics")),1),s(u,{content:e.$t("producer.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(n(),v(_,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:d(()=>[e.generatingLyrics?f("",!0):(n(),v(m,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),E(" "+a(e.$t("producer.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):f("",!0)]),e.config?.action!=="extend"?(n(),v($,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=k=>e.lyric=k),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),v($,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=k=>e.lyric=k),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const Ct=V(gt,[["render",wt],["__scopeId","data-v-88c6da2b"]]),Vt=b({name:"StyleInput",components:{ElInput:z,InfoIcon:F},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style:e})}}}}),St={class:"field"},Et={class:"flex items-center justify-between mb-1"},Ut={class:"flex items-center"},Pt={class:"text-sm font-bold"};function At(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",St,[o("div",Et,[o("div",Ut,[o("span",Pt,a(e.$t("producer.name.style")),1),s(u,{content:e.$t("producer.description.style")},null,8,["content"])])]),s(m,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:2,type:"textarea",placeholder:e.$t("producer.placeholder.style")},null,8,["modelValue","placeholder"])])}const Tt=V(Vt,[["render",At]]),Ft=b({name:"TitleInput",components:{ElInput:z,InfoIcon:F},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,title:e})}}}}),It={class:"field"},Lt={class:"flex items-center mb-1"},Gt={class:"text-sm font-bold"};function jt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",It,[o("div",Lt,[o("span",Gt,a(e.$t("producer.name.title")),1),s(u,{content:e.$t("producer.description.title")},null,8,["content"])]),s(m,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),placeholder:e.$t("producer.placeholder.title")},null,8,["modelValue","placeholder"])])}const Dt=V(Ft,[["render",jt]]),Rt=b({name:"ExtendFromInput",components:{ElImage:N,ElIcon:K,ElInputNumber:X,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Zt={class:"field"},zt={class:"box"},Nt={class:"title font-bold"},Mt={class:"input-wrapper"},Ot={class:"task"},Bt={class:"left"},qt={key:2,class:"duration"},Wt={class:"info"},Ht={class:"title"},Kt={class:"style"};function Jt(e,t,l,i,h,p){const u=r("el-input-number"),m=r("el-image"),_=r("video-pause"),$=r("el-icon"),k=r("video-play"),y=H("loading");return n(),c("div",Zt,[o("div",zt,[o("h2",Nt,a(e.$t("producer.name.extend")),1),o("div",Mt,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=U=>e.value=U),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),o("div",Ot,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=U=>e.onClick(e.audio))},[R((n(),c("div",Bt,[s(m,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=U=>e.onPause(e.audio))},[s($,null,{default:d(()=>[s(_)]),_:1})])):f("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=U=>e.onPlay(e.audio))},[s($,null,{default:d(()=>[s(k)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",qt,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[y,!e.audio?.audio_url]]),o("div",Wt,[o("h2",Ht,a(e.audio?.title),1),o("p",Kt,a(e.audio?.style),1)])])):f("",!0)])])}const Yt=V(Rt,[["render",Jt],["__scopeId","data-v-26d43480"]]),Qt=b({name:"CoverFromInput",components:{ElImage:N,ElIcon:K,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Xt={class:"field"},xt={class:"box"},eo={class:"title font-bold"},to={class:"task"},oo={class:"left"},so={key:2,class:"duration"},no={class:"info"},ro={class:"title"},io={class:"style"};function ao(e,t,l,i,h,p){const u=r("el-image"),m=r("video-pause"),_=r("el-icon"),$=r("video-play"),k=H("loading");return n(),c("div",Xt,[o("div",xt,[o("h2",eo,a(e.$t("producer.name.cover")),1)]),o("div",to,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=y=>e.onClick(e.audio))},[R((n(),c("div",oo,[s(u,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=y=>e.onPause(e.audio))},[s(_,null,{default:d(()=>[s(m)]),_:1})])):f("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=y=>e.onPlay(e.audio))},[s(_,null,{default:d(()=>[s($)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",so,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[k,!e.audio?.audio_url]]),o("div",no,[o("h2",ro,a(e.audio?.title),1),o("p",io,a(e.audio?.style),1)])])):f("",!0)])])}const lo=V(Qt,[["render",ao],["__scopeId","data-v-d8a8e583"]]),co=b({name:"VocalGenderSelector",components:{ElRadioGroup:Ce,ElRadioButton:we,InfoIcon:F},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),uo={class:"mb-2"},po={class:"flex items-center mb-1"},mo={class:"text-sm font-bold"};function fo(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-radio-button"),_=r("el-radio-group");return n(),c("div",uo,[o("div",po,[o("span",mo,a(e.$t("producer.name.vocalGender")),1),s(u,{content:e.$t("producer.description.vocalGender")},null,8,["content"])]),s(_,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=$=>e.vocalGender=$)},{default:d(()=>[s(m,{value:""},{default:d(()=>[E(a(e.$t("producer.gender.auto")),1)]),_:1}),s(m,{value:"f"},{default:d(()=>[E(a(e.$t("producer.gender.female")),1)]),_:1}),s(m,{value:"m"},{default:d(()=>[E(a(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const ho=V(co,[["render",fo]]),_o=b({name:"AdvancedParams",components:{ElCollapse:Se,ElCollapseItem:Ve,ElInput:z,ElSlider:x,ElInputNumber:X},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??0},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,weirdness:e||void 0})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,seed:e})}}}}),$o={key:0,class:"mb-3"},go={class:"flex items-center mb-1"},vo={class:"text-xs font-bold"},yo={key:1,class:"mb-3"},ko={class:"flex items-center mb-1"},bo={class:"text-xs font-bold"},wo={key:2,class:"mb-3"},Co={class:"flex items-center justify-between mb-1"},Vo={class:"text-xs font-bold"},So={class:"text-xs text-[var(--el-text-color-secondary)]"},Eo={key:3,class:"mb-3"},Uo={class:"flex items-center justify-between mb-1"},Po={class:"text-xs font-bold"},Ao={class:"text-xs text-[var(--el-text-color-secondary)]"},To={key:4,class:"mb-3"},Fo={class:"flex items-center justify-between mb-1"},Io={class:"text-xs font-bold"},Lo={class:"text-xs text-[var(--el-text-color-secondary)]"},Go={key:5,class:"mb-3"},jo={class:"flex items-center mb-1"},Do={class:"text-xs font-bold"};function Ro(e,t,l,i,h,p){const u=r("el-input"),m=r("el-slider"),_=r("el-input-number"),$=r("el-collapse-item"),k=r("el-collapse");return n(),v(k,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=y=>e.activeNames=y),class:"advanced-collapse"},{default:d(()=>[s($,{title:e.$t("producer.name.advancedParams"),name:"advanced"},{default:d(()=>[e.config?.custom?(n(),c("div",$o,[o("div",go,[o("span",vo,a(e.$t("producer.name.styleNegative")),1)]),s(u,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=y=>e.styleNegative=y),placeholder:e.$t("producer.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):f("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",yo,[o("div",ko,[o("span",bo,a(e.$t("producer.name.lyricPrompt")),1)]),s(u,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=y=>e.lyricPrompt=y),placeholder:e.$t("producer.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):f("",!0),e.config?.custom?(n(),c("div",wo,[o("div",Co,[o("span",Vo,a(e.$t("producer.name.weirdness")),1),o("span",So,a(e.weirdness??0),1)]),s(m,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=y=>e.weirdness=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom?(n(),c("div",Eo,[o("div",Uo,[o("span",Po,a(e.$t("producer.name.soundStrength")),1),o("span",Ao,a(e.soundStrength??50),1)]),s(m,{modelValue:e.soundStrength,"onUpdate:modelValue":t[3]||(t[3]=y=>e.soundStrength=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",To,[o("div",Fo,[o("span",Io,a(e.$t("producer.name.lyricsStrength")),1),o("span",Lo,a(e.lyricsStrength??50),1)]),s(m,{modelValue:e.lyricsStrength,"onUpdate:modelValue":t[4]||(t[4]=y=>e.lyricsStrength=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom?(n(),c("div",Go,[o("div",jo,[o("span",Do,a(e.$t("producer.name.seed")),1)]),s(_,{modelValue:e.seed,"onUpdate:modelValue":t[5]||(t[5]=y=>e.seed=y),min:0,controls:!1,placeholder:e.$t("producer.placeholder.seed"),class:"w-full"},null,8,["modelValue","placeholder"])])):f("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Zo=V(_o,[["render",Ro],["__scopeId","data-v-88e65aee"]]),zo=b({name:"ReplaceSectionInput",components:{ElInputNumber:X,ElImage:N,InfoIcon:F},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"})}}}),No={class:"field"},Mo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},Bo={key:0,class:"task mb-2"},qo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Wo={class:"info flex-1 min-w-0"},Ho={class:"text-sm font-bold m-0 truncate"},Ko={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Jo={class:"flex gap-2"};function Yo(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-image"),_=r("el-input-number"),$=H("loading");return n(),c("div",No,[o("div",Mo,[o("h2",Oo,a(e.$t("producer.name.replaceSection")),1),s(u,{content:e.$t("producer.description.replaceSection")},null,8,["content"])]),e.audio?(n(),c("div",Bo,[o("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=k=>e.onClick(e.audio))},[R((n(),c("div",qo,[s(m,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[$,!e.audio?.audio_url]]),o("div",Wo,[o("h2",Ho,a(e.audio?.title),1),o("p",Ko,a(e.audio?.style),1)])])])):f("",!0),o("div",Jo,[s(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=k=>e.replaceSectionStart=k),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),s(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=k=>e.replaceSectionEnd=k),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const Qo=V(zo,[["render",Yo]]),Xo=b({name:"PresetPanel",components:{TypeSelector:ot,PromptInput:_t,LyricInput:Ct,StyleInput:Tt,TitleInput:Dt,ExtendFromInput:Yt,CoverFromInput:lo,UploadAudio:ct,VocalGenderSelector:ho,AdvancedParams:Zo,ReplaceSectionInput:Qo,FontAwesomeIcon:D,ElButton:W,Consumption:Ee},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},consumption(){return Ue(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("producer.button.extend"):e==="cover"?this.$t("producer.button.cover_music"):e==="variation"?this.$t("producer.button.variation"):e==="replace_section"?this.$t("producer.button.replace_section"):e==="stems"?this.$t("producer.button.get_stems"):e==="swap_vocals"?this.$t("producer.button.swap_vocals"):e==="swap_instrumentals"?this.$t("producer.button.swap_instrumentals"):this.$t("producer.button.generate")}},methods:{onGenerate(){this.$emit("generate")}}}),xo={class:"flex flex-col h-full"},es={class:"flex-1 overflow-y-auto p-5"},ts={class:"flex flex-col items-center justify-center px-5 pb-5"};function os(e,t,l,i,h,p){const u=r("type-selector"),m=r("upload-audio"),_=r("prompt-input"),$=r("lyric-input"),k=r("style-input"),y=r("title-input"),U=r("vocal-gender-selector"),S=r("extend-from-input"),M=r("cover-from-input"),O=r("replace-section-input"),J=r("advanced-params"),g=r("consumption"),C=r("font-awesome-icon"),te=r("el-button");return n(),c("div",xo,[o("div",es,[s(u,{class:"mb-4"}),s(m,{class:"mb-4"}),e.config?.custom?f("",!0):(n(),v(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),v($,{key:1,class:"mb-4"})):f("",!0),e.config?.custom?(n(),v(k,{key:2,class:"mb-4"})):f("",!0),e.config?.custom?(n(),v(y,{key:3,class:"mb-4"})):f("",!0),e.config?.custom&&!e.config.instrumental?(n(),v(U,{key:4,class:"mb-4"})):f("",!0),e.config?.action==="extend"?(n(),v(S,{key:5,class:"mb-4"})):f("",!0),e.config?.action==="cover"?(n(),v(M,{key:6,class:"mb-4"})):f("",!0),e.config?.action==="replace_section"?(n(),v(O,{key:7,class:"mb-4"})):f("",!0),s(J,{class:"mb-4"})]),o("div",ts,[s(g,{value:e.consumption,service:e.service},null,8,["value","service"]),s(te,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(C,{icon:"fa-solid fa-magic",class:"mr-2"}),E(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const ss=V(Xo,[["render",os],["__scopeId","data-v-6642bb3c"]]),ns="https://webhook.acedata.cloud/producer",rs=b({name:"TaskPreview",components:{ElImage:N,ElIcon:K,ElTooltip:Fe,FontAwesomeIcon:D,VideoPlay:Q,VideoPause:Y,ElDropdown:Te,ElDropdownMenu:Ae,ElDropdownItem:Pe,Loading:ie},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===L.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(l=>({...l,action:t})):e},application(){return this.$store.state.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.debug("set config",t),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation();const i=new URL(t).pathname,h=i.substring(i.lastIndexOf("/")+1);fetch(t).then(p=>p.blob()).then(p=>{$e.saveAs(p,h)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),w.error(this.$t("producer.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const i={audio_id:e},h=this.credential?.token;if(!h){console.error("no token specified"),l(new Error("No token specified"));return}I.video(i,{token:h}).then(p=>{const u=p.data?.data?.video_url;u?t(u):l(new Error("Video URL not found in response"))}).catch(p=>{l(p)})})},onPreview(e,t){e.stopPropagation(),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},onVariation(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:"variation",audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl("swap_vocals",e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl("swap_instrumentals",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,w.info(this.$t("producer.message.fetchingWav"));const i=(await I.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;i?this.onDownload(null,i):w.error(this.$t("producer.message.fetchWavFailed"))}catch{w.error(this.$t("producer.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){const l={action:e,audio_id:t,callback_url:ns},i=this.credential?.token;if(!i){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),I.audio(l,{token:i}).then(()=>{w.success(this.$t("producer.message.startTaskSuccess"))}).catch(h=>{w.error(h?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("producer/getTasks",{limit:30,offset:0})}}}),is={class:"task"},as=["onClick"],ls={class:"left"},cs=["onClick"],ds=["onClick"],us={key:2,class:"duration"},ps={class:"info"},ms={class:"title"},fs={class:"style"},hs={class:"right"},_s={class:"el-dropdown-link"},$s={class:"flex items-center min-w-[120px]"},gs={class:"flex items-center min-w-[120px]"},vs={class:"el-dropdown-link"};function ys(e,t,l,i,h,p){const u=r("el-image"),m=r("video-pause"),_=r("el-icon"),$=r("video-play"),k=r("font-awesome-icon"),y=r("el-tooltip"),U=r("Loading"),S=r("el-dropdown-item"),M=r("el-dropdown-menu"),O=r("el-dropdown"),J=H("loading");return n(),c("div",is,[(n(!0),c(G,null,q(e.audios,g=>(n(),c("div",{key:g.id,class:"audio",onClick:P(C=>e.onClick(g),["stop"])},[R((n(),c("div",ls,[s(u,{src:g?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),g?.audio_url&&e.$store.state?.producer?.audio?.id===g.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:P(C=>e.onPause(g),["stop"])},[s(_,null,{default:d(()=>[s(m)]),_:1})],8,cs)):f("",!0),g?.audio_url&&(e.$store.state?.producer?.audio?.id!==g.id||e.$store.state?.producer?.audio?.id===g.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:P(C=>e.onPlay(g),["stop"])},[s(_,null,{default:d(()=>[s($)]),_:1})],8,ds)):f("",!0),g?.duration?(n(),c("div",us,a(e.useFormatDuring(g?.duration)),1)):f("",!0)])),[[J,!g?.audio_url]]),o("div",ps,[o("h2",ms,a(g?.title),1),o("p",fs,a(g?.style),1)]),o("div",hs,[s(O,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[s(S,{disabled:e.isFetchingVideoUrl,onClick:C=>e.handleVideoDownload(g)},{default:d(()=>[o("div",$s,[e.isFetchingVideoUrl?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(U)]),_:1})):f("",!0),o("span",null,a(e.$t("producer.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),g?.audio_url?(n(),v(S,{key:0,onClick:P(C=>e.onDownload(C,g?.audio_url),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.download_audio")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{disabled:e.isFetchingWav,onClick:C=>e.handleWavDownload(g)},{default:d(()=>[o("div",gs,[e.isFetchingWav?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(U)]),_:1})):f("",!0),o("span",null,a(e.$t("producer.button.download_wav")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:d(()=>[o("span",_s,[s(y,{effect:"dark",content:e.$t("producer.button.download"),placement:"top"},{default:d(()=>[g?.audio_url||g?.video_url?(n(),v(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):f("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(O,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[g?.audio_url?(n(),v(S,{key:0,onClick:P(C=>e.onExtend(C,g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.extend")),1)]),_:1},8,["onClick"])):f("",!0),g.id?(n(),v(S,{key:1,onClick:P(C=>e.onGetStems(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.get_stems")),1)]),_:1},8,["onClick"])):f("",!0),g.id?(n(),v(S,{key:2,onClick:P(C=>e.onGetAllStems(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{onClick:P(C=>e.onCover(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.cover_music")),1)]),_:1},8,["onClick"]),g?.id?(n(),v(S,{key:3,onClick:P(C=>e.onVariation(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.variation")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:4,onClick:P(C=>e.onSwapVocals(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.swap_vocals")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:5,onClick:P(C=>e.onSwapInstrumentals(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.swap_instrumentals")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:6,onClick:P(C=>e.onReplaceSection(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):f("",!0)]),_:2},1024)]),default:d(()=>[o("span",vs,[s(y,{effect:"dark",content:e.$t("producer.button.more"),placement:"top"},{default:d(()=>[g?.audio_url||g?.video_url?(n(),v(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):f("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,as))),128))])}const ks=V(rs,[["render",ys]]),bs={class:"player-slider"},ws=b({__name:"PlayerSlider",setup(e){const t=Z(),l=T({get:()=>t.state.producer?.audio?.progress,set:u=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:u})}),i=T({get:()=>t.state.producer?.audio?.duration,set:u=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:u})}),h=()=>{},p=u=>t.dispatch("producer/setAudio",{...t.state.producer.audio,progress:u});return(u,m)=>(n(),c("div",bs,[s(A(x),{modelValue:l.value,"onUpdate:modelValue":m[0]||(m[0]=_=>l.value=_),"show-tooltip":!1,min:0,max:i.value,onChange:p,onInput:h},null,8,["modelValue","max"])]))}}),Cs={class:"flex player-song"},Vs=["src"],Ss={class:"ml-2 text-xs flex flex-col justify-between"},Es={class:"w-52 2xl:w-96 cursor-pointer truncate"},Us={class:"flex"},Ps={class:"ml-2 text-dc"},As=b({__name:"PlayerSong",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio,set:i=>t.commit("producer/setAudio",i)});return se(l,(i,h)=>{if(i?.audio_url!==h?.audio_url){console.log("audio changed",i),i.object&&(console.log("111",i.object),i.object.pause(),delete i.object);const p=new Audio(i.audio_url);i.state==="playing"?p.play():p.pause(),p.addEventListener("loadedmetadata",()=>{p.currentTime=0,p.addEventListener("timeupdate",()=>{t.commit("producer/setAudio",{...t.state.producer.audio,progress:p.currentTime})})}),t.commit("producer/setAudio",{...t.state.producer.audio,object:p})}else if(i?.progress!==h?.progress&&Math.abs(i.progress-i.object.currentTime)>2){console.log("progress changed",i.progress);const p=t.state.producer.audio;p.object&&(p.object.currentTime=p.progress)}else i?.state!==h?.state&&(console.log("state changed",i.state),i.object&&(i.state==="playing"?i.object.play():i.object.pause()));i?.volume!==h?.volume&&(console.log("volume changed",i.volume),i.object&&(i.object.volume=i.volume/100))}),(i,h)=>(n(),c("div",Cs,[o("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||A(ge)},null,8,Vs),o("div",Ss,[o("div",Es,[o("div",Us,[o("span",null,a(l.value?.title||"Music"),1),o("span",Ps,"- "+a(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Ts={class:"flex justify-end items-center gap-x-2.5"},Fs={class:"text-xs"},Is=b({__name:"PlayerAction",setup(e){const t=Z(),l=T({get:()=>t.state.producer?.audio?.progress,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:h})}),i=T({get:()=>t.state.producer?.audio?.duration,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:h})});return(h,p)=>(n(),c("div",Ts,[o("span",Fs,a(A(j)(l.value))+" / "+a(A(j)(i.value)),1)]))}}),Ls={class:"player-volume flex flex-col items-center pt-2"},Gs={class:"text-sm mt-3"},js=b({__name:"PlayerVolumeSlider",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio?.volume,set:p=>t.commit("producer/setAudio",{...t.state.producer.audio,volume:p})}),i=T({get:()=>t.state.producer.audio?.muted,set:p=>t.commit("producer/setAudio",{...t.state.producer.audio,muted:p})}),h=p=>t.dispatch("producer/setVolume",p);return(p,u)=>(n(),c("div",Ls,[s(A(x),{modelValue:l.value,"onUpdate:modelValue":u[0]||(u[0]=m=>l.value=m),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:i.value,onInput:h},null,8,["modelValue","disabled"]),o("div",Gs,a(l.value),1)]))}}),Ds={class:"flex items-center justify-center gap-x-3"},Rs=b({__name:"PlayerController",setup(e){const t=Z(),l=()=>t.dispatch("producer/setAudio",{...t.state.producer.audio,state:t.state.producer.audio.state==="playing"?"paused":"playing"}),i=T(()=>t.state.producer.audio);return(h,p)=>(n(),c("div",Ds,[s(ee,{icon:i.value?.state==="playing"?A(ve):A(ye),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),s(A(Ie),{placement:"top",width:"50px",trigger:"click"},{reference:d(()=>[s(ee,{icon:A(ke),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:d(()=>[s(js)]),_:1})]))}}),Zs={class:"flex flex-col items-stretch h-20"},zs={class:"flex grow px-5 items-center"},Ns={class:"flex-1"},Ms={class:"flex-1"},Os={class:"flex-1"},Bs=b({__name:"Player",setup(e){return(t,l)=>(n(),c("div",Zs,[s(ws),o("div",zs,[o("div",Ns,[s(As)]),o("div",Ms,[s(Rs)]),o("div",Os,[s(Is)])])]))}}),qs=b({name:"RecentPanel",components:{ElSkeletonItem:je,ElSkeleton:Ge,TaskPreview:ks,Player:Bs,NoTasks:Le,ScrollList:he},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ws={key:0,class:"tasks"},Hs={class:"left w-[70px] p-[10px] flex items-center"},Ks={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Js={key:2,class:"w-full flex-1 flex items-center justify-center"},Ys={class:"h-20"};function Qs(e,t,l,i,h,p){const u=r("el-skeleton-item"),m=r("el-skeleton"),_=r("task-preview"),$=r("scroll-list"),k=r("no-tasks"),y=r("player");return n(),c(G,null,[e.tasks?.items===void 0?(n(),c("div",Ws,[(n(),c(G,null,q(3,U=>o("div",{key:U,class:"flex"},[o("div",Hs,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),o("div",Ks,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),s(u,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),v($,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=U=>e.$emit("reach-top"))},{default:d(()=>[(n(!0),c(G,null,q(e.tasks?.items,(U,S)=>(n(),v(_,{key:S,"model-value":U,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),c("div",Js,[s(k)])):f("",!0),R(o("div",Ys,[s(y)],512),[[ne,!!e.$store?.state?.producer?.audio?.object]])],64)}const Xs=V(qs,[["render",Qs]]),xs=b({name:"TaskPreview",components:{IconPicture:ae,ElImage:N,ElAvatar:be,ElIcon:K},computed:{audio(){return this.$store.state.producer?.audio}}}),en={key:0,class:"size-full overflow-hidden"},tn={class:"relative h-[300px]"},on={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},sn={class:"absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent"},nn={class:"p-4"},rn={class:"flex items-center font-bold mb-2"},an={class:"text-[var(--el-text-color-regular)] mb-2"},ln={class:"text-xs text-[var(--el-text-color-regular)]"},cn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},dn={key:1,class:"w-full h-full"};function un(e,t,l,i,h,p){const u=r("icon-picture"),m=r("el-icon"),_=r("el-image"),$=r("el-avatar");return e.audio?.object?(n(),c("div",en,[o("div",tn,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:d(()=>[o("div",on,[s(m,{class:"text-3xl"},{default:d(()=>[s(u)]),_:1})])]),_:1},8,["src"]),o("h2",sn,a(e.audio?.title),1)]),o("div",nn,[o("div",rn,[s($,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),o("span",null,a(e.audio?.title),1)]),o("p",an,a(e.audio?.style),1),o("p",ln,a(e.$dayjs.format(e.audio?.created_at)),1),o("div",cn,[o("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",dn))}const pn=V(xs,[["render",un]]),mn="https://webhook.acedata.cloud/producer",fn=b({name:"ProducerIndex",components:{Layout:Be,ConfigPanel:ss,RecentPanel:Xs,PreviewPanel:pn},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===L.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===L.Request},needApply(){return this.$store.state.producer.status.getApplications===L.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await De({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("producer/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("producer/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){ce.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===de&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:l,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",i),this.fetchingTasks=!0;try{await this.$store.dispatch("producer/getTasks",{limit:t,createdAtMin:l,createdAtMax:i})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:mn},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),le("producer",I.audio(e,{token:t})).then(()=>{w.success(this.$t("producer.message.startTaskSuccess"))}).catch(l=>{w.error(l?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function hn(e,t,l,i,h,p){const u=r("config-panel"),m=r("recent-panel"),_=r("preview-panel"),$=r("layout");return n(),v($,null,{config:d(()=>[s(u,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:d(()=>[s(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:d(()=>[s(_)]),_:1})}const mr=V(fn,[["render",hn],["__scopeId","data-v-c1b12468"]]);export{mr as default};
1
+ import{F as D}from"./index.es-B8_8wmrH.js";import{E as W}from"./index-BIKYfCNm.js";import{E as oe}from"./index-D8fds_1u.js";import{d as b,H as c,E as o,z as B,C as s,y as d,D as r,q as n,F as a,O as G,N as q,J as f,x as v,I as E,G as R,K as H,M as P,u as A,c as T,w as se,L as ne}from"./vendor-vue-NSDaktjZ.js";import{E as V,b7 as re,ec as Y,ed as Q,S as K,H as ie,aw as L,ee as Z,ef as ae,cd as le,a7 as ce}from"./index-B5VThxFx.js";import{a as de}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-BY35pUwo.js";import{b as ue}from"./producer-DP85fuAq.js";import{E as pe}from"./index-BG8woF1-.js";import{E as me,a as fe}from"./index-BcFuJFD4.js";import{I as F,S as he}from"./ScrollList-BdIMpJr2.js";import{E as _e}from"./index-Z1E1odYA.js";import{E as w}from"./index-CixKTx1D.js";import{E as z}from"./index-Bsa0Z5HA.js";import{u as j,F as $e,O as ge,_ as ee,P as ve,a as ye,V as ke,E as be}from"./IconPark.vue_vue_type_script_setup_true_lang-CgTVojOA.js";import{E as X}from"./index-B_dZSh1V.js";import{E as N}from"./index-BthUaHYA.js";import{E as we,a as Ce}from"./index-CcP0tlvX.js";import{E as x}from"./index-DswOcPEa.js";import{E as Ve,a as Se}from"./index-N-6pnqez.js";import{C as Ee}from"./Consumption-DbcJR769.js";import{a as Ue}from"./price-D-PQQgbY.js";import{E as Pe,b as Ae,a as Te}from"./index-Mv1rryhx.js";import{E as Fe}from"./index-CPQzwH96.js";import{E as Ie}from"./index-CAk1ZtSG.js";import{N as Le}from"./NoTasks-B3OHHyLX.js";import{a as Ge,E as je}from"./index-Y6Hpp21c.js";import{l as De}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-DOEGLSGe.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-DgDQ8pCz.js";import"./index-jKSTpmaL.js";import"./index-Bcez2XRv.js";import"./typescript-Ch72LBtj.js";import"./strings-beZM2Y-f.js";import"./isEqual-BvJig0uU.js";import"./_Uint8Array-d0PfytAk.js";import"./castArray-B4IZIXMJ.js";import"./debounce-BA7XqfxN.js";import"./_baseIteratee-CbQQ2vi2.js";import"./index-CdSLN7HB.js";import"./index-C6VAcwnH.js";import"./_baseClone-fTTPu5Nv.js";import"./_initCloneObject-BrlQCApt.js";import"./index-C_u-Xh_j.js";import"./index-Cu41y2Fl.js";import"./index-B34AK5IJ.js";import"./dropdown-CNDQXnop.js";const Re=b({name:"LayoutProducer",components:{ElDrawer:oe,ElButton:W,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),Ze={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ne={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Me={class:"preview h-full w-[300px] flex flex-col"};function Oe(e,t,l,i,h,p){const u=r("font-awesome-icon"),m=r("el-button"),_=r("el-drawer");return n(),c("div",Ze,[o("div",ze,[B(e.$slots,"config",{},void 0,!0)]),o("div",Ne,[B(e.$slots,"result",{},void 0,!0)]),o("div",Me,[B(e.$slots,"preview",{},void 0,!0)]),s(m,{circle:"",class:"menu",onClick:t[0]||(t[0]=$=>e.drawer=!0)},{default:d(()=>[s(u,{icon:"fa-solid fa-magic"})]),_:1}),s(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:d(()=>[B(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Be=V(Re,[["render",Oe],["__scopeId","data-v-7453886f"]]),qe=b({name:"TypeSelector",components:{ElSelect:fe,ElOption:me,ElSwitch:pe},data(){return{options:[{label:"FUZZ-2.0 Pro",value:"FUZZ-2.0 Pro",info:"8 min"},{label:"FUZZ-2.0",value:"FUZZ-2.0",info:"8 min"},{label:"FUZZ-2.0 Raw",value:"FUZZ-2.0 Raw",info:"8 min"},{label:"FUZZ-1.1 Pro",value:"FUZZ-1.1 Pro",info:"4 min"},{label:"FUZZ-1.0 Pro",value:"FUZZ-1.0 Pro",info:"4 min"},{label:"FUZZ-1.1",value:"FUZZ-1.1",info:"4 min"},{label:"FUZZ-1.0",value:"FUZZ-1.0",info:"2 min"},{label:"FUZZ-0.8",value:"FUZZ-0.8",info:"2 min"}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||(this.model=ue)}}),We={class:"flex items-center justify-between mb-3"},He={class:"text-sm font-bold"},Ke={class:"mb-3"},Je={class:"flex items-center mb-1"},Ye={class:"text-sm font-bold"},Qe={class:"flex items-center justify-between w-full"},Xe={class:"text-xs text-[var(--el-text-color-placeholder)]"},xe={key:0,class:"flex items-center justify-between mb-3"},et={class:"text-sm font-bold"};function tt(e,t,l,i,h,p){const u=r("el-switch"),m=r("el-option"),_=r("el-select");return n(),c("div",null,[o("div",We,[o("span",He,a(e.$t("producer.name.type")),1),s(u,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=$=>e.custom=$)},null,8,["modelValue"])]),o("div",Ke,[o("div",Je,[o("span",Ye,a(e.$t("producer.name.model")),1)]),s(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=$=>e.model=$),class:"w-full",size:"default",placeholder:e.$t("producer.placeholder.select")},{default:d(()=>[(n(!0),c(G,null,q(e.options,$=>(n(),v(m,{key:$.value,label:$.label,value:$.value},{default:d(()=>[o("div",Qe,[o("span",null,a($.label),1),o("span",Xe,a($.info),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),c("div",xe,[o("span",et,a(e.$t("producer.name.instrumental")),1),s(u,{modelValue:e.instrumental,"onUpdate:modelValue":t[2]||(t[2]=$=>e.instrumental=$)},null,8,["modelValue"])])):f("",!0)])}const ot=V(qe,[["render",tt]]),st=b({name:"UploadAudio",components:{ElUpload:_e,ElButton:W,InfoIcon:F,FontAwesomeIcon:D},emits:["change"],data(){return{fileList:[],uploadUrl:re()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.producer?.config?.audio_id},set(){}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){w.warning(this.$t("producer.message.uploadReferencesExceed"))},onError(){w.error(this.$t("producer.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},l=this.credential?.token;if(!l){console.error("no token specified");return}w.info(this.$t("producer.message.startingUploadAudio")),I.upload(t,{token:l}).then(i=>{console.debug("get upload music success",i.data);const h=i.data?.data.audio_id;this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,audio_id:h,action:"upload_extend"}),w.success(this.$t("producer.message.startUploadAudioSuccess"))}).catch(i=>{w.error(i?.response?.data?.error?.message||this.$t("producer.message.startUploadAudioFailed"))})},onSetAudio(){}}}),nt={class:"relative"},rt={class:"flex justify-between"},it={class:"flex justify-start items-center"},at={class:"text-sm font-bold"};function lt(e,t,l,i,h,p){const u=r("info-icon"),m=r("font-awesome-icon"),_=r("el-button"),$=r("el-upload");return n(),c("div",nt,[o("div",rt,[o("div",it,[o("span",at,a(e.$t("producer.name.referenceAudios")),1),s(u,{content:e.$t("producer.description.uploadAudios")},null,8,["content"])])]),s($,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=k=>e.fileList=k),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:d(()=>[s(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),E(" "+a(e.$t("producer.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ct=V(st,[["render",lt],["__scopeId","data-v-e4cd0467"]]),dt="",ut=b({name:"PromptInput",components:{ElInput:z,InfoIcon:F},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=dt)}}),pt={class:"field"},mt={class:"flex items-center mb-1"},ft={class:"text-sm font-bold"};function ht(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",pt,[o("div",mt,[o("span",ft,a(e.$t("producer.name.songDescription")),1),s(u,{content:e.$t("producer.description.prompt")},null,8,["content"])]),s(m,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),rows:4,type:"textarea",placeholder:e.$t("producer.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const _t=V(ut,[["render",ht]]),$t="",gt=b({name:"LyricInput",components:{ElInput:z,ElButton:W,FontAwesomeIcon:D,InfoIcon:F},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||(this.lyric=$t)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,w.info(this.$t("producer.message.generatingLyrics"));try{const i=(await I.lyric({prompt:t},{token:e})).data?.data;i?.text&&(this.lyric=i.text,i?.title&&!this.config?.title&&this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric:i.text,title:i.title}),w.success(this.$t("producer.message.generateLyricsSuccess")))}catch{w.error(this.$t("producer.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),vt={class:"field"},yt={class:"flex items-center justify-between mb-1"},kt={class:"flex items-center"},bt={class:"text-sm font-bold"};function wt(e,t,l,i,h,p){const u=r("info-icon"),m=r("font-awesome-icon"),_=r("el-button"),$=r("el-input");return n(),c("div",vt,[o("div",yt,[o("div",kt,[o("span",bt,a(e.$t("producer.name.lyrics")),1),s(u,{content:e.$t("producer.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(n(),v(_,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:d(()=>[e.generatingLyrics?f("",!0):(n(),v(m,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),E(" "+a(e.$t("producer.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):f("",!0)]),e.config?.action!=="extend"?(n(),v($,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=k=>e.lyric=k),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),v($,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=k=>e.lyric=k),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const Ct=V(gt,[["render",wt],["__scopeId","data-v-88c6da2b"]]),Vt=b({name:"StyleInput",components:{ElInput:z,InfoIcon:F},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style:e})}}}}),St={class:"field"},Et={class:"flex items-center justify-between mb-1"},Ut={class:"flex items-center"},Pt={class:"text-sm font-bold"};function At(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",St,[o("div",Et,[o("div",Ut,[o("span",Pt,a(e.$t("producer.name.style")),1),s(u,{content:e.$t("producer.description.style")},null,8,["content"])])]),s(m,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:2,type:"textarea",placeholder:e.$t("producer.placeholder.style")},null,8,["modelValue","placeholder"])])}const Tt=V(Vt,[["render",At]]),Ft=b({name:"TitleInput",components:{ElInput:z,InfoIcon:F},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,title:e})}}}}),It={class:"field"},Lt={class:"flex items-center mb-1"},Gt={class:"text-sm font-bold"};function jt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",It,[o("div",Lt,[o("span",Gt,a(e.$t("producer.name.title")),1),s(u,{content:e.$t("producer.description.title")},null,8,["content"])]),s(m,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),placeholder:e.$t("producer.placeholder.title")},null,8,["modelValue","placeholder"])])}const Dt=V(Ft,[["render",jt]]),Rt=b({name:"ExtendFromInput",components:{ElImage:N,ElIcon:K,ElInputNumber:X,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Zt={class:"field"},zt={class:"box"},Nt={class:"title font-bold"},Mt={class:"input-wrapper"},Ot={class:"task"},Bt={class:"left"},qt={key:2,class:"duration"},Wt={class:"info"},Ht={class:"title"},Kt={class:"style"};function Jt(e,t,l,i,h,p){const u=r("el-input-number"),m=r("el-image"),_=r("video-pause"),$=r("el-icon"),k=r("video-play"),y=H("loading");return n(),c("div",Zt,[o("div",zt,[o("h2",Nt,a(e.$t("producer.name.extend")),1),o("div",Mt,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=U=>e.value=U),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),o("div",Ot,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=U=>e.onClick(e.audio))},[R((n(),c("div",Bt,[s(m,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=U=>e.onPause(e.audio))},[s($,null,{default:d(()=>[s(_)]),_:1})])):f("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=U=>e.onPlay(e.audio))},[s($,null,{default:d(()=>[s(k)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",qt,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[y,!e.audio?.audio_url]]),o("div",Wt,[o("h2",Ht,a(e.audio?.title),1),o("p",Kt,a(e.audio?.style),1)])])):f("",!0)])])}const Yt=V(Rt,[["render",Jt],["__scopeId","data-v-26d43480"]]),Qt=b({name:"CoverFromInput",components:{ElImage:N,ElIcon:K,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Xt={class:"field"},xt={class:"box"},eo={class:"title font-bold"},to={class:"task"},oo={class:"left"},so={key:2,class:"duration"},no={class:"info"},ro={class:"title"},io={class:"style"};function ao(e,t,l,i,h,p){const u=r("el-image"),m=r("video-pause"),_=r("el-icon"),$=r("video-play"),k=H("loading");return n(),c("div",Xt,[o("div",xt,[o("h2",eo,a(e.$t("producer.name.cover")),1)]),o("div",to,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=y=>e.onClick(e.audio))},[R((n(),c("div",oo,[s(u,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=y=>e.onPause(e.audio))},[s(_,null,{default:d(()=>[s(m)]),_:1})])):f("",!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=y=>e.onPlay(e.audio))},[s(_,null,{default:d(()=>[s($)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",so,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[k,!e.audio?.audio_url]]),o("div",no,[o("h2",ro,a(e.audio?.title),1),o("p",io,a(e.audio?.style),1)])])):f("",!0)])])}const lo=V(Qt,[["render",ao],["__scopeId","data-v-d8a8e583"]]),co=b({name:"VocalGenderSelector",components:{ElRadioGroup:Ce,ElRadioButton:we,InfoIcon:F},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),uo={class:"mb-2"},po={class:"flex items-center mb-1"},mo={class:"text-sm font-bold"};function fo(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-radio-button"),_=r("el-radio-group");return n(),c("div",uo,[o("div",po,[o("span",mo,a(e.$t("producer.name.vocalGender")),1),s(u,{content:e.$t("producer.description.vocalGender")},null,8,["content"])]),s(_,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=$=>e.vocalGender=$)},{default:d(()=>[s(m,{value:""},{default:d(()=>[E(a(e.$t("producer.gender.auto")),1)]),_:1}),s(m,{value:"f"},{default:d(()=>[E(a(e.$t("producer.gender.female")),1)]),_:1}),s(m,{value:"m"},{default:d(()=>[E(a(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const ho=V(co,[["render",fo]]),_o=b({name:"AdvancedParams",components:{ElCollapse:Se,ElCollapseItem:Ve,ElInput:z,ElSlider:x,ElInputNumber:X},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||""},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??0},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,weirdness:e||void 0})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,seed:e})}}}}),$o={key:0,class:"mb-3"},go={class:"flex items-center mb-1"},vo={class:"text-xs font-bold"},yo={key:1,class:"mb-3"},ko={class:"flex items-center mb-1"},bo={class:"text-xs font-bold"},wo={key:2,class:"mb-3"},Co={class:"flex items-center justify-between mb-1"},Vo={class:"text-xs font-bold"},So={class:"text-xs text-[var(--el-text-color-secondary)]"},Eo={key:3,class:"mb-3"},Uo={class:"flex items-center justify-between mb-1"},Po={class:"text-xs font-bold"},Ao={class:"text-xs text-[var(--el-text-color-secondary)]"},To={key:4,class:"mb-3"},Fo={class:"flex items-center justify-between mb-1"},Io={class:"text-xs font-bold"},Lo={class:"text-xs text-[var(--el-text-color-secondary)]"},Go={key:5,class:"mb-3"},jo={class:"flex items-center mb-1"},Do={class:"text-xs font-bold"};function Ro(e,t,l,i,h,p){const u=r("el-input"),m=r("el-slider"),_=r("el-input-number"),$=r("el-collapse-item"),k=r("el-collapse");return n(),v(k,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=y=>e.activeNames=y),class:"advanced-collapse"},{default:d(()=>[s($,{title:e.$t("producer.name.advancedParams"),name:"advanced"},{default:d(()=>[e.config?.custom?(n(),c("div",$o,[o("div",go,[o("span",vo,a(e.$t("producer.name.styleNegative")),1)]),s(u,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=y=>e.styleNegative=y),placeholder:e.$t("producer.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):f("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",yo,[o("div",ko,[o("span",bo,a(e.$t("producer.name.lyricPrompt")),1)]),s(u,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=y=>e.lyricPrompt=y),placeholder:e.$t("producer.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):f("",!0),e.config?.custom?(n(),c("div",wo,[o("div",Co,[o("span",Vo,a(e.$t("producer.name.weirdness")),1),o("span",So,a(e.weirdness??0),1)]),s(m,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=y=>e.weirdness=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom?(n(),c("div",Eo,[o("div",Uo,[o("span",Po,a(e.$t("producer.name.soundStrength")),1),o("span",Ao,a(e.soundStrength??50),1)]),s(m,{modelValue:e.soundStrength,"onUpdate:modelValue":t[3]||(t[3]=y=>e.soundStrength=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",To,[o("div",Fo,[o("span",Io,a(e.$t("producer.name.lyricsStrength")),1),o("span",Lo,a(e.lyricsStrength??50),1)]),s(m,{modelValue:e.lyricsStrength,"onUpdate:modelValue":t[4]||(t[4]=y=>e.lyricsStrength=y),min:0,max:100,step:1},null,8,["modelValue"])])):f("",!0),e.config?.custom?(n(),c("div",Go,[o("div",jo,[o("span",Do,a(e.$t("producer.name.seed")),1)]),s(_,{modelValue:e.seed,"onUpdate:modelValue":t[5]||(t[5]=y=>e.seed=y),min:0,controls:!1,placeholder:e.$t("producer.placeholder.seed"),class:"w-full"},null,8,["modelValue","placeholder"])])):f("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Zo=V(_o,[["render",Ro],["__scopeId","data-v-88e65aee"]]),zo=b({name:"ReplaceSectionInput",components:{ElInputNumber:X,ElImage:N,InfoIcon:F},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"})}}}),No={class:"field"},Mo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},Bo={key:0,class:"task mb-2"},qo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Wo={class:"info flex-1 min-w-0"},Ho={class:"text-sm font-bold m-0 truncate"},Ko={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Jo={class:"flex gap-2"};function Yo(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-image"),_=r("el-input-number"),$=H("loading");return n(),c("div",No,[o("div",Mo,[o("h2",Oo,a(e.$t("producer.name.replaceSection")),1),s(u,{content:e.$t("producer.description.replaceSection")},null,8,["content"])]),e.audio?(n(),c("div",Bo,[o("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=k=>e.onClick(e.audio))},[R((n(),c("div",qo,[s(m,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[$,!e.audio?.audio_url]]),o("div",Wo,[o("h2",Ho,a(e.audio?.title),1),o("p",Ko,a(e.audio?.style),1)])])])):f("",!0),o("div",Jo,[s(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=k=>e.replaceSectionStart=k),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),s(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=k=>e.replaceSectionEnd=k),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const Qo=V(zo,[["render",Yo]]),Xo=b({name:"PresetPanel",components:{TypeSelector:ot,PromptInput:_t,LyricInput:Ct,StyleInput:Tt,TitleInput:Dt,ExtendFromInput:Yt,CoverFromInput:lo,UploadAudio:ct,VocalGenderSelector:ho,AdvancedParams:Zo,ReplaceSectionInput:Qo,FontAwesomeIcon:D,ElButton:W,Consumption:Ee},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},consumption(){return Ue(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("producer.button.extend"):e==="cover"?this.$t("producer.button.cover_music"):e==="variation"?this.$t("producer.button.variation"):e==="replace_section"?this.$t("producer.button.replace_section"):e==="stems"?this.$t("producer.button.get_stems"):e==="swap_vocals"?this.$t("producer.button.swap_vocals"):e==="swap_instrumentals"?this.$t("producer.button.swap_instrumentals"):this.$t("producer.button.generate")}},methods:{onGenerate(){this.$emit("generate")}}}),xo={class:"flex flex-col h-full"},es={class:"flex-1 overflow-y-auto p-5"},ts={class:"flex flex-col items-center justify-center px-5 pb-5"};function os(e,t,l,i,h,p){const u=r("type-selector"),m=r("upload-audio"),_=r("prompt-input"),$=r("lyric-input"),k=r("style-input"),y=r("title-input"),U=r("vocal-gender-selector"),S=r("extend-from-input"),M=r("cover-from-input"),O=r("replace-section-input"),J=r("advanced-params"),g=r("consumption"),C=r("font-awesome-icon"),te=r("el-button");return n(),c("div",xo,[o("div",es,[s(u,{class:"mb-4"}),s(m,{class:"mb-4"}),e.config?.custom?f("",!0):(n(),v(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),v($,{key:1,class:"mb-4"})):f("",!0),e.config?.custom?(n(),v(k,{key:2,class:"mb-4"})):f("",!0),e.config?.custom?(n(),v(y,{key:3,class:"mb-4"})):f("",!0),e.config?.custom&&!e.config.instrumental?(n(),v(U,{key:4,class:"mb-4"})):f("",!0),e.config?.action==="extend"?(n(),v(S,{key:5,class:"mb-4"})):f("",!0),e.config?.action==="cover"?(n(),v(M,{key:6,class:"mb-4"})):f("",!0),e.config?.action==="replace_section"?(n(),v(O,{key:7,class:"mb-4"})):f("",!0),s(J,{class:"mb-4"})]),o("div",ts,[s(g,{value:e.consumption,service:e.service},null,8,["value","service"]),s(te,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(C,{icon:"fa-solid fa-magic",class:"mr-2"}),E(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const ss=V(Xo,[["render",os],["__scopeId","data-v-6642bb3c"]]),ns="https://webhook.acedata.cloud/producer",rs=b({name:"TaskPreview",components:{ElImage:N,ElIcon:K,ElTooltip:Fe,FontAwesomeIcon:D,VideoPlay:Q,VideoPause:Y,ElDropdown:Te,ElDropdownMenu:Ae,ElDropdownItem:Pe,Loading:ie},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===L.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(l=>({...l,action:t})):e},application(){return this.$store.state.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:j,onPlay(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("producer/setAudio",{...this.$store.state.producer.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.debug("set config",t),this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation();const i=new URL(t).pathname,h=i.substring(i.lastIndexOf("/")+1);fetch(t).then(p=>p.blob()).then(p=>{$e.saveAs(p,h)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),w.error(this.$t("producer.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const i={audio_id:e},h=this.credential?.token;if(!h){console.error("no token specified"),l(new Error("No token specified"));return}I.video(i,{token:h}).then(p=>{const u=p.data?.data?.video_url;u?t(u):l(new Error("Video URL not found in response"))}).catch(p=>{l(p)})})},onPreview(e,t){e.stopPropagation(),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},onVariation(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:"variation",audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl("swap_vocals",e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl("swap_instrumentals",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,w.info(this.$t("producer.message.fetchingWav"));const i=(await I.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;i?this.onDownload(null,i):w.error(this.$t("producer.message.fetchWavFailed"))}catch{w.error(this.$t("producer.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){const l={action:e,audio_id:t,callback_url:ns},i=this.credential?.token;if(!i){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),I.audio(l,{token:i}).then(()=>{w.success(this.$t("producer.message.startTaskSuccess"))}).catch(h=>{w.error(h?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("producer/getTasks",{limit:30,offset:0})}}}),is={class:"task"},as=["onClick"],ls={class:"left"},cs=["onClick"],ds=["onClick"],us={key:2,class:"duration"},ps={class:"info"},ms={class:"title"},fs={class:"style"},hs={class:"right"},_s={class:"el-dropdown-link"},$s={class:"flex items-center min-w-[120px]"},gs={class:"flex items-center min-w-[120px]"},vs={class:"el-dropdown-link"};function ys(e,t,l,i,h,p){const u=r("el-image"),m=r("video-pause"),_=r("el-icon"),$=r("video-play"),k=r("font-awesome-icon"),y=r("el-tooltip"),U=r("Loading"),S=r("el-dropdown-item"),M=r("el-dropdown-menu"),O=r("el-dropdown"),J=H("loading");return n(),c("div",is,[(n(!0),c(G,null,q(e.audios,g=>(n(),c("div",{key:g.id,class:"audio",onClick:P(C=>e.onClick(g),["stop"])},[R((n(),c("div",ls,[s(u,{src:g?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),g?.audio_url&&e.$store.state?.producer?.audio?.id===g.id&&e.$store.state?.producer?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:P(C=>e.onPause(g),["stop"])},[s(_,null,{default:d(()=>[s(m)]),_:1})],8,cs)):f("",!0),g?.audio_url&&(e.$store.state?.producer?.audio?.id!==g.id||e.$store.state?.producer?.audio?.id===g.id&&e.$store.state?.producer?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:P(C=>e.onPlay(g),["stop"])},[s(_,null,{default:d(()=>[s($)]),_:1})],8,ds)):f("",!0),g?.duration?(n(),c("div",us,a(e.useFormatDuring(g?.duration)),1)):f("",!0)])),[[J,!g?.audio_url]]),o("div",ps,[o("h2",ms,a(g?.title),1),o("p",fs,a(g?.style),1)]),o("div",hs,[s(O,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[s(S,{disabled:e.isFetchingVideoUrl,onClick:C=>e.handleVideoDownload(g)},{default:d(()=>[o("div",$s,[e.isFetchingVideoUrl?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(U)]),_:1})):f("",!0),o("span",null,a(e.$t("producer.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),g?.audio_url?(n(),v(S,{key:0,onClick:P(C=>e.onDownload(C,g?.audio_url),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.download_audio")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{disabled:e.isFetchingWav,onClick:C=>e.handleWavDownload(g)},{default:d(()=>[o("div",gs,[e.isFetchingWav?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(U)]),_:1})):f("",!0),o("span",null,a(e.$t("producer.button.download_wav")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:d(()=>[o("span",_s,[s(y,{effect:"dark",content:e.$t("producer.button.download"),placement:"top"},{default:d(()=>[g?.audio_url||g?.video_url?(n(),v(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):f("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(O,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[g?.audio_url?(n(),v(S,{key:0,onClick:P(C=>e.onExtend(C,g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.extend")),1)]),_:1},8,["onClick"])):f("",!0),g.id?(n(),v(S,{key:1,onClick:P(C=>e.onGetStems(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.get_stems")),1)]),_:1},8,["onClick"])):f("",!0),g.id?(n(),v(S,{key:2,onClick:P(C=>e.onGetAllStems(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{onClick:P(C=>e.onCover(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.cover_music")),1)]),_:1},8,["onClick"]),g?.id?(n(),v(S,{key:3,onClick:P(C=>e.onVariation(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.variation")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:4,onClick:P(C=>e.onSwapVocals(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.swap_vocals")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:5,onClick:P(C=>e.onSwapInstrumentals(g.id),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.swap_instrumentals")),1)]),_:1},8,["onClick"])):f("",!0),g?.id?(n(),v(S,{key:6,onClick:P(C=>e.onReplaceSection(g),["stop"])},{default:d(()=>[E(a(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):f("",!0)]),_:2},1024)]),default:d(()=>[o("span",vs,[s(y,{effect:"dark",content:e.$t("producer.button.more"),placement:"top"},{default:d(()=>[g?.audio_url||g?.video_url?(n(),v(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):f("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,as))),128))])}const ks=V(rs,[["render",ys]]),bs={class:"player-slider"},ws=b({__name:"PlayerSlider",setup(e){const t=Z(),l=T({get:()=>t.state.producer?.audio?.progress,set:u=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:u})}),i=T({get:()=>t.state.producer?.audio?.duration,set:u=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:u})}),h=()=>{},p=u=>t.dispatch("producer/setAudio",{...t.state.producer.audio,progress:u});return(u,m)=>(n(),c("div",bs,[s(A(x),{modelValue:l.value,"onUpdate:modelValue":m[0]||(m[0]=_=>l.value=_),"show-tooltip":!1,min:0,max:i.value,onChange:p,onInput:h},null,8,["modelValue","max"])]))}}),Cs={class:"flex player-song"},Vs=["src"],Ss={class:"ml-2 text-xs flex flex-col justify-between"},Es={class:"w-52 2xl:w-96 cursor-pointer truncate"},Us={class:"flex"},Ps={class:"ml-2 text-dc"},As=b({__name:"PlayerSong",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio,set:i=>t.commit("producer/setAudio",i)});return se(l,(i,h)=>{if(i?.audio_url!==h?.audio_url){console.log("audio changed",i),i.object&&(console.log("111",i.object),i.object.pause(),delete i.object);const p=new Audio(i.audio_url);i.state==="playing"?p.play():p.pause(),p.addEventListener("loadedmetadata",()=>{p.currentTime=0,p.addEventListener("timeupdate",()=>{t.commit("producer/setAudio",{...t.state.producer.audio,progress:p.currentTime})})}),t.commit("producer/setAudio",{...t.state.producer.audio,object:p})}else if(i?.progress!==h?.progress&&Math.abs(i.progress-i.object.currentTime)>2){console.log("progress changed",i.progress);const p=t.state.producer.audio;p.object&&(p.object.currentTime=p.progress)}else i?.state!==h?.state&&(console.log("state changed",i.state),i.object&&(i.state==="playing"?i.object.play():i.object.pause()));i?.volume!==h?.volume&&(console.log("volume changed",i.volume),i.object&&(i.object.volume=i.volume/100))}),(i,h)=>(n(),c("div",Cs,[o("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||A(ge)},null,8,Vs),o("div",Ss,[o("div",Es,[o("div",Us,[o("span",null,a(l.value?.title||"Music"),1),o("span",Ps,"- "+a(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Ts={class:"flex justify-end items-center gap-x-2.5"},Fs={class:"text-xs"},Is=b({__name:"PlayerAction",setup(e){const t=Z(),l=T({get:()=>t.state.producer?.audio?.progress,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:h})}),i=T({get:()=>t.state.producer?.audio?.duration,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:h})});return(h,p)=>(n(),c("div",Ts,[o("span",Fs,a(A(j)(l.value))+" / "+a(A(j)(i.value)),1)]))}}),Ls={class:"player-volume flex flex-col items-center pt-2"},Gs={class:"text-sm mt-3"},js=b({__name:"PlayerVolumeSlider",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio?.volume,set:p=>t.commit("producer/setAudio",{...t.state.producer.audio,volume:p})}),i=T({get:()=>t.state.producer.audio?.muted,set:p=>t.commit("producer/setAudio",{...t.state.producer.audio,muted:p})}),h=p=>t.dispatch("producer/setVolume",p);return(p,u)=>(n(),c("div",Ls,[s(A(x),{modelValue:l.value,"onUpdate:modelValue":u[0]||(u[0]=m=>l.value=m),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:i.value,onInput:h},null,8,["modelValue","disabled"]),o("div",Gs,a(l.value),1)]))}}),Ds={class:"flex items-center justify-center gap-x-3"},Rs=b({__name:"PlayerController",setup(e){const t=Z(),l=()=>t.dispatch("producer/setAudio",{...t.state.producer.audio,state:t.state.producer.audio.state==="playing"?"paused":"playing"}),i=T(()=>t.state.producer.audio);return(h,p)=>(n(),c("div",Ds,[s(ee,{icon:i.value?.state==="playing"?A(ve):A(ye),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),s(A(Ie),{placement:"top",width:"50px",trigger:"click"},{reference:d(()=>[s(ee,{icon:A(ke),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:d(()=>[s(js)]),_:1})]))}}),Zs={class:"flex flex-col items-stretch h-20"},zs={class:"flex grow px-5 items-center"},Ns={class:"flex-1"},Ms={class:"flex-1"},Os={class:"flex-1"},Bs=b({__name:"Player",setup(e){return(t,l)=>(n(),c("div",Zs,[s(ws),o("div",zs,[o("div",Ns,[s(As)]),o("div",Ms,[s(Rs)]),o("div",Os,[s(Is)])])]))}}),qs=b({name:"RecentPanel",components:{ElSkeletonItem:je,ElSkeleton:Ge,TaskPreview:ks,Player:Bs,NoTasks:Le,ScrollList:he},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ws={key:0,class:"tasks"},Hs={class:"left w-[70px] p-[10px] flex items-center"},Ks={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Js={key:2,class:"w-full flex-1 flex items-center justify-center"},Ys={class:"h-20"};function Qs(e,t,l,i,h,p){const u=r("el-skeleton-item"),m=r("el-skeleton"),_=r("task-preview"),$=r("scroll-list"),k=r("no-tasks"),y=r("player");return n(),c(G,null,[e.tasks?.items===void 0?(n(),c("div",Ws,[(n(),c(G,null,q(3,U=>o("div",{key:U,class:"flex"},[o("div",Hs,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),o("div",Ks,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),s(u,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),v($,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=U=>e.$emit("reach-top"))},{default:d(()=>[(n(!0),c(G,null,q(e.tasks?.items,(U,S)=>(n(),v(_,{key:S,"model-value":U,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),c("div",Js,[s(k)])):f("",!0),R(o("div",Ys,[s(y)],512),[[ne,!!e.$store?.state?.producer?.audio?.object]])],64)}const Xs=V(qs,[["render",Qs]]),xs=b({name:"TaskPreview",components:{IconPicture:ae,ElImage:N,ElAvatar:be,ElIcon:K},computed:{audio(){return this.$store.state.producer?.audio}}}),en={key:0,class:"size-full overflow-hidden"},tn={class:"relative h-[300px]"},on={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},sn={class:"absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent"},nn={class:"p-4"},rn={class:"flex items-center font-bold mb-2"},an={class:"text-[var(--el-text-color-regular)] mb-2"},ln={class:"text-xs text-[var(--el-text-color-regular)]"},cn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},dn={key:1,class:"w-full h-full"};function un(e,t,l,i,h,p){const u=r("icon-picture"),m=r("el-icon"),_=r("el-image"),$=r("el-avatar");return e.audio?.object?(n(),c("div",en,[o("div",tn,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:d(()=>[o("div",on,[s(m,{class:"text-3xl"},{default:d(()=>[s(u)]),_:1})])]),_:1},8,["src"]),o("h2",sn,a(e.audio?.title),1)]),o("div",nn,[o("div",rn,[s($,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),o("span",null,a(e.audio?.title),1)]),o("p",an,a(e.audio?.style),1),o("p",ln,a(e.$dayjs.format(e.audio?.created_at)),1),o("div",cn,[o("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",dn))}const pn=V(xs,[["render",un]]),mn="https://webhook.acedata.cloud/producer",fn=b({name:"ProducerIndex",components:{Layout:Be,ConfigPanel:ss,RecentPanel:Xs,PreviewPanel:pn},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===L.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===L.Request},needApply(){return this.$store.state.producer.status.getApplications===L.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await De({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("producer/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("producer/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){ce.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===de&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:l,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",i),this.fetchingTasks=!0;try{await this.$store.dispatch("producer/getTasks",{limit:t,createdAtMin:l,createdAtMax:i})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:mn},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),le("producer",I.audio(e,{token:t})).then(()=>{w.success(this.$t("producer.message.startTaskSuccess"))}).catch(l=>{w.error(l?.response?.data?.error?.message||this.$t("producer.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function hn(e,t,l,i,h,p){const u=r("config-panel"),m=r("recent-panel"),_=r("preview-panel"),$=r("layout");return n(),v($,null,{config:d(()=>[s(u,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:d(()=>[s(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:d(()=>[s(_)]),_:1})}const mr=V(fn,[["render",hn],["__scopeId","data-v-c1b12468"]]);export{mr as default};
@@ -1 +1 @@
1
- import{F as C}from"./index.es-DWP0WL9I.js";import{E as T}from"./index-DD7PDhJt.js";import{E as M}from"./index-CMrxr9s5.js";import{d as w,H as r,E as c,z as U,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as L}from"./vendor-vue-NSDaktjZ.js";import{E as v,b7 as j,cd as B,aw as D}from"./index-DKlUKxnB.js";import{a as F,b as N}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-D9-nLyZk.js";import{p as q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as z}from"./ScrollList-COWNfBjK.js";import{I as W}from"./ImagePreview-CLAIXPcM.js";import{E as H}from"./index-DTZY5KH9.js";import{E as V}from"./index-Ci2kDHK1.js";import{E as J}from"./index-Dyd6KG-o.js";import{C as K}from"./Consumption-F9vhwk03.js";import{a as Q}from"./price-BLWWDZIp.js";import{b as X}from"./errorCode-Cqj9Td_Z.js";import{w as Y}from"./wan-CrFiliGM.js";import{C as Z}from"./CopyToClipboard-UjbBZ_ac.js";import{V as x}from"./VideoPlayer-CzcMT9AZ.js";import{E as ee}from"./index-CW2ML0Zo.js";import{E as te}from"./index-ByzOFVtn.js";import{E as oe}from"./index-B_59vVR6.js";import{B as se}from"./BotPlaceholder-jDf8T7ol.js";import{N as ne}from"./NoTasks-sYq9Zr2G.js";import{l as ae}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-BR1a3Xvf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-QRqt1QsU.js";import"./typescript-DEARewO1.js";import"./index-B4Ov55Re.js";import"./strings-beZM2Y-f.js";import"./isEqual-DGwqaOMZ.js";import"./_Uint8Array-DYoXPfzZ.js";import"./castArray-kDnnxK3Y.js";import"./debounce-B3qQloOM.js";import"./_baseIteratee-CCpRH0CC.js";import"./index-BMRSApyp.js";import"./index-BeJ6JfNM.js";import"./_baseClone-BHq6vhwI.js";import"./_initCloneObject-D8dKrUgV.js";import"./index-DFloj7qj.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BVrGyG9B.js";const le=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),re={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ce={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function de(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",re,[c("div",ie,[U(e.$slots,"config",{},void 0,!0)]),c("div",ce,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",de],["__scopeId","data-v-98681d9b"]]),pe=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=F)}}),me={class:"field"},fe={class:"title font-bold"},he={class:"float-left"};function _e(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",me,[c("h2",fe,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",he,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=v(pe,[["render",_e],["__scopeId","data-v-eb090beb"]]),$e="720p",we=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=$e)}}),ve={class:"field"},be={class:"title font-bold"},ke={class:"float-left"};function ye(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",ve,[c("h2",be,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ke,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=v(we,[["render",ye],["__scopeId","data-v-3e39f44e"]]),Ee=5,Ie=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ee)}}),Te={class:"field"},Se={class:"title font-bold"},Le={class:"float-left"};function Ue(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Te,[c("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=v(Ie,[["render",Ue],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:H,ElButton:T,InfoIcon:P,ImagePreview:W},mixins:[q],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ge={class:"relative"},Ae={class:"flex justify-between"},De={class:"flex justify-start items-center"},Pe={class:"text-sm font-bold"};function Me(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ge,[c("div",Ae,[c("div",De,[c("span",Pe,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Me],["__scopeId","data-v-c9ebe1b1"]]),je="",Be=w({name:"PromptInput",components:{ElInput:J,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=je)}}),Fe={class:"field"},Ne={class:"box"},qe={class:"title font-bold"};function ze(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Fe,[c("div",Ne,[c("h2",qe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const We=v(Be,[["render",ze],["__scopeId","data-v-45557a2d"]]),He=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:We,ImageUrlInput:Oe,ModelSelector:ge,ResolutionSelector:Ve,DurationSelector:Ce,Consumption:K},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Q(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Je={class:"flex flex-col h-full"},Ke={class:"flex-1 overflow-y-auto p-5"},Qe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Xe(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Je,[c("div",Ke,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Qe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ye=v(He,[["render",Xe]]),Ze=w({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:C,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:N}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),xe={class:"preview"},et={class:"left"},tt={class:"main"},ot={class:"bot"},st={class:"datetime"},nt={class:"info"},at={key:0,class:"prompt mt-2"},lt={key:0},rt={key:1},it={key:0,class:L({content:!0,failed:!0})},ct={key:0,class:"mb-4"},dt={key:1,class:L({operations:!0,"mt-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ft={key:1,class:L({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:L({content:!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function bt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",xe,[c("div",et,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",tt,[c("div",ot,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",st,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.prompt?(s(),r("p",at,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",lt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",rt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",it,[e.modelValue?.response?.video_url?(s(),r("div",ct,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",dt,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",ut,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",pt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",mt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ft,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",ht,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",_t,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",gt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",$t,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",vt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const kt=v(Ze,[["render",bt],["__scopeId","data-v-6d1d636e"]]),yt=w({name:"RecentPanel",components:{TaskPreview:kt,BotPlaceholder:se,NoTasks:ne,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Vt={key:0},Et={key:2,class:"w-full h-full flex items-center justify-center"};function It(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Vt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",Et,[t(g)])):m("",!0)],64)}const Tt=v(yt,[["render",It]]),St="https://webhook.acedata.cloud/wan",Lt=w({name:"WanIndex",components:{ConfigPanel:Ye,Layout:ue,RecentPanel:Tt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ae({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:St},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",Y.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===X?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Vo=v(Lt,[["render",Ut]]);export{Vo as default};
1
+ import{F as C}from"./index.es-B8_8wmrH.js";import{E as T}from"./index-BIKYfCNm.js";import{E as M}from"./index-D8fds_1u.js";import{d as w,H as r,E as c,z as U,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as L}from"./vendor-vue-NSDaktjZ.js";import{E as v,b7 as j,cd as B,aw as D}from"./index-B5VThxFx.js";import{a as F,b as N}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-BcFuJFD4.js";import{p as q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as z}from"./ScrollList-BdIMpJr2.js";import{I as W}from"./ImagePreview-BO9qxdtw.js";import{E as H}from"./index-Z1E1odYA.js";import{E as V}from"./index-CixKTx1D.js";import{E as J}from"./index-Bsa0Z5HA.js";import{C as K}from"./Consumption-DbcJR769.js";import{a as Q}from"./price-D-PQQgbY.js";import{b as X}from"./errorCode-Cqj9Td_Z.js";import{w as Y}from"./wan-CMwds55r.js";import{C as Z}from"./CopyToClipboard-SvDri6QJ.js";import{V as x}from"./VideoPlayer-DLau3K08.js";import{E as ee}from"./index-CPQzwH96.js";import{E as te}from"./index-CKXwdWS1.js";import{E as oe}from"./index-BthUaHYA.js";import{B as se}from"./BotPlaceholder-BJ5FbY4i.js";import{N as ne}from"./NoTasks-B3OHHyLX.js";import{l as ae}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-DOEGLSGe.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-Bcez2XRv.js";import"./typescript-Ch72LBtj.js";import"./index-jKSTpmaL.js";import"./strings-beZM2Y-f.js";import"./isEqual-BvJig0uU.js";import"./_Uint8Array-d0PfytAk.js";import"./castArray-B4IZIXMJ.js";import"./debounce-BA7XqfxN.js";import"./_baseIteratee-CbQQ2vi2.js";import"./index-CdSLN7HB.js";import"./index-C6VAcwnH.js";import"./_baseClone-fTTPu5Nv.js";import"./_initCloneObject-BrlQCApt.js";import"./index-C_u-Xh_j.js";import"./vue-plyr-BO2nlN4c.js";import"./index-Y6Hpp21c.js";const le=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),re={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ce={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function de(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",re,[c("div",ie,[U(e.$slots,"config",{},void 0,!0)]),c("div",ce,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",de],["__scopeId","data-v-98681d9b"]]),pe=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=F)}}),me={class:"field"},fe={class:"title font-bold"},he={class:"float-left"};function _e(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",me,[c("h2",fe,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",he,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=v(pe,[["render",_e],["__scopeId","data-v-eb090beb"]]),$e="720p",we=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=$e)}}),ve={class:"field"},be={class:"title font-bold"},ke={class:"float-left"};function ye(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",ve,[c("h2",be,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ke,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=v(we,[["render",ye],["__scopeId","data-v-3e39f44e"]]),Ee=5,Ie=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ee)}}),Te={class:"field"},Se={class:"title font-bold"},Le={class:"float-left"};function Ue(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Te,[c("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=v(Ie,[["render",Ue],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:H,ElButton:T,InfoIcon:P,ImagePreview:W},mixins:[q],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ge={class:"relative"},Ae={class:"flex justify-between"},De={class:"flex justify-start items-center"},Pe={class:"text-sm font-bold"};function Me(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ge,[c("div",Ae,[c("div",De,[c("span",Pe,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Me],["__scopeId","data-v-c9ebe1b1"]]),je="",Be=w({name:"PromptInput",components:{ElInput:J,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=je)}}),Fe={class:"field"},Ne={class:"box"},qe={class:"title font-bold"};function ze(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Fe,[c("div",Ne,[c("h2",qe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const We=v(Be,[["render",ze],["__scopeId","data-v-45557a2d"]]),He=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:We,ImageUrlInput:Oe,ModelSelector:ge,ResolutionSelector:Ve,DurationSelector:Ce,Consumption:K},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Q(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Je={class:"flex flex-col h-full"},Ke={class:"flex-1 overflow-y-auto p-5"},Qe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Xe(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Je,[c("div",Ke,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Qe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ye=v(He,[["render",Xe]]),Ze=w({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:C,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:N}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),xe={class:"preview"},et={class:"left"},tt={class:"main"},ot={class:"bot"},st={class:"datetime"},nt={class:"info"},at={key:0,class:"prompt mt-2"},lt={key:0},rt={key:1},it={key:0,class:L({content:!0,failed:!0})},ct={key:0,class:"mb-4"},dt={key:1,class:L({operations:!0,"mt-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ft={key:1,class:L({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:L({content:!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function bt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",xe,[c("div",et,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",tt,[c("div",ot,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",st,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.prompt?(s(),r("p",at,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",lt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",rt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",it,[e.modelValue?.response?.video_url?(s(),r("div",ct,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",dt,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",ut,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",pt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",mt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ft,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",ht,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",_t,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",gt,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",$t,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",vt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const kt=v(Ze,[["render",bt],["__scopeId","data-v-6d1d636e"]]),yt=w({name:"RecentPanel",components:{TaskPreview:kt,BotPlaceholder:se,NoTasks:ne,ScrollList:z},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Vt={key:0},Et={key:2,class:"w-full h-full flex items-center justify-center"};function It(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Vt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",Et,[t(g)])):m("",!0)],64)}const Tt=v(yt,[["render",It]]),St="https://webhook.acedata.cloud/wan",Lt=w({name:"WanIndex",components:{ConfigPanel:Ye,Layout:ue,RecentPanel:Tt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ae({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:St},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",Y.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===X?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Vo=v(Lt,[["render",Ut]]);export{Vo as default};
@@ -1 +1 @@
1
- import{F as P}from"./index.es-DWP0WL9I.js";import{E as U}from"./index-DD7PDhJt.js";import{E as Y}from"./index-CMrxr9s5.js";import{d as b,H as i,E as r,z as L,C as a,y as p,D as n,q as t,F as l,O as E,N as T,x as m,Q as A,R as J,J as d,I as _}from"./vendor-vue-NSDaktjZ.js";import{E as k,b7 as Q,cd as K,aw as M}from"./index-DKlUKxnB.js";import{a as W,b as Z,c as x,d as ee,e as oe,f as te,g as G,h as se,i as ne,j as ae}from"./veo-Dg8Zhpd-.js";import{E as C,a as O}from"./index-D9-nLyZk.js";import{I as j,S as le}from"./ScrollList-COWNfBjK.js";import{E as ie}from"./index-g1qbc9hT.js";import{V as D}from"./VideoPlayer-CzcMT9AZ.js";import{E as R}from"./index-Dyd6KG-o.js";import{p as re}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ce}from"./ImagePreview-CLAIXPcM.js";import{E as de}from"./index-DTZY5KH9.js";import{E as I}from"./index-Ci2kDHK1.js";import{C as ue}from"./Consumption-F9vhwk03.js";import{a as pe}from"./price-BLWWDZIp.js";import{b as me}from"./errorCode-Cqj9Td_Z.js";import{v as ve}from"./veo-B0_jjzRC.js";import{C as fe}from"./CopyToClipboard-UjbBZ_ac.js";import{E as _e}from"./index-CW2ML0Zo.js";import{E as he}from"./index-ByzOFVtn.js";import{E as $e}from"./index-B_59vVR6.js";import{B as ge}from"./BotPlaceholder-jDf8T7ol.js";import{N as be}from"./NoTasks-sYq9Zr2G.js";import{l as ke}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-BR1a3Xvf.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-QRqt1QsU.js";import"./typescript-DEARewO1.js";import"./index-B4Ov55Re.js";import"./strings-beZM2Y-f.js";import"./isEqual-DGwqaOMZ.js";import"./_Uint8Array-DYoXPfzZ.js";import"./castArray-kDnnxK3Y.js";import"./debounce-B3qQloOM.js";import"./_baseIteratee-CCpRH0CC.js";import"./index-BMRSApyp.js";import"./validator-395EcdVg.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DFloj7qj.js";import"./index-BeJ6JfNM.js";import"./_baseClone-BHq6vhwI.js";import"./_initCloneObject-D8dKrUgV.js";import"./index-BVrGyG9B.js";const ye=b({name:"LayoutVeo",components:{ElDrawer:Y,ElButton:U,FontAwesomeIcon:P},data(){return{drawer:!1}}}),Ve={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ee={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ie(e,o,v,f,y,V){const c=n("font-awesome-icon"),u=n("el-button"),s=n("el-drawer");return t(),i("div",Ve,[r("div",we,[L(e.$slots,"config",{},void 0,!0)]),r("div",Ee,[L(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:p(()=>[a(c,{icon:"fa-solid fa-magic"})]),_:1}),a(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Te=k(ye,[["render",Ie],["__scopeId","data-v-816b984c"]]),Se=b({name:"ModelSelector",components:{ElSelect:O,ElOption:C},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=W)}}),Ae={class:"field"},Ce={class:"title font-bold"};function Oe(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Ae,[r("h2",Ce,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Pe=k(Se,[["render",Oe],["__scopeId","data-v-a59d89c9"]]),Ue=b({name:"ActionSelector",components:{ElSelect:O,ElOption:C},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=Z)}}),Le={class:"field"},je={class:"title font-bold"},Re={class:"float-left"};function Me(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Le,[r("h2",je,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},{default:p(()=>[r("span",Re,l(s.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=k(Ue,[["render",Me],["__scopeId","data-v-f4d8785c"]]),De=b({name:"TranslationSelector",components:{ElSwitch:ie,InfoIcon:j},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=x)}}),Ne={class:"relative"},Fe={class:"flex justify-between"},ze={class:"flex justify-start items-center"},Be={class:"text-sm font-bold"},qe={class:"flex justify-end items-center"};function He(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-switch");return t(),i("div",Ne,[r("div",Fe,[r("div",ze,[r("span",Be,l(e.$t("veo.name.translation")),1),a(c,{content:e.$t("veo.description.translation")},null,8,["content"])]),r("div",qe,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value"},null,8,["modelValue"])])])])}const Xe=k(De,[["render",He]]),Ye=b({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=ee)}}),Je={class:"text-sm font-bold mb-2 block"},Qe={class:"items"},Ke=["onClick"],We={class:"name"};function Ze(e,o,v,f,y,V){return t(),i("div",null,[r("span",Je,l(e.$t("veo.name.ratio")),1),r("div",Qe,[(t(!0),i(E,null,T(e.options,(c,u)=>(t(),i("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:s=>e.value=c.value},[r("div",{class:A(["preview",c.label])},[r("div",{class:"rect",style:J({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",We,l(c.label),1)],10,Ke))),128))])])}const xe=k(Ye,[["render",Ze],["__scopeId","data-v-0f16be77"]]),eo=b({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),oo={class:"relative"},to={class:"flex mb-2"},so={class:"text-sm font-bold"};function no(e,o,v,f,y,V){const c=n("video-player");return t(),i("div",oo,[r("div",to,[r("span",so,l(e.$t("veo.name.action3")),1)]),r("div",null,[e.config?.video_url?(t(),m(c,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const ao=k(eo,[["render",no]]),lo=b({name:"VideoIdInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),io={class:"field"},ro={class:"title font-bold"};function co(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",io,[r("h2",ro,l(e.$t("veo.name.videoId")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const uo=k(lo,[["render",co],["__scopeId","data-v-6eba4026"]]),po=b({name:"StartEndImage",components:{ElUpload:de,ElButton:U,InfoIcon:j,FontAwesomeIcon:P,ImagePreview:ce},mixins:[re],emits:["change"],data(){return{fileList:[],uploadUrl:Q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),mo={class:"relative"},vo={class:"flex justify-between"},fo={class:"flex justify-start items-center"},_o={class:"text-sm font-bold"};function ho(e,o,v,f,y,V){const c=n("info-icon"),u=n("image-preview"),s=n("font-awesome-icon"),w=n("el-button"),$=n("el-upload");return t(),i("div",mo,[r("div",vo,[r("div",fo,[r("span",_o,l(e.$t("veo.name.startEndImage")),1),a(c,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a($,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=h=>e.fileList=h),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:h})=>[h.url&&h.percentage!==void 0?(t(),m(u,{key:0,url:h.url,name:h.name,percentage:h.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(s,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const $o=k(po,[["render",ho],["__scopeId","data-v-b8ddb8fb"]]),go=b({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return te.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=oe)}}),bo={class:"field"},ko={class:"title font-bold"};function yo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",bo,[r("h2",ko,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Vo=k(go,[["render",yo],["__scopeId","data-v-8b74a7ae"]]),wo=b({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return G.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!G.includes(this.value))&&(this.value=se)}}),Eo={class:"field"},Io={class:"title font-bold"};function To(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Eo,[r("h2",Io,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const So=k(wo,[["render",To],["__scopeId","data-v-cc3f9355"]]),Ao=b({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return ae.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=ne)}}),Co={class:"field"},Oo={class:"title font-bold"};function Po(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Co,[r("h2",Oo,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Uo=k(Ao,[["render",Po],["__scopeId","data-v-3affff3c"]]),Lo=b({name:"ImageMaskInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),jo={class:"field"},Ro={class:"title font-bold"};function Mo(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",jo,[r("h2",Ro,l(e.$t("veo.name.imageMask")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const Go=k(Lo,[["render",Mo],["__scopeId","data-v-6cc27c68"]]),Do="",No=b({name:"PromptInput",components:{ElInput:R,InfoIcon:j},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Do)}}),Fo={class:"field"},zo={class:"box"},Bo={class:"title font-bold"};function qo(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-input");return t(),i("div",Fo,[r("div",zo,[r("h2",Bo,l(e.$t("veo.name.prompt")),1),a(c,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),a(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ho=k(No,[["render",qo],["__scopeId","data-v-84c55ea0"]]),Xo=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Yo=["text2video","image2video","ingredients2video"],Jo=b({name:"ConfigPanel",components:{ElButton:U,Consumption:ue,FontAwesomeIcon:P,PromptInput:Ho,ModelSelector:Pe,StartEndImage:$o,ActionSelector:Ge,VideoFromInput:ao,VideoIdInput:uo,UpsampleActionSelector:Vo,ExtendModelSelector:So,MotionTypeSelector:Uo,ImageMaskInput:Go,TranslationSelector:Xe,AspectRatioSelector:xe},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return pe(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Xo.includes(this.config?.action??"")},isGeneration(){return Yo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Qo={class:"flex flex-col h-full"},Ko={class:"flex-1 overflow-y-auto p-5"},Wo={class:"flex flex-col items-center justify-center px-5 pb-5"};function Zo(e,o,v,f,y,V){const c=n("action-selector"),u=n("video-from-input"),s=n("video-id-input"),w=n("upsample-action-selector"),$=n("extend-model-selector"),h=n("prompt-input"),S=n("motion-type-selector"),g=n("image-mask-input"),N=n("translation-selector"),F=n("aspect-ratio-selector"),z=n("model-selector"),B=n("start-end-image"),q=n("consumption"),H=n("font-awesome-icon"),X=n("el-button");return t(),i("div",Qo,[r("div",Ko,[a(c,{class:"mb-4"}),e.isPostProcessing?(t(),i(E,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(s,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(w,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m($,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(h,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(S,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(h,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(g,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(h,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(E,{key:8},[a(N,{class:"mb-4"}),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(F,{key:0,class:"mb-4"})):d("",!0),a(h,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:2,class:"mb-2"})):d("",!0)],64)):d("",!0)]),r("div",Wo,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(X,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const xo=k(Jo,[["render",Zo]]),et=b({name:"TaskPreview",components:{ElImage:$e,CopyToClipboard:fe,FontAwesomeIcon:P,ElAlert:he,VideoPlayer:D,ElTooltip:_e,ElButton:U},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,f){console.debug("seed config from preview",{action:v,upsampleAction:f,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,...f?{upsample_action:f}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),ot={class:"preview"},tt={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},it={key:0,class:"prompt mt-2"},rt={key:0},ct={key:1},dt={key:0,class:A({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:A({operations:!0,"mt-2":!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:A({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},kt={key:2,class:A({content:!0})},yt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function wt(e,o,v,f,y,V){const c=n("el-image"),u=n("video-player"),s=n("el-button"),w=n("el-tooltip"),$=n("font-awesome-icon"),h=n("copy-to-clipboard"),S=n("el-alert");return t(),i("div",ot,[r("div",tt,[a(c,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),r("div",st,[r("div",nt,[_(l(e.$t("veo.name.veoBot"))+" ",1),r("span",at,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",lt,[e.modelValue?.request?.prompt?(t(),i("p",it,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",rt," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",ct," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",dt,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",ut,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",pt,[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=g=>e.onPickAction(g,e.modelValue?.response,"extend"))},{default:p(()=>[_(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=g=>e.onPickAction(g,e.modelValue?.response,"reshoot"))},{default:p(()=>[_(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=g=>e.onPickAction(g,e.modelValue?.response,"object_insert"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=g=>e.onPickAction(g,e.modelValue?.response,"object_remove"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=g=>e.onDownload(g,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[_(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"])])):d("",!0),a(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[r("p",mt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",vt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",ft,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",_t,[a(S,{closable:!1,class:"failure"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",ht,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),r("p",$t,[a($,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(h,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",gt,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",bt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",kt,[a(S,{closable:!1,class:"info"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",yt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",Vt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const Et=k(et,[["render",wt],["__scopeId","data-v-83f2991f"]]),It=b({name:"RecentPanel",components:{TaskPreview:Et,NoTasks:be,BotPlaceholder:ge,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Tt={key:0},St={key:2,class:"w-full h-full flex items-center justify-center"};function At(e,o,v,f,y,V){const c=n("bot-placeholder"),u=n("task-preview"),s=n("scroll-list"),w=n("no-tasks");return t(),i(E,null,[e.tasks?.items===void 0?(t(),i("div",Tt,[a(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(s,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=$=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(E,null,T(e.tasks?.items,($,h)=>(t(),m(u,{key:h,"model-value":$},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",St,[a(w)])):d("",!0)],64)}const Ct=k(It,[["render",At]]),Ot="https://webhook.acedata.cloud/veo",Pt=b({name:"VeoIndex",components:{ConfigPanel:xo,Layout:Te,RecentPanel:Ct},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ke({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:f}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ot},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),K("veo",ve.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===me?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,o,v,f,y,V){const c=n("config-panel"),u=n("recent-panel"),s=n("layout");return t(),m(s,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ss=k(Pt,[["render",Ut]]);export{Ss as default};
1
+ import{F as P}from"./index.es-B8_8wmrH.js";import{E as U}from"./index-BIKYfCNm.js";import{E as Y}from"./index-D8fds_1u.js";import{d as b,H as i,E as r,z as L,C as a,y as p,D as n,q as t,F as l,O as E,N as T,x as m,Q as A,R as J,J as d,I as _}from"./vendor-vue-NSDaktjZ.js";import{E as k,b7 as Q,cd as K,aw as M}from"./index-B5VThxFx.js";import{a as W,b as Z,c as x,d as ee,e as oe,f as te,g as G,h as se,i as ne,j as ae}from"./veo-Dg8Zhpd-.js";import{E as C,a as O}from"./index-BcFuJFD4.js";import{I as j,S as le}from"./ScrollList-BdIMpJr2.js";import{E as ie}from"./index-BG8woF1-.js";import{V as D}from"./VideoPlayer-DLau3K08.js";import{E as R}from"./index-Bsa0Z5HA.js";import{p as re}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ce}from"./ImagePreview-BO9qxdtw.js";import{E as de}from"./index-Z1E1odYA.js";import{E as I}from"./index-CixKTx1D.js";import{C as ue}from"./Consumption-DbcJR769.js";import{a as pe}from"./price-D-PQQgbY.js";import{b as me}from"./errorCode-Cqj9Td_Z.js";import{v as ve}from"./veo-IaIv3GnY.js";import{C as fe}from"./CopyToClipboard-SvDri6QJ.js";import{E as _e}from"./index-CPQzwH96.js";import{E as he}from"./index-CKXwdWS1.js";import{E as $e}from"./index-BthUaHYA.js";import{B as ge}from"./BotPlaceholder-BJ5FbY4i.js";import{N as be}from"./NoTasks-B3OHHyLX.js";import{l as ke}from"./pagination-Cnc6Oeyx.js";import"./use-form-item-DOEGLSGe.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-Cvgzdobq.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-Bcez2XRv.js";import"./typescript-Ch72LBtj.js";import"./index-jKSTpmaL.js";import"./strings-beZM2Y-f.js";import"./isEqual-BvJig0uU.js";import"./_Uint8Array-d0PfytAk.js";import"./castArray-B4IZIXMJ.js";import"./debounce-BA7XqfxN.js";import"./_baseIteratee-CbQQ2vi2.js";import"./index-CdSLN7HB.js";import"./validator-DgDQ8pCz.js";import"./vue-plyr-BO2nlN4c.js";import"./index-C_u-Xh_j.js";import"./index-C6VAcwnH.js";import"./_baseClone-fTTPu5Nv.js";import"./_initCloneObject-BrlQCApt.js";import"./index-Y6Hpp21c.js";const ye=b({name:"LayoutVeo",components:{ElDrawer:Y,ElButton:U,FontAwesomeIcon:P},data(){return{drawer:!1}}}),Ve={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ee={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ie(e,o,v,f,y,V){const c=n("font-awesome-icon"),u=n("el-button"),s=n("el-drawer");return t(),i("div",Ve,[r("div",we,[L(e.$slots,"config",{},void 0,!0)]),r("div",Ee,[L(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:p(()=>[a(c,{icon:"fa-solid fa-magic"})]),_:1}),a(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Te=k(ye,[["render",Ie],["__scopeId","data-v-816b984c"]]),Se=b({name:"ModelSelector",components:{ElSelect:O,ElOption:C},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=W)}}),Ae={class:"field"},Ce={class:"title font-bold"};function Oe(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Ae,[r("h2",Ce,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Pe=k(Se,[["render",Oe],["__scopeId","data-v-a59d89c9"]]),Ue=b({name:"ActionSelector",components:{ElSelect:O,ElOption:C},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=Z)}}),Le={class:"field"},je={class:"title font-bold"},Re={class:"float-left"};function Me(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Le,[r("h2",je,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},{default:p(()=>[r("span",Re,l(s.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=k(Ue,[["render",Me],["__scopeId","data-v-f4d8785c"]]),De=b({name:"TranslationSelector",components:{ElSwitch:ie,InfoIcon:j},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=x)}}),Ne={class:"relative"},Fe={class:"flex justify-between"},ze={class:"flex justify-start items-center"},Be={class:"text-sm font-bold"},qe={class:"flex justify-end items-center"};function He(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-switch");return t(),i("div",Ne,[r("div",Fe,[r("div",ze,[r("span",Be,l(e.$t("veo.name.translation")),1),a(c,{content:e.$t("veo.description.translation")},null,8,["content"])]),r("div",qe,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value"},null,8,["modelValue"])])])])}const Xe=k(De,[["render",He]]),Ye=b({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=ee)}}),Je={class:"text-sm font-bold mb-2 block"},Qe={class:"items"},Ke=["onClick"],We={class:"name"};function Ze(e,o,v,f,y,V){return t(),i("div",null,[r("span",Je,l(e.$t("veo.name.ratio")),1),r("div",Qe,[(t(!0),i(E,null,T(e.options,(c,u)=>(t(),i("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:s=>e.value=c.value},[r("div",{class:A(["preview",c.label])},[r("div",{class:"rect",style:J({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",We,l(c.label),1)],10,Ke))),128))])])}const xe=k(Ye,[["render",Ze],["__scopeId","data-v-0f16be77"]]),eo=b({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),oo={class:"relative"},to={class:"flex mb-2"},so={class:"text-sm font-bold"};function no(e,o,v,f,y,V){const c=n("video-player");return t(),i("div",oo,[r("div",to,[r("span",so,l(e.$t("veo.name.action3")),1)]),r("div",null,[e.config?.video_url?(t(),m(c,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const ao=k(eo,[["render",no]]),lo=b({name:"VideoIdInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),io={class:"field"},ro={class:"title font-bold"};function co(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",io,[r("h2",ro,l(e.$t("veo.name.videoId")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const uo=k(lo,[["render",co],["__scopeId","data-v-6eba4026"]]),po=b({name:"StartEndImage",components:{ElUpload:de,ElButton:U,InfoIcon:j,FontAwesomeIcon:P,ImagePreview:ce},mixins:[re],emits:["change"],data(){return{fileList:[],uploadUrl:Q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),mo={class:"relative"},vo={class:"flex justify-between"},fo={class:"flex justify-start items-center"},_o={class:"text-sm font-bold"};function ho(e,o,v,f,y,V){const c=n("info-icon"),u=n("image-preview"),s=n("font-awesome-icon"),w=n("el-button"),$=n("el-upload");return t(),i("div",mo,[r("div",vo,[r("div",fo,[r("span",_o,l(e.$t("veo.name.startEndImage")),1),a(c,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a($,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=h=>e.fileList=h),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:h})=>[h.url&&h.percentage!==void 0?(t(),m(u,{key:0,url:h.url,name:h.name,percentage:h.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(s,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const $o=k(po,[["render",ho],["__scopeId","data-v-b8ddb8fb"]]),go=b({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return te.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=oe)}}),bo={class:"field"},ko={class:"title font-bold"};function yo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",bo,[r("h2",ko,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Vo=k(go,[["render",yo],["__scopeId","data-v-8b74a7ae"]]),wo=b({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return G.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!G.includes(this.value))&&(this.value=se)}}),Eo={class:"field"},Io={class:"title font-bold"};function To(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Eo,[r("h2",Io,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const So=k(wo,[["render",To],["__scopeId","data-v-cc3f9355"]]),Ao=b({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:C},computed:{options(){return ae.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=ne)}}),Co={class:"field"},Oo={class:"title font-bold"};function Po(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Co,[r("h2",Oo,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Uo=k(Ao,[["render",Po],["__scopeId","data-v-3affff3c"]]),Lo=b({name:"ImageMaskInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),jo={class:"field"},Ro={class:"title font-bold"};function Mo(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",jo,[r("h2",Ro,l(e.$t("veo.name.imageMask")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const Go=k(Lo,[["render",Mo],["__scopeId","data-v-6cc27c68"]]),Do="",No=b({name:"PromptInput",components:{ElInput:R,InfoIcon:j},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Do)}}),Fo={class:"field"},zo={class:"box"},Bo={class:"title font-bold"};function qo(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-input");return t(),i("div",Fo,[r("div",zo,[r("h2",Bo,l(e.$t("veo.name.prompt")),1),a(c,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),a(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ho=k(No,[["render",qo],["__scopeId","data-v-84c55ea0"]]),Xo=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Yo=["text2video","image2video","ingredients2video"],Jo=b({name:"ConfigPanel",components:{ElButton:U,Consumption:ue,FontAwesomeIcon:P,PromptInput:Ho,ModelSelector:Pe,StartEndImage:$o,ActionSelector:Ge,VideoFromInput:ao,VideoIdInput:uo,UpsampleActionSelector:Vo,ExtendModelSelector:So,MotionTypeSelector:Uo,ImageMaskInput:Go,TranslationSelector:Xe,AspectRatioSelector:xe},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return pe(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Xo.includes(this.config?.action??"")},isGeneration(){return Yo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Qo={class:"flex flex-col h-full"},Ko={class:"flex-1 overflow-y-auto p-5"},Wo={class:"flex flex-col items-center justify-center px-5 pb-5"};function Zo(e,o,v,f,y,V){const c=n("action-selector"),u=n("video-from-input"),s=n("video-id-input"),w=n("upsample-action-selector"),$=n("extend-model-selector"),h=n("prompt-input"),S=n("motion-type-selector"),g=n("image-mask-input"),N=n("translation-selector"),F=n("aspect-ratio-selector"),z=n("model-selector"),B=n("start-end-image"),q=n("consumption"),H=n("font-awesome-icon"),X=n("el-button");return t(),i("div",Qo,[r("div",Ko,[a(c,{class:"mb-4"}),e.isPostProcessing?(t(),i(E,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(s,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(w,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m($,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(h,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(S,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(h,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(g,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(h,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(E,{key:8},[a(N,{class:"mb-4"}),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(F,{key:0,class:"mb-4"})):d("",!0),a(h,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:2,class:"mb-2"})):d("",!0)],64)):d("",!0)]),r("div",Wo,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(X,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const xo=k(Jo,[["render",Zo]]),et=b({name:"TaskPreview",components:{ElImage:$e,CopyToClipboard:fe,FontAwesomeIcon:P,ElAlert:he,VideoPlayer:D,ElTooltip:_e,ElButton:U},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,f){console.debug("seed config from preview",{action:v,upsampleAction:f,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,...f?{upsample_action:f}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),ot={class:"preview"},tt={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},it={key:0,class:"prompt mt-2"},rt={key:0},ct={key:1},dt={key:0,class:A({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:A({operations:!0,"mt-2":!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:A({content:!0})},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},kt={key:2,class:A({content:!0})},yt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function wt(e,o,v,f,y,V){const c=n("el-image"),u=n("video-player"),s=n("el-button"),w=n("el-tooltip"),$=n("font-awesome-icon"),h=n("copy-to-clipboard"),S=n("el-alert");return t(),i("div",ot,[r("div",tt,[a(c,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),r("div",st,[r("div",nt,[_(l(e.$t("veo.name.veoBot"))+" ",1),r("span",at,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",lt,[e.modelValue?.request?.prompt?(t(),i("p",it,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",rt," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",ct," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",dt,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",ut,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",pt,[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=g=>e.onPickAction(g,e.modelValue?.response,"extend"))},{default:p(()=>[_(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=g=>e.onPickAction(g,e.modelValue?.response,"reshoot"))},{default:p(()=>[_(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=g=>e.onPickAction(g,e.modelValue?.response,"object_insert"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=g=>e.onPickAction(g,e.modelValue?.response,"object_remove"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=g=>e.onDownload(g,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[_(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"])])):d("",!0),a(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[r("p",mt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",vt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",ft,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",_t,[a(S,{closable:!1,class:"failure"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",ht,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),r("p",$t,[a($,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(h,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",gt,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",bt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",kt,[a(S,{closable:!1,class:"info"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",yt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",Vt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const Et=k(et,[["render",wt],["__scopeId","data-v-83f2991f"]]),It=b({name:"RecentPanel",components:{TaskPreview:Et,NoTasks:be,BotPlaceholder:ge,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Tt={key:0},St={key:2,class:"w-full h-full flex items-center justify-center"};function At(e,o,v,f,y,V){const c=n("bot-placeholder"),u=n("task-preview"),s=n("scroll-list"),w=n("no-tasks");return t(),i(E,null,[e.tasks?.items===void 0?(t(),i("div",Tt,[a(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(s,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=$=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(E,null,T(e.tasks?.items,($,h)=>(t(),m(u,{key:h,"model-value":$},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",St,[a(w)])):d("",!0)],64)}const Ct=k(It,[["render",At]]),Ot="https://webhook.acedata.cloud/veo",Pt=b({name:"VeoIndex",components:{ConfigPanel:xo,Layout:Te,RecentPanel:Ct},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ke({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:f}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ot},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),K("veo",ve.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===me?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ut(e,o,v,f,y,V){const c=n("config-panel"),u=n("recent-panel"),s=n("layout");return t(),m(s,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ss=k(Pt,[["render",Ut]]);export{Ss as default};