@acedatacloud/nexior 3.166.0 → 3.168.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 (239) hide show
  1. package/dist/assets/{Auth-DFRTIldg.js → Auth-BDyXSjIe.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-BLqNsw9k.js → BotPlaceholder-BEomWKuP.js} +1 -1
  3. package/dist/assets/{Callback-CHgC-5ER.js → Callback-DoJBHDRi.js} +1 -1
  4. package/dist/assets/{Console-BUhuv8r2.js → Console-B85hzCWD.js} +1 -1
  5. package/dist/assets/{Consumption-D9Hn2ImE.js → Consumption-Vrs9Ym-e.js} +1 -1
  6. package/dist/assets/{Conversation-CT5b219A.js → Conversation-yBAeOfTL.js} +1 -1
  7. package/dist/assets/{CopyToClipboard-YKue_6LC.js → CopyToClipboard-BKPPPZex.js} +1 -1
  8. package/dist/assets/{Detail-DJ3K4Lui.js → Detail-IqUP_8Rf.js} +2 -2
  9. package/dist/assets/{EditArray-D9X7ilzT.js → EditArray-c0xJ35n-.js} +1 -1
  10. package/dist/assets/{Extra-tNEhYDVR.js → Extra-B0rcl4cC.js} +1 -1
  11. package/dist/assets/{FilePreview-BLBZCIvI.js → FilePreview-B83vVjmo.js} +1 -1
  12. package/dist/assets/{History-BsiIeeU2.js → History-CLZkfWJ_.js} +1 -1
  13. package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-rN4yfqRq.js → IconPark.vue_vue_type_script_setup_true_lang-ksQMUIfc.js} +1 -1
  14. package/dist/assets/{ImagePreview-CUOTVDKq.js → ImagePreview-B0AGcjB1.js} +1 -1
  15. package/dist/assets/{ImageWrapper-BTYsRpEP.js → ImageWrapper-_iiM_a6H.js} +1 -1
  16. package/dist/assets/{Index-DTbuJEY1.js → Index-B672ipBS.js} +1 -1
  17. package/dist/assets/{Index-B-AW-gIW.js → Index-B7N_ZM2U.js} +1 -1
  18. package/dist/assets/{Index-BAEdyQeV.js → Index-BKjB-9Oe.js} +2 -2
  19. package/dist/assets/{Index-CBgaEKEn.js → Index-By3xsmxj.js} +1 -1
  20. package/dist/assets/{Index-DvgaohNO.js → Index-CSuhKEjt.js} +1 -1
  21. package/dist/assets/{Index-Aud0OTuP.js → Index-CezD43xH.js} +1 -1
  22. package/dist/assets/{Index-CBA8zIuN.js → Index-CxsRl-11.js} +1 -1
  23. package/dist/assets/{Index-C138EMq8.js → Index-D-qTlC3Z.js} +1 -1
  24. package/dist/assets/{Index-DWjSghj6.js → Index-D1tmlbyD.js} +1 -1
  25. package/dist/assets/Index-DC676h74.js +1 -0
  26. package/dist/assets/{Index-C6BwOZ3w.js → Index-DHx4p08s.js} +1 -1
  27. package/dist/assets/{Index-DeVbMbCS.js → Index-DZ47oisV.js} +1 -1
  28. package/dist/assets/{Index-HvXcS5Be.js → Index-DbKTdta8.js} +1 -1
  29. package/dist/assets/{Index-CAKUcveC.js → Index-Dc2nFTk1.js} +1 -1
  30. package/dist/assets/{Index-CJWvx5ND.js → Index-Did7kzpk.js} +1 -1
  31. package/dist/assets/{Index-DTWbz-mb.js → Index-DpHIGaEz.js} +1 -1
  32. package/dist/assets/{Index-1m4ePc99.js → Index-F42-VQFW.js} +1 -1
  33. package/dist/assets/{Index-D4OExIA4.js → Index-NTKMlpsi.js} +1 -1
  34. package/dist/assets/{Index-DmiBBxMR.js → Index-T9ebwI8G.js} +1 -1
  35. package/dist/assets/Index-YCV8wVla.css +1 -0
  36. package/dist/assets/{Index-Dcwar_I_.js → Index-ah7mFp7z.js} +1 -1
  37. package/dist/assets/Index-hZRJDvDU.css +1 -0
  38. package/dist/assets/{Index-cV8Yyo9p.js → Index-mAdg-qFC.js} +1 -1
  39. package/dist/assets/Index-mfKfVj3g.js +1 -0
  40. package/dist/assets/{Index-0fxXA4_J.js → Index-pNqGPmBt.js} +1 -1
  41. package/dist/assets/{Index-SD4zKg1q.js → Index-vu_JhkJW.js} +1 -1
  42. package/dist/assets/{Invitees-Dx5MX_iJ.js → Invitees-B_jQ5kVN.js} +1 -1
  43. package/dist/assets/{List-Cxywj_LE.js → List-7Wl_Izc4.js} +1 -1
  44. package/dist/assets/{List-CQxikLB8.js → List-BCkL1DtJ.js} +1 -1
  45. package/dist/assets/{List-BIYl6bzU.js → List-CvW8rP13.js} +1 -1
  46. package/dist/assets/{Main-Ctqdhys8.js → Main-QbmvnnMG.js} +1 -1
  47. package/dist/assets/{Navigator-CcH_hYdW.js → Navigator-C-p3RzVC.js} +1 -1
  48. package/dist/assets/{NoTasks-B7fpKwEM.js → NoTasks-DTEzeszL.js} +1 -1
  49. package/dist/assets/{NotFound-CTcD9OJN.js → NotFound-CVtQTglJ.js} +1 -1
  50. package/dist/assets/{OAuthCallback-DilJbVAG.js → OAuthCallback-CpR2-nmg.js} +1 -1
  51. package/dist/assets/{Pagination-D2l4tVs_.js → Pagination-DmumC74j.js} +1 -1
  52. package/dist/assets/{Status-DEM2PLOr.js → Status-Bf9lfqL1.js} +1 -1
  53. package/dist/assets/{Subscribe-CJOh4174.js → Subscribe-Db51l7te.js} +1 -1
  54. package/dist/assets/{VideoPlayer-DPmqjyk_.js → VideoPlayer-DLqpJWFk.js} +1 -1
  55. package/dist/assets/_Uint8Array-BXWVuq2q.js +1 -0
  56. package/dist/assets/{_baseClone-CkHqwwjY.js → _baseClone-CdH871Qw.js} +1 -1
  57. package/dist/assets/{_baseIteratee-BJlOKELK.js → _baseIteratee-BD8B7GME.js} +1 -1
  58. package/dist/assets/{_initCloneObject-DJHkV8_e.js → _initCloneObject-BBeThwBy.js} +1 -1
  59. package/dist/assets/{add-DgiDgPk2.js → add-UrLMzye7.js} +1 -1
  60. package/dist/assets/{all-wallets-Ir8fVnIE.js → all-wallets-opGrYoFq.js} +1 -1
  61. package/dist/assets/{app-store-BSr6K8vJ.js → app-store-eRITh79T.js} +1 -1
  62. package/dist/assets/{apple-Yw5vBM9e.js → apple-BJrlVv7w.js} +1 -1
  63. package/dist/assets/{arrow-bottom-vVfNYwgN.js → arrow-bottom-Bjnbevqv.js} +1 -1
  64. package/dist/assets/{arrow-bottom-circle-C03-yd0p.js → arrow-bottom-circle-B3cg2xpo.js} +1 -1
  65. package/dist/assets/{arrow-left-Houf2S9n.js → arrow-left-BIRR85uZ.js} +1 -1
  66. package/dist/assets/{arrow-right-C0p7Cfns.js → arrow-right-CMkhN4--.js} +1 -1
  67. package/dist/assets/{arrow-top-BFZ3-_4h.js → arrow-top-D-ULF3EB.js} +1 -1
  68. package/dist/assets/{avatar-CDKyOWa1.js → avatar-D0aH2OKD.js} +1 -1
  69. package/dist/assets/{bank-DlDeeg-M.js → bank-B9xrTyFs.js} +1 -1
  70. package/dist/assets/{basic-DdHY_6kS.js → basic-LOPbFEDH.js} +60 -60
  71. package/dist/assets/{browser-BvJkxROA.js → browser-Da5KzxtX.js} +1 -1
  72. package/dist/assets/{byokCredential-BSHUJThg.js → byokCredential-Pee77Xtw.js} +1 -1
  73. package/dist/assets/{card-bjHpyjBK.js → card-Cmds_I_j.js} +1 -1
  74. package/dist/assets/{castArray-PDXtni_G.js → castArray-CUDnQsIK.js} +1 -1
  75. package/dist/assets/{chat-D_3mtJGM.js → chat-E_RwqKGz.js} +1 -1
  76. package/dist/assets/{checkmark-CvNDvyd2.js → checkmark-D5qigt51.js} +1 -1
  77. package/dist/assets/{checkmark-bold-BaD95hk7.js → checkmark-bold-LvKhYYxu.js} +1 -1
  78. package/dist/assets/{chevron-bottom-BZTrBoQZ.js → chevron-bottom-CCJifxR0.js} +1 -1
  79. package/dist/assets/{chevron-left-gkGHznHL.js → chevron-left-DoFRVtBs.js} +1 -1
  80. package/dist/assets/{chevron-right-B2ps_1x1.js → chevron-right-7VzYWBD3.js} +1 -1
  81. package/dist/assets/{chevron-top-BcHLsjsv.js → chevron-top-Cr09TF1o.js} +1 -1
  82. package/dist/assets/{chrome-store-B_e6TuIp.js → chrome-store-tZ5X31Ib.js} +1 -1
  83. package/dist/assets/{clock-Crtz1b91.js → clock-DhSlFX8L.js} +1 -1
  84. package/dist/assets/{close-CVk0Y4TQ.js → close-8NNhk5MQ.js} +1 -1
  85. package/dist/assets/{coinPlaceholder-CToK3nFp.js → coinPlaceholder-CGqCWk_o.js} +1 -1
  86. package/dist/assets/{compass-D9KY3PBb.js → compass-DcyOP90T.js} +1 -1
  87. package/dist/assets/{copy-_SHmr2qS.js → copy-D1WNYxGL.js} +1 -1
  88. package/dist/assets/{createTaskActions-pg5m9M7p.js → createTaskActions-DAYGdsVq.js} +1 -1
  89. package/dist/assets/{cursor-BXSppnwr.js → cursor-cMwhnIk5.js} +1 -1
  90. package/dist/assets/{cursor-transparent-ITFaqM-M.js → cursor-transparent-CrQv8Onm.js} +1 -1
  91. package/dist/assets/{debounce-DLWpM2kv.js → debounce-DCSodorO.js} +1 -1
  92. package/dist/assets/{desktop-Ctxvg_Mc.js → desktop-B93vdfc0.js} +1 -1
  93. package/dist/assets/{disconnect-362IL6KW.js → disconnect-CTOrg89I.js} +1 -1
  94. package/dist/assets/{discord-D6KbitWr.js → discord-B928iac1.js} +1 -1
  95. package/dist/assets/{distribution-opJjNwQy.js → distribution-CnJXY8oi.js} +1 -1
  96. package/dist/assets/{dropdown-CRfezuvq.js → dropdown-BDLqMJ6c.js} +1 -1
  97. package/dist/assets/{etherscan-TTFJLDpm.js → etherscan-C7rdhh_l.js} +1 -1
  98. package/dist/assets/{exclamation-triangle-DeRUzLlM.js → exclamation-triangle-TLEW8o_8.js} +1 -1
  99. package/dist/assets/{extension-D_fSzTou.js → extension-BCPc05eE.js} +1 -1
  100. package/dist/assets/{external-link-CIqLSeAr.js → external-link-BVSFanSk.js} +1 -1
  101. package/dist/assets/{facebook-CxdM6ryJ.js → facebook-yWzRWreo.js} +1 -1
  102. package/dist/assets/{farcaster-YTjCYlDM.js → farcaster-ObXhKU7L.js} +1 -1
  103. package/dist/assets/{filters-98lL8dRx.js → filters-D65QChWv.js} +1 -1
  104. package/dist/assets/{github-DTyEwyGJ.js → github-CfpVGN4l.js} +1 -1
  105. package/dist/assets/{google-BSZydxsM.js → google-DgM2THGc.js} +1 -1
  106. package/dist/assets/{help-circle-CcNn1rLc.js → help-circle-BuTaWLeN.js} +1 -1
  107. package/dist/assets/{id-Cun2ausq.js → id-BDpIvgHc.js} +1 -1
  108. package/dist/assets/{image-Dub-7Nlr.js → image-BPV6AkRv.js} +1 -1
  109. package/dist/assets/{index-kT3FXf87.js → index--_ruvatY.js} +1 -1
  110. package/dist/assets/{index-Khp7dQxO.js → index-50IhPevG.js} +2 -2
  111. package/dist/assets/{index-ClVcQZ50.js → index-B0_GI7q2.js} +1 -1
  112. package/dist/assets/{index-DDjfpPMW.js → index-B6H89xyY.js} +1 -1
  113. package/dist/assets/{index-DJqHVsEt.js → index-BEB0_UvQ.js} +1 -1
  114. package/dist/assets/{index-CYFuwdxJ.js → index-BFQ7oRfU.js} +1 -1
  115. package/dist/assets/{index-4t94d9Yq.js → index-BJD6-2dA.js} +1 -1
  116. package/dist/assets/{index-8Tl1cChK.js → index-BKkACFcM.js} +1 -1
  117. package/dist/assets/{index-DCc5mWT3.js → index-BNn6E6CM.js} +1 -1
  118. package/dist/assets/{index-CAROfd4i.js → index-BP0i0DI0.js} +1 -1
  119. package/dist/assets/{index-B2wj3UbJ.js → index-BS0e3mH-.js} +1 -1
  120. package/dist/assets/{index-Bua3buBf.js → index-BT6khhJu.js} +1 -1
  121. package/dist/assets/{index-CxdFHeqj.js → index-BX7sWEUw.js} +1 -1
  122. package/dist/assets/{index-CeH6helO.js → index-BZ0LCluE.js} +1 -1
  123. package/dist/assets/{index-D0ozHIX4.js → index-BfTKfSn5.js} +1 -1
  124. package/dist/assets/{index-wJ0GDIQS.js → index-BgIT6hC5.js} +1 -1
  125. package/dist/assets/{index-Cr_uqtp_.js → index-BmuW8LII.js} +1 -1
  126. package/dist/assets/{index--Bss94FI.js → index-Bo_W4_wC.js} +1 -1
  127. package/dist/assets/{index-BiORZ5ee.js → index-C2Ix0O_U.js} +1 -1
  128. package/dist/assets/{index-Bb3nI4T1.js → index-CAjrQ30c.js} +1 -1
  129. package/dist/assets/{index-Da2aFJLl.js → index-CAk112Jj.js} +1 -1
  130. package/dist/assets/{index-IHF4ze7_.js → index-CNiheU_Y.js} +1 -1
  131. package/dist/assets/{index-acpn-dGD.js → index-COHCLZDM.js} +1 -1
  132. package/dist/assets/{index-CuKao8C3.js → index-CajQSidV.js} +1 -1
  133. package/dist/assets/{index-DyRgASC4.js → index-CeewlRvZ.js} +1 -1
  134. package/dist/assets/{index-GPTup2zg.js → index-CfNLp6F4.js} +1 -1
  135. package/dist/assets/{index-Ub7ss3ID.js → index-CfmUVjcp.js} +1 -1
  136. package/dist/assets/{index-YpXkt_KJ.js → index-CjU5cdO7.js} +1 -1
  137. package/dist/assets/{index-C8DvX3qL.js → index-ClmF6hRq.js} +1 -1
  138. package/dist/assets/{index-B5PvIfC4.js → index-Cncx8-l_.js} +1 -1
  139. package/dist/assets/{index-cJCFIiQJ.js → index-CnleZlCG.js} +1 -1
  140. package/dist/assets/{index-B3mTxs9Y.js → index-CoVdVq1Z.js} +1 -1
  141. package/dist/assets/{index-BshjP0UT.js → index-D6Kzs1Nw.js} +1 -1
  142. package/dist/assets/{index-D4lbSr-T.js → index-D9DK1isc.js} +1 -1
  143. package/dist/assets/{index-ypJPwIOS.js → index-DCbpcMpj.js} +1 -1
  144. package/dist/assets/{index-B1THd-aO.js → index-DHULlsKQ.js} +1 -1
  145. package/dist/assets/{index-DoBI-9N1.js → index-DHnWz_8g.js} +1 -1
  146. package/dist/assets/{index-BCnzh3Xr.js → index-DHoQZLtm.js} +1 -1
  147. package/dist/assets/{index-DD1qoXbO.js → index-DLUXCsx1.js} +1 -1
  148. package/dist/assets/{index-DfpNVEjT.js → index-DMucU6uG.js} +1 -1
  149. package/dist/assets/{index-B72vsB6D.js → index-DXwCOxQx.js} +14 -14
  150. package/dist/assets/{index-Dh2kPrs0.js → index-DZM-NR6G.js} +1 -1
  151. package/dist/assets/{index-ZISytNMe.js → index-DcjROC1z.js} +1 -1
  152. package/dist/assets/{index-CEGyzWWI.js → index-DcjdVEoX.js} +1 -1
  153. package/dist/assets/{index-CGJx6pfn.js → index-DdSlwtcL.js} +1 -1
  154. package/dist/assets/{index-DS__MBdR.js → index-Df15q-se.js} +1 -1
  155. package/dist/assets/{index-BQYPVVtj.js → index-DfM49-13.js} +1 -1
  156. package/dist/assets/{index-CEW9DsqN.js → index-DgEnLOYy.js} +5 -5
  157. package/dist/assets/{index-CcjaGWkK.js → index-Dttr4JHi.js} +1 -1
  158. package/dist/assets/{index-CkEMCLbE.js → index-Gby8YUdT.js} +1 -1
  159. package/dist/assets/{index-Qqh2mgIx.js → index-OKrnShZm.js} +1 -1
  160. package/dist/assets/{index-BTe0Vafw.js → index-Pf9Yjl5V.js} +1 -1
  161. package/dist/assets/{index-BdXdvXDF.js → index-RCOqdLUs.js} +1 -1
  162. package/dist/assets/{index-Cou85JSj.js → index-TEpyQgfK.js} +3 -3
  163. package/dist/assets/{index-D-R1uHlt.js → index-jU7GB09F.js} +1 -1
  164. package/dist/assets/{index-BYv3KnKa.js → index-tZ_Ise3S.js} +1 -1
  165. package/dist/assets/{index-B8517Kq_.js → index-uHPJAWOO.js} +1 -1
  166. package/dist/assets/{index-0tg1OcXL.js → index-uvAG1r2M.js} +1 -1
  167. package/dist/assets/{index-BeuqTSkS.js → index-wIXuMScl.js} +1 -1
  168. package/dist/assets/{index-PWZeMLxN.js → index-y4M9HGmQ.js} +1 -1
  169. package/dist/assets/{index.browser.esm-BqXPSHSK.js → index.browser.esm-D7d8Rln2.js} +1 -1
  170. package/dist/assets/{index.es-B9yw59kn.js → index.es-CGNqC7gi.js} +1 -1
  171. package/dist/assets/{info-MRa9rCfe.js → info-DM9rskjg.js} +1 -1
  172. package/dist/assets/{info-circle-DHJUnSLt.js → info-circle-DlTmoyc5.js} +1 -1
  173. package/dist/assets/{isEqual-9RWKK6ZC.js → isEqual-DBKyqIIt.js} +1 -1
  174. package/dist/assets/{isPlainObject-D782C786.js → isPlainObject-BEU12YqN.js} +1 -1
  175. package/dist/assets/{lightbulb-DSK7zynz.js → lightbulb-DHpQkifU.js} +1 -1
  176. package/dist/assets/{mail-M2oaM6Nj.js → mail-RQ1QwebF.js} +1 -1
  177. package/dist/assets/{midjourney-B13yDVpe.js → midjourney-DtyT0jZS.js} +1 -1
  178. package/dist/assets/{mobile-DeRXzMkq.js → mobile-VdDXMKEH.js} +1 -1
  179. package/dist/assets/{more-CDR2PEkZ.js → more-BE6J6IIj.js} +1 -1
  180. package/dist/assets/{network-placeholder-Ch_TWeDL.js → network-placeholder-Mx5SY88G.js} +1 -1
  181. package/dist/assets/{nftPlaceholder-C7M0Ea0A.js → nftPlaceholder-C7cAVXAB.js} +1 -1
  182. package/dist/assets/{off-BVu_zU6U.js → off-D5KoU2IH.js} +1 -1
  183. package/dist/assets/{order-qF6Pm2MY.js → order-BscwC2FZ.js} +1 -1
  184. package/dist/assets/{pagination-CBYfRJVG.js → pagination-ttqKdzba.js} +1 -1
  185. package/dist/assets/{play-store-sgj5_sA_.js → play-store-NLHYHAzn.js} +1 -1
  186. package/dist/assets/{plus-D7oK-AaE.js → plus-B4X29bak.js} +1 -1
  187. package/dist/assets/{price-BTNYcVQ5.js → price-DpiQB5Yf.js} +1 -1
  188. package/dist/assets/producer-Br_uIp1_.js +7 -0
  189. package/dist/assets/{producer-CRQQOFfj.js → producer-CvNMCVkQ.js} +1 -1
  190. package/dist/assets/producer-Dz_QexIx.js +7 -0
  191. package/dist/assets/{qr-code-BcT7Ar6m.js → qr-code-DeoPDarM.js} +1 -1
  192. package/dist/assets/{recycle-horizontal-CjtP_6AI.js → recycle-horizontal-C8vaKTfu.js} +1 -1
  193. package/dist/assets/{refresh-J0icmcmr.js → refresh-BTBS0EUI.js} +1 -1
  194. package/dist/assets/{reown-logo-Gm4M3etA.js → reown-logo-D682jtgT.js} +1 -1
  195. package/dist/assets/{search-CYAtmvQh.js → search-CLA1DAiY.js} +1 -1
  196. package/dist/assets/{secp256k1-D54YM-Dv.js → secp256k1-C0KaaotE.js} +1 -1
  197. package/dist/assets/{secp256k1-CygyzlO4.js → secp256k1-UQxLo_3_.js} +1 -1
  198. package/dist/assets/{seedream-BnGwXTN0.js → seedream-D8o6AzwQ.js} +1 -1
  199. package/dist/assets/seedream-DcTLW5r2.js +1 -0
  200. package/dist/assets/seedream-rLJUDb-d.js +1 -0
  201. package/dist/assets/{send-D484iT01.js → send-aX_GxPEK.js} +1 -1
  202. package/dist/assets/{service-UlOlaUCA.js → service-Bl8gGQ55.js} +1 -1
  203. package/dist/assets/{solana-wallets-BlkwJPMF.js → solana-wallets-DplP8WdI.js} +2 -2
  204. package/dist/assets/{solana-wallets-vue-DG2aQxVX.js → solana-wallets-vue-Ci7B_C6i.js} +1 -1
  205. package/dist/assets/{suno-C5xsII9n.js → suno-Cx2k0nCv.js} +1 -1
  206. package/dist/assets/{swapHorizontal-C3MXca9V.js → swapHorizontal-C0y88R1i.js} +1 -1
  207. package/dist/assets/{swapHorizontalBold-B55hvlhg.js → swapHorizontalBold-ChU04fWb.js} +1 -1
  208. package/dist/assets/{swapHorizontalMedium-DD_DKTRw.js → swapHorizontalMedium-DJDVePDM.js} +1 -1
  209. package/dist/assets/{swapHorizontalRoundedBold-CZx7flz3.js → swapHorizontalRoundedBold-DX-bndMU.js} +1 -1
  210. package/dist/assets/{swapVertical-Dr4LtnFY.js → swapVertical-AcQg_Wvo.js} +1 -1
  211. package/dist/assets/{telegram-BXetNu8t.js → telegram-Lgnv9Ozw.js} +1 -1
  212. package/dist/assets/{three-dots-BINazGcv.js → three-dots-BWmtbAZ_.js} +1 -1
  213. package/dist/assets/{twitch-MRXoqcJp.js → twitch-DOUAsbJl.js} +1 -1
  214. package/dist/assets/{twitterIcon-Cg3VC0i4.js → twitterIcon-CbBbPa9k.js} +1 -1
  215. package/dist/assets/{typescript-DqAqST2T.js → typescript-BS0psKoU.js} +1 -1
  216. package/dist/assets/{use-form-item-Yq9rpjQi.js → use-form-item-BCHl5hOu.js} +1 -1
  217. package/dist/assets/validator-CmY_SPNn.js +1 -0
  218. package/dist/assets/{verify-BHNcEXgF.js → verify-D8_6usMb.js} +1 -1
  219. package/dist/assets/{verify-filled-du2-p6M5.js → verify-filled-YSomKc90.js} +1 -1
  220. package/dist/assets/{w3m-modal-CzZbiHZk.js → w3m-modal-CjCjnI4-.js} +1 -1
  221. package/dist/assets/{wallet-DuYmXFm1.js → wallet-CQ4eeF60.js} +1 -1
  222. package/dist/assets/{wallet-placeholder-ydE7j-YM.js → wallet-placeholder-BWHCAd0e.js} +1 -1
  223. package/dist/assets/{walletconnect-BjDk5PHK.js → walletconnect-CCdGO7JL.js} +1 -1
  224. package/dist/assets/{warning-circle-CQTu56y4.js → warning-circle-gDsO_gdI.js} +1 -1
  225. package/dist/assets/{web-Byc8UprP.js → web-BIxDucrP.js} +1 -1
  226. package/dist/assets/{web-af7ZvQZT.js → web-VeP6mq4A.js} +1 -1
  227. package/dist/assets/{x-1Jl_JTA4.js → x-DgWe3wGg.js} +1 -1
  228. package/dist/index.html +1 -1
  229. package/package.json +1 -1
  230. package/dist/assets/Index-DMHyDsV2.css +0 -1
  231. package/dist/assets/Index-D_5VDtZe.css +0 -1
  232. package/dist/assets/Index-DjsTZzCq.js +0 -1
  233. package/dist/assets/Index-DwjUaatK.js +0 -1
  234. package/dist/assets/_Uint8Array-DdojeWiA.js +0 -1
  235. package/dist/assets/producer-BpQVWNsN.js +0 -7
  236. package/dist/assets/producer-CmjvX-Jw.js +0 -7
  237. package/dist/assets/seedream-CBaTJXUS.js +0 -1
  238. package/dist/assets/seedream-CXCUm_0w.js +0 -1
  239. package/dist/assets/validator-BOFed1cS.js +0 -1
