@acedatacloud/nexior 3.237.0 → 3.239.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/{ApiCodeButton-C2MQ9SzY.js → ApiCodeButton-9XDDLdNe.js} +1 -1
- package/dist/assets/{Auth-DE0Y3fR8.js → Auth-E-skiK5V.js} +1 -1
- package/dist/assets/{BotPlaceholder-Baul6A1g.js → BotPlaceholder-Bm3iFf5b.js} +1 -1
- package/dist/assets/{Callback-Dv9h1N-u.js → Callback-D_hR-iD4.js} +1 -1
- package/dist/assets/{Console-Cw_MlcCk.js → Console-BM0YTLRm.js} +1 -1
- package/dist/assets/{Consumption-DbCpeKTx.js → Consumption-Dvylkuyr.js} +1 -1
- package/dist/assets/{Conversation-BvJZrWl6.js → Conversation-BijKY7y4.js} +1 -1
- package/dist/assets/{CopyToClipboard-DEq33hBp.js → CopyToClipboard-3JBcjf6f.js} +1 -1
- package/dist/assets/{Detail-9ifpkob9.js → Detail-lOm9PZvx.js} +2 -2
- package/dist/assets/{Extra-BqLhQ62X.js → Extra-DPbHG9qK.js} +1 -1
- package/dist/assets/{FilePreview-CpuXslD4.js → FilePreview-DoguENGr.js} +1 -1
- package/dist/assets/{Hailuo-B1B7hp7C.js → Hailuo-DohJzCSN.js} +1 -1
- package/dist/assets/{History-DQoZXwD7.js → History-kX-OZwNZ.js} +1 -1
- package/dist/assets/{ImagePreview-B7TR3cuv.js → ImagePreview-Deaq21aE.js} +1 -1
- package/dist/assets/{ImageWrapper-DGlipIs0.js → ImageWrapper-DImeHzsC.js} +1 -1
- package/dist/assets/{Index-CEU6rwpF.js → Index-B0X6_nJH.js} +1 -1
- package/dist/assets/{Index-C4FqHBdr.js → Index-BE7-MjC3.js} +1 -1
- package/dist/assets/{Index-BZiFFd5M.js → Index-BFsNP2B_.js} +1 -1
- package/dist/assets/{Index-7SdYsPNf.js → Index-BJ3_okcm.js} +1 -1
- package/dist/assets/{Index-CC_dbzme.js → Index-BKYmZwGJ.js} +1 -1
- package/dist/assets/{Index-BpqieUEs.js → Index-B_XtH1-K.js} +1 -1
- package/dist/assets/{Index-PlCoBue0.js → Index-BgFaQOoo.js} +1 -1
- package/dist/assets/{Index-DGjItSg3.js → Index-BhpyCXhO.js} +1 -1
- package/dist/assets/{Index-zepKpyhJ.js → Index-C98LPYHA.js} +1 -1
- package/dist/assets/{Index-97U6EEhb.js → Index-CFroiTM4.js} +1 -1
- package/dist/assets/{Index-iFFYR9dh.js → Index-CVe_7DP8.js} +1 -1
- package/dist/assets/{Index-BV9fa1SR.js → Index-CaeG-Ijb.js} +1 -1
- package/dist/assets/{Index-Ds1DEoo7.js → Index-Cj9nyhEQ.js} +1 -1
- package/dist/assets/{Index-B_rEjzTP.js → Index-CyquPdM-.js} +1 -1
- package/dist/assets/{Index-CGjbzFgY.js → Index-D43f89Xf.js} +1 -1
- package/dist/assets/{Index-D-f9FKON.js → Index-DB8QWEcm.js} +1 -1
- package/dist/assets/{Index-raZEkNn-.js → Index-DNpl_Z74.js} +1 -1
- package/dist/assets/{Index-JkHOfEye.js → Index-DUbD0frI.js} +1 -1
- package/dist/assets/{Index-D_A85AF-.js → Index-DVis1sP7.js} +1 -1
- package/dist/assets/{Index-BNajdlv2.js → Index-DZ5j-DTs.js} +1 -1
- package/dist/assets/{Index-xF44OWWZ.js → Index-DnPgKumX.js} +1 -1
- package/dist/assets/{Index-Bu8n154W.js → Index-Dwff1_YM.js} +1 -1
- package/dist/assets/{Index-Ch6AgNup.js → Index-DyAuRyZg.js} +1 -1
- package/dist/assets/{Index-BJ8FKVm8.js → Index-DzFtGWLo.js} +1 -1
- package/dist/assets/{Index-VXLrbfhx.js → Index-wIEETVeb.js} +1 -1
- package/dist/assets/{Invitees-Bn5R9H6k.js → Invitees-i5VbbrcY.js} +1 -1
- package/dist/assets/{List-CC7vWwTB.js → List-B4Dxou83.js} +1 -1
- package/dist/assets/{List-BHMrQ6of.js → List-CEZWNjFR.js} +1 -1
- package/dist/assets/{List-DmcckN8y.js → List-Dbu3Ztki.js} +1 -1
- package/dist/assets/{Main-CPLCZJ3L.js → Main-fFwoQBAi.js} +1 -1
- package/dist/assets/{Model-2o8tb8AP.js → Model-C-KyaS22.js} +1 -1
- package/dist/assets/Navigator-BaaMmQ4U.js +3 -0
- package/dist/assets/{Navigator-C2gf5cvB.css → Navigator-DyXS7zmI.css} +1 -1
- package/dist/assets/{NoTasks-DMd-Y0Bj.js → NoTasks-DYAWTz-D.js} +1 -1
- package/dist/assets/{NotFound-BcUsizQg.js → NotFound-CDJbN_1S.js} +1 -1
- package/dist/assets/{Pagination-CcmWJkH5.js → Pagination-DufV0sEu.js} +1 -1
- package/dist/assets/{Player.vue_vue_type_script_setup_true_lang-BPghDa7I.js → Player.vue_vue_type_script_setup_true_lang-D3T5quDE.js} +1 -1
- package/dist/assets/{Status-sFgKDqv-.js → Status-C4IHxHJ1.js} +1 -1
- package/dist/assets/{Subscribe-CSzM2w1e.js → Subscribe-BGKhTstR.js} +1 -1
- package/dist/assets/{TabSwitcher-6eK3wvHA.js → TabSwitcher-DW6ihcmN.js} +1 -1
- package/dist/assets/{Tts-7MnpOMoM.js → Tts-KOlK790E.js} +1 -1
- package/dist/assets/{VideoPlayer-BAxqS3nn.js → VideoPlayer-Br2yW1lu.js} +1 -1
- package/dist/assets/{_Uint8Array-CqhDs8r-.js → _Uint8Array-CRC1hUw5.js} +1 -1
- package/dist/assets/{_baseClone-F4jqycTX.js → _baseClone-BR0qWb-t.js} +1 -1
- package/dist/assets/{_baseIteratee-Cx49hKZX.js → _baseIteratee-BQgCC_-_.js} +1 -1
- package/dist/assets/{_initCloneObject-D8OU-52K.js → _initCloneObject-EbmJQUEy.js} +1 -1
- package/dist/assets/{add-DgavPQm6.js → add-CRpDp35U.js} +1 -1
- package/dist/assets/{all-wallets-BOladkIi.js → all-wallets-DwbobbEs.js} +1 -1
- package/dist/assets/{app-store-DRUq7UMb.js → app-store-ips1Ck1n.js} +1 -1
- package/dist/assets/{apple-Cf4x0ojp.js → apple-DHC4UjwD.js} +1 -1
- package/dist/assets/{arrow-bottom-BkSweJ2L.js → arrow-bottom-BZFYAi_-.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-C2gL13gm.js → arrow-bottom-circle-CQHF78JI.js} +1 -1
- package/dist/assets/{arrow-left-D_dkTzLS.js → arrow-left-DxFsbLoi.js} +1 -1
- package/dist/assets/{arrow-right-_i-I4BYG.js → arrow-right-Bvacre0J.js} +1 -1
- package/dist/assets/{arrow-top-D9Gi9pWy.js → arrow-top-CGIfeznS.js} +1 -1
- package/dist/assets/{avatar-Bwoj2Y6p.js → avatar-DSBIeYLM.js} +1 -1
- package/dist/assets/{bank-DD-Tm2u5.js → bank-BhhhHBlx.js} +1 -1
- package/dist/assets/{basic-Dxl8Uqr_.js → basic-DqTjgomq.js} +1 -1
- package/dist/assets/{browser-DR1GgNeB.js → browser-Cq11PuHx.js} +1 -1
- package/dist/assets/{byokCredential-C4-IgX5R.js → byokCredential-CR_scd-V.js} +1 -1
- package/dist/assets/{card-D1BJdJ7z.js → card-CWT4zM8c.js} +1 -1
- package/dist/assets/{castArray-B4Yz3lTf.js → castArray-D90oh5Za.js} +1 -1
- package/dist/assets/{chat-BeFGqVk3.js → chat-DovQA6qr.js} +1 -1
- package/dist/assets/{checkmark-DdXJyQdS.js → checkmark-G7hCMAuv.js} +1 -1
- package/dist/assets/{checkmark-bold-BpF2lVsn.js → checkmark-bold-DRTmcfqk.js} +1 -1
- package/dist/assets/{chevron-bottom-Ck0NtV5T.js → chevron-bottom-ZbJ3daPB.js} +1 -1
- package/dist/assets/{chevron-left-B79dE51I.js → chevron-left-BffvOzR9.js} +1 -1
- package/dist/assets/{chevron-right-CqjhxMnU.js → chevron-right-mhZNm2FM.js} +1 -1
- package/dist/assets/{chevron-top-NDwmbhQW.js → chevron-top-DaZAYyiN.js} +1 -1
- package/dist/assets/{chrome-store-yc3tOv0n.js → chrome-store-G4JXejzb.js} +1 -1
- package/dist/assets/{clock-CRTbAvEp.js → clock-DWiCagKC.js} +1 -1
- package/dist/assets/{close-Db6z47ze.js → close-iqkiQ-Hh.js} +1 -1
- package/dist/assets/{coinPlaceholder-D41FJmzF.js → coinPlaceholder-yVGymBZU.js} +1 -1
- package/dist/assets/{compass-DSrkNVls.js → compass-DYe-Gp8w.js} +1 -1
- package/dist/assets/{copy-pvxHGkbe.js → copy-Crx05MoJ.js} +1 -1
- package/dist/assets/{createTaskActions-V7wwin3_.js → createTaskActions-Q6UtPA9W.js} +1 -1
- package/dist/assets/{cursor-BUp6Uvf_.js → cursor-CtXPztuR.js} +1 -1
- package/dist/assets/{cursor-transparent-uA8Uh7jh.js → cursor-transparent-CqD8yUua.js} +1 -1
- package/dist/assets/{debounce-Czl_Hgxw.js → debounce-B16-iZx6.js} +1 -1
- package/dist/assets/{desktop-Cp5JWDuI.js → desktop-DjCmfA67.js} +1 -1
- package/dist/assets/{disconnect-JiXzu1lL.js → disconnect-2kt93r5t.js} +1 -1
- package/dist/assets/{discord-HxYXfbJ_.js → discord-BXh9KuOQ.js} +1 -1
- package/dist/assets/{distribution-DuKvZpdt.js → distribution-BqdaQ6Cl.js} +1 -1
- package/dist/assets/{dropdown-Bu264COk.js → dropdown-D9V39-fe.js} +1 -1
- package/dist/assets/{etherscan-CQss6knH.js → etherscan-6mn_a0iV.js} +1 -1
- package/dist/assets/{exclamation-triangle-DzeqdJVv.js → exclamation-triangle-BNZ7Y0y8.js} +1 -1
- package/dist/assets/{extension-EIYIpDag.js → extension-Ctbyh_V5.js} +1 -1
- package/dist/assets/{external-link-xrS2ajm9.js → external-link-CNs_rVuZ.js} +1 -1
- package/dist/assets/{facebook-BGIMg_-u.js → facebook-CEapcw-R.js} +1 -1
- package/dist/assets/{farcaster-DBxkV759.js → farcaster-Dh8WXaVA.js} +1 -1
- package/dist/assets/{filters-B1sRRpVi.js → filters-BA2TDn92.js} +1 -1
- package/dist/assets/{github-BXA_MxLk.js → github-PKGGE05y.js} +1 -1
- package/dist/assets/{google-Cvsuwgnf.js → google-DraeeoL7.js} +1 -1
- package/dist/assets/{help-circle-h6Dv_jiW.js → help-circle-BuYisFM2.js} +1 -1
- package/dist/assets/{highlight-CwI9kFio.js → highlight-DEv6Uzjh.js} +1 -1
- package/dist/assets/{id-DU6uPXQN.js → id-BCZIyTBk.js} +1 -1
- package/dist/assets/{image-Cs1u4Vzv.js → image-DxhDw2vp.js} +1 -1
- package/dist/assets/{index-CNmXg0Xr.js → index-8HF8bAn8.js} +1 -1
- package/dist/assets/{index-DMtC0tQC.js → index-B5zfRlKe.js} +1 -1
- package/dist/assets/{index-DNJR8VlC.js → index-B8P1W9Dy.js} +1 -1
- package/dist/assets/{index-Bho_zxTF.js → index-BAWUkbI3.js} +1 -1
- package/dist/assets/{index-BTsT39OO.js → index-BBhODJQx.js} +1 -1
- package/dist/assets/{index-QK2Oa-KY.js → index-BFUf5YVt.js} +1 -1
- package/dist/assets/{index-ci2BqSr8.js → index-BHVQW8Q2.js} +1 -1
- package/dist/assets/{index-DtSTB-41.js → index-BKgRYY8E.js} +1 -1
- package/dist/assets/{index-yMuV2e4E.js → index-BLH93c1h.js} +1 -1
- package/dist/assets/{index-2GkrLLTf.js → index-BV4fHzx-.js} +1 -1
- package/dist/assets/{index-DAYum5hi.js → index-BVwAPJvQ.js} +1 -1
- package/dist/assets/{index-Hs0Bx2Kc.js → index-Bi53K4Mi.js} +1 -1
- package/dist/assets/{index-ixYd2J7a.js → index-BiKbOqit.js} +5 -5
- package/dist/assets/{index-BNhPwgid.js → index-BitdtvW1.js} +4 -4
- package/dist/assets/{index-DH-R5k-K.js → index-BjbmY8Qg.js} +1 -1
- package/dist/assets/{index-tFnO9PkK.js → index-BkchfnNA.js} +1 -1
- package/dist/assets/{index-kRap_oJr.js → index-Bo7zkVzy.js} +1 -1
- package/dist/assets/{index-CbAq-71H.js → index-BtCpCAYM.js} +1 -1
- package/dist/assets/{index-BwZwETre.js → index-BtRIGKkx.js} +1 -1
- package/dist/assets/{index-CvtjSBvL.js → index-Bz9B1sA_.js} +1 -1
- package/dist/assets/{index-DmxpLrqJ.js → index-C0zx3uvU.js} +1 -1
- package/dist/assets/{index-7YI76Rdj.js → index-C41gSxyw.js} +1 -1
- package/dist/assets/{index-BHgdHX0w.js → index-C9-0VnKI.js} +1 -1
- package/dist/assets/{index-Dy-usgmC.js → index-CAnSJQ4u.js} +1 -1
- package/dist/assets/{index-CwgZ37Ug.js → index-CBCFXmR4.js} +1 -1
- package/dist/assets/{index-XVF4kigm.js → index-CCeJfLsu.js} +1 -1
- package/dist/assets/{index-CwnNiLeW.js → index-CFtFSkRX.js} +1 -1
- package/dist/assets/{index-CKVYrrtD.js → index-CRROw2v3.js} +1 -1
- package/dist/assets/{index-blOeQXxC.js → index-CVCfk6pt.js} +1 -1
- package/dist/assets/{index-D7zqZA37.js → index-CXGm2ibp.js} +1 -1
- package/dist/assets/{index-Cvty-gmp.js → index-C_zWcuAN.js} +1 -1
- package/dist/assets/{index-bk10PI5E.js → index-CbNmLSFW.js} +1 -1
- package/dist/assets/{index-Ua1E8d1o.js → index-Cco9hRL2.js} +2 -2
- package/dist/assets/{index-ZTi6ldXW.js → index-Ccy80B9i.js} +1 -1
- package/dist/assets/{index-C1SjgDpr.js → index-CfpZLGo7.js} +1 -1
- package/dist/assets/{index-DepEVXPI.js → index-CgwDba1C.js} +1 -1
- package/dist/assets/{index-BJo8vlkh.js → index-CrqbAkrw.js} +1 -1
- package/dist/assets/{index-CvCKGUMa.js → index-CuQoKX2f.js} +1 -1
- package/dist/assets/{index-BKuvfiRO.js → index-Cy8wLIr0.js} +1 -1
- package/dist/assets/{index-BVv5SRE3.js → index-D0beq2Y9.js} +3 -3
- package/dist/assets/{index-BRsHscIT.js → index-D21QqIXk.js} +1 -1
- package/dist/assets/{index-Cg7rtJ1A.js → index-D7f1sAJb.js} +1 -1
- package/dist/assets/{index-gxV04cPS.js → index-D7zJSPd1.js} +1 -1
- package/dist/assets/{index-B1oB6YEW.js → index-D95HBrhl.js} +1 -1
- package/dist/assets/{index-CkHswQhP.js → index-DDg_ne2W.js} +1 -1
- package/dist/assets/{index-Ruv04G7j.js → index-DI25owPX.js} +1 -1
- package/dist/assets/{index-DNQyB2jN.js → index-DJQOztFq.js} +1 -1
- package/dist/assets/{index-C5wTAYUI.js → index-DMuir5Ca.js} +1 -1
- package/dist/assets/{index-BELKLyOB.js → index-DQ7HmFtn.js} +1 -1
- package/dist/assets/{index-90Hjetr9.js → index-DY9n5RWp.js} +1 -1
- package/dist/assets/{index-CL6K14uy.js → index-DYQToXUU.js} +1 -1
- package/dist/assets/{index-19JS42QG.js → index-D_TaRFAX.js} +1 -1
- package/dist/assets/{index-BAAlVPkq.js → index-DayNhmqV.js} +1 -1
- package/dist/assets/{index-wCZDtI69.js → index-DcCp2-Ex.js} +1 -1
- package/dist/assets/{index-CqprjkP_.js → index-DldYJWMF.js} +1 -1
- package/dist/assets/{index-CegRGlaj.js → index-DqD-0Cn7.js} +1 -1
- package/dist/assets/{index-Cah9_Ghr.js → index-IEnCZwtg.js} +1 -1
- package/dist/assets/{index-PJc43D6S.js → index-PLhHdafx.js} +1 -1
- package/dist/assets/{index-CYIjgPaZ.js → index-TqGfcTRI.js} +1 -1
- package/dist/assets/{index-CZtZF4TE.js → index-XLYMNUFJ.js} +1 -1
- package/dist/assets/{index-DMWjnsgd.js → index-_-FKmUiC.js} +1 -1
- package/dist/assets/{index-BS9U-gw1.js → index-cn5_DmaE.js} +1 -1
- package/dist/assets/{index-BhZge2V1.js → index-osOxmKEr.js} +1 -1
- package/dist/assets/{index.browser.esm-BzF_B6Nn.js → index.browser.esm-BpmaOdhL.js} +1 -1
- package/dist/assets/{index.es-DyJLipdG.js → index.es-fM0biscR.js} +1 -1
- package/dist/assets/{info-B_gzZsvB.js → info-DrWk6vRi.js} +1 -1
- package/dist/assets/{info-circle-CVgGNJhH.js → info-circle-02zOJVKW.js} +1 -1
- package/dist/assets/{isEqual-BOE0f6gl.js → isEqual-CMrgrIDS.js} +1 -1
- package/dist/assets/{isPlainObject-CZg6Ew5N.js → isPlainObject-C8UsK3_R.js} +1 -1
- package/dist/assets/{lightbulb-BnaLxOyF.js → lightbulb-Dcnqg3zI.js} +1 -1
- package/dist/assets/{mail-CafzkYkm.js → mail-C8sqp_v6.js} +1 -1
- package/dist/assets/{midjourney-BBVcwBNl.js → midjourney-BHGRMonG.js} +1 -1
- package/dist/assets/{mobile-CtZqDryc.js → mobile-cH01pbv1.js} +1 -1
- package/dist/assets/{more-C1pi40aj.js → more-BYMndHQe.js} +1 -1
- package/dist/assets/{network-placeholder-BX_Izdj6.js → network-placeholder-QWwr0dl-.js} +1 -1
- package/dist/assets/{nftPlaceholder-BuWFeyKg.js → nftPlaceholder-DoAK6JHj.js} +1 -1
- package/dist/assets/{off-BUw0UTze.js → off-DU4onOnU.js} +1 -1
- package/dist/assets/{order-CZUPtKPH.js → order-DmJO74Fs.js} +1 -1
- package/dist/assets/{pagination-C2vPjR_g.js → pagination-CDMeT271.js} +1 -1
- package/dist/assets/{play-store-D4jpEBQ9.js → play-store-DFZUhS6Y.js} +1 -1
- package/dist/assets/{plus-vg6FAgDZ.js → plus-C2zrXi7v.js} +1 -1
- package/dist/assets/{price-YQCGNRFk.js → price-UzqaC8kS.js} +1 -1
- package/dist/assets/{producer-99MlGCbq.js → producer-CwYheP8p.js} +1 -1
- package/dist/assets/{qr-code-hAUbgqVP.js → qr-code-dngEl-ZK.js} +1 -1
- package/dist/assets/{recycle-horizontal-RZUHK_9H.js → recycle-horizontal-B4wowDGK.js} +1 -1
- package/dist/assets/{refresh-BEeEMRFk.js → refresh-C6LEL-5a.js} +1 -1
- package/dist/assets/{reown-logo-xAFTKSdf.js → reown-logo-DtQhfal2.js} +1 -1
- package/dist/assets/{search-BrwFFifG.js → search-Sm0vDUH5.js} +1 -1
- package/dist/assets/{secp256k1-Bymojw6K.js → secp256k1-BelJbK0s.js} +1 -1
- package/dist/assets/{secp256k1-D8Xywgg9.js → secp256k1-mIpi5NB9.js} +1 -1
- package/dist/assets/{seedream-D6RmVzEo.js → seedream-CmLyPhZ0.js} +1 -1
- package/dist/assets/{send-KtGb0M1_.js → send-DQbdEfeX.js} +1 -1
- package/dist/assets/{service-hdAghS_N.js → service-Cth1lVB8.js} +1 -1
- package/dist/assets/{solana-wallets-ki4bpYeu.js → solana-wallets-BAy2-eoa.js} +2 -2
- package/dist/assets/{solana-wallets-vue--F1mT6vg.js → solana-wallets-vue-FjQ7t8jk.js} +1 -1
- package/dist/assets/subsite-8htWTxFn.js +1 -0
- package/dist/assets/subsite-BL5mOrr1.js +1 -0
- package/dist/assets/subsite-BNKmSzo-.js +1 -0
- package/dist/assets/subsite-BiGtGhvE.js +1 -0
- package/dist/assets/subsite-BvzAuzC-.js +1 -0
- package/dist/assets/subsite-C54AOcnd.js +1 -0
- package/dist/assets/subsite-CCktyerR.js +1 -0
- package/dist/assets/subsite-CDYEQOTD.js +1 -0
- package/dist/assets/subsite-ChmCrf9h.js +1 -0
- package/dist/assets/subsite-CiCLsst4.js +1 -0
- package/dist/assets/subsite-CjsQyrer.js +1 -0
- package/dist/assets/subsite-D1uL2HXY.js +1 -0
- package/dist/assets/subsite-D5ENZyhT.js +1 -0
- package/dist/assets/subsite-DH2q3YKR.js +1 -0
- package/dist/assets/subsite-DUoz-n2w.js +1 -0
- package/dist/assets/subsite-DiUNQwvY.js +1 -0
- package/dist/assets/subsite-MlffMoHD.js +1 -0
- package/dist/assets/subsite-aavu4y0F.js +1 -0
- package/dist/assets/{suno-Cfzf_ihe.js → suno-VCUQZZa7.js} +1 -1
- package/dist/assets/{swapHorizontal-B_qLLdAo.js → swapHorizontal-Cs5ExypK.js} +1 -1
- package/dist/assets/{swapHorizontalBold-CD5jkO3T.js → swapHorizontalBold-BYj0sSJS.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-BG8EtUzG.js → swapHorizontalMedium-BkkxkNRJ.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-DVG6gcTL.js → swapHorizontalRoundedBold-CzBCoABO.js} +1 -1
- package/dist/assets/{swapVertical-m9u-nplK.js → swapVertical-CWFkNqay.js} +1 -1
- package/dist/assets/{telegram-BbX5e5S8.js → telegram-CP9ruRz3.js} +1 -1
- package/dist/assets/{three-dots-DfALpKwR.js → three-dots-DPEF_pkB.js} +1 -1
- package/dist/assets/{twitch-C_wg0vdT.js → twitch-Dom0AiOG.js} +1 -1
- package/dist/assets/{twitterIcon-BBja6km9.js → twitterIcon-BADqc1Z8.js} +1 -1
- package/dist/assets/{typescript-DYyGuIeV.js → typescript-CdFsS8fD.js} +1 -1
- package/dist/assets/{use-form-item-M-EBwqcE.js → use-form-item-CaXGkw6S.js} +1 -1
- package/dist/assets/validator-BIWRmSMB.js +1 -0
- package/dist/assets/{verify-DSrdtv3S.js → verify-Dwwr_ytZ.js} +1 -1
- package/dist/assets/{verify-filled-CJEvAe-t.js → verify-filled-JqqsjM4k.js} +1 -1
- package/dist/assets/{w3m-modal-Cic_q5DL.js → w3m-modal-CDncFu_i.js} +1 -1
- package/dist/assets/{wallet-C0P7wWSb.js → wallet-BbYj1sn_.js} +1 -1
- package/dist/assets/{wallet-placeholder-Fui2c1Ti.js → wallet-placeholder-C2ScyMjR.js} +1 -1
- package/dist/assets/{walletconnect-Cij5Cfeo.js → walletconnect-B2A33q08.js} +1 -1
- package/dist/assets/{warning-circle-Cpoux31G.js → warning-circle-Dvs9YTFd.js} +1 -1
- package/dist/assets/{web-DGdJ1bx5.js → web-DTuJ35Tx.js} +1 -1
- package/dist/assets/{web-DNd2BgAr.js → web-DnbaFvS2.js} +1 -1
- package/dist/assets/{x-BnEHxJR_.js → x-DH3hIXRZ.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Navigator-ByuWpScz.js +0 -3
- package/dist/assets/subsite-7l2A4PE7.js +0 -1
- package/dist/assets/subsite-BNQM8Dkp.js +0 -1
- package/dist/assets/subsite-BSK2WsSr.js +0 -1
- package/dist/assets/subsite-BXG2_a7Y.js +0 -1
- package/dist/assets/subsite-BXio0HWv.js +0 -1
- package/dist/assets/subsite-Bcn-kayq.js +0 -1
- package/dist/assets/subsite-Bq_ZUC2f.js +0 -1
- package/dist/assets/subsite-Bs2LBffB.js +0 -1
- package/dist/assets/subsite-CKG_VBQh.js +0 -1
- package/dist/assets/subsite-CLKyVx2U.js +0 -1
- package/dist/assets/subsite-CkLYoT0G.js +0 -1
- package/dist/assets/subsite-D-2srI3S.js +0 -1
- package/dist/assets/subsite-D-VxeBd7.js +0 -1
- package/dist/assets/subsite-DEEDUo21.js +0 -1
- package/dist/assets/subsite-DLFuWkBw.js +0 -1
- package/dist/assets/subsite-Say18AMe.js +0 -1
- package/dist/assets/subsite-oinDhmIs.js +0 -1
- package/dist/assets/subsite-uDhfLFIz.js +0 -1
- package/dist/assets/validator-BXiGjteq.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as L}from"./index.es-DyJLipdG.js";import{E as D}from"./index-D7zqZA37.js";import{E as N}from"./index-CL6K14uy.js";import{d as v,H as r,E as i,z as P,C as o,y as m,D as s,q as a,F as l,O as T,N as I,x as w,Q as A,R as j,I as _,J as h,G as q,L as H}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as K,cs as W,aM as Z,S as G,ct as J}from"./index-BNhPwgid.js";import{a as M,b as z,c as E,d as F,e as Q,f as Y,g as X,h as x,i as ee}from"./sora-Dyuoglk1.js";import{E as R,a as O}from"./index-blOeQXxC.js";import{p as te}from"./pasteUploadMixin-BurWbGNQ.js";import{u as oe,a as se,e as ae}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as ne,S as le,l as re}from"./pagination-C2vPjR_g.js";import{I as ie}from"./ImagePreview-B7TR3cuv.js";import{E as ce}from"./index-DMtC0tQC.js";import{E as V}from"./index-90Hjetr9.js";import{C as de}from"./Consumption-DbCpeKTx.js";import{P as ue,N as pe}from"./NoTasks-DMd-Y0Bj.js";import{a as me}from"./price-YQCGNRFk.js";import{b as fe}from"./errorCode-Cqj9Td_Z.js";import{C as _e}from"./CopyToClipboard-DEq33hBp.js";import{V as he}from"./VideoPlayer-BAxqS3nn.js";import{A as $e}from"./ApiCodeButton-C2MQ9SzY.js";import{E as ge}from"./index-CKVYrrtD.js";import{E as ve}from"./index-CZtZF4TE.js";import{E as be}from"./index-tFnO9PkK.js";import{B as ke}from"./BotPlaceholder-Baul6A1g.js";import"./use-form-item-M-EBwqcE.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-QK2Oa-KY.js";import"./typescript-DYyGuIeV.js";import"./index-DtSTB-41.js";import"./strings-beZM2Y-f.js";import"./isEqual-BOE0f6gl.js";import"./_Uint8Array-CqhDs8r-.js";import"./castArray-B4Yz3lTf.js";import"./index-BS9U-gw1.js";import"./index-Cah9_Ghr.js";import"./debounce-Czl_Hgxw.js";import"./_baseIteratee-Cx49hKZX.js";import"./index-kRap_oJr.js";import"./highlight-CwI9kFio.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-XVF4kigm.js";import"./_baseClone-F4jqycTX.js";import"./_initCloneObject-D8OU-52K.js";import"./vue-plyr-BO2nlN4c.js";import"./index-ci2BqSr8.js";const we=v({name:"LayoutSora",components:{ElDrawer:N,ElButton:D,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ye={class:"main flex flex-row flex-1"},Se={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ve={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ee(e,t,d,f,$,g){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),r("div",ye,[i("div",Se,[P(e.$slots,"config",{},void 0,!0)]),i("div",Ve,[P(e.$slots,"result",{},void 0,!0)]),o(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:m(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[P(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Te=b(we,[["render",Ee],["__scopeId","data-v-bbee238c"]]),Ae=v({name:"ModelSelector",components:{ElSelect:O,ElOption:R},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:Q,label:"sora-2"},{value:Y,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},d=z[e]||[E],f=t.duration,$=f&&d.includes(f)?f:d.includes(E)?E:d[0],g={...t,model:e,duration:$,size:t.size||F};this.$store.commit("sora/setConfig",g)}}},mounted(){this.value||(this.value=M)}}),Ie={class:"field"},Ce={class:"title font-bold"};function Le(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Ie,[i("h2",Ce,l(e.$t("sora.name.model")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ae,[["render",Le],["__scopeId","data-v-0cb7913d"]]),Re=v({name:"ActionSelector",components:{ElSelect:O,ElOption:R},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Oe={class:"field"},Ue={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Oe,[i("h2",Ue,l(e.$t("sora.name.action")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},{default:m(()=>[i("span",Pe,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=b(Re,[["render",Ge],["__scopeId","data-v-7b82fa7f"]]),ze=v({name:"DurationSelector",components:{ElSelect:O,ElOption:R},computed:{model(){return this.$store.state.sora?.config?.model||M},allowedDurations(){return z[this.model]||[E]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(E)?E:e[0];this.value=t}}},mounted(){this.value||(this.value=E)}}),Fe={class:"field"},Be={class:"control"},Ne={class:"title font-bold"};function je(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Fe,[i("div",Be,[i("h2",Ne,l(e.$t("sora.name.duration")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.optionsForModel,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const qe=b(ze,[["render",je],["__scopeId","data-v-c2934598"]]),He=v({name:"OrientationSelector",data(){return{options:[{value:"portrait",labelKey:"sora.option.portrait",width:13,height:25},{value:"landscape",labelKey:"sora.option.landscape",width:25,height:13}]}},computed:{active(){const e=this.options.findIndex(t=>t.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=x)}}),Ke={class:"text-sm font-bold mb-2 block"},We={class:"items"},Ze=["onClick"],Je={class:"name"};function Qe(e,t,d,f,$,g){return a(),r("div",null,[i("span",Ke,l(e.$t("sora.name.orientation")),1),i("div",We,[(a(!0),r(T,null,I(e.options,(c,u)=>(a(),r("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:n=>e.value=c.value},[i("div",{class:A(["preview",c.value])},[i("div",{class:"rect",style:j({width:c.width+"px",height:c.height+"px"})},null,4)],2),i("p",Je,l(e.$t(c.labelKey)),1)],10,Ze))),128))])])}const Ye=b(He,[["render",Qe],["__scopeId","data-v-a20be6d9"]]),Xe=v({name:"StartEndImage",components:{ElUpload:ce,ElButton:D,InfoIcon:ne,FontAwesomeIcon:L,ImagePreview:ie},mixins:[te,oe],emits:["change"],data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){V.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){V.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),xe={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,d,f,$,g){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),k=s("el-button"),S=s("el-upload");return a(),r("div",xe,[i("div",et,[i("div",tt,[i("span",ot,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(S,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=p=>e.fileList=p),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:p})=>[p.url&&p.percentage!==void 0?(a(),w(u,{key:0,url:p.url,name:p.name,percentage:p.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(p),1)},null,8,["url","name","percentage","onRemove"])):h("",!0)]),default:m(()=>[o(k,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:m(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const at=b(Xe,[["render",st],["__scopeId","data-v-4f7d9ba5"]]),nt=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),lt=v({name:"SizeSelector",components:{ElSelect:O,ElOption:R},data(){return{options:ee.map(e=>({value:e,label:nt(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=F)}}),rt={class:"field"},it={class:"control"},ct={class:"title font-bold"};function dt(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",rt,[i("div",it,[i("h2",ct,l(e.$t("sora.name.size")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const ut=b(lt,[["render",dt],["__scopeId","data-v-8c485f0f"]]),pt="",mt=v({name:"PromptInput",components:{PromptTextarea:ue},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=pt)}});function ft(e,t,d,f,$,g){const c=s("prompt-textarea");return a(),w(c,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),title:e.$t("sora.name.prompt"),info:e.$t("sora.description.prompt"),placeholder:e.$t("sora.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const _t=b(mt,[["render",ft]]),ht=v({name:"ConfigPanel",components:{ElButton:D,Consumption:de,FontAwesomeIcon:L,PromptInput:_t,ModelSelector:De,StartEndImage:at,SizeSelector:ut,ActionSelector:Me,OrientationSelector:Ye,DurationSelector:qe},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),$t={class:"flex flex-col h-full"},gt={class:"flex-1 overflow-y-auto p-5"},vt={class:"flex flex-col items-center justify-center px-5 pb-5"};function bt(e,t,d,f,$,g){const c=s("model-selector"),u=s("action-selector"),n=s("duration-selector"),k=s("size-selector"),S=s("orientation-selector"),p=s("prompt-input"),y=s("start-end-image"),C=s("consumption"),U=s("font-awesome-icon"),B=s("el-button");return a(),r("div",$t,[i("div",gt,[o(c,{class:"mb-4"}),o(u,{class:"mb-4"}),o(n,{class:"mb-4"}),o(k,{class:"mb-4"}),o(S,{class:"mb-4"}),o(p,{class:"mb-4"}),q(o(y,{class:"mb-2"},null,512),[[H,e.config?.action==="image2video"]])]),i("div",vt,[o(C,{value:e.consumption,service:e.service},null,8,["value","service"]),o(B,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const kt=b(ht,[["render",bt]]),wt=v({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:_e,FontAwesomeIcon:L,ElAlert:ve,VideoPlayer:he,ElTooltip:ge,ElButton:D,ApiCodeButton:$e},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),yt={class:"preview"},St={class:"left"},Vt={class:"main"},Et={class:"bot"},Tt={class:"datetime"},At={class:"info"},It={key:0,class:"prompt mt-2"},Ct={key:0},Lt={key:1},Dt={key:0,class:A({content:!0,failed:!0})},Rt={key:0,class:"mb-4"},Ot={key:1,class:A({operations:!0,"mt-2":!0})},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Mt={key:1,class:A({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},jt={key:2,class:A({content:!0})},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Kt(e,t,d,f,$,g){const c=s("el-image"),u=s("video-player"),n=s("el-button"),k=s("el-tooltip"),S=s("api-code-button"),p=s("font-awesome-icon"),y=s("copy-to-clipboard"),C=s("el-alert");return a(),r("div",yt,[i("div",St,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),i("div",Vt,[i("div",Et,[_(l(e.$t("sora.name.soraBot"))+" ",1),i("span",Tt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",At,[e.modelValue?.request?.prompt?(a(),r("p",It,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",Ct," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(a(),r("span",Lt," - ("+l(e.$t("sora.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Rt,[o(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):h("",!0),e.modelValue?.response.success?(a(),r("div",Ot,[o(k,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:m(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=U=>e.onDownload(U,e.modelValue?.response?.data[0]?.video_url))},{default:m(()=>[_(l(e.$t("sora.button.download")),1)]),_:1})):h("",!0)]),_:1},8,["content"]),o(S,{path:"/sora/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),o(C,{closable:!1,class:"mt-2 success"},{default:m(()=>[i("p",Ut,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),i("p",Pt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Gt,[o(p,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Mt,[o(C,{closable:!1,class:"failure"},{template:m(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("sora.name.failure")),1)]),default:m(()=>[i("p",zt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),i("p",Ft,[o(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Bt,[o(p,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===void 0?(a(),r("div",jt,[o(C,{closable:!1,class:"info"},{template:m(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("sora.name.failure")),1)]),default:m(()=>[i("p",qt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Ht,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):h("",!0)]),_:1})])):h("",!0)])])}const Wt=b(wt,[["render",Kt],["__scopeId","data-v-935f9471"]]),Zt=v({name:"RecentPanel",components:{TaskPreview:Wt,NoTasks:pe,BotPlaceholder:ke,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Jt={key:0},Qt={key:2,class:"w-full h-full flex items-center justify-center"};function Yt(e,t,d,f,$,g){const c=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),k=s("no-tasks");return a(),r(T,null,[e.tasks?.items===void 0?(a(),r("div",Jt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=S=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),r(T,null,I(e.tasks?.items,(S,p)=>(a(),w(u,{key:p,"model-value":S},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),r("div",Qt,[o(k)])):h("",!0)],64)}const Xt=b(Zt,[["render",Yt]]),xt=J("sora"),eo=v({name:"SoraIndex",components:{ConfigPanel:kt,Layout:Te,RecentPanel:Xt},mixins:[se],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await re({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:d,createdAtMax:f}=e||{};console.debug("limit",t,"createdAtMin",d,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:d,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ae(this.uploadTracker,d=>this.$t(d),d=>V.warning(d)))return;const e={...this.config,callback_url:xt},t=this.credential?.token;if(!t){console.error("no token specified");return}V.info(this.$t("sora.message.startingTask")),W("sora",Z.generate(e,{token:t})).then(()=>{V.success(this.$t("sora.message.startTaskSuccess"))}).catch(d=>{d?.response?.data?.error?.code===fe?V.error(this.$t("sora.message.usedUp")):V.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function to(e,t,d,f,$,g){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:m(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[o(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Xo=b(eo,[["render",to]]);export{Xo as default};
|
|
1
|
+
import{F as L}from"./index.es-fM0biscR.js";import{E as D}from"./index-CXGm2ibp.js";import{E as N}from"./index-DYQToXUU.js";import{d as v,H as r,E as i,z as P,C as o,y as m,D as s,q as a,F as l,O as T,N as I,x as w,Q as A,R as j,I as _,J as h,G as q,L as H}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as K,cs as W,aM as Z,S as G,ct as J}from"./index-BitdtvW1.js";import{a as M,b as z,c as E,d as F,e as Q,f as Y,g as X,h as x,i as ee}from"./sora-Dyuoglk1.js";import{E as R,a as O}from"./index-CVCfk6pt.js";import{p as te}from"./pasteUploadMixin-BurWbGNQ.js";import{u as oe,a as se,e as ae}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as ne,S as le,l as re}from"./pagination-CDMeT271.js";import{I as ie}from"./ImagePreview-Deaq21aE.js";import{E as ce}from"./index-B5zfRlKe.js";import{E as V}from"./index-DY9n5RWp.js";import{C as de}from"./Consumption-Dvylkuyr.js";import{P as ue,N as pe}from"./NoTasks-DYAWTz-D.js";import{a as me}from"./price-UzqaC8kS.js";import{b as fe}from"./errorCode-Cqj9Td_Z.js";import{C as _e}from"./CopyToClipboard-3JBcjf6f.js";import{V as he}from"./VideoPlayer-Br2yW1lu.js";import{A as $e}from"./ApiCodeButton-9XDDLdNe.js";import{E as ge}from"./index-CRROw2v3.js";import{E as ve}from"./index-XLYMNUFJ.js";import{E as be}from"./index-BkchfnNA.js";import{B as ke}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BFUf5YVt.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./strings-beZM2Y-f.js";import"./isEqual-CMrgrIDS.js";import"./_Uint8Array-CRC1hUw5.js";import"./castArray-D90oh5Za.js";import"./index-cn5_DmaE.js";import"./index-IEnCZwtg.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_initCloneObject-EbmJQUEy.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BHVQW8Q2.js";const we=v({name:"LayoutSora",components:{ElDrawer:N,ElButton:D,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ye={class:"main flex flex-row flex-1"},Se={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ve={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ee(e,t,d,f,$,g){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),r("div",ye,[i("div",Se,[P(e.$slots,"config",{},void 0,!0)]),i("div",Ve,[P(e.$slots,"result",{},void 0,!0)]),o(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:m(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[P(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Te=b(we,[["render",Ee],["__scopeId","data-v-bbee238c"]]),Ae=v({name:"ModelSelector",components:{ElSelect:O,ElOption:R},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:Q,label:"sora-2"},{value:Y,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},d=z[e]||[E],f=t.duration,$=f&&d.includes(f)?f:d.includes(E)?E:d[0],g={...t,model:e,duration:$,size:t.size||F};this.$store.commit("sora/setConfig",g)}}},mounted(){this.value||(this.value=M)}}),Ie={class:"field"},Ce={class:"title font-bold"};function Le(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Ie,[i("h2",Ce,l(e.$t("sora.name.model")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ae,[["render",Le],["__scopeId","data-v-0cb7913d"]]),Re=v({name:"ActionSelector",components:{ElSelect:O,ElOption:R},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Oe={class:"field"},Ue={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Oe,[i("h2",Ue,l(e.$t("sora.name.action")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},{default:m(()=>[i("span",Pe,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=b(Re,[["render",Ge],["__scopeId","data-v-7b82fa7f"]]),ze=v({name:"DurationSelector",components:{ElSelect:O,ElOption:R},computed:{model(){return this.$store.state.sora?.config?.model||M},allowedDurations(){return z[this.model]||[E]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(E)?E:e[0];this.value=t}}},mounted(){this.value||(this.value=E)}}),Fe={class:"field"},Be={class:"control"},Ne={class:"title font-bold"};function je(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",Fe,[i("div",Be,[i("h2",Ne,l(e.$t("sora.name.duration")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.optionsForModel,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const qe=b(ze,[["render",je],["__scopeId","data-v-c2934598"]]),He=v({name:"OrientationSelector",data(){return{options:[{value:"portrait",labelKey:"sora.option.portrait",width:13,height:25},{value:"landscape",labelKey:"sora.option.landscape",width:25,height:13}]}},computed:{active(){const e=this.options.findIndex(t=>t.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=x)}}),Ke={class:"text-sm font-bold mb-2 block"},We={class:"items"},Ze=["onClick"],Je={class:"name"};function Qe(e,t,d,f,$,g){return a(),r("div",null,[i("span",Ke,l(e.$t("sora.name.orientation")),1),i("div",We,[(a(!0),r(T,null,I(e.options,(c,u)=>(a(),r("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:n=>e.value=c.value},[i("div",{class:A(["preview",c.value])},[i("div",{class:"rect",style:j({width:c.width+"px",height:c.height+"px"})},null,4)],2),i("p",Je,l(e.$t(c.labelKey)),1)],10,Ze))),128))])])}const Ye=b(He,[["render",Qe],["__scopeId","data-v-a20be6d9"]]),Xe=v({name:"StartEndImage",components:{ElUpload:ce,ElButton:D,InfoIcon:ne,FontAwesomeIcon:L,ImagePreview:ie},mixins:[te,oe],emits:["change"],data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){V.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){V.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),xe={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,d,f,$,g){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),k=s("el-button"),S=s("el-upload");return a(),r("div",xe,[i("div",et,[i("div",tt,[i("span",ot,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(S,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=p=>e.fileList=p),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:p})=>[p.url&&p.percentage!==void 0?(a(),w(u,{key:0,url:p.url,name:p.name,percentage:p.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(p),1)},null,8,["url","name","percentage","onRemove"])):h("",!0)]),default:m(()=>[o(k,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:m(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const at=b(Xe,[["render",st],["__scopeId","data-v-4f7d9ba5"]]),nt=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),lt=v({name:"SizeSelector",components:{ElSelect:O,ElOption:R},data(){return{options:ee.map(e=>({value:e,label:nt(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=F)}}),rt={class:"field"},it={class:"control"},ct={class:"title font-bold"};function dt(e,t,d,f,$,g){const c=s("el-option"),u=s("el-select");return a(),r("div",rt,[i("div",it,[i("h2",ct,l(e.$t("sora.name.size")),1),o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:m(()=>[(a(!0),r(T,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const ut=b(lt,[["render",dt],["__scopeId","data-v-8c485f0f"]]),pt="",mt=v({name:"PromptInput",components:{PromptTextarea:ue},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=pt)}});function ft(e,t,d,f,$,g){const c=s("prompt-textarea");return a(),w(c,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),title:e.$t("sora.name.prompt"),info:e.$t("sora.description.prompt"),placeholder:e.$t("sora.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const _t=b(mt,[["render",ft]]),ht=v({name:"ConfigPanel",components:{ElButton:D,Consumption:de,FontAwesomeIcon:L,PromptInput:_t,ModelSelector:De,StartEndImage:at,SizeSelector:ut,ActionSelector:Me,OrientationSelector:Ye,DurationSelector:qe},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),$t={class:"flex flex-col h-full"},gt={class:"flex-1 overflow-y-auto p-5"},vt={class:"flex flex-col items-center justify-center px-5 pb-5"};function bt(e,t,d,f,$,g){const c=s("model-selector"),u=s("action-selector"),n=s("duration-selector"),k=s("size-selector"),S=s("orientation-selector"),p=s("prompt-input"),y=s("start-end-image"),C=s("consumption"),U=s("font-awesome-icon"),B=s("el-button");return a(),r("div",$t,[i("div",gt,[o(c,{class:"mb-4"}),o(u,{class:"mb-4"}),o(n,{class:"mb-4"}),o(k,{class:"mb-4"}),o(S,{class:"mb-4"}),o(p,{class:"mb-4"}),q(o(y,{class:"mb-2"},null,512),[[H,e.config?.action==="image2video"]])]),i("div",vt,[o(C,{value:e.consumption,service:e.service},null,8,["value","service"]),o(B,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const kt=b(ht,[["render",bt]]),wt=v({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:_e,FontAwesomeIcon:L,ElAlert:ve,VideoPlayer:he,ElTooltip:ge,ElButton:D,ApiCodeButton:$e},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),yt={class:"preview"},St={class:"left"},Vt={class:"main"},Et={class:"bot"},Tt={class:"datetime"},At={class:"info"},It={key:0,class:"prompt mt-2"},Ct={key:0},Lt={key:1},Dt={key:0,class:A({content:!0,failed:!0})},Rt={key:0,class:"mb-4"},Ot={key:1,class:A({operations:!0,"mt-2":!0})},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Mt={key:1,class:A({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},jt={key:2,class:A({content:!0})},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Kt(e,t,d,f,$,g){const c=s("el-image"),u=s("video-player"),n=s("el-button"),k=s("el-tooltip"),S=s("api-code-button"),p=s("font-awesome-icon"),y=s("copy-to-clipboard"),C=s("el-alert");return a(),r("div",yt,[i("div",St,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),i("div",Vt,[i("div",Et,[_(l(e.$t("sora.name.soraBot"))+" ",1),i("span",Tt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",At,[e.modelValue?.request?.prompt?(a(),r("p",It,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",Ct," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(a(),r("span",Lt," - ("+l(e.$t("sora.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Rt,[o(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):h("",!0),e.modelValue?.response.success?(a(),r("div",Ot,[o(k,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:m(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=U=>e.onDownload(U,e.modelValue?.response?.data[0]?.video_url))},{default:m(()=>[_(l(e.$t("sora.button.download")),1)]),_:1})):h("",!0)]),_:1},8,["content"]),o(S,{path:"/sora/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),o(C,{closable:!1,class:"mt-2 success"},{default:m(()=>[i("p",Ut,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),i("p",Pt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Gt,[o(p,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Mt,[o(C,{closable:!1,class:"failure"},{template:m(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("sora.name.failure")),1)]),default:m(()=>[i("p",zt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),i("p",Ft,[o(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Bt,[o(p,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("sora.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===void 0?(a(),r("div",jt,[o(C,{closable:!1,class:"info"},{template:m(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("sora.name.failure")),1)]),default:m(()=>[i("p",qt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Ht,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):h("",!0)]),_:1})])):h("",!0)])])}const Wt=b(wt,[["render",Kt],["__scopeId","data-v-935f9471"]]),Zt=v({name:"RecentPanel",components:{TaskPreview:Wt,NoTasks:pe,BotPlaceholder:ke,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Jt={key:0},Qt={key:2,class:"w-full h-full flex items-center justify-center"};function Yt(e,t,d,f,$,g){const c=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),k=s("no-tasks");return a(),r(T,null,[e.tasks?.items===void 0?(a(),r("div",Jt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=S=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),r(T,null,I(e.tasks?.items,(S,p)=>(a(),w(u,{key:p,"model-value":S},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),r("div",Qt,[o(k)])):h("",!0)],64)}const Xt=b(Zt,[["render",Yt]]),xt=J("sora"),eo=v({name:"SoraIndex",components:{ConfigPanel:kt,Layout:Te,RecentPanel:Xt},mixins:[se],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await re({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:d,createdAtMax:f}=e||{};console.debug("limit",t,"createdAtMin",d,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:d,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ae(this.uploadTracker,d=>this.$t(d),d=>V.warning(d)))return;const e={...this.config,callback_url:xt},t=this.credential?.token;if(!t){console.error("no token specified");return}V.info(this.$t("sora.message.startingTask")),W("sora",Z.generate(e,{token:t})).then(()=>{V.success(this.$t("sora.message.startTaskSuccess"))}).catch(d=>{d?.response?.data?.error?.code===fe?V.error(this.$t("sora.message.usedUp")):V.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function to(e,t,d,f,$,g){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:m(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[o(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Xo=b(eo,[["render",to]]);export{Xo as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as z}from"./index.es-DyJLipdG.js";import{E as P}from"./index-D7zqZA37.js";import{E as x}from"./index-CL6K14uy.js";import{d as y,H as n,E as m,z as O,C as s,y as _,D as i,q as a,x as I,F as o,I as u,O as S,N as M,J as d,M as K,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as X,cC as U,cD as J,cE as Q,cF as B,cG as G,cH as N,cI as Y,cJ as ee,cK as te,cL as se,cM as oe,cN as ae,cO as R,cP as ie,cQ as ne,cs as re,aZ as D,S as j,ct as le}from"./index-BNhPwgid.js";import{P as me,N as ce}from"./NoTasks-DMd-Y0Bj.js";import{u as pe,a as ue,e as de}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q,S as ge,l as he}from"./pagination-C2vPjR_g.js";import{I as F}from"./ImagePreview-B7TR3cuv.js";import{E as fe}from"./index-DMtC0tQC.js";import{E as V}from"./index-90Hjetr9.js";import{C as _e}from"./Consumption-DbCpeKTx.js";import{a as $e}from"./price-YQCGNRFk.js";import{E as H,a as Z,b as be}from"./index-blOeQXxC.js";import{E as ve}from"./index-Dy-usgmC.js";import{E as ke}from"./index-BKuvfiRO.js";import{b as Ee}from"./errorCode-Cqj9Td_Z.js";import{C as Se}from"./CopyToClipboard-DEq33hBp.js";import{I as Ie}from"./ImageWrapper-DGlipIs0.js";import{A as ye}from"./ApiCodeButton-C2MQ9SzY.js";import{E as we}from"./index-CKVYrrtD.js";import{E as Ve}from"./index-CZtZF4TE.js";import{E as Ae}from"./index-tFnO9PkK.js";import{B as Me}from"./BotPlaceholder-Baul6A1g.js";import"./use-form-item-M-EBwqcE.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BS9U-gw1.js";import"./typescript-DYyGuIeV.js";import"./index-DtSTB-41.js";import"./index-Cah9_Ghr.js";import"./highlight-CwI9kFio.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-XVF4kigm.js";import"./_baseClone-F4jqycTX.js";import"./_Uint8Array-CqhDs8r-.js";import"./_initCloneObject-D8OU-52K.js";import"./isEqual-BOE0f6gl.js";import"./index-QK2Oa-KY.js";import"./strings-beZM2Y-f.js";import"./castArray-B4Yz3lTf.js";import"./debounce-Czl_Hgxw.js";import"./_baseIteratee-Cx49hKZX.js";import"./index-kRap_oJr.js";import"./index-Cu41y2Fl.js";import"./validator-BXiGjteq.js";import"./index-ci2BqSr8.js";const Ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:z},data(){return{drawer:!1}}}),Te={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Le(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-drawer");return a(),n("div",Te,[m("div",ze,[O(e.$slots,"config",{},void 0,!0)]),m("div",Pe,[O(e.$slots,"result",{},void 0,!0)]),s(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:_(()=>[s(p,{icon:"fa-solid fa-magic"})]),_:1}),s(v,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ce=w(Ge,[["render",Le],["__scopeId","data-v-e480ada6"]]),Oe="",Ue=y({name:"PromptInput",components:{PromptTextarea:me},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Oe)}});function qe(e,t,c,r,h,b){const p=i("prompt-textarea");return a(),I(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("openaiimage.name.prompt"),info:e.$t("openaiimage.description.prompt"),placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ue,[["render",qe]]),Re=y({name:"ImageUrlsInput",components:{ElUpload:fe,ElButton:P,InfoIcon:q,ImagePreview:F,FontAwesomeIcon:z},mixins:[pe],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(h=>!h?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const h=this.fileList.find(b=>b?.response?.file_url===r||b?.url===r);h?t.push(h):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(b=>b===r||b?.url===r?.url||b?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){V.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){V.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),De={class:"field flex items-center justify-between"},je={class:"title font-bold text-[14px] mb-[10px]"},We={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Be={class:"controls flex items-center"},Fe={class:"file-list flex flex-wrap gap-[10px]"};function He(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-upload"),f=i("info-icon"),k=i("image-preview");return a(),n(S,null,[m("div",De,[m("h2",je,o(e.$t("openaiimage.name.imageUrls")),1),m("div",We,[m("div",Be,[s(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:_(()=>[s(g,{size:"small",type:"primary",round:""},{default:_(()=>[s(p,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Fe,[(a(!0),n(S,null,M(e.fileList,($,l)=>(a(),I(k,{key:$.uid||$?.response?.file_url||$.url||l,url:$.url||$?.response?.file_url,name:$.name,percentage:$.percentage,onRemove:E=>e.onRemovePreview(l,$)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ze=w(Re,[["render",He]]),xe=y({name:"OpenAIImageModelSelector",components:{ElSelect:Z,ElOption:H,InfoIcon:q},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:Q,label:this.$t("openaiimage.model.gptImage15")},{value:B,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ke={class:"field"},Xe={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Ye(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-select");return a(),n("div",Ke,[m("div",Xe,[m("div",Je,[m("h2",Qe,o(e.$t("openaiimage.name.model")),1),s(p,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:_(()=>[(a(!0),n(S,null,M(e.options,f=>(a(),I(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const et=w(xe,[["render",Ye],["__scopeId","data-v-cec771bd"]]);function tt(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const st=y({name:"OpenAIImageSizeSelector",components:{ElSelect:Z,ElOption:H,ElOptionGroup:be,ElSwitch:ke,ElInputNumber:ve,InfoIcon:q},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ie.includes(this.model)},presets(){return R[this.model]??R[U]??[]},presetGroups(){return this.model===B?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:oe},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:ae}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??G;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??G},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return te},minSide(){return ee},maxSide(){return Y},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>N?this.$t("openaiimage.error.customSizePixels",{pixels:N.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??G);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??G)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??G);return}const e=tt(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ot={class:"resolution"},at={class:"field"},it={class:"label"},nt={class:"box"},rt={class:"title font-bold"},lt={class:"field custom-toggle"},mt={class:"label"},ct={class:"box"},pt={class:"title font-bold"},ut={key:0,class:"custom-inputs"},dt={class:"row"},gt={class:"row-label"},ht={class:"row"},ft={class:"row-label"},_t={key:0,class:"error"};function $t(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-option-group"),f=i("el-select"),k=i("el-switch"),$=i("el-input-number");return a(),n("div",ot,[m("div",at,[m("div",it,[m("div",nt,[m("h2",rt,o(e.$t("openaiimage.name.size")),1),s(p,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(f,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.presetValue=l),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:_(()=>[(a(!0),n(S,null,M(e.presetGroups,l=>(a(),I(v,{key:l.label,label:l.label},{default:_(()=>[(a(!0),n(S,null,M(l.options,E=>(a(),I(g,{key:E,label:E,value:E},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(S,{key:0},[m("div",lt,[m("div",mt,[m("div",ct,[m("h2",pt,o(e.$t("openaiimage.name.customSize")),1),s(p,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(k,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=l=>e.useCustom=l),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ut,[m("div",dt,[m("span",gt,o(e.$t("openaiimage.name.width")),1),s($,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=l=>e.customWidth=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),m("div",ht,[m("span",ft,o(e.$t("openaiimage.name.height")),1),s($,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=l=>e.customHeight=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",_t,o(e.customError),1)):d("",!0)])):d("",!0)],64)):d("",!0)])}const bt=w(st,[["render",$t],["__scopeId","data-v-218b58cb"]]),vt=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:z,PromptInput:Ne,Consumption:_e,ImageUrlsInput:Ze,ModelSelector:et,ResolutionSelector:bt},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return $e({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),kt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},St={class:"flex flex-col items-center justify-center px-5 pb-5"};function It(e,t,c,r,h,b){const p=i("model-selector"),g=i("resolution-selector"),v=i("prompt-input"),f=i("image-urls-input"),k=i("consumption"),$=i("font-awesome-icon"),l=i("el-button");return a(),n("div",kt,[m("div",Et,[s(p,{class:"mb-4"}),s(g,{class:"mb-4"}),s(v,{class:"mb-4"}),s(f,{class:"mb-4"})]),m("div",St,[s(k,{value:e.consumption,service:e.service},null,8,["value","service"]),s(l,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[s($,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const yt=w(vt,[["render",It]]),wt=y({name:"TaskPreview",components:{ElImage:Ae,CopyToClipboard:Se,FontAwesomeIcon:z,ElAlert:Ve,ImageWrapper:Ie,ElButton:P,ElTooltip:we,ImagePreview:F,ApiCodeButton:ye},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ne}},computed:{openaiimagePath(){return this.modelValue?.request?.action==="edit"?"/openai/images/edits":"/openai/images/generations"},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),Vt={class:"preview"},At={class:"left"},Mt={class:"main"},Gt={class:"bot"},Tt={class:"datetime"},zt={class:"info"},Pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Lt={key:1,class:"prompt mt-2"},Ct={key:0},Ot={key:0,class:L({content:!0,failed:!0})},Ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},qt={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={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"},Bt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ft={key:1,class:L({content:!0})},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Yt={key:2,class:L({content:!0})},es={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ss={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},os={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function as(e,t,c,r,h,b){const p=i("el-image"),g=i("image-preview"),v=i("image-wrapper"),f=i("el-button"),k=i("el-tooltip"),$=i("api-code-button"),l=i("font-awesome-icon"),E=i("copy-to-clipboard"),C=i("el-alert");return a(),n("div",Vt,[m("div",At,[s(p,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",Mt,[m("div",Gt,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",Tt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",zt,[e.referenceImages.length>0?(a(),n("div",Pt,[(a(!0),n(S,null,M(e.referenceImages,(A,T)=>(a(),I(g,{key:T,url:A,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):d("",!0),e.modelValue?.request?.prompt?(a(),n("p",Lt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(a(),n("span",Ct," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):d("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Ot,[m("div",Ut,[(a(!0),n(S,null,M(e.images,(A,T)=>(a(),I(v,{key:T,src:A?.image_url||A?.url||"","raw-src":A?.image_url||A?.url||""},null,8,["src","raw-src"]))),128))]),m("div",qt,[s(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[s(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(A=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:_(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),s($,{path:e.openaiimagePath,body:e.modelValue?.request},null,8,["path","body"])]),s(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Nt,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",Dt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",jt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Wt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Bt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):d("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Ft,[s(C,{closable:!1,class:"failure"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Ht,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Zt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",xt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",Kt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Xt,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Jt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Qt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):d("",!0)]),_:1})])):(a(),n("div",Yt,[s(C,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",es,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",ts,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",ss,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",os,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const is=w(wt,[["render",as],["__scopeId","data-v-8057d8e2"]]),ns=y({name:"RecentPanel",components:{TaskPreview:is,BotPlaceholder:Me,NoTasks:ce,ScrollList:ge},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),rs={key:0},ls={key:2,class:"w-full h-full flex items-center justify-center"};function ms(e,t,c,r,h,b){const p=i("bot-placeholder"),g=i("task-preview"),v=i("scroll-list"),f=i("no-tasks");return a(),n(S,null,[e.tasks?.items===void 0?(a(),n("div",rs,[s(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(v,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:_(()=>[(a(!0),n(S,null,M(e.tasks?.items,k=>(a(),I(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(a(),n("div",ls,[s(f)])):d("",!0)],64)}const cs=w(ns,[["render",ms]]),W=le("openaiimage"),ps=y({name:"OpenAIImageIndex",components:{ConfigPanel:yt,Layout:Ce,RecentPanel:cs},mixins:[ue],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await he({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){if(!de(this.uploadTracker,p=>this.$t(p),p=>V.warning(p)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){V.error(this.$t("openaiimage.message.promptRequired"));return}e.prompt=e.prompt.trim(),!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:W},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:W},h=this.credential?.token;if(!h){console.error("no token specified");return}V.info(this.$t("openaiimage.message.startingTask")),re("openaiimage",t?D.edit(r,{token:h}):D.generate(c,{token:h})).then(p=>{console.debug("task accepted",p.data?.task_id),V.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(p=>{const g=p?.response?.data;g?.error?.code===Ee?V.error(this.$t("openaiimage.message.usedUp")):V.error(this.$t("openaiimage.message.startTaskFailed")+(g?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e=="string"&&e.trim().length>0}}});function us(e,t,c,r,h,b){const p=i("config-panel"),g=i("recent-panel"),v=i("layout");return a(),I(v,null,{config:_(()=>[s(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[s(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=w(ps,[["render",us]]);export{mo as default};
|
|
1
|
+
import{F as z}from"./index.es-fM0biscR.js";import{E as P}from"./index-CXGm2ibp.js";import{E as x}from"./index-DYQToXUU.js";import{d as y,H as n,E as m,z as O,C as s,y as _,D as i,q as a,x as I,F as o,I as u,O as S,N as M,J as d,M as K,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as X,cC as U,cD as J,cE as Q,cF as B,cG as G,cH as N,cI as Y,cJ as ee,cK as te,cL as se,cM as oe,cN as ae,cO as R,cP as ie,cQ as ne,cs as re,aZ as D,S as j,ct as le}from"./index-BitdtvW1.js";import{P as me,N as ce}from"./NoTasks-DYAWTz-D.js";import{u as pe,a as ue,e as de}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q,S as ge,l as he}from"./pagination-CDMeT271.js";import{I as F}from"./ImagePreview-Deaq21aE.js";import{E as fe}from"./index-B5zfRlKe.js";import{E as V}from"./index-DY9n5RWp.js";import{C as _e}from"./Consumption-Dvylkuyr.js";import{a as $e}from"./price-UzqaC8kS.js";import{E as H,a as Z,b as be}from"./index-CVCfk6pt.js";import{E as ve}from"./index-CAnSJQ4u.js";import{E as ke}from"./index-Cy8wLIr0.js";import{b as Ee}from"./errorCode-Cqj9Td_Z.js";import{C as Se}from"./CopyToClipboard-3JBcjf6f.js";import{I as Ie}from"./ImageWrapper-DImeHzsC.js";import{A as ye}from"./ApiCodeButton-9XDDLdNe.js";import{E as we}from"./index-CRROw2v3.js";import{E as Ve}from"./index-XLYMNUFJ.js";import{E as Ae}from"./index-BkchfnNA.js";import{B as Me}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-cn5_DmaE.js";import"./typescript-CdFsS8fD.js";import"./index-BKgRYY8E.js";import"./index-IEnCZwtg.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_Uint8Array-CRC1hUw5.js";import"./_initCloneObject-EbmJQUEy.js";import"./isEqual-CMrgrIDS.js";import"./index-BFUf5YVt.js";import"./strings-beZM2Y-f.js";import"./castArray-D90oh5Za.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./index-Cu41y2Fl.js";import"./validator-BIWRmSMB.js";import"./index-BHVQW8Q2.js";const Ge=y({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:P,FontAwesomeIcon:z},data(){return{drawer:!1}}}),Te={class:"main flex flex-row flex-1"},ze={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Le(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-drawer");return a(),n("div",Te,[m("div",ze,[O(e.$slots,"config",{},void 0,!0)]),m("div",Pe,[O(e.$slots,"result",{},void 0,!0)]),s(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:_(()=>[s(p,{icon:"fa-solid fa-magic"})]),_:1}),s(v,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ce=w(Ge,[["render",Le],["__scopeId","data-v-e480ada6"]]),Oe="",Ue=y({name:"PromptInput",components:{PromptTextarea:me},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Oe)}});function qe(e,t,c,r,h,b){const p=i("prompt-textarea");return a(),I(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=g=>e.prompt=g),title:e.$t("openaiimage.name.prompt"),info:e.$t("openaiimage.description.prompt"),placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ue,[["render",qe]]),Re=y({name:"ImageUrlsInput",components:{ElUpload:fe,ElButton:P,InfoIcon:q,ImagePreview:F,FontAwesomeIcon:z},mixins:[pe],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(h=>!h?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const h=this.fileList.find(b=>b?.response?.file_url===r||b?.url===r);h?t.push(h):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(b=>b===r||b?.url===r?.url||b?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){V.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){V.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),De={class:"field flex items-center justify-between"},je={class:"title font-bold text-[14px] mb-[10px]"},We={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Be={class:"controls flex items-center"},Fe={class:"file-list flex flex-wrap gap-[10px]"};function He(e,t,c,r,h,b){const p=i("font-awesome-icon"),g=i("el-button"),v=i("el-upload"),f=i("info-icon"),k=i("image-preview");return a(),n(S,null,[m("div",De,[m("h2",je,o(e.$t("openaiimage.name.imageUrls")),1),m("div",We,[m("div",Be,[s(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:_(()=>[s(g,{size:"small",type:"primary",round:""},{default:_(()=>[s(p,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(f,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),m("div",Fe,[(a(!0),n(S,null,M(e.fileList,($,l)=>(a(),I(k,{key:$.uid||$?.response?.file_url||$.url||l,url:$.url||$?.response?.file_url,name:$.name,percentage:$.percentage,onRemove:E=>e.onRemovePreview(l,$)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ze=w(Re,[["render",He]]),xe=y({name:"OpenAIImageModelSelector",components:{ElSelect:Z,ElOption:H,InfoIcon:q},data(){return{options:[{value:J,label:this.$t("openaiimage.model.gptImage1")},{value:Q,label:this.$t("openaiimage.model.gptImage15")},{value:B,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ke={class:"field"},Xe={class:"label"},Je={class:"box"},Qe={class:"title font-bold"};function Ye(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-select");return a(),n("div",Ke,[m("div",Xe,[m("div",Je,[m("h2",Qe,o(e.$t("openaiimage.name.model")),1),s(p,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:_(()=>[(a(!0),n(S,null,M(e.options,f=>(a(),I(g,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const et=w(xe,[["render",Ye],["__scopeId","data-v-cec771bd"]]);function tt(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const st=y({name:"OpenAIImageSizeSelector",components:{ElSelect:Z,ElOption:H,ElOptionGroup:be,ElSwitch:ke,ElInputNumber:ve,InfoIcon:q},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ie.includes(this.model)},presets(){return R[this.model]??R[U]??[]},presetGroups(){return this.model===B?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:oe},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:ae}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??G;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??G},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return te},minSide(){return ee},maxSide(){return Y},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>N?this.$t("openaiimage.error.customSizePixels",{pixels:N.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??G);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??G)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??G);return}const e=tt(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ot={class:"resolution"},at={class:"field"},it={class:"label"},nt={class:"box"},rt={class:"title font-bold"},lt={class:"field custom-toggle"},mt={class:"label"},ct={class:"box"},pt={class:"title font-bold"},ut={key:0,class:"custom-inputs"},dt={class:"row"},gt={class:"row-label"},ht={class:"row"},ft={class:"row-label"},_t={key:0,class:"error"};function $t(e,t,c,r,h,b){const p=i("info-icon"),g=i("el-option"),v=i("el-option-group"),f=i("el-select"),k=i("el-switch"),$=i("el-input-number");return a(),n("div",ot,[m("div",at,[m("div",it,[m("div",nt,[m("h2",rt,o(e.$t("openaiimage.name.size")),1),s(p,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(f,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.presetValue=l),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:_(()=>[(a(!0),n(S,null,M(e.presetGroups,l=>(a(),I(v,{key:l.label,label:l.label},{default:_(()=>[(a(!0),n(S,null,M(l.options,E=>(a(),I(g,{key:E,label:E,value:E},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(S,{key:0},[m("div",lt,[m("div",mt,[m("div",ct,[m("h2",pt,o(e.$t("openaiimage.name.customSize")),1),s(p,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(k,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=l=>e.useCustom=l),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ut,[m("div",dt,[m("span",gt,o(e.$t("openaiimage.name.width")),1),s($,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=l=>e.customWidth=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),m("div",ht,[m("span",ft,o(e.$t("openaiimage.name.height")),1),s($,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=l=>e.customHeight=l),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",_t,o(e.customError),1)):d("",!0)])):d("",!0)],64)):d("",!0)])}const bt=w(st,[["render",$t],["__scopeId","data-v-218b58cb"]]),vt=y({name:"ConfigPanel",components:{ElButton:P,FontAwesomeIcon:z,PromptInput:Ne,Consumption:_e,ImageUrlsInput:Ze,ModelSelector:et,ResolutionSelector:bt},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return $e({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),kt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},St={class:"flex flex-col items-center justify-center px-5 pb-5"};function It(e,t,c,r,h,b){const p=i("model-selector"),g=i("resolution-selector"),v=i("prompt-input"),f=i("image-urls-input"),k=i("consumption"),$=i("font-awesome-icon"),l=i("el-button");return a(),n("div",kt,[m("div",Et,[s(p,{class:"mb-4"}),s(g,{class:"mb-4"}),s(v,{class:"mb-4"}),s(f,{class:"mb-4"})]),m("div",St,[s(k,{value:e.consumption,service:e.service},null,8,["value","service"]),s(l,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[s($,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const yt=w(vt,[["render",It]]),wt=y({name:"TaskPreview",components:{ElImage:Ae,CopyToClipboard:Se,FontAwesomeIcon:z,ElAlert:Ve,ImageWrapper:Ie,ElButton:P,ElTooltip:we,ImagePreview:F,ApiCodeButton:ye},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ne}},computed:{openaiimagePath(){return this.modelValue?.request?.action==="edit"?"/openai/images/edits":"/openai/images/generations"},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),Vt={class:"preview"},At={class:"left"},Mt={class:"main"},Gt={class:"bot"},Tt={class:"datetime"},zt={class:"info"},Pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Lt={key:1,class:"prompt mt-2"},Ct={key:0},Ot={key:0,class:L({content:!0,failed:!0})},Ut={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},qt={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={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"},Bt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ft={key:1,class:L({content:!0})},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Yt={key:2,class:L({content:!0})},es={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ss={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},os={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function as(e,t,c,r,h,b){const p=i("el-image"),g=i("image-preview"),v=i("image-wrapper"),f=i("el-button"),k=i("el-tooltip"),$=i("api-code-button"),l=i("font-awesome-icon"),E=i("copy-to-clipboard"),C=i("el-alert");return a(),n("div",Vt,[m("div",At,[s(p,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),m("div",Mt,[m("div",Gt,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),m("span",Tt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),m("div",zt,[e.referenceImages.length>0?(a(),n("div",Pt,[(a(!0),n(S,null,M(e.referenceImages,(A,T)=>(a(),I(g,{key:T,url:A,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):d("",!0),e.modelValue?.request?.prompt?(a(),n("p",Lt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(a(),n("span",Ct," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):d("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Ot,[m("div",Ut,[(a(!0),n(S,null,M(e.images,(A,T)=>(a(),I(v,{key:T,src:A?.image_url||A?.url||"","raw-src":A?.image_url||A?.url||""},null,8,["src","raw-src"]))),128))]),m("div",qt,[s(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[s(f,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=K(A=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:_(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),s($,{path:e.openaiimagePath,body:e.modelValue?.request},null,8,["path","body"])]),s(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Nt,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",Dt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",jt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Wt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Bt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):d("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Ft,[s(C,{closable:!1,class:"failure"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",Ht,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",Zt,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",xt,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",Kt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),m("p",Xt,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Jt,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Qt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):d("",!0)]),_:1})])):(a(),n("div",Yt,[s(C,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),n("p",es,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):d("",!0),e.modelValue?.request?.size?(a(),n("p",ts,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):d("",!0),e.modelValue?.request?.action?(a(),n("p",ss,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):d("",!0),m("p",os,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const is=w(wt,[["render",as],["__scopeId","data-v-8057d8e2"]]),ns=y({name:"RecentPanel",components:{TaskPreview:is,BotPlaceholder:Me,NoTasks:ce,ScrollList:ge},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),rs={key:0},ls={key:2,class:"w-full h-full flex items-center justify-center"};function ms(e,t,c,r,h,b){const p=i("bot-placeholder"),g=i("task-preview"),v=i("scroll-list"),f=i("no-tasks");return a(),n(S,null,[e.tasks?.items===void 0?(a(),n("div",rs,[s(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(v,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:_(()=>[(a(!0),n(S,null,M(e.tasks?.items,k=>(a(),I(g,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(a(),n("div",ls,[s(f)])):d("",!0)],64)}const cs=w(ns,[["render",ms]]),W=le("openaiimage"),ps=y({name:"OpenAIImageIndex",components:{ConfigPanel:yt,Layout:Ce,RecentPanel:cs},mixins:[ue],inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await he({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){if(!de(this.uploadTracker,p=>this.$t(p),p=>V.warning(p)))return;const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){V.error(this.$t("openaiimage.message.promptRequired"));return}e.prompt=e.prompt.trim(),!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:W},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:W},h=this.credential?.token;if(!h){console.error("no token specified");return}V.info(this.$t("openaiimage.message.startingTask")),re("openaiimage",t?D.edit(r,{token:h}):D.generate(c,{token:h})).then(p=>{console.debug("task accepted",p.data?.task_id),V.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(p=>{const g=p?.response?.data;g?.error?.code===Ee?V.error(this.$t("openaiimage.message.usedUp")):V.error(this.$t("openaiimage.message.startTaskFailed")+(g?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e=="string"&&e.trim().length>0}}});function us(e,t,c,r,h,b){const p=i("config-panel"),g=i("recent-panel"),v=i("layout");return a(),I(v,null,{config:_(()=>[s(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[s(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=w(ps,[["render",us]]);export{mo as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as U}from"./index.es-DyJLipdG.js";import{E as A}from"./index-D7zqZA37.js";import{E as O}from"./index-CL6K14uy.js";import{d as g,H as r,E as c,z as R,C as t,y as m,D as s,q as a,F as n,O as S,N as C,x as V,I as _,J as h,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as $,bp as B,cs as N,aG as j,o as F,S as P,ct as z}from"./index-BNhPwgid.js";import{a as K,b as H,c as J}from"./pika-DpzVVVef.js";import{I as G,S as Q,l as W}from"./pagination-C2vPjR_g.js";import{E as X}from"./index-BKuvfiRO.js";import{E as D,a as M}from"./index-blOeQXxC.js";import{a as Y,E as Z}from"./index-BAAlVPkq.js";import{p as x}from"./pasteUploadMixin-BurWbGNQ.js";import{u as ee,a as te,e as oe}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as se}from"./ImagePreview-B7TR3cuv.js";import{E as ae}from"./index-DMtC0tQC.js";import{E as w}from"./index-90Hjetr9.js";import{P as ne,N as ie}from"./NoTasks-DMd-Y0Bj.js";import{C as le}from"./Consumption-DbCpeKTx.js";import{a as re}from"./price-YQCGNRFk.js";import{b as ce,a as pe}from"./errorCode-Cqj9Td_Z.js";import{C as de}from"./CopyToClipboard-DEq33hBp.js";import{s as ue}from"./vue-plyr-BO2nlN4c.js";import{A as me}from"./ApiCodeButton-C2MQ9SzY.js";import{E as fe}from"./index-CKVYrrtD.js";import{E as _e}from"./index-CZtZF4TE.js";import{E as he}from"./index-tFnO9PkK.js";import{B as ge}from"./BotPlaceholder-Baul6A1g.js";import"./use-form-item-M-EBwqcE.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-CwI9kFio.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-BXiGjteq.js";import"./index-DtSTB-41.js";import"./index-QK2Oa-KY.js";import"./typescript-DYyGuIeV.js";import"./strings-beZM2Y-f.js";import"./isEqual-BOE0f6gl.js";import"./_Uint8Array-CqhDs8r-.js";import"./castArray-B4Yz3lTf.js";import"./index-BS9U-gw1.js";import"./index-Cah9_Ghr.js";import"./debounce-Czl_Hgxw.js";import"./_baseIteratee-Cx49hKZX.js";import"./index-kRap_oJr.js";import"./index-XVF4kigm.js";import"./_baseClone-F4jqycTX.js";import"./_initCloneObject-D8OU-52K.js";import"./index-ci2BqSr8.js";const $e=g({name:"LayoutPika",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:U},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},be={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ye(e,o,l,d,k,v){const p=s("font-awesome-icon"),f=s("el-button"),i=s("el-drawer");return a(),r("div",ke,[c("div",ve,[R(e.$slots,"config",{},void 0,!0)]),c("div",be,[R(e.$slots,"result",{},void 0,!0)]),t(f,{circle:"",class:"menu",onClick:o[0]||(o[0]=b=>e.drawer=!0)},{default:m(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(i,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const we=$($e,[["render",ye],["__scopeId","data-v-10596416"]]),Ve=g({name:"IngredientsSelector",components:{ElSwitch:X,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=K)}}),Ee={class:"field"},Ie={class:"title font-bold"};function Se(e,o,l,d,k,v){const p=s("el-switch"),f=s("info-icon");return a(),r("div",Ee,[c("h2",Ie,n(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value"},null,8,["modelValue"]),t(f,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const Te=$(Ve,[["render",Se],["__scopeId","data-v-17c0af5c"]]),Ce=g({name:"EffectSelector",components:{ElSelect:M,ElOption:D},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),Pe={class:"field"},Ue={class:"title font-bold"},Ae={class:"float-left"};function Le(e,o,l,d,k,v){const p=s("el-option"),f=s("el-select");return a(),r("div",Pe,[c("h2",Ue,n(e.$t("pika.name.effect")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.label,value:i.value},{default:m(()=>[c("span",Ae,n(i.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=$(Ce,[["render",Le],["__scopeId","data-v-d1c54475"]]),Ge=g({name:"IngredientsModelSelector",components:{ElRadioButton:Z,ElRadioGroup:Y},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=H)}}),De={class:"field"},Me={class:"title font-bold"};function qe(e,o,l,d,k,v){const p=s("el-radio-button"),f=s("el-radio-group");return a(),r("div",De,[c("h2",Me,n(e.$t("pika.name.ingredientsModel")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"quality"},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.value},{default:m(()=>[_(n(i.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Oe=$(Ge,[["render",qe],["__scopeId","data-v-b72865fa"]]),Be=g({name:"ModelSelector",components:{ElSelect:M,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=J)}}),Ne={class:"field"},je={class:"title font-bold"};function Fe(e,o,l,d,k,v){const p=s("el-option"),f=s("el-select");return a(),r("div",Ne,[c("h2",je,n(e.$t("pika.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.label,value:i.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=$(Be,[["render",Fe],["__scopeId","data-v-7b2e870a"]]),Ke=g({name:"ImageUrlInput",components:{ElUpload:ae,ElButton:A,InfoIcon:G,ImagePreview:se,FontAwesomeIcon:U},mixins:[x,ee],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){w.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){w.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){w.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),He={class:"field"},Je={class:"title font-bold"},Qe={class:"upload-wrapper"};function We(e,o,l,d,k,v){const p=s("image-preview"),f=s("font-awesome-icon"),i=s("el-button"),b=s("el-upload"),E=s("info-icon");return a(),r("div",He,[c("h2",Je,n(e.$t("pika.name.imageUrl")),1),c("div",Qe,[t(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:u})=>[t(p,{url:u.url||u.response?.file_url,name:u.name,percentage:u.percentage,onRemove:I=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])]),default:m(()=>[t(i,{size:"small",type:"primary",round:""},{default:m(()=>[t(f,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+n(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(E,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Xe=$(Ke,[["render",We],["__scopeId","data-v-25cefe78"]]),Ye="",Ze=g({name:"PromptInput",components:{PromptTextarea:ne},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ye)}});function xe(e,o,l,d,k,v){const p=s("prompt-textarea");return a(),V(p,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=f=>e.prompt=f),title:e.$t("pika.name.prompt"),info:e.$t("pika.description.prompt"),placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const et=$(Ze,[["render",xe]]),tt=g({name:"PresetPanel",components:{ImageUrlInput:Xe,ElButton:A,FontAwesomeIcon:U,Consumption:le,PromptInput:et,IngredientsSelector:Te,IngredientsModelSelector:Oe,ModelSelector:ze,EffectSelector:Re},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return re(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ot={class:"flex flex-col h-full"},st={class:"flex-1 overflow-y-auto p-5"},at={class:"flex flex-col items-center justify-center px-5 pb-5"};function nt(e,o,l,d,k,v){const p=s("prompt-input"),f=s("model-selector"),i=s("ingredients-selector"),b=s("effect-selector"),E=s("image-url-input"),u=s("ingredients-model-selector"),I=s("consumption"),T=s("font-awesome-icon"),y=s("el-button");return a(),r("div",ot,[c("div",st,[t(p,{class:"mb-4"}),t(f,{class:"mb-4"}),t(i,{class:"mb-4"}),t(b,{class:"mb-4"}),e.config?.ingredients?(a(),V(E,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),V(u,{key:1,class:"mb-4"})):h("",!0)]),c("div",at,[t(I,{value:e.consumption,service:e.service},null,8,["value","service"]),t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const it=$(tt,[["render",nt]]),lt=g({name:"VideoPlayer",components:{VuePlyr:ue},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),rt=["data-poster"],ct=["src"];function pt(e,o,l,d,k,v){const p=s("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:m(()=>[c("video",{controls:"",playsinline:"",preload:"metadata","data-poster":e.modelValue?.image_url},[c("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,ct)],8,rt)]),_:1},8,["options"])])}const dt=$(lt,[["render",pt],["__scopeId","data-v-897d9fe0"]]),ut=g({name:"TaskPreview",components:{ElImage:he,CopyToClipboard:de,FontAwesomeIcon:U,ElAlert:_e,VideoPlayer:dt,ElTooltip:fe,ElButton:A,ApiCodeButton:me},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(l=>{let d=l;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,l=new URL(o.src),d=l.searchParams.get("retry");if(!d)l.searchParams.set("retry","1");else if(parseInt(d)<2)l.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=l.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),mt={class:"left"},ft={class:"main"},_t={class:"bot"},ht={class:"datetime"},gt={class:"info"},$t={key:0,class:"prompt mt-2"},kt={key:0},vt={key:1},bt={key:0,class:L({content:!0,failed:!0})},yt={class:"image-wrapper"},wt={key:0,class:L({operations:!0,"mt-2":!0})},Vt={key:0,class:"description"},Et={class:"description"},It={key:1,class:"description"},St={key:1,class:L({content:!0})},Tt={class:"description"},Ct={class:"description"},Pt={key:0,class:"description"},Ut={class:"description"},At={key:2,class:L({content:!0})},Lt={class:"description"};function Rt(e,o,l,d,k,v){const p=s("el-image"),f=s("VideoPlayer"),i=s("el-button"),b=s("el-tooltip"),E=s("api-code-button"),u=s("font-awesome-icon"),I=s("copy-to-clipboard"),T=s("el-alert");return a(!0),r(S,null,C(e.videos,(y,q)=>(a(),r("div",{key:q,class:"preview"},[c("div",mt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),c("div",ft,[c("div",_t,[_(n(e.$t("pika.name.pikaBot"))+" ",1),c("span",ht,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",gt,[e.modelValue?.request?.prompt?(a(),r("p",$t,[_(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",kt," - ("+n(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"?(a(),r("span",vt," - ("+n(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",bt,[c("div",yt,[t(f,{"model-value":y},null,8,["model-value"])]),y?(a(),r("div",wt,[t(b,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),V(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:zt=>e.onDownload(y?.video_url)},{default:m(()=>[_(n(e.$t("pika.button.download")),1)]),_:1},8,["onClick"])):h("",!0)]),_:2},1032,["content"]),t(E,{path:"/pika/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[e.modelValue?.request?.model?(a(),r("p",Vt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.model"))+": "+n(e.modelValue?.request?.model),1)])):h("",!0),c("p",Et,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",It,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",St,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[c("p",Tt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Ct,[t(u,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("pika.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(I,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Pt,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),c("p",Ut,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(I,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),r("div",At,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[c("p",Lt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const Gt=$(ut,[["render",Rt],["__scopeId","data-v-52856c99"]]),Dt=g({name:"RecentPanel",components:{TaskPreview:Gt,BotPlaceholder:ge,NoTasks:ie,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Ot(e,o,l,d,k,v){const p=s("bot-placeholder"),f=s("task-preview"),i=s("scroll-list"),b=s("no-tasks");return a(),r(S,null,[e.tasks?.items===void 0?(a(),r("div",Mt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),V(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=E=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),r(S,null,C(e.tasks?.items,(E,u)=>(a(),V(f,{key:u,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),r("div",qt,[t(b)])):h("",!0)],64)}const Bt=$(Dt,[["render",Ot]]),Nt=z("pika"),jt=g({name:"PikaIndex",components:{ConfigPanel:it,Layout:we,RecentPanel:Bt},mixins:[te],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===P.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await W({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("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){F.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===pe&&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:o=5,createdAtMin:l,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",l,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:l,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!oe(this.uploadTracker,l=>this.$t(l),l=>w.warning(l)))return;const e={...this.config,callback_url:Nt},o=this.credential?.token;if(!o){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),N("pika",j.generate(e,{token:o})).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(l=>{l?.response?.data?.error?.code===ce?w.error(this.$t("pika.message.usedUp")):w.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ft(e,o,l,d,k,v){const p=s("config-panel"),f=s("recent-panel"),i=s("layout");return a(),V(i,null,{config:m(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Fo=$(jt,[["render",Ft],["__scopeId","data-v-eae39ce1"]]);export{Fo as default};
|
|
1
|
+
import{F as U}from"./index.es-fM0biscR.js";import{E as A}from"./index-CXGm2ibp.js";import{E as O}from"./index-DYQToXUU.js";import{d as g,H as r,E as c,z as R,C as t,y as m,D as s,q as a,F as n,O as S,N as C,x as V,I as _,J as h,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as $,bp as B,cs as N,aG as j,o as F,S as P,ct as z}from"./index-BitdtvW1.js";import{a as K,b as H,c as J}from"./pika-DpzVVVef.js";import{I as G,S as Q,l as W}from"./pagination-CDMeT271.js";import{E as X}from"./index-Cy8wLIr0.js";import{E as D,a as M}from"./index-CVCfk6pt.js";import{a as Y,E as Z}from"./index-DayNhmqV.js";import{p as x}from"./pasteUploadMixin-BurWbGNQ.js";import{u as ee,a as te,e as oe}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as se}from"./ImagePreview-Deaq21aE.js";import{E as ae}from"./index-B5zfRlKe.js";import{E as w}from"./index-DY9n5RWp.js";import{P as ne,N as ie}from"./NoTasks-DYAWTz-D.js";import{C as le}from"./Consumption-Dvylkuyr.js";import{a as re}from"./price-UzqaC8kS.js";import{b as ce,a as pe}from"./errorCode-Cqj9Td_Z.js";import{C as de}from"./CopyToClipboard-3JBcjf6f.js";import{s as ue}from"./vue-plyr-BO2nlN4c.js";import{A as me}from"./ApiCodeButton-9XDDLdNe.js";import{E as fe}from"./index-CRROw2v3.js";import{E as _e}from"./index-XLYMNUFJ.js";import{E as he}from"./index-BkchfnNA.js";import{B as ge}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-BIWRmSMB.js";import"./index-BKgRYY8E.js";import"./index-BFUf5YVt.js";import"./typescript-CdFsS8fD.js";import"./strings-beZM2Y-f.js";import"./isEqual-CMrgrIDS.js";import"./_Uint8Array-CRC1hUw5.js";import"./castArray-D90oh5Za.js";import"./index-cn5_DmaE.js";import"./index-IEnCZwtg.js";import"./debounce-B16-iZx6.js";import"./_baseIteratee-BQgCC_-_.js";import"./index-Bo7zkVzy.js";import"./index-CCeJfLsu.js";import"./_baseClone-BR0qWb-t.js";import"./_initCloneObject-EbmJQUEy.js";import"./index-BHVQW8Q2.js";const $e=g({name:"LayoutPika",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:U},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},be={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ye(e,o,l,d,k,v){const p=s("font-awesome-icon"),f=s("el-button"),i=s("el-drawer");return a(),r("div",ke,[c("div",ve,[R(e.$slots,"config",{},void 0,!0)]),c("div",be,[R(e.$slots,"result",{},void 0,!0)]),t(f,{circle:"",class:"menu",onClick:o[0]||(o[0]=b=>e.drawer=!0)},{default:m(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(i,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const we=$($e,[["render",ye],["__scopeId","data-v-10596416"]]),Ve=g({name:"IngredientsSelector",components:{ElSwitch:X,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=K)}}),Ee={class:"field"},Ie={class:"title font-bold"};function Se(e,o,l,d,k,v){const p=s("el-switch"),f=s("info-icon");return a(),r("div",Ee,[c("h2",Ie,n(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value"},null,8,["modelValue"]),t(f,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const Te=$(Ve,[["render",Se],["__scopeId","data-v-17c0af5c"]]),Ce=g({name:"EffectSelector",components:{ElSelect:M,ElOption:D},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),Pe={class:"field"},Ue={class:"title font-bold"},Ae={class:"float-left"};function Le(e,o,l,d,k,v){const p=s("el-option"),f=s("el-select");return a(),r("div",Pe,[c("h2",Ue,n(e.$t("pika.name.effect")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.label,value:i.value},{default:m(()=>[c("span",Ae,n(i.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=$(Ce,[["render",Le],["__scopeId","data-v-d1c54475"]]),Ge=g({name:"IngredientsModelSelector",components:{ElRadioButton:Z,ElRadioGroup:Y},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=H)}}),De={class:"field"},Me={class:"title font-bold"};function qe(e,o,l,d,k,v){const p=s("el-radio-button"),f=s("el-radio-group");return a(),r("div",De,[c("h2",Me,n(e.$t("pika.name.ingredientsModel")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"quality"},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.value},{default:m(()=>[_(n(i.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Oe=$(Ge,[["render",qe],["__scopeId","data-v-b72865fa"]]),Be=g({name:"ModelSelector",components:{ElSelect:M,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=J)}}),Ne={class:"field"},je={class:"title font-bold"};function Fe(e,o,l,d,k,v){const p=s("el-option"),f=s("el-select");return a(),r("div",Ne,[c("h2",je,n(e.$t("pika.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),r(S,null,C(e.options,i=>(a(),V(p,{key:i.value,label:i.label,value:i.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=$(Be,[["render",Fe],["__scopeId","data-v-7b2e870a"]]),Ke=g({name:"ImageUrlInput",components:{ElUpload:ae,ElButton:A,InfoIcon:G,ImagePreview:se,FontAwesomeIcon:U},mixins:[x,ee],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){w.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){w.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){w.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),He={class:"field"},Je={class:"title font-bold"},Qe={class:"upload-wrapper"};function We(e,o,l,d,k,v){const p=s("image-preview"),f=s("font-awesome-icon"),i=s("el-button"),b=s("el-upload"),E=s("info-icon");return a(),r("div",He,[c("h2",Je,n(e.$t("pika.name.imageUrl")),1),c("div",Qe,[t(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:u})=>[t(p,{url:u.url||u.response?.file_url,name:u.name,percentage:u.percentage,onRemove:I=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])]),default:m(()=>[t(i,{size:"small",type:"primary",round:""},{default:m(()=>[t(f,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+n(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(E,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Xe=$(Ke,[["render",We],["__scopeId","data-v-25cefe78"]]),Ye="",Ze=g({name:"PromptInput",components:{PromptTextarea:ne},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ye)}});function xe(e,o,l,d,k,v){const p=s("prompt-textarea");return a(),V(p,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=f=>e.prompt=f),title:e.$t("pika.name.prompt"),info:e.$t("pika.description.prompt"),placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const et=$(Ze,[["render",xe]]),tt=g({name:"PresetPanel",components:{ImageUrlInput:Xe,ElButton:A,FontAwesomeIcon:U,Consumption:le,PromptInput:et,IngredientsSelector:Te,IngredientsModelSelector:Oe,ModelSelector:ze,EffectSelector:Re},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return re(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ot={class:"flex flex-col h-full"},st={class:"flex-1 overflow-y-auto p-5"},at={class:"flex flex-col items-center justify-center px-5 pb-5"};function nt(e,o,l,d,k,v){const p=s("prompt-input"),f=s("model-selector"),i=s("ingredients-selector"),b=s("effect-selector"),E=s("image-url-input"),u=s("ingredients-model-selector"),I=s("consumption"),T=s("font-awesome-icon"),y=s("el-button");return a(),r("div",ot,[c("div",st,[t(p,{class:"mb-4"}),t(f,{class:"mb-4"}),t(i,{class:"mb-4"}),t(b,{class:"mb-4"}),e.config?.ingredients?(a(),V(E,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),V(u,{key:1,class:"mb-4"})):h("",!0)]),c("div",at,[t(I,{value:e.consumption,service:e.service},null,8,["value","service"]),t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const it=$(tt,[["render",nt]]),lt=g({name:"VideoPlayer",components:{VuePlyr:ue},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),rt=["data-poster"],ct=["src"];function pt(e,o,l,d,k,v){const p=s("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:m(()=>[c("video",{controls:"",playsinline:"",preload:"metadata","data-poster":e.modelValue?.image_url},[c("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,ct)],8,rt)]),_:1},8,["options"])])}const dt=$(lt,[["render",pt],["__scopeId","data-v-897d9fe0"]]),ut=g({name:"TaskPreview",components:{ElImage:he,CopyToClipboard:de,FontAwesomeIcon:U,ElAlert:_e,VideoPlayer:dt,ElTooltip:fe,ElButton:A,ApiCodeButton:me},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(l=>{let d=l;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,l=new URL(o.src),d=l.searchParams.get("retry");if(!d)l.searchParams.set("retry","1");else if(parseInt(d)<2)l.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=l.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),mt={class:"left"},ft={class:"main"},_t={class:"bot"},ht={class:"datetime"},gt={class:"info"},$t={key:0,class:"prompt mt-2"},kt={key:0},vt={key:1},bt={key:0,class:L({content:!0,failed:!0})},yt={class:"image-wrapper"},wt={key:0,class:L({operations:!0,"mt-2":!0})},Vt={key:0,class:"description"},Et={class:"description"},It={key:1,class:"description"},St={key:1,class:L({content:!0})},Tt={class:"description"},Ct={class:"description"},Pt={key:0,class:"description"},Ut={class:"description"},At={key:2,class:L({content:!0})},Lt={class:"description"};function Rt(e,o,l,d,k,v){const p=s("el-image"),f=s("VideoPlayer"),i=s("el-button"),b=s("el-tooltip"),E=s("api-code-button"),u=s("font-awesome-icon"),I=s("copy-to-clipboard"),T=s("el-alert");return a(!0),r(S,null,C(e.videos,(y,q)=>(a(),r("div",{key:q,class:"preview"},[c("div",mt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),c("div",ft,[c("div",_t,[_(n(e.$t("pika.name.pikaBot"))+" ",1),c("span",ht,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",gt,[e.modelValue?.request?.prompt?(a(),r("p",$t,[_(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",kt," - ("+n(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"?(a(),r("span",vt," - ("+n(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",bt,[c("div",yt,[t(f,{"model-value":y},null,8,["model-value"])]),y?(a(),r("div",wt,[t(b,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),V(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:zt=>e.onDownload(y?.video_url)},{default:m(()=>[_(n(e.$t("pika.button.download")),1)]),_:1},8,["onClick"])):h("",!0)]),_:2},1032,["content"]),t(E,{path:"/pika/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[e.modelValue?.request?.model?(a(),r("p",Vt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.model"))+": "+n(e.modelValue?.request?.model),1)])):h("",!0),c("p",Et,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",It,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",St,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[c("p",Tt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Ct,[t(u,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("pika.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(I,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),r("p",Pt,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),c("p",Ut,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(I,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),r("div",At,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[c("p",Lt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const Gt=$(ut,[["render",Rt],["__scopeId","data-v-52856c99"]]),Dt=g({name:"RecentPanel",components:{TaskPreview:Gt,BotPlaceholder:ge,NoTasks:ie,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Ot(e,o,l,d,k,v){const p=s("bot-placeholder"),f=s("task-preview"),i=s("scroll-list"),b=s("no-tasks");return a(),r(S,null,[e.tasks?.items===void 0?(a(),r("div",Mt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),V(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=E=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),r(S,null,C(e.tasks?.items,(E,u)=>(a(),V(f,{key:u,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),r("div",qt,[t(b)])):h("",!0)],64)}const Bt=$(Dt,[["render",Ot]]),Nt=z("pika"),jt=g({name:"PikaIndex",components:{ConfigPanel:it,Layout:we,RecentPanel:Bt},mixins:[te],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===P.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await W({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("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){F.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===pe&&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:o=5,createdAtMin:l,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",l,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:l,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!oe(this.uploadTracker,l=>this.$t(l),l=>w.warning(l)))return;const e={...this.config,callback_url:Nt},o=this.credential?.token;if(!o){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),N("pika",j.generate(e,{token:o})).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(l=>{l?.response?.data?.error?.code===ce?w.error(this.$t("pika.message.usedUp")):w.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ft(e,o,l,d,k,v){const p=s("config-panel"),f=s("recent-panel"),i=s("layout");return a(),V(i,null,{config:m(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Fo=$(jt,[["render",Ft],["__scopeId","data-v-eae39ce1"]]);export{Fo as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{d as e,H as n,q as o}from"./vendor-vue-NSDaktjZ.js";import{H as s}from"./index-
|
|
1
|
+
import{d as e,H as n,q as o}from"./vendor-vue-NSDaktjZ.js";import{H as s}from"./index-BitdtvW1.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";const r=e({name:"SettingsIndex",mounted(){const t=this.$route.query.tab||"";window.dispatchEvent(new CustomEvent("open-user-settings",{detail:{tab:t}}))}}),a={class:"settings-page"};function i(t,c,p,d,m,_){return o(),n("div",a)}const g=s(r,[["render",i]]);export{g as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as S}from"./index.es-DyJLipdG.js";import{E as U}from"./index-D7zqZA37.js";import{E as x}from"./index-CL6K14uy.js";import{d as k,H as m,E as l,z as j,C as o,y as c,D as s,q as a,F as i,I as _,x as $,J as f,M as z,Q as C,O as B,N as H}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as A,cs as J,aE as K,S as D,ct as Q}from"./index-BNhPwgid.js";import{a as W,b as X,c as Y}from"./luma-DcySqBv2.js";import{I as L,S as Z,l as ee}from"./pagination-C2vPjR_g.js";import{E as P}from"./index-BKuvfiRO.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{u as R,a as te,e as oe}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q}from"./ImagePreview-B7TR3cuv.js";import{E as G}from"./index-DMtC0tQC.js";import{E as v}from"./index-90Hjetr9.js";import{F as se}from"./FilePreview-CpuXslD4.js";import{P as ne,N as ae}from"./NoTasks-DMd-Y0Bj.js";import{V as N}from"./VideoPlayer-BAxqS3nn.js";import{C as le}from"./Consumption-DbCpeKTx.js";import{a as ie}from"./price-YQCGNRFk.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ce}from"./CopyToClipboard-DEq33hBp.js";import{A as me}from"./ApiCodeButton-C2MQ9SzY.js";import{E as ue}from"./index-CKVYrrtD.js";import{E as de}from"./index-CZtZF4TE.js";import{E as pe}from"./index-tFnO9PkK.js";import{B as fe}from"./BotPlaceholder-Baul6A1g.js";import"./use-form-item-M-EBwqcE.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-CwI9kFio.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-BXiGjteq.js";import"./index-DtSTB-41.js";import"./index-XVF4kigm.js";import"./typescript-DYyGuIeV.js";import"./_baseClone-F4jqycTX.js";import"./_Uint8Array-CqhDs8r-.js";import"./_initCloneObject-D8OU-52K.js";import"./isEqual-BOE0f6gl.js";import"./index-BS9U-gw1.js";import"./index-Cah9_Ghr.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-Czl_Hgxw.js";import"./index-ci2BqSr8.js";const _e=k({name:"LayoutLuma",components:{ElDrawer:x,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),he={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)]"},$e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ve(e,t,u,h,y,E){const r=s("font-awesome-icon"),d=s("el-button"),p=s("el-drawer");return a(),m("div",he,[l("div",ge,[j(e.$slots,"config",{},void 0,!0)]),l("div",$e,[j(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(p,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"350px",class:"drawer"},{default:c(()=>[j(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=w(_e,[["render",ve],["__scopeId","data-v-fdc8f36b"]]),ke=k({name:"EnhancementSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug("set enhancement",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=W)}}),we={class:"relative"},ye={class:"flex justify-between"},Ee={class:"flex justify-start items-center"},Ve={class:"text-sm font-bold"},Se={class:"flex justify-end items-center"};function Ue(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",we,[l("div",ye,[l("div",Ee,[l("span",Ve,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),l("div",Se,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Le=w(ke,[["render",Ue]]),Te=k({name:"CustomSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=X)}}),Ie={class:"relative"},Ce={class:"flex justify-between"},je={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"},Pe={class:"flex justify-end items-center"};function Re(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ie,[l("div",Ce,[l("div",je,[l("span",Ae,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),l("div",Pe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Ge=w(Te,[["render",Re]]),Me=k({name:"LoopSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug("set loop",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=Y)}}),Fe={class:"relative"},ze={class:"flex justify-between"},Be={class:"flex justify-start items-center"},De={class:"text-sm font-bold"},Oe={class:"flex justify-end items-center"};function qe(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Fe,[l("div",ze,[l("div",Be,[l("span",De,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),l("div",Oe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Ne=w(Me,[["render",qe]]),xe=k({name:"EndImage",components:{ElUpload:G,ElButton:U,ImagePreview:q,InfoIcon:L,FontAwesomeIcon:S},mixins:[O,R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){v.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){v.error(this.$t("luma.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),He={class:"relative"},Je={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},Qe={class:"text-sm font-bold"};function We(e,t,u,h,y,E){const r=s("info-icon"),d=s("image-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",He,[l("div",Je,[l("div",Ke,[l("span",Qe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.url&&n.percentage!==void 0?(a(),$(d,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Xe=w(xe,[["render",We],["__scopeId","data-v-cd768b26"]]),Ye=k({name:"StartImage",components:{ElUpload:G,ElButton:U,ImagePreview:q,InfoIcon:L,FontAwesomeIcon:S},mixins:[O,R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){v.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){v.error(this.$t("luma.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ze={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,u,h,y,E){const r=s("info-icon"),d=s("image-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",Ze,[l("div",et,[l("div",tt,[l("span",ot,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.percentage!=null?(a(),$(d,{key:0,url:n.url||n.response.file_url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const nt=w(Ye,[["render",st],["__scopeId","data-v-4d03e978"]]),at=k({name:"UploadVideo",components:{ElUpload:G,ElButton:U,InfoIcon:L,FilePreview:se,FontAwesomeIcon:S},mixins:[R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||(this.value=void 0)},methods:{onExceed(){v.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){v.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",u=e.size/1024/1024<10;return t?u?!0:(v.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(v.error(this.$t("luma.message.uploadVideoTypeFailed")),!1)},onSetVideoUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e,action:"extend"})},async onSuccess(){this.onSetVideoUrl()}}}),lt={class:"relative"},it={class:"flex justify-between"},rt={class:"flex justify-start items-center"},ct={class:"text-sm font-bold"};function mt(e,t,u,h,y,E){const r=s("info-icon"),d=s("file-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",lt,[l("div",it,[l("div",rt,[l("span",ct,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),accept:".mp4",name:"file",class:"value","show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.percentage!=null?(a(),$(d,{key:0,url:n.url||n.response?.file_url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const ut=w(at,[["render",mt],["__scopeId","data-v-b4c637fa"]]),dt="",pt=k({name:"PromptInput",components:{PromptTextarea:ne},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=dt)}});function ft(e,t,u,h,y,E){const r=s("prompt-textarea");return a(),$(r,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=d=>e.prompt=d),title:e.$t("luma.name.prompt"),info:e.$t("luma.description.prompt"),placeholder:e.$t("luma.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const _t=w(pt,[["render",ft]]),ht=k({name:"ExtendFromInput",components:{VideoPlayer:N},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),gt={class:"relative"},$t={class:"flex mb-2"},vt={class:"text-sm font-bold"};function bt(e,t,u,h,y,E){const r=s("video-player");return a(),m("div",gt,[l("div",$t,[l("span",vt,i(e.$t("luma.name.extend")),1)]),l("div",null,[e.config?.video_url?(a(),$(r,{key:0,src:e.config?.video_url},null,8,["src"])):f("",!0)])])}const kt=w(ht,[["render",bt]]),wt=k({name:"ConfigPanel",components:{LoopSelector:Ne,StartImageInput:nt,EndImageInput:Xe,EnhancementSelector:Le,ElButton:U,FontAwesomeIcon:S,PromptInput:_t,ExtendFromInput:kt,CustomSelector:Ge,UploadVideo:ut,Consumption:le},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ie(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},Vt={class:"flex flex-col items-center justify-center px-5 pb-5"};function St(e,t,u,h,y,E){const r=s("extend-from-input"),d=s("prompt-input"),p=s("custom-selector"),g=s("upload-video"),b=s("start-image-input"),n=s("end-image-input"),V=s("enhancement-selector"),T=s("loop-selector"),I=s("consumption"),M=s("font-awesome-icon"),F=s("el-button");return a(),m("div",yt,[l("div",Et,[e.config?.video_id||e.config?.video_url?(a(),$(r,{key:0,class:"mb-4"})):f("",!0),o(d,{class:"mb-4"}),e.config?.video_id?f("",!0):(a(),$(p,{key:1,class:"mb-4"})),e.config?.custom?(a(),$(g,{key:2,class:"mb-4"})):f("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),$(b,{key:3,class:"mb-4"})):f("",!0),o(n,{class:"mb-4"}),o(V,{class:"mb-4"}),o(T,{class:"mb-4"})]),l("div",Vt,[o(I,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),$(F,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),$(F,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const Ut=w(wt,[["render",St]]),Lt=k({name:"TaskPreview",components:{ElImage:pe,CopyToClipboard:ce,FontAwesomeIcon:S,ElAlert:de,VideoPlayer:N,ElTooltip:ue,ElButton:U,ApiCodeButton:me},props:{modelValue:{type:Object,required:!0}},emits:["extend"],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug("set config",t),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:"extend",thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit("extend")},onDownload(e){window.open(e,"_blank")}}}),Tt={class:"preview"},It={class:"left"},Ct={class:"main"},jt={class:"bot"},At={class:"datetime"},Pt={class:"info"},Rt={key:0,class:"prompt mt-2"},Gt={key:0},Mt={key:1},Ft={key:0,class:C({content:!0,failed:!0})},zt={key:0,class:"mb-4"},Bt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},qt={key:1,class:C({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Kt={key:2,class:C({content:!0})},Qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Wt(e,t,u,h,y,E){const r=s("el-image"),d=s("video-player"),p=s("el-button"),g=s("el-tooltip"),b=s("api-code-button"),n=s("font-awesome-icon"),V=s("copy-to-clipboard"),T=s("el-alert");return a(),m("div",Tt,[l("div",It,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),l("div",Ct,[l("div",jt,[_(i(e.$t("luma.name.lumaBot"))+" ",1),l("span",At,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Pt,[e.modelValue?.request?.prompt?(a(),m("p",Rt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),m("span",Gt," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Mt," - ("+i(e.$t("luma.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Ft,[e.modelValue.response.video_url?(a(),m("div",zt,[o(d,{src:e.modelValue.response.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Bt,[o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=z(I=>e.onExtend(I,e.modelValue?.response),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.downloadVideo"),placement:"top-start"},{default:c(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=z(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"]),o(b,{path:"/luma/videos",body:e.modelValue?.request},null,8,["body"])])):f("",!0),o(T,{closable:!1,class:"mt-2 success"},{default:c(()=>[l("p",Dt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),m("p",Ot,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0)]),_:1})])):f("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",qt,[o(T,{closable:!1,class:"failure"},{template:c(()=>[o(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[l("p",Nt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])]),l("p",xt,[o(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("luma.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),o(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),m("p",Ht,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),l("p",Jt,[o(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("luma.name.traceId"))+": "+i(e.modelValue?.trace_id)+" ",1),o(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):f("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Kt,[o(T,{closable:!1,class:"info"},{template:c(()=>[o(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[l("p",Qt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0)])])}const Xt=w(Lt,[["render",Wt],["__scopeId","data-v-9c354ffe"]]),Yt=k({name:"RecentPanel",components:{BotPlaceholder:fe,TaskPreview:Xt,NoTasks:ae,ScrollList:Z},props:{loading:{type:Boolean,default:!1}},emits:["reach-top","extend"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Zt={key:0},eo={key:2,class:"w-full h-full flex items-center justify-center"};function to(e,t,u,h,y,E){const r=s("bot-placeholder"),d=s("task-preview"),p=s("scroll-list"),g=s("no-tasks");return a(),m(B,null,[e.tasks?.items===void 0?(a(),m("div",Zt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(p,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=b=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(B,null,H(e.tasks?.items,b=>(a(),$(d,{key:b.id,"model-value":b,onExtend:t[0]||(t[0]=n=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(a(),m("div",eo,[o(g)])):f("",!0)],64)}const oo=w(Yt,[["render",to]]),so=Q("luma"),no=k({name:"LumaIndex",components:{ConfigPanel:Ut,Layout:be,RecentPanel:oo},mixins:[te],inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.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 ee({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("luma/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("luma/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){console.debug("scrolling down"),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:u,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:u,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!oe(this.uploadTracker,u=>this.$t(u),u=>v.warning(u)))return;const e={...this.config,callback_url:so};if(!this.hasText(e.prompt)){v.error(this.$t("luma.message.promptRequired"));return}e.prompt=e.prompt?.trim();const t=this.credential?.token;if(!t){console.error("no token specified");return}v.info(this.$t("luma.message.startingTask")),J("luma",K.generate(e,{token:t})).then(()=>{v.success(this.$t("luma.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===re?v.error(this.$t("luma.message.usedUp")):v.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e=="string"&&e.trim().length>0}}});function ao(e,t,u,h,y,E){const r=s("config-panel"),d=s("recent-panel"),p=s("layout");return a(),$(p,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=g=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const Zo=w(no,[["render",ao]]);export{Zo as default};
|
|
1
|
+
import{F as S}from"./index.es-fM0biscR.js";import{E as U}from"./index-CXGm2ibp.js";import{E as x}from"./index-DYQToXUU.js";import{d as k,H as m,E as l,z as j,C as o,y as c,D as s,q as a,F as i,I as _,x as $,J as f,M as z,Q as C,O as B,N as H}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as A,cs as J,aE as K,S as D,ct as Q}from"./index-BitdtvW1.js";import{a as W,b as X,c as Y}from"./luma-DcySqBv2.js";import{I as L,S as Z,l as ee}from"./pagination-CDMeT271.js";import{E as P}from"./index-Cy8wLIr0.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{u as R,a as te,e as oe}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as q}from"./ImagePreview-Deaq21aE.js";import{E as G}from"./index-B5zfRlKe.js";import{E as v}from"./index-DY9n5RWp.js";import{F as se}from"./FilePreview-DoguENGr.js";import{P as ne,N as ae}from"./NoTasks-DYAWTz-D.js";import{V as N}from"./VideoPlayer-Br2yW1lu.js";import{C as le}from"./Consumption-Dvylkuyr.js";import{a as ie}from"./price-UzqaC8kS.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ce}from"./CopyToClipboard-3JBcjf6f.js";import{A as me}from"./ApiCodeButton-9XDDLdNe.js";import{E as ue}from"./index-CRROw2v3.js";import{E as de}from"./index-XLYMNUFJ.js";import{E as pe}from"./index-BkchfnNA.js";import{B as fe}from"./BotPlaceholder-Bm3iFf5b.js";import"./use-form-item-CaXGkw6S.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-DEv6Uzjh.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-BIWRmSMB.js";import"./index-BKgRYY8E.js";import"./index-CCeJfLsu.js";import"./typescript-CdFsS8fD.js";import"./_baseClone-BR0qWb-t.js";import"./_Uint8Array-CRC1hUw5.js";import"./_initCloneObject-EbmJQUEy.js";import"./isEqual-CMrgrIDS.js";import"./index-cn5_DmaE.js";import"./index-IEnCZwtg.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-B16-iZx6.js";import"./index-BHVQW8Q2.js";const _e=k({name:"LayoutLuma",components:{ElDrawer:x,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),he={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)]"},$e={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ve(e,t,u,h,y,E){const r=s("font-awesome-icon"),d=s("el-button"),p=s("el-drawer");return a(),m("div",he,[l("div",ge,[j(e.$slots,"config",{},void 0,!0)]),l("div",$e,[j(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(p,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"350px",class:"drawer"},{default:c(()=>[j(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=w(_e,[["render",ve],["__scopeId","data-v-fdc8f36b"]]),ke=k({name:"EnhancementSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug("set enhancement",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=W)}}),we={class:"relative"},ye={class:"flex justify-between"},Ee={class:"flex justify-start items-center"},Ve={class:"text-sm font-bold"},Se={class:"flex justify-end items-center"};function Ue(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",we,[l("div",ye,[l("div",Ee,[l("span",Ve,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),l("div",Se,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Le=w(ke,[["render",Ue]]),Te=k({name:"CustomSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=X)}}),Ie={class:"relative"},Ce={class:"flex justify-between"},je={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"},Pe={class:"flex justify-end items-center"};function Re(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ie,[l("div",Ce,[l("div",je,[l("span",Ae,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),l("div",Pe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Ge=w(Te,[["render",Re]]),Me=k({name:"LoopSelector",components:{ElSwitch:P,InfoIcon:L},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug("set loop",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=Y)}}),Fe={class:"relative"},ze={class:"flex justify-between"},Be={class:"flex justify-start items-center"},De={class:"text-sm font-bold"},Oe={class:"flex justify-end items-center"};function qe(e,t,u,h,y,E){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Fe,[l("div",ze,[l("div",Be,[l("span",De,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),l("div",Oe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value"},null,8,["modelValue"])])])])}const Ne=w(Me,[["render",qe]]),xe=k({name:"EndImage",components:{ElUpload:G,ElButton:U,ImagePreview:q,InfoIcon:L,FontAwesomeIcon:S},mixins:[O,R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){v.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){v.error(this.$t("luma.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),He={class:"relative"},Je={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},Qe={class:"text-sm font-bold"};function We(e,t,u,h,y,E){const r=s("info-icon"),d=s("image-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",He,[l("div",Je,[l("div",Ke,[l("span",Qe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.url&&n.percentage!==void 0?(a(),$(d,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Xe=w(xe,[["render",We],["__scopeId","data-v-cd768b26"]]),Ye=k({name:"StartImage",components:{ElUpload:G,ElButton:U,ImagePreview:q,InfoIcon:L,FontAwesomeIcon:S},mixins:[O,R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){v.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){v.error(this.$t("luma.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ze={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,u,h,y,E){const r=s("info-icon"),d=s("image-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",Ze,[l("div",et,[l("div",tt,[l("span",ot,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.percentage!=null?(a(),$(d,{key:0,url:n.url||n.response.file_url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const nt=w(Ye,[["render",st],["__scopeId","data-v-4d03e978"]]),at=k({name:"UploadVideo",components:{ElUpload:G,ElButton:U,InfoIcon:L,FilePreview:se,FontAwesomeIcon:S},mixins:[R],data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||(this.value=void 0)},methods:{onExceed(){v.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){v.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",u=e.size/1024/1024<10;return t?u?!0:(v.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(v.error(this.$t("luma.message.uploadVideoTypeFailed")),!1)},onSetVideoUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e,action:"extend"})},async onSuccess(){this.onSetVideoUrl()}}}),lt={class:"relative"},it={class:"flex justify-between"},rt={class:"flex justify-start items-center"},ct={class:"text-sm font-bold"};function mt(e,t,u,h,y,E){const r=s("info-icon"),d=s("file-preview"),p=s("font-awesome-icon"),g=s("el-button"),b=s("el-upload");return a(),m("div",lt,[l("div",it,[l("div",rt,[l("span",ct,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=n=>e.fileList=n),accept:".mp4",name:"file",class:"value","show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:n})=>[n.percentage!=null?(a(),$(d,{key:0,url:n.url||n.response?.file_url,name:n.name,percentage:n.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const ut=w(at,[["render",mt],["__scopeId","data-v-b4c637fa"]]),dt="",pt=k({name:"PromptInput",components:{PromptTextarea:ne},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=dt)}});function ft(e,t,u,h,y,E){const r=s("prompt-textarea");return a(),$(r,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=d=>e.prompt=d),title:e.$t("luma.name.prompt"),info:e.$t("luma.description.prompt"),placeholder:e.$t("luma.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const _t=w(pt,[["render",ft]]),ht=k({name:"ExtendFromInput",components:{VideoPlayer:N},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),gt={class:"relative"},$t={class:"flex mb-2"},vt={class:"text-sm font-bold"};function bt(e,t,u,h,y,E){const r=s("video-player");return a(),m("div",gt,[l("div",$t,[l("span",vt,i(e.$t("luma.name.extend")),1)]),l("div",null,[e.config?.video_url?(a(),$(r,{key:0,src:e.config?.video_url},null,8,["src"])):f("",!0)])])}const kt=w(ht,[["render",bt]]),wt=k({name:"ConfigPanel",components:{LoopSelector:Ne,StartImageInput:nt,EndImageInput:Xe,EnhancementSelector:Le,ElButton:U,FontAwesomeIcon:S,PromptInput:_t,ExtendFromInput:kt,CustomSelector:Ge,UploadVideo:ut,Consumption:le},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ie(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},Et={class:"flex-1 overflow-y-auto p-5"},Vt={class:"flex flex-col items-center justify-center px-5 pb-5"};function St(e,t,u,h,y,E){const r=s("extend-from-input"),d=s("prompt-input"),p=s("custom-selector"),g=s("upload-video"),b=s("start-image-input"),n=s("end-image-input"),V=s("enhancement-selector"),T=s("loop-selector"),I=s("consumption"),M=s("font-awesome-icon"),F=s("el-button");return a(),m("div",yt,[l("div",Et,[e.config?.video_id||e.config?.video_url?(a(),$(r,{key:0,class:"mb-4"})):f("",!0),o(d,{class:"mb-4"}),e.config?.video_id?f("",!0):(a(),$(p,{key:1,class:"mb-4"})),e.config?.custom?(a(),$(g,{key:2,class:"mb-4"})):f("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),$(b,{key:3,class:"mb-4"})):f("",!0),o(n,{class:"mb-4"}),o(V,{class:"mb-4"}),o(T,{class:"mb-4"})]),l("div",Vt,[o(I,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),$(F,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),$(F,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const Ut=w(wt,[["render",St]]),Lt=k({name:"TaskPreview",components:{ElImage:pe,CopyToClipboard:ce,FontAwesomeIcon:S,ElAlert:de,VideoPlayer:N,ElTooltip:ue,ElButton:U,ApiCodeButton:me},props:{modelValue:{type:Object,required:!0}},emits:["extend"],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug("set config",t),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:"extend",thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit("extend")},onDownload(e){window.open(e,"_blank")}}}),Tt={class:"preview"},It={class:"left"},Ct={class:"main"},jt={class:"bot"},At={class:"datetime"},Pt={class:"info"},Rt={key:0,class:"prompt mt-2"},Gt={key:0},Mt={key:1},Ft={key:0,class:C({content:!0,failed:!0})},zt={key:0,class:"mb-4"},Bt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},qt={key:1,class:C({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Jt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Kt={key:2,class:C({content:!0})},Qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Wt(e,t,u,h,y,E){const r=s("el-image"),d=s("video-player"),p=s("el-button"),g=s("el-tooltip"),b=s("api-code-button"),n=s("font-awesome-icon"),V=s("copy-to-clipboard"),T=s("el-alert");return a(),m("div",Tt,[l("div",It,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),l("div",Ct,[l("div",jt,[_(i(e.$t("luma.name.lumaBot"))+" ",1),l("span",At,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Pt,[e.modelValue?.request?.prompt?(a(),m("p",Rt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),m("span",Gt," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Mt," - ("+i(e.$t("luma.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Ft,[e.modelValue.response.video_url?(a(),m("div",zt,[o(d,{src:e.modelValue.response.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Bt,[o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=z(I=>e.onExtend(I,e.modelValue?.response),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.downloadVideo"),placement:"top-start"},{default:c(()=>[o(p,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=z(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"]),o(b,{path:"/luma/videos",body:e.modelValue?.request},null,8,["body"])])):f("",!0),o(T,{closable:!1,class:"mt-2 success"},{default:c(()=>[l("p",Dt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(a(),m("p",Ot,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0)]),_:1})])):f("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",qt,[o(T,{closable:!1,class:"failure"},{template:c(()=>[o(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[l("p",Nt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])]),l("p",xt,[o(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("luma.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),o(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(a(),m("p",Ht,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):f("",!0),l("p",Jt,[o(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("luma.name.traceId"))+": "+i(e.modelValue?.trace_id)+" ",1),o(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):f("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Kt,[o(T,{closable:!1,class:"info"},{template:c(()=>[o(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[l("p",Qt,[o(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0)])])}const Xt=w(Lt,[["render",Wt],["__scopeId","data-v-9c354ffe"]]),Yt=k({name:"RecentPanel",components:{BotPlaceholder:fe,TaskPreview:Xt,NoTasks:ae,ScrollList:Z},props:{loading:{type:Boolean,default:!1}},emits:["reach-top","extend"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Zt={key:0},eo={key:2,class:"w-full h-full flex items-center justify-center"};function to(e,t,u,h,y,E){const r=s("bot-placeholder"),d=s("task-preview"),p=s("scroll-list"),g=s("no-tasks");return a(),m(B,null,[e.tasks?.items===void 0?(a(),m("div",Zt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(p,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=b=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(B,null,H(e.tasks?.items,b=>(a(),$(d,{key:b.id,"model-value":b,onExtend:t[0]||(t[0]=n=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(a(),m("div",eo,[o(g)])):f("",!0)],64)}const oo=w(Yt,[["render",to]]),so=Q("luma"),no=k({name:"LumaIndex",components:{ConfigPanel:Ut,Layout:be,RecentPanel:oo},mixins:[te],inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.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 ee({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("luma/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("luma/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){console.debug("scrolling down"),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:u,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:u,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!oe(this.uploadTracker,u=>this.$t(u),u=>v.warning(u)))return;const e={...this.config,callback_url:so};if(!this.hasText(e.prompt)){v.error(this.$t("luma.message.promptRequired"));return}e.prompt=e.prompt?.trim();const t=this.credential?.token;if(!t){console.error("no token specified");return}v.info(this.$t("luma.message.startingTask")),J("luma",K.generate(e,{token:t})).then(()=>{v.success(this.$t("luma.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===re?v.error(this.$t("luma.message.usedUp")):v.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e=="string"&&e.trim().length>0}}});function ao(e,t,u,h,y,E){const r=s("config-panel"),d=s("recent-panel"),p=s("layout");return a(),$(p,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=g=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const Zo=w(no,[["render",ao]]);export{Zo as default};
|