@acedatacloud/nexior 3.165.0 → 3.166.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 (228) hide show
  1. package/dist/assets/{Auth-QFl8wvov.js → Auth-DFRTIldg.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-teJQgw1R.js → BotPlaceholder-BLqNsw9k.js} +1 -1
  3. package/dist/assets/{Callback-DUG_0nL9.js → Callback-CHgC-5ER.js} +1 -1
  4. package/dist/assets/{Console-C4ni_K8l.js → Console-BUhuv8r2.js} +1 -1
  5. package/dist/assets/{Consumption-DTqKtl19.js → Consumption-D9Hn2ImE.js} +1 -1
  6. package/dist/assets/{Conversation-B1nlcCj3.js → Conversation-CT5b219A.js} +1 -1
  7. package/dist/assets/{CopyToClipboard-CHIfP83C.js → CopyToClipboard-YKue_6LC.js} +1 -1
  8. package/dist/assets/{Detail-CpZay6En.js → Detail-DJ3K4Lui.js} +2 -2
  9. package/dist/assets/{EditArray-fTlZytbV.js → EditArray-D9X7ilzT.js} +1 -1
  10. package/dist/assets/{Extra-hWv_Zh-w.js → Extra-tNEhYDVR.js} +1 -1
  11. package/dist/assets/{FilePreview-ZxOIpkjO.js → FilePreview-BLBZCIvI.js} +1 -1
  12. package/dist/assets/{History-C0ckJn8X.js → History-BsiIeeU2.js} +1 -1
  13. package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-ChnszgHA.js → IconPark.vue_vue_type_script_setup_true_lang-rN4yfqRq.js} +1 -1
  14. package/dist/assets/{ImagePreview-Bdb0i-UY.js → ImagePreview-CUOTVDKq.js} +1 -1
  15. package/dist/assets/{ImageWrapper-DQ4mprTG.js → ImageWrapper-BTYsRpEP.js} +1 -1
  16. package/dist/assets/{Index-D62cd0vK.js → Index-0fxXA4_J.js} +1 -1
  17. package/dist/assets/{Index-C5QNZoPE.js → Index-1m4ePc99.js} +1 -1
  18. package/dist/assets/{Index-BAbLvO0T.js → Index-Aud0OTuP.js} +1 -1
  19. package/dist/assets/{Index-H53x6bs-.js → Index-B-AW-gIW.js} +1 -1
  20. package/dist/assets/{Index-BRtxGRTG.js → Index-BAEdyQeV.js} +1 -1
  21. package/dist/assets/{Index-DW6bQp-A.css → Index-BaRagseA.css} +1 -1
  22. package/dist/assets/{Index-D8naCCGX.js → Index-C138EMq8.js} +1 -1
  23. package/dist/assets/{Index-CahgxOO6.js → Index-C6BwOZ3w.js} +1 -1
  24. package/dist/assets/{Index-CKF-bPuL.js → Index-CAKUcveC.js} +1 -1
  25. package/dist/assets/{Index-CHr-S8VL.js → Index-CBA8zIuN.js} +1 -1
  26. package/dist/assets/Index-CBgaEKEn.js +1 -0
  27. package/dist/assets/{Index-JQGxDvVx.js → Index-CJWvx5ND.js} +1 -1
  28. package/dist/assets/{Index-Dihiqk3n.js → Index-D4OExIA4.js} +1 -1
  29. package/dist/assets/{Index-CVQSictr.js → Index-DTWbz-mb.js} +1 -1
  30. package/dist/assets/{Index-GAyX8JLL.js → Index-DTbuJEY1.js} +1 -1
  31. package/dist/assets/{Index-CBaFV7Km.js → Index-DWjSghj6.js} +1 -1
  32. package/dist/assets/{Index-BJKR_l5i.js → Index-Dcwar_I_.js} +1 -1
  33. package/dist/assets/{Index-BS6gQkGg.js → Index-DeVbMbCS.js} +1 -1
  34. package/dist/assets/{Index-w1fclgzE.js → Index-DjsTZzCq.js} +1 -1
  35. package/dist/assets/{Index-C8PSwcv8.js → Index-DmiBBxMR.js} +1 -1
  36. package/dist/assets/{Index-z92kW0LQ.js → Index-DvgaohNO.js} +1 -1
  37. package/dist/assets/{Index-B0JQUqqM.js → Index-DwjUaatK.js} +1 -1
  38. package/dist/assets/{Index-kkNkz_os.js → Index-HvXcS5Be.js} +1 -1
  39. package/dist/assets/{Index-BDIOWR2s.js → Index-SD4zKg1q.js} +1 -1
  40. package/dist/assets/{Index-D4AU2wLY.js → Index-cV8Yyo9p.js} +1 -1
  41. package/dist/assets/{Invitees-Cpyz-GEF.js → Invitees-Dx5MX_iJ.js} +1 -1
  42. package/dist/assets/{List-CuVqG93t.js → List-BIYl6bzU.js} +1 -1
  43. package/dist/assets/{List-CRr2Ebvy.js → List-CQxikLB8.js} +1 -1
  44. package/dist/assets/{List-D7mcU_w0.js → List-Cxywj_LE.js} +1 -1
  45. package/dist/assets/{Main-B5NCR5Tx.js → Main-Ctqdhys8.js} +1 -1
  46. package/dist/assets/{Navigator-CDg5_jXD.js → Navigator-CcH_hYdW.js} +1 -1
  47. package/dist/assets/{NoTasks-Dro6OdxD.js → NoTasks-B7fpKwEM.js} +1 -1
  48. package/dist/assets/{NotFound-BhS5F53U.js → NotFound-CTcD9OJN.js} +1 -1
  49. package/dist/assets/{OAuthCallback-1nC4_les.js → OAuthCallback-DilJbVAG.js} +1 -1
  50. package/dist/assets/{Pagination-CGK6TLMi.js → Pagination-D2l4tVs_.js} +1 -1
  51. package/dist/assets/{Status-B2CODnvr.js → Status-DEM2PLOr.js} +1 -1
  52. package/dist/assets/{Subscribe-Cmosa6qP.js → Subscribe-CJOh4174.js} +1 -1
  53. package/dist/assets/{VideoPlayer-Cy3-ZAWg.js → VideoPlayer-DPmqjyk_.js} +1 -1
  54. package/dist/assets/{_Uint8Array-JndvkAwf.js → _Uint8Array-DdojeWiA.js} +1 -1
  55. package/dist/assets/{_baseClone-BywLfCY-.js → _baseClone-CkHqwwjY.js} +1 -1
  56. package/dist/assets/{_baseIteratee-BaTk7Xco.js → _baseIteratee-BJlOKELK.js} +1 -1
  57. package/dist/assets/{_initCloneObject-D5P_u5bs.js → _initCloneObject-DJHkV8_e.js} +1 -1
  58. package/dist/assets/{add-MHM5adot.js → add-DgiDgPk2.js} +1 -1
  59. package/dist/assets/{all-wallets-DghbU6pB.js → all-wallets-Ir8fVnIE.js} +1 -1
  60. package/dist/assets/{app-store-B5d2ke5R.js → app-store-BSr6K8vJ.js} +1 -1
  61. package/dist/assets/{apple-DcWUSF7H.js → apple-Yw5vBM9e.js} +1 -1
  62. package/dist/assets/{arrow-bottom-circle-C7pglfhV.js → arrow-bottom-circle-C03-yd0p.js} +1 -1
  63. package/dist/assets/{arrow-bottom-CAFMTIro.js → arrow-bottom-vVfNYwgN.js} +1 -1
  64. package/dist/assets/{arrow-left-Ca5HiJyU.js → arrow-left-Houf2S9n.js} +1 -1
  65. package/dist/assets/{arrow-right-BHK6x0D0.js → arrow-right-C0p7Cfns.js} +1 -1
  66. package/dist/assets/{arrow-top-M7zp-rH1.js → arrow-top-BFZ3-_4h.js} +1 -1
  67. package/dist/assets/{avatar-DgwLY0F2.js → avatar-CDKyOWa1.js} +1 -1
  68. package/dist/assets/{bank-SSDifLcO.js → bank-DlDeeg-M.js} +1 -1
  69. package/dist/assets/{basic-Be21SJ4t.js → basic-DdHY_6kS.js} +1 -1
  70. package/dist/assets/{browser-CUJm8BoS.js → browser-BvJkxROA.js} +1 -1
  71. package/dist/assets/{byokCredential-Np5spQbA.js → byokCredential-BSHUJThg.js} +1 -1
  72. package/dist/assets/{card-CSSyeeL5.js → card-bjHpyjBK.js} +1 -1
  73. package/dist/assets/{castArray-BzRYTmyg.js → castArray-PDXtni_G.js} +1 -1
  74. package/dist/assets/{chat-CO5_buPC.js → chat-D_3mtJGM.js} +1 -1
  75. package/dist/assets/{checkmark-DHknSf9L.js → checkmark-CvNDvyd2.js} +1 -1
  76. package/dist/assets/{checkmark-bold-BRynkBu_.js → checkmark-bold-BaD95hk7.js} +1 -1
  77. package/dist/assets/{chevron-bottom-CxoghWFm.js → chevron-bottom-BZTrBoQZ.js} +1 -1
  78. package/dist/assets/{chevron-left--wPz3w6Z.js → chevron-left-gkGHznHL.js} +1 -1
  79. package/dist/assets/{chevron-right-saEXbUGn.js → chevron-right-B2ps_1x1.js} +1 -1
  80. package/dist/assets/{chevron-top-DS7eYYgl.js → chevron-top-BcHLsjsv.js} +1 -1
  81. package/dist/assets/{chrome-store-DYuG5PcW.js → chrome-store-B_e6TuIp.js} +1 -1
  82. package/dist/assets/{clock-CBdDJ5Df.js → clock-Crtz1b91.js} +1 -1
  83. package/dist/assets/{close-BjPE_-aP.js → close-CVk0Y4TQ.js} +1 -1
  84. package/dist/assets/{coinPlaceholder-BiVzICb3.js → coinPlaceholder-CToK3nFp.js} +1 -1
  85. package/dist/assets/{compass-PMZMMq0Z.js → compass-D9KY3PBb.js} +1 -1
  86. package/dist/assets/{copy-Uj5cKBl8.js → copy-_SHmr2qS.js} +1 -1
  87. package/dist/assets/{createTaskActions-CU8q3u1r.js → createTaskActions-pg5m9M7p.js} +1 -1
  88. package/dist/assets/{cursor-C6BXinQj.js → cursor-BXSppnwr.js} +1 -1
  89. package/dist/assets/{cursor-transparent-DsTmLChU.js → cursor-transparent-ITFaqM-M.js} +1 -1
  90. package/dist/assets/{debounce-D7YINRDE.js → debounce-DLWpM2kv.js} +1 -1
  91. package/dist/assets/{desktop-DVhIgZOr.js → desktop-Ctxvg_Mc.js} +1 -1
  92. package/dist/assets/{disconnect-CuUhUKSv.js → disconnect-362IL6KW.js} +1 -1
  93. package/dist/assets/{discord-BVTnwzNj.js → discord-D6KbitWr.js} +1 -1
  94. package/dist/assets/{distribution-CqMjpTR8.js → distribution-opJjNwQy.js} +1 -1
  95. package/dist/assets/{dropdown-B9aMQjZh.js → dropdown-CRfezuvq.js} +1 -1
  96. package/dist/assets/{etherscan-C0uYoQGL.js → etherscan-TTFJLDpm.js} +1 -1
  97. package/dist/assets/{exclamation-triangle-BwC-OFyl.js → exclamation-triangle-DeRUzLlM.js} +1 -1
  98. package/dist/assets/{extension-CIOTKKOf.js → extension-D_fSzTou.js} +1 -1
  99. package/dist/assets/{external-link-CYMLf0Ns.js → external-link-CIqLSeAr.js} +1 -1
  100. package/dist/assets/{facebook-DyaS9rXQ.js → facebook-CxdM6ryJ.js} +1 -1
  101. package/dist/assets/{farcaster-0IbvFQrl.js → farcaster-YTjCYlDM.js} +1 -1
  102. package/dist/assets/{filters-CvFHkNa0.js → filters-98lL8dRx.js} +1 -1
  103. package/dist/assets/{github-BqnwncTz.js → github-DTyEwyGJ.js} +1 -1
  104. package/dist/assets/{google-SQuxevK_.js → google-BSZydxsM.js} +1 -1
  105. package/dist/assets/{help-circle-DYG8MQQG.js → help-circle-CcNn1rLc.js} +1 -1
  106. package/dist/assets/{id-XQhzrZqg.js → id-Cun2ausq.js} +1 -1
  107. package/dist/assets/{image-BXv_qOZO.js → image-Dub-7Nlr.js} +1 -1
  108. package/dist/assets/{index-KJ_Bm-Sb.js → index--Bss94FI.js} +1 -1
  109. package/dist/assets/{index-CD3hMCXK.js → index-0tg1OcXL.js} +1 -1
  110. package/dist/assets/{index-4fUmHLSf.js → index-4t94d9Yq.js} +1 -1
  111. package/dist/assets/{index-COvldWeP.js → index-8Tl1cChK.js} +1 -1
  112. package/dist/assets/{index-DutPYY3x.js → index-B1THd-aO.js} +1 -1
  113. package/dist/assets/{index-CWWZeClw.js → index-B2wj3UbJ.js} +1 -1
  114. package/dist/assets/{index-BcqWtXWM.js → index-B3mTxs9Y.js} +1 -1
  115. package/dist/assets/{index-ByGJSI5C.js → index-B5PvIfC4.js} +1 -1
  116. package/dist/assets/{index-Bwh4uhxH.js → index-B72vsB6D.js} +4 -4
  117. package/dist/assets/{index-MJt9uRMV.js → index-B8517Kq_.js} +1 -1
  118. package/dist/assets/{index-Bj-EDfAG.js → index-BCnzh3Xr.js} +1 -1
  119. package/dist/assets/{index-CLC3F3zh.js → index-BQYPVVtj.js} +1 -1
  120. package/dist/assets/{index-DG93bVkv.js → index-BTe0Vafw.js} +1 -1
  121. package/dist/assets/{index-CMCb9_bq.js → index-BYv3KnKa.js} +1 -1
  122. package/dist/assets/{index-Ck-GkfGu.js → index-Bb3nI4T1.js} +1 -1
  123. package/dist/assets/{index-Cdu2CINy.js → index-BdXdvXDF.js} +1 -1
  124. package/dist/assets/{index-BbRzjoyH.js → index-BeuqTSkS.js} +1 -1
  125. package/dist/assets/{index-CdNNDZgX.js → index-BiORZ5ee.js} +1 -1
  126. package/dist/assets/{index-udv8oHBR.js → index-BshjP0UT.js} +1 -1
  127. package/dist/assets/{index-D0svo0N2.js → index-Bua3buBf.js} +1 -1
  128. package/dist/assets/{index-U7KDLTxZ.js → index-C8DvX3qL.js} +1 -1
  129. package/dist/assets/{index-1aVfodJV.js → index-CAROfd4i.js} +1 -1
  130. package/dist/assets/{index-BRqPnPCL.js → index-CEGyzWWI.js} +1 -1
  131. package/dist/assets/{index-IQO2FhFE.js → index-CEW9DsqN.js} +5 -5
  132. package/dist/assets/{index-CghmaEfO.js → index-CGJx6pfn.js} +1 -1
  133. package/dist/assets/{index-nLjkUfZa.js → index-CYFuwdxJ.js} +1 -1
  134. package/dist/assets/{index-CAOsMXTW.js → index-CcjaGWkK.js} +1 -1
  135. package/dist/assets/{index-DDM_letT.js → index-CeH6helO.js} +1 -1
  136. package/dist/assets/{index-Df-EZV4-.js → index-CkEMCLbE.js} +1 -1
  137. package/dist/assets/{index-Beb7n_xY.js → index-ClVcQZ50.js} +1 -1
  138. package/dist/assets/{index-CWm6OdeE.js → index-Cou85JSj.js} +3 -3
  139. package/dist/assets/{index-DjsIiC0Y.js → index-Cr_uqtp_.js} +1 -1
  140. package/dist/assets/{index-D8r95ZCp.js → index-CuKao8C3.js} +1 -1
  141. package/dist/assets/{index-BpgdZsBs.js → index-CxdFHeqj.js} +1 -1
  142. package/dist/assets/{index-CZoz3sTY.js → index-D-R1uHlt.js} +1 -1
  143. package/dist/assets/{index-dLkFe5tp.js → index-D0ozHIX4.js} +1 -1
  144. package/dist/assets/{index-ByjQrnzD.js → index-D4lbSr-T.js} +1 -1
  145. package/dist/assets/{index-Bs4QQKmj.js → index-DCc5mWT3.js} +1 -1
  146. package/dist/assets/{index-Boh3hilg.js → index-DD1qoXbO.js} +1 -1
  147. package/dist/assets/{index-DSAaysXY.js → index-DDjfpPMW.js} +1 -1
  148. package/dist/assets/{index-ZaB33foX.js → index-DJqHVsEt.js} +1 -1
  149. package/dist/assets/{index-DWKjA_D8.js → index-DS__MBdR.js} +1 -1
  150. package/dist/assets/{index-D51AeHP9.js → index-Da2aFJLl.js} +1 -1
  151. package/dist/assets/{index-CWtgQWA5.js → index-DfpNVEjT.js} +1 -1
  152. package/dist/assets/{index-Dy5k6Duv.js → index-Dh2kPrs0.js} +1 -1
  153. package/dist/assets/{index-CEeWvdaB.js → index-DoBI-9N1.js} +1 -1
  154. package/dist/assets/{index-BiZZIfOf.js → index-DyRgASC4.js} +1 -1
  155. package/dist/assets/{index-Biwor0fW.js → index-GPTup2zg.js} +1 -1
  156. package/dist/assets/{index-CaMEIrh2.js → index-IHF4ze7_.js} +1 -1
  157. package/dist/assets/{index-DfHMyt1g.js → index-Khp7dQxO.js} +2 -2
  158. package/dist/assets/{index-DvfuPWbJ.js → index-PWZeMLxN.js} +1 -1
  159. package/dist/assets/{index-BgDIlmz8.js → index-Qqh2mgIx.js} +1 -1
  160. package/dist/assets/{index-BSoor3tO.js → index-Ub7ss3ID.js} +1 -1
  161. package/dist/assets/{index-BhAfU2EN.js → index-YpXkt_KJ.js} +1 -1
  162. package/dist/assets/{index-BUOjw5KN.js → index-ZISytNMe.js} +1 -1
  163. package/dist/assets/{index-BPugvnwC.js → index-acpn-dGD.js} +1 -1
  164. package/dist/assets/{index-5zp5rRSg.js → index-cJCFIiQJ.js} +1 -1
  165. package/dist/assets/{index-B3qBkdOQ.js → index-kT3FXf87.js} +1 -1
  166. package/dist/assets/{index-BipWEOw7.js → index-wJ0GDIQS.js} +1 -1
  167. package/dist/assets/{index-CaE4JHcH.js → index-ypJPwIOS.js} +1 -1
  168. package/dist/assets/{index.browser.esm-DwXBoLOX.js → index.browser.esm-BqXPSHSK.js} +1 -1
  169. package/dist/assets/{index.es-DoDsyBxd.js → index.es-B9yw59kn.js} +1 -1
  170. package/dist/assets/{info-Dnpt2U_5.js → info-MRa9rCfe.js} +1 -1
  171. package/dist/assets/{info-circle-Bt1w-pCz.js → info-circle-DHJUnSLt.js} +1 -1
  172. package/dist/assets/{isEqual-CgVTCLh1.js → isEqual-9RWKK6ZC.js} +1 -1
  173. package/dist/assets/{isPlainObject-DrlQ5Pnc.js → isPlainObject-D782C786.js} +1 -1
  174. package/dist/assets/{kling-DOOG08lq.js → kling-CFlrhlVc.js} +1 -1
  175. package/dist/assets/{kling-CFHGJQbi.js → kling-DCFW6ga_.js} +1 -1
  176. package/dist/assets/{lightbulb-aD-dsBxv.js → lightbulb-DSK7zynz.js} +1 -1
  177. package/dist/assets/{mail-7R5Js7B2.js → mail-M2oaM6Nj.js} +1 -1
  178. package/dist/assets/{midjourney-CtxD1PH8.js → midjourney-B13yDVpe.js} +1 -1
  179. package/dist/assets/{mobile-BtkxgoTF.js → mobile-DeRXzMkq.js} +1 -1
  180. package/dist/assets/{more-DAvhe9VU.js → more-CDR2PEkZ.js} +1 -1
  181. package/dist/assets/{network-placeholder-CCkyDJeN.js → network-placeholder-Ch_TWeDL.js} +1 -1
  182. package/dist/assets/{nftPlaceholder-CIJHDSVd.js → nftPlaceholder-C7M0Ea0A.js} +1 -1
  183. package/dist/assets/{off-BwoZGGFO.js → off-BVu_zU6U.js} +1 -1
  184. package/dist/assets/{order-BZjOBAha.js → order-qF6Pm2MY.js} +1 -1
  185. package/dist/assets/{pagination-DuUw6h7L.js → pagination-CBYfRJVG.js} +1 -1
  186. package/dist/assets/{play-store-CwQNyCN6.js → play-store-sgj5_sA_.js} +1 -1
  187. package/dist/assets/{plus-BbAuv3hx.js → plus-D7oK-AaE.js} +1 -1
  188. package/dist/assets/{price-Dq6B3nmI.js → price-BTNYcVQ5.js} +1 -1
  189. package/dist/assets/{producer-CI1GeNU0.js → producer-CRQQOFfj.js} +1 -1
  190. package/dist/assets/{qr-code-oGfaJIYm.js → qr-code-BcT7Ar6m.js} +1 -1
  191. package/dist/assets/{recycle-horizontal-CIMdWX63.js → recycle-horizontal-CjtP_6AI.js} +1 -1
  192. package/dist/assets/{refresh-CETVZsJS.js → refresh-J0icmcmr.js} +1 -1
  193. package/dist/assets/{reown-logo-CLmHzqhX.js → reown-logo-Gm4M3etA.js} +1 -1
  194. package/dist/assets/{search-Buv7Cq2F.js → search-CYAtmvQh.js} +1 -1
  195. package/dist/assets/{secp256k1-CWhf6TH4.js → secp256k1-CygyzlO4.js} +1 -1
  196. package/dist/assets/{secp256k1-DZFSOuaq.js → secp256k1-D54YM-Dv.js} +1 -1
  197. package/dist/assets/{seedream-BpNX1g1O.js → seedream-BnGwXTN0.js} +1 -1
  198. package/dist/assets/{send-BSMhw9Xa.js → send-D484iT01.js} +1 -1
  199. package/dist/assets/{service-CIPDs5an.js → service-UlOlaUCA.js} +1 -1
  200. package/dist/assets/{solana-wallets-RAxh0-qX.js → solana-wallets-BlkwJPMF.js} +2 -2
  201. package/dist/assets/{solana-wallets-vue-CieCmGxz.js → solana-wallets-vue-DG2aQxVX.js} +1 -1
  202. package/dist/assets/{suno-DFaKmajK.js → suno-C5xsII9n.js} +1 -1
  203. package/dist/assets/{swapHorizontal-Cs-Nsa-N.js → swapHorizontal-C3MXca9V.js} +1 -1
  204. package/dist/assets/{swapHorizontalBold-C_g3Z5YY.js → swapHorizontalBold-B55hvlhg.js} +1 -1
  205. package/dist/assets/{swapHorizontalMedium-Cni6iZGc.js → swapHorizontalMedium-DD_DKTRw.js} +1 -1
  206. package/dist/assets/{swapHorizontalRoundedBold-BIHXs_Kn.js → swapHorizontalRoundedBold-CZx7flz3.js} +1 -1
  207. package/dist/assets/{swapVertical-B2X4zH4b.js → swapVertical-Dr4LtnFY.js} +1 -1
  208. package/dist/assets/{telegram-C_umRltj.js → telegram-BXetNu8t.js} +1 -1
  209. package/dist/assets/{three-dots-in7LQz0m.js → three-dots-BINazGcv.js} +1 -1
  210. package/dist/assets/{twitch-BhlPlBfi.js → twitch-MRXoqcJp.js} +1 -1
  211. package/dist/assets/{twitterIcon-CrxI95_1.js → twitterIcon-Cg3VC0i4.js} +1 -1
  212. package/dist/assets/{typescript-C7vXUz1j.js → typescript-DqAqST2T.js} +1 -1
  213. package/dist/assets/{use-form-item-CkUvjro6.js → use-form-item-Yq9rpjQi.js} +1 -1
  214. package/dist/assets/validator-BOFed1cS.js +1 -0
  215. package/dist/assets/{verify-D6DQIx4j.js → verify-BHNcEXgF.js} +1 -1
  216. package/dist/assets/{verify-filled-FR7cKPze.js → verify-filled-du2-p6M5.js} +1 -1
  217. package/dist/assets/{w3m-modal-B5HAb7kJ.js → w3m-modal-CzZbiHZk.js} +1 -1
  218. package/dist/assets/{wallet-CDX0DAit.js → wallet-DuYmXFm1.js} +1 -1
  219. package/dist/assets/{wallet-placeholder-BRABXVV_.js → wallet-placeholder-ydE7j-YM.js} +1 -1
  220. package/dist/assets/{walletconnect-1VhScNHL.js → walletconnect-BjDk5PHK.js} +1 -1
  221. package/dist/assets/{warning-circle-DDJ5i3sU.js → warning-circle-CQTu56y4.js} +1 -1
  222. package/dist/assets/{web-BV6i-IiK.js → web-Byc8UprP.js} +1 -1
  223. package/dist/assets/{web-BfkNWdqt.js → web-af7ZvQZT.js} +1 -1
  224. package/dist/assets/{x-Cl7CMuoB.js → x-1Jl_JTA4.js} +1 -1
  225. package/dist/index.html +1 -1
  226. package/package.json +1 -1
  227. package/dist/assets/Index-CWGuNkuR.js +0 -1
  228. package/dist/assets/validator-BYlyQQaq.js +0 -1