@@ -1 +1 @@
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
+ import{F as T}from"./index.es-CGNqC7gi.js";import{E as L}from"./index-DdSlwtcL.js";import{E as Z}from"./index-DcjdVEoX.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-DXwCOxQx.js";import{I as C,S as re,l as me}from"./pagination-ttqKdzba.js";import{E as ce}from"./index-Gby8YUdT.js";import{I as B}from"./ImagePreview-B0AGcjB1.js";import{E as ue}from"./index-jU7GB09F.js";import{E as G}from"./index-uvAG1r2M.js";import{C as pe}from"./Consumption-Vrs9Ym-e.js";import{a as de}from"./price-DpiQB5Yf.js";import{E as F,a as H,b as ge}from"./index-BNn6E6CM.js";import{E as he}from"./index-D6Kzs1Nw.js";import{E as fe}from"./index-BZ0LCluE.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as $e}from"./CopyToClipboard-BKPPPZex.js";import{I as be}from"./ImageWrapper-_iiM_a6H.js";import{E as ve}from"./index-C2Ix0O_U.js";import{E as Ee}from"./index-DfM49-13.js";import{E as ke}from"./index-RCOqdLUs.js";import{B as Ie}from"./BotPlaceholder-BEomWKuP.js";import{N as Se}from"./NoTasks-DTEzeszL.js";import"./use-form-item-BCHl5hOu.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-BS0psKoU.js";import"./index-BS0e3mH-.js";import"./index-BFQ7oRfU.js";import"./index-B6H89xyY.js";import"./_baseClone-CdH871Qw.js";import"./_Uint8Array-BXWVuq2q.js";import"./_initCloneObject-BBeThwBy.js";import"./isEqual-DBKyqIIt.js";import"./index-DLUXCsx1.js";import"./strings-beZM2Y-f.js";import"./castArray-CUDnQsIK.js";import"./debounce-DCSodorO.js";import"./_baseIteratee-BD8B7GME.js";import"./index-DZM-NR6G.js";import"./index-Cu41y2Fl.js";import"./validator-CmY_SPNn.js";import"./index-Cncx8-l_.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};
@@ -0,0 +1 @@
1
+ .menu[data-v-5ff0c320]{display:none}@media(max-width:767px){.config[data-v-5ff0c320]{display:none}.result[data-v-5ff0c320]{width:100%}.menu[data-v-5ff0c320]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field .box[data-v-5559520a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-5559520a]{font-size:14px;margin-bottom:10px}.field .info[data-v-5559520a]{margin-left:auto}.field .prompt[data-v-5559520a]{resize:none}.field[data-v-dc18c674]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-dc18c674]{width:30%;display:flex;align-items:center}.field .label .box[data-v-dc18c674]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-dc18c674]{font-size:14px;margin:0}.field .label .box .info[data-v-dc18c674]{margin-left:6px}.field .value[data-v-dc18c674]{width:160px;display:flex;justify-content:flex-end}.field[data-v-609ade55]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-609ade55]{width:30%;display:flex;align-items:center}.field .label .box[data-v-609ade55]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-609ade55]{font-size:14px;margin:0}.field .label .box .info[data-v-609ade55]{margin-left:6px}.field .value[data-v-609ade55]{width:160px}.field[data-v-19b16252]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-19b16252]{width:30%;display:flex;align-items:center}.field .label .box[data-v-19b16252]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-19b16252]{font-size:14px;margin:0}.field .label .box .info[data-v-19b16252]{margin-left:6px}.field .value[data-v-19b16252]{width:200px}.field[data-v-17ef8d1a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-17ef8d1a]{width:30%;display:flex;align-items:center}.field .label .box[data-v-17ef8d1a]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-17ef8d1a]{font-size:14px;margin:0}.field .label .box .info[data-v-17ef8d1a]{margin-left:6px}.field .value[data-v-17ef8d1a]{width:160px;display:flex;justify-content:flex-end}.field .value .counter[data-v-17ef8d1a]{width:140px}.field[data-v-5b43aa5e]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-5b43aa5e]{width:30%;display:flex;align-items:center}.field .label .box[data-v-5b43aa5e]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-5b43aa5e]{font-size:14px;margin:0}.field .label .box .info[data-v-5b43aa5e]{margin-left:6px}.field .value[data-v-5b43aa5e]{width:160px}.field[data-v-240f084b]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-240f084b]{width:30%;display:flex;align-items:center}.field .label .box[data-v-240f084b]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-240f084b]{font-size:14px;margin:0}.field .label .box .info[data-v-240f084b]{margin-left:6px}.field .value[data-v-240f084b]{width:160px;display:flex;justify-content:flex-end}.field .value .counter[data-v-240f084b]{width:140px}.field[data-v-461b9f95]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-461b9f95]{width:30%;display:flex;align-items:center}.field .label .box[data-v-461b9f95]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-461b9f95]{font-size:14px;margin:0}.field .label .box .info[data-v-461b9f95]{margin-left:6px}.field .value[data-v-461b9f95]{width:160px;display:flex;justify-content:flex-end}.field .value .counter[data-v-461b9f95]{width:140px}.field[data-v-9e2abf0f]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .label[data-v-9e2abf0f]{width:30%;display:flex;align-items:center}.field .label .box[data-v-9e2abf0f]{display:flex;flex-direction:row;align-items:center}.field .label .box .title[data-v-9e2abf0f]{font-size:14px;margin:0}.field .label .box .info[data-v-9e2abf0f]{margin-left:6px}.field .value[data-v-9e2abf0f]{width:160px;display:flex;justify-content:flex-end}.preview[data-v-0dfc6a09]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:16px}.preview .left[data-v-0dfc6a09]{width:70px}.preview .left .avatar[data-v-0dfc6a09]{width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-0dfc6a09]{flex:1;width:calc(100% - 70px);min-width:0;padding:10px 10px 0}.preview .main .bot[data-v-0dfc6a09]{font-size:16px;font-weight:700;color:var(--el-color-primary);margin-bottom:0;margin-top:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview .main .bot .datetime[data-v-0dfc6a09]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info[data-v-0dfc6a09]{overflow:hidden}.preview .main .info .prompt[data-v-0dfc6a09]{font-size:16px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:15px;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.preview .main .content[data-v-0dfc6a09]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-0dfc6a09]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-0dfc6a09]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-0dfc6a09]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-0dfc6a09]{border-color:var(--el-color-info)}.preview .main .operations[data-v-0dfc6a09]{display:flex;justify-content:left;flex-direction:row;width:100%;align-items:baseline;flex-wrap:wrap;overflow:hidden;text-align:center;color:var(--el-text-color-regular);font-size:14px}.preview .main .operations .btn-action[data-v-0dfc6a09]{margin-bottom:10px}
@@ -1 +1 @@
1
- import{F as L}from"./index.es-B9yw59kn.js";import{E}from"./index-CGJx6pfn.js";import{E as R}from"./index-CEGyzWWI.js";import{d as b,H as i,E as r,z as T,C as t,y as u,D as a,q as s,F as o,O as C,N as G,x as v,I as d,J as m,M as A,Q as S}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as M,cr as D,aR as j,S as U,cs as B}from"./index-B72vsB6D.js";import{a as q}from"./hailuo-C8Dw-0xR.js";import{E as F,a as O}from"./index-DCc5mWT3.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as N,l as H}from"./pagination-CBYfRJVG.js";import{I as J}from"./ImagePreview-CUOTVDKq.js";import{E as K}from"./index-D-R1uHlt.js";import{E as V}from"./index-0tg1OcXL.js";import{E as Q}from"./index-CkEMCLbE.js";import{C as W}from"./Consumption-D9Hn2ImE.js";import{a as X}from"./price-BTNYcVQ5.js";import{b as Y}from"./errorCode-Cqj9Td_Z.js";import{C as Z}from"./CopyToClipboard-YKue_6LC.js";import{V as x}from"./VideoPlayer-DPmqjyk_.js";import{E as ee}from"./index-BiORZ5ee.js";import{E as te}from"./index-BQYPVVtj.js";import{E as oe}from"./index-BdXdvXDF.js";import{B as se}from"./BotPlaceholder-BLqNsw9k.js";import{N as ae}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 ne=b({name:"LayoutHailuo",components:{ElDrawer:R,ElButton:E,FontAwesomeIcon:L},data(){return{drawer:!1}}}),le={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},re={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ce(e,n,f,g,w,y){const p=a("font-awesome-icon"),h=a("el-button"),c=a("el-drawer");return s(),i("div",le,[r("div",ie,[T(e.$slots,"config",{},void 0,!0)]),r("div",re,[T(e.$slots,"result",{},void 0,!0)]),t(h,{circle:"",class:"menu",onClick:n[0]||(n[0]=_=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(c,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=k(ne,[["render",ce],["__scopeId","data-v-fa61db7a"]]),de=b({name:"ModelSelector",components:{ElSelect:O,ElOption:F},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")},{value:"minimax-i2v-director",label:this.$t("hailuo.button.model3")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=q)}}),me={class:"field"},pe={class:"title font-bold"},he={class:"float-left"};function fe(e,n,f,g,w,y){const p=a("el-option"),h=a("el-select");return s(),i("div",me,[r("h2",pe,o(e.$t("hailuo.name.model")),1),t(h,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=c=>e.value=c),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:u(()=>[(s(!0),i(C,null,G(e.options,c=>(s(),v(p,{key:c.value,label:c.label,value:c.value},{default:u(()=>[r("span",he,o(c.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=k(de,[["render",fe],["__scopeId","data-v-a768fbd9"]]),_e=b({name:"StartImageUrlInput",components:{ElUpload:K,ElButton:E,InfoIcon:P,ImagePreview:J},mixins:[z],data(){return{fileList:[],uploadUrl:M()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){V.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),$e={class:"relative"},ve={class:"flex justify-between"},be={class:"flex justify-start items-center"},ke={class:"text-sm font-bold"};function we(e,n,f,g,w,y){const p=a("info-icon"),h=a("image-preview"),c=a("el-button"),_=a("el-upload");return s(),i("div",$e,[r("div",ve,[r("div",be,[r("span",ke,o(e.$t("hailuo.name.startImageUrl")),1),t(p,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(_,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=l=>e.fileList=l),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:l})=>[l.url&&l.percentage!==void 0?(s(),v(h,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:$=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:u(()=>[t(c,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:u(()=>[d(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const ye=k(_e,[["render",we],["__scopeId","data-v-48f4a681"]]),Ve="",Ee=b({name:"PromptInput",components:{ElInput:Q,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ve)}}),Se={class:"field"},Ie={class:"box"},Te={class:"title font-bold"};function Ce(e,n,f,g,w,y){const p=a("info-icon"),h=a("el-input");return s(),i("div",Se,[r("div",Ie,[r("h2",Te,o(e.$t("hailuo.name.prompt")),1),t(p,{content:e.$t("hailuo.description.prompt"),class:"info"},null,8,["content"])]),t(h,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=c=>e.prompt=c),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Le=k(Ee,[["render",Ce],["__scopeId","data-v-c601bcba"]]),Ue=b({name:"PresetPanel",components:{ElButton:E,FontAwesomeIcon:L,PromptInput:Le,StartImageUrlInput:ye,ModelSelector:ge,Consumption:W},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return X(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ge={class:"flex flex-col h-full"},Pe={class:"flex-1 overflow-y-auto p-5"},Re={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ae(e,n,f,g,w,y){const p=a("prompt-input"),h=a("model-selector"),c=a("start-image-url-input"),_=a("consumption"),l=a("font-awesome-icon"),$=a("el-button");return s(),i("div",Ge,[r("div",Pe,[t(p,{class:"mb-4"}),t(h,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),v(c,{key:0,class:"mb-2"})):m("",!0)]),r("div",Re,[t(_,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),v($,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),d(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),v($,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),d(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Me=k(Ue,[["render",Ae]]),De=b({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:L,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:E},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),je={class:"preview"},Be={class:"left"},qe={class:"main"},Fe={class:"bot"},Oe={class:"datetime"},ze={class:"info"},Ne={key:0,class:"prompt mt-2"},He={key:0},Je={key:1},Ke={key:0,class:S({content:!0,failed:!0})},Qe={key:0,class:"mb-4"},We={key:1,class:S({operations:!0,"mt-2":!0})},Xe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ye={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ze={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},xe={key:1,class:S({content:!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},st={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},at={key:2,class:S({content:!0})},nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function lt(e,n,f,g,w,y){const p=a("el-image"),h=a("video-player"),c=a("el-button"),_=a("el-tooltip"),l=a("font-awesome-icon"),$=a("copy-to-clipboard"),I=a("el-alert");return s(),i("div",je,[r("div",Be,[t(p,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",qe,[r("div",Fe,[d(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Oe,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",ze,[e.modelValue?.request?.prompt?(s(),i("p",Ne,[d(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),i("span",He," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),i("span",Je," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),i("div",Ke,[e.video?.video_url?(s(),i("div",Qe,[t(h,{src:e.video?.video_url},null,8,["src"])])):m("",!0),e.video?(s(),i("div",We,[t(_,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.video?.video_url?(s(),v(c,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=A(gt=>e.onDownload(e.video?.video_url),["stop"]))},{default:u(()=>[d(o(e.$t("hailuo.button.download")),1)]),_:1})):m("",!0)]),_:1},8,["content"])])):m("",!0),t(I,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(s(),i("p",Xe,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),r("p",Ye,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),i("p",Ze,[t(l,{icon:"fa-solid fa-clock",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),i("div",xe,[t(I,{closable:!1,class:"failure"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failure")),1)]),default:u(()=>[r("p",et,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),r("p",tt,[t(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t($,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),i("p",ot,[t(l,{icon:"fa-solid fa-clock",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),r("p",st,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t($,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),i("div",at,[t(I,{closable:!1,class:"info"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failure")),1)]),default:u(()=>[r("p",nt,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const it=k(De,[["render",lt],["__scopeId","data-v-1ff65585"]]),rt=b({name:"RecentPanel",components:{TaskPreview:it,BotPlaceholder:se,NoTasks:ae,ScrollList:N},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ct={key:0},ut={key:2,class:"w-full h-full flex items-center justify-center"};function dt(e,n,f,g,w,y){const p=a("bot-placeholder"),h=a("task-preview"),c=a("scroll-list"),_=a("no-tasks");return s(),i(C,null,[e.tasks?.items===void 0?(s(),i("div",ct,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),v(c,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=l=>e.$emit("reach-top"))},{default:u(()=>[(s(!0),i(C,null,G(e.tasks?.items,l=>(s(),v(h,{key:l.id,"model-value":l},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),i("div",ut,[t(_)])):m("",!0)],64)}const mt=k(rt,[["render",dt]]),pt=B("hailuo"),ht=b({name:"HailuoIndex",components:{ConfigPanel:Me,Layout:ue,RecentPanel:mt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await H({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("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:f,createdAtMax:g}=e||{};console.debug("limit",n,"createdAtMin",f,"createdAtMax",g),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:f,createdAtMax:g})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:pt},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("hailuo.message.startingTask")),D("hailuo",j.generate(e,{token:n})).then(()=>{V.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===Y?V.error(this.$t("hailuo.message.usedUp")):V.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ft(e,n,f,g,w,y){const p=a("config-panel"),h=a("recent-panel"),c=a("layout");return s(),v(c,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(h,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const io=k(ht,[["render",ft]]);export{io as default};
1
+ import{F as L}from"./index.es-CGNqC7gi.js";import{E}from"./index-DdSlwtcL.js";import{E as R}from"./index-DcjdVEoX.js";import{d as b,H as i,E as r,z as T,C as t,y as u,D as a,q as s,F as o,O as C,N as G,x as v,I as d,J as m,M as A,Q as S}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as M,cr as D,aR as j,S as U,cs as B}from"./index-DXwCOxQx.js";import{a as q}from"./hailuo-C8Dw-0xR.js";import{E as F,a as O}from"./index-BNn6E6CM.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as N,l as H}from"./pagination-ttqKdzba.js";import{I as J}from"./ImagePreview-B0AGcjB1.js";import{E as K}from"./index-jU7GB09F.js";import{E as V}from"./index-uvAG1r2M.js";import{E as Q}from"./index-Gby8YUdT.js";import{C as W}from"./Consumption-Vrs9Ym-e.js";import{a as X}from"./price-DpiQB5Yf.js";import{b as Y}from"./errorCode-Cqj9Td_Z.js";import{C as Z}from"./CopyToClipboard-BKPPPZex.js";import{V as x}from"./VideoPlayer-DLqpJWFk.js";import{E as ee}from"./index-C2Ix0O_U.js";import{E as te}from"./index-DfM49-13.js";import{E as oe}from"./index-RCOqdLUs.js";import{B as se}from"./BotPlaceholder-BEomWKuP.js";import{N as ae}from"./NoTasks-DTEzeszL.js";import"./use-form-item-BCHl5hOu.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-DLUXCsx1.js";import"./typescript-BS0psKoU.js";import"./index-BS0e3mH-.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBKyqIIt.js";import"./_Uint8Array-BXWVuq2q.js";import"./castArray-CUDnQsIK.js";import"./debounce-DCSodorO.js";import"./_baseIteratee-BD8B7GME.js";import"./index-DZM-NR6G.js";import"./index-B6H89xyY.js";import"./_baseClone-CdH871Qw.js";import"./_initCloneObject-BBeThwBy.js";import"./index-BFQ7oRfU.js";import"./vue-plyr-BO2nlN4c.js";import"./index-Cncx8-l_.js";const ne=b({name:"LayoutHailuo",components:{ElDrawer:R,ElButton:E,FontAwesomeIcon:L},data(){return{drawer:!1}}}),le={class:"main flex flex-row flex-1"},ie={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},re={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ce(e,n,f,g,w,y){const p=a("font-awesome-icon"),h=a("el-button"),c=a("el-drawer");return s(),i("div",le,[r("div",ie,[T(e.$slots,"config",{},void 0,!0)]),r("div",re,[T(e.$slots,"result",{},void 0,!0)]),t(h,{circle:"",class:"menu",onClick:n[0]||(n[0]=_=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(c,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=k(ne,[["render",ce],["__scopeId","data-v-fa61db7a"]]),de=b({name:"ModelSelector",components:{ElSelect:O,ElOption:F},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")},{value:"minimax-i2v-director",label:this.$t("hailuo.button.model3")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=q)}}),me={class:"field"},pe={class:"title font-bold"},he={class:"float-left"};function fe(e,n,f,g,w,y){const p=a("el-option"),h=a("el-select");return s(),i("div",me,[r("h2",pe,o(e.$t("hailuo.name.model")),1),t(h,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=c=>e.value=c),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:u(()=>[(s(!0),i(C,null,G(e.options,c=>(s(),v(p,{key:c.value,label:c.label,value:c.value},{default:u(()=>[r("span",he,o(c.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=k(de,[["render",fe],["__scopeId","data-v-a768fbd9"]]),_e=b({name:"StartImageUrlInput",components:{ElUpload:K,ElButton:E,InfoIcon:P,ImagePreview:J},mixins:[z],data(){return{fileList:[],uploadUrl:M()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){V.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),$e={class:"relative"},ve={class:"flex justify-between"},be={class:"flex justify-start items-center"},ke={class:"text-sm font-bold"};function we(e,n,f,g,w,y){const p=a("info-icon"),h=a("image-preview"),c=a("el-button"),_=a("el-upload");return s(),i("div",$e,[r("div",ve,[r("div",be,[r("span",ke,o(e.$t("hailuo.name.startImageUrl")),1),t(p,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(_,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=l=>e.fileList=l),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:l})=>[l.url&&l.percentage!==void 0?(s(),v(h,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:$=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:u(()=>[t(c,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:u(()=>[d(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const ye=k(_e,[["render",we],["__scopeId","data-v-48f4a681"]]),Ve="",Ee=b({name:"PromptInput",components:{ElInput:Q,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ve)}}),Se={class:"field"},Ie={class:"box"},Te={class:"title font-bold"};function Ce(e,n,f,g,w,y){const p=a("info-icon"),h=a("el-input");return s(),i("div",Se,[r("div",Ie,[r("h2",Te,o(e.$t("hailuo.name.prompt")),1),t(p,{content:e.$t("hailuo.description.prompt"),class:"info"},null,8,["content"])]),t(h,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=c=>e.prompt=c),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Le=k(Ee,[["render",Ce],["__scopeId","data-v-c601bcba"]]),Ue=b({name:"PresetPanel",components:{ElButton:E,FontAwesomeIcon:L,PromptInput:Le,StartImageUrlInput:ye,ModelSelector:ge,Consumption:W},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return X(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ge={class:"flex flex-col h-full"},Pe={class:"flex-1 overflow-y-auto p-5"},Re={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ae(e,n,f,g,w,y){const p=a("prompt-input"),h=a("model-selector"),c=a("start-image-url-input"),_=a("consumption"),l=a("font-awesome-icon"),$=a("el-button");return s(),i("div",Ge,[r("div",Pe,[t(p,{class:"mb-4"}),t(h,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),v(c,{key:0,class:"mb-2"})):m("",!0)]),r("div",Re,[t(_,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),v($,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),d(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),v($,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),d(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Me=k(Ue,[["render",Ae]]),De=b({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:L,ElAlert:te,VideoPlayer:x,ElTooltip:ee,ElButton:E},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),je={class:"preview"},Be={class:"left"},qe={class:"main"},Fe={class:"bot"},Oe={class:"datetime"},ze={class:"info"},Ne={key:0,class:"prompt mt-2"},He={key:0},Je={key:1},Ke={key:0,class:S({content:!0,failed:!0})},Qe={key:0,class:"mb-4"},We={key:1,class:S({operations:!0,"mt-2":!0})},Xe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ye={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ze={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},xe={key:1,class:S({content:!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},st={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},at={key:2,class:S({content:!0})},nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function lt(e,n,f,g,w,y){const p=a("el-image"),h=a("video-player"),c=a("el-button"),_=a("el-tooltip"),l=a("font-awesome-icon"),$=a("copy-to-clipboard"),I=a("el-alert");return s(),i("div",je,[r("div",Be,[t(p,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",qe,[r("div",Fe,[d(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Oe,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",ze,[e.modelValue?.request?.prompt?(s(),i("p",Ne,[d(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),i("span",He," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),i("span",Je," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),i("div",Ke,[e.video?.video_url?(s(),i("div",Qe,[t(h,{src:e.video?.video_url},null,8,["src"])])):m("",!0),e.video?(s(),i("div",We,[t(_,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.video?.video_url?(s(),v(c,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=A(gt=>e.onDownload(e.video?.video_url),["stop"]))},{default:u(()=>[d(o(e.$t("hailuo.button.download")),1)]),_:1})):m("",!0)]),_:1},8,["content"])])):m("",!0),t(I,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(s(),i("p",Xe,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),r("p",Ye,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),i("p",Ze,[t(l,{icon:"fa-solid fa-clock",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),i("div",xe,[t(I,{closable:!1,class:"failure"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failure")),1)]),default:u(()=>[r("p",et,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),r("p",tt,[t(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t($,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),i("p",ot,[t(l,{icon:"fa-solid fa-clock",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),r("p",st,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t($,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),i("div",at,[t(I,{closable:!1,class:"info"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.failure")),1)]),default:u(()=>[r("p",nt,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),d(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const it=k(De,[["render",lt],["__scopeId","data-v-1ff65585"]]),rt=b({name:"RecentPanel",components:{TaskPreview:it,BotPlaceholder:se,NoTasks:ae,ScrollList:N},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ct={key:0},ut={key:2,class:"w-full h-full flex items-center justify-center"};function dt(e,n,f,g,w,y){const p=a("bot-placeholder"),h=a("task-preview"),c=a("scroll-list"),_=a("no-tasks");return s(),i(C,null,[e.tasks?.items===void 0?(s(),i("div",ct,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),v(c,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=l=>e.$emit("reach-top"))},{default:u(()=>[(s(!0),i(C,null,G(e.tasks?.items,l=>(s(),v(h,{key:l.id,"model-value":l},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),i("div",ut,[t(_)])):m("",!0)],64)}const mt=k(rt,[["render",dt]]),pt=B("hailuo"),ht=b({name:"HailuoIndex",components:{ConfigPanel:Me,Layout:ue,RecentPanel:mt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await H({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("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:f,createdAtMax:g}=e||{};console.debug("limit",n,"createdAtMin",f,"createdAtMax",g),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:f,createdAtMax:g})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:pt},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("hailuo.message.startingTask")),D("hailuo",j.generate(e,{token:n})).then(()=>{V.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===Y?V.error(this.$t("hailuo.message.usedUp")):V.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ft(e,n,f,g,w,y){const p=a("config-panel"),h=a("recent-panel"),c=a("layout");return s(),v(c,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(h,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const io=k(ht,[["render",ft]]);export{io as default};
@@ -0,0 +1 @@
1
+ .menu[data-v-7453886f]{display:none}@media(max-width:767px){.main .config[data-v-7453886f]{display:none}.main .result[data-v-7453886f]{width:100%}.main .preview[data-v-7453886f]{display:none}.main .menu[data-v-7453886f]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.model-option[data-v-42496b9a]{display:flex;align-items:center;justify-content:space-between;width:100%;padding:2px 0}.model-option-name[data-v-42496b9a]{font-weight:500}.model-option-desc[data-v-42496b9a]{font-size:12px;color:var(--el-text-color-placeholder);margin-left:8px;white-space:nowrap}.upload-wrapper.inline-upload[data-v-355e932b] .el-upload{display:inline-flex}.field[data-v-88c6da2b] .el-textarea__inner{font-family:monospace;line-height:1.6}.field .box[data-v-26d43480]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative;margin-bottom:10px}.field .box .title[data-v-26d43480]{font-size:14px;margin-bottom:10px}.field .box .input-wrapper[data-v-26d43480]{width:150px;margin-left:30px}.field .box[data-v-d8a8e583]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative;margin-bottom:10px}.field .box .title[data-v-d8a8e583]{font-size:14px;margin-bottom:10px}.field .box .input-wrapper[data-v-d8a8e583]{width:150px;margin-left:30px}.advanced-collapse[data-v-44ad862b]{border:none}.advanced-collapse[data-v-44ad862b] .el-collapse-item__header{font-size:14px;font-weight:700;background:transparent;border:none;height:32px;line-height:32px}.advanced-collapse[data-v-44ad862b] .el-collapse-item__wrap{background:transparent;border:none}.advanced-collapse[data-v-44ad862b] .el-collapse-item__content{padding-bottom:0}.producer-mode-tabs[data-v-4a4b209e] .el-tabs__nav-wrap:after{height:1px}.producer-mode-tabs[data-v-4a4b209e] .el-tabs__item{font-size:14px;font-weight:500}.task{display:flex;flex-direction:column;cursor:pointer}.task .audio{display:flex;margin-bottom:10px;border-radius:10px}.task .audio:hover{background-color:var(--el-bg-color-page)}.task .audio .left{position:relative;width:60px;height:60px;margin-right:16px;flex-shrink:0}.task .audio .left:hover .overlay{display:block}.task .audio .left .cover{width:100%;height:100%;border-radius:4px}.task .audio .left .duration{position:absolute;right:0;bottom:0;background-color:#000000b3;padding:2px 4px;color:#fff;border-radius:2px;font-size:10px}.task .audio .left .overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;display:none;transition:opacity .3s;border-radius:4px;text-align:center;line-height:70px;cursor:pointer}.task .audio .left .overlay .el-icon{font-size:20px;color:#fff}.task .audio .info{flex:1;min-width:0;overflow:hidden}.task .audio .info .title{font-size:14px;font-weight:700;margin-top:5px;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.task .audio .info .style{font-size:12px;margin-bottom:0;color:var(--el-text-color-secondary);white-space:normal;word-break:break-word;overflow-wrap:anywhere}.task .audio .right{width:120px;display:flex;align-items:center;justify-content:flex-end;padding-right:1px}.task .audio .right .icon{display:block;z-index:100;cursor:pointer;margin-right:15px}.task .audio .right .el-button{margin-right:15px}.player-slider .el-slider{height:10px}.player-slider .el-slider .el-slider__runway,.player-slider .el-slider .el-slider__bar{height:2px;border-radius:0}.player-slider .el-slider .el-slider__button-wrapper{width:10px;height:10px;top:-10.5px}.player-slider .el-slider .el-slider__button{width:8px;height:8px}.el-popover.el-popper{min-width:auto}.status[data-v-d6806962]{margin-bottom:10px}.panel.detail[data-v-d6806962]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-d6806962]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-d6806962]{position:relative}
@@ -1 +1 @@
1
- import{F as C}from"./index.es-B9yw59kn.js";import{E as T}from"./index-CGJx6pfn.js";import{E as M}from"./index-CEGyzWWI.js";import{d as v,H as r,E as c,z as L,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as U}from"./vendor-vue-NSDaktjZ.js";import{G as w,bl as j,cr as B,b4 as F,S as D,cs as N}from"./index-B72vsB6D.js";import{a as q,b as z}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-DCc5mWT3.js";import{p as W}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as H,l as J}from"./pagination-CBYfRJVG.js";import{I as K}from"./ImagePreview-CUOTVDKq.js";import{E as Q}from"./index-D-R1uHlt.js";import{E as V}from"./index-0tg1OcXL.js";import{E as X}from"./index-CkEMCLbE.js";import{C as Y}from"./Consumption-D9Hn2ImE.js";import{a as Z}from"./price-BTNYcVQ5.js";import{b as x}from"./errorCode-Cqj9Td_Z.js";import{C as ee}from"./CopyToClipboard-YKue_6LC.js";import{V as te}from"./VideoPlayer-DPmqjyk_.js";import{E as oe}from"./index-BiORZ5ee.js";import{E as se}from"./index-BQYPVVtj.js";import{E as ne}from"./index-BdXdvXDF.js";import{B as ae}from"./BotPlaceholder-BLqNsw9k.js";import{N as le}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 re=v({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ie={class:"main flex flex-row flex-1"},ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},de={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ue(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",ie,[c("div",ce,[L(e.$slots,"config",{},void 0,!0)]),c("div",de,[L(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=w(re,[["render",ue],["__scopeId","data-v-98681d9b"]]),me=v({name:"ModelSelector",components:{ElSelect:G,ElOption:R},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=q)}}),fe={class:"field"},he={class:"title font-bold"},_e={class:"float-left"};function ge(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",fe,[c("h2",he,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",_e,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const $e=w(me,[["render",ge],["__scopeId","data-v-eb090beb"]]),ve="720p",we=v({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ve)}}),be={class:"field"},ke={class:"title font-bold"},ye={class:"float-left"};function Ve(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",be,[c("h2",ke,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ye,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=w(we,[["render",Ve],["__scopeId","data-v-3e39f44e"]]),Ie=5,Te=v({name:"DurationSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ie)}}),Se={class:"field"},Ue={class:"title font-bold"},Le={class:"float-left"};function Ce(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Se,[c("h2",Ue,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=w(Te,[["render",Ce],["__scopeId","data-v-5f35a2cf"]]),Ge=v({name:"ImageUrlInput",components:{ElUpload:Q,ElButton:T,InfoIcon:P,ImagePreview:K},mixins:[W],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ae={class:"relative"},De={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},Me={class:"text-sm font-bold"};function Oe(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ae,[c("div",De,[c("div",Pe,[c("span",Me,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=w(Ge,[["render",Oe],["__scopeId","data-v-c9ebe1b1"]]),Be="",Fe=v({name:"PromptInput",components:{ElInput:X,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Be)}}),Ne={class:"field"},qe={class:"box"},ze={class:"title font-bold"};function We(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Ne,[c("div",qe,[c("h2",ze,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const He=w(Fe,[["render",We],["__scopeId","data-v-45557a2d"]]),Je=v({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:He,ImageUrlInput:je,ModelSelector:$e,ResolutionSelector:Ee,DurationSelector:Re,Consumption:Y},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Z(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Ke,[c("div",Qe,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Xe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ze=w(Je,[["render",Ye]]),xe=v({name:"TaskPreview",components:{ElImage:ne,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:se,VideoPlayer:te,ElTooltip:oe,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:z}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},nt={class:"datetime"},at={class:"info"},lt={key:0,class:"prompt mt-2"},rt={key:0},it={key:1},ct={key:0,class:U({content:!0,failed:!0})},dt={key:0,class:"mb-4"},ut={key:1,class:U({operations:!0,"mt-2":!0})},pt={key:0,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:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:U({content:!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:U({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function kt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",et,[c("div",tt,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",ot,[c("div",st,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",nt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",at,[e.modelValue?.request?.prompt?(s(),r("p",lt,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",rt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",it," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",ct,[e.modelValue?.response?.video_url?(s(),r("div",dt,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",ut,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",pt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",mt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ft,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ht,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",_t,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",gt,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",$t,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",vt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",bt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const yt=w(xe,[["render",kt],["__scopeId","data-v-6d1d636e"]]),Vt=v({name:"RecentPanel",components:{TaskPreview:yt,BotPlaceholder:ae,NoTasks:le,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(g)])):m("",!0)],64)}const St=w(Vt,[["render",Tt]]),Ut=N("wan"),Lt=v({name:"WanIndex",components:{ConfigPanel:Ze,Layout:pe,RecentPanel:St},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await J({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",F.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===x?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ct(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const yo=w(Lt,[["render",Ct]]);export{yo as default};
1
+ import{F as C}from"./index.es-CGNqC7gi.js";import{E as T}from"./index-DdSlwtcL.js";import{E as M}from"./index-DcjdVEoX.js";import{d as v,H as r,E as c,z as L,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as U}from"./vendor-vue-NSDaktjZ.js";import{G as w,bl as j,cr as B,b4 as F,S as D,cs as N}from"./index-DXwCOxQx.js";import{a as q,b as z}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-BNn6E6CM.js";import{p as W}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as H,l as J}from"./pagination-ttqKdzba.js";import{I as K}from"./ImagePreview-B0AGcjB1.js";import{E as Q}from"./index-jU7GB09F.js";import{E as V}from"./index-uvAG1r2M.js";import{E as X}from"./index-Gby8YUdT.js";import{C as Y}from"./Consumption-Vrs9Ym-e.js";import{a as Z}from"./price-DpiQB5Yf.js";import{b as x}from"./errorCode-Cqj9Td_Z.js";import{C as ee}from"./CopyToClipboard-BKPPPZex.js";import{V as te}from"./VideoPlayer-DLqpJWFk.js";import{E as oe}from"./index-C2Ix0O_U.js";import{E as se}from"./index-DfM49-13.js";import{E as ne}from"./index-RCOqdLUs.js";import{B as ae}from"./BotPlaceholder-BEomWKuP.js";import{N as le}from"./NoTasks-DTEzeszL.js";import"./use-form-item-BCHl5hOu.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-DLUXCsx1.js";import"./typescript-BS0psKoU.js";import"./index-BS0e3mH-.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBKyqIIt.js";import"./_Uint8Array-BXWVuq2q.js";import"./castArray-CUDnQsIK.js";import"./debounce-DCSodorO.js";import"./_baseIteratee-BD8B7GME.js";import"./index-DZM-NR6G.js";import"./index-B6H89xyY.js";import"./_baseClone-CdH871Qw.js";import"./_initCloneObject-BBeThwBy.js";import"./index-BFQ7oRfU.js";import"./vue-plyr-BO2nlN4c.js";import"./index-Cncx8-l_.js";const re=v({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ie={class:"main flex flex-row flex-1"},ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},de={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ue(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",ie,[c("div",ce,[L(e.$slots,"config",{},void 0,!0)]),c("div",de,[L(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=w(re,[["render",ue],["__scopeId","data-v-98681d9b"]]),me=v({name:"ModelSelector",components:{ElSelect:G,ElOption:R},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=q)}}),fe={class:"field"},he={class:"title font-bold"},_e={class:"float-left"};function ge(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",fe,[c("h2",he,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",_e,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const $e=w(me,[["render",ge],["__scopeId","data-v-eb090beb"]]),ve="720p",we=v({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ve)}}),be={class:"field"},ke={class:"title font-bold"},ye={class:"float-left"};function Ve(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",be,[c("h2",ke,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ye,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=w(we,[["render",Ve],["__scopeId","data-v-3e39f44e"]]),Ie=5,Te=v({name:"DurationSelector",components:{ElSelect:G,ElOption:R},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ie)}}),Se={class:"field"},Ue={class:"title font-bold"},Le={class:"float-left"};function Ce(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Se,[c("h2",Ue,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=w(Te,[["render",Ce],["__scopeId","data-v-5f35a2cf"]]),Ge=v({name:"ImageUrlInput",components:{ElUpload:Q,ElButton:T,InfoIcon:P,ImagePreview:K},mixins:[W],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ae={class:"relative"},De={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},Me={class:"text-sm font-bold"};function Oe(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ae,[c("div",De,[c("div",Pe,[c("span",Me,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=w(Ge,[["render",Oe],["__scopeId","data-v-c9ebe1b1"]]),Be="",Fe=v({name:"PromptInput",components:{ElInput:X,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Be)}}),Ne={class:"field"},qe={class:"box"},ze={class:"title font-bold"};function We(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Ne,[c("div",qe,[c("h2",ze,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const He=w(Fe,[["render",We],["__scopeId","data-v-45557a2d"]]),Je=v({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:He,ImageUrlInput:je,ModelSelector:$e,ResolutionSelector:Ee,DurationSelector:Re,Consumption:Y},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Z(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Ke,[c("div",Qe,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Xe,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ze=w(Je,[["render",Ye]]),xe=v({name:"TaskPreview",components:{ElImage:ne,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:se,VideoPlayer:te,ElTooltip:oe,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:z}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},nt={class:"datetime"},at={class:"info"},lt={key:0,class:"prompt mt-2"},rt={key:0},it={key:1},ct={key:0,class:U({content:!0,failed:!0})},dt={key:0,class:"mb-4"},ut={key:1,class:U({operations:!0,"mt-2":!0})},pt={key:0,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:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:U({content:!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:U({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function kt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",et,[c("div",tt,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",ot,[c("div",st,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",nt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",at,[e.modelValue?.request?.prompt?(s(),r("p",lt,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",rt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",it," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",ct,[e.modelValue?.response?.video_url?(s(),r("div",dt,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",ut,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",pt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",mt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ft,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ht,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",_t,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",gt,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",$t,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",vt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",wt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",bt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const yt=w(xe,[["render",kt],["__scopeId","data-v-6d1d636e"]]),Vt=v({name:"RecentPanel",components:{TaskPreview:yt,BotPlaceholder:ae,NoTasks:le,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(g)])):m("",!0)],64)}const St=w(Vt,[["render",Tt]]),Ut=N("wan"),Lt=v({name:"WanIndex",components:{ConfigPanel:Ze,Layout:pe,RecentPanel:St},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await J({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",F.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===x?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ct(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const yo=w(Lt,[["render",Ct]]);export{yo as default};
@@ -0,0 +1 @@
1
+ import{F as z}from"./index.es-CGNqC7gi.js";import{E as W}from"./index-DdSlwtcL.js";import{E as le}from"./index-DcjdVEoX.js";import{d as k,H as u,E as s,z as B,C as o,y as l,D as n,q as r,F as a,O as G,N as q,J as _,x as b,I as C,G as j,K as H,M as E,u as A,c as F,w as ce,L as de}from"./vendor-vue-NSDaktjZ.js";import{G as S,bl as ue,eH as X,eI as Y,X as K,J as pe,S as L,cs as se,eJ as R,eK as me,cr as fe,n as _e}from"./index-DXwCOxQx.js";import{a as he}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-CvNMCVkQ.js";import{I as T,S as $e,l as ge}from"./pagination-ttqKdzba.js";import{b as ve}from"./producer-DP85fuAq.js";import{E as ye}from"./index-BZ0LCluE.js";import{E as be,a as ke}from"./index-BNn6E6CM.js";import{E as ne,a as re}from"./index-BgIT6hC5.js";import{E as we}from"./index-jU7GB09F.js";import{E as w}from"./index-uvAG1r2M.js";import{E as Z}from"./index-Gby8YUdT.js";import{u as D,F as Ce,O as Ve,_ as oe,P as Se,a as Ue,V as Pe,E as Ee}from"./IconPark.vue_vue_type_script_setup_true_lang-ksQMUIfc.js";import{E as Q}from"./index-D6Kzs1Nw.js";import{E as N}from"./index-RCOqdLUs.js";import{E as x}from"./index-CfNLp6F4.js";import{E as Ae,a as Te}from"./index-uHPJAWOO.js";import{C as Fe}from"./Consumption-Vrs9Ym-e.js";import{a as Ie}from"./price-DpiQB5Yf.js";import{E as Le,a as Ge}from"./index-wIXuMScl.js";import{E as De,b as ze,a as je}from"./index-Pf9Yjl5V.js";import{E as Re}from"./index-C2Ix0O_U.js";import{E as Ze}from"./index-CajQSidV.js";import{N as Ne}from"./NoTasks-DTEzeszL.js";import{a as Me,E as Oe}from"./index-Cncx8-l_.js";import"./use-form-item-BCHl5hOu.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-CmY_SPNn.js";import"./index-BS0e3mH-.js";import"./index-DLUXCsx1.js";import"./typescript-BS0psKoU.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBKyqIIt.js";import"./_Uint8Array-BXWVuq2q.js";import"./castArray-CUDnQsIK.js";import"./debounce-DCSodorO.js";import"./_baseIteratee-BD8B7GME.js";import"./index-DZM-NR6G.js";import"./index-B6H89xyY.js";import"./_baseClone-CdH871Qw.js";import"./_initCloneObject-BBeThwBy.js";import"./index-BFQ7oRfU.js";import"./index-Cu41y2Fl.js";import"./index-Dttr4JHi.js";import"./isPlainObject-BEU12YqN.js";import"./dropdown-BDLqMJ6c.js";const Be=k({name:"LayoutProducer",components:{ElDrawer:le,ElButton:W,FontAwesomeIcon:z},data(){return{drawer:!1,preview:!1}},computed:{}}),qe={class:"main flex flex-row flex-1"},We={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},He={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Ke={class:"preview h-full w-[300px] flex flex-col"};function Je(e,t,d,i,h,p){const c=n("font-awesome-icon"),m=n("el-button"),f=n("el-drawer");return r(),u("div",qe,[s("div",We,[B(e.$slots,"config",{},void 0,!0)]),s("div",He,[B(e.$slots,"result",{},void 0,!0)]),s("div",Ke,[B(e.$slots,"preview",{},void 0,!0)]),o(m,{circle:"",class:"menu",onClick:t[0]||(t[0]=y=>e.drawer=!0)},{default:l(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=y=>e.drawer=y),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:l(()=>[B(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Xe=S(Be,[["render",Je],["__scopeId","data-v-7453886f"]]),Ye=k({name:"TypeSelector",components:{ElSelect:ke,ElOption:be,ElSwitch:ye,InfoIcon:T},data(){return{options:[{label:"FUZZ-2.0 Pro",value:"FUZZ-2.0 Pro",desc:this.$t("producer.model.fuzz20proDesc")},{label:"FUZZ-2.0",value:"FUZZ-2.0",desc:this.$t("producer.model.fuzz20desc")},{label:"FUZZ-2.0 Raw",value:"FUZZ-2.0 Raw",desc:this.$t("producer.model.fuzz20rawDesc")},{label:"FUZZ-1.1 Pro",value:"FUZZ-1.1 Pro",desc:this.$t("producer.model.fuzz11proDesc")},{label:"FUZZ-1.1",value:"FUZZ-1.1",desc:this.$t("producer.model.fuzz11desc")},{label:"FUZZ-1.0 Pro",value:"FUZZ-1.0 Pro",desc:this.$t("producer.model.fuzz10proDesc")},{label:"FUZZ-1.0",value:"FUZZ-1.0",desc:this.$t("producer.model.fuzz10desc")},{label:"FUZZ-0.8",value:"FUZZ-0.8",desc:this.$t("producer.model.fuzz08desc")}]}},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=ve)}}),Qe={class:"mb-3"},xe={class:"flex items-center mb-1"},et={class:"text-sm font-bold"},tt={class:"model-option"},ot={class:"model-option-name"},st={class:"model-option-desc"},nt={key:0,class:"flex items-center justify-between mb-3"},rt={class:"flex items-center"},it={class:"text-sm font-bold"};function at(e,t,d,i,h,p){const c=n("el-option"),m=n("el-select"),f=n("info-icon"),y=n("el-switch");return r(),u("div",null,[s("div",Qe,[s("div",xe,[s("span",et,a(e.$t("producer.name.model")),1)]),o(m,{modelValue:e.model,"onUpdate:modelValue":t[0]||(t[0]=g=>e.model=g),class:"w-full model-select",size:"default",placeholder:e.$t("producer.placeholder.select")},{default:l(()=>[(r(!0),u(G,null,q(e.options,g=>(r(),b(c,{key:g.value,label:g.label,value:g.value},{default:l(()=>[s("div",tt,[s("span",ot,a(g.label),1),s("span",st,a(g.desc),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(r(),u("div",nt,[s("div",rt,[s("span",it,a(e.$t("producer.name.instrumental")),1),o(f,{content:e.$t("producer.description.instrumental")},null,8,["content"])]),o(y,{modelValue:e.instrumental,"onUpdate:modelValue":t[1]||(t[1]=g=>e.instrumental=g)},null,8,["modelValue"])])):_("",!0)])}const lt=S(Ye,[["render",at],["__scopeId","data-v-42496b9a"]]),ct=k({name:"UploadAudio",components:{ElUpload:we,ElButton:W,ElRadioGroup:re,ElRadioButton:ne,InfoIcon:T,FontAwesomeIcon:z},emits:["change"],data(){return{fileList:[],uploadUrl:ue()+"/api/v1/files/",audioPreviewUrl:null,uploading:!1}},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)},hasUploadedAudio(){const e=this.$store.state.producer?.config?.action;return e==="upload_extend"||e==="upload_cover"},uploadAction:{get(){return this.$store.state.producer?.config?.action||"upload_extend"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit("change",e)}}},methods:{onExceed(){w.warning(this.$t("producer.message.uploadReferencesExceed"))},onError(){this.uploading=!1,w.error(this.$t("producer.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},d=this.credential?.token;if(!d){console.error("no token specified"),this.uploading=!1;return}this.uploading=!0,w.info(this.$t("producer.message.startingUploadAudio"));try{const h=(await I.upload(t,{token:d})).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"))}finally{this.uploading=!1}}}}),dt={class:"relative"},ut={class:"flex justify-between items-center mb-2"},pt={class:"flex justify-start items-center"},mt={class:"text-sm font-bold"},ft={key:0,class:"mb-2"},_t=["src"],ht={key:1,class:"mt-1"};function $t(e,t,d,i,h,p){const c=n("info-icon"),m=n("font-awesome-icon"),f=n("el-button"),y=n("el-upload"),g=n("el-radio-button"),U=n("el-radio-group");return r(),u("div",dt,[s("div",ut,[s("div",pt,[s("span",mt,a(e.$t("producer.name.referenceAudios")),1),o(c,{content:e.$t("producer.description.uploadAudios")},null,8,["content"])]),o(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),name:"file",limit:1,class:"upload-wrapper inline-upload",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:l(()=>[o(f,{round:"",type:"primary",size:"small",loading:e.uploading},{default:l(()=>[o(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),C(" "+a(e.$t("producer.button.uploadAudios")),1)]),_:1},8,["loading"])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),e.audioPreviewUrl?(r(),u("div",ft,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,_t)])):_("",!0),e.hasUploadedAudio?(r(),u("div",ht,[o(U,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=v=>e.uploadAction=v),size:"small"},{default:l(()=>[o(g,{value:"upload_extend"},{default:l(()=>[C(a(e.$t("producer.button.extend")),1)]),_:1}),o(g,{value:"upload_cover"},{default:l(()=>[C(a(e.$t("producer.button.cover_music")),1)]),_:1})]),_:1},8,["modelValue"])])):_("",!0)])}const gt=S(ct,[["render",$t],["__scopeId","data-v-355e932b"]]),vt="",yt=k({name:"PromptInput",components:{ElInput:Z,InfoIcon:T},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=vt)}}),bt={class:"field"},kt={class:"flex items-center mb-1"},wt={class:"text-sm font-bold"};function Ct(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-input");return r(),u("div",bt,[s("div",kt,[s("span",wt,a(e.$t("producer.name.songDescription")),1),o(c,{content:e.$t("producer.description.prompt")},null,8,["content"])]),o(m,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=f=>e.prompt=f),rows:4,type:"textarea",placeholder:e.$t("producer.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Vt=S(yt,[["render",Ct]]),St="",Ut=k({name:"LyricInput",components:{ElInput:Z,ElButton:W,FontAwesomeIcon:z,InfoIcon:T},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=St)},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}}}}),Pt={class:"field"},Et={class:"flex items-center justify-between mb-1"},At={class:"flex items-center"},Tt={class:"text-sm font-bold"};function Ft(e,t,d,i,h,p){const c=n("info-icon"),m=n("font-awesome-icon"),f=n("el-button"),y=n("el-input");return r(),u("div",Pt,[s("div",Et,[s("div",At,[s("span",Tt,a(e.$t("producer.name.lyrics")),1),o(c,{content:e.$t("producer.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(r(),b(f,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:l(()=>[e.generatingLyrics?_("",!0):(r(),b(m,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),C(" "+a(e.$t("producer.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):_("",!0)]),e.config?.action!=="extend"?(r(),b(y,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=g=>e.lyric=g),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(r(),b(y,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=g=>e.lyric=g),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("producer.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const It=S(Ut,[["render",Ft],["__scopeId","data-v-88c6da2b"]]),Lt=k({name:"StyleInput",components:{ElInput:Z,InfoIcon:T},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,style:e})}}}}),Gt={class:"field"},Dt={class:"flex items-center justify-between mb-1"},zt={class:"flex items-center"},jt={class:"text-sm font-bold"};function Rt(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-input");return r(),u("div",Gt,[s("div",Dt,[s("div",zt,[s("span",jt,a(e.$t("producer.name.style")),1),o(c,{content:e.$t("producer.description.style")},null,8,["content"])])]),o(m,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=f=>e.style=f),rows:2,type:"textarea",placeholder:e.$t("producer.placeholder.style")},null,8,["modelValue","placeholder"])])}const Zt=S(Lt,[["render",Rt]]),Nt=k({name:"TitleInput",components:{ElInput:Z,InfoIcon:T},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,title:e})}}}}),Mt={class:"field"},Ot={class:"flex items-center mb-1"},Bt={class:"text-sm font-bold"};function qt(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-input");return r(),u("div",Mt,[s("div",Ot,[s("span",Bt,a(e.$t("producer.name.title")),1),o(c,{content:e.$t("producer.description.title")},null,8,["content"])]),o(m,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=f=>e.title=f),placeholder:e.$t("producer.placeholder.title")},null,8,["modelValue","placeholder"])])}const Wt=S(Nt,[["render",qt]]),Ht=k({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:D,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})}}}),Kt={class:"field"},Jt={class:"box"},Xt={class:"title font-bold"},Yt={class:"input-wrapper"},Qt={class:"task"},xt={class:"left"},eo={key:2,class:"duration"},to={class:"info"},oo={class:"title"},so={class:"style"};function no(e,t,d,i,h,p){const c=n("el-input-number"),m=n("el-image"),f=n("video-pause"),y=n("el-icon"),g=n("video-play"),U=H("loading");return r(),u("div",Kt,[s("div",Jt,[s("h2",Xt,a(e.$t("producer.name.extend")),1),s("div",Yt,[o(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=v=>e.value=v),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"])])]),s("div",Qt,[e.audio?(r(),u("div",{key:0,class:"audio",onClick:t[3]||(t[3]=v=>e.onClick(e.audio))},[j((r(),u("div",xt,[o(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"?(r(),u("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=v=>e.onPause(e.audio))},[o(y,null,{default:l(()=>[o(f)]),_:1})])):_("",!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")?(r(),u("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=v=>e.onPlay(e.audio))},[o(y,null,{default:l(()=>[o(g)]),_:1})])):_("",!0),e.audio?.duration?(r(),u("div",eo,a(e.useFormatDuring(e.audio?.duration)),1)):_("",!0)])),[[U,!e.audio?.audio_url]]),s("div",to,[s("h2",oo,a(e.audio?.title),1),s("p",so,a(e.audio?.style),1)])])):_("",!0)])])}const ro=S(Ht,[["render",no],["__scopeId","data-v-26d43480"]]),io=k({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:D,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})}}}),ao={class:"field"},lo={class:"box"},co={class:"title font-bold"},uo={class:"task"},po={class:"left"},mo={key:2,class:"duration"},fo={class:"info"},_o={class:"title"},ho={class:"style"};function $o(e,t,d,i,h,p){const c=n("el-image"),m=n("video-pause"),f=n("el-icon"),y=n("video-play"),g=H("loading");return r(),u("div",ao,[s("div",lo,[s("h2",co,a(e.$t("producer.name.cover")),1)]),s("div",uo,[e.audio?(r(),u("div",{key:0,class:"audio",onClick:t[2]||(t[2]=U=>e.onClick(e.audio))},[j((r(),u("div",po,[o(c,{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"?(r(),u("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=U=>e.onPause(e.audio))},[o(f,null,{default:l(()=>[o(m)]),_:1})])):_("",!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")?(r(),u("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=U=>e.onPlay(e.audio))},[o(f,null,{default:l(()=>[o(y)]),_:1})])):_("",!0),e.audio?.duration?(r(),u("div",mo,a(e.useFormatDuring(e.audio?.duration)),1)):_("",!0)])),[[g,!e.audio?.audio_url]]),s("div",fo,[s("h2",_o,a(e.audio?.title),1),s("p",ho,a(e.audio?.style),1)])])):_("",!0)])])}const go=S(io,[["render",$o],["__scopeId","data-v-d8a8e583"]]),vo=k({name:"VocalGenderSelector",components:{ElRadioGroup:re,ElRadioButton:ne,InfoIcon:T},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})}}}}),yo={class:"mb-2"},bo={class:"flex items-center mb-1"},ko={class:"text-sm font-bold"};function wo(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-radio-button"),f=n("el-radio-group");return r(),u("div",yo,[s("div",bo,[s("span",ko,a(e.$t("producer.name.vocalGender")),1),o(c,{content:e.$t("producer.description.vocalGender")},null,8,["content"])]),o(f,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=y=>e.vocalGender=y)},{default:l(()=>[o(m,{value:""},{default:l(()=>[C(a(e.$t("producer.gender.auto")),1)]),_:1}),o(m,{value:"f"},{default:l(()=>[C(a(e.$t("producer.gender.female")),1)]),_:1}),o(m,{value:"m"},{default:l(()=>[C(a(e.$t("producer.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const Co=S(vo,[["render",wo]]),Vo=k({name:"AdvancedParams",components:{ElCollapse:Te,ElCollapseItem:Ae,ElInput:Z,ElSlider:x,ElInputNumber:Q,InfoIcon:T},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??50},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,weirdness:e})}},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})}}}}),So={key:0,class:"mb-3"},Uo={class:"flex items-center mb-1"},Po={class:"text-xs font-bold"},Eo={key:1,class:"mb-3"},Ao={class:"flex items-center mb-1"},To={class:"text-xs font-bold"},Fo={class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},Lo={class:"flex items-center"},Go={class:"text-xs font-bold"},Do={class:"text-xs text-[var(--el-text-color-secondary)]"},zo={class:"mb-3"},jo={class:"flex items-center justify-between mb-1"},Ro={class:"flex items-center"},Zo={class:"text-xs font-bold"},No={class:"text-xs text-[var(--el-text-color-secondary)]"},Mo={key:2,class:"mb-3"},Oo={class:"flex items-center justify-between mb-1"},Bo={class:"flex items-center"},qo={class:"text-xs font-bold"},Wo={class:"text-xs text-[var(--el-text-color-secondary)]"},Ho={class:"mb-3"},Ko={class:"flex items-center mb-1"},Jo={class:"text-xs font-bold"};function Xo(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-input"),f=n("el-slider"),y=n("el-input-number"),g=n("el-collapse-item"),U=n("el-collapse");return r(),b(U,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=v=>e.activeNames=v),class:"advanced-collapse"},{default:l(()=>[o(g,{title:e.$t("producer.name.advancedParams"),name:"advanced"},{default:l(()=>[e.config?.custom?(r(),u("div",So,[s("div",Uo,[s("span",Po,a(e.$t("producer.name.styleNegative")),1),o(c,{content:e.$t("producer.description.styleNegative")},null,8,["content"])]),o(m,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=v=>e.styleNegative=v),size:"small",placeholder:e.$t("producer.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):_("",!0),e.config?.custom&&!e.config?.instrumental?(r(),u("div",Eo,[s("div",Ao,[s("span",To,a(e.$t("producer.name.lyricPrompt")),1),o(c,{content:e.$t("producer.description.lyricPrompt")},null,8,["content"])]),o(m,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=v=>e.lyricPrompt=v),size:"small",placeholder:e.$t("producer.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):_("",!0),s("div",Fo,[s("div",Io,[s("div",Lo,[s("span",Go,a(e.$t("producer.name.weirdness")),1),o(c,{content:e.$t("producer.description.weirdness")},null,8,["content"])]),s("span",Do,a(e.weirdness??50),1)]),o(f,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=v=>e.weirdness=v),min:0,max:100,step:1},null,8,["modelValue"])]),s("div",zo,[s("div",jo,[s("div",Ro,[s("span",Zo,a(e.$t("producer.name.soundStrength")),1),o(c,{content:e.$t("producer.description.soundStrength")},null,8,["content"])]),s("span",No,a(e.soundStrength??50),1)]),o(f,{modelValue:e.soundStrength,"onUpdate:modelValue":t[3]||(t[3]=v=>e.soundStrength=v),min:0,max:100,step:1},null,8,["modelValue"])]),e.config?.custom&&!e.config?.instrumental?(r(),u("div",Mo,[s("div",Oo,[s("div",Bo,[s("span",qo,a(e.$t("producer.name.lyricsStrength")),1),o(c,{content:e.$t("producer.description.lyricsStrength")},null,8,["content"])]),s("span",Wo,a(e.lyricsStrength??50),1)]),o(f,{modelValue:e.lyricsStrength,"onUpdate:modelValue":t[4]||(t[4]=v=>e.lyricsStrength=v),min:0,max:100,step:1},null,8,["modelValue"])])):_("",!0),s("div",Ho,[s("div",Ko,[s("span",Jo,a(e.$t("producer.name.seed")),1),o(c,{content:e.$t("producer.description.seed")},null,8,["content"])]),o(y,{modelValue:e.seed,"onUpdate:modelValue":t[5]||(t[5]=v=>e.seed=v),min:0,controls:!1,size:"small",placeholder:e.$t("producer.placeholder.seed"),class:"w-full"},null,8,["modelValue","placeholder"])])]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Yo=S(Vo,[["render",Xo],["__scopeId","data-v-44ad862b"]]),Qo=k({name:"ReplaceSectionInput",components:{ElInputNumber:Q,ElImage:N,InfoIcon:T},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"})}}}),xo={class:"field"},es={class:"flex items-center mb-2"},ts={class:"text-sm font-bold m-0"},os={key:0,class:"task mb-2"},ss={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ns={class:"info flex-1 min-w-0"},rs={class:"text-sm font-bold m-0 truncate"},is={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},as={class:"flex gap-2"};function ls(e,t,d,i,h,p){const c=n("info-icon"),m=n("el-image"),f=n("el-input-number"),y=H("loading");return r(),u("div",xo,[s("div",es,[s("h2",ts,a(e.$t("producer.name.replaceSection")),1),o(c,{content:e.$t("producer.description.replaceSection")},null,8,["content"])]),e.audio?(r(),u("div",os,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[j((r(),u("div",ss,[o(m,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[y,!e.audio?.audio_url]]),s("div",ns,[s("h2",rs,a(e.audio?.title),1),s("p",is,a(e.audio?.style),1)])])])):_("",!0),s("div",as,[o(f,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.replaceSectionStart=g),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("producer.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.replaceSectionEnd=g),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 cs=S(Qo,[["render",ls]]),ds=k({name:"PresetPanel",components:{TypeSelector:lt,PromptInput:Vt,LyricInput:It,StyleInput:Zt,TitleInput:Wt,ExtendFromInput:ro,CoverFromInput:go,UploadAudio:gt,VocalGenderSelector:Co,AdvancedParams:Yo,ReplaceSectionInput:cs,FontAwesomeIcon:z,ElButton:W,ElTabs:Ge,ElTabPane:Le,Consumption:Fe},emits:["generate"],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?"custom":"simple"},set(e){this.$store.commit("producer/setConfig",{...this.$store.state.producer?.config,custom:e==="custom"})}},consumption(){return Ie(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){const e=this.config?.action;return e==="extend"||e==="upload_extend"?this.$t("producer.button.extend"):e==="cover"||e==="upload_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")},onClearAll(){this.$store.commit("producer/setConfig",{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:"",lyric:"",style:"",title:"",model:this.$store.state.producer?.config?.model})}}}),us={class:"flex flex-col h-full"},ps={class:"flex-1 overflow-y-auto p-5"},ms={class:"pt-2 px-1"},fs={class:"pt-2 px-1"},_s={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},hs={class:"flex gap-2 w-full"};function $s(e,t,d,i,h,p){const c=n("type-selector"),m=n("upload-audio"),f=n("prompt-input"),y=n("extend-from-input"),g=n("cover-from-input"),U=n("replace-section-input"),v=n("advanced-params"),P=n("el-tab-pane"),M=n("lyric-input"),O=n("style-input"),J=n("title-input"),$=n("vocal-gender-selector"),V=n("el-tabs"),ie=n("consumption"),ee=n("font-awesome-icon"),te=n("el-button");return r(),u("div",us,[s("div",ps,[o(V,{modelValue:e.mode,"onUpdate:modelValue":t[0]||(t[0]=ae=>e.mode=ae),class:"producer-mode-tabs",stretch:""},{default:l(()=>[o(P,{label:e.$t("producer.mode.simple"),name:"simple"},{default:l(()=>[s("div",ms,[o(c,{class:"mb-4"}),o(m,{class:"mb-4"}),o(f,{class:"mb-4"}),e.config?.action==="extend"?(r(),b(y,{key:0,class:"mb-4"})):_("",!0),e.config?.action==="cover"?(r(),b(g,{key:1,class:"mb-4"})):_("",!0),e.config?.action==="replace_section"?(r(),b(U,{key:2,class:"mb-4"})):_("",!0),o(v,{class:"mb-4"})])]),_:1},8,["label"]),o(P,{label:e.$t("producer.mode.custom"),name:"custom"},{default:l(()=>[s("div",fs,[o(c,{class:"mb-4"}),o(m,{class:"mb-4"}),e.config?.instrumental?_("",!0):(r(),b(M,{key:0,class:"mb-4"})),o(O,{class:"mb-4"}),o(J,{class:"mb-4"}),e.config?.instrumental?_("",!0):(r(),b($,{key:1,class:"mb-4"})),e.config?.action==="extend"?(r(),b(y,{key:2,class:"mb-4"})):_("",!0),e.config?.action==="cover"?(r(),b(g,{key:3,class:"mb-4"})):_("",!0),e.config?.action==="replace_section"?(r(),b(U,{key:4,class:"mb-4"})):_("",!0),o(v,{class:"mb-4"})])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),s("div",_s,[o(ie,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",hs,[o(te,{class:"flex-1",onClick:e.onClearAll},{default:l(()=>[o(ee,{icon:"fa-solid fa-broom",class:"mr-1"}),C(" "+a(e.$t("producer.button.clear_all")),1)]),_:1},8,["onClick"]),o(te,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:l(()=>[o(ee,{icon:"fa-solid fa-magic",class:"mr-2"}),C(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const gs=S(ds,[["render",$s],["__scopeId","data-v-4a4b209e"]]),vs=se("producer"),ys=k({name:"TaskPreview",components:{ElImage:N,ElIcon:K,ElTooltip:Re,FontAwesomeIcon:z,VideoPlay:Y,VideoPause:X,ElDropdown:je,ElDropdownMenu:ze,ElDropdownItem:De,Loading:pe},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(d=>({...d,action:t})):e},application(){return this.$store.state.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:D,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=>{Ce.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,d)=>{const i={audio_id:e},h=this.credential?.token;if(!h){console.error("no token specified"),d(new Error("No token specified"));return}I.video(i,{token:h}).then(p=>{const c=p.data?.data?.video_url;c?t(c):d(new Error("Video URL not found in response"))}).catch(p=>{d(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 d={action:e,audio_id:t,callback_url:vs},i=this.credential?.token;if(!i){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),I.audio(d,{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})}}}),bs={class:"task"},ks=["onClick"],ws={class:"left"},Cs=["onClick"],Vs=["onClick"],Ss={key:2,class:"duration"},Us={class:"info"},Ps={class:"title"},Es={class:"style"},As={class:"right"},Ts={class:"el-dropdown-link"},Fs={class:"flex items-center min-w-[120px]"},Is={class:"flex items-center min-w-[120px]"},Ls={class:"el-dropdown-link"};function Gs(e,t,d,i,h,p){const c=n("el-image"),m=n("video-pause"),f=n("el-icon"),y=n("video-play"),g=n("font-awesome-icon"),U=n("el-tooltip"),v=n("Loading"),P=n("el-dropdown-item"),M=n("el-dropdown-menu"),O=n("el-dropdown"),J=H("loading");return r(),u("div",bs,[(r(!0),u(G,null,q(e.audios,$=>(r(),u("div",{key:$.id,class:"audio",onClick:E(V=>e.onClick($),["stop"])},[j((r(),u("div",ws,[o(c,{src:$?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),$?.audio_url&&e.$store.state?.producer?.audio?.id===$.id&&e.$store.state?.producer?.audio?.state==="playing"?(r(),u("div",{key:0,class:"overlay",onClick:E(V=>e.onPause($),["stop"])},[o(f,null,{default:l(()=>[o(m)]),_:1})],8,Cs)):_("",!0),$?.audio_url&&(e.$store.state?.producer?.audio?.id!==$.id||e.$store.state?.producer?.audio?.id===$.id&&e.$store.state?.producer?.audio?.state==="paused")?(r(),u("div",{key:1,class:"overlay",onClick:E(V=>e.onPlay($),["stop"])},[o(f,null,{default:l(()=>[o(y)]),_:1})],8,Vs)):_("",!0),$?.duration?(r(),u("div",Ss,a(e.useFormatDuring($?.duration)),1)):_("",!0)])),[[J,!$?.audio_url]]),s("div",Us,[s("h2",Ps,a($?.title),1),s("p",Es,a($?.style),1)]),s("div",As,[o(O,null,{dropdown:l(()=>[o(M,null,{default:l(()=>[o(P,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload($)},{default:l(()=>[s("div",Fs,[e.isFetchingVideoUrl?(r(),b(f,{key:0,class:"is-loading mr-2"},{default:l(()=>[o(v)]),_:1})):_("",!0),s("span",null,a(e.$t("producer.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),$?.audio_url?(r(),b(P,{key:0,onClick:E(V=>e.onDownload(V,$?.audio_url),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.download_audio")),1)]),_:1},8,["onClick"])):_("",!0),o(P,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload($)},{default:l(()=>[s("div",Is,[e.isFetchingWav?(r(),b(f,{key:0,class:"is-loading mr-2"},{default:l(()=>[o(v)]),_:1})):_("",!0),s("span",null,a(e.$t("producer.button.download_wav")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:l(()=>[s("span",Ts,[o(U,{effect:"dark",content:e.$t("producer.button.download"),placement:"top"},{default:l(()=>[$?.audio_url||$?.video_url?(r(),b(g,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):_("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(O,null,{dropdown:l(()=>[o(M,null,{default:l(()=>[$?.audio_url?(r(),b(P,{key:0,onClick:E(V=>e.onExtend(V,$),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.extend")),1)]),_:1},8,["onClick"])):_("",!0),$.id?(r(),b(P,{key:1,onClick:E(V=>e.onGetStems($.id),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.get_stems")),1)]),_:1},8,["onClick"])):_("",!0),$.id?(r(),b(P,{key:2,onClick:E(V=>e.onGetAllStems($.id),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.all_stems")),1)]),_:1},8,["onClick"])):_("",!0),o(P,{onClick:E(V=>e.onCover($),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.cover_music")),1)]),_:1},8,["onClick"]),$?.id?(r(),b(P,{key:3,onClick:E(V=>e.onVariation($),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.variation")),1)]),_:1},8,["onClick"])):_("",!0),$?.id?(r(),b(P,{key:4,onClick:E(V=>e.onSwapVocals($.id),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.swap_vocals")),1)]),_:1},8,["onClick"])):_("",!0),$?.id?(r(),b(P,{key:5,onClick:E(V=>e.onSwapInstrumentals($.id),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.swap_instrumentals")),1)]),_:1},8,["onClick"])):_("",!0),$?.id?(r(),b(P,{key:6,onClick:E(V=>e.onReplaceSection($),["stop"])},{default:l(()=>[C(a(e.$t("producer.button.replace_section")),1)]),_:1},8,["onClick"])):_("",!0)]),_:2},1024)]),default:l(()=>[s("span",Ls,[o(U,{effect:"dark",content:e.$t("producer.button.more"),placement:"top"},{default:l(()=>[$?.audio_url||$?.video_url?(r(),b(g,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):_("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ks))),128))])}const Ds=S(ys,[["render",Gs]]),zs={class:"player-slider"},js=k({__name:"PlayerSlider",setup(e){const t=R(),d=F({get:()=>t.state.producer?.audio?.progress,set:c=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:c})}),i=F({get:()=>t.state.producer?.audio?.duration,set:c=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:c})}),h=()=>{},p=c=>t.dispatch("producer/setAudio",{...t.state.producer.audio,progress:c});return(c,m)=>(r(),u("div",zs,[o(A(x),{modelValue:d.value,"onUpdate:modelValue":m[0]||(m[0]=f=>d.value=f),"show-tooltip":!1,min:0,max:i.value,onChange:p,onInput:h},null,8,["modelValue","max"])]))}}),Rs={class:"flex player-song"},Zs=["src"],Ns={class:"ml-2 text-xs flex flex-col justify-between"},Ms={class:"w-52 2xl:w-96 cursor-pointer truncate"},Os={class:"flex"},Bs={class:"ml-2 text-dc"},qs=k({__name:"PlayerSong",setup(e){const t=R(),d=F({get:()=>t.state.producer.audio,set:i=>t.commit("producer/setAudio",i)});return ce(d,(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)=>(r(),u("div",Rs,[s("img",{alt:"",class:"w-11 h-11 rounded",src:d.value?.image_url||A(Ve)},null,8,Zs),s("div",Ns,[s("div",Ms,[s("div",Os,[s("span",null,a(d.value?.title||"Music"),1),s("span",Bs,"- "+a(d.value?.style||"SmallRuralDog"),1)])])])]))}}),Ws={class:"flex justify-end items-center gap-x-2.5"},Hs={class:"text-xs"},Ks=k({__name:"PlayerAction",setup(e){const t=R(),d=F({get:()=>t.state.producer?.audio?.progress,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,progress:h})}),i=F({get:()=>t.state.producer?.audio?.duration,set:h=>t.commit("producer/setAudio",{...t.state.producer.audio,duration:h})});return(h,p)=>(r(),u("div",Ws,[s("span",Hs,a(A(D)(d.value))+" / "+a(A(D)(i.value)),1)]))}}),Js={class:"player-volume flex flex-col items-center pt-2"},Xs={class:"text-sm mt-3"},Ys=k({__name:"PlayerVolumeSlider",setup(e){const t=R(),d=F({get:()=>t.state.producer.audio?.volume,set:p=>t.commit("producer/setAudio",{...t.state.producer.audio,volume:p})}),i=F({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,c)=>(r(),u("div",Js,[o(A(x),{modelValue:d.value,"onUpdate:modelValue":c[0]||(c[0]=m=>d.value=m),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:i.value,onInput:h},null,8,["modelValue","disabled"]),s("div",Xs,a(d.value),1)]))}}),Qs={class:"flex items-center justify-center gap-x-3"},xs=k({__name:"PlayerController",setup(e){const t=R(),d=()=>t.dispatch("producer/setAudio",{...t.state.producer.audio,state:t.state.producer.audio.state==="playing"?"paused":"playing"}),i=F(()=>t.state.producer.audio);return(h,p)=>(r(),u("div",Qs,[o(oe,{icon:i.value?.state==="playing"?A(Se):A(Ue),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:d},null,8,["icon"]),o(A(Ze),{placement:"top",width:"50px",trigger:"click"},{reference:l(()=>[o(oe,{icon:A(Pe),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:l(()=>[o(Ys)]),_:1})]))}}),en={class:"flex flex-col items-stretch h-20"},tn={class:"flex grow px-5 items-center"},on={class:"flex-1"},sn={class:"flex-1"},nn={class:"flex-1"},rn=k({__name:"Player",setup(e){return(t,d)=>(r(),u("div",en,[o(js),s("div",tn,[s("div",on,[o(qs)]),s("div",sn,[o(xs)]),s("div",nn,[o(Ks)])])]))}}),an=k({name:"RecentPanel",components:{ElSkeletonItem:Oe,ElSkeleton:Me,TaskPreview:Ds,Player:rn,NoTasks:Ne,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?.()}}}),ln={key:0,class:"tasks"},cn={class:"left w-[70px] p-[10px] flex items-center"},dn={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},un={key:2,class:"w-full flex-1 flex items-center justify-center"},pn={class:"h-20"};function mn(e,t,d,i,h,p){const c=n("el-skeleton-item"),m=n("el-skeleton"),f=n("task-preview"),y=n("scroll-list"),g=n("no-tasks"),U=n("player");return r(),u(G,null,[e.tasks?.items===void 0?(r(),u("div",ln,[(r(),u(G,null,q(3,v=>s("div",{key:v,class:"flex"},[s("div",cn,[o(m,{animated:""},{template:l(()=>[o(c,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",dn,[o(m,{animated:""},{template:l(()=>[o(c,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(c,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),b(y,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=v=>e.$emit("reach-top"))},{default:l(()=>[(r(!0),u(G,null,q(e.tasks?.items,(v,P)=>(r(),b(f,{key:P,"model-value":v,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):_("",!0),e.tasks?.items?.length===0?(r(),u("div",un,[o(g)])):_("",!0),j(s("div",pn,[o(U)],512),[[de,!!e.$store?.state?.producer?.audio?.object]])],64)}const fn=S(an,[["render",mn]]),_n=k({name:"TaskPreview",components:{IconPicture:me,ElImage:N,ElAvatar:Ee,ElIcon:K},computed:{audio(){return this.$store.state.producer?.audio}}}),hn={key:0,class:"size-full overflow-hidden"},$n={class:"relative h-[300px]"},gn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},vn={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"},yn={class:"p-4"},bn={class:"flex items-center font-bold mb-2"},kn={class:"text-[var(--el-text-color-regular)] mb-2"},wn={class:"text-xs text-[var(--el-text-color-regular)]"},Cn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Vn={key:1,class:"w-full h-full"};function Sn(e,t,d,i,h,p){const c=n("icon-picture"),m=n("el-icon"),f=n("el-image"),y=n("el-avatar");return e.audio?.object?(r(),u("div",hn,[s("div",$n,[o(f,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:l(()=>[s("div",gn,[o(m,{class:"text-3xl"},{default:l(()=>[o(c)]),_:1})])]),_:1},8,["src"]),s("h2",vn,a(e.audio?.title),1)]),s("div",yn,[s("div",bn,[o(y,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,a(e.audio?.title),1)]),s("p",kn,a(e.audio?.style),1),s("p",wn,a(e.$dayjs.format(e.audio?.created_at)),1),s("div",Cn,[s("p",null,a(e.audio?.lyric),1)])])])):(r(),u("div",Vn))}const Un=S(_n,[["render",Sn]]),Pn=se("producer"),En=k({name:"ProducerIndex",components:{Layout:Xe,ConfigPanel:gs,RecentPanel:fn,PreviewPanel:Un},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 ge({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(){_e.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===he&&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:d,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",d,"createdAtMax",i),this.fetchingTasks=!0;try{await this.$store.dispatch("producer/getTasks",{limit:t,createdAtMin:d,createdAtMax:i})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:Pn},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("producer.message.startingTask")),fe("producer",I.audio(e,{token:t})).then(()=>{w.success(this.$t("producer.message.startTaskSuccess"))}).catch(d=>{w.error(d?.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 An(e,t,d,i,h,p){const c=n("config-panel"),m=n("recent-panel"),f=n("preview-panel"),y=n("layout");return r(),b(y,null,{config:l(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:l(()=>[o(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:l(()=>[o(f)]),_:1})}const Er=S(En,[["render",An],["__scopeId","data-v-d6806962"]]);export{Er as default};