@acedatacloud/nexior 3.240.0 → 3.242.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-Bu2nLY5J.js → ApiCodeButton-BAAm5I15.js} +1 -1
- package/dist/assets/{Auth-MVXwbx0J.js → Auth-Djdravfe.js} +1 -1
- package/dist/assets/{BotPlaceholder-B5Bw1tlj.js → BotPlaceholder-DxAlgny2.js} +1 -1
- package/dist/assets/{Callback-CltrhgQA.js → Callback-95sJofG_.js} +1 -1
- package/dist/assets/{Console-CgysLeM3.js → Console-CFwofsGK.js} +1 -1
- package/dist/assets/{Consumption-BAwCyKhW.js → Consumption-CUbvFAAd.js} +1 -1
- package/dist/assets/{Conversation-zDAXEQqo.js → Conversation-BTFZ_K7W.js} +2 -2
- package/dist/assets/{Conversation-1fUmUeC1.css → Conversation-Q9xqXsnE.css} +1 -1
- package/dist/assets/{CopyToClipboard-B1L4gFQs.js → CopyToClipboard-q8AT00kT.js} +1 -1
- package/dist/assets/{Detail-5n82dmr-.js → Detail-CMsovR0k.js} +2 -2
- package/dist/assets/{Extra-BgGNwscr.js → Extra-Bc4Wsfpc.js} +1 -1
- package/dist/assets/{FilePreview-Hbma88Qo.js → FilePreview-TUpFWJij.js} +1 -1
- package/dist/assets/{Hailuo-CnUcHX2i.js → Hailuo-DvimuKdo.js} +1 -1
- package/dist/assets/{History-DGmfJiN5.js → History-bkAUPkjk.js} +1 -1
- package/dist/assets/{ImagePreview-BjgklCqN.js → ImagePreview-Bl6hkqwF.js} +1 -1
- package/dist/assets/{ImageWrapper-Gdemv0z3.js → ImageWrapper-CUd1scGc.js} +1 -1
- package/dist/assets/{Index-CiY_Y0jY.js → Index-B6i6eW_c.js} +1 -1
- package/dist/assets/{Index-CJaf5_XG.js → Index-BMCKltnb.js} +1 -1
- package/dist/assets/{Index-Cbcjj-AY.js → Index-BPt2zGp2.js} +1 -1
- package/dist/assets/{Index-DjJcHPVV.js → Index-BTQiXrnP.js} +1 -1
- package/dist/assets/{Index-DD4INS9g.js → Index-BecWT8Rs.js} +1 -1
- package/dist/assets/{Index-DenNaMxa.js → Index-Bj11toyX.js} +1 -1
- package/dist/assets/{Index-tSbYt2id.js → Index-Bp8sq5k7.js} +1 -1
- package/dist/assets/{Index-MWSwaNZf.js → Index-Bt8-2d3B.js} +1 -1
- package/dist/assets/{Index-DVlwl58S.js → Index-CEYlD1Js.js} +1 -1
- package/dist/assets/{Index-CspjrBOF.js → Index-CFK28Khy.js} +1 -1
- package/dist/assets/{Index-CDwIsBFd.js → Index-CaLC7juX.js} +1 -1
- package/dist/assets/{Index-Cl8Xxyup.js → Index-CeWpbTGC.js} +1 -1
- package/dist/assets/{Index-BBEtdH9l.js → Index-ChAiGiCp.js} +1 -1
- package/dist/assets/{Index-Bk0gOn4W.js → Index-CqQ1fl0b.js} +1 -1
- package/dist/assets/{Index-C71z7s6j.js → Index-Cx79aWZr.js} +1 -1
- package/dist/assets/{Index-Drv2EbJI.js → Index-D0KykOWk.js} +1 -1
- package/dist/assets/{Index-osgVGw2t.js → Index-D2hn23ys.js} +1 -1
- package/dist/assets/{Index-Beq58ww2.js → Index-DAHcgfkJ.js} +1 -1
- package/dist/assets/{Index-DUCq5f56.js → Index-DPNG9Ons.js} +1 -1
- package/dist/assets/{Index-DnC39l_Q.js → Index-DbjgY5pK.js} +1 -1
- package/dist/assets/{Index-BfKwv0eb.js → Index-Fb7kZ4Ip.js} +1 -1
- package/dist/assets/{Index-D12Yc04H.js → Index-G8N03yTf.js} +1 -1
- package/dist/assets/{Index-D3YJWopQ.js → Index-MjGkzjWw.js} +1 -1
- package/dist/assets/{Index-D8LIm110.js → Index-OZ9J_VYy.js} +1 -1
- package/dist/assets/{Index-BOlGOuA5.js → Index-UEXyHToH.js} +1 -1
- package/dist/assets/{Invitees-CQcBWZIM.js → Invitees-LVPWCmTN.js} +1 -1
- package/dist/assets/{List-Cw4CkHUs.js → List-9ZCZd4Kv.js} +1 -1
- package/dist/assets/{List-BoO6cP4z.js → List-ixFcaOqL.js} +1 -1
- package/dist/assets/{List-BLKUfRUt.js → List-nM4odZuz.js} +1 -1
- package/dist/assets/{Main-DXsWIIt1.js → Main-DasW3xML.js} +1 -1
- package/dist/assets/{Model-BLGUDfZz.js → Model-CQtKOVaO.js} +1 -1
- package/dist/assets/{Navigator-Diw71MjW.css → Navigator-CIQ9gUay.css} +1 -1
- package/dist/assets/{Navigator-D67RKX6g.js → Navigator-DasTIwvO.js} +2 -2
- package/dist/assets/{NoTasks-DLn86jTC.js → NoTasks-hJEZMzd9.js} +1 -1
- package/dist/assets/{NotFound-C5dv6Kjb.js → NotFound-DvsxRCnS.js} +1 -1
- package/dist/assets/{Pagination-0_XLUd-n.js → Pagination-Cs3IZeMQ.js} +1 -1
- package/dist/assets/{Player.vue_vue_type_script_setup_true_lang-CyZbXnZx.js → Player.vue_vue_type_script_setup_true_lang-BJVRnSmY.js} +1 -1
- package/dist/assets/{Status-DjSNonyM.js → Status-CLg_PEvS.js} +1 -1
- package/dist/assets/{Subscribe-DYMDeoww.js → Subscribe-D0DkM9nH.js} +1 -1
- package/dist/assets/{TabSwitcher-BwEKX6yw.js → TabSwitcher-DmEVWs6n.js} +1 -1
- package/dist/assets/{Tts-DYyb20bL.js → Tts-Dr8Pp5-K.js} +1 -1
- package/dist/assets/{VideoPlayer-lNCFIvjW.js → VideoPlayer-CMtYz-DY.js} +1 -1
- package/dist/assets/{_Uint8Array-pGzioutB.js → _Uint8Array-Dky9YMEI.js} +1 -1
- package/dist/assets/{_baseClone-D8eUdaQd.js → _baseClone-BcpYfRjc.js} +1 -1
- package/dist/assets/{_baseIteratee-BCY-1IYO.js → _baseIteratee-B03IqKJU.js} +1 -1
- package/dist/assets/{_initCloneObject-CAH0nDM3.js → _initCloneObject-zlapHgef.js} +1 -1
- package/dist/assets/{add-4pP0Wiem.js → add-B0qb6J18.js} +1 -1
- package/dist/assets/{all-wallets-DQ1EnmWI.js → all-wallets-DSWH4sBD.js} +1 -1
- package/dist/assets/{app-store-CSbgMxFH.js → app-store-BBOe_ywr.js} +1 -1
- package/dist/assets/{apple-ZwnWcRrl.js → apple-DITlNBpN.js} +1 -1
- package/dist/assets/{arrow-bottom-BVOOOKi7.js → arrow-bottom-BvG-2GkF.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-BdURFSFJ.js → arrow-bottom-circle-OIQgXZQW.js} +1 -1
- package/dist/assets/{arrow-left-qggBrx-R.js → arrow-left-2P3lYrId.js} +1 -1
- package/dist/assets/{arrow-right-BaxSKZcj.js → arrow-right-C53l-hda.js} +1 -1
- package/dist/assets/{arrow-top-DNnWLjaS.js → arrow-top-DUpgzebu.js} +1 -1
- package/dist/assets/{avatar-B0gMZK2R.js → avatar-DCTYz3v7.js} +1 -1
- package/dist/assets/{bank-sp9vGgEp.js → bank-BJhd4U-V.js} +1 -1
- package/dist/assets/{basic-D3qRqU9j.js → basic-hceQTq-H.js} +1 -1
- package/dist/assets/{browser-BCMEImu1.js → browser-CcmokQ7X.js} +1 -1
- package/dist/assets/{byokCredential-CISXgUhK.js → byokCredential-BJNVtZQD.js} +1 -1
- package/dist/assets/{card-CE2GYV7m.js → card-CjoPZuk9.js} +1 -1
- package/dist/assets/{castArray-CJ8hzGGj.js → castArray-9UHm33vq.js} +1 -1
- package/dist/assets/chat-BFvmXnGq.js +1 -0
- package/dist/assets/chat-BJ1O-acr.js +1 -0
- package/dist/assets/chat-BVnywm8V.js +1 -0
- package/dist/assets/chat-Bg5nzR2s.js +1 -0
- package/dist/assets/chat-Bi9bSam4.js +1 -0
- package/dist/assets/chat-BiKeApIc.js +1 -0
- package/dist/assets/{chat-B1OUDJRg.js → chat-C0n_qgQX.js} +1 -1
- package/dist/assets/chat-C6a-XWNv.js +1 -0
- package/dist/assets/chat-CcBdBoIQ.js +1 -0
- package/dist/assets/chat-DA19T0N-.js +1 -0
- package/dist/assets/chat-DDwlXTRr.js +1 -0
- package/dist/assets/chat-D_ldAckE.js +1 -0
- package/dist/assets/chat-Dh1tEg2g.js +1 -0
- package/dist/assets/chat-DktNImx9.js +1 -0
- package/dist/assets/chat-J4Z-vAUt.js +1 -0
- package/dist/assets/chat-UZtzKTY5.js +1 -0
- package/dist/assets/chat-VonUfVbJ.js +1 -0
- package/dist/assets/chat-mrd8Uqt-.js +1 -0
- package/dist/assets/chat-n5ursQ4V.js +1 -0
- package/dist/assets/{checkmark-_Fg66XcU.js → checkmark-Bp6YVlmh.js} +1 -1
- package/dist/assets/{checkmark-bold-CgYeIl0T.js → checkmark-bold-CoEHzMD2.js} +1 -1
- package/dist/assets/{chevron-bottom-C_QL5-Bz.js → chevron-bottom-DFl_nYaF.js} +1 -1
- package/dist/assets/{chevron-left-DilaVL0B.js → chevron-left-DQVIneyI.js} +1 -1
- package/dist/assets/{chevron-right-BGrX1ToW.js → chevron-right-C-Q4IhHi.js} +1 -1
- package/dist/assets/{chevron-top-wGqTBsfo.js → chevron-top-BdWQmyNy.js} +1 -1
- package/dist/assets/{chrome-store-BQVIpUxR.js → chrome-store-CI2BRPR0.js} +1 -1
- package/dist/assets/{clock-B7zChjNC.js → clock-C9V_cA6S.js} +1 -1
- package/dist/assets/{close-GEY-WIPu.js → close-fXP5leSd.js} +1 -1
- package/dist/assets/{coinPlaceholder-tscoun_E.js → coinPlaceholder-O6rs_4E_.js} +1 -1
- package/dist/assets/{compass-CZuq8FEk.js → compass-fEvDnc3x.js} +1 -1
- package/dist/assets/{copy-D6ICjkKl.js → copy-BJk700QJ.js} +1 -1
- package/dist/assets/{createTaskActions-BEjXSCHm.js → createTaskActions-CvIiHODG.js} +1 -1
- package/dist/assets/{cursor-oFFjVoXL.js → cursor-BJnxVGKI.js} +1 -1
- package/dist/assets/{cursor-transparent-zwVrQsY1.js → cursor-transparent-D4lkkIhD.js} +1 -1
- package/dist/assets/{debounce-G93CFNE1.js → debounce-D3Q18PUh.js} +1 -1
- package/dist/assets/{desktop-B4oyPaU_.js → desktop-BeNGPkqN.js} +1 -1
- package/dist/assets/{disconnect-KiTBpX_6.js → disconnect-ByQEym26.js} +1 -1
- package/dist/assets/{discord-BLxijDdw.js → discord-C8LfnJcF.js} +1 -1
- package/dist/assets/{distribution-ClawWswB.js → distribution-CFsJgetf.js} +1 -1
- package/dist/assets/{dropdown-wn8wa-_S.js → dropdown-Diri8mN7.js} +1 -1
- package/dist/assets/{etherscan-CE2F8Xw6.js → etherscan-CJIIAlmG.js} +1 -1
- package/dist/assets/{exclamation-triangle-BzziKWnK.js → exclamation-triangle-Dhzn_-Kl.js} +1 -1
- package/dist/assets/{extension-lB-sxIFk.js → extension-BgTTW0cM.js} +1 -1
- package/dist/assets/{external-link-DeSW97tD.js → external-link-Bx_KD-ug.js} +1 -1
- package/dist/assets/{facebook-ClFpcvFA.js → facebook-DPl1E09B.js} +1 -1
- package/dist/assets/{farcaster-C4s006nq.js → farcaster-DlLKDn_Q.js} +1 -1
- package/dist/assets/{filters-2lTgPbw7.js → filters-CnkUTvYM.js} +1 -1
- package/dist/assets/{github-DPor1lTC.js → github-CSK5uUKl.js} +1 -1
- package/dist/assets/{google-Cbtzzd6i.js → google-DDKXvLSL.js} +1 -1
- package/dist/assets/{help-circle-Bplzn7yC.js → help-circle-pYNDFOCu.js} +1 -1
- package/dist/assets/{highlight-DsFwBu4N.js → highlight-Cf3JCquz.js} +1 -1
- package/dist/assets/{id-DUTTATgR.js → id-BzejLobi.js} +1 -1
- package/dist/assets/{image-CABCG5CT.js → image-CcV73urn.js} +1 -1
- package/dist/assets/{index-D7cRCqFS.js → index-2XpyGLGv.js} +1 -1
- package/dist/assets/{index-B2RWgAXh.js → index-8JRZsFmf.js} +1 -1
- package/dist/assets/{index-4sXDQxR4.js → index-B0tt4rC-.js} +1 -1
- package/dist/assets/{index-Br5-UL2X.js → index-B31L2H-W.js} +1 -1
- package/dist/assets/{index-B3_om4ZB.js → index-B90TpNiI.js} +1 -1
- package/dist/assets/{index-Cvc-YkZx.js → index-BBoJBh3v.js} +1 -1
- package/dist/assets/{index-Dy4hgCya.js → index-BCKi0u0P.js} +1 -1
- package/dist/assets/{index-DHPT8S22.js → index-BH2Gx2wP.js} +1 -1
- package/dist/assets/{index-CdgbI3Pp.js → index-BN12ko2b.js} +1 -1
- package/dist/assets/{index-DgjpEM3x.js → index-BPANUMJE.js} +1 -1
- package/dist/assets/{index-CXgPGdvu.js → index-BZplOvWX.js} +1 -1
- package/dist/assets/{index-BZ650ta7.js → index-BbTJPQF7.js} +5 -5
- package/dist/assets/{index-f5KBtxLP.js → index-BiV6FhgA.js} +1 -1
- package/dist/assets/{index-BgYoXjG3.js → index-BoRFnFUT.js} +1 -1
- package/dist/assets/{index-BDNA2DMu.js → index-BprU921G.js} +1 -1
- package/dist/assets/{index-CxBaRfj2.js → index-BpvHHYP4.js} +1 -1
- package/dist/assets/{index-Cso_L9kT.js → index-Bqgtbl4r.js} +1 -1
- package/dist/assets/{index-CkucVuT-.js → index-C0epyDYL.js} +1 -1
- package/dist/assets/{index-B1wXO9Vt.js → index-C2HvU0NI.js} +1 -1
- package/dist/assets/{index-Buukpn8o.js → index-C5CJ0Euq.js} +1 -1
- package/dist/assets/{index-BKPqbe4l.js → index-C8vRANS2.js} +1 -1
- package/dist/assets/{index-DkLXeCmb.js → index-CCGH0otF.js} +1 -1
- package/dist/assets/{index-WPH6eO9g.js → index-CJHwlDCY.js} +1 -1
- package/dist/assets/{index-qnMPi-5D.js → index-CLDzI0WW.js} +1 -1
- package/dist/assets/{index-1WxaVCeu.js → index-CLnRg-bf.js} +1 -1
- package/dist/assets/{index-DGIx57wo.js → index-CTwcfOOP.js} +1 -1
- package/dist/assets/{index-BFKyqrk3.js → index-CVp0GTWj.js} +1 -1
- package/dist/assets/{index-Bn4CF14q.js → index-CZaRtw2_.js} +1 -1
- package/dist/assets/{index-sRDCM6JU.js → index-Ch9ViY0v.js} +2 -2
- package/dist/assets/{index-kok2V6cj.js → index-ChuKoOLp.js} +14 -14
- package/dist/assets/{index-CQsdLZkK.js → index-CkN1wpyQ.js} +1 -1
- package/dist/assets/{index-CfjhTpXV.js → index-ClrLoHiE.js} +1 -1
- package/dist/assets/{index-DSFt02oT.js → index-CmHS-OdS.js} +1 -1
- package/dist/assets/{index-Co8QBZNt.js → index-Cmkg6CTs.js} +1 -1
- package/dist/assets/{index-IIu99qEL.js → index-CmsaDv4-.js} +1 -1
- package/dist/assets/{index-D2fLbQOU.js → index-CoA-nCdp.js} +1 -1
- package/dist/assets/{index-BCum0A0B.js → index-CpSoQqye.js} +1 -1
- package/dist/assets/{index-CNnBDoa1.js → index-CrO1zKci.js} +1 -1
- package/dist/assets/{index-BI3c17YF.js → index-CvBbOBIO.js} +1 -1
- package/dist/assets/{index-BEpptA5S.js → index-CvJV8vcm.js} +1 -1
- package/dist/assets/{index-B7qOoyCR.js → index-Cvv5uGKG.js} +1 -1
- package/dist/assets/{index-Dp_Mn_DN.js → index-CxMD46RM.js} +1 -1
- package/dist/assets/{index-C9krDm9Y.js → index-D0XJKBGa.js} +1 -1
- package/dist/assets/{index-DPxpocQo.js → index-D1kDVwua.js} +1 -1
- package/dist/assets/{index-BfmYQvxy.js → index-DB1lxKA8.js} +1 -1
- package/dist/assets/{index-yNToY-SP.js → index-DBnNRQSq.js} +1 -1
- package/dist/assets/{index-BvlOxujk.js → index-DCuEnaSl.js} +1 -1
- package/dist/assets/{index-Bq9eVEdU.js → index-DKQHLQJ7.js} +1 -1
- package/dist/assets/{index-BJr3r4qN.js → index-DNghjMst.js} +1 -1
- package/dist/assets/{index-DWWSYHUH.js → index-DPBhVV33.js} +1 -1
- package/dist/assets/{index-5d8gk-Z2.js → index-DPrYAHHG.js} +1 -1
- package/dist/assets/{index-D8fRcnkf.js → index-DV3kkQnj.js} +3 -3
- package/dist/assets/{index-CLIkNw25.js → index-DcRIH5uQ.js} +1 -1
- package/dist/assets/{index-CgqZ4RXB.js → index-DdEDMA7z.js} +1 -1
- package/dist/assets/{index-BnUjW8_R.js → index-DmNjtF4K.js} +1 -1
- package/dist/assets/{index-DcO0RpyY.js → index-DsxqkUFm.js} +1 -1
- package/dist/assets/{index-_0hbL4Kz.js → index-H7c4eppj.js} +1 -1
- package/dist/assets/{index-OunnXcRy.js → index-ZLsA_LaH.js} +1 -1
- package/dist/assets/{index-BYnYd0I7.js → index-ZuyabccH.js} +1 -1
- package/dist/assets/{index-BoAkyNNY.js → index-_J7LImXy.js} +1 -1
- package/dist/assets/{index-KTS__Qmb.js → index-cAGQ4Zgy.js} +1 -1
- package/dist/assets/{index-Cp55c10D.js → index-dvUE41IS.js} +1 -1
- package/dist/assets/{index-RM1Yx2Zt.js → index-gstemDCC.js} +1 -1
- package/dist/assets/{index.browser.esm-7IocQhpc.js → index.browser.esm-Bz4y9AM_.js} +1 -1
- package/dist/assets/{index.es-UMFIHXWc.js → index.es-DFk6alzA.js} +1 -1
- package/dist/assets/{info-CKDUbxoF.js → info-DYTcBjcr.js} +1 -1
- package/dist/assets/{info-circle-B_kyIlbw.js → info-circle-1vBHZLMU.js} +1 -1
- package/dist/assets/{isEqual-DBGyFRF0.js → isEqual-BLkH-Pjf.js} +1 -1
- package/dist/assets/{isPlainObject-BffmECLj.js → isPlainObject-BCm3IKW7.js} +1 -1
- package/dist/assets/{lightbulb-r-LyxXzT.js → lightbulb-BTSwPCnA.js} +1 -1
- package/dist/assets/{mail-Cmi_B5ib.js → mail-BO96Y1bD.js} +1 -1
- package/dist/assets/{midjourney-CpAIejbT.js → midjourney-uz8aST5C.js} +1 -1
- package/dist/assets/{mobile-CtV2VqE7.js → mobile-Dpzp5ZqB.js} +1 -1
- package/dist/assets/{more-D6K0huEn.js → more-DqNeCLmE.js} +1 -1
- package/dist/assets/{network-placeholder-CZilKAko.js → network-placeholder-DfS7t2qk.js} +1 -1
- package/dist/assets/{nftPlaceholder-BQzwKTsV.js → nftPlaceholder-DpsdNCf0.js} +1 -1
- package/dist/assets/{off-B6pZ8DjL.js → off-BEeIIYS0.js} +1 -1
- package/dist/assets/{order-D5tnFLUF.js → order-BarptHRo.js} +1 -1
- package/dist/assets/{pagination-EsDrj3yC.js → pagination-CKRvreU2.js} +1 -1
- package/dist/assets/{play-store-BCTckm04.js → play-store-1RRZmHZ0.js} +1 -1
- package/dist/assets/{plus-mdaUsXl5.js → plus-BxGjpifS.js} +1 -1
- package/dist/assets/{price-Beya5kld.js → price-CZ_KvTOE.js} +1 -1
- package/dist/assets/{producer-rWlmBf6r.js → producer-B5EXA31n.js} +1 -1
- package/dist/assets/{qr-code-D8Sjqh8L.js → qr-code-B4XFZ2zx.js} +1 -1
- package/dist/assets/{recycle-horizontal-CPLHRf4o.js → recycle-horizontal-znmbOfPU.js} +1 -1
- package/dist/assets/{refresh-jKwy0GpU.js → refresh-ChxCsROE.js} +1 -1
- package/dist/assets/{reown-logo-CPPULql9.js → reown-logo-CRoqC1i1.js} +1 -1
- package/dist/assets/{search-1eSZhp20.js → search-BJvlpDJB.js} +1 -1
- package/dist/assets/{secp256k1-BsXGtyEK.js → secp256k1-DGojhQdr.js} +1 -1
- package/dist/assets/{secp256k1-B_FLw2WH.js → secp256k1-sMoEsD8z.js} +1 -1
- package/dist/assets/{seedream-jD5w8Wkn.js → seedream-KsoTngUI.js} +1 -1
- package/dist/assets/{send-B3yYwiO-.js → send-D3urj6BC.js} +1 -1
- package/dist/assets/{service-6pzgrgNR.js → service-Vo0bBQzK.js} +1 -1
- package/dist/assets/{solana-wallets-B8mQpYIR.js → solana-wallets-D13JOJx1.js} +2 -2
- package/dist/assets/{solana-wallets-vue-OMit6gDf.js → solana-wallets-vue-BA56e4Sy.js} +1 -1
- package/dist/assets/{subsite-CCktyerR.js → subsite-0Gu6-XDL.js} +1 -1
- package/dist/assets/{subsite-BvzAuzC-.js → subsite-6iXIivyP.js} +1 -1
- package/dist/assets/{subsite-D1uL2HXY.js → subsite-BocXunJk.js} +1 -1
- package/dist/assets/{subsite-DH2q3YKR.js → subsite-BpC6fEyn.js} +1 -1
- package/dist/assets/{subsite-aavu4y0F.js → subsite-BrmN-NoH.js} +1 -1
- package/dist/assets/{subsite-ChmCrf9h.js → subsite-CpdsoWNQ.js} +1 -1
- package/dist/assets/{subsite-8htWTxFn.js → subsite-CrV9QJpt.js} +1 -1
- package/dist/assets/{subsite-CiCLsst4.js → subsite-Cv-clFHs.js} +1 -1
- package/dist/assets/{subsite-BNKmSzo-.js → subsite-DKuGEBhh.js} +1 -1
- package/dist/assets/{subsite-CjsQyrer.js → subsite-DPLyE6-m.js} +1 -1
- package/dist/assets/{subsite-D5ENZyhT.js → subsite-DU83agAb.js} +1 -1
- package/dist/assets/{subsite-BiGtGhvE.js → subsite-Dd-BXBXA.js} +1 -1
- package/dist/assets/{subsite-DiUNQwvY.js → subsite-De1hHUH6.js} +1 -1
- package/dist/assets/{subsite-BL5mOrr1.js → subsite-Deu8704B.js} +1 -1
- package/dist/assets/{subsite-CDYEQOTD.js → subsite-DhjkwFaX.js} +1 -1
- package/dist/assets/{subsite-C54AOcnd.js → subsite-DoibDTCT.js} +1 -1
- package/dist/assets/{subsite-MlffMoHD.js → subsite-QPD4eyus.js} +1 -1
- package/dist/assets/{subsite-DUoz-n2w.js → subsite-vz32NYYZ.js} +1 -1
- package/dist/assets/{suno-DSUwKnh3.js → suno-Xg3xem7A.js} +1 -1
- package/dist/assets/{swapHorizontal-Br-5wqY-.js → swapHorizontal-CkEYwp0b.js} +1 -1
- package/dist/assets/{swapHorizontalBold-DuCN4UcO.js → swapHorizontalBold-D3h3rVtu.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-zV1oXq_b.js → swapHorizontalMedium-D9Sp05tr.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-DDrEgAhO.js → swapHorizontalRoundedBold-lkZC_zCz.js} +1 -1
- package/dist/assets/{swapVertical-y0KV1QQR.js → swapVertical-Bg1Dz2zM.js} +1 -1
- package/dist/assets/{telegram-mND4CsPI.js → telegram-DV1fXBQt.js} +1 -1
- package/dist/assets/{three-dots-HzdB6sGq.js → three-dots-u-O1hAgs.js} +1 -1
- package/dist/assets/{twitch-0478BEgU.js → twitch-i4rmOfJd.js} +1 -1
- package/dist/assets/{twitterIcon-D0Pr83ih.js → twitterIcon-BurjfTQs.js} +1 -1
- package/dist/assets/{typescript-CfmcPqGh.js → typescript-CqgbTwhG.js} +1 -1
- package/dist/assets/{use-form-item-CYiJWVVo.js → use-form-item-BAnuDQeY.js} +1 -1
- package/dist/assets/validator-DwtE3Sn3.js +1 -0
- package/dist/assets/{verify-QazBPVGr.js → verify-D4yetJ8p.js} +1 -1
- package/dist/assets/{verify-filled-DFzSdAuk.js → verify-filled-DZMWmBcf.js} +1 -1
- package/dist/assets/{w3m-modal-BQ0hIRJA.js → w3m-modal-BHsKSN-8.js} +1 -1
- package/dist/assets/{wallet-DMP1k3cH.js → wallet-DyiKnVhV.js} +1 -1
- package/dist/assets/{wallet-placeholder-B3gN0g8z.js → wallet-placeholder-CkPWFOSE.js} +1 -1
- package/dist/assets/{walletconnect-Dl5PB53v.js → walletconnect-CV96x8RH.js} +1 -1
- package/dist/assets/{warning-circle-DwJzRCqK.js → warning-circle-DMhinUXX.js} +1 -1
- package/dist/assets/{web-CTaJ2ntq.js → web-9CPF_p0f.js} +1 -1
- package/dist/assets/{web-Cw04riuO.js → web-Bn05ogYX.js} +1 -1
- package/dist/assets/{x-BejnjBsB.js → x-DhGOH052.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/chat-15L1iHYd.js +0 -1
- package/dist/assets/chat-BIGDz2U8.js +0 -1
- package/dist/assets/chat-Bzz6VpI2.js +0 -1
- package/dist/assets/chat-C1Fov3VZ.js +0 -1
- package/dist/assets/chat-CLbEuebR.js +0 -1
- package/dist/assets/chat-CMe4j38Z.js +0 -1
- package/dist/assets/chat-CPJzXDDq.js +0 -1
- package/dist/assets/chat-CRMiyNWh.js +0 -1
- package/dist/assets/chat-C_QoPV7n.js +0 -1
- package/dist/assets/chat-CzBgIVjJ.js +0 -1
- package/dist/assets/chat-DLPgIxZs.js +0 -1
- package/dist/assets/chat-Db5jHkMr.js +0 -1
- package/dist/assets/chat-DnTeHwdL.js +0 -1
- package/dist/assets/chat-GQ2lWN7D.js +0 -1
- package/dist/assets/chat-J0zL9WVN.js +0 -1
- package/dist/assets/chat-JNXCDzNu.js +0 -1
- package/dist/assets/chat-_8bK1SD2.js +0 -1
- package/dist/assets/chat-q7DMvyHC.js +0 -1
- package/dist/assets/validator-7URr4p3I.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as L}from"./index.es-UMFIHXWc.js";import{E as D}from"./index-D7cRCqFS.js";import{E as N}from"./index-1WxaVCeu.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-kok2V6cj.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-DkLXeCmb.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-EsDrj3yC.js";import{I as ie}from"./ImagePreview-BjgklCqN.js";import{E as ce}from"./index-yNToY-SP.js";import{E as V}from"./index-Buukpn8o.js";import{C as de}from"./Consumption-BAwCyKhW.js";import{P as ue,N as pe}from"./NoTasks-DLn86jTC.js";import{a as me}from"./price-Beya5kld.js";import{b as fe}from"./errorCode-Cqj9Td_Z.js";import{C as _e}from"./CopyToClipboard-B1L4gFQs.js";import{V as he}from"./VideoPlayer-lNCFIvjW.js";import{A as $e}from"./ApiCodeButton-Bu2nLY5J.js";import{E as ge}from"./index-BnUjW8_R.js";import{E as ve}from"./index-CLIkNw25.js";import{E as be}from"./index-CXgPGdvu.js";import{B as ke}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BYnYd0I7.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBGyFRF0.js";import"./_Uint8Array-pGzioutB.js";import"./castArray-CJ8hzGGj.js";import"./index-WPH6eO9g.js";import"./index-DWWSYHUH.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_initCloneObject-CAH0nDM3.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BJr3r4qN.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-DFk6alzA.js";import{E as D}from"./index-2XpyGLGv.js";import{E as N}from"./index-CLnRg-bf.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-ChuKoOLp.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-CCGH0otF.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-CKRvreU2.js";import{I as ie}from"./ImagePreview-Bl6hkqwF.js";import{E as ce}from"./index-DBnNRQSq.js";import{E as V}from"./index-C5CJ0Euq.js";import{C as de}from"./Consumption-CUbvFAAd.js";import{P as ue,N as pe}from"./NoTasks-hJEZMzd9.js";import{a as me}from"./price-CZ_KvTOE.js";import{b as fe}from"./errorCode-Cqj9Td_Z.js";import{C as _e}from"./CopyToClipboard-q8AT00kT.js";import{V as he}from"./VideoPlayer-CMtYz-DY.js";import{A as $e}from"./ApiCodeButton-BAAm5I15.js";import{E as ge}from"./index-DmNjtF4K.js";import{E as ve}from"./index-DcRIH5uQ.js";import{E as be}from"./index-BZplOvWX.js";import{B as ke}from"./BotPlaceholder-DxAlgny2.js";import"./use-form-item-BAnuDQeY.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-ZuyabccH.js";import"./typescript-CqgbTwhG.js";import"./index-cAGQ4Zgy.js";import"./strings-beZM2Y-f.js";import"./isEqual-BLkH-Pjf.js";import"./_Uint8Array-Dky9YMEI.js";import"./castArray-9UHm33vq.js";import"./index-CJHwlDCY.js";import"./index-DPBhVV33.js";import"./debounce-D3Q18PUh.js";import"./_baseIteratee-B03IqKJU.js";import"./index-CvBbOBIO.js";import"./highlight-Cf3JCquz.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CrO1zKci.js";import"./_baseClone-BcpYfRjc.js";import"./_initCloneObject-zlapHgef.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DNghjMst.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{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-ChuKoOLp.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-UMFIHXWc.js";import{E as U}from"./index-D7cRCqFS.js";import{E as x}from"./index-1WxaVCeu.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-kok2V6cj.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-EsDrj3yC.js";import{E as P}from"./index-BDNA2DMu.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-BjgklCqN.js";import{E as G}from"./index-yNToY-SP.js";import{E as v}from"./index-Buukpn8o.js";import{F as se}from"./FilePreview-Hbma88Qo.js";import{P as ne,N as ae}from"./NoTasks-DLn86jTC.js";import{V as N}from"./VideoPlayer-lNCFIvjW.js";import{C as le}from"./Consumption-BAwCyKhW.js";import{a as ie}from"./price-Beya5kld.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ce}from"./CopyToClipboard-B1L4gFQs.js";import{A as me}from"./ApiCodeButton-Bu2nLY5J.js";import{E as ue}from"./index-BnUjW8_R.js";import{E as de}from"./index-CLIkNw25.js";import{E as pe}from"./index-CXgPGdvu.js";import{B as fe}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-7URr4p3I.js";import"./index-KTS__Qmb.js";import"./index-CNnBDoa1.js";import"./typescript-CfmcPqGh.js";import"./_baseClone-D8eUdaQd.js";import"./_Uint8Array-pGzioutB.js";import"./_initCloneObject-CAH0nDM3.js";import"./isEqual-DBGyFRF0.js";import"./index-WPH6eO9g.js";import"./index-DWWSYHUH.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-G93CFNE1.js";import"./index-BJr3r4qN.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-DFk6alzA.js";import{E as U}from"./index-2XpyGLGv.js";import{E as x}from"./index-CLnRg-bf.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-ChuKoOLp.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-CKRvreU2.js";import{E as P}from"./index-BprU921G.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-Bl6hkqwF.js";import{E as G}from"./index-DBnNRQSq.js";import{E as v}from"./index-C5CJ0Euq.js";import{F as se}from"./FilePreview-TUpFWJij.js";import{P as ne,N as ae}from"./NoTasks-hJEZMzd9.js";import{V as N}from"./VideoPlayer-CMtYz-DY.js";import{C as le}from"./Consumption-CUbvFAAd.js";import{a as ie}from"./price-CZ_KvTOE.js";import{b as re}from"./errorCode-Cqj9Td_Z.js";import{C as ce}from"./CopyToClipboard-q8AT00kT.js";import{A as me}from"./ApiCodeButton-BAAm5I15.js";import{E as ue}from"./index-DmNjtF4K.js";import{E as de}from"./index-DcRIH5uQ.js";import{E as pe}from"./index-BZplOvWX.js";import{B as fe}from"./BotPlaceholder-DxAlgny2.js";import"./use-form-item-BAnuDQeY.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-Cf3JCquz.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-DwtE3Sn3.js";import"./index-cAGQ4Zgy.js";import"./index-CrO1zKci.js";import"./typescript-CqgbTwhG.js";import"./_baseClone-BcpYfRjc.js";import"./_Uint8Array-Dky9YMEI.js";import"./_initCloneObject-zlapHgef.js";import"./isEqual-BLkH-Pjf.js";import"./index-CJHwlDCY.js";import"./index-DPBhVV33.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-D3Q18PUh.js";import"./index-DNghjMst.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 +1 @@
|
|
|
1
|
-
import{F as R}from"./index.es-UMFIHXWc.js";import{E as S}from"./index-D7cRCqFS.js";import{E as D}from"./index-1WxaVCeu.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as h,J as m,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as O,cs as B,b5 as j,S as G,ct as F}from"./index-kok2V6cj.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as P}from"./index-DkLXeCmb.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{u as W,a as H,e as J}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as K,S as Q,l as X}from"./pagination-EsDrj3yC.js";import{I as Y}from"./ImagePreview-BjgklCqN.js";import{E as Z}from"./index-yNToY-SP.js";import{E as T}from"./index-Buukpn8o.js";import{P as x,N as ee}from"./NoTasks-DLn86jTC.js";import{C as te}from"./Consumption-BAwCyKhW.js";import{a as oe}from"./price-Beya5kld.js";import{b as se}from"./errorCode-Cqj9Td_Z.js";import{C as ne}from"./CopyToClipboard-B1L4gFQs.js";import{V as ae}from"./VideoPlayer-lNCFIvjW.js";import{A as le}from"./ApiCodeButton-Bu2nLY5J.js";import{E as re}from"./index-BnUjW8_R.js";import{E as ie}from"./index-CLIkNw25.js";import{E as ce}from"./index-CXgPGdvu.js";import{B as de}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BYnYd0I7.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBGyFRF0.js";import"./_Uint8Array-pGzioutB.js";import"./castArray-CJ8hzGGj.js";import"./index-WPH6eO9g.js";import"./index-DWWSYHUH.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_initCloneObject-CAH0nDM3.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BJr3r4qN.js";const ue=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,n,p,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",pe,[i("div",me,[C(e.$slots,"config",{},void 0,!0)]),i("div",fe,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=b(ue,[["render",he],["__scopeId","data-v-3b0702a7"]]),ge=v({name:"ModelSelector",components:{ElSelect:P,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),$e={class:"field"},we={class:"title font-bold"},ve={class:"float-left"};function be(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",$e,[i("h2",we,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ke=b(ge,[["render",be],["__scopeId","data-v-eb090beb"]]),ye="720p",Ve=v({name:"ResolutionSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ye)}}),Te={class:"field"},Ee={class:"title font-bold"},Ie={class:"float-left"};function Se(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Te,[i("h2",Ee,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ie,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=b(Ve,[["render",Se],["__scopeId","data-v-3e39f44e"]]),Le=5,Ce=v({name:"DurationSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Le)}}),Re={class:"field"},Ae={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Re,[i("h2",Ae,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Pe,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ce,[["render",Ge],["__scopeId","data-v-5f35a2cf"]]),Me=v({name:"ImageUrlInput",components:{ElUpload:Z,ElButton:S,InfoIcon:K,ImagePreview:Y},mixins:[z,W],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Oe={class:"relative"},Be={class:"flex justify-between"},je={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"};function Ne(e,n,p,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Oe,[i("div",Be,[i("div",je,[i("span",Fe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:f})=>[f.url&&f.percentage!==void 0?(s(),$(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[h(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const qe=b(Me,[["render",Ne],["__scopeId","data-v-41a69004"]]),ze="",We=v({name:"PromptInput",components:{PromptTextarea:x},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}});function He(e,n,p,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Je=b(We,[["render",He]]),Ke=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:Je,ImageUrlInput:qe,ModelSelector:ke,ResolutionSelector:Ue,DurationSelector:De,Consumption:te},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return oe(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Qe={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-5"},Ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ze(e,n,p,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),f=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",Qe,[i("div",Xe,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(f,{key:2,class:"mb-2"})):m("",!0)]),i("div",Ye,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const xe=b(Ke,[["render",Ze]]),et=v({name:"TaskPreview",components:{ElImage:ce,CopyToClipboard:ne,FontAwesomeIcon:R,ElAlert:ie,VideoPlayer:ae,ElTooltip:re,ElButton:S,ApiCodeButton:le},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),tt={class:"preview"},ot={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},it={key:0},ct={key:1},dt={key:0,class:L({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:L({operations:!0,"mt-2":!0})},mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:2,class:L({content:!0})},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function yt(e,n,p,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),f=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",tt,[i("div",ot,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",st,[i("div",nt,[h(a(e.$t("wan.name.wanBot"))+" ",1),i("span",at,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",lt,[e.modelValue?.request?.prompt?(s(),r("p",rt,[h(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",it," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",ct," - ("+a(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",dt,[e.modelValue?.response?.video_url?(s(),r("div",ut,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",pt,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(At=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[h(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(f,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",mt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ht,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",_t,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",gt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",$t,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",wt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),i("p",vt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",bt,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",kt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const Vt=b(et,[["render",yt],["__scopeId","data-v-916b8970"]]),Tt=v({name:"RecentPanel",components:{TaskPreview:Vt,BotPlaceholder:de,NoTasks:ee,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function St(e,n,p,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=f=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,f=>(s(),$(u,{key:f.id,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(w)])):m("",!0)],64)}const Ut=b(Tt,[["render",St]]),Lt=F("wan"),Ct=v({name:"WanIndex",components:{ConfigPanel:xe,Layout:_e,RecentPanel:Ut},mixins:[H],inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await X({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!J(this.uploadTracker,p=>this.$t(p),p=>T.warning(p)))return;const e={...this.config,callback_url:Lt},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===se?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,n,p,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Lo=b(Ct,[["render",Rt]]);export{Lo as default};
|
|
1
|
+
import{F as R}from"./index.es-DFk6alzA.js";import{E as S}from"./index-2XpyGLGv.js";import{E as D}from"./index-CLnRg-bf.js";import{d as v,H as r,E as i,z as C,C as t,y as c,D as o,q as s,F as a,O as I,N as U,x as $,I as h,J as m,M,Q as L}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as O,cs as B,b5 as j,S as G,ct as F}from"./index-ChuKoOLp.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as A,a as P}from"./index-CCGH0otF.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{u as W,a as H,e as J}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as K,S as Q,l as X}from"./pagination-CKRvreU2.js";import{I as Y}from"./ImagePreview-Bl6hkqwF.js";import{E as Z}from"./index-DBnNRQSq.js";import{E as T}from"./index-C5CJ0Euq.js";import{P as x,N as ee}from"./NoTasks-hJEZMzd9.js";import{C as te}from"./Consumption-CUbvFAAd.js";import{a as oe}from"./price-CZ_KvTOE.js";import{b as se}from"./errorCode-Cqj9Td_Z.js";import{C as ne}from"./CopyToClipboard-q8AT00kT.js";import{V as ae}from"./VideoPlayer-CMtYz-DY.js";import{A as le}from"./ApiCodeButton-BAAm5I15.js";import{E as re}from"./index-DmNjtF4K.js";import{E as ie}from"./index-DcRIH5uQ.js";import{E as ce}from"./index-BZplOvWX.js";import{B as de}from"./BotPlaceholder-DxAlgny2.js";import"./use-form-item-BAnuDQeY.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-ZuyabccH.js";import"./typescript-CqgbTwhG.js";import"./index-cAGQ4Zgy.js";import"./strings-beZM2Y-f.js";import"./isEqual-BLkH-Pjf.js";import"./_Uint8Array-Dky9YMEI.js";import"./castArray-9UHm33vq.js";import"./index-CJHwlDCY.js";import"./index-DPBhVV33.js";import"./debounce-D3Q18PUh.js";import"./_baseIteratee-B03IqKJU.js";import"./index-CvBbOBIO.js";import"./highlight-Cf3JCquz.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CrO1zKci.js";import"./_baseClone-BcpYfRjc.js";import"./_initCloneObject-zlapHgef.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DNghjMst.js";const ue=v({name:"LayoutWan",components:{ElDrawer:D,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,n,p,_,k,y){const d=o("font-awesome-icon"),u=o("el-button"),l=o("el-drawer");return s(),r("div",pe,[i("div",me,[C(e.$slots,"config",{},void 0,!0)]),i("div",fe,[C(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:n[0]||(n[0]=w=>e.drawer=!0)},{default:c(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(l,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"340px"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=b(ue,[["render",he],["__scopeId","data-v-3b0702a7"]]),ge=v({name:"ModelSelector",components:{ElSelect:P,ElOption:A},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=N)}}),$e={class:"field"},we={class:"title font-bold"},ve={class:"float-left"};function be(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",$e,[i("h2",we,a(e.$t("wan.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",ve,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ke=b(ge,[["render",be],["__scopeId","data-v-eb090beb"]]),ye="720p",Ve=v({name:"ResolutionSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ye)}}),Te={class:"field"},Ee={class:"title font-bold"},Ie={class:"float-left"};function Se(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Te,[i("h2",Ee,a(e.$t("wan.name.resolution")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Ie,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=b(Ve,[["render",Se],["__scopeId","data-v-3e39f44e"]]),Le=5,Ce=v({name:"DurationSelector",components:{ElSelect:P,ElOption:A},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Le)}}),Re={class:"field"},Ae={class:"title font-bold"},Pe={class:"float-left"};function Ge(e,n,p,_,k,y){const d=o("el-option"),u=o("el-select");return s(),r("div",Re,[i("h2",Ae,a(e.$t("wan.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),r(I,null,U(e.options,l=>(s(),$(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",Pe,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=b(Ce,[["render",Ge],["__scopeId","data-v-5f35a2cf"]]),Me=v({name:"ImageUrlInput",components:{ElUpload:Z,ElButton:S,InfoIcon:K,ImagePreview:Y},mixins:[z,W],data(){return{fileList:[],uploadUrl:O()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){T.warning(this.$t("wan.message.uploadImageExceed"))},onError(){T.error(this.$t("wan.message.uploadImageError"))},async onRemove(){T.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Oe={class:"relative"},Be={class:"flex justify-between"},je={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"};function Ne(e,n,p,_,k,y){const d=o("info-icon"),u=o("image-preview"),l=o("el-button"),w=o("el-upload");return s(),r("div",Oe,[i("div",Be,[i("div",je,[i("span",Fe,a(e.$t("wan.name.imageUrl")),1),t(d,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(w,{"file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:f})=>[f.url&&f.percentage!==void 0?(s(),$(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:g=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:c(()=>[t(l,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[h(a(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const qe=b(Me,[["render",Ne],["__scopeId","data-v-41a69004"]]),ze="",We=v({name:"PromptInput",components:{PromptTextarea:x},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}});function He(e,n,p,_,k,y){const d=o("prompt-textarea");return s(),$(d,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=u=>e.prompt=u),title:e.$t("wan.name.prompt"),info:e.$t("wan.description.prompt"),placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Je=b(We,[["render",He]]),Ke=v({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:Je,ImageUrlInput:qe,ModelSelector:ke,ResolutionSelector:Ue,DurationSelector:De,Consumption:te},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return oe(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),Qe={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-5"},Ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ze(e,n,p,_,k,y){const d=o("prompt-input"),u=o("model-selector"),l=o("resolution-selector"),w=o("duration-selector"),f=o("image-url-input"),g=o("consumption"),V=o("font-awesome-icon"),E=o("el-button");return s(),r("div",Qe,[i("div",Xe,[t(d,{class:"mb-4"}),t(u,{class:"mb-4"}),e.supportsResolution?(s(),$(l,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(w,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(f,{key:2,class:"mb-2"})):m("",!0)]),i("div",Ye,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),t(E,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(V,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+a(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const xe=b(Ke,[["render",Ze]]),et=v({name:"TaskPreview",components:{ElImage:ce,CopyToClipboard:ne,FontAwesomeIcon:R,ElAlert:ie,VideoPlayer:ae,ElTooltip:re,ElButton:S,ApiCodeButton:le},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),tt={class:"preview"},ot={class:"left"},st={class:"main"},nt={class:"bot"},at={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},it={key:0},ct={key:1},dt={key:0,class:L({content:!0,failed:!0})},ut={key:0,class:"mb-4"},pt={key:1,class:L({operations:!0,"mt-2":!0})},mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},bt={key:2,class:L({content:!0})},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function yt(e,n,p,_,k,y){const d=o("el-image"),u=o("video-player"),l=o("el-button"),w=o("el-tooltip"),f=o("api-code-button"),g=o("font-awesome-icon"),V=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",tt,[i("div",ot,[t(d,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),i("div",st,[i("div",nt,[h(a(e.$t("wan.name.wanBot"))+" ",1),i("span",at,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",lt,[e.modelValue?.request?.prompt?(s(),r("p",rt,[h(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",it," - ("+a(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",ct," - ("+a(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",dt,[e.modelValue?.response?.video_url?(s(),r("div",ut,[t(u,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",pt,[t(w,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:c(()=>[t(l,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=M(At=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[h(a(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"]),t(f,{path:"/wan/videos",body:e.modelValue?.request},null,8,["body"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),r("p",mt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.model"))+": "+a(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),i("p",ft,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ht,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",_t,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",gt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),i("p",$t,[t(g,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+a(e.$t("wan.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",wt,[t(g,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+a(e.$t("wan.name.elapsed"))+": "+a(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),i("p",vt,[t(g,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("wan.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(s(),r("div",bt,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(g,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("wan.name.failure")),1)]),default:c(()=>[i("p",kt,[t(g,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("wan.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const Vt=b(et,[["render",yt],["__scopeId","data-v-916b8970"]]),Tt=v({name:"RecentPanel",components:{TaskPreview:Vt,BotPlaceholder:de,NoTasks:ee,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function St(e,n,p,_,k,y){const d=o("bot-placeholder"),u=o("task-preview"),l=o("scroll-list"),w=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(l,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=f=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),r(I,null,U(e.tasks?.items,f=>(s(),$(u,{key:f.id,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(w)])):m("",!0)],64)}const Ut=b(Tt,[["render",St]]),Lt=F("wan"),Ct=v({name:"WanIndex",components:{ConfigPanel:xe,Layout:_e,RecentPanel:Ut},mixins:[H],inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await X({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:p,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",p,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:p,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!J(this.uploadTracker,p=>this.$t(p),p=>T.warning(p)))return;const e={...this.config,callback_url:Lt},n=this.credential?.token;if(!n){console.error("no token specified");return}T.info(this.$t("wan.message.startingTask")),B("wan",j.generate(e,{token:n})).then(()=>{T.success(this.$t("wan.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===se?T.error(this.$t("wan.message.usedUp")):T.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,n,p,_,k,y){const d=o("config-panel"),u=o("recent-panel"),l=o("layout");return s(),$(l,null,{config:c(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Lo=b(Ct,[["render",Rt]]);export{Lo as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as U}from"./index.es-UMFIHXWc.js";import{E as L}from"./index-D7cRCqFS.js";import{E as Y}from"./index-1WxaVCeu.js";import{d as g,H as i,E as c,z as j,C as a,y as p,D as s,q as t,F as l,O as w,N as S,x as m,Q as A,R as J,J as d,I as h}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as K,cs as Q,aK as W,S as R,ct as Z}from"./index-kok2V6cj.js";import{a as x,b as ee,c as oe,d as te,e as se,f as ne,g as M,h as ae,i as le,j as ie}from"./veo-Dg8Zhpd-.js";import{E as P,a as O}from"./index-DkLXeCmb.js";import{I as G,S as re,l as ce}from"./pagination-EsDrj3yC.js";import{E as de}from"./index-BDNA2DMu.js";import{V as D}from"./VideoPlayer-lNCFIvjW.js";import{E as N}from"./index-WPH6eO9g.js";import{p as ue}from"./pasteUploadMixin-BurWbGNQ.js";import{u as pe,a as me,e as ve}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as fe}from"./ImagePreview-BjgklCqN.js";import{E as _e}from"./index-yNToY-SP.js";import{E as I}from"./index-Buukpn8o.js";import{C as he}from"./Consumption-BAwCyKhW.js";import{P as $e,N as ge}from"./NoTasks-DLn86jTC.js";import{a as be}from"./price-Beya5kld.js";import{b as ke}from"./errorCode-Cqj9Td_Z.js";import{C as ye}from"./CopyToClipboard-B1L4gFQs.js";import{A as Ve}from"./ApiCodeButton-Bu2nLY5J.js";import{E as we}from"./index-BnUjW8_R.js";import{E as Ee}from"./index-CLIkNw25.js";import{E as Te}from"./index-CXgPGdvu.js";import{B as Ie}from"./BotPlaceholder-B5Bw1tlj.js";import"./use-form-item-CYiJWVVo.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BYnYd0I7.js";import"./typescript-CfmcPqGh.js";import"./index-KTS__Qmb.js";import"./strings-beZM2Y-f.js";import"./isEqual-DBGyFRF0.js";import"./_Uint8Array-pGzioutB.js";import"./castArray-CJ8hzGGj.js";import"./debounce-G93CFNE1.js";import"./_baseIteratee-BCY-1IYO.js";import"./index-BI3c17YF.js";import"./highlight-DsFwBu4N.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-7URr4p3I.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DWWSYHUH.js";import"./index-CNnBDoa1.js";import"./_baseClone-D8eUdaQd.js";import"./_initCloneObject-CAH0nDM3.js";import"./index-BJr3r4qN.js";const Se=g({name:"LayoutVeo",components:{ElDrawer:Y,ElButton:L,FontAwesomeIcon:U},data(){return{drawer:!1}}}),Ae={class:"main flex flex-row flex-1"},Ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Oe(e,o,v,_,k,y){const r=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return t(),i("div",Ae,[c("div",Ce,[j(e.$slots,"config",{},void 0,!0)]),c("div",Pe,[j(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=V=>e.drawer=!0)},{default:p(()=>[a(r,{icon:"fa-solid fa-magic"})]),_:1}),a(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=V=>e.drawer=V),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[j(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ue=b(Se,[["render",Oe],["__scopeId","data-v-9b26d591"]]),Le=g({name:"ModelSelector",components:{ElSelect:O,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=x)}}),je={class:"field"},Re={class:"title font-bold"};function Me(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",je,[c("h2",Re,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=b(Le,[["render",Me],["__scopeId","data-v-a59d89c9"]]),De=g({name:"ActionSelector",components:{ElSelect:O,ElOption:P},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),Ne={class:"field"},Fe={class:"title font-bold"},ze={class:"float-left"};function Be(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Ne,[c("h2",Fe,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},{default:p(()=>[c("span",ze,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const qe=b(De,[["render",Be],["__scopeId","data-v-f4d8785c"]]),He=g({name:"TranslationSelector",components:{ElSwitch:de,InfoIcon:G},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=oe)}}),Xe={class:"relative"},Ye={class:"flex justify-between"},Je={class:"flex justify-start items-center"},Ke={class:"text-sm font-bold"},Qe={class:"flex justify-end items-center"};function We(e,o,v,_,k,y){const r=s("info-icon"),u=s("el-switch");return t(),i("div",Xe,[c("div",Ye,[c("div",Je,[c("span",Ke,l(e.$t("veo.name.translation")),1),a(r,{content:e.$t("veo.description.translation")},null,8,["content"])]),c("div",Qe,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value"},null,8,["modelValue"])])])])}const Ze=b(He,[["render",We]]),xe=g({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),eo={class:"text-sm font-bold mb-2 block"},oo={class:"items"},to=["onClick"],so={class:"name"};function no(e,o,v,_,k,y){return t(),i("div",null,[c("span",eo,l(e.$t("veo.name.ratio")),1),c("div",oo,[(t(!0),i(w,null,S(e.options,(r,u)=>(t(),i("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:n=>e.value=r.value},[c("div",{class:A(["preview",r.label])},[c("div",{class:"rect",style:J({width:r.width+"px",height:r.height+"px"})},null,4)],2),c("p",so,l(r.label),1)],10,to))),128))])])}const ao=b(xe,[["render",no],["__scopeId","data-v-0f16be77"]]),lo=g({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),io={class:"relative"},ro={class:"flex mb-2"},co={class:"text-sm font-bold"};function uo(e,o,v,_,k,y){const r=s("video-player");return t(),i("div",io,[c("div",ro,[c("span",co,l(e.$t("veo.name.action3")),1)]),c("div",null,[e.config?.video_url?(t(),m(r,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const po=b(lo,[["render",uo]]),mo=g({name:"VideoIdInput",components:{ElInput:N},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),vo={class:"field"},fo={class:"title font-bold"};function _o(e,o,v,_,k,y){const r=s("el-input");return t(),i("div",vo,[c("h2",fo,l(e.$t("veo.name.videoId")),1),a(r,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const ho=b(mo,[["render",_o],["__scopeId","data-v-6eba4026"]]),$o=g({name:"StartEndImage",components:{ElUpload:_e,ElButton:L,InfoIcon:G,FontAwesomeIcon:U,ImagePreview:fe},mixins:[ue,pe],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?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),go={class:"relative"},bo={class:"flex justify-between"},ko={class:"flex justify-start items-center"},yo={class:"text-sm font-bold"};function Vo(e,o,v,_,k,y){const r=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),V=s("el-button"),T=s("el-upload");return t(),i("div",go,[c("div",bo,[c("div",ko,[c("span",yo,l(e.$t("veo.name.startEndImage")),1),a(r,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a(T,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=f=>e.fileList=f),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:f})=>[f.url&&f.percentage!==void 0?(t(),m(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(V,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const wo=b($o,[["render",Vo],["__scopeId","data-v-f9a79b4a"]]),Eo=g({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return ne.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=se)}}),To={class:"field"},Io={class:"title font-bold"};function So(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",To,[c("h2",Io,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ao=b(Eo,[["render",So],["__scopeId","data-v-8b74a7ae"]]),Co=g({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return M.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!M.includes(this.value))&&(this.value=ae)}}),Po={class:"field"},Oo={class:"title font-bold"};function Uo(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Po,[c("h2",Oo,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Lo=b(Co,[["render",Uo],["__scopeId","data-v-cc3f9355"]]),jo=g({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return ie.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=le)}}),Ro={class:"field"},Mo={class:"title font-bold"};function Go(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Ro,[c("h2",Mo,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Do=b(jo,[["render",Go],["__scopeId","data-v-3affff3c"]]),No=g({name:"ImageMaskInput",components:{ElInput:N},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),Fo={class:"field"},zo={class:"title font-bold"};function Bo(e,o,v,_,k,y){const r=s("el-input");return t(),i("div",Fo,[c("h2",zo,l(e.$t("veo.name.imageMask")),1),a(r,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const qo=b(No,[["render",Bo],["__scopeId","data-v-6cc27c68"]]),Ho="",Xo=g({name:"PromptInput",components:{PromptTextarea:$e},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ho)}});function Yo(e,o,v,_,k,y){const r=s("prompt-textarea");return t(),m(r,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=u=>e.prompt=u),title:e.$t("veo.name.prompt"),info:e.$t("veo.description.prompt"),placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Jo=b(Xo,[["render",Yo]]),Ko=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Qo=["text2video","image2video","ingredients2video"],Wo=g({name:"ConfigPanel",components:{ElButton:L,Consumption:he,FontAwesomeIcon:U,PromptInput:Jo,ModelSelector:Ge,StartEndImage:wo,ActionSelector:qe,VideoFromInput:po,VideoIdInput:ho,UpsampleActionSelector:Ao,ExtendModelSelector:Lo,MotionTypeSelector:Do,ImageMaskInput:qo,TranslationSelector:Ze,AspectRatioSelector:ao},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return be(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Ko.includes(this.config?.action??"")},isGeneration(){return Qo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Zo={class:"flex flex-col h-full"},xo={class:"flex-1 overflow-y-auto p-5"},et={class:"flex flex-col items-center justify-center px-5 pb-5"};function ot(e,o,v,_,k,y){const r=s("action-selector"),u=s("video-from-input"),n=s("video-id-input"),V=s("upsample-action-selector"),T=s("extend-model-selector"),f=s("prompt-input"),E=s("motion-type-selector"),C=s("image-mask-input"),$=s("translation-selector"),F=s("aspect-ratio-selector"),z=s("model-selector"),B=s("start-end-image"),q=s("consumption"),H=s("font-awesome-icon"),X=s("el-button");return t(),i("div",Zo,[c("div",xo,[a(r,{class:"mb-4"}),e.isPostProcessing?(t(),i(w,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(n,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(V,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(T,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(f,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(E,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(f,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(C,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(f,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(w,{key:8},[a($,{class:"mb-4"}),a(F,{class:"mb-4"}),a(f,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:0,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:1,class:"mb-2"})):d("",!0)],64)):d("",!0)]),c("div",et,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(X,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const tt=b(Wo,[["render",ot]]),st=g({name:"TaskPreview",components:{ElImage:Te,CopyToClipboard:ye,FontAwesomeIcon:U,ElAlert:Ee,VideoPlayer:D,ElTooltip:we,ElButton:L,ApiCodeButton:Ve},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,_){console.debug("seed config from preview",{action:v,upsampleAction:_,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,..._?{upsample_action:_}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),nt={class:"preview"},at={class:"left"},lt={class:"main"},it={class:"bot"},rt={class:"datetime"},ct={class:"info"},dt={key:0,class:"prompt mt-2"},ut={key:0},pt={key:1},mt={key:0,class:A({content:!0,failed:!0})},vt={key:0,class:"mb-4"},ft={key:1,class:A({operations:!0,"mt-2":!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},gt={key:1,class:A({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:A({content:!0})},Et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function It(e,o,v,_,k,y){const r=s("el-image"),u=s("video-player"),n=s("el-button"),V=s("el-tooltip"),T=s("api-code-button"),f=s("font-awesome-icon"),E=s("copy-to-clipboard"),C=s("el-alert");return t(),i("div",nt,[c("div",at,[a(r,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),c("div",lt,[c("div",it,[h(l(e.$t("veo.name.veoBot"))+" ",1),c("span",rt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",ct,[e.modelValue?.request?.prompt?(t(),i("p",dt,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",ut," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",pt," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",mt,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",vt,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",ft,[e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=$=>e.onPickAction($,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=$=>e.onPickAction($,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=$=>e.onPickAction($,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=$=>e.onPickAction($,e.modelValue?.response,"extend"))},{default:p(()=>[h(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=$=>e.onPickAction($,e.modelValue?.response,"reshoot"))},{default:p(()=>[h(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=$=>e.onPickAction($,e.modelValue?.response,"object_insert"))},{default:p(()=>[h(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=$=>e.onPickAction($,e.modelValue?.response,"object_remove"))},{default:p(()=>[h(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(V,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=$=>e.onDownload($,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[h(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),a(T,{path:"/veo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),a(C,{closable:!1,class:"mt-2 success"},{default:p(()=>[c("p",_t,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),c("p",ht,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",$t,[a(f,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",gt,[a(C,{closable:!1,class:"failure"},{template:p(()=>[a(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[c("p",bt,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),c("p",kt,[a(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(E,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",yt,[a(f,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",Vt,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(E,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",wt,[a(C,{closable:!1,class:"info"},{template:p(()=>[a(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[c("p",Et,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",Tt,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(E,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const St=b(st,[["render",It],["__scopeId","data-v-912779c9"]]),At=g({name:"RecentPanel",components:{TaskPreview:St,NoTasks:ge,BotPlaceholder:Ie,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ct={key:0},Pt={key:2,class:"w-full h-full flex items-center justify-center"};function Ot(e,o,v,_,k,y){const r=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),V=s("no-tasks");return t(),i(w,null,[e.tasks?.items===void 0?(t(),i("div",Ct,[a(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=T=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(w,null,S(e.tasks?.items,(T,f)=>(t(),m(u,{key:f,"model-value":T},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",Pt,[a(V)])):d("",!0)],64)}const Ut=b(At,[["render",Ot]]),Lt=Z("veo"),jt=g({name:"VeoIndex",components:{ConfigPanel:tt,Layout:Ue,RecentPanel:Ut},mixins:[me],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===R.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===R.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:_}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ve(this.uploadTracker,v=>this.$t(v),v=>I.warning(v)))return;const e={...this.config,callback_url:Lt},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),Q("veo",W.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===ke?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,o,v,_,k,y){const r=s("config-panel"),u=s("recent-panel"),n=s("layout");return t(),m(n,null,{config:p(()=>[a(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ls=b(jt,[["render",Rt]]);export{Ls as default};
|
|
1
|
+
import{F as U}from"./index.es-DFk6alzA.js";import{E as L}from"./index-2XpyGLGv.js";import{E as Y}from"./index-CLnRg-bf.js";import{d as g,H as i,E as c,z as j,C as a,y as p,D as s,q as t,F as l,O as w,N as S,x as m,Q as A,R as J,J as d,I as h}from"./vendor-vue-NSDaktjZ.js";import{H as b,bp as K,cs as Q,aK as W,S as R,ct as Z}from"./index-ChuKoOLp.js";import{a as x,b as ee,c as oe,d as te,e as se,f as ne,g as M,h as ae,i as le,j as ie}from"./veo-Dg8Zhpd-.js";import{E as P,a as O}from"./index-CCGH0otF.js";import{I as G,S as re,l as ce}from"./pagination-CKRvreU2.js";import{E as de}from"./index-BprU921G.js";import{V as D}from"./VideoPlayer-CMtYz-DY.js";import{E as N}from"./index-CJHwlDCY.js";import{p as ue}from"./pasteUploadMixin-BurWbGNQ.js";import{u as pe,a as me,e as ve}from"./uploadTrackerMixin--N-yU8Tl.js";import{I as fe}from"./ImagePreview-Bl6hkqwF.js";import{E as _e}from"./index-DBnNRQSq.js";import{E as I}from"./index-C5CJ0Euq.js";import{C as he}from"./Consumption-CUbvFAAd.js";import{P as $e,N as ge}from"./NoTasks-hJEZMzd9.js";import{a as be}from"./price-CZ_KvTOE.js";import{b as ke}from"./errorCode-Cqj9Td_Z.js";import{C as ye}from"./CopyToClipboard-q8AT00kT.js";import{A as Ve}from"./ApiCodeButton-BAAm5I15.js";import{E as we}from"./index-DmNjtF4K.js";import{E as Ee}from"./index-DcRIH5uQ.js";import{E as Te}from"./index-BZplOvWX.js";import{B as Ie}from"./BotPlaceholder-DxAlgny2.js";import"./use-form-item-BAnuDQeY.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-ZuyabccH.js";import"./typescript-CqgbTwhG.js";import"./index-cAGQ4Zgy.js";import"./strings-beZM2Y-f.js";import"./isEqual-BLkH-Pjf.js";import"./_Uint8Array-Dky9YMEI.js";import"./castArray-9UHm33vq.js";import"./debounce-D3Q18PUh.js";import"./_baseIteratee-B03IqKJU.js";import"./index-CvBbOBIO.js";import"./highlight-Cf3JCquz.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-DwtE3Sn3.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DPBhVV33.js";import"./index-CrO1zKci.js";import"./_baseClone-BcpYfRjc.js";import"./_initCloneObject-zlapHgef.js";import"./index-DNghjMst.js";const Se=g({name:"LayoutVeo",components:{ElDrawer:Y,ElButton:L,FontAwesomeIcon:U},data(){return{drawer:!1}}}),Ae={class:"main flex flex-row flex-1"},Ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Pe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Oe(e,o,v,_,k,y){const r=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return t(),i("div",Ae,[c("div",Ce,[j(e.$slots,"config",{},void 0,!0)]),c("div",Pe,[j(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=V=>e.drawer=!0)},{default:p(()=>[a(r,{icon:"fa-solid fa-magic"})]),_:1}),a(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=V=>e.drawer=V),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[j(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ue=b(Se,[["render",Oe],["__scopeId","data-v-9b26d591"]]),Le=g({name:"ModelSelector",components:{ElSelect:O,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=x)}}),je={class:"field"},Re={class:"title font-bold"};function Me(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",je,[c("h2",Re,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=b(Le,[["render",Me],["__scopeId","data-v-a59d89c9"]]),De=g({name:"ActionSelector",components:{ElSelect:O,ElOption:P},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),Ne={class:"field"},Fe={class:"title font-bold"},ze={class:"float-left"};function Be(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Ne,[c("h2",Fe,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},{default:p(()=>[c("span",ze,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const qe=b(De,[["render",Be],["__scopeId","data-v-f4d8785c"]]),He=g({name:"TranslationSelector",components:{ElSwitch:de,InfoIcon:G},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=oe)}}),Xe={class:"relative"},Ye={class:"flex justify-between"},Je={class:"flex justify-start items-center"},Ke={class:"text-sm font-bold"},Qe={class:"flex justify-end items-center"};function We(e,o,v,_,k,y){const r=s("info-icon"),u=s("el-switch");return t(),i("div",Xe,[c("div",Ye,[c("div",Je,[c("span",Ke,l(e.$t("veo.name.translation")),1),a(r,{content:e.$t("veo.description.translation")},null,8,["content"])]),c("div",Qe,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value"},null,8,["modelValue"])])])])}const Ze=b(He,[["render",We]]),xe=g({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),eo={class:"text-sm font-bold mb-2 block"},oo={class:"items"},to=["onClick"],so={class:"name"};function no(e,o,v,_,k,y){return t(),i("div",null,[c("span",eo,l(e.$t("veo.name.ratio")),1),c("div",oo,[(t(!0),i(w,null,S(e.options,(r,u)=>(t(),i("div",{key:u,class:A({active:e.active===u,item:!0}),onClick:n=>e.value=r.value},[c("div",{class:A(["preview",r.label])},[c("div",{class:"rect",style:J({width:r.width+"px",height:r.height+"px"})},null,4)],2),c("p",so,l(r.label),1)],10,to))),128))])])}const ao=b(xe,[["render",no],["__scopeId","data-v-0f16be77"]]),lo=g({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),io={class:"relative"},ro={class:"flex mb-2"},co={class:"text-sm font-bold"};function uo(e,o,v,_,k,y){const r=s("video-player");return t(),i("div",io,[c("div",ro,[c("span",co,l(e.$t("veo.name.action3")),1)]),c("div",null,[e.config?.video_url?(t(),m(r,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const po=b(lo,[["render",uo]]),mo=g({name:"VideoIdInput",components:{ElInput:N},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),vo={class:"field"},fo={class:"title font-bold"};function _o(e,o,v,_,k,y){const r=s("el-input");return t(),i("div",vo,[c("h2",fo,l(e.$t("veo.name.videoId")),1),a(r,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const ho=b(mo,[["render",_o],["__scopeId","data-v-6eba4026"]]),$o=g({name:"StartEndImage",components:{ElUpload:_e,ElButton:L,InfoIcon:G,FontAwesomeIcon:U,ImagePreview:fe},mixins:[ue,pe],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?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),go={class:"relative"},bo={class:"flex justify-between"},ko={class:"flex justify-start items-center"},yo={class:"text-sm font-bold"};function Vo(e,o,v,_,k,y){const r=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),V=s("el-button"),T=s("el-upload");return t(),i("div",go,[c("div",bo,[c("div",ko,[c("span",yo,l(e.$t("veo.name.startEndImage")),1),a(r,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a(T,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=f=>e.fileList=f),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:f})=>[f.url&&f.percentage!==void 0?(t(),m(u,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(V,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const wo=b($o,[["render",Vo],["__scopeId","data-v-f9a79b4a"]]),Eo=g({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return ne.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=se)}}),To={class:"field"},Io={class:"title font-bold"};function So(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",To,[c("h2",Io,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ao=b(Eo,[["render",So],["__scopeId","data-v-8b74a7ae"]]),Co=g({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return M.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!M.includes(this.value))&&(this.value=ae)}}),Po={class:"field"},Oo={class:"title font-bold"};function Uo(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Po,[c("h2",Oo,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Lo=b(Co,[["render",Uo],["__scopeId","data-v-cc3f9355"]]),jo=g({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:P},computed:{options(){return ie.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=le)}}),Ro={class:"field"},Mo={class:"title font-bold"};function Go(e,o,v,_,k,y){const r=s("el-option"),u=s("el-select");return t(),i("div",Ro,[c("h2",Mo,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(w,null,S(e.options,n=>(t(),m(r,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Do=b(jo,[["render",Go],["__scopeId","data-v-3affff3c"]]),No=g({name:"ImageMaskInput",components:{ElInput:N},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),Fo={class:"field"},zo={class:"title font-bold"};function Bo(e,o,v,_,k,y){const r=s("el-input");return t(),i("div",Fo,[c("h2",zo,l(e.$t("veo.name.imageMask")),1),a(r,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const qo=b(No,[["render",Bo],["__scopeId","data-v-6cc27c68"]]),Ho="",Xo=g({name:"PromptInput",components:{PromptTextarea:$e},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Ho)}});function Yo(e,o,v,_,k,y){const r=s("prompt-textarea");return t(),m(r,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=u=>e.prompt=u),title:e.$t("veo.name.prompt"),info:e.$t("veo.description.prompt"),placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Jo=b(Xo,[["render",Yo]]),Ko=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Qo=["text2video","image2video","ingredients2video"],Wo=g({name:"ConfigPanel",components:{ElButton:L,Consumption:he,FontAwesomeIcon:U,PromptInput:Jo,ModelSelector:Ge,StartEndImage:wo,ActionSelector:qe,VideoFromInput:po,VideoIdInput:ho,UpsampleActionSelector:Ao,ExtendModelSelector:Lo,MotionTypeSelector:Do,ImageMaskInput:qo,TranslationSelector:Ze,AspectRatioSelector:ao},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return be(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Ko.includes(this.config?.action??"")},isGeneration(){return Qo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Zo={class:"flex flex-col h-full"},xo={class:"flex-1 overflow-y-auto p-5"},et={class:"flex flex-col items-center justify-center px-5 pb-5"};function ot(e,o,v,_,k,y){const r=s("action-selector"),u=s("video-from-input"),n=s("video-id-input"),V=s("upsample-action-selector"),T=s("extend-model-selector"),f=s("prompt-input"),E=s("motion-type-selector"),C=s("image-mask-input"),$=s("translation-selector"),F=s("aspect-ratio-selector"),z=s("model-selector"),B=s("start-end-image"),q=s("consumption"),H=s("font-awesome-icon"),X=s("el-button");return t(),i("div",Zo,[c("div",xo,[a(r,{class:"mb-4"}),e.isPostProcessing?(t(),i(w,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(n,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(V,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(T,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(f,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(E,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(f,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(C,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(f,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(w,{key:8},[a($,{class:"mb-4"}),a(F,{class:"mb-4"}),a(f,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:0,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:1,class:"mb-2"})):d("",!0)],64)):d("",!0)]),c("div",et,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(X,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const tt=b(Wo,[["render",ot]]),st=g({name:"TaskPreview",components:{ElImage:Te,CopyToClipboard:ye,FontAwesomeIcon:U,ElAlert:Ee,VideoPlayer:D,ElTooltip:we,ElButton:L,ApiCodeButton:Ve},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,_){console.debug("seed config from preview",{action:v,upsampleAction:_,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,..._?{upsample_action:_}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),nt={class:"preview"},at={class:"left"},lt={class:"main"},it={class:"bot"},rt={class:"datetime"},ct={class:"info"},dt={key:0,class:"prompt mt-2"},ut={key:0},pt={key:1},mt={key:0,class:A({content:!0,failed:!0})},vt={key:0,class:"mb-4"},ft={key:1,class:A({operations:!0,"mt-2":!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},gt={key:1,class:A({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},wt={key:2,class:A({content:!0})},Et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function It(e,o,v,_,k,y){const r=s("el-image"),u=s("video-player"),n=s("el-button"),V=s("el-tooltip"),T=s("api-code-button"),f=s("font-awesome-icon"),E=s("copy-to-clipboard"),C=s("el-alert");return t(),i("div",nt,[c("div",at,[a(r,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),c("div",lt,[c("div",it,[h(l(e.$t("veo.name.veoBot"))+" ",1),c("span",rt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",ct,[e.modelValue?.request?.prompt?(t(),i("p",dt,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",ut," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",pt," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",mt,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",vt,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",ft,[e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=$=>e.onPickAction($,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=$=>e.onPickAction($,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=$=>e.onPickAction($,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[h(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=$=>e.onPickAction($,e.modelValue?.response,"extend"))},{default:p(()=>[h(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=$=>e.onPickAction($,e.modelValue?.response,"reshoot"))},{default:p(()=>[h(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=$=>e.onPickAction($,e.modelValue?.response,"object_insert"))},{default:p(()=>[h(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=$=>e.onPickAction($,e.modelValue?.response,"object_remove"))},{default:p(()=>[h(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(V,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=$=>e.onDownload($,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[h(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),a(T,{path:"/veo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),a(C,{closable:!1,class:"mt-2 success"},{default:p(()=>[c("p",_t,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),c("p",ht,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",$t,[a(f,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",gt,[a(C,{closable:!1,class:"failure"},{template:p(()=>[a(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[c("p",bt,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),c("p",kt,[a(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(E,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",yt,[a(f,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",Vt,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(E,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",wt,[a(C,{closable:!1,class:"info"},{template:p(()=>[a(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[c("p",Et,[a(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(E,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",Tt,[a(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(E,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const St=b(st,[["render",It],["__scopeId","data-v-912779c9"]]),At=g({name:"RecentPanel",components:{TaskPreview:St,NoTasks:ge,BotPlaceholder:Ie,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ct={key:0},Pt={key:2,class:"w-full h-full flex items-center justify-center"};function Ot(e,o,v,_,k,y){const r=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),V=s("no-tasks");return t(),i(w,null,[e.tasks?.items===void 0?(t(),i("div",Ct,[a(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=T=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(w,null,S(e.tasks?.items,(T,f)=>(t(),m(u,{key:f,"model-value":T},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",Pt,[a(V)])):d("",!0)],64)}const Ut=b(At,[["render",Ot]]),Lt=Z("veo"),jt=g({name:"VeoIndex",components:{ConfigPanel:tt,Layout:Ue,RecentPanel:Ut},mixins:[me],inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===R.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===R.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:_}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!ve(this.uploadTracker,v=>this.$t(v),v=>I.warning(v)))return;const e={...this.config,callback_url:Lt},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),Q("veo",W.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===ke?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Rt(e,o,v,_,k,y){const r=s("config-panel"),u=s("recent-panel"),n=s("layout");return t(),m(n,null,{config:p(()=>[a(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ls=b(jt,[["render",Rt]]);export{Ls as default};
|