@@ -1 +1 @@
1
- import{F as T}from"./index.es-DoDsyBxd.js";import{E as L}from"./index-CghmaEfO.js";import{E as Z}from"./index-BRqPnPCL.js";import{d as S,H as n,E as l,z as O,C as s,y as $,D as i,q as a,F as o,I as u,O as k,N as A,x as I,J as g,M as x,Q as P}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as K,cw as U,cx as X,cy as J,cz as W,cA as M,cB as R,cC as Q,cD as Y,cE as ee,cF as te,cG as se,cH as oe,cI as q,cJ as ae,cK as ie,cr as ne,aY as N,S as D,cs as le}from"./index-Bwh4uhxH.js";import{I as C,S as re,l as me}from"./pagination-DuUw6h7L.js";import{E as ce}from"./index-Df-EZV4-.js";import{I as B}from"./ImagePreview-Bdb0i-UY.js";import{E as ue}from"./index-CZoz3sTY.js";import{E as G}from"./index-CD3hMCXK.js";import{C as pe}from"./Consumption-DTqKtl19.js";import{a as de}from"./price-Dq6B3nmI.js";import{E as F,a as H,b as ge}from"./index-Bs4QQKmj.js";import{E as he}from"./index-udv8oHBR.js";import{E as fe}from"./index-DDM_letT.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as $e}from"./CopyToClipboard-CHIfP83C.js";import{I as be}from"./ImageWrapper-DQ4mprTG.js";import{E as ve}from"./index-CdNNDZgX.js";import{E as Ee}from"./index-CLC3F3zh.js";import{E as ke}from"./index-Cdu2CINy.js";import{B as Ie}from"./BotPlaceholder-teJQgw1R.js";import{N as Se}from"./NoTasks-Dro6OdxD.js";import"./use-form-item-CkUvjro6.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-C7vXUz1j.js";import"./index-CWWZeClw.js";import"./index-nLjkUfZa.js";import"./index-DSAaysXY.js";import"./_baseClone-BywLfCY-.js";import"./_Uint8Array-JndvkAwf.js";import"./_initCloneObject-D5P_u5bs.js";import"./isEqual-CgVTCLh1.js";import"./index-Boh3hilg.js";import"./strings-beZM2Y-f.js";import"./castArray-BzRYTmyg.js";import"./debounce-D7YINRDE.js";import"./_baseIteratee-BaTk7Xco.js";import"./index-Dy5k6Duv.js";import"./index-Cu41y2Fl.js";import"./validator-BYlyQQaq.js";import"./index-ByGJSI5C.js";const ye=S({name:"LayoutNanobanana",components:{ElDrawer:Z,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ae={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ge(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-drawer");return a(),n("div",we,[l("div",Ve,[O(e.$slots,"config",{},void 0,!0)]),l("div",Ae,[O(e.$slots,"result",{},void 0,!0)]),s(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=_=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(b,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Me=y(ye,[["render",Ge],["__scopeId","data-v-bfe5cd4b"]]),ze="",Te=S({name:"PromptInput",components:{ElInput:ce,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}}),Le={class:"field"},Pe={class:"box"},Ce={class:"title font-bold"};function Oe(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-input");return a(),n("div",Le,[l("div",Pe,[l("h2",Ce,o(e.$t("openaiimage.name.prompt")),1),s(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),s(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=b=>e.prompt=b),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ue=y(Te,[["render",Oe],["__scopeId","data-v-92f61e4a"]]),Re=S({name:"ImageUrlsInput",components:{ElUpload:ue,ElButton:L,InfoIcon:C,ImagePreview:B,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(f=>!f?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const f=this.fileList.find(v=>v?.response?.file_url===r||v?.url===r);f?t.push(f):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(v=>v===r||v?.url===r?.url||v?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){G.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){G.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),qe={class:"field flex items-center justify-between"},Ne={class:"title font-bold text-[14px] mb-[10px]"},De={class:"upload-wrapper flex flex-col items-start gap-[8px]"},je={class:"controls flex items-center"},We={class:"file-list flex flex-wrap gap-[10px]"};function Be(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-upload"),_=i("info-icon"),E=i("image-preview");return a(),n(k,null,[l("div",qe,[l("h2",Ne,o(e.$t("openaiimage.name.imageUrls")),1),l("div",De,[l("div",je,[s(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[s(h,{size:"small",type:"primary",round:""},{default:$(()=>[s(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(_,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",We,[(a(!0),n(k,null,A(e.fileList,(m,p)=>(a(),I(E,{key:m.uid||m?.response?.file_url||m.url||p,url:m.url||m?.response?.file_url,name:m.name,percentage:m.percentage,onRemove:w=>e.onRemovePreview(p,m)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Fe=y(Re,[["render",Be]]),He=S({name:"OpenAIImageModelSelector",components:{ElSelect:H,ElOption:F,InfoIcon:C},data(){return{options:[{value:X,label:this.$t("openaiimage.model.gptImage1")},{value:J,label:this.$t("openaiimage.model.gptImage15")},{value:W,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ze={class:"field"},xe={class:"label"},Ke={class:"box"},Xe={class:"title font-bold"};function Je(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-select");return a(),n("div",Ze,[l("div",xe,[l("div",Ke,[l("h2",Xe,o(e.$t("openaiimage.name.model")),1),s(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(b,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),n(k,null,A(e.options,_=>(a(),I(h,{key:_.value,label:_.label,value:_.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Qe=y(He,[["render",Je],["__scopeId","data-v-cec771bd"]]);function Ye(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const et=S({name:"OpenAIImageSizeSelector",components:{ElSelect:H,ElOption:F,ElOptionGroup:ge,ElSwitch:fe,ElInputNumber:he,InfoIcon:C},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ae.includes(this.model)},presets(){return q[this.model]??q[U]??[]},presetGroups(){return this.model===W?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:te},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:oe}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??M;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??M},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return ee},minSide(){return Y},maxSide(){return Q},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>R?this.$t("openaiimage.error.customSizePixels",{pixels:R.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??M);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??M)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??M);return}const e=Ye(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),tt={class:"resolution"},st={class:"field"},ot={class:"label"},at={class:"box"},it={class:"title font-bold"},nt={class:"field custom-toggle"},lt={class:"label"},rt={class:"box"},mt={class:"title font-bold"},ct={key:0,class:"custom-inputs"},ut={class:"row"},pt={class:"row-label"},dt={class:"row"},gt={class:"row-label"},ht={key:0,class:"error"};function ft(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-option-group"),_=i("el-select"),E=i("el-switch"),m=i("el-input-number");return a(),n("div",tt,[l("div",st,[l("div",ot,[l("div",at,[l("h2",it,o(e.$t("openaiimage.name.size")),1),s(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(_,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=p=>e.presetValue=p),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:$(()=>[(a(!0),n(k,null,A(e.presetGroups,p=>(a(),I(b,{key:p.label,label:p.label},{default:$(()=>[(a(!0),n(k,null,A(p.options,w=>(a(),I(h,{key:w,label:w,value:w},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(k,{key:0},[l("div",nt,[l("div",lt,[l("div",rt,[l("h2",mt,o(e.$t("openaiimage.name.customSize")),1),s(d,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(E,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=p=>e.useCustom=p),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ct,[l("div",ut,[l("span",pt,o(e.$t("openaiimage.name.width")),1),s(m,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=p=>e.customWidth=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),l("div",dt,[l("span",gt,o(e.$t("openaiimage.name.height")),1),s(m,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=p=>e.customHeight=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",ht,o(e.customError),1)):g("",!0)])):g("",!0)],64)):g("",!0)])}const _t=y(et,[["render",ft],["__scopeId","data-v-218b58cb"]]),$t=S({name:"ConfigPanel",components:{ElButton:L,FontAwesomeIcon:T,PromptInput:Ue,Consumption:pe,ImageUrlsInput:Fe,ModelSelector:Qe,ResolutionSelector:_t},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return de({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},vt={class:"flex-1 overflow-y-auto p-5"},Et={class:"flex flex-col items-center justify-center px-5 pb-5"};function kt(e,t,c,r,f,v){const d=i("model-selector"),h=i("resolution-selector"),b=i("prompt-input"),_=i("image-urls-input"),E=i("consumption"),m=i("font-awesome-icon"),p=i("el-button");return a(),n("div",bt,[l("div",vt,[s(d,{class:"mb-4"}),s(h,{class:"mb-4"}),s(b,{class:"mb-4"}),s(_,{class:"mb-4"})]),l("div",Et,[s(E,{value:e.consumption,service:e.service},null,8,["value","service"]),s(p,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(m,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const It=y($t,[["render",kt]]),St=S({name:"TaskPreview",components:{ElImage:ke,CopyToClipboard:$e,FontAwesomeIcon:T,ElAlert:Ee,ImageWrapper:be,ElButton:L,ElTooltip:ve,ImagePreview:B},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ie}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),yt={class:"preview"},wt={class:"left"},Vt={class:"main"},At={class:"bot"},Gt={class:"datetime"},Mt={class:"info"},zt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Tt={key:1,class:"prompt mt-2"},Lt={key:0},Pt={key:0,class:P({content:!0,failed:!0})},Ct={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ot={class:P({operations:!0,"mt-2":!0,"mb-2":!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Wt={key:1,class:P({content:!0})},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Jt={key:2,class:P({content:!0})},Qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},es={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function ss(e,t,c,r,f,v){const d=i("el-image"),h=i("image-preview"),b=i("image-wrapper"),_=i("el-button"),E=i("el-tooltip"),m=i("font-awesome-icon"),p=i("copy-to-clipboard"),w=i("el-alert");return a(),n("div",yt,[l("div",wt,[s(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),l("div",Vt,[l("div",At,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),l("span",Gt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Mt,[e.referenceImages.length>0?(a(),n("div",zt,[(a(!0),n(k,null,A(e.referenceImages,(V,z)=>(a(),I(h,{key:z,url:V,name:`image-${z+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(a(),n("p",Tt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),n("span",Lt," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Pt,[l("div",Ct,[(a(!0),n(k,null,A(e.images,(V,z)=>(a(),I(b,{key:z,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),l("div",Ot,[s(E,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[s(_,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=x(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(w,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Ut,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",qt,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Nt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Dt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",jt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Wt,[s(w,{closable:!1,class:"failure"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Bt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Ft,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",Ht,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Zt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",xt,[s(m,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Kt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Xt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(a(),n("div",Jt,[s(w,{closable:!1,class:"info"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Qt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Yt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",es,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",ts,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const os=y(St,[["render",ss],["__scopeId","data-v-87775c45"]]),as=S({name:"RecentPanel",components:{TaskPreview:os,BotPlaceholder:Ie,NoTasks:Se,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),is={key:0},ns={key:2,class:"w-full h-full flex items-center justify-center"};function ls(e,t,c,r,f,v){const d=i("bot-placeholder"),h=i("task-preview"),b=i("scroll-list"),_=i("no-tasks");return a(),n(k,null,[e.tasks?.items===void 0?(a(),n("div",is,[s(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(b,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=E=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),n(k,null,A(e.tasks?.items,E=>(a(),I(h,{key:E.id,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),n("div",ns,[s(_)])):g("",!0)],64)}const rs=y(as,[["render",ls]]),j=le("openaiimage"),ms=S({name:"OpenAIImageIndex",components:{ConfigPanel:It,Layout:Me,RecentPanel:rs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===D.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},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 me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/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.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:j},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:j},f=this.credential?.token;if(!f){console.error("no token specified");return}G.info(this.$t("openaiimage.message.startingTask")),ne("openaiimage",t?N.edit(r,{token:f}):N.generate(c,{token:f})).then(d=>{console.debug("task accepted",d.data?.task_id),G.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===_e?G.error(this.$t("openaiimage.message.usedUp")):G.error(this.$t("openaiimage.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function cs(e,t,c,r,f,v){const d=i("config-panel"),h=i("recent-panel"),b=i("layout");return a(),I(b,null,{config:$(()=>[s(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[s(h,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const so=y(ms,[["render",cs]]);export{so as default};
1
+ import{F as T}from"./index.es-B9yw59kn.js";import{E as L}from"./index-CGJx6pfn.js";import{E as Z}from"./index-CEGyzWWI.js";import{d as S,H as n,E as l,z as O,C as s,y as $,D as i,q as a,F as o,I as u,O as k,N as A,x as I,J as g,M as x,Q as P}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as K,cw as U,cx as X,cy as J,cz as W,cA as M,cB as R,cC as Q,cD as Y,cE as ee,cF as te,cG as se,cH as oe,cI as q,cJ as ae,cK as ie,cr as ne,aY as N,S as D,cs as le}from"./index-B72vsB6D.js";import{I as C,S as re,l as me}from"./pagination-CBYfRJVG.js";import{E as ce}from"./index-CkEMCLbE.js";import{I as B}from"./ImagePreview-CUOTVDKq.js";import{E as ue}from"./index-D-R1uHlt.js";import{E as G}from"./index-0tg1OcXL.js";import{C as pe}from"./Consumption-D9Hn2ImE.js";import{a as de}from"./price-BTNYcVQ5.js";import{E as F,a as H,b as ge}from"./index-DCc5mWT3.js";import{E as he}from"./index-BshjP0UT.js";import{E as fe}from"./index-CeH6helO.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as $e}from"./CopyToClipboard-YKue_6LC.js";import{I as be}from"./ImageWrapper-BTYsRpEP.js";import{E as ve}from"./index-BiORZ5ee.js";import{E as Ee}from"./index-BQYPVVtj.js";import{E as ke}from"./index-BdXdvXDF.js";import{B as Ie}from"./BotPlaceholder-BLqNsw9k.js";import{N as Se}from"./NoTasks-B7fpKwEM.js";import"./use-form-item-Yq9rpjQi.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-DqAqST2T.js";import"./index-B2wj3UbJ.js";import"./index-CYFuwdxJ.js";import"./index-DDjfpPMW.js";import"./_baseClone-CkHqwwjY.js";import"./_Uint8Array-DdojeWiA.js";import"./_initCloneObject-DJHkV8_e.js";import"./isEqual-9RWKK6ZC.js";import"./index-DD1qoXbO.js";import"./strings-beZM2Y-f.js";import"./castArray-PDXtni_G.js";import"./debounce-DLWpM2kv.js";import"./_baseIteratee-BJlOKELK.js";import"./index-Dh2kPrs0.js";import"./index-Cu41y2Fl.js";import"./validator-BOFed1cS.js";import"./index-B5PvIfC4.js";const ye=S({name:"LayoutNanobanana",components:{ElDrawer:Z,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ae={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ge(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-drawer");return a(),n("div",we,[l("div",Ve,[O(e.$slots,"config",{},void 0,!0)]),l("div",Ae,[O(e.$slots,"result",{},void 0,!0)]),s(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=_=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(b,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Me=y(ye,[["render",Ge],["__scopeId","data-v-bfe5cd4b"]]),ze="",Te=S({name:"PromptInput",components:{ElInput:ce,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}}),Le={class:"field"},Pe={class:"box"},Ce={class:"title font-bold"};function Oe(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-input");return a(),n("div",Le,[l("div",Pe,[l("h2",Ce,o(e.$t("openaiimage.name.prompt")),1),s(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),s(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=b=>e.prompt=b),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ue=y(Te,[["render",Oe],["__scopeId","data-v-92f61e4a"]]),Re=S({name:"ImageUrlsInput",components:{ElUpload:ue,ElButton:L,InfoIcon:C,ImagePreview:B,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(f=>!f?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const f=this.fileList.find(v=>v?.response?.file_url===r||v?.url===r);f?t.push(f):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(v=>v===r||v?.url===r?.url||v?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){G.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){G.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),qe={class:"field flex items-center justify-between"},Ne={class:"title font-bold text-[14px] mb-[10px]"},De={class:"upload-wrapper flex flex-col items-start gap-[8px]"},je={class:"controls flex items-center"},We={class:"file-list flex flex-wrap gap-[10px]"};function Be(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-upload"),_=i("info-icon"),E=i("image-preview");return a(),n(k,null,[l("div",qe,[l("h2",Ne,o(e.$t("openaiimage.name.imageUrls")),1),l("div",De,[l("div",je,[s(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[s(h,{size:"small",type:"primary",round:""},{default:$(()=>[s(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(_,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",We,[(a(!0),n(k,null,A(e.fileList,(m,p)=>(a(),I(E,{key:m.uid||m?.response?.file_url||m.url||p,url:m.url||m?.response?.file_url,name:m.name,percentage:m.percentage,onRemove:w=>e.onRemovePreview(p,m)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Fe=y(Re,[["render",Be]]),He=S({name:"OpenAIImageModelSelector",components:{ElSelect:H,ElOption:F,InfoIcon:C},data(){return{options:[{value:X,label:this.$t("openaiimage.model.gptImage1")},{value:J,label:this.$t("openaiimage.model.gptImage15")},{value:W,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ze={class:"field"},xe={class:"label"},Ke={class:"box"},Xe={class:"title font-bold"};function Je(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-select");return a(),n("div",Ze,[l("div",xe,[l("div",Ke,[l("h2",Xe,o(e.$t("openaiimage.name.model")),1),s(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(b,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),n(k,null,A(e.options,_=>(a(),I(h,{key:_.value,label:_.label,value:_.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Qe=y(He,[["render",Je],["__scopeId","data-v-cec771bd"]]);function Ye(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const et=S({name:"OpenAIImageSizeSelector",components:{ElSelect:H,ElOption:F,ElOptionGroup:ge,ElSwitch:fe,ElInputNumber:he,InfoIcon:C},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ae.includes(this.model)},presets(){return q[this.model]??q[U]??[]},presetGroups(){return this.model===W?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:te},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:oe}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??M;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??M},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return ee},minSide(){return Y},maxSide(){return Q},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>R?this.$t("openaiimage.error.customSizePixels",{pixels:R.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??M);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??M)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??M);return}const e=Ye(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),tt={class:"resolution"},st={class:"field"},ot={class:"label"},at={class:"box"},it={class:"title font-bold"},nt={class:"field custom-toggle"},lt={class:"label"},rt={class:"box"},mt={class:"title font-bold"},ct={key:0,class:"custom-inputs"},ut={class:"row"},pt={class:"row-label"},dt={class:"row"},gt={class:"row-label"},ht={key:0,class:"error"};function ft(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-option-group"),_=i("el-select"),E=i("el-switch"),m=i("el-input-number");return a(),n("div",tt,[l("div",st,[l("div",ot,[l("div",at,[l("h2",it,o(e.$t("openaiimage.name.size")),1),s(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(_,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=p=>e.presetValue=p),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:$(()=>[(a(!0),n(k,null,A(e.presetGroups,p=>(a(),I(b,{key:p.label,label:p.label},{default:$(()=>[(a(!0),n(k,null,A(p.options,w=>(a(),I(h,{key:w,label:w,value:w},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(k,{key:0},[l("div",nt,[l("div",lt,[l("div",rt,[l("h2",mt,o(e.$t("openaiimage.name.customSize")),1),s(d,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(E,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=p=>e.useCustom=p),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ct,[l("div",ut,[l("span",pt,o(e.$t("openaiimage.name.width")),1),s(m,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=p=>e.customWidth=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),l("div",dt,[l("span",gt,o(e.$t("openaiimage.name.height")),1),s(m,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=p=>e.customHeight=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",ht,o(e.customError),1)):g("",!0)])):g("",!0)],64)):g("",!0)])}const _t=y(et,[["render",ft],["__scopeId","data-v-218b58cb"]]),$t=S({name:"ConfigPanel",components:{ElButton:L,FontAwesomeIcon:T,PromptInput:Ue,Consumption:pe,ImageUrlsInput:Fe,ModelSelector:Qe,ResolutionSelector:_t},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return de({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},vt={class:"flex-1 overflow-y-auto p-5"},Et={class:"flex flex-col items-center justify-center px-5 pb-5"};function kt(e,t,c,r,f,v){const d=i("model-selector"),h=i("resolution-selector"),b=i("prompt-input"),_=i("image-urls-input"),E=i("consumption"),m=i("font-awesome-icon"),p=i("el-button");return a(),n("div",bt,[l("div",vt,[s(d,{class:"mb-4"}),s(h,{class:"mb-4"}),s(b,{class:"mb-4"}),s(_,{class:"mb-4"})]),l("div",Et,[s(E,{value:e.consumption,service:e.service},null,8,["value","service"]),s(p,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(m,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const It=y($t,[["render",kt]]),St=S({name:"TaskPreview",components:{ElImage:ke,CopyToClipboard:$e,FontAwesomeIcon:T,ElAlert:Ee,ImageWrapper:be,ElButton:L,ElTooltip:ve,ImagePreview:B},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ie}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),yt={class:"preview"},wt={class:"left"},Vt={class:"main"},At={class:"bot"},Gt={class:"datetime"},Mt={class:"info"},zt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Tt={key:1,class:"prompt mt-2"},Lt={key:0},Pt={key:0,class:P({content:!0,failed:!0})},Ct={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ot={class:P({operations:!0,"mt-2":!0,"mb-2":!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Wt={key:1,class:P({content:!0})},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Jt={key:2,class:P({content:!0})},Qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},es={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function ss(e,t,c,r,f,v){const d=i("el-image"),h=i("image-preview"),b=i("image-wrapper"),_=i("el-button"),E=i("el-tooltip"),m=i("font-awesome-icon"),p=i("copy-to-clipboard"),w=i("el-alert");return a(),n("div",yt,[l("div",wt,[s(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),l("div",Vt,[l("div",At,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),l("span",Gt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Mt,[e.referenceImages.length>0?(a(),n("div",zt,[(a(!0),n(k,null,A(e.referenceImages,(V,z)=>(a(),I(h,{key:z,url:V,name:`image-${z+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(a(),n("p",Tt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),n("span",Lt," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Pt,[l("div",Ct,[(a(!0),n(k,null,A(e.images,(V,z)=>(a(),I(b,{key:z,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),l("div",Ot,[s(E,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[s(_,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=x(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(w,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Ut,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",qt,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Nt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Dt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",jt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Wt,[s(w,{closable:!1,class:"failure"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Bt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Ft,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",Ht,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Zt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",xt,[s(m,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Kt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Xt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(a(),n("div",Jt,[s(w,{closable:!1,class:"info"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Qt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Yt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",es,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",ts,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const os=y(St,[["render",ss],["__scopeId","data-v-87775c45"]]),as=S({name:"RecentPanel",components:{TaskPreview:os,BotPlaceholder:Ie,NoTasks:Se,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),is={key:0},ns={key:2,class:"w-full h-full flex items-center justify-center"};function ls(e,t,c,r,f,v){const d=i("bot-placeholder"),h=i("task-preview"),b=i("scroll-list"),_=i("no-tasks");return a(),n(k,null,[e.tasks?.items===void 0?(a(),n("div",is,[s(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(b,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=E=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),n(k,null,A(e.tasks?.items,E=>(a(),I(h,{key:E.id,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),n("div",ns,[s(_)])):g("",!0)],64)}const rs=y(as,[["render",ls]]),j=le("openaiimage"),ms=S({name:"OpenAIImageIndex",components:{ConfigPanel:It,Layout:Me,RecentPanel:rs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===D.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},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 me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/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.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:j},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:j},f=this.credential?.token;if(!f){console.error("no token specified");return}G.info(this.$t("openaiimage.message.startingTask")),ne("openaiimage",t?N.edit(r,{token:f}):N.generate(c,{token:f})).then(d=>{console.debug("task accepted",d.data?.task_id),G.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===_e?G.error(this.$t("openaiimage.message.usedUp")):G.error(this.$t("openaiimage.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function cs(e,t,c,r,f,v){const d=i("config-panel"),h=i("recent-panel"),b=i("layout");return a(),I(b,null,{config:$(()=>[s(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[s(h,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const so=y(ms,[["render",cs]]);export{so as default};
@@ -1 +1 @@
1
- import{F as L}from"./index.es-DoDsyBxd.js";import{E as C}from"./index-CghmaEfO.js";import{E as N}from"./index-BRqPnPCL.js";import{d as b,H as r,E as i,z as U,C as o,y as u,D as s,q as a,F as l,O as V,N as A,x as y,Q as I,R as q,I as h,J as $,G as K,L as W}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as H,cr as Z,aL as J,S as G,cs as Q}from"./index-Bwh4uhxH.js";import{a as P,b as z,c as S,d as M,e as Y,f as X,g as x,h as ee,i as te}from"./sora-Dyuoglk1.js";import{E as D,a as R}from"./index-Bs4QQKmj.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as F,S as se,l as ae}from"./pagination-DuUw6h7L.js";import{I as ne}from"./ImagePreview-Bdb0i-UY.js";import{E as le}from"./index-CZoz3sTY.js";import{E as T}from"./index-CD3hMCXK.js";import{C as re}from"./Consumption-DTqKtl19.js";import{E as ie}from"./index-Df-EZV4-.js";import{a as ce}from"./price-Dq6B3nmI.js";import{b as de}from"./errorCode-Cqj9Td_Z.js";import{C as ue}from"./CopyToClipboard-CHIfP83C.js";import{V as pe}from"./VideoPlayer-Cy3-ZAWg.js";import{E as me}from"./index-CdNNDZgX.js";import{E as fe}from"./index-CLC3F3zh.js";import{E as _e}from"./index-Cdu2CINy.js";import{B as he}from"./BotPlaceholder-teJQgw1R.js";import{N as $e}from"./NoTasks-Dro6OdxD.js";import"./use-form-item-CkUvjro6.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-Boh3hilg.js";import"./typescript-C7vXUz1j.js";import"./index-CWWZeClw.js";import"./strings-beZM2Y-f.js";import"./isEqual-CgVTCLh1.js";import"./_Uint8Array-JndvkAwf.js";import"./castArray-BzRYTmyg.js";import"./debounce-D7YINRDE.js";import"./_baseIteratee-BaTk7Xco.js";import"./index-Dy5k6Duv.js";import"./index-DSAaysXY.js";import"./_baseClone-BywLfCY-.js";import"./_initCloneObject-D5P_u5bs.js";import"./index-nLjkUfZa.js";import"./vue-plyr-BO2nlN4c.js";import"./index-ByGJSI5C.js";const ge=b({name:"LayoutSora",components:{ElDrawer:N,ElButton:C,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ve={class:"main flex flex-row flex-1"},be={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ke={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function we(e,t,p,m,g,v){const c=s("font-awesome-icon"),d=s("el-button"),n=s("el-drawer");return a(),r("div",ve,[i("div",be,[U(e.$slots,"config",{},void 0,!0)]),i("div",ke,[U(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=w=>e.drawer=!0)},{default:u(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ye=k(ge,[["render",we],["__scopeId","data-v-2dca3c13"]]),Se=b({name:"ModelSelector",components:{ElSelect:R,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:Y,label:"sora-2"},{value:X,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},p=z[e]||[S],m=t.duration,g=m&&p.includes(m)?m:p.includes(S)?S:p[0],v={...t,model:e,duration:g,size:t.size||M};this.$store.commit("sora/setConfig",v)}}},mounted(){this.value||(this.value=P)}}),Ve={class:"field"},Ee={class:"title font-bold"};function Te(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Ve,[i("h2",Ee,l(e.$t("sora.name.model")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=k(Se,[["render",Te],["__scopeId","data-v-0cb7913d"]]),Ae=b({name:"ActionSelector",components:{ElSelect:R,ElOption:D},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=x)}}),Le={class:"field"},Ce={class:"title font-bold"},De={class:"float-left"};function Re(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Le,[i("h2",Ce,l(e.$t("sora.name.action")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},{default:u(()=>[i("span",De,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Oe=k(Ae,[["render",Re],["__scopeId","data-v-7b82fa7f"]]),Ue=b({name:"DurationSelector",components:{ElSelect:R,ElOption:D},computed:{model(){return this.$store.state.sora?.config?.model||P},allowedDurations(){return z[this.model]||[S]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(S)?S:e[0];this.value=t}}},mounted(){this.value||(this.value=S)}}),Ge={class:"field"},Pe={class:"control"},ze={class:"title font-bold"};function Me(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Ge,[i("div",Pe,[i("h2",ze,l(e.$t("sora.name.duration")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.optionsForModel,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const Fe=k(Ue,[["render",Me],["__scopeId","data-v-c2934598"]]),Be=b({name:"OrientationSelector",data(){return{options:[{value:"portrait",labelKey:"sora.option.portrait",width:13,height:25},{value:"landscape",labelKey:"sora.option.landscape",width:25,height:13}]}},computed:{active(){const e=this.options.findIndex(t=>t.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=ee)}}),je={class:"text-sm font-bold mb-2 block"},Ne={class:"items"},qe=["onClick"],Ke={class:"name"};function We(e,t,p,m,g,v){return a(),r("div",null,[i("span",je,l(e.$t("sora.name.orientation")),1),i("div",Ne,[(a(!0),r(V,null,A(e.options,(c,d)=>(a(),r("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:n=>e.value=c.value},[i("div",{class:I(["preview",c.value])},[i("div",{class:"rect",style:q({width:c.width+"px",height:c.height+"px"})},null,4)],2),i("p",Ke,l(e.$t(c.labelKey)),1)],10,qe))),128))])])}const He=k(Be,[["render",We],["__scopeId","data-v-a20be6d9"]]),Ze=b({name:"StartEndImage",components:{ElUpload:le,ElButton:C,InfoIcon:F,FontAwesomeIcon:L,ImagePreview:ne},mixins:[oe],emits:["change"],data(){return{fileList:[],uploadUrl:H()+"/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?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){T.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){T.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Je={class:"relative"},Qe={class:"flex justify-between"},Ye={class:"flex justify-start items-center"},Xe={class:"text-sm font-bold"};function xe(e,t,p,m,g,v){const c=s("info-icon"),d=s("image-preview"),n=s("font-awesome-icon"),w=s("el-button"),_=s("el-upload");return a(),r("div",Je,[i("div",Qe,[i("div",Ye,[i("span",Xe,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(_,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),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:u(({file:f})=>[f.url&&f.percentage!==void 0?(a(),y(d,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:u(()=>[o(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const et=k(Ze,[["render",xe],["__scopeId","data-v-a942382b"]]),tt=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),ot=b({name:"SizeSelector",components:{ElSelect:R,ElOption:D},data(){return{options:te.map(e=>({value:e,label:tt(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=M)}}),st={class:"field"},at={class:"control"},nt={class:"title font-bold"};function lt(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",st,[i("div",at,[i("h2",nt,l(e.$t("sora.name.size")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const rt=k(ot,[["render",lt],["__scopeId","data-v-8c485f0f"]]),it="",ct=b({name:"PromptInput",components:{ElInput:ie,InfoIcon:F},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=it)}}),dt={class:"field"},ut={class:"box"},pt={class:"title font-bold"};function mt(e,t,p,m,g,v){const c=s("info-icon"),d=s("el-input");return a(),r("div",dt,[i("div",ut,[i("h2",pt,l(e.$t("sora.name.prompt")),1),o(c,{content:e.$t("sora.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("sora.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ft=k(ct,[["render",mt],["__scopeId","data-v-a57633d5"]]),_t=b({name:"ConfigPanel",components:{ElButton:C,Consumption:re,FontAwesomeIcon:L,PromptInput:ft,ModelSelector:Ie,StartEndImage:et,SizeSelector:rt,ActionSelector:Oe,OrientationSelector:He,DurationSelector:Fe},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ht={class:"flex flex-col h-full"},$t={class:"flex-1 overflow-y-auto p-5"},gt={class:"flex flex-col items-center justify-center px-5 pb-5"};function vt(e,t,p,m,g,v){const c=s("model-selector"),d=s("action-selector"),n=s("duration-selector"),w=s("size-selector"),_=s("orientation-selector"),f=s("prompt-input"),E=s("start-end-image"),O=s("consumption"),B=s("font-awesome-icon"),j=s("el-button");return a(),r("div",ht,[i("div",$t,[o(c,{class:"mb-4"}),o(d,{class:"mb-4"}),o(n,{class:"mb-4"}),o(w,{class:"mb-4"}),o(_,{class:"mb-4"}),o(f,{class:"mb-4"}),K(o(E,{class:"mb-2"},null,512),[[W,e.config?.action==="image2video"]])]),i("div",gt,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),o(j,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[o(B,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const bt=k(_t,[["render",vt]]),kt=b({name:"TaskPreview",components:{ElImage:_e,CopyToClipboard:ue,FontAwesomeIcon:L,ElAlert:fe,VideoPlayer:pe,ElTooltip:me,ElButton:C},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),wt={class:"preview"},yt={class:"left"},St={class:"main"},Vt={class:"bot"},Et={class:"datetime"},Tt={class:"info"},It={key:0,class:"prompt mt-2"},At={key:0},Lt={key:1},Ct={key:0,class:I({content:!0,failed:!0})},Dt={key:0,class:"mb-4"},Rt={key:1,class:I({operations:!0,"mt-2":!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Pt={key:1,class:I({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={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"},jt={key:2,class:I({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Kt(e,t,p,m,g,v){const c=s("el-image"),d=s("video-player"),n=s("el-button"),w=s("el-tooltip"),_=s("font-awesome-icon"),f=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",wt,[i("div",yt,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),i("div",St,[i("div",Vt,[h(l(e.$t("sora.name.soraBot"))+" ",1),i("span",Et,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",Tt,[e.modelValue?.request?.prompt?(a(),r("p",It,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(a(),r("span",At," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(a(),r("span",Lt," - ("+l(e.$t("sora.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Ct,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Dt,[o(d,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):$("",!0),e.modelValue?.response.success?(a(),r("div",Rt,[o(w,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),y(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=O=>e.onDownload(O,e.modelValue?.response?.data[0]?.video_url))},{default:u(()=>[h(l(e.$t("sora.button.download")),1)]),_:1})):$("",!0)]),_:1},8,["content"])])):$("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[i("p",Ot,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),i("p",Ut,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Gt,[o(_,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Pt,[o(E,{closable:!1,class:"failure"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[i("p",zt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),i("p",Mt,[o(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(f,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Ft,[o(_,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):$("",!0),e.modelValue?.response?.trace_id?(a(),r("p",Bt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===void 0?(a(),r("div",jt,[o(E,{closable:!1,class:"info"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[i("p",Nt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",qt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0)])])}const Wt=k(kt,[["render",Kt],["__scopeId","data-v-fa5225eb"]]),Ht=b({name:"RecentPanel",components:{TaskPreview:Wt,NoTasks:$e,BotPlaceholder:he,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Zt={key:0},Jt={key:2,class:"w-full h-full flex items-center justify-center"};function Qt(e,t,p,m,g,v){const c=s("bot-placeholder"),d=s("task-preview"),n=s("scroll-list"),w=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Zt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),y(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(V,null,A(e.tasks?.items,(_,f)=>(a(),y(d,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):$("",!0),e.tasks?.items?.length===0?(a(),r("div",Jt,[o(w)])):$("",!0)],64)}const Yt=k(Ht,[["render",Qt]]),Xt=Q("sora"),xt=b({name:"SoraIndex",components:{ConfigPanel:bt,Layout:ye,RecentPanel:Yt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.tasks}},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 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("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/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:t=5,createdAtMin:p,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:p,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Xt},t=this.credential?.token;if(!t){console.error("no token specified");return}T.info(this.$t("sora.message.startingTask")),Z("sora",J.generate(e,{token:t})).then(()=>{T.success(this.$t("sora.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===de?T.error(this.$t("sora.message.usedUp")):T.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function eo(e,t,p,m,g,v){const c=s("config-panel"),d=s("recent-panel"),n=s("layout");return a(),y(n,null,{config:u(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Wo=k(xt,[["render",eo]]);export{Wo as default};
1
+ import{F as L}from"./index.es-B9yw59kn.js";import{E as C}from"./index-CGJx6pfn.js";import{E as N}from"./index-CEGyzWWI.js";import{d as b,H as r,E as i,z as U,C as o,y as u,D as s,q as a,F as l,O as V,N as A,x as y,Q as I,R as q,I as h,J as $,G as K,L as W}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as H,cr as Z,aL as J,S as G,cs as Q}from"./index-B72vsB6D.js";import{a as P,b as z,c as S,d as M,e as Y,f as X,g as x,h as ee,i as te}from"./sora-Dyuoglk1.js";import{E as D,a as R}from"./index-DCc5mWT3.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as F,S as se,l as ae}from"./pagination-CBYfRJVG.js";import{I as ne}from"./ImagePreview-CUOTVDKq.js";import{E as le}from"./index-D-R1uHlt.js";import{E as T}from"./index-0tg1OcXL.js";import{C as re}from"./Consumption-D9Hn2ImE.js";import{E as ie}from"./index-CkEMCLbE.js";import{a as ce}from"./price-BTNYcVQ5.js";import{b as de}from"./errorCode-Cqj9Td_Z.js";import{C as ue}from"./CopyToClipboard-YKue_6LC.js";import{V as pe}from"./VideoPlayer-DPmqjyk_.js";import{E as me}from"./index-BiORZ5ee.js";import{E as fe}from"./index-BQYPVVtj.js";import{E as _e}from"./index-BdXdvXDF.js";import{B as he}from"./BotPlaceholder-BLqNsw9k.js";import{N as $e}from"./NoTasks-B7fpKwEM.js";import"./use-form-item-Yq9rpjQi.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-DD1qoXbO.js";import"./typescript-DqAqST2T.js";import"./index-B2wj3UbJ.js";import"./strings-beZM2Y-f.js";import"./isEqual-9RWKK6ZC.js";import"./_Uint8Array-DdojeWiA.js";import"./castArray-PDXtni_G.js";import"./debounce-DLWpM2kv.js";import"./_baseIteratee-BJlOKELK.js";import"./index-Dh2kPrs0.js";import"./index-DDjfpPMW.js";import"./_baseClone-CkHqwwjY.js";import"./_initCloneObject-DJHkV8_e.js";import"./index-CYFuwdxJ.js";import"./vue-plyr-BO2nlN4c.js";import"./index-B5PvIfC4.js";const ge=b({name:"LayoutSora",components:{ElDrawer:N,ElButton:C,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ve={class:"main flex flex-row flex-1"},be={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ke={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function we(e,t,p,m,g,v){const c=s("font-awesome-icon"),d=s("el-button"),n=s("el-drawer");return a(),r("div",ve,[i("div",be,[U(e.$slots,"config",{},void 0,!0)]),i("div",ke,[U(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=w=>e.drawer=!0)},{default:u(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ye=k(ge,[["render",we],["__scopeId","data-v-2dca3c13"]]),Se=b({name:"ModelSelector",components:{ElSelect:R,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:Y,label:"sora-2"},{value:X,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},p=z[e]||[S],m=t.duration,g=m&&p.includes(m)?m:p.includes(S)?S:p[0],v={...t,model:e,duration:g,size:t.size||M};this.$store.commit("sora/setConfig",v)}}},mounted(){this.value||(this.value=P)}}),Ve={class:"field"},Ee={class:"title font-bold"};function Te(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Ve,[i("h2",Ee,l(e.$t("sora.name.model")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=k(Se,[["render",Te],["__scopeId","data-v-0cb7913d"]]),Ae=b({name:"ActionSelector",components:{ElSelect:R,ElOption:D},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=x)}}),Le={class:"field"},Ce={class:"title font-bold"},De={class:"float-left"};function Re(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Le,[i("h2",Ce,l(e.$t("sora.name.action")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},{default:u(()=>[i("span",De,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Oe=k(Ae,[["render",Re],["__scopeId","data-v-7b82fa7f"]]),Ue=b({name:"DurationSelector",components:{ElSelect:R,ElOption:D},computed:{model(){return this.$store.state.sora?.config?.model||P},allowedDurations(){return z[this.model]||[S]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(S)?S:e[0];this.value=t}}},mounted(){this.value||(this.value=S)}}),Ge={class:"field"},Pe={class:"control"},ze={class:"title font-bold"};function Me(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",Ge,[i("div",Pe,[i("h2",ze,l(e.$t("sora.name.duration")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.optionsForModel,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const Fe=k(Ue,[["render",Me],["__scopeId","data-v-c2934598"]]),Be=b({name:"OrientationSelector",data(){return{options:[{value:"portrait",labelKey:"sora.option.portrait",width:13,height:25},{value:"landscape",labelKey:"sora.option.landscape",width:25,height:13}]}},computed:{active(){const e=this.options.findIndex(t=>t.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=ee)}}),je={class:"text-sm font-bold mb-2 block"},Ne={class:"items"},qe=["onClick"],Ke={class:"name"};function We(e,t,p,m,g,v){return a(),r("div",null,[i("span",je,l(e.$t("sora.name.orientation")),1),i("div",Ne,[(a(!0),r(V,null,A(e.options,(c,d)=>(a(),r("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:n=>e.value=c.value},[i("div",{class:I(["preview",c.value])},[i("div",{class:"rect",style:q({width:c.width+"px",height:c.height+"px"})},null,4)],2),i("p",Ke,l(e.$t(c.labelKey)),1)],10,qe))),128))])])}const He=k(Be,[["render",We],["__scopeId","data-v-a20be6d9"]]),Ze=b({name:"StartEndImage",components:{ElUpload:le,ElButton:C,InfoIcon:F,FontAwesomeIcon:L,ImagePreview:ne},mixins:[oe],emits:["change"],data(){return{fileList:[],uploadUrl:H()+"/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?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){T.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){T.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Je={class:"relative"},Qe={class:"flex justify-between"},Ye={class:"flex justify-start items-center"},Xe={class:"text-sm font-bold"};function xe(e,t,p,m,g,v){const c=s("info-icon"),d=s("image-preview"),n=s("font-awesome-icon"),w=s("el-button"),_=s("el-upload");return a(),r("div",Je,[i("div",Qe,[i("div",Ye,[i("span",Xe,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(_,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),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:u(({file:f})=>[f.url&&f.percentage!==void 0?(a(),y(d,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:u(()=>[o(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const et=k(Ze,[["render",xe],["__scopeId","data-v-a942382b"]]),tt=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),ot=b({name:"SizeSelector",components:{ElSelect:R,ElOption:D},data(){return{options:te.map(e=>({value:e,label:tt(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=M)}}),st={class:"field"},at={class:"control"},nt={class:"title font-bold"};function lt(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return a(),r("div",st,[i("div",at,[i("h2",nt,l(e.$t("sora.name.size")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(a(!0),r(V,null,A(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const rt=k(ot,[["render",lt],["__scopeId","data-v-8c485f0f"]]),it="",ct=b({name:"PromptInput",components:{ElInput:ie,InfoIcon:F},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=it)}}),dt={class:"field"},ut={class:"box"},pt={class:"title font-bold"};function mt(e,t,p,m,g,v){const c=s("info-icon"),d=s("el-input");return a(),r("div",dt,[i("div",ut,[i("h2",pt,l(e.$t("sora.name.prompt")),1),o(c,{content:e.$t("sora.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("sora.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ft=k(ct,[["render",mt],["__scopeId","data-v-a57633d5"]]),_t=b({name:"ConfigPanel",components:{ElButton:C,Consumption:re,FontAwesomeIcon:L,PromptInput:ft,ModelSelector:Ie,StartEndImage:et,SizeSelector:rt,ActionSelector:Oe,OrientationSelector:He,DurationSelector:Fe},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ht={class:"flex flex-col h-full"},$t={class:"flex-1 overflow-y-auto p-5"},gt={class:"flex flex-col items-center justify-center px-5 pb-5"};function vt(e,t,p,m,g,v){const c=s("model-selector"),d=s("action-selector"),n=s("duration-selector"),w=s("size-selector"),_=s("orientation-selector"),f=s("prompt-input"),E=s("start-end-image"),O=s("consumption"),B=s("font-awesome-icon"),j=s("el-button");return a(),r("div",ht,[i("div",$t,[o(c,{class:"mb-4"}),o(d,{class:"mb-4"}),o(n,{class:"mb-4"}),o(w,{class:"mb-4"}),o(_,{class:"mb-4"}),o(f,{class:"mb-4"}),K(o(E,{class:"mb-2"},null,512),[[W,e.config?.action==="image2video"]])]),i("div",gt,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),o(j,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[o(B,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const bt=k(_t,[["render",vt]]),kt=b({name:"TaskPreview",components:{ElImage:_e,CopyToClipboard:ue,FontAwesomeIcon:L,ElAlert:fe,VideoPlayer:pe,ElTooltip:me,ElButton:C},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),wt={class:"preview"},yt={class:"left"},St={class:"main"},Vt={class:"bot"},Et={class:"datetime"},Tt={class:"info"},It={key:0,class:"prompt mt-2"},At={key:0},Lt={key:1},Ct={key:0,class:I({content:!0,failed:!0})},Dt={key:0,class:"mb-4"},Rt={key:1,class:I({operations:!0,"mt-2":!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Pt={key:1,class:I({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={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"},jt={key:2,class:I({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Kt(e,t,p,m,g,v){const c=s("el-image"),d=s("video-player"),n=s("el-button"),w=s("el-tooltip"),_=s("font-awesome-icon"),f=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",wt,[i("div",yt,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),i("div",St,[i("div",Vt,[h(l(e.$t("sora.name.soraBot"))+" ",1),i("span",Et,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",Tt,[e.modelValue?.request?.prompt?(a(),r("p",It,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(a(),r("span",At," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(a(),r("span",Lt," - ("+l(e.$t("sora.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Ct,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Dt,[o(d,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):$("",!0),e.modelValue?.response.success?(a(),r("div",Rt,[o(w,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),y(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=O=>e.onDownload(O,e.modelValue?.response?.data[0]?.video_url))},{default:u(()=>[h(l(e.$t("sora.button.download")),1)]),_:1})):$("",!0)]),_:1},8,["content"])])):$("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[i("p",Ot,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),i("p",Ut,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Gt,[o(_,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Pt,[o(E,{closable:!1,class:"failure"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[i("p",zt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),i("p",Mt,[o(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(f,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Ft,[o(_,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):$("",!0),e.modelValue?.response?.trace_id?(a(),r("p",Bt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===void 0?(a(),r("div",jt,[o(E,{closable:!1,class:"info"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[i("p",Nt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",qt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0)])])}const Wt=k(kt,[["render",Kt],["__scopeId","data-v-fa5225eb"]]),Ht=b({name:"RecentPanel",components:{TaskPreview:Wt,NoTasks:$e,BotPlaceholder:he,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Zt={key:0},Jt={key:2,class:"w-full h-full flex items-center justify-center"};function Qt(e,t,p,m,g,v){const c=s("bot-placeholder"),d=s("task-preview"),n=s("scroll-list"),w=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Zt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),y(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(V,null,A(e.tasks?.items,(_,f)=>(a(),y(d,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):$("",!0),e.tasks?.items?.length===0?(a(),r("div",Jt,[o(w)])):$("",!0)],64)}const Yt=k(Ht,[["render",Qt]]),Xt=Q("sora"),xt=b({name:"SoraIndex",components:{ConfigPanel:bt,Layout:ye,RecentPanel:Yt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.tasks}},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 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("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/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:t=5,createdAtMin:p,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:p,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Xt},t=this.credential?.token;if(!t){console.error("no token specified");return}T.info(this.$t("sora.message.startingTask")),Z("sora",J.generate(e,{token:t})).then(()=>{T.success(this.$t("sora.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===de?T.error(this.$t("sora.message.usedUp")):T.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function eo(e,t,p,m,g,v){const c=s("config-panel"),d=s("recent-panel"),n=s("layout");return a(),y(n,null,{config:u(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Wo=k(xt,[["render",eo]]);export{Wo as default};
@@ -1 +1 @@
1
- import{F as D}from"./index.es-DoDsyBxd.js";import{E as W}from"./index-CghmaEfO.js";import{E as se}from"./index-BRqPnPCL.js";import{d as b,H as c,E as o,z as O,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 U,G as R,K as H,M as P,u as A,c as T,w as ne,L as re}from"./vendor-vue-NSDaktjZ.js";import{G as V,bl as ie,ez as X,eA as Y,X as K,J as ae,S as L,cs as te,eB as Z,eC as le,cr as ce,n as de}from"./index-Bwh4uhxH.js";import{a as ue}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-CI1GeNU0.js";import{b as pe}from"./producer-DP85fuAq.js";import{E as me}from"./index-DDM_letT.js";import{E as fe,a as he}from"./index-Bs4QQKmj.js";import{I as F,S as _e,l as $e}from"./pagination-DuUw6h7L.js";import{E as ge}from"./index-CZoz3sTY.js";import{E as w}from"./index-CD3hMCXK.js";import{E as z}from"./index-Df-EZV4-.js";import{u as j,F as ve,O as ye,_ as ee,P as ke,a as be,V as we,E as Ce}from"./IconPark.vue_vue_type_script_setup_true_lang-ChnszgHA.js";import{E as Q}from"./index-udv8oHBR.js";import{E as N}from"./index-Cdu2CINy.js";import{E as Ve,a as Se}from"./index-BipWEOw7.js";import{E as x}from"./index-Biwor0fW.js";import{E as Ue,a as Ee}from"./index-MJt9uRMV.js";import{C as Pe}from"./Consumption-DTqKtl19.js";import{a as Ae}from"./price-Dq6B3nmI.js";import{E as Te,b as Fe,a as Ie}from"./index-DG93bVkv.js";import{E as Le}from"./index-CdNNDZgX.js";import{E as Ge}from"./index-D8r95ZCp.js";import{N as je}from"./NoTasks-Dro6OdxD.js";import{a as De,E as Re}from"./index-ByGJSI5C.js";import"./use-form-item-CkUvjro6.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-BYlyQQaq.js";import"./index-CWWZeClw.js";import"./index-Boh3hilg.js";import"./typescript-C7vXUz1j.js";import"./strings-beZM2Y-f.js";import"./isEqual-CgVTCLh1.js";import"./_Uint8Array-JndvkAwf.js";import"./castArray-BzRYTmyg.js";import"./debounce-D7YINRDE.js";import"./_baseIteratee-BaTk7Xco.js";import"./index-Dy5k6Duv.js";import"./index-DSAaysXY.js";import"./_baseClone-BywLfCY-.js";import"./_initCloneObject-D5P_u5bs.js";import"./index-nLjkUfZa.js";import"./index-Cu41y2Fl.js";import"./index-CAOsMXTW.js";import"./dropdown-B9aMQjZh.js";const Ze=b({name:"LayoutProducer",components:{ElDrawer:se,ElButton:W,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),ze={class:"main flex flex-row flex-1"},Ne={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Me={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Be={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",Ne,[O(e.$slots,"config",{},void 0,!0)]),o("div",Me,[O(e.$slots,"result",{},void 0,!0)]),o("div",Be,[O(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(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const qe=V(Ze,[["render",Oe],["__scopeId","data-v-7453886f"]]),We=b({name:"TypeSelector",components:{ElSelect:he,ElOption:fe,ElSwitch:me},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=pe)}}),He={class:"flex items-center justify-between mb-3"},Ke={class:"text-sm font-bold"},Je={class:"mb-3"},Xe={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)]"},et={key:0,class:"flex items-center justify-between mb-3"},tt={class:"text-sm font-bold"};function ot(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",He,[o("span",Ke,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",Je,[o("div",Xe,[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",et,[o("span",tt,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 st=V(We,[["render",ot]]),nt=b({name:"UploadAudio",components:{ElUpload:ge,ElButton:W,InfoIcon:F,FontAwesomeIcon:D},emits:["change"],data(){return{fileList:[],uploadUrl:ie()+"/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(){}}}),rt={class:"relative"},it={class:"flex justify-between"},at={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function ct(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",rt,[o("div",it,[o("div",at,[o("span",lt,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"}),U(" "+a(e.$t("producer.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const dt=V(nt,[["render",ct],["__scopeId","data-v-e4cd0467"]]),ut="",pt=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=ut)}}),mt={class:"field"},ft={class:"flex items-center mb-1"},ht={class:"text-sm font-bold"};function _t(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",mt,[o("div",ft,[o("span",ht,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(pt,[["render",_t]]),gt="",vt=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=gt)},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}}}}),yt={class:"field"},kt={class:"flex items-center justify-between mb-1"},bt={class:"flex items-center"},wt={class:"text-sm font-bold"};function Ct(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",yt,[o("div",kt,[o("div",bt,[o("span",wt,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"})),U(" "+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 Vt=V(vt,[["render",Ct],["__scopeId","data-v-88c6da2b"]]),St=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})}}}}),Ut={class:"field"},Et={class:"flex items-center justify-between mb-1"},Pt={class:"flex items-center"},At={class:"text-sm font-bold"};function Tt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",Ut,[o("div",Et,[o("div",Pt,[o("span",At,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 Ft=V(St,[["render",Tt]]),It=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})}}}}),Lt={class:"field"},Gt={class:"flex items-center mb-1"},jt={class:"text-sm font-bold"};function Dt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",Lt,[o("div",Gt,[o("span",jt,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 Rt=V(It,[["render",Dt]]),Zt=b({name:"ExtendFromInput",components:{ElImage:N,ElIcon:K,ElInputNumber:Q,VideoPlay:Y,VideoPause:X},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"},Nt={class:"box"},Mt={class:"title font-bold"},Bt={class:"input-wrapper"},Ot={class:"task"},qt={class:"left"},Wt={key:2,class:"duration"},Ht={class:"info"},Kt={class:"title"},Jt={class:"style"};function Xt(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",Nt,[o("h2",Mt,a(e.$t("producer.name.extend")),1),o("div",Bt,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=E=>e.value=E),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]=E=>e.onClick(e.audio))},[R((n(),c("div",qt,[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]=E=>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]=E=>e.onPlay(e.audio))},[s($,null,{default:d(()=>[s(k)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",Wt,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[y,!e.audio?.audio_url]]),o("div",Ht,[o("h2",Kt,a(e.audio?.title),1),o("p",Jt,a(e.audio?.style),1)])])):f("",!0)])])}const Yt=V(Zt,[["render",Xt],["__scopeId","data-v-26d43480"]]),Qt=b({name:"CoverFromInput",components:{ElImage:N,ElIcon:K,VideoPlay:Y,VideoPause:X},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"},eo={class:"box"},to={class:"title font-bold"},oo={class:"task"},so={class:"left"},no={key:2,class:"duration"},ro={class:"info"},io={class:"title"},ao={class:"style"};function lo(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",eo,[o("h2",to,a(e.$t("producer.name.cover")),1)]),o("div",oo,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=y=>e.onClick(e.audio))},[R((n(),c("div",so,[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",no,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[k,!e.audio?.audio_url]]),o("div",ro,[o("h2",io,a(e.audio?.title),1),o("p",ao,a(e.audio?.style),1)])])):f("",!0)])])}const co=V(Qt,[["render",lo],["__scopeId","data-v-d8a8e583"]]),uo=b({name:"VocalGenderSelector",components:{ElRadioGroup:Se,ElRadioButton:Ve,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})}}}}),po={class:"mb-2"},mo={class:"flex items-center mb-1"},fo={class:"text-sm font-bold"};function ho(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-radio-button"),_=r("el-radio-group");return n(),c("div",po,[o("div",mo,[o("span",fo,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(()=>[U(a(e.$t("producer.gender.auto")),1)]),_:1}),s(m,{value:"f"},{default:d(()=>[U(a(e.$t("producer.gender.female")),1)]),_:1}),s(m,{value:"m"},{default:d(()=>[U(a(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const _o=V(uo,[["render",ho]]),$o=b({name:"AdvancedParams",components:{ElCollapse:Ee,ElCollapseItem:Ue,ElInput:z,ElSlider:x,ElInputNumber:Q},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})}}}}),go={key:0,class:"mb-3"},vo={class:"flex items-center mb-1"},yo={class:"text-xs font-bold"},ko={key:1,class:"mb-3"},bo={class:"flex items-center mb-1"},wo={class:"text-xs font-bold"},Co={key:2,class:"mb-3"},Vo={class:"flex items-center justify-between mb-1"},So={class:"text-xs font-bold"},Uo={class:"text-xs text-[var(--el-text-color-secondary)]"},Eo={key:3,class:"mb-3"},Po={class:"flex items-center justify-between mb-1"},Ao={class:"text-xs font-bold"},To={class:"text-xs text-[var(--el-text-color-secondary)]"},Fo={key:4,class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},Lo={class:"text-xs font-bold"},Go={class:"text-xs text-[var(--el-text-color-secondary)]"},jo={key:5,class:"mb-3"},Do={class:"flex items-center mb-1"},Ro={class:"text-xs font-bold"};function Zo(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",go,[o("div",vo,[o("span",yo,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",ko,[o("div",bo,[o("span",wo,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",Co,[o("div",Vo,[o("span",So,a(e.$t("producer.name.weirdness")),1),o("span",Uo,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",Po,[o("span",Ao,a(e.$t("producer.name.soundStrength")),1),o("span",To,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",Fo,[o("div",Io,[o("span",Lo,a(e.$t("producer.name.lyricsStrength")),1),o("span",Go,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",jo,[o("div",Do,[o("span",Ro,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",Zo],["__scopeId","data-v-88e65aee"]]),No=b({name:"ReplaceSectionInput",components:{ElInputNumber:Q,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"})}}}),Mo={class:"field"},Bo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},qo={key:0,class:"task mb-2"},Wo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ho={class:"info flex-1 min-w-0"},Ko={class:"text-sm font-bold m-0 truncate"},Jo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xo={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",Mo,[o("div",Bo,[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",qo,[o("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=k=>e.onClick(e.audio))},[R((n(),c("div",Wo,[s(m,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[$,!e.audio?.audio_url]]),o("div",Ho,[o("h2",Ko,a(e.audio?.title),1),o("p",Jo,a(e.audio?.style),1)])])])):f("",!0),o("div",Xo,[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(No,[["render",Yo]]),xo=b({name:"PresetPanel",components:{TypeSelector:st,PromptInput:$t,LyricInput:Vt,StyleInput:Ft,TitleInput:Rt,ExtendFromInput:Yt,CoverFromInput:co,UploadAudio:dt,VocalGenderSelector:_o,AdvancedParams:zo,ReplaceSectionInput:Qo,FontAwesomeIcon:D,ElButton:W,Consumption:Pe},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},consumption(){return Ae(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")}}}),es={class:"flex flex-col h-full"},ts={class:"flex-1 overflow-y-auto p-5"},os={class:"flex flex-col items-center justify-center px-5 pb-5"};function ss(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"),E=r("vocal-gender-selector"),S=r("extend-from-input"),M=r("cover-from-input"),B=r("replace-section-input"),J=r("advanced-params"),g=r("consumption"),C=r("font-awesome-icon"),oe=r("el-button");return n(),c("div",es,[o("div",ts,[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(E,{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(B,{key:7,class:"mb-4"})):f("",!0),s(J,{class:"mb-4"})]),o("div",os,[s(g,{value:e.consumption,service:e.service},null,8,["value","service"]),s(oe,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(C,{icon:"fa-solid fa-magic",class:"mr-2"}),U(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const ns=V(xo,[["render",ss],["__scopeId","data-v-6642bb3c"]]),rs=te("producer"),is=b({name:"TaskPreview",components:{ElImage:N,ElIcon:K,ElTooltip:Le,FontAwesomeIcon:D,VideoPlay:Y,VideoPause:X,ElDropdown:Ie,ElDropdownMenu:Fe,ElDropdownItem:Te,Loading:ae},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=>{ve.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:rs},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})}}}),as={class:"task"},ls=["onClick"],cs={class:"left"},ds=["onClick"],us=["onClick"],ps={key:2,class:"duration"},ms={class:"info"},fs={class:"title"},hs={class:"style"},_s={class:"right"},$s={class:"el-dropdown-link"},gs={class:"flex items-center min-w-[120px]"},vs={class:"flex items-center min-w-[120px]"},ys={class:"el-dropdown-link"};function ks(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"),E=r("Loading"),S=r("el-dropdown-item"),M=r("el-dropdown-menu"),B=r("el-dropdown"),J=H("loading");return n(),c("div",as,[(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",cs,[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,ds)):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,us)):f("",!0),g?.duration?(n(),c("div",ps,a(e.useFormatDuring(g?.duration)),1)):f("",!0)])),[[J,!g?.audio_url]]),o("div",ms,[o("h2",fs,a(g?.title),1),o("p",hs,a(g?.style),1)]),o("div",_s,[s(B,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[s(S,{disabled:e.isFetchingVideoUrl,onClick:C=>e.handleVideoDownload(g)},{default:d(()=>[o("div",gs,[e.isFetchingVideoUrl?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(E)]),_: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(()=>[U(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",vs,[e.isFetchingWav?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(E)]),_: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(B,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(()=>[U(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(()=>[U(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(()=>[U(a(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{onClick:P(C=>e.onCover(g),["stop"])},{default:d(()=>[U(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(()=>[U(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(()=>[U(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(()=>[U(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(()=>[U(a(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):f("",!0)]),_:2},1024)]),default:d(()=>[o("span",ys,[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,ls))),128))])}const bs=V(is,[["render",ks]]),ws={class:"player-slider"},Cs=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",ws,[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"])]))}}),Vs={class:"flex player-song"},Ss=["src"],Us={class:"ml-2 text-xs flex flex-col justify-between"},Es={class:"w-52 2xl:w-96 cursor-pointer truncate"},Ps={class:"flex"},As={class:"ml-2 text-dc"},Ts=b({__name:"PlayerSong",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio,set:i=>t.commit("producer/setAudio",i)});return ne(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",Vs,[o("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||A(ye)},null,8,Ss),o("div",Us,[o("div",Es,[o("div",Ps,[o("span",null,a(l.value?.title||"Music"),1),o("span",As,"- "+a(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Fs={class:"flex justify-end items-center gap-x-2.5"},Is={class:"text-xs"},Ls=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",Fs,[o("span",Is,a(A(j)(l.value))+" / "+a(A(j)(i.value)),1)]))}}),Gs={class:"player-volume flex flex-col items-center pt-2"},js={class:"text-sm mt-3"},Ds=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",Gs,[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",js,a(l.value),1)]))}}),Rs={class:"flex items-center justify-center gap-x-3"},Zs=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",Rs,[s(ee,{icon:i.value?.state==="playing"?A(ke):A(be),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),s(A(Ge),{placement:"top",width:"50px",trigger:"click"},{reference:d(()=>[s(ee,{icon:A(we),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:d(()=>[s(Ds)]),_:1})]))}}),zs={class:"flex flex-col items-stretch h-20"},Ns={class:"flex grow px-5 items-center"},Ms={class:"flex-1"},Bs={class:"flex-1"},Os={class:"flex-1"},qs=b({__name:"Player",setup(e){return(t,l)=>(n(),c("div",zs,[s(Cs),o("div",Ns,[o("div",Ms,[s(Ts)]),o("div",Bs,[s(Zs)]),o("div",Os,[s(Ls)])])]))}}),Ws=b({name:"RecentPanel",components:{ElSkeletonItem:Re,ElSkeleton:De,TaskPreview:bs,Player:qs,NoTasks:je,ScrollList:_e},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?.()}}}),Hs={key:0,class:"tasks"},Ks={class:"left w-[70px] p-[10px] flex items-center"},Js={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Xs={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",Hs,[(n(),c(G,null,q(3,E=>o("div",{key:E,class:"flex"},[o("div",Ks,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),o("div",Js,[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]=E=>e.$emit("reach-top"))},{default:d(()=>[(n(!0),c(G,null,q(e.tasks?.items,(E,S)=>(n(),v(_,{key:S,"model-value":E,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),c("div",Xs,[s(k)])):f("",!0),R(o("div",Ys,[s(y)],512),[[re,!!e.$store?.state?.producer?.audio?.object]])],64)}const xs=V(Ws,[["render",Qs]]),en=b({name:"TaskPreview",components:{IconPicture:le,ElImage:N,ElAvatar:Ce,ElIcon:K},computed:{audio(){return this.$store.state.producer?.audio}}}),tn={key:0,class:"size-full overflow-hidden"},on={class:"relative h-[300px]"},sn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},nn={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"},rn={class:"p-4"},an={class:"flex items-center font-bold mb-2"},ln={class:"text-[var(--el-text-color-regular)] mb-2"},cn={class:"text-xs text-[var(--el-text-color-regular)]"},dn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},un={key:1,class:"w-full h-full"};function pn(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",tn,[o("div",on,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:d(()=>[o("div",sn,[s(m,{class:"text-3xl"},{default:d(()=>[s(u)]),_:1})])]),_:1},8,["src"]),o("h2",nn,a(e.audio?.title),1)]),o("div",rn,[o("div",an,[s($,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),o("span",null,a(e.audio?.title),1)]),o("p",ln,a(e.audio?.style),1),o("p",cn,a(e.$dayjs.format(e.audio?.created_at)),1),o("div",dn,[o("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",un))}const mn=V(en,[["render",pn]]),fn=te("producer"),hn=b({name:"ProducerIndex",components:{Layout:qe,ConfigPanel:ns,RecentPanel:xs,PreviewPanel:mn},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 $e({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(){de.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ue&&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:fn},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),ce("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 _n(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(hn,[["render",_n],["__scopeId","data-v-d6806962"]]);export{mr as default};
1
+ import{F as D}from"./index.es-B9yw59kn.js";import{E as W}from"./index-CGJx6pfn.js";import{E as se}from"./index-CEGyzWWI.js";import{d as b,H as c,E as o,z as O,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 U,G as R,K as H,M as P,u as A,c as T,w as ne,L as re}from"./vendor-vue-NSDaktjZ.js";import{G as V,bl as ie,ez as X,eA as Y,X as K,J as ae,S as L,cs as te,eB as Z,eC as le,cr as ce,n as de}from"./index-B72vsB6D.js";import{a as ue}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-CRQQOFfj.js";import{b as pe}from"./producer-DP85fuAq.js";import{E as me}from"./index-CeH6helO.js";import{E as fe,a as he}from"./index-DCc5mWT3.js";import{I as F,S as _e,l as $e}from"./pagination-CBYfRJVG.js";import{E as ge}from"./index-D-R1uHlt.js";import{E as w}from"./index-0tg1OcXL.js";import{E as z}from"./index-CkEMCLbE.js";import{u as j,F as ve,O as ye,_ as ee,P as ke,a as be,V as we,E as Ce}from"./IconPark.vue_vue_type_script_setup_true_lang-rN4yfqRq.js";import{E as Q}from"./index-BshjP0UT.js";import{E as N}from"./index-BdXdvXDF.js";import{E as Ve,a as Se}from"./index-wJ0GDIQS.js";import{E as x}from"./index-GPTup2zg.js";import{E as Ue,a as Ee}from"./index-B8517Kq_.js";import{C as Pe}from"./Consumption-D9Hn2ImE.js";import{a as Ae}from"./price-BTNYcVQ5.js";import{E as Te,b as Fe,a as Ie}from"./index-BTe0Vafw.js";import{E as Le}from"./index-BiORZ5ee.js";import{E as Ge}from"./index-CuKao8C3.js";import{N as je}from"./NoTasks-B7fpKwEM.js";import{a as De,E as Re}from"./index-B5PvIfC4.js";import"./use-form-item-Yq9rpjQi.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-BOFed1cS.js";import"./index-B2wj3UbJ.js";import"./index-DD1qoXbO.js";import"./typescript-DqAqST2T.js";import"./strings-beZM2Y-f.js";import"./isEqual-9RWKK6ZC.js";import"./_Uint8Array-DdojeWiA.js";import"./castArray-PDXtni_G.js";import"./debounce-DLWpM2kv.js";import"./_baseIteratee-BJlOKELK.js";import"./index-Dh2kPrs0.js";import"./index-DDjfpPMW.js";import"./_baseClone-CkHqwwjY.js";import"./_initCloneObject-DJHkV8_e.js";import"./index-CYFuwdxJ.js";import"./index-Cu41y2Fl.js";import"./index-CcjaGWkK.js";import"./dropdown-CRfezuvq.js";const Ze=b({name:"LayoutProducer",components:{ElDrawer:se,ElButton:W,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),ze={class:"main flex flex-row flex-1"},Ne={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Me={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Be={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",Ne,[O(e.$slots,"config",{},void 0,!0)]),o("div",Me,[O(e.$slots,"result",{},void 0,!0)]),o("div",Be,[O(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(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const qe=V(Ze,[["render",Oe],["__scopeId","data-v-7453886f"]]),We=b({name:"TypeSelector",components:{ElSelect:he,ElOption:fe,ElSwitch:me},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=pe)}}),He={class:"flex items-center justify-between mb-3"},Ke={class:"text-sm font-bold"},Je={class:"mb-3"},Xe={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)]"},et={key:0,class:"flex items-center justify-between mb-3"},tt={class:"text-sm font-bold"};function ot(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",He,[o("span",Ke,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",Je,[o("div",Xe,[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",et,[o("span",tt,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 st=V(We,[["render",ot]]),nt=b({name:"UploadAudio",components:{ElUpload:ge,ElButton:W,InfoIcon:F,FontAwesomeIcon:D},emits:["change"],data(){return{fileList:[],uploadUrl:ie()+"/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(){}}}),rt={class:"relative"},it={class:"flex justify-between"},at={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function ct(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",rt,[o("div",it,[o("div",at,[o("span",lt,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"}),U(" "+a(e.$t("producer.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const dt=V(nt,[["render",ct],["__scopeId","data-v-e4cd0467"]]),ut="",pt=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=ut)}}),mt={class:"field"},ft={class:"flex items-center mb-1"},ht={class:"text-sm font-bold"};function _t(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",mt,[o("div",ft,[o("span",ht,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(pt,[["render",_t]]),gt="",vt=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=gt)},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}}}}),yt={class:"field"},kt={class:"flex items-center justify-between mb-1"},bt={class:"flex items-center"},wt={class:"text-sm font-bold"};function Ct(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",yt,[o("div",kt,[o("div",bt,[o("span",wt,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"})),U(" "+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 Vt=V(vt,[["render",Ct],["__scopeId","data-v-88c6da2b"]]),St=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})}}}}),Ut={class:"field"},Et={class:"flex items-center justify-between mb-1"},Pt={class:"flex items-center"},At={class:"text-sm font-bold"};function Tt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",Ut,[o("div",Et,[o("div",Pt,[o("span",At,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 Ft=V(St,[["render",Tt]]),It=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})}}}}),Lt={class:"field"},Gt={class:"flex items-center mb-1"},jt={class:"text-sm font-bold"};function Dt(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-input");return n(),c("div",Lt,[o("div",Gt,[o("span",jt,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 Rt=V(It,[["render",Dt]]),Zt=b({name:"ExtendFromInput",components:{ElImage:N,ElIcon:K,ElInputNumber:Q,VideoPlay:Y,VideoPause:X},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"},Nt={class:"box"},Mt={class:"title font-bold"},Bt={class:"input-wrapper"},Ot={class:"task"},qt={class:"left"},Wt={key:2,class:"duration"},Ht={class:"info"},Kt={class:"title"},Jt={class:"style"};function Xt(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",Nt,[o("h2",Mt,a(e.$t("producer.name.extend")),1),o("div",Bt,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=E=>e.value=E),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]=E=>e.onClick(e.audio))},[R((n(),c("div",qt,[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]=E=>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]=E=>e.onPlay(e.audio))},[s($,null,{default:d(()=>[s(k)]),_:1})])):f("",!0),e.audio?.duration?(n(),c("div",Wt,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[y,!e.audio?.audio_url]]),o("div",Ht,[o("h2",Kt,a(e.audio?.title),1),o("p",Jt,a(e.audio?.style),1)])])):f("",!0)])])}const Yt=V(Zt,[["render",Xt],["__scopeId","data-v-26d43480"]]),Qt=b({name:"CoverFromInput",components:{ElImage:N,ElIcon:K,VideoPlay:Y,VideoPause:X},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"},eo={class:"box"},to={class:"title font-bold"},oo={class:"task"},so={class:"left"},no={key:2,class:"duration"},ro={class:"info"},io={class:"title"},ao={class:"style"};function lo(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",eo,[o("h2",to,a(e.$t("producer.name.cover")),1)]),o("div",oo,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=y=>e.onClick(e.audio))},[R((n(),c("div",so,[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",no,a(e.useFormatDuring(e.audio?.duration)),1)):f("",!0)])),[[k,!e.audio?.audio_url]]),o("div",ro,[o("h2",io,a(e.audio?.title),1),o("p",ao,a(e.audio?.style),1)])])):f("",!0)])])}const co=V(Qt,[["render",lo],["__scopeId","data-v-d8a8e583"]]),uo=b({name:"VocalGenderSelector",components:{ElRadioGroup:Se,ElRadioButton:Ve,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})}}}}),po={class:"mb-2"},mo={class:"flex items-center mb-1"},fo={class:"text-sm font-bold"};function ho(e,t,l,i,h,p){const u=r("info-icon"),m=r("el-radio-button"),_=r("el-radio-group");return n(),c("div",po,[o("div",mo,[o("span",fo,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(()=>[U(a(e.$t("producer.gender.auto")),1)]),_:1}),s(m,{value:"f"},{default:d(()=>[U(a(e.$t("producer.gender.female")),1)]),_:1}),s(m,{value:"m"},{default:d(()=>[U(a(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const _o=V(uo,[["render",ho]]),$o=b({name:"AdvancedParams",components:{ElCollapse:Ee,ElCollapseItem:Ue,ElInput:z,ElSlider:x,ElInputNumber:Q},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})}}}}),go={key:0,class:"mb-3"},vo={class:"flex items-center mb-1"},yo={class:"text-xs font-bold"},ko={key:1,class:"mb-3"},bo={class:"flex items-center mb-1"},wo={class:"text-xs font-bold"},Co={key:2,class:"mb-3"},Vo={class:"flex items-center justify-between mb-1"},So={class:"text-xs font-bold"},Uo={class:"text-xs text-[var(--el-text-color-secondary)]"},Eo={key:3,class:"mb-3"},Po={class:"flex items-center justify-between mb-1"},Ao={class:"text-xs font-bold"},To={class:"text-xs text-[var(--el-text-color-secondary)]"},Fo={key:4,class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},Lo={class:"text-xs font-bold"},Go={class:"text-xs text-[var(--el-text-color-secondary)]"},jo={key:5,class:"mb-3"},Do={class:"flex items-center mb-1"},Ro={class:"text-xs font-bold"};function Zo(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",go,[o("div",vo,[o("span",yo,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",ko,[o("div",bo,[o("span",wo,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",Co,[o("div",Vo,[o("span",So,a(e.$t("producer.name.weirdness")),1),o("span",Uo,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",Po,[o("span",Ao,a(e.$t("producer.name.soundStrength")),1),o("span",To,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",Fo,[o("div",Io,[o("span",Lo,a(e.$t("producer.name.lyricsStrength")),1),o("span",Go,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",jo,[o("div",Do,[o("span",Ro,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",Zo],["__scopeId","data-v-88e65aee"]]),No=b({name:"ReplaceSectionInput",components:{ElInputNumber:Q,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"})}}}),Mo={class:"field"},Bo={class:"flex items-center mb-2"},Oo={class:"text-sm font-bold m-0"},qo={key:0,class:"task mb-2"},Wo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ho={class:"info flex-1 min-w-0"},Ko={class:"text-sm font-bold m-0 truncate"},Jo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xo={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",Mo,[o("div",Bo,[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",qo,[o("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=k=>e.onClick(e.audio))},[R((n(),c("div",Wo,[s(m,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[$,!e.audio?.audio_url]]),o("div",Ho,[o("h2",Ko,a(e.audio?.title),1),o("p",Jo,a(e.audio?.style),1)])])])):f("",!0),o("div",Xo,[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(No,[["render",Yo]]),xo=b({name:"PresetPanel",components:{TypeSelector:st,PromptInput:$t,LyricInput:Vt,StyleInput:Ft,TitleInput:Rt,ExtendFromInput:Yt,CoverFromInput:co,UploadAudio:dt,VocalGenderSelector:_o,AdvancedParams:zo,ReplaceSectionInput:Qo,FontAwesomeIcon:D,ElButton:W,Consumption:Pe},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},consumption(){return Ae(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")}}}),es={class:"flex flex-col h-full"},ts={class:"flex-1 overflow-y-auto p-5"},os={class:"flex flex-col items-center justify-center px-5 pb-5"};function ss(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"),E=r("vocal-gender-selector"),S=r("extend-from-input"),M=r("cover-from-input"),B=r("replace-section-input"),J=r("advanced-params"),g=r("consumption"),C=r("font-awesome-icon"),oe=r("el-button");return n(),c("div",es,[o("div",ts,[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(E,{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(B,{key:7,class:"mb-4"})):f("",!0),s(J,{class:"mb-4"})]),o("div",os,[s(g,{value:e.consumption,service:e.service},null,8,["value","service"]),s(oe,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(C,{icon:"fa-solid fa-magic",class:"mr-2"}),U(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const ns=V(xo,[["render",ss],["__scopeId","data-v-6642bb3c"]]),rs=te("producer"),is=b({name:"TaskPreview",components:{ElImage:N,ElIcon:K,ElTooltip:Le,FontAwesomeIcon:D,VideoPlay:Y,VideoPause:X,ElDropdown:Ie,ElDropdownMenu:Fe,ElDropdownItem:Te,Loading:ae},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=>{ve.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:rs},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})}}}),as={class:"task"},ls=["onClick"],cs={class:"left"},ds=["onClick"],us=["onClick"],ps={key:2,class:"duration"},ms={class:"info"},fs={class:"title"},hs={class:"style"},_s={class:"right"},$s={class:"el-dropdown-link"},gs={class:"flex items-center min-w-[120px]"},vs={class:"flex items-center min-w-[120px]"},ys={class:"el-dropdown-link"};function ks(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"),E=r("Loading"),S=r("el-dropdown-item"),M=r("el-dropdown-menu"),B=r("el-dropdown"),J=H("loading");return n(),c("div",as,[(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",cs,[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,ds)):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,us)):f("",!0),g?.duration?(n(),c("div",ps,a(e.useFormatDuring(g?.duration)),1)):f("",!0)])),[[J,!g?.audio_url]]),o("div",ms,[o("h2",fs,a(g?.title),1),o("p",hs,a(g?.style),1)]),o("div",_s,[s(B,null,{dropdown:d(()=>[s(M,null,{default:d(()=>[s(S,{disabled:e.isFetchingVideoUrl,onClick:C=>e.handleVideoDownload(g)},{default:d(()=>[o("div",gs,[e.isFetchingVideoUrl?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(E)]),_: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(()=>[U(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",vs,[e.isFetchingWav?(n(),v(_,{key:0,class:"is-loading mr-2"},{default:d(()=>[s(E)]),_: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(B,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(()=>[U(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(()=>[U(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(()=>[U(a(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):f("",!0),s(S,{onClick:P(C=>e.onCover(g),["stop"])},{default:d(()=>[U(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(()=>[U(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(()=>[U(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(()=>[U(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(()=>[U(a(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):f("",!0)]),_:2},1024)]),default:d(()=>[o("span",ys,[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,ls))),128))])}const bs=V(is,[["render",ks]]),ws={class:"player-slider"},Cs=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",ws,[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"])]))}}),Vs={class:"flex player-song"},Ss=["src"],Us={class:"ml-2 text-xs flex flex-col justify-between"},Es={class:"w-52 2xl:w-96 cursor-pointer truncate"},Ps={class:"flex"},As={class:"ml-2 text-dc"},Ts=b({__name:"PlayerSong",setup(e){const t=Z(),l=T({get:()=>t.state.producer.audio,set:i=>t.commit("producer/setAudio",i)});return ne(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",Vs,[o("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||A(ye)},null,8,Ss),o("div",Us,[o("div",Es,[o("div",Ps,[o("span",null,a(l.value?.title||"Music"),1),o("span",As,"- "+a(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Fs={class:"flex justify-end items-center gap-x-2.5"},Is={class:"text-xs"},Ls=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",Fs,[o("span",Is,a(A(j)(l.value))+" / "+a(A(j)(i.value)),1)]))}}),Gs={class:"player-volume flex flex-col items-center pt-2"},js={class:"text-sm mt-3"},Ds=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",Gs,[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",js,a(l.value),1)]))}}),Rs={class:"flex items-center justify-center gap-x-3"},Zs=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",Rs,[s(ee,{icon:i.value?.state==="playing"?A(ke):A(be),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),s(A(Ge),{placement:"top",width:"50px",trigger:"click"},{reference:d(()=>[s(ee,{icon:A(we),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:d(()=>[s(Ds)]),_:1})]))}}),zs={class:"flex flex-col items-stretch h-20"},Ns={class:"flex grow px-5 items-center"},Ms={class:"flex-1"},Bs={class:"flex-1"},Os={class:"flex-1"},qs=b({__name:"Player",setup(e){return(t,l)=>(n(),c("div",zs,[s(Cs),o("div",Ns,[o("div",Ms,[s(Ts)]),o("div",Bs,[s(Zs)]),o("div",Os,[s(Ls)])])]))}}),Ws=b({name:"RecentPanel",components:{ElSkeletonItem:Re,ElSkeleton:De,TaskPreview:bs,Player:qs,NoTasks:je,ScrollList:_e},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?.()}}}),Hs={key:0,class:"tasks"},Ks={class:"left w-[70px] p-[10px] flex items-center"},Js={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Xs={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",Hs,[(n(),c(G,null,q(3,E=>o("div",{key:E,class:"flex"},[o("div",Ks,[s(m,{animated:""},{template:d(()=>[s(u,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),o("div",Js,[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]=E=>e.$emit("reach-top"))},{default:d(()=>[(n(!0),c(G,null,q(e.tasks?.items,(E,S)=>(n(),v(_,{key:S,"model-value":E,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),c("div",Xs,[s(k)])):f("",!0),R(o("div",Ys,[s(y)],512),[[re,!!e.$store?.state?.producer?.audio?.object]])],64)}const xs=V(Ws,[["render",Qs]]),en=b({name:"TaskPreview",components:{IconPicture:le,ElImage:N,ElAvatar:Ce,ElIcon:K},computed:{audio(){return this.$store.state.producer?.audio}}}),tn={key:0,class:"size-full overflow-hidden"},on={class:"relative h-[300px]"},sn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},nn={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"},rn={class:"p-4"},an={class:"flex items-center font-bold mb-2"},ln={class:"text-[var(--el-text-color-regular)] mb-2"},cn={class:"text-xs text-[var(--el-text-color-regular)]"},dn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},un={key:1,class:"w-full h-full"};function pn(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",tn,[o("div",on,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:d(()=>[o("div",sn,[s(m,{class:"text-3xl"},{default:d(()=>[s(u)]),_:1})])]),_:1},8,["src"]),o("h2",nn,a(e.audio?.title),1)]),o("div",rn,[o("div",an,[s($,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),o("span",null,a(e.audio?.title),1)]),o("p",ln,a(e.audio?.style),1),o("p",cn,a(e.$dayjs.format(e.audio?.created_at)),1),o("div",dn,[o("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",un))}const mn=V(en,[["render",pn]]),fn=te("producer"),hn=b({name:"ProducerIndex",components:{Layout:qe,ConfigPanel:ns,RecentPanel:xs,PreviewPanel:mn},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 $e({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(){de.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ue&&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:fn},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),ce("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 _n(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(hn,[["render",_n],["__scopeId","data-v-d6806962"]]);export{mr as default};