@acedatacloud/nexior 3.170.0 → 3.171.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.
- package/dist/assets/{Auth-VF3cnXzW.js → Auth-Cp59Wmiw.js} +1 -1
- package/dist/assets/{BotPlaceholder-B9QOi1ey.js → BotPlaceholder-CHhKWD1w.js} +1 -1
- package/dist/assets/{Callback-F0SeeSDo.js → Callback-D-pAHK0a.js} +1 -1
- package/dist/assets/{Console-CH2diJ2J.js → Console-DW7kaGZ1.js} +1 -1
- package/dist/assets/{Consumption-DBnjPImy.js → Consumption-OATlAFxr.js} +1 -1
- package/dist/assets/{Conversation-B-cZWeI9.js → Conversation-C9VA4Oot.js} +1 -1
- package/dist/assets/{CopyToClipboard-BJW57H6l.js → CopyToClipboard-sLoZUATy.js} +1 -1
- package/dist/assets/{Detail-C4J4_l09.js → Detail-eVeHu_WS.js} +2 -2
- package/dist/assets/{EditArray-CdcoBWUC.js → EditArray-B27tsiSg.js} +1 -1
- package/dist/assets/{Extra-Caqp9_lD.js → Extra-Br1Uwoy5.js} +1 -1
- package/dist/assets/{FilePreview-CJ9dBUbV.js → FilePreview-Cg8uaQBS.js} +1 -1
- package/dist/assets/{History-D3Kk0D7N.js → History-CBQ_hVQf.js} +1 -1
- package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-Be74ryVM.js → IconPark.vue_vue_type_script_setup_true_lang-BIxg9fKB.js} +1 -1
- package/dist/assets/{ImagePreview-CrnFevwy.js → ImagePreview-DC1yGIv-.js} +1 -1
- package/dist/assets/{ImageWrapper-QKKAzDLH.js → ImageWrapper-CswqCFR0.js} +1 -1
- package/dist/assets/{Index-DEUE6bhW.js → Index-B9fmenqE.js} +1 -1
- package/dist/assets/{Index-C11uTLRa.js → Index-BHbj4W7M.js} +1 -1
- package/dist/assets/{Index-DwsQa8UK.js → Index-BPqsGpO0.js} +1 -1
- package/dist/assets/{Index-BoplBAkm.js → Index-BzAv59ut.js} +1 -1
- package/dist/assets/{Index-pi6B32Tj.js → Index-C4qPkHis.js} +1 -1
- package/dist/assets/{Index-zAur3IZa.js → Index-C7YvGQJC.js} +1 -1
- package/dist/assets/Index-C8whg1xy.js +1 -0
- package/dist/assets/{Index-BkIMqpH0.js → Index-CBUg6wCN.js} +1 -1
- package/dist/assets/{Index-CclwZlkN.js → Index-CDIjoON9.js} +1 -1
- package/dist/assets/{Index--bqEUN-w.js → Index-CDR0VSQM.js} +1 -1
- package/dist/assets/{Index-DQZ9Jz5l.js → Index-CUONfmH9.js} +1 -1
- package/dist/assets/{Index-YCV8wVla.css → Index-CWmi9Gxv.css} +1 -1
- package/dist/assets/{Index-Fw2NBTUv.js → Index-C_SzW-BL.js} +1 -1
- package/dist/assets/{Index-DmqZd9UF.js → Index-Clv-VOQb.js} +2 -2
- package/dist/assets/{Index-D46N-VI6.js → Index-CxTmjtm_.js} +1 -1
- package/dist/assets/{Index-D1cL0war.js → Index-DOl1cqK8.js} +1 -1
- package/dist/assets/{Index-m7d5sx6w.js → Index-DS4ARgBN.js} +1 -1
- package/dist/assets/{Index-CnbJQ1YH.js → Index-DfKUONze.js} +1 -1
- package/dist/assets/{Index-1HjvZkkC.js → Index-Dl-j5EOx.js} +1 -1
- package/dist/assets/{Index-DoINbbqY.js → Index-Dydp55OO.js} +1 -1
- package/dist/assets/{Index-BTrV415e.js → Index-WONzpkZJ.js} +1 -1
- package/dist/assets/{Index-DrFHxTP-.js → Index-cokSPW0v.js} +1 -1
- package/dist/assets/{Index-4hTeTDjL.js → Index-eV8wZGk3.js} +1 -1
- package/dist/assets/{Index-BjKCEjNa.js → Index-tJ5hZV8b.js} +1 -1
- package/dist/assets/{Index-B0f13Ozp.js → Index-xOFtArC_.js} +1 -1
- package/dist/assets/{Invitees-BnHyjO_x.js → Invitees-BFwjiXfB.js} +1 -1
- package/dist/assets/{List-B-8WIHBb.js → List-BEWQEZdd.js} +1 -1
- package/dist/assets/{List-BNJdg-kb.js → List-BRENyz3G.js} +1 -1
- package/dist/assets/{List-DExihEdC.js → List-BlYqWg6d.js} +1 -1
- package/dist/assets/{Main-BL5vyLyG.js → Main-C1osywOl.js} +1 -1
- package/dist/assets/{Navigator-DROlmJC4.js → Navigator-ChMOflz9.js} +1 -1
- package/dist/assets/{NoTasks-26Zng1nj.js → NoTasks-mDpomjBm.js} +1 -1
- package/dist/assets/{NotFound-Ch25LwMb.js → NotFound-CU6zBHhS.js} +1 -1
- package/dist/assets/{OAuthCallback-Bd-JNNlZ.js → OAuthCallback-sdBMaJXv.js} +1 -1
- package/dist/assets/{Pagination--kU5zI7X.js → Pagination-BHOE4lao.js} +1 -1
- package/dist/assets/{Status-B5KW21bI.js → Status-juoLMEFE.js} +1 -1
- package/dist/assets/{Subscribe-CS09SYWw.js → Subscribe-DM1cJnbq.js} +1 -1
- package/dist/assets/{VideoPlayer-BCOKfNkV.js → VideoPlayer-CSsRwO-p.js} +1 -1
- package/dist/assets/{_Uint8Array-B2A7LHKA.js → _Uint8Array-DBwyuLEd.js} +1 -1
- package/dist/assets/{_baseClone-BZ95xiP-.js → _baseClone-BEzNjaw5.js} +1 -1
- package/dist/assets/{_baseIteratee-FN-_0qs8.js → _baseIteratee-BZtBRHel.js} +1 -1
- package/dist/assets/{_initCloneObject-aP5H13NU.js → _initCloneObject-COIbuV6v.js} +1 -1
- package/dist/assets/{add-D0yAJYkb.js → add-BdUJ3wHj.js} +1 -1
- package/dist/assets/{all-wallets-DeP3Svpe.js → all-wallets-C_x9B-Gn.js} +1 -1
- package/dist/assets/{app-store-DfR6-dyl.js → app-store-Bvbi9Keo.js} +1 -1
- package/dist/assets/{apple-C5MEd1ob.js → apple-BSpivjSX.js} +1 -1
- package/dist/assets/{arrow-bottom-BnuQiWmr.js → arrow-bottom-CtMjWci3.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-C97p1z4f.js → arrow-bottom-circle-jRPoFXTe.js} +1 -1
- package/dist/assets/{arrow-left-CdN24fmU.js → arrow-left-CDIngzM3.js} +1 -1
- package/dist/assets/{arrow-right-CCHQu1dE.js → arrow-right-DNt0CrXL.js} +1 -1
- package/dist/assets/{arrow-top-Byoh3xk5.js → arrow-top-DpWRN4ds.js} +1 -1
- package/dist/assets/{avatar-BJ9lIXru.js → avatar-DEn8zDAt.js} +1 -1
- package/dist/assets/{bank-QRYkKbl3.js → bank-Ds0Mv6fO.js} +1 -1
- package/dist/assets/{basic-D_L5leBi.js → basic-B3L5zJVW.js} +1 -1
- package/dist/assets/{browser-CJ7dQL5Z.js → browser-ClGRbn88.js} +1 -1
- package/dist/assets/{byokCredential-CTDuhDYU.js → byokCredential-DSN7bvuK.js} +1 -1
- package/dist/assets/{card-x_TrQusk.js → card-DCrI0ckk.js} +1 -1
- package/dist/assets/{castArray-53pOe3KQ.js → castArray-BqBjQ3IM.js} +1 -1
- package/dist/assets/{chat-BhHEU6BM.js → chat-B77mMXqy.js} +1 -1
- package/dist/assets/{checkmark-C7oOrJYe.js → checkmark-DUINAXzV.js} +1 -1
- package/dist/assets/{checkmark-bold-4cQWPe61.js → checkmark-bold-BeCEH6bm.js} +1 -1
- package/dist/assets/{chevron-bottom-_dQKBiFM.js → chevron-bottom--eB86go9.js} +1 -1
- package/dist/assets/{chevron-left-D0NV8O8C.js → chevron-left-jccada1g.js} +1 -1
- package/dist/assets/{chevron-right-D6JDpkMM.js → chevron-right-DxnFPAmK.js} +1 -1
- package/dist/assets/{chevron-top-kNPDidM9.js → chevron-top-BOap2-EL.js} +1 -1
- package/dist/assets/{chrome-store-CxOaI4Hb.js → chrome-store-pXqUg25C.js} +1 -1
- package/dist/assets/{clock-CbXQh-F8.js → clock-C3KtFo2s.js} +1 -1
- package/dist/assets/{close-Bn0BNDNy.js → close-wP7uSyzp.js} +1 -1
- package/dist/assets/{coinPlaceholder-DhxJgHT9.js → coinPlaceholder-CKM-NDj7.js} +1 -1
- package/dist/assets/{compass-DWJF99cH.js → compass-CnLEacK-.js} +1 -1
- package/dist/assets/{copy-Bhqc86J8.js → copy-DpIOSXG-.js} +1 -1
- package/dist/assets/{createTaskActions-BN1HkWyL.js → createTaskActions-CjIzgOrW.js} +1 -1
- package/dist/assets/{cursor-DwJlPLnQ.js → cursor-BZjkGw34.js} +1 -1
- package/dist/assets/{cursor-transparent-O0OdmTX3.js → cursor-transparent-B6rk-oov.js} +1 -1
- package/dist/assets/{debounce-BcJrfGup.js → debounce-DqdXAlzO.js} +1 -1
- package/dist/assets/{desktop-BMFQI9P4.js → desktop-OzBV6O9W.js} +1 -1
- package/dist/assets/{disconnect-CLsPUsK6.js → disconnect-hhXZW3oo.js} +1 -1
- package/dist/assets/{discord-BVCA4xBS.js → discord-CGo_weTU.js} +1 -1
- package/dist/assets/{distribution-Cz2eCH6L.js → distribution-BZ-vu4Zu.js} +1 -1
- package/dist/assets/{dropdown-3E7c4xrR.js → dropdown-Be4EMcgs.js} +1 -1
- package/dist/assets/{etherscan-vhO5x_yU.js → etherscan-BmDJCVuW.js} +1 -1
- package/dist/assets/{exclamation-triangle-Cc2SkU1E.js → exclamation-triangle-BObUFRsR.js} +1 -1
- package/dist/assets/{extension-CmF3W8Nf.js → extension-DjUpTHX0.js} +1 -1
- package/dist/assets/{external-link-fMVN9Pzt.js → external-link-CIQENuk6.js} +1 -1
- package/dist/assets/{facebook-B5EhO3FP.js → facebook-MZbVBFn7.js} +1 -1
- package/dist/assets/{farcaster-buwSuMdk.js → farcaster-BW7M1uEo.js} +1 -1
- package/dist/assets/{filters-Tcjfv0X8.js → filters-SZoPMvjt.js} +1 -1
- package/dist/assets/{github-_oOKA18r.js → github-CKDJo6G9.js} +1 -1
- package/dist/assets/{google-Ckv4l19c.js → google-Z9QeqFy2.js} +1 -1
- package/dist/assets/{help-circle-Djn2VE-3.js → help-circle-nJaA46Zo.js} +1 -1
- package/dist/assets/{id-68ONLthU.js → id-DW5QpCie.js} +1 -1
- package/dist/assets/{image-CD2DW0Qh.js → image-BOzNVZK1.js} +1 -1
- package/dist/assets/{index-CL4XM25M.js → index-2IltcxdV.js} +1 -1
- package/dist/assets/{index-BZEygfiD.js → index-2wizd-FP.js} +1 -1
- package/dist/assets/{index-CuZ50XJw.js → index-6--OU9dU.js} +5 -5
- package/dist/assets/{index-BUzL3mG3.js → index-86jD_Yp2.js} +1 -1
- package/dist/assets/{index-V0HdFli2.js → index-9SVyxGs4.js} +1 -1
- package/dist/assets/{index-DBkdI3ol.js → index-B3bb1pl6.js} +1 -1
- package/dist/assets/{index-BruLq0u0.js → index-BN1Wo4YM.js} +1 -1
- package/dist/assets/{index-B6mLb6e8.js → index-BPHPEDCf.js} +1 -1
- package/dist/assets/{index-bDiZwiDZ.js → index-BToUH2_-.js} +1 -1
- package/dist/assets/{index-DQ4vhmG8.js → index-BV6KEj8Z.js} +1 -1
- package/dist/assets/{index-I5Elxh-P.js → index-BVvciCEL.js} +1 -1
- package/dist/assets/{index-BOwou-sO.js → index-BXTNQlkh.js} +1 -1
- package/dist/assets/{index-CMgn5AKb.js → index-B_7gJYj4.js} +1 -1
- package/dist/assets/{index-h66xntSo.js → index-B_Ep3UCH.js} +1 -1
- package/dist/assets/{index-B5oJqc_9.js → index-B_oZZfCd.js} +1 -1
- package/dist/assets/{index-Bg1B_vBf.js → index-C0kBCkCE.js} +1 -1
- package/dist/assets/{index-BY7MxHf1.js → index-C2GiZHGJ.js} +1 -1
- package/dist/assets/{index-DM0ZMRHq.js → index-CDhTQzgu.js} +1 -1
- package/dist/assets/{index-BfFkaXCu.js → index-CGOcFGGs.js} +1 -1
- package/dist/assets/{index-fVwEB6e1.js → index-CHKn5drI.js} +1 -1
- package/dist/assets/{index-Dq-zqqRI.js → index-CMSzPY-s.js} +1 -1
- package/dist/assets/{index-BwMqm0aw.js → index-CPap2_rB.js} +1 -1
- package/dist/assets/{index-C2HQ5LM8.js → index-CSSTzBy_.js} +1 -1
- package/dist/assets/{index-Bb_Objnj.js → index-CUdBsDKP.js} +1 -1
- package/dist/assets/{index-DbG4b_TM.js → index-CcO8iFag.js} +1 -1
- package/dist/assets/{index-Bu88L-0G.js → index-CdnrDrdJ.js} +1 -1
- package/dist/assets/{index-cPlUJqWp.js → index-CiNYjplf.js} +1 -1
- package/dist/assets/{index-DqWAyv8n.js → index-Cl4AEdy5.js} +1 -1
- package/dist/assets/{index-BqkfKmrA.js → index-D-Y1QMKw.js} +1 -1
- package/dist/assets/{index-BlIpyxfh.js → index-D0kIg8mF.js} +1 -1
- package/dist/assets/{index-B5DYq5Vl.js → index-D7bbYc46.js} +1 -1
- package/dist/assets/{index-o2Y486om.js → index-DAtRHLgV.js} +1 -1
- package/dist/assets/{index-COpiMxVS.js → index-DBGXBiyP.js} +1 -1
- package/dist/assets/{index-BMKPoXYa.js → index-DESC9Ac7.js} +1 -1
- package/dist/assets/{index-Cawz29VF.js → index-DGNjQsCL.js} +1 -1
- package/dist/assets/{index-foi7Bo6Z.js → index-DJYawjBl.js} +1 -1
- package/dist/assets/{index-Bq2nn5Kh.js → index-DbPP8z5i.js} +1 -1
- package/dist/assets/{index-D5XWFMbk.js → index-DeaZoUiy.js} +1 -1
- package/dist/assets/{index-Dtb3bz7G.js → index-Df7smySz.js} +1 -1
- package/dist/assets/{index-CH0p72be.js → index-Ditn8hXX.js} +1 -1
- package/dist/assets/{index-fs8NIAvF.js → index-DjAf4cK0.js} +1 -1
- package/dist/assets/{index-DEznpV0t.js → index-DuBBgV2_.js} +1 -1
- package/dist/assets/{index-sqNKrOEb.js → index-DxFlUCW5.js} +1 -1
- package/dist/assets/{index-DGBjocWl.js → index-Dyf4PAPu.js} +1 -1
- package/dist/assets/{index-hOTqAi1M.js → index-EGQh8Uo0.js} +1 -1
- package/dist/assets/{index-v5NivPfi.js → index-Ga-XBVnv.js} +1 -1
- package/dist/assets/{index-CfBgADrZ.js → index-Oeeo1N3Z.js} +1 -1
- package/dist/assets/{index-BvyjdwfF.js → index-SuuTvQVk.js} +1 -1
- package/dist/assets/{index-DN4mjgau.js → index-Vb7d-TR4.js} +1 -1
- package/dist/assets/{index-Obo66Ces.js → index-Wr0vJjz2.js} +1 -1
- package/dist/assets/{index-DNFHH8j-.js → index-Y1vaziNK.js} +1 -1
- package/dist/assets/{index-DE1Z13Im.js → index-a6K_-36R.js} +3 -3
- package/dist/assets/{index-CXi2BKzQ.js → index-anfLrdJD.js} +2 -2
- package/dist/assets/{index-BFfIFYNj.js → index-bGmow-wY.js} +1 -1
- package/dist/assets/{index-B8RQA81q.js → index-gFWKK1nV.js} +1 -1
- package/dist/assets/{index-Cv6NTziM.js → index-jPBfz-k0.js} +1 -1
- package/dist/assets/{index-DIdL546u.js → index-kQqkhSg_.js} +1 -1
- package/dist/assets/{index-Bs2RP32Q.js → index-nB1Hi1wd.js} +1 -1
- package/dist/assets/{index-BIds-uEL.js → index-qFuAMDbZ.js} +14 -14
- package/dist/assets/{index-Dy-b6ht8.js → index-qkHjER5H.js} +1 -1
- package/dist/assets/{index.browser.esm-t2mutQq-.js → index.browser.esm-CHzGq_oX.js} +1 -1
- package/dist/assets/{index.es-CQyS8SIc.js → index.es-CDPFvyel.js} +1 -1
- package/dist/assets/{info-Dm_T52fW.js → info-Eg3fbiPk.js} +1 -1
- package/dist/assets/{info-circle-D_0gMbXg.js → info-circle-C3LagQyA.js} +1 -1
- package/dist/assets/{isEqual-DaExPLna.js → isEqual-ayKYUYxb.js} +1 -1
- package/dist/assets/{isPlainObject-D96w9DwK.js → isPlainObject-BYPrvrem.js} +1 -1
- package/dist/assets/{lightbulb-BdzhxMfi.js → lightbulb-B6SzmbQO.js} +1 -1
- package/dist/assets/{mail-CSHmQLT1.js → mail-B1Eml30J.js} +1 -1
- package/dist/assets/{midjourney-Cj4rs7IV.js → midjourney-CDkQkRqS.js} +1 -1
- package/dist/assets/{mobile-DYb5WTB9.js → mobile-B_iQjw-h.js} +1 -1
- package/dist/assets/{more-CwamieWr.js → more-CTRdXLaD.js} +1 -1
- package/dist/assets/{network-placeholder-DrTgF9B0.js → network-placeholder-BFLhtUUo.js} +1 -1
- package/dist/assets/{nftPlaceholder-DHgS25Mp.js → nftPlaceholder-BBMaZ4hw.js} +1 -1
- package/dist/assets/{off-lVHp_7Np.js → off-By2HNoax.js} +1 -1
- package/dist/assets/{order-BtDjK0GI.js → order-DUxBZAEp.js} +1 -1
- package/dist/assets/{pagination-C7LoVO-i.js → pagination-DAmKU21e.js} +1 -1
- package/dist/assets/{play-store-BJGFkziF.js → play-store-DzkRw43u.js} +1 -1
- package/dist/assets/{plus-DGUzPGqh.js → plus-CQmiMkOJ.js} +1 -1
- package/dist/assets/{price-BLR7O2kA.js → price-CEZBAo0j.js} +1 -1
- package/dist/assets/{producer-BtXshY3j.js → producer-BSFpTi9T.js} +1 -1
- package/dist/assets/{qr-code-DeOQiF0X.js → qr-code-BXb784jA.js} +1 -1
- package/dist/assets/{recycle-horizontal-DsJnW7Xa.js → recycle-horizontal-_C06yNpt.js} +1 -1
- package/dist/assets/{refresh-8knqJ_Zz.js → refresh-CaWZyO0y.js} +1 -1
- package/dist/assets/{reown-logo-DGpIcQBx.js → reown-logo-DdXKPgSg.js} +1 -1
- package/dist/assets/{search-n8DWsiEV.js → search-BS7DDpDw.js} +1 -1
- package/dist/assets/{secp256k1-C_ik2RxI.js → secp256k1-MN-CP4RI.js} +1 -1
- package/dist/assets/{secp256k1-BmIpMEV3.js → secp256k1-dm_GN4L5.js} +1 -1
- package/dist/assets/{seedream-VwnzpGim.js → seedream-ClGo-4XM.js} +1 -1
- package/dist/assets/seedream-Dv_GtpZG.js +1 -0
- package/dist/assets/seedream-cZ-4WZQF.js +1 -0
- package/dist/assets/{send-CnLYGF6e.js → send-DY9yG81Z.js} +1 -1
- package/dist/assets/{service-B__E2Ntg.js → service-CGpPIbUL.js} +1 -1
- package/dist/assets/{solana-wallets-CohKbxbz.js → solana-wallets-CA-u5IJj.js} +2 -2
- package/dist/assets/{solana-wallets-vue-C1rPh3H0.js → solana-wallets-vue-DXMu3w_o.js} +1 -1
- package/dist/assets/{suno-BxxgTpKs.js → suno-BGr9-l7M.js} +1 -1
- package/dist/assets/{swapHorizontal-Cz888HP7.js → swapHorizontal-MWKzwm2n.js} +1 -1
- package/dist/assets/{swapHorizontalBold-CCN1ZI6v.js → swapHorizontalBold-Be3nord6.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-BjxWvI7q.js → swapHorizontalMedium-CTssgpMe.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-LPWGdNPn.js → swapHorizontalRoundedBold-BaruK0X1.js} +1 -1
- package/dist/assets/{swapVertical-DDDW7pW9.js → swapVertical-BrZ1r-kq.js} +1 -1
- package/dist/assets/{telegram-Bir43uJl.js → telegram-DM1VR1gI.js} +1 -1
- package/dist/assets/{three-dots-DmGu0APO.js → three-dots-DA5MuQEx.js} +1 -1
- package/dist/assets/{twitch-DV_Shpo-.js → twitch-D5pOnDY8.js} +1 -1
- package/dist/assets/{twitterIcon-DjKcRDAh.js → twitterIcon-CEv0pY_a.js} +1 -1
- package/dist/assets/{typescript-BhRbbY-i.js → typescript-BMlz9EKI.js} +1 -1
- package/dist/assets/{use-form-item-pWJ40ZYM.js → use-form-item-B1DR4GI-.js} +1 -1
- package/dist/assets/validator-dv6q1tDx.js +1 -0
- package/dist/assets/{verify-Bqxh6nzq.js → verify-B4b9yqXd.js} +1 -1
- package/dist/assets/{verify-filled-9q7ulNo-.js → verify-filled-D6NqpQQx.js} +1 -1
- package/dist/assets/{w3m-modal-DRtbqlMQ.js → w3m-modal-Dgq4o2rj.js} +1 -1
- package/dist/assets/{wallet-B6ZOK9ue.js → wallet-DKLXWflU.js} +1 -1
- package/dist/assets/{wallet-placeholder-Bikht5NR.js → wallet-placeholder-DSTu2Sah.js} +1 -1
- package/dist/assets/{walletconnect-BV2qdNuE.js → walletconnect-CUxsbe9C.js} +1 -1
- package/dist/assets/{warning-circle-BLdbVMQB.js → warning-circle-DdpwMcxp.js} +1 -1
- package/dist/assets/{web-knvsE5kF.js → web-C9SgJhAX.js} +1 -1
- package/dist/assets/{web-Cjbj7QP2.js → web-el1WqWXx.js} +1 -1
- package/dist/assets/{x-B8_mMkWP.js → x-BFS0q9Yv.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Index-BQSfNdKE.js +0 -1
- package/dist/assets/seedream-DcTLW5r2.js +0 -1
- package/dist/assets/seedream-rLJUDb-d.js +0 -1
- package/dist/assets/validator-C-Hgr87W.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as T}from"./index.es-CQyS8SIc.js";import{E as q}from"./index-DNFHH8j-.js";import{E as W}from"./index-DN4mjgau.js";import{d as k,H as l,E as c,z as C,C as a,y as g,D as s,q as n,F as o,I as u,O as V,N,x as A,J as p,M as K,Q as U}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as H,cO as Q,cP as z,cQ as P,cR as J,cS as S,cT as M,cU as j,cV as D,cr as X,aV as Y,S as F,cs as Z}from"./index-BIds-uEL.js";import{I as O,S as ee,l as te}from"./pagination-C7LoVO-i.js";import{E as ae}from"./index-Bq2nn5Kh.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as x}from"./ImagePreview-CrnFevwy.js";import{E as ne}from"./index-BqkfKmrA.js";import{E as R}from"./index-CL4XM25M.js";import{E as B,a as G}from"./index-hOTqAi1M.js";import{C as se}from"./Consumption-DBnjPImy.js";import{a as le}from"./price-BLR7O2kA.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ie}from"./CopyToClipboard-BJW57H6l.js";import{I as ce}from"./ImageWrapper-QKKAzDLH.js";import{E as ue}from"./index-Dtb3bz7G.js";import{E as me}from"./index-BUzL3mG3.js";import{E as de}from"./index-DGBjocWl.js";import{B as pe}from"./BotPlaceholder-B9QOi1ey.js";import{N as fe}from"./NoTasks-26Zng1nj.js";import"./use-form-item-pWJ40ZYM.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-BhRbbY-i.js";import"./index-BFfIFYNj.js";import"./index-BOwou-sO.js";import"./index-DIdL546u.js";import"./_baseClone-BZ95xiP-.js";import"./_Uint8Array-B2A7LHKA.js";import"./_initCloneObject-aP5H13NU.js";import"./isEqual-DaExPLna.js";import"./index-o2Y486om.js";import"./strings-beZM2Y-f.js";import"./castArray-53pOe3KQ.js";import"./debounce-BcJrfGup.js";import"./_baseIteratee-FN-_0qs8.js";import"./index-CfBgADrZ.js";import"./index-D5XWFMbk.js";const he=k({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:q,FontAwesomeIcon:T},data(){return{drawer:!1}}}),_e={class:"main flex flex-row flex-1"},ge={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},be={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function $e(e,t,$,i,b,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-drawer");return n(),l("div",_e,[c("div",ge,[C(e.$slots,"config",{},void 0,!0)]),c("div",be,[C(e.$slots,"result",{},void 0,!0)]),a(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=d=>e.drawer=!0)},{default:g(()=>[a(h,{icon:"fa-solid fa-magic"})]),_:1}),a(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:g(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=y(he,[["render",$e],["__scopeId","data-v-9fbc8a5c"]]),ke="",ye=k({name:"PromptInput",components:{ElInput:ae,InfoIcon:O},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ke)}}),we={class:"field"},Ve={class:"box"},Ae={class:"title font-bold"};function Ne(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-input");return n(),l("div",we,[c("div",Ve,[c("h2",Ae,o(e.$t("nanobanana.name.prompt")),1),a(h,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),a(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ee=y(ye,[["render",Ne],["__scopeId","data-v-2331e197"]]),Re=k({name:"ImageUrlsInput",components:{ElUpload:ne,ElButton:q,InfoIcon:O,ImagePreview:x,FontAwesomeIcon:T},mixins:[oe],data(){return{fileList:[],uploadUrl:H()+"/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.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(b=>!b?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const b=this.fileList.find(f=>f?.response?.file_url===i||f?.url===i);b?t.push(b):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(f=>f===i||f?.url===i?.url||f?.response?.file_url===i?.response?.file_url)||t.push(i)}),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(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.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()}}}),Ie={class:"field flex items-center justify-between"},Le={class:"title font-bold text-[14px] mb-[10px]"},Se={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Te={class:"controls flex items-center"},qe={class:"file-list flex flex-wrap gap-[10px]"};function Ue(e,t,$,i,b,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-upload"),d=s("info-icon"),w=s("image-preview");return n(),l(V,null,[c("div",Ie,[c("h2",Le,o(e.$t("nanobanana.name.imageUrls")),1),c("div",Se,[c("div",Te,[a(m,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),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:g(()=>[a(_,{size:"small",type:"primary",round:""},{default:g(()=>[a(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(d,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",qe,[(n(!0),l(V,null,N(e.fileList,(r,v)=>(n(),A(w,{key:r.uid||r?.response?.file_url||r.url||v,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:E=>e.onRemovePreview(v,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Oe=y(Re,[["render",Ue]]),Ce=k({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Pe={class:"field"},Be={class:"title font-bold"};function Ge(e,t,$,i,b,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Pe,[c("h2",Be,o(e.$t("nanobanana.name.aspectRatio")),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:g(()=>[(n(!0),l(V,null,N(e.options,m=>(n(),A(h,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=y(Ce,[["render",Ge],["__scopeId","data-v-67f08a08"]]),je=k({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{options:[{value:z,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:J,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),De={class:"field"},Fe={class:"label"},ze={class:"box"},xe={class:"title font-bold"};function We(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",De,[c("div",Fe,[c("div",ze,[c("h2",xe,o(e.$t("nanobanana.name.model")),1),a(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:g(()=>[(n(!0),l(V,null,N(e.options,d=>(n(),A(_,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ke=y(je,[["render",We],["__scopeId","data-v-94304d73"]]),He=k({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{cachedResolution:S,options:[{value:M,label:M},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==z}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Qe={class:"field"},Je={class:"label"},Xe={class:"box"},Ye={class:"title font-bold"};function Ze(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",Qe,[c("div",Je,[c("div",Xe,[c("h2",Ye,o(e.$t("nanobanana.name.resolution")),1),a(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:g(()=>[(n(!0),l(V,null,N(e.options,d=>(n(),A(_,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const et=y(He,[["render",Ze],["__scopeId","data-v-fd5ab393"]]),tt=k({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:T,PromptInput:Ee,Consumption:se,ImageUrlsInput:Oe,AspectRatioSelector:Me,ModelSelector:Ke,ResolutionSelector:et},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return le({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),at={class:"flex flex-col h-full"},ot={class:"flex-1 overflow-y-auto p-5"},nt={class:"flex flex-col items-center justify-center px-5 pb-5"};function st(e,t,$,i,b,f){const h=s("model-selector"),_=s("resolution-selector"),m=s("prompt-input"),d=s("aspect-ratio-selector"),w=s("image-urls-input"),r=s("consumption"),v=s("font-awesome-icon"),E=s("el-button");return n(),l("div",at,[c("div",ot,[a(h,{class:"mb-4"}),a(_,{class:"mb-4"}),a(m,{class:"mb-4"}),a(d,{class:"mb-4"}),a(w,{class:"mb-4"})]),c("div",nt,[a(r,{value:e.consumption,service:e.service},null,8,["value","service"]),a(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:g(()=>[a(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const lt=y(tt,[["render",st]]),rt=k({name:"TaskPreview",components:{ElImage:de,CopyToClipboard:ie,FontAwesomeIcon:T,ElAlert:me,ImageWrapper:ce,ElButton:q,ElTooltip:ue,ImagePreview:x},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),it={class:"preview"},ct={class:"left"},ut={class:"main"},mt={class:"bot"},dt={class:"datetime"},pt={class:"info"},ft={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ht={key:1,class:"prompt mt-2"},_t={key:0},gt={key:0,class:U({content:!0,failed:!0})},bt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},$t={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},vt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Et={key:1,class:U({content:!0})},Rt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ct={key:2,class:U({content:!0})},Pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Dt(e,t,$,i,b,f){const h=s("el-image"),_=s("image-preview"),m=s("image-wrapper"),d=s("el-button"),w=s("el-tooltip"),r=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return n(),l("div",it,[c("div",ct,[a(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",ut,[c("div",mt,[u(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",dt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",pt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",ft,[(n(!0),l(V,null,N(e.modelValue?.request?.image_urls,(I,L)=>(n(),A(_,{key:L,url:I,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):p("",!0),e.modelValue?.request?.prompt?(n(),l("p",ht,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(n(),l("span",_t," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):p("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",gt,[c("div",bt,[(n(!0),l(V,null,N(e.images,(I,L)=>(n(),A(m,{key:L,src:I?.image_url,"raw-src":I?.image_url},null,8,["src","raw-src"]))),128))]),c("div",$t,[a(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:g(()=>[a(d,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(I=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:g(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),a(E,{closable:!1,class:"mt-2 success"},{default:g(()=>[e.modelValue?.request?.model?(n(),l("p",vt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",kt,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",yt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",wt,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",Vt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",At,[a(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Nt,[a(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):p("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Et,[a(E,{closable:!1,class:"failure"},{template:g(()=>[a(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:g(()=>[e.modelValue?.request?.model?(n(),l("p",Rt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",It,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Lt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",St,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",Tt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",qt,[a(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Ut,[a(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Ot,[a(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):p("",!0)]),_:1})])):(n(),l("div",Ct,[a(E,{closable:!1,class:"info"},{template:g(()=>[a(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:g(()=>[e.modelValue?.request?.model?(n(),l("p",Pt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Bt,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Gt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",Mt,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",jt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Ft=y(rt,[["render",Dt],["__scopeId","data-v-8d5f4fff"]]),zt=k({name:"RecentPanel",components:{TaskPreview:Ft,BotPlaceholder:pe,NoTasks:fe,ScrollList:ee},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),xt={key:0},Wt={key:2,class:"w-full h-full flex items-center justify-center"};function Kt(e,t,$,i,b,f){const h=s("bot-placeholder"),_=s("task-preview"),m=s("scroll-list"),d=s("no-tasks");return n(),l(V,null,[e.tasks?.items===void 0?(n(),l("div",xt,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),A(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:g(()=>[(n(!0),l(V,null,N(e.tasks?.items,w=>(n(),A(_,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(n(),l("div",Wt,[a(d)])):p("",!0)],64)}const Ht=y(zt,[["render",Kt]]),Qt=Z("nanobanana"),Jt=k({name:"NanobananaIndex",components:{ConfigPanel:lt,Layout:ve,RecentPanel:Ht},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.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 te({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("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/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:$,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",i),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=S);const $={...e,action:t?"edit":"generate",callback_url:Qt},i=this.credential?.token;if(!i){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),X("nanobanana",Y.generate($,{token:i})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(b=>{const f=b?.response?.data;f?.error?.code===re?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Xt(e,t,$,i,b,f){const h=s("config-panel"),_=s("recent-panel"),m=s("layout");return n(),A(m,null,{config:g(()=>[a(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:g(()=>[a(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ma=y(Jt,[["render",Xt]]);export{Ma as default};
|
|
1
|
+
import{F as T}from"./index.es-CDPFvyel.js";import{E as q}from"./index-Y1vaziNK.js";import{E as W}from"./index-Vb7d-TR4.js";import{d as k,H as l,E as c,z as C,C as a,y as g,D as s,q as n,F as o,I as u,O as V,N,x as A,J as p,M as K,Q as U}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as H,cO as Q,cP as z,cQ as P,cR as J,cS as S,cT as M,cU as j,cV as D,cr as X,aV as Y,S as F,cs as Z}from"./index-qFuAMDbZ.js";import{I as O,S as ee,l as te}from"./pagination-DAmKU21e.js";import{E as ae}from"./index-DbPP8z5i.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as x}from"./ImagePreview-DC1yGIv-.js";import{E as ne}from"./index-D-Y1QMKw.js";import{E as R}from"./index-2IltcxdV.js";import{E as B,a as G}from"./index-EGQh8Uo0.js";import{C as se}from"./Consumption-OATlAFxr.js";import{a as le}from"./price-CEZBAo0j.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ie}from"./CopyToClipboard-sLoZUATy.js";import{I as ce}from"./ImageWrapper-CswqCFR0.js";import{E as ue}from"./index-Df7smySz.js";import{E as me}from"./index-86jD_Yp2.js";import{E as de}from"./index-Dyf4PAPu.js";import{B as pe}from"./BotPlaceholder-CHhKWD1w.js";import{N as fe}from"./NoTasks-mDpomjBm.js";import"./use-form-item-B1DR4GI-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-BMlz9EKI.js";import"./index-bGmow-wY.js";import"./index-BXTNQlkh.js";import"./index-kQqkhSg_.js";import"./_baseClone-BEzNjaw5.js";import"./_Uint8Array-DBwyuLEd.js";import"./_initCloneObject-COIbuV6v.js";import"./isEqual-ayKYUYxb.js";import"./index-DAtRHLgV.js";import"./strings-beZM2Y-f.js";import"./castArray-BqBjQ3IM.js";import"./debounce-DqdXAlzO.js";import"./_baseIteratee-BZtBRHel.js";import"./index-Oeeo1N3Z.js";import"./index-DeaZoUiy.js";const he=k({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:q,FontAwesomeIcon:T},data(){return{drawer:!1}}}),_e={class:"main flex flex-row flex-1"},ge={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},be={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function $e(e,t,$,i,b,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-drawer");return n(),l("div",_e,[c("div",ge,[C(e.$slots,"config",{},void 0,!0)]),c("div",be,[C(e.$slots,"result",{},void 0,!0)]),a(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=d=>e.drawer=!0)},{default:g(()=>[a(h,{icon:"fa-solid fa-magic"})]),_:1}),a(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:g(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=y(he,[["render",$e],["__scopeId","data-v-9fbc8a5c"]]),ke="",ye=k({name:"PromptInput",components:{ElInput:ae,InfoIcon:O},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ke)}}),we={class:"field"},Ve={class:"box"},Ae={class:"title font-bold"};function Ne(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-input");return n(),l("div",we,[c("div",Ve,[c("h2",Ae,o(e.$t("nanobanana.name.prompt")),1),a(h,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),a(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ee=y(ye,[["render",Ne],["__scopeId","data-v-2331e197"]]),Re=k({name:"ImageUrlsInput",components:{ElUpload:ne,ElButton:q,InfoIcon:O,ImagePreview:x,FontAwesomeIcon:T},mixins:[oe],data(){return{fileList:[],uploadUrl:H()+"/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.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(b=>!b?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const b=this.fileList.find(f=>f?.response?.file_url===i||f?.url===i);b?t.push(b):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(f=>f===i||f?.url===i?.url||f?.response?.file_url===i?.response?.file_url)||t.push(i)}),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(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.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()}}}),Ie={class:"field flex items-center justify-between"},Le={class:"title font-bold text-[14px] mb-[10px]"},Se={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Te={class:"controls flex items-center"},qe={class:"file-list flex flex-wrap gap-[10px]"};function Ue(e,t,$,i,b,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-upload"),d=s("info-icon"),w=s("image-preview");return n(),l(V,null,[c("div",Ie,[c("h2",Le,o(e.$t("nanobanana.name.imageUrls")),1),c("div",Se,[c("div",Te,[a(m,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),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:g(()=>[a(_,{size:"small",type:"primary",round:""},{default:g(()=>[a(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(d,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",qe,[(n(!0),l(V,null,N(e.fileList,(r,v)=>(n(),A(w,{key:r.uid||r?.response?.file_url||r.url||v,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:E=>e.onRemovePreview(v,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Oe=y(Re,[["render",Ue]]),Ce=k({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Pe={class:"field"},Be={class:"title font-bold"};function Ge(e,t,$,i,b,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Pe,[c("h2",Be,o(e.$t("nanobanana.name.aspectRatio")),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:g(()=>[(n(!0),l(V,null,N(e.options,m=>(n(),A(h,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=y(Ce,[["render",Ge],["__scopeId","data-v-67f08a08"]]),je=k({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{options:[{value:z,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:J,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),De={class:"field"},Fe={class:"label"},ze={class:"box"},xe={class:"title font-bold"};function We(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",De,[c("div",Fe,[c("div",ze,[c("h2",xe,o(e.$t("nanobanana.name.model")),1),a(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:g(()=>[(n(!0),l(V,null,N(e.options,d=>(n(),A(_,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ke=y(je,[["render",We],["__scopeId","data-v-94304d73"]]),He=k({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{cachedResolution:S,options:[{value:M,label:M},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==z}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),Qe={class:"field"},Je={class:"label"},Xe={class:"box"},Ye={class:"title font-bold"};function Ze(e,t,$,i,b,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",Qe,[c("div",Je,[c("div",Xe,[c("h2",Ye,o(e.$t("nanobanana.name.resolution")),1),a(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:g(()=>[(n(!0),l(V,null,N(e.options,d=>(n(),A(_,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const et=y(He,[["render",Ze],["__scopeId","data-v-fd5ab393"]]),tt=k({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:T,PromptInput:Ee,Consumption:se,ImageUrlsInput:Oe,AspectRatioSelector:Me,ModelSelector:Ke,ResolutionSelector:et},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return le({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),at={class:"flex flex-col h-full"},ot={class:"flex-1 overflow-y-auto p-5"},nt={class:"flex flex-col items-center justify-center px-5 pb-5"};function st(e,t,$,i,b,f){const h=s("model-selector"),_=s("resolution-selector"),m=s("prompt-input"),d=s("aspect-ratio-selector"),w=s("image-urls-input"),r=s("consumption"),v=s("font-awesome-icon"),E=s("el-button");return n(),l("div",at,[c("div",ot,[a(h,{class:"mb-4"}),a(_,{class:"mb-4"}),a(m,{class:"mb-4"}),a(d,{class:"mb-4"}),a(w,{class:"mb-4"})]),c("div",nt,[a(r,{value:e.consumption,service:e.service},null,8,["value","service"]),a(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:g(()=>[a(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const lt=y(tt,[["render",st]]),rt=k({name:"TaskPreview",components:{ElImage:de,CopyToClipboard:ie,FontAwesomeIcon:T,ElAlert:me,ImageWrapper:ce,ElButton:q,ElTooltip:ue,ImagePreview:x},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),it={class:"preview"},ct={class:"left"},ut={class:"main"},mt={class:"bot"},dt={class:"datetime"},pt={class:"info"},ft={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ht={key:1,class:"prompt mt-2"},_t={key:0},gt={key:0,class:U({content:!0,failed:!0})},bt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},$t={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},vt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Et={key:1,class:U({content:!0})},Rt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ct={key:2,class:U({content:!0})},Pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Dt(e,t,$,i,b,f){const h=s("el-image"),_=s("image-preview"),m=s("image-wrapper"),d=s("el-button"),w=s("el-tooltip"),r=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return n(),l("div",it,[c("div",ct,[a(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",ut,[c("div",mt,[u(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",dt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",pt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",ft,[(n(!0),l(V,null,N(e.modelValue?.request?.image_urls,(I,L)=>(n(),A(_,{key:L,url:I,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):p("",!0),e.modelValue?.request?.prompt?(n(),l("p",ht,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(n(),l("span",_t," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):p("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",gt,[c("div",bt,[(n(!0),l(V,null,N(e.images,(I,L)=>(n(),A(m,{key:L,src:I?.image_url,"raw-src":I?.image_url},null,8,["src","raw-src"]))),128))]),c("div",$t,[a(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:g(()=>[a(d,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(I=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:g(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),a(E,{closable:!1,class:"mt-2 success"},{default:g(()=>[e.modelValue?.request?.model?(n(),l("p",vt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",kt,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",yt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",wt,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",Vt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",At,[a(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Nt,[a(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):p("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Et,[a(E,{closable:!1,class:"failure"},{template:g(()=>[a(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:g(()=>[e.modelValue?.request?.model?(n(),l("p",Rt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",It,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Lt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",St,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",Tt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",qt,[a(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Ut,[a(r,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Ot,[a(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):p("",!0)]),_:1})])):(n(),l("div",Ct,[a(E,{closable:!1,class:"info"},{template:g(()=>[a(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:g(()=>[e.modelValue?.request?.model?(n(),l("p",Pt,[a(r,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Bt,[a(r,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Gt,[a(r,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",Mt,[a(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),c("p",jt,[a(r,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Ft=y(rt,[["render",Dt],["__scopeId","data-v-8d5f4fff"]]),zt=k({name:"RecentPanel",components:{TaskPreview:Ft,BotPlaceholder:pe,NoTasks:fe,ScrollList:ee},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),xt={key:0},Wt={key:2,class:"w-full h-full flex items-center justify-center"};function Kt(e,t,$,i,b,f){const h=s("bot-placeholder"),_=s("task-preview"),m=s("scroll-list"),d=s("no-tasks");return n(),l(V,null,[e.tasks?.items===void 0?(n(),l("div",xt,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),A(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:g(()=>[(n(!0),l(V,null,N(e.tasks?.items,w=>(n(),A(_,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(n(),l("div",Wt,[a(d)])):p("",!0)],64)}const Ht=y(zt,[["render",Kt]]),Qt=Z("nanobanana"),Jt=k({name:"NanobananaIndex",components:{ConfigPanel:lt,Layout:ve,RecentPanel:Ht},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.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 te({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("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/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:$,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",i),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=S);const $={...e,action:t?"edit":"generate",callback_url:Qt},i=this.credential?.token;if(!i){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),X("nanobanana",Y.generate($,{token:i})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(b=>{const f=b?.response?.data;f?.error?.code===re?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Xt(e,t,$,i,b,f){const h=s("config-panel"),_=s("recent-panel"),m=s("layout");return n(),A(m,null,{config:g(()=>[a(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:g(()=>[a(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ma=y(Jt,[["render",Xt]]);export{Ma as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bm as O,br as $,G as v,bs as N,bn as S,bo as T,bp as L,ac as U,bt as D,bu as R,bl as P}from"./index-
|
|
1
|
+
import{bm as O,br as $,G as v,bs as N,bn as S,bo as T,bp as L,ac as U,bt as D,bu as R,bl as P}from"./index-qFuAMDbZ.js";import{F as b}from"./index.es-CDPFvyel.js";import{E as B,a as A}from"./index-DBGXBiyP.js";import{E as F}from"./index-Ga-XBVnv.js";import{E as k}from"./index-Dyf4PAPu.js";import{d as E,x as f,y as n,C as o,I as _,F as m,J as g,E as s,D as t,q as r,H as h,R as H,O as V,N as q,Q as J}from"./vendor-vue-NSDaktjZ.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-BMlz9EKI.js";import"./index-Cl4AEdy5.js";import"./index-Df7smySz.js";import"./index-bGmow-wY.js";import"./index-BuyEbX8F.js";import"./index-Oeeo1N3Z.js";import"./dropdown-Be4EMcgs.js";import"./debounce-DqdXAlzO.js";import"./index-BXTNQlkh.js";const M=E({name:"HelpEntry",components:{ElImage:k,ElDialog:O,ElPopover:F,ElMenu:A,ElMenuItem:B,FontAwesomeIcon:b},props:{visible:{type:Boolean,default:!0}},emits:["close"],computed:{site(){return this.$store.state.site}},methods:{onJoin(){window.open(this.$store.state.site?.features?.support?.discord?.url,"_blank")},onProfit(){this.$router.push({name:$})}}}),X={class:"flex"},z={class:"flex-1 text-center"};function G(e,i,w,I,y,C){const c=t("font-awesome-icon"),l=t("el-menu-item"),p=t("el-image"),d=t("el-popover"),a=t("el-menu"),u=t("el-dialog");return r(),f(u,{"model-value":e.visible,width:200,class:"text-center",onClose:i[0]||(i[0]=x=>e.$emit("close"))},{default:n(()=>[o(a,{collapse:!1,class:"menu"},{default:n(()=>[e.site?.features?.support?.discord?.enabled?(r(),f(l,{key:0,index:"1",onClick:e.onJoin},{title:n(()=>[_(m(e.$t("common.message.joinDiscord")),1)]),default:n(()=>[o(c,{icon:"fa-brands fa-discord",class:"mr-2"})]),_:1},8,["onClick"])):g("",!0),o(d,{width:350,trigger:"hover"},{reference:n(()=>[e.site?.features?.support?.wechat?.enabled?(r(),f(l,{key:0,index:"2"},{title:n(()=>[_(m(e.$t("common.message.addWeChat")),1)]),default:n(()=>[o(c,{icon:"fa-brands fa-weixin",class:"mr-2"})]),_:1})):g("",!0)]),default:n(()=>[s("div",X,[s("div",z,[o(p,{src:e.site?.features?.support?.wechat?.qr},null,8,["src"])])])]),_:1})]),_:1})]),_:1},8,["model-value"])}const j=v(M,[["render",G],["__scopeId","data-v-0fce633f"]]),Q=E({name:"ProfileIndex",components:{ElImage:k,HelpDialog:j,FontAwesomeIcon:b},data(){return{operating:{locale:!1,dark:!1,help:!1}}},computed:{user(){return this.$store.getters.user},showSupport(){return this.$store?.state?.site?.features?.support?.enabled&&(this.$store?.state?.site?.features?.support?.discord?.enabled||this.$store?.state?.site?.features?.support?.wechat?.enabled)},showSite(){return this.$store?.state?.site?.admins?.includes(this.$store.getters.user?.id)},links(){return[{key:"profile",text:this.$t("console.menu.userProfile"),href:`${R()}/user/profile`,icon:"fa-regular fa-user"},{key:"application-list",text:this.$t("console.menu.applicationList"),name:T,icon:"fa-solid fa-cube"},{key:"order-list",text:this.$t("console.menu.orderList"),name:L,icon:"fa-solid fa-store"},{key:"usage-list",text:this.$t("console.menu.usageList"),name:U,icon:"fa-solid fa-rotate-left"},{key:"distribution-index",text:this.$t("console.menu.distributionIndex"),name:$,icon:"fa-solid fa-coins"},...this.showSite?[{key:"site-index",text:this.$t("common.nav.site"),name:D,icon:"fa-solid fa-gear"}]:[],{key:"dark-setting",text:this.$t("common.nav.darkMode"),icon:"fa-solid fa-moon",callback:()=>{this.operating.dark=!0}},{key:"locale-setting",text:this.$t("common.nav.locale"),icon:"fa-solid fa-language",callback:()=>{this.operating.locale=!0}},{key:"developerPlatform",text:this.$t("console.menu.developerPlatform"),href:P(),icon:"fa-solid fa-laptop-code"},...this.showSupport?[{key:"support",text:this.$t("common.nav.support"),callback:()=>{this.operating.help=!0},icon:"fa-solid fa-question"}]:[],{key:"logout",text:this.$t("common.nav.logOut"),icon:"fa-solid fa-arrow-right-from-bracket",callback:async()=>{await this.$store.dispatch("logout")}}]}},methods:{onHome(){this.$router.push({name:S})},onNavigate(e){e.name?this.$router.push({name:e.name}):e.href?window.open(N(e.href),"_blank"):e.callback&&e.callback()}}}),W={class:"profile"},K={class:"info"},Y={class:"links"},Z=["onClick"],ee={class:"icon"},te={class:"text"},oe={class:"suffix"};function se(e,i,w,I,y,C){const c=t("el-image"),l=t("font-awesome-icon"),p=t("locale-selector"),d=t("help-dialog");return r(),h("div",W,[s("div",K,[o(c,{src:e.user.avatar,fit:"cover",class:"avatar"},null,8,["src"]),s("h2",null,m(e.user.username),1),s("div",{style:H({backgroundImage:"url("+e.user.avatar+")"}),class:"background"},null,4)]),s("div",Y,[(r(!0),h(V,null,q(e.links,(a,u)=>(r(),h("a",{key:u,class:J({link:!0,active:e.$route.name===a.name}),onClick:x=>e.onNavigate(a)},[s("span",ee,[o(l,{icon:a.icon,class:"text-sm"},null,8,["icon"])]),s("span",te,m(a.text),1),s("span",oe,[o(l,{icon:"fa-solid fa-chevron-right",class:"text-sm"})])],10,Z))),128))]),o(p,{visible:e.operating.locale==!0,onClose:i[0]||(i[0]=a=>e.operating.locale=!1)},null,8,["visible"]),o(d,{visible:e.operating.help==!0,onClose:i[1]||(i[1]=a=>e.operating.help=!1)},null,8,["visible"])])}const Ee=v(Q,[["render",se],["__scopeId","data-v-bf1d72a9"]]);export{Ee as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as z}from"./index.es-CQyS8SIc.js";import{E as W}from"./index-DNFHH8j-.js";import{E as le}from"./index-DN4mjgau.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-BIds-uEL.js";import{a as he}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-BtXshY3j.js";import{I as T,S as $e,l as ge}from"./pagination-C7LoVO-i.js";import{b as ve}from"./producer-DP85fuAq.js";import{E as ye}from"./index-B6mLb6e8.js";import{E as be,a as ke}from"./index-hOTqAi1M.js";import{E as ne,a as re}from"./index-C2HQ5LM8.js";import{E as we}from"./index-BqkfKmrA.js";import{E as w}from"./index-CL4XM25M.js";import{E as Z}from"./index-Bq2nn5Kh.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-Be74ryVM.js";import{E as Q}from"./index-sqNKrOEb.js";import{E as N}from"./index-DGBjocWl.js";import{E as x}from"./index-DBkdI3ol.js";import{E as Ae,a as Te}from"./index-DM0ZMRHq.js";import{C as Fe}from"./Consumption-DBnjPImy.js";import{a as Ie}from"./price-BLR7O2kA.js";import{E as Le,a as Ge}from"./index-Dq-zqqRI.js";import{E as De,b as ze,a as je}from"./index-foi7Bo6Z.js";import{E as Re}from"./index-Dtb3bz7G.js";import{E as Ze}from"./index-v5NivPfi.js";import{N as Ne}from"./NoTasks-26Zng1nj.js";import{a as Me,E as Oe}from"./index-D5XWFMbk.js";import"./use-form-item-pWJ40ZYM.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-C-Hgr87W.js";import"./index-BFfIFYNj.js";import"./index-o2Y486om.js";import"./typescript-BhRbbY-i.js";import"./strings-beZM2Y-f.js";import"./isEqual-DaExPLna.js";import"./_Uint8Array-B2A7LHKA.js";import"./castArray-53pOe3KQ.js";import"./debounce-BcJrfGup.js";import"./_baseIteratee-FN-_0qs8.js";import"./index-CfBgADrZ.js";import"./index-DIdL546u.js";import"./_baseClone-BZ95xiP-.js";import"./_initCloneObject-aP5H13NU.js";import"./index-BOwou-sO.js";import"./index-Cu41y2Fl.js";import"./index-DqWAyv8n.js";import"./isPlainObject-D96w9DwK.js";import"./dropdown-3E7c4xrR.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};
|
|
1
|
+
import{F as z}from"./index.es-CDPFvyel.js";import{E as W}from"./index-Y1vaziNK.js";import{E as le}from"./index-Vb7d-TR4.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,eD as X,eE as Y,X as K,J as pe,S as L,cs as se,eF as R,eG as me,cr as fe,n as _e}from"./index-qFuAMDbZ.js";import{a as he}from"./errorCode-Cqj9Td_Z.js";import{p as I}from"./producer-BSFpTi9T.js";import{I as T,S as $e,l as ge}from"./pagination-DAmKU21e.js";import{b as ve}from"./producer-DP85fuAq.js";import{E as ye}from"./index-BPHPEDCf.js";import{E as be,a as ke}from"./index-EGQh8Uo0.js";import{E as ne,a as re}from"./index-CSSTzBy_.js";import{E as we}from"./index-D-Y1QMKw.js";import{E as w}from"./index-2IltcxdV.js";import{E as Z}from"./index-DbPP8z5i.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-BIxg9fKB.js";import{E as Q}from"./index-DxFlUCW5.js";import{E as N}from"./index-Dyf4PAPu.js";import{E as x}from"./index-B3bb1pl6.js";import{E as Ae,a as Te}from"./index-CDhTQzgu.js";import{C as Fe}from"./Consumption-OATlAFxr.js";import{a as Ie}from"./price-CEZBAo0j.js";import{E as Le,a as Ge}from"./index-CMSzPY-s.js";import{E as De,b as ze,a as je}from"./index-DJYawjBl.js";import{E as Re}from"./index-Df7smySz.js";import{E as Ze}from"./index-Ga-XBVnv.js";import{N as Ne}from"./NoTasks-mDpomjBm.js";import{a as Me,E as Oe}from"./index-DeaZoUiy.js";import"./use-form-item-B1DR4GI-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-dv6q1tDx.js";import"./index-bGmow-wY.js";import"./index-DAtRHLgV.js";import"./typescript-BMlz9EKI.js";import"./strings-beZM2Y-f.js";import"./isEqual-ayKYUYxb.js";import"./_Uint8Array-DBwyuLEd.js";import"./castArray-BqBjQ3IM.js";import"./debounce-DqdXAlzO.js";import"./_baseIteratee-BZtBRHel.js";import"./index-Oeeo1N3Z.js";import"./index-kQqkhSg_.js";import"./_baseClone-BEzNjaw5.js";import"./_initCloneObject-COIbuV6v.js";import"./index-BXTNQlkh.js";import"./index-Cu41y2Fl.js";import"./index-Cl4AEdy5.js";import"./isPlainObject-BYPrvrem.js";import"./dropdown-Be4EMcgs.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};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as q}from"./index.es-CDPFvyel.js";import{E as P}from"./index-Y1vaziNK.js";import{E as oe}from"./index-Vb7d-TR4.js";import{d as k,H as c,E as l,z as U,C as s,y as $,D as a,q as n,F as r,I as g,O as S,N as A,J as v,x as E,M as ae,Q as R}from"./vendor-vue-NSDaktjZ.js";import{G as y,dh as O,di as D,dj as B,dk as C,dl as G,dm as W,dn as F,dp as H,dq as J,dr as Q,bl as ne,ds as re,dt as K,du as le,dv as ie,dw as ce,dx as Z,dy as de,dz as me,dA as Y,cr as ue,S as X,cs as pe}from"./index-qFuAMDbZ.js";import{I,S as fe,l as _e}from"./pagination-DAmKU21e.js";import{E as ge}from"./index-DbPP8z5i.js";import{p as he}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ee}from"./ImagePreview-DC1yGIv-.js";import{E as $e}from"./index-D-Y1QMKw.js";import{E as z}from"./index-2IltcxdV.js";import{C as ve}from"./Consumption-OATlAFxr.js";import{a as be}from"./price-CEZBAo0j.js";import{E as j,a as N,b as Ee}from"./index-EGQh8Uo0.js";import{E as ke}from"./index-BN1Wo4YM.js";import{E as x}from"./index-DxFlUCW5.js";import{E as ye}from"./index-BPHPEDCf.js";import{b as Se}from"./errorCode-Cqj9Td_Z.js";import{s as we}from"./seedream-ClGo-4XM.js";import{C as Ie}from"./CopyToClipboard-sLoZUATy.js";import{I as Ae}from"./ImageWrapper-CswqCFR0.js";import{E as Ve}from"./index-Df7smySz.js";import{E as ze}from"./index-86jD_Yp2.js";import{E as Me}from"./index-Dyf4PAPu.js";import{B as Te}from"./BotPlaceholder-CHhKWD1w.js";import{N as Re}from"./NoTasks-mDpomjBm.js";import"./use-form-item-B1DR4GI-.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-BMlz9EKI.js";import"./index-bGmow-wY.js";import"./index-BXTNQlkh.js";import"./index-kQqkhSg_.js";import"./_baseClone-BEzNjaw5.js";import"./_Uint8Array-DBwyuLEd.js";import"./_initCloneObject-COIbuV6v.js";import"./isEqual-ayKYUYxb.js";import"./index-DAtRHLgV.js";import"./strings-beZM2Y-f.js";import"./castArray-BqBjQ3IM.js";import"./debounce-DqdXAlzO.js";import"./_baseIteratee-BZtBRHel.js";import"./index-Oeeo1N3Z.js";import"./validator-dv6q1tDx.js";import"./index-Cu41y2Fl.js";import"./index-DeaZoUiy.js";const Le=k({name:"LayoutSeedream",components:{ElDrawer:oe,ElButton:P,FontAwesomeIcon:q},data(){return{drawer:!1}}}),De={class:"main flex flex-row flex-1"},Ce={class:"config w-[320px] h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},qe={class:"result h-full p-6 flex-1 flex flex-col bg-[var(--app-content-bg)]"};function Pe(e,t,d,o,m,p){const u=a("font-awesome-icon"),f=a("el-button"),i=a("el-drawer");return n(),c("div",De,[l("div",Ce,[U(e.$slots,"config",{},void 0,!0)]),l("div",qe,[U(e.$slots,"result",{},void 0,!0)]),s(f,{circle:"",class:"menu",onClick:t[0]||(t[0]=_=>e.drawer=!0)},{default:$(()=>[s(u,{icon:"fa-solid fa-magic"})]),_:1}),s(i,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ue=y(Le,[["render",Pe],["__scopeId","data-v-5ff0c320"]]),Ge="",Fe=k({name:"SeedreamPromptInput",components:{ElInput:ge,InfoIcon:I},computed:{prompt:{get(){return this.$store.state.seedream?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ge)}}),Oe={class:"field"},Be={class:"box"},je={class:"title font-bold"};function Ne(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-input");return n(),c("div",Oe,[l("div",Be,[l("h2",je,r(e.$t("seedream.name.prompt")),1),s(u,{content:e.$t("seedream.description.prompt"),class:"info"},null,8,["content"])]),s(f,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=i=>e.prompt=i),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("seedream.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const xe=y(Fe,[["render",Ne],["__scopeId","data-v-5559520a"]]),We={image:!0,imageRequired:!1,sizeTiers:[O,D,B,C],sizeAdaptive:!0,sizePixel:!0,sizePixelDefault:void 0,groupGeneration:!1,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};function w(e){switch(e){case Q:return{image:!0,imageRequired:!1,sizeTiers:[D,B,C],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!0,tools:!0};case J:case H:return{image:!0,imageRequired:!1,sizeTiers:[O,D,C],sizeAdaptive:!0,sizePixel:!0,groupGeneration:!0,seed:!1,guidanceScale:!1,outputFormat:!1,tools:!1};case F:return{image:!1,imageRequired:!1,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:"1024x1024",groupGeneration:!1,seed:!0,guidanceScale:!0,guidanceScaleDefault:W[F],outputFormat:!1,tools:!1};case G:return{image:!0,imageRequired:!0,sizeTiers:[],sizeAdaptive:!1,sizePixel:!0,sizePixelDefault:"1024x1024",groupGeneration:!1,seed:!0,guidanceScale:!0,guidanceScaleDefault:W[G],outputFormat:!1,tools:!1};default:return We}}const Ke=[O,D,B,C];function Ze(e,t){if(!e)return[];const d=t.model??e.model;if(!d)return[];const o=w(d),m=[];Array.isArray(e.image)&&e.image.length>0&&!o.image&&m.push({field:"image",i18nLabel:"seedream.name.imageUrls"});const p=typeof e.size=="string"?e.size:void 0;if(p){const u=p.toUpperCase();Ke.includes(u)&&!o.sizeTiers.includes(u)?m.push({field:"size",i18nLabel:"seedream.name.size"}):p==="adaptive"&&!o.sizeAdaptive&&m.push({field:"size",i18nLabel:"seedream.name.size"})}return e.sequential_image_generation==="auto"&&!o.groupGeneration&&m.push({field:"sequential_image_generation",i18nLabel:"seedream.name.maxImages"}),e.seed!==void 0&&e.seed!==null&&!o.seed&&m.push({field:"seed",i18nLabel:"seedream.name.seed"}),e.guidance_scale!==void 0&&e.guidance_scale!==null&&!o.guidanceScale&&m.push({field:"guidance_scale",i18nLabel:"seedream.name.guidanceScale"}),e.output_format&&!o.outputFormat&&m.push({field:"output_format",i18nLabel:"seedream.name.outputFormat"}),Array.isArray(e.tools)&&e.tools.length>0&&!o.tools&&m.push({field:"tools",i18nLabel:"seedream.name.tools"}),m}function Xe(e,t,d){const o={...e},m=d.model??e.model,p=w(m);for(const u of t)switch(u.field){case"image":delete o.image;break;case"size":p.sizePixelDefault?o.size=p.sizePixelDefault:delete o.size;break;case"sequential_image_generation":o.sequential_image_generation="disabled",delete o.sequential_image_generation_options;break;case"seed":delete o.seed;break;case"guidance_scale":delete o.guidance_scale;break;case"output_format":delete o.output_format;break;case"tools":delete o.tools;break}return o}const He=k({name:"SeedreamImageInput",components:{ElUpload:$e,ElButton:P,InfoIcon:I,ImagePreview:ee,FontAwesomeIcon:q},mixins:[he],data(){return{fileList:[],uploadUrl:ne()+"/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.seedream?.config?.image},model(){return this.$store.state.seedream?.config?.model},supported(){return w(this.model).image}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const o=(this.fileList||[]).filter(m=>!m?.response?.file_url);this.fileList=o.length?o:[];return}const t=[];e.forEach(o=>{const m=this.fileList.find(p=>p?.response?.file_url===o||p?.url===o);m?t.push(m):t.push({name:o.split("/").pop()||o,url:o,status:"success",percentage:100,response:{file_url:o}})}),(this.fileList||[]).filter(o=>!o?.response?.file_url).forEach(o=>{t.some(p=>p===o||p?.url===o?.url||p?.response?.file_url===o?.response?.file_url)||t.push(o)}),this.fileList=t}}},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.onSetImages()},onExceed(){z.warning(this.$t("seedream.message.uploadImageExceed"))},onError(){z.error(this.$t("seedream.message.uploadImageError"))},onSetImages(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,image:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImages()},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.onSetImages()}}}),Je={key:0},Qe={class:"field"},Ye={class:"label"},et={class:"box"},tt={class:"title font-bold"},st={class:"value"},ot={class:"file-list mt-2 flex flex-wrap gap-[10px]"};function at(e,t,d,o,m,p){const u=a("info-icon"),f=a("font-awesome-icon"),i=a("el-button"),_=a("el-upload"),h=a("image-preview");return e.supported?(n(),c("div",Je,[l("div",Qe,[l("div",Ye,[l("div",et,[l("h2",tt,r(e.$t("seedream.name.imageUrls")),1),s(u,{content:e.$t("seedream.description.imageUrls"),class:"info"},null,8,["content"])])]),l("div",st,[s(_,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=b=>e.fileList=b),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",limit:14,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(i,{size:"small",type:"primary",round:""},{default:$(()=>[s(f,{icon:"fa-solid fa-upload",class:"mr-1"}),g(" "+r(e.$t("seedream.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"])])]),l("div",ot,[(n(!0),c(S,null,A(e.fileList,(b,M)=>(n(),E(h,{key:b.uid||b?.response?.file_url||b.url||M,url:b.url||b?.response?.file_url,name:b.name,percentage:b.percentage,onRemove:L=>e.onRemovePreview(M,b)},null,8,["url","name","percentage","onRemove"]))),128))])])):v("",!0)}const nt=y(He,[["render",at],["__scopeId","data-v-2aa4829c"]]),rt=k({name:"SeedreamModelSelector",components:{ElSelect:N,ElOption:j,InfoIcon:I},data(){return{revertKey:0,options:[{value:Q,label:this.$t("seedream.model.seedream50")},{value:J,label:this.$t("seedream.model.seedream45")},{value:H,label:this.$t("seedream.model.seedream40")},{value:F,label:this.$t("seedream.model.seedream30t2i")},{value:G,label:this.$t("seedream.model.seededit30i2i")}]}},computed:{value(){return this.$store.state.seedream?.config?.model}},mounted(){this.value||this.applyModel(re)},methods:{async onChange(e){const t=this.$store.state.seedream?.config||{},d=Ze(t,{model:e});if(d.length===0){this.applyModel(e);return}const o=d.map(m=>this.$t(m.i18nLabel)).join("、");try{await ke.confirm(this.$t("seedream.message.featureNotSupportedBody",{fields:o}),this.$t("seedream.message.featureNotSupportedTitle"),{confirmButtonText:this.$t("seedream.button.confirmContinue"),cancelButtonText:this.$t("seedream.button.cancelSwitch"),type:"warning"});const m=Xe({...t,model:e},d,{model:e});this.$store.commit("seedream/setConfig",m),z.success(this.$t("seedream.message.featureRemovedNotice",{fields:o}))}catch{this.revertKey+=1}},applyModel(e){this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,model:e})}}}),lt={class:"field"},it={class:"label"},ct={class:"box"},dt={class:"title font-bold"};function mt(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-option"),i=a("el-select");return n(),c("div",lt,[l("div",it,[l("div",ct,[l("h2",dt,r(e.$t("seedream.name.model")),1),s(u,{content:e.$t("seedream.description.model"),class:"info"},null,8,["content"])])]),(n(),E(i,{key:e.revertKey,"model-value":e.value,class:"value",placeholder:e.$t("seedream.placeholder.select"),onChange:e.onChange},{default:$(()=>[(n(!0),c(S,null,A(e.options,_=>(n(),E(f,{key:_.value,label:_.label,value:_.value},null,8,["label","value"]))),128))]),_:1},8,["model-value","placeholder","onChange"]))])}const ut=y(rt,[["render",mt],["__scopeId","data-v-8892a12c"]]),pt=k({name:"SeedreamSizeSelector",components:{ElSelect:N,ElOption:j,ElOptionGroup:Ee,InfoIcon:I},data(){return{SEEDREAM_SIZE_ADAPTIVE:ie,pixelOptions:le}},computed:{model(){return this.$store.state.seedream?.config?.model},capabilities(){return w(this.model)},value:{get(){return this.$store.state.seedream?.config?.size},set(e){this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,size:e})}}},watch:{model:{immediate:!0,handler(){if(this.value)return;const e=this.capabilities;e.sizeTiers.length?this.value=e.sizeTiers.includes(K)?K:e.sizeTiers[0]:e.sizePixelDefault&&(this.value=e.sizePixelDefault)}}}}),ft={class:"field"},_t={class:"label"},gt={class:"box"},ht={class:"title font-bold"};function $t(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-option"),i=a("el-option-group"),_=a("el-select");return n(),c("div",ft,[l("div",_t,[l("div",gt,[l("h2",ht,r(e.$t("seedream.name.size")),1),s(u,{content:e.$t("seedream.description.size"),class:"info"},null,8,["content"])])]),s(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=h=>e.value=h),class:"value",placeholder:e.$t("seedream.placeholder.size"),filterable:"","allow-create":"","default-first-option":""},{default:$(()=>[e.capabilities.sizeTiers.length?(n(),E(i,{key:0,label:e.$t("seedream.size.group.tier")},{default:$(()=>[(n(!0),c(S,null,A(e.capabilities.sizeTiers,h=>(n(),E(f,{key:h,label:h,value:h},null,8,["label","value"]))),128))]),_:1},8,["label"])):v("",!0),e.capabilities.sizeAdaptive?(n(),E(i,{key:1,label:e.$t("seedream.size.group.adaptive")},{default:$(()=>[(n(),E(f,{key:e.SEEDREAM_SIZE_ADAPTIVE,label:e.$t("seedream.size.adaptive"),value:e.SEEDREAM_SIZE_ADAPTIVE},null,8,["label","value"]))]),_:1},8,["label"])):v("",!0),s(i,{label:e.$t("seedream.size.group.pixel")},{default:$(()=>[(n(!0),c(S,null,A(e.pixelOptions,h=>(n(),E(f,{key:h.value,label:`${h.value} (${h.ratio})`,value:h.value},null,8,["label","value"]))),128))]),_:1},8,["label"])]),_:1},8,["modelValue","placeholder"])])}const vt=y(pt,[["render",$t],["__scopeId","data-v-dd7bd021"]]),bt=k({name:"SeedreamMaxImagesSelector",components:{ElInputNumber:x,InfoIcon:I},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return w(this.config?.model).groupGeneration},referenceImageCount(){const e=this.config?.image;return Array.isArray(e)?e.length:0},effectiveMax(){const e=Z-this.referenceImageCount;return Math.max(1,Math.min(Z,e))},value:{get(){const e=this.config?.sequential_image_generation_options?.max_images;return typeof e=="number"&&e>=1?e:ce},set(e){const t={...this.config||{}},d=Math.max(1,Math.min(this.effectiveMax,Math.floor(e||1)));d>1?(t.sequential_image_generation="auto",t.sequential_image_generation_options={...t.sequential_image_generation_options||{},max_images:d}):(t.sequential_image_generation="disabled",t.sequential_image_generation_options&&delete t.sequential_image_generation_options),this.$store.commit("seedream/setConfig",t)}}},watch:{effectiveMax(e){this.value>e&&(this.value=e)}}}),Et={key:0,class:"field"},kt={class:"label"},yt={class:"box"},St={class:"title font-bold"},wt={class:"value"};function It(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-input-number");return e.supported?(n(),c("div",Et,[l("div",kt,[l("div",yt,[l("h2",St,r(e.$t("seedream.name.maxImages")),1),s(u,{content:e.$t("seedream.description.maxImages"),class:"info"},null,8,["content"])])]),l("div",wt,[s(f,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=i=>e.value=i),min:1,max:e.effectiveMax,step:1,size:"default","controls-position":"right",class:"counter"},null,8,["modelValue","max"])])])):v("",!0)}const At=y(bt,[["render",It],["__scopeId","data-v-f079fd20"]]),Vt=k({name:"SeedreamOutputFormatSelector",components:{ElSelect:N,ElOption:j,InfoIcon:I},data(){return{options:[...de]}},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return w(this.config?.model).outputFormat},value:{get(){return this.config?.output_format},set(e){const t={...this.config||{}};t.output_format=e,this.$store.commit("seedream/setConfig",t)}}}}),zt={key:0,class:"field"},Mt={class:"label"},Tt={class:"box"},Rt={class:"title font-bold"};function Lt(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-option"),i=a("el-select");return e.supported?(n(),c("div",zt,[l("div",Mt,[l("div",Tt,[l("h2",Rt,r(e.$t("seedream.name.outputFormat")),1),s(u,{content:e.$t("seedream.description.outputFormat"),class:"info"},null,8,["content"])])]),s(i,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",placeholder:e.$t("seedream.placeholder.select")},{default:$(()=>[(n(!0),c(S,null,A(e.options,_=>(n(),E(f,{key:_,label:_.toUpperCase(),value:_},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])):v("",!0)}const Dt=y(Vt,[["render",Lt],["__scopeId","data-v-69ea4c07"]]),Ct=k({name:"SeedreamSeedInput",components:{ElInputNumber:x,InfoIcon:I},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return w(this.config?.model).seed},value:{get(){const e=this.config?.seed;return typeof e=="number"?e:-1},set(e){const t={...this.config||{}},d=typeof e=="number"&&Number.isInteger(e)?e:-1;t.seed=d,this.$store.commit("seedream/setConfig",t)}}}}),qt={key:0,class:"field"},Pt={class:"label"},Ut={class:"box"},Gt={class:"title font-bold"},Ft={class:"value"};function Ot(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-input-number");return e.supported?(n(),c("div",qt,[l("div",Pt,[l("div",Ut,[l("h2",Gt,r(e.$t("seedream.name.seed")),1),s(u,{content:e.$t("seedream.description.seed"),class:"info"},null,8,["content"])])]),l("div",Ft,[s(f,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=i=>e.value=i),min:-1,max:2147483647,step:1,size:"default","controls-position":"right",class:"counter"},null,8,["modelValue"])])])):v("",!0)}const Bt=y(Ct,[["render",Ot],["__scopeId","data-v-10cdc1e0"]]),jt=k({name:"SeedreamGuidanceScaleInput",components:{ElInputNumber:x,InfoIcon:I},computed:{config(){return this.$store.state.seedream?.config||{}},supported(){return w(this.config?.model).guidanceScale},defaultValue(){return w(this.config?.model).guidanceScaleDefault??2.5},value:{get(){const e=this.config?.guidance_scale;return typeof e=="number"?e:this.defaultValue},set(e){const t={...this.config||{}},d=typeof e=="number"&&e>=1&&e<=10?e:this.defaultValue;t.guidance_scale=d,this.$store.commit("seedream/setConfig",t)}}}}),Nt={key:0,class:"field"},xt={class:"label"},Wt={class:"box"},Kt={class:"title font-bold"},Zt={class:"value"};function Xt(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-input-number");return e.supported?(n(),c("div",Nt,[l("div",xt,[l("div",Wt,[l("h2",Kt,r(e.$t("seedream.name.guidanceScale")),1),s(u,{content:e.$t("seedream.description.guidanceScale"),class:"info"},null,8,["content"])])]),l("div",Zt,[s(f,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=i=>e.value=i),min:1,max:10,step:.1,precision:1,size:"default","controls-position":"right",class:"counter"},null,8,["modelValue"])])])):v("",!0)}const Ht=y(jt,[["render",Xt],["__scopeId","data-v-7386f064"]]),Jt=k({name:"SeedreamWatermarkSwitch",components:{ElSwitch:ye,InfoIcon:I},computed:{value:{get(){const e=this.$store.state.seedream?.config?.watermark;return e===void 0?me:!!e},set(e){this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,watermark:e})}}}}),Qt={class:"field"},Yt={class:"label"},es={class:"box"},ts={class:"title font-bold"},ss={class:"value"};function os(e,t,d,o,m,p){const u=a("info-icon"),f=a("el-switch");return n(),c("div",Qt,[l("div",Yt,[l("div",es,[l("h2",ts,r(e.$t("seedream.name.watermark")),1),s(u,{content:e.$t("seedream.description.watermark"),class:"info"},null,8,["content"])])]),l("div",ss,[s(f,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=i=>e.value=i)},null,8,["modelValue"])])])}const as=y(Jt,[["render",os],["__scopeId","data-v-9e2abf0f"]]),ns=k({name:"SeedreamConfigPanel",components:{ElButton:P,FontAwesomeIcon:q,PromptInput:xe,Consumption:ve,ImageInput:nt,ModelSelector:ut,SizeSelector:vt,MaxImagesSelector:At,OutputFormatSelector:Dt,SeedInput:Bt,GuidanceScaleInput:Ht,WatermarkSwitch:as},emits:["generate"],computed:{config(){return this.$store.state.seedream?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image)&&e.image.length>0,d=e?.sequential_image_generation==="auto"?Math.max(1,Math.floor(e?.sequential_image_generation_options?.max_images||1)):1;return be({...e,action:t?"edit":"generate",model:Y(e?.model),count:d},this.service?.cost)},service(){return this.$store.state.seedream?.service}},methods:{onGenerate(){this.$emit("generate")}}}),rs={class:"flex flex-col h-full"},ls={class:"flex-1 overflow-y-auto p-5"},is={class:"flex flex-col items-center justify-center px-5 pb-5"};function cs(e,t,d,o,m,p){const u=a("model-selector"),f=a("size-selector"),i=a("max-images-selector"),_=a("output-format-selector"),h=a("seed-input"),b=a("guidance-scale-input"),M=a("watermark-switch"),L=a("prompt-input"),V=a("image-input"),T=a("consumption"),te=a("font-awesome-icon"),se=a("el-button");return n(),c("div",rs,[l("div",ls,[s(u,{class:"mb-4"}),s(f,{class:"mb-4"}),s(i,{class:"mb-4"}),s(_,{class:"mb-4"}),s(h,{class:"mb-4"}),s(b,{class:"mb-4"}),s(M,{class:"mb-4"}),s(L,{class:"mb-4"}),s(V,{class:"mb-4"})]),l("div",is,[s(T,{value:e.consumption,service:e.service},null,8,["value","service"]),s(se,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(te,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+r(e.$t("seedream.button.generate")),1)]),_:1},8,["onClick"])])])}const ds=y(ns,[["render",cs]]),ms=k({name:"SeedreamTaskPreview",components:{ElImage:Me,CopyToClipboard:Ie,FontAwesomeIcon:q,ElAlert:ze,ImageWrapper:Ae,ElButton:P,ElTooltip:Ve,ImagePreview:ee},props:{modelValue:{type:Object,required:!0}},computed:{isEdit(){return Array.isArray(this.modelValue?.request?.image)&&(this.modelValue?.request?.image?.length||0)>0},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{shortModel(e){return Y(e)||e},onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.seedream?.config||{}};t.image=[e],this.$store.commit("seedream/setConfig",t)}}}),us={class:"preview"},ps={class:"left"},fs={class:"main"},_s={class:"bot"},gs={class:"datetime"},hs={class:"info"},$s={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},vs={key:1,class:"prompt mt-2"},bs={key:0},Es={key:0,class:R({content:!0})},ks={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ys={key:1,class:R({content:!0,failed:!0})},Ss={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},ws={class:R({operations:!0,"mt-2":!0,"mb-2":!0})},Is={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},As={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},zs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ms={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ts={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Rs={key:2,class:R({content:!0})},Ls={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ds={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Cs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ps={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Us={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gs={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Fs={key:3,class:R({content:!0})},Os={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bs={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function js(e,t,d,o,m,p){const u=a("el-image"),f=a("image-preview"),i=a("font-awesome-icon"),_=a("copy-to-clipboard"),h=a("el-alert"),b=a("image-wrapper"),M=a("el-button"),L=a("el-tooltip");return n(),c("div",us,[l("div",ps,[s(u,{src:"https://cdn.acedata.cloud/9egrbn.png",class:"avatar"})]),l("div",fs,[l("div",_s,[g(r(e.$t("seedream.name.seedreamBot"))+" ",1),l("span",gs,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",hs,[Array.isArray(e.modelValue?.request?.image)&&e.modelValue?.request?.image.length>0?(n(),c("div",$s,[(n(!0),c(S,null,A(e.modelValue?.request?.image,(V,T)=>(n(),E(f,{key:T,url:V,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):v("",!0),e.modelValue?.request?.prompt?(n(),c("p",vs,[g(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(n(),c("span",bs," - ("+r(e.$t("seedream.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(n(),c("div",ys,[l("div",Ss,[(n(!0),c(S,null,A(e.images,(V,T)=>(n(),E(b,{key:T,src:V?.image_url,"raw-src":V?.image_url},null,8,["src","raw-src"]))),128))]),l("div",ws,[s(L,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[s(M,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=ae(V=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:$(()=>[g(r(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(h,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(n(),c("p",Is,[s(i,{icon:"fa-solid fa-cube",class:"mr-1"}),g(" "+r(e.$t("seedream.name.model"))+": "+r(e.shortModel(e.modelValue?.request?.model)),1)])):v("",!0),e.modelValue?.request?.size?(n(),c("p",As,[s(i,{icon:"fa-solid fa-image",class:"mr-1"}),g(" "+r(e.$t("seedream.name.size"))+": "+r(e.modelValue?.request?.size),1)])):v("",!0),l("p",Vs,[s(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),g(" "+r(e.$t("seedream.name.task"))+": "+r(e.isEdit?e.$t("seedream.name.edits"):e.$t("seedream.name.generate")),1)]),l("p",zs,[s(i,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+r(e.$t("seedream.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),s(_,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),c("p",Ms,[s(i,{icon:"fa-solid fa-clock",class:"mr-1"}),g(" "+r(e.$t("seedream.name.elapsed"))+": "+r(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):v("",!0),e.modelValue?.response?.trace_id?(n(),c("p",Ts,[s(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+r(e.$t("seedream.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),s(_,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),c("div",Rs,[s(h,{closable:!1,class:"failure"},{template:$(()=>[s(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+r(e.$t("seedream.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),c("p",Ls,[s(i,{icon:"fa-solid fa-cube",class:"mr-1"}),g(" "+r(e.$t("seedream.name.model"))+": "+r(e.shortModel(e.modelValue?.request?.model)),1)])):v("",!0),e.modelValue?.request?.size?(n(),c("p",Ds,[s(i,{icon:"fa-solid fa-image",class:"mr-1"}),g(" "+r(e.$t("seedream.name.size"))+": "+r(e.modelValue?.request?.size),1)])):v("",!0),l("p",Cs,[s(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),g(" "+r(e.$t("seedream.name.task"))+": "+r(e.isEdit?e.$t("seedream.name.edits"):e.$t("seedream.name.generate")),1)]),l("p",qs,[s(i,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+r(e.$t("seedream.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),s(_,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.error?.message?(n(),c("p",Ps,[s(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+r(e.$t("seedream.name.failureReason"))+": "+r(e.modelValue?.response?.error?.message)+" ",1),s(_,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])])):v("",!0),e.modelValue?.elapsed?(n(),c("p",Us,[s(i,{icon:"fa-solid fa-clock",class:"mr-1"}),g(" "+r(e.$t("seedream.name.elapsed"))+": "+r(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):v("",!0),e.modelValue?.response?.trace_id?(n(),c("p",Gs,[s(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+r(e.$t("seedream.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),s(_,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),c("div",Fs,[s(h,{closable:!1,class:"info"},{template:$(()=>[s(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+r(e.$t("seedream.name.status")),1)]),default:$(()=>[l("p",Os,[s(i,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+r(e.$t("seedream.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),s(_,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),c("p",Bs,[s(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+r(e.$t("seedream.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),s(_,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),c("div",Es,[s(h,{closable:!1,class:"info"},{template:$(()=>[s(i,{icon:"fa-regular fa-clock",class:"mr-1"}),g(" "+r(e.$t("seedream.status.pending")),1)]),default:$(()=>[l("p",ks,[s(i,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+r(e.$t("seedream.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),s(_,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})]))])])}const Ns=y(ms,[["render",js],["__scopeId","data-v-0dfc6a09"]]),xs=k({name:"SeedreamRecentPanel",components:{TaskPreview:Ns,BotPlaceholder:Te,NoTasks:Re,ScrollList:fe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],computed:{tasks(){return{...this.$store.state.seedream?.tasks,items:this.$store.state.seedream?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ws={key:0},Ks={key:2,class:"w-full h-full flex items-center justify-center"};function Zs(e,t,d,o,m,p){const u=a("bot-placeholder"),f=a("task-preview"),i=a("scroll-list"),_=a("no-tasks");return n(),c(S,null,[e.tasks?.items===void 0?(n(),c("div",Ws,[s(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),E(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=h=>e.$emit("reach-top"))},{default:$(()=>[(n(!0),c(S,null,A(e.tasks?.items,h=>(n(),E(f,{key:h.id,"model-value":h},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),c("div",Ks,[s(_)])):v("",!0)],64)}const Xs=y(xs,[["render",Zs]]),Hs=pe("seedream"),Js=k({name:"SeedreamIndex",components:{ConfigPanel:ds,Layout:Ue,RecentPanel:Xs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.seedream?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.seedream?.status?.getTasks===X.Request},credential(){return this.$store.state.seedream?.credential},config(){return this.$store.state.seedream?.config},application(){return this.$store.state.seedream?.application},tasks(){return this.$store.state.seedream?.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 _e({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("seedream/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("seedream/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:d,createdAtMax:o}=e||{};console.debug("limit",t,"createdAtMin",d,"createdAtMax",o),await this.$store.dispatch("seedream/getTasks",{limit:t,createdAtMin:d,createdAtMax:o})},async onGenerate(){const e={...this.config||{}};!(Array.isArray(e?.image)&&e.image.length>0)&&"image"in e&&delete e.image,e?.size||delete e.size;const d={...e,callback_url:Hs},o=this.credential?.token;if(!o){console.error("no token specified");return}z.info(this.$t("seedream.message.startingTask")),ue("seedream",we.generate(d,{token:o})).then(()=>{z.success(this.$t("seedream.message.startTaskSuccess"))}).catch(m=>{const p=m?.response?.data;p?.error?.code===Se?z.error(this.$t("seedream.message.usedUp")):z.error(this.$t("seedream.message.startTaskFailed")+(p?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Qs(e,t,d,o,m,p){const u=a("config-panel"),f=a("recent-panel"),i=a("layout");return n(),E(i,null,{config:$(()=>[s(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[s(f,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Zo=y(Js,[["render",Qs]]);export{Zo as default};
|