@acedatacloud/nexior 3.225.0 → 3.226.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-C59fK0-P.js → ApiCodeButton-CkgmddPY.js} +1 -1
- package/dist/assets/{Auth-CyrcRENJ.js → Auth-h6N9ZBLa.js} +1 -1
- package/dist/assets/{BotPlaceholder-BK6VXpIO.js → BotPlaceholder-s0833dXM.js} +1 -1
- package/dist/assets/{Callback-Co9-Lr4R.js → Callback-CBljhjFT.js} +1 -1
- package/dist/assets/{Console-olrEmSva.js → Console-C3Gx64sK.js} +1 -1
- package/dist/assets/{Consumption-olJH452p.js → Consumption-DJb3Zq85.js} +1 -1
- package/dist/assets/{Conversation--JeO8hRF.js → Conversation-VkhRa_B5.js} +1 -1
- package/dist/assets/{CopyToClipboard-DPa3E4GR.js → CopyToClipboard-DszAErjC.js} +1 -1
- package/dist/assets/{Detail-CrETJzMz.js → Detail-DbXyKJAH.js} +2 -2
- package/dist/assets/{Extra-BCrfx-lR.js → Extra-D4S1pWsZ.js} +1 -1
- package/dist/assets/{FilePreview-D8mwFfzd.js → FilePreview-a5f4UpE6.js} +1 -1
- package/dist/assets/{Hailuo-DiPlgsJB.js → Hailuo-7_9fVHuN.js} +1 -1
- package/dist/assets/{History-0i248U-6.js → History-eaRwqJ8v.js} +1 -1
- package/dist/assets/{ImagePreview-B3CWsVuY.js → ImagePreview-BKqMFwxZ.js} +1 -1
- package/dist/assets/{ImageWrapper-MfEE4bKQ.js → ImageWrapper-Dm7-bIgX.js} +1 -1
- package/dist/assets/{Index-shirfbqq.js → Index-B5XRCe1Z.js} +1 -1
- package/dist/assets/Index-BBK-7Gmo.js +1 -0
- package/dist/assets/{Index-BKW4nrmZ.js → Index-BMdIXpA_.js} +1 -1
- package/dist/assets/{Index-sddGgsl9.js → Index-BN47fdme.js} +1 -1
- package/dist/assets/{Index-DL1iFFh2.css → Index-B_HRzev8.css} +1 -1
- package/dist/assets/{Index-B8OGu3rd.js → Index-BdqobCHx.js} +1 -1
- package/dist/assets/{Index-WM-d1CfM.js → Index-BjzdB6YT.js} +1 -1
- package/dist/assets/{Index-x0hEKfzU.js → Index-BlEHXaM6.js} +1 -1
- package/dist/assets/{Index-DkspKPmA.js → Index-Bmxbl7BK.js} +1 -1
- package/dist/assets/{Index-C74if5I3.js → Index-C3P5HTF4.js} +1 -1
- package/dist/assets/{Index-D7k_csx_.js → Index-C3w9Wt7D.js} +1 -1
- package/dist/assets/{Index-CSFv34ZI.js → Index-C7QvtYVG.js} +1 -1
- package/dist/assets/{Index-NHhtOaq6.js → Index-C7crVbxy.js} +1 -1
- package/dist/assets/{Index-DalgeRFO.js → Index-C91R35lY.js} +1 -1
- package/dist/assets/{Index-CM69DLjF.js → Index-CV0ESyQJ.js} +1 -1
- package/dist/assets/{Index-B5wEmueC.js → Index-CZePZ_IQ.js} +1 -1
- package/dist/assets/{Index-BQlLFswn.js → Index-CiesuReN.js} +1 -1
- package/dist/assets/{Index-CYwNFvPT.js → Index-CsPREH2f.js} +1 -1
- package/dist/assets/{Index-lGvoEMcs.js → Index-DHrvjqNq.js} +1 -1
- package/dist/assets/{Index-DIPg5-ws.js → Index-GtfMoPB3.js} +1 -1
- package/dist/assets/{Index-CFk67SKU.js → Index-Lhvb0cWT.js} +1 -1
- package/dist/assets/{Index-COpfpXVh.js → Index-Sx6KWAO1.js} +1 -1
- package/dist/assets/{Index-gX9AsWI5.js → Index-VQEB0VqM.js} +1 -1
- package/dist/assets/{Index-2aRnbPfh.js → Index-kAbxiEc3.js} +1 -1
- package/dist/assets/{Index-CR31MKN4.js → Index-xxk4WFkB.js} +1 -1
- package/dist/assets/{Index-Cl8WyhJI.js → Index-zRRlcw_e.js} +1 -1
- package/dist/assets/{Invitees-ByQWni_g.js → Invitees-RYbo2VU4.js} +1 -1
- package/dist/assets/{List-DiNkI61Z.js → List-CB7EaiaU.js} +1 -1
- package/dist/assets/{List-B6RGFrFP.js → List-CaodU12c.js} +1 -1
- package/dist/assets/{List-B3ExlO5a.js → List-CsTbqM1W.js} +1 -1
- package/dist/assets/{Main-BS3KFbr4.js → Main-SUKzn9hJ.js} +1 -1
- package/dist/assets/{Model-CpJG_oaF.js → Model-kxF-TnJ5.js} +1 -1
- package/dist/assets/{Navigator-CO_ymsoD.js → Navigator-CQol9KTQ.js} +1 -1
- package/dist/assets/{NoTasks-meE6rr3b.js → NoTasks-CF8uilN4.js} +1 -1
- package/dist/assets/{NotFound-NmY0cuoy.js → NotFound-DThEOiTU.js} +1 -1
- package/dist/assets/{Pagination-iXfEJA33.js → Pagination-9j7qKAkP.js} +1 -1
- package/dist/assets/{Player.vue_vue_type_script_setup_true_lang-CAm3pKds.js → Player.vue_vue_type_script_setup_true_lang-Dr6DTJzX.js} +1 -1
- package/dist/assets/{Status-0jDN6xl7.js → Status-C5w4Q0oa.js} +1 -1
- package/dist/assets/{Subscribe-CpQxYv-b.js → Subscribe-Cd3WyZRx.js} +1 -1
- package/dist/assets/{TabSwitcher-DHLOEqPP.js → TabSwitcher-CMJn8pSW.js} +1 -1
- package/dist/assets/{Tts-C0KYiTwW.js → Tts-C5YaVQGT.js} +1 -1
- package/dist/assets/{VideoPlayer-CLOYjGw9.js → VideoPlayer-B8hJJa4d.js} +1 -1
- package/dist/assets/{_Uint8Array-CAXQwVOS.js → _Uint8Array-dMcWmqZF.js} +1 -1
- package/dist/assets/{_baseClone-DXPY_NNj.js → _baseClone-DZKAu36s.js} +1 -1
- package/dist/assets/{_baseIteratee-EfYP4TWi.js → _baseIteratee-DulLK_c3.js} +1 -1
- package/dist/assets/{_initCloneObject-DTxX8SUA.js → _initCloneObject-BsCXP6pc.js} +1 -1
- package/dist/assets/{add-D__2y_a0.js → add-OK5omDua.js} +1 -1
- package/dist/assets/{all-wallets-BzS0eIzM.js → all-wallets-CjApRqmW.js} +1 -1
- package/dist/assets/{app-store-BqH8rlu1.js → app-store-C6UG4O4e.js} +1 -1
- package/dist/assets/{apple-WT3iT0dN.js → apple-CG_jtKa2.js} +1 -1
- package/dist/assets/{arrow-bottom-9k4opqGy.js → arrow-bottom-B72K2hir.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-D0_OjvJt.js → arrow-bottom-circle-CWG-67_c.js} +1 -1
- package/dist/assets/{arrow-left-DndNB8V8.js → arrow-left-Dcoju2q0.js} +1 -1
- package/dist/assets/{arrow-right-CFrutH0W.js → arrow-right-Bqsdjmh5.js} +1 -1
- package/dist/assets/{arrow-top-pYitlwov.js → arrow-top-CQCwB1lL.js} +1 -1
- package/dist/assets/{avatar-dgRuv65G.js → avatar-CHqoyrR3.js} +1 -1
- package/dist/assets/{bank-BuMDFrcN.js → bank-CF2CeVja.js} +1 -1
- package/dist/assets/{basic-DJU8UKid.js → basic-BWq3gIe_.js} +1 -1
- package/dist/assets/{browser-KHpCjmQu.js → browser-CeaXvNbh.js} +1 -1
- package/dist/assets/{byokCredential-C8IDwxHf.js → byokCredential-BTtsKkzK.js} +1 -1
- package/dist/assets/{card-PC3gpuXz.js → card-DRrDQ1qB.js} +1 -1
- package/dist/assets/{castArray-o97GVNr8.js → castArray-mD4k-COw.js} +1 -1
- package/dist/assets/{chat-DlR0Uut1.js → chat-D8tvhnLb.js} +1 -1
- package/dist/assets/{checkmark-BzG8OKZO.js → checkmark-B6Coes2-.js} +1 -1
- package/dist/assets/{checkmark-bold-v6TNk-cx.js → checkmark-bold-BBu5bhvD.js} +1 -1
- package/dist/assets/{chevron-bottom-B3vEsvP_.js → chevron-bottom-BPFNICeS.js} +1 -1
- package/dist/assets/{chevron-left-iURqOOsR.js → chevron-left-BTT7SFx_.js} +1 -1
- package/dist/assets/{chevron-right-DDXOk5bu.js → chevron-right-CvI5EckA.js} +1 -1
- package/dist/assets/{chevron-top-CMJ0jSGJ.js → chevron-top-Bo-El6aA.js} +1 -1
- package/dist/assets/{chrome-store-BIK8-UlX.js → chrome-store-Blv8sYWJ.js} +1 -1
- package/dist/assets/{clock-JcoTF8Gl.js → clock-VULWe8YY.js} +1 -1
- package/dist/assets/{close-D_THt0FH.js → close-BqPbfYQc.js} +1 -1
- package/dist/assets/{coinPlaceholder-DryitdL-.js → coinPlaceholder-DUvhzWm6.js} +1 -1
- package/dist/assets/{compass-D0TzSIbF.js → compass-D6-ogJsk.js} +1 -1
- package/dist/assets/{copy-DCOuabHl.js → copy-BW_CcWuQ.js} +1 -1
- package/dist/assets/{createTaskActions-ozwbPA56.js → createTaskActions-seQCbTL5.js} +1 -1
- package/dist/assets/{cursor-Tw_3lQgl.js → cursor-7DwZX_h1.js} +1 -1
- package/dist/assets/{cursor-transparent-DIjznPBg.js → cursor-transparent-CFtJpuus.js} +1 -1
- package/dist/assets/{debounce-IGDjJ0RI.js → debounce-fzRpYvTx.js} +1 -1
- package/dist/assets/{desktop-DFZge7Yd.js → desktop-BvqKJf7a.js} +1 -1
- package/dist/assets/{disconnect-k9rkd7r1.js → disconnect-Dh2Q9ng4.js} +1 -1
- package/dist/assets/{discord-BmAewmdf.js → discord-BPu8g7y2.js} +1 -1
- package/dist/assets/{distribution-B7FY0HHM.js → distribution-fRp0VqRq.js} +1 -1
- package/dist/assets/{dropdown-Daxyy0Df.js → dropdown-D5iOHOWU.js} +1 -1
- package/dist/assets/{etherscan-BtpA_WC4.js → etherscan-DzgI5dld.js} +1 -1
- package/dist/assets/{exclamation-triangle-Bj7UC9JR.js → exclamation-triangle-D-hBr5tG.js} +1 -1
- package/dist/assets/{extension--6oWj6gp.js → extension-BhavRvMH.js} +1 -1
- package/dist/assets/{external-link-DfmnAjPq.js → external-link-DssR47MQ.js} +1 -1
- package/dist/assets/{facebook-BkiEdXK2.js → facebook-CrLMT2p8.js} +1 -1
- package/dist/assets/{farcaster-BQxJUITq.js → farcaster-MMwu0mgx.js} +1 -1
- package/dist/assets/{filters-CAZ3PXc8.js → filters-BnFMxhRF.js} +1 -1
- package/dist/assets/{github-DC82lJ5_.js → github-DRkAaKu8.js} +1 -1
- package/dist/assets/{google-5243kPqK.js → google-ibbI_oFU.js} +1 -1
- package/dist/assets/{help-circle-CRSOaP-6.js → help-circle-CNZ1Z9lT.js} +1 -1
- package/dist/assets/{highlight-BJauIwLT.js → highlight-DcfXaBeC.js} +1 -1
- package/dist/assets/{id-9bntkE-A.js → id-6UboB5fw.js} +1 -1
- package/dist/assets/{image-DbyZcqq1.js → image-MEKK89Qk.js} +1 -1
- package/dist/assets/{index-DEQaBtZM.js → index--96oDgPk.js} +1 -1
- package/dist/assets/{index-CkvYcCVd.js → index-B0tmHD6W.js} +1 -1
- package/dist/assets/{index-I8l3O3OX.js → index-B12SAORZ.js} +1 -1
- package/dist/assets/{index-QRYRN0ui.js → index-B5MFdHEY.js} +1 -1
- package/dist/assets/{index-BWtJnB9K.js → index-B8AvA8w1.js} +1 -1
- package/dist/assets/{index-Bmn8GWA1.js → index-BCk0BbjD.js} +1 -1
- package/dist/assets/{index-k_xr2erY.js → index-BO1HJuEm.js} +2 -2
- package/dist/assets/{index-HpTopfFP.js → index-BPUUia6V.js} +1 -1
- package/dist/assets/{index-BHm7N755.js → index-BSglm0Mh.js} +1 -1
- package/dist/assets/{index-D2zHY5lR.js → index-BUr6thfj.js} +1 -1
- package/dist/assets/{index-CJJXga6X.js → index-BVkFwr_L.js} +1 -1
- package/dist/assets/{index-ME-HdiZk.js → index-BVxZYnz6.js} +1 -1
- package/dist/assets/{index-CKLmaP2G.js → index-BWmAvPe7.js} +1 -1
- package/dist/assets/{index-DeuMw1Tc.js → index-BZTL3ViV.js} +1 -1
- package/dist/assets/{index-XtHvjDW3.js → index-B_eA3JZ6.js} +1 -1
- package/dist/assets/{index-DCDqia7V.js → index-BdD8t8Dh.js} +1 -1
- package/dist/assets/{index-CV-Q_DwW.js → index-BfwtSiqw.js} +1 -1
- package/dist/assets/{index-DWVFEiyY.js → index-BjOiLYfa.js} +1 -1
- package/dist/assets/{index-ClmKXcwE.js → index-Blt2Omu9.js} +1 -1
- package/dist/assets/{index-LgbvqD9M.js → index-BmldmpJ7.js} +1 -1
- package/dist/assets/{index-CceiNluP.js → index-BmpASoJL.js} +1 -1
- package/dist/assets/{index-50Arx2ay.js → index-BqV7Dywc.js} +1 -1
- package/dist/assets/{index-8hlUVWNm.js → index-Brl0omIh.js} +1 -1
- package/dist/assets/{index-B0qFYAzt.js → index-Bumd8iDl.js} +1 -1
- package/dist/assets/{index-D7wuMQid.js → index-BzL62eR-.js} +1 -1
- package/dist/assets/{index-Bc9dpXO-.js → index-C-pA8pQB.js} +1 -1
- package/dist/assets/{index-CMd2QQE1.js → index-C944EN_X.js} +1 -1
- package/dist/assets/{index-BLcUi3xb.js → index-CAPDePb0.js} +1 -1
- package/dist/assets/{index-CPXG2GVO.js → index-CBGglJJ1.js} +1 -1
- package/dist/assets/{index-i4bsFS5I.js → index-CDRJgwze.js} +1 -1
- package/dist/assets/{index-DLGqTrwL.js → index-CExb-pgq.js} +1 -1
- package/dist/assets/{index-BDXoTT3-.js → index-CFGOjnwV.js} +1 -1
- package/dist/assets/{index-CX2xzF7l.js → index-CFGrrV17.js} +1 -1
- package/dist/assets/{index-BpfnbqLy.js → index-CGFTjr4j.js} +1 -1
- package/dist/assets/{index-Dw5_Z8kM.js → index-CKC1QXPY.js} +1 -1
- package/dist/assets/{index-DMsm9lCV.js → index-CTe-d_6k.js} +1 -1
- package/dist/assets/{index-BXR7JsFG.js → index-CV3Lmk-s.js} +1 -1
- package/dist/assets/{index-BuJDkS44.js → index-CX3Kkhe8.js} +3 -3
- package/dist/assets/{index-CcjyG_wx.js → index-CaN8MHgO.js} +1 -1
- package/dist/assets/{index-CZtLoeIX.js → index-Ck2lWPQ8.js} +1 -1
- package/dist/assets/{index-BcuZ_JXH.js → index-CkzdWDJ8.js} +1 -1
- package/dist/assets/{index-CTCGc3EE.js → index-ClLWFUWe.js} +1 -1
- package/dist/assets/{index-Bpp-Zg7l.js → index-CmJMSATA.js} +1 -1
- package/dist/assets/{index-DPEN1Y3h.js → index-Cp-N3Z9d.js} +3 -3
- package/dist/assets/{index-B3GFjuLg.js → index-CrIxCDkE.js} +1 -1
- package/dist/assets/{index-CJKUHGiZ.js → index-Cw2jO3EU.js} +5 -5
- package/dist/assets/{index-CyudTOvt.js → index-CxCN6BXU.js} +1 -1
- package/dist/assets/{index-BWQMUW5b.js → index-CzmKNTJj.js} +1 -1
- package/dist/assets/{index-CPXiJxKP.js → index-D8d_EiGA.js} +1 -1
- package/dist/assets/{index-BX1OoJEA.js → index-D9BkjAHP.js} +1 -1
- package/dist/assets/{index-xisvXfSG.js → index-DG0OeiDu.js} +1 -1
- package/dist/assets/{index-DH4oTCmN.js → index-DQOSv-tV.js} +1 -1
- package/dist/assets/{index-jdYLby1m.js → index-DTbR5rAQ.js} +1 -1
- package/dist/assets/{index-CYyaAJO7.js → index-Db9d2-xc.js} +1 -1
- package/dist/assets/{index-DqL4me50.js → index-Dj3DVAp3.js} +1 -1
- package/dist/assets/{index-DQnJtR-Z.js → index-DyfY2E-a.js} +1 -1
- package/dist/assets/{index-BAPAp6Xb.js → index-TJBAFmkH.js} +1 -1
- package/dist/assets/{index-DB1TcDoe.js → index-_S-XXu4O.js} +1 -1
- package/dist/assets/{index-CxO1W3WZ.js → index-fe6CHwgM.js} +1 -1
- package/dist/assets/{index-DoMkV5cd.js → index-jB6V2dn5.js} +1 -1
- package/dist/assets/{index-DSijVGKp.js → index-tO5MdGXt.js} +1 -1
- package/dist/assets/{index-C8gAt9te.js → index-vvF0hkxw.js} +1 -1
- package/dist/assets/{index-D5Azrgpl.js → index-wJ-tzrqi.js} +1 -1
- package/dist/assets/{index.browser.esm-BVds7Smh.js → index.browser.esm-B_LBdNY3.js} +1 -1
- package/dist/assets/{index.es-BXqpwkqA.js → index.es-C8TbH2BC.js} +1 -1
- package/dist/assets/{info-IdxmaHlX.js → info-B1ux_wtz.js} +1 -1
- package/dist/assets/{info-circle-CgyMuK-L.js → info-circle-CgDobzgc.js} +1 -1
- package/dist/assets/{isEqual-Am6JmVzR.js → isEqual-C_dkvvUP.js} +1 -1
- package/dist/assets/{isPlainObject-DY55rAte.js → isPlainObject-aPqrRKoh.js} +1 -1
- package/dist/assets/{lightbulb-D8dB-3hN.js → lightbulb-CVjEyGlE.js} +1 -1
- package/dist/assets/{mail-DtbowEzX.js → mail-DVy_KzuR.js} +1 -1
- package/dist/assets/{midjourney-CHJALNqQ.js → midjourney-Dtb1E59V.js} +1 -1
- package/dist/assets/{mobile-Be7vQBFX.js → mobile-FjF3Gva8.js} +1 -1
- package/dist/assets/{more-BlLmPymz.js → more-wf3KVvjR.js} +1 -1
- package/dist/assets/{network-placeholder-BmRaaZ_I.js → network-placeholder-C2sz0QQ2.js} +1 -1
- package/dist/assets/{nftPlaceholder-DVcN7OmR.js → nftPlaceholder-Dkp0hc8o.js} +1 -1
- package/dist/assets/{off-Xwm00zSV.js → off-BWK3JRS0.js} +1 -1
- package/dist/assets/{order-CC9WxENJ.js → order-C31aVuXe.js} +1 -1
- package/dist/assets/{pagination-Bukm0OON.js → pagination-BCfNKuC9.js} +1 -1
- package/dist/assets/{play-store-DcONT-21.js → play-store-DKZ4ZOrX.js} +1 -1
- package/dist/assets/{plus-QbJjX-W7.js → plus-DBGuMj_H.js} +1 -1
- package/dist/assets/{price-CulrpxQT.js → price-DyHd8y4L.js} +1 -1
- package/dist/assets/{producer-CCZ47VBZ.js → producer-0q8zUaf1.js} +1 -1
- package/dist/assets/{qr-code-FtHK_Ozv.js → qr-code-C2pCAFPz.js} +1 -1
- package/dist/assets/{recycle-horizontal-BxERXpb8.js → recycle-horizontal-C9PvqW6l.js} +1 -1
- package/dist/assets/{refresh-BLbhqEkO.js → refresh-Br0-WzNx.js} +1 -1
- package/dist/assets/{reown-logo-DzfmLvsD.js → reown-logo-DRj9OW9L.js} +1 -1
- package/dist/assets/{search-DM_z6Y6U.js → search-DLfv3qqA.js} +1 -1
- package/dist/assets/{secp256k1-qf8lNpvg.js → secp256k1-BBUihW2V.js} +1 -1
- package/dist/assets/{secp256k1-uDMcOQ8E.js → secp256k1-kqqZ93NX.js} +1 -1
- package/dist/assets/{seedream-DjxOVK9a.js → seedream-DHwGPmgg.js} +1 -1
- package/dist/assets/{send-CPhKPN1L.js → send-B6YM2TSM.js} +1 -1
- package/dist/assets/{service-J6QvMukD.js → service-9zs_eBMA.js} +1 -1
- package/dist/assets/{solana-wallets-FOuWDYUF.js → solana-wallets-BaFEWG8a.js} +2 -2
- package/dist/assets/{solana-wallets-vue-eAUJubbz.js → solana-wallets-vue-OtEurO24.js} +1 -1
- package/dist/assets/{suno-BqNSEL0s.js → suno-VziWUZTH.js} +1 -1
- package/dist/assets/{swapHorizontal-CNEOnxCj.js → swapHorizontal-DNcXNhot.js} +1 -1
- package/dist/assets/{swapHorizontalBold-D2zHrMdq.js → swapHorizontalBold-DR-cWctN.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-ClWPKnEb.js → swapHorizontalMedium-BNAr8hX2.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-BkvDK1mp.js → swapHorizontalRoundedBold-TbVsceyO.js} +1 -1
- package/dist/assets/{swapVertical-CFZd4YAG.js → swapVertical-yaS8u3rQ.js} +1 -1
- package/dist/assets/{telegram-B5iEOnPR.js → telegram-Be8gzftz.js} +1 -1
- package/dist/assets/{three-dots-oFQkeEi_.js → three-dots-BKDwVwYA.js} +1 -1
- package/dist/assets/{twitch-DvRJRGIN.js → twitch-DvKIwM9A.js} +1 -1
- package/dist/assets/{twitterIcon-DqudWPBL.js → twitterIcon-CINC1tDw.js} +1 -1
- package/dist/assets/{typescript-f8CZHruo.js → typescript-Jtl3VF26.js} +1 -1
- package/dist/assets/{use-form-item-C0sdV2df.js → use-form-item-DLYZ0lkO.js} +1 -1
- package/dist/assets/validator-Dc1F-Mud.js +1 -0
- package/dist/assets/{verify-filled-CoL2Iugt.js → verify-filled-BdtgzMA7.js} +1 -1
- package/dist/assets/{verify-Ph3FXGkV.js → verify-nfw-ePqu.js} +1 -1
- package/dist/assets/{w3m-modal-DCHTKC6W.js → w3m-modal-Df6DCh_B.js} +1 -1
- package/dist/assets/{wallet-DRLrkXzG.js → wallet-DDr071PN.js} +1 -1
- package/dist/assets/{wallet-placeholder-cu0GqAJd.js → wallet-placeholder-BQslLVSg.js} +1 -1
- package/dist/assets/{walletconnect-DjID6M-B.js → walletconnect-os1bgmov.js} +1 -1
- package/dist/assets/{warning-circle-Cm3XJpTh.js → warning-circle-Ct3mqoi0.js} +1 -1
- package/dist/assets/{web-BltAvq_P.js → web-Zfo0kRRf.js} +1 -1
- package/dist/assets/{web-BuD7kFZ0.js → web-y3KukLeU.js} +1 -1
- package/dist/assets/{x-Duex3BX3.js → x-CKSlPvr_.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Index-jWyuWnEo.js +0 -1
- package/dist/assets/validator-aW0kNVIp.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as A}from"./index.es-BXqpwkqA.js";import{E as L}from"./index-CJJXga6X.js";import{E as O}from"./index-BHm7N755.js";import{d as g,H as l,E as r,z as R,C as t,y as m,D as s,q as a,F as n,O as S,N as C,x as w,I as _,J as h,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as $,bp as B,cs as j,aG as F,o as N,S as P,ct as z}from"./index-BuJDkS44.js";import{a as K,b as H,c as J}from"./pika-DpzVVVef.js";import{I as G,S as Q,l as W}from"./pagination-Bukm0OON.js";import{E as X}from"./index-QRYRN0ui.js";import{E as D,a as M}from"./index-CyudTOvt.js";import{a as Y,E as Z}from"./index-BcuZ_JXH.js";import{p as x}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ee}from"./ImagePreview-B3CWsVuY.js";import{E as te}from"./index-CPXiJxKP.js";import{E as V}from"./index-CPXG2GVO.js";import{P as oe,N as se}from"./NoTasks-meE6rr3b.js";import{C as ae}from"./Consumption-olJH452p.js";import{a as ne}from"./price-CulrpxQT.js";import{b as ie,a as le}from"./errorCode-Cqj9Td_Z.js";import{C as re}from"./CopyToClipboard-DPa3E4GR.js";import{s as ce}from"./vue-plyr-BO2nlN4c.js";import{A as pe}from"./ApiCodeButton-C59fK0-P.js";import{E as de}from"./index-Dw5_Z8kM.js";import{E as ue}from"./index-DMsm9lCV.js";import{E as me}from"./index-DH4oTCmN.js";import{B as fe}from"./BotPlaceholder-BK6VXpIO.js";import"./use-form-item-C0sdV2df.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-BJauIwLT.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-aW0kNVIp.js";import"./index-I8l3O3OX.js";import"./index-HpTopfFP.js";import"./typescript-f8CZHruo.js";import"./strings-beZM2Y-f.js";import"./isEqual-Am6JmVzR.js";import"./_Uint8Array-CAXQwVOS.js";import"./castArray-o97GVNr8.js";import"./index-CV-Q_DwW.js";import"./index-DSijVGKp.js";import"./debounce-IGDjJ0RI.js";import"./_baseIteratee-EfYP4TWi.js";import"./index-B0qFYAzt.js";import"./index-CkvYcCVd.js";import"./_baseClone-DXPY_NNj.js";import"./_initCloneObject-DTxX8SUA.js";import"./index-BAPAp6Xb.js";const _e=g({name:"LayoutPika",components:{ElDrawer:O,ElButton:L,FontAwesomeIcon:A},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 ke(e,o,c,d,k,v){const p=s("font-awesome-icon"),f=s("el-button"),i=s("el-drawer");return a(),l("div",he,[r("div",ge,[R(e.$slots,"config",{},void 0,!0)]),r("div",$e,[R(e.$slots,"result",{},void 0,!0)]),t(f,{circle:"",class:"menu",onClick:o[0]||(o[0]=b=>e.drawer=!0)},{default:m(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(i,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=$(_e,[["render",ke],["__scopeId","data-v-10596416"]]),be=g({name:"IngredientsSelector",components:{ElSwitch:X,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=K)}}),ye={class:"field"},we={class:"title font-bold"};function Ve(e,o,c,d,k,v){const p=s("el-switch"),f=s("info-icon");return a(),l("div",ye,[r("h2",we,n(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value"},null,8,["modelValue"]),t(f,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const Ee=$(be,[["render",Ve],["__scopeId","data-v-17c0af5c"]]),Ie=g({name:"EffectSelector",components:{ElSelect:M,ElOption:D},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),Se={class:"field"},Te={class:"title font-bold"},Ce={class:"float-left"};function Pe(e,o,c,d,k,v){const p=s("el-option"),f=s("el-select");return a(),l("div",Se,[r("h2",Te,n(e.$t("pika.name.effect")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.label,value:i.value},{default:m(()=>[r("span",Ce,n(i.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ae=$(Ie,[["render",Pe],["__scopeId","data-v-d1c54475"]]),Le=g({name:"IngredientsModelSelector",components:{ElRadioButton:Z,ElRadioGroup:Y},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=H)}}),Ue={class:"field"},Re={class:"title font-bold"};function Ge(e,o,c,d,k,v){const p=s("el-radio-button"),f=s("el-radio-group");return a(),l("div",Ue,[r("h2",Re,n(e.$t("pika.name.ingredientsModel")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"quality"},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.value},{default:m(()=>[_(n(i.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const De=$(Le,[["render",Ge],["__scopeId","data-v-b72865fa"]]),Me=g({name:"ModelSelector",components:{ElSelect:M,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=J)}}),qe={class:"field"},Oe={class:"title font-bold"};function Be(e,o,c,d,k,v){const p=s("el-option"),f=s("el-select");return a(),l("div",qe,[r("h2",Oe,n(e.$t("pika.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.label,value:i.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const je=$(Me,[["render",Be],["__scopeId","data-v-7b2e870a"]]),Fe=g({name:"ImageUrlInput",components:{ElUpload:te,ElButton:L,InfoIcon:G,ImagePreview:ee,FontAwesomeIcon:A},mixins:[x],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Ne={class:"field"},ze={class:"title font-bold"},Ke={class:"upload-wrapper"};function He(e,o,c,d,k,v){const p=s("image-preview"),f=s("font-awesome-icon"),i=s("el-button"),b=s("el-upload"),E=s("info-icon");return a(),l("div",Ne,[r("h2",ze,n(e.$t("pika.name.imageUrl")),1),r("div",Ke,[t(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:u})=>[t(p,{url:u.url||u.response?.file_url,name:u.name,percentage:u.percentage,onRemove:I=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])]),default:m(()=>[t(i,{size:"small",type:"primary",round:""},{default:m(()=>[t(f,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+n(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(E,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Je=$(Fe,[["render",He],["__scopeId","data-v-a948772f"]]),Qe="",We=g({name:"PromptInput",components:{PromptTextarea:oe},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Qe)}});function Xe(e,o,c,d,k,v){const p=s("prompt-textarea");return a(),w(p,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=f=>e.prompt=f),title:e.$t("pika.name.prompt"),info:e.$t("pika.description.prompt"),placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ye=$(We,[["render",Xe]]),Ze=g({name:"PresetPanel",components:{ImageUrlInput:Je,ElButton:L,FontAwesomeIcon:A,Consumption:ae,PromptInput:Ye,IngredientsSelector:Ee,IngredientsModelSelector:De,ModelSelector:je,EffectSelector:Ae},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),xe={class:"flex flex-col h-full"},et={class:"flex-1 overflow-y-auto p-5"},tt={class:"flex flex-col items-center justify-center px-5 pb-5"};function ot(e,o,c,d,k,v){const p=s("prompt-input"),f=s("model-selector"),i=s("ingredients-selector"),b=s("effect-selector"),E=s("image-url-input"),u=s("ingredients-model-selector"),I=s("consumption"),T=s("font-awesome-icon"),y=s("el-button");return a(),l("div",xe,[r("div",et,[t(p,{class:"mb-4"}),t(f,{class:"mb-4"}),t(i,{class:"mb-4"}),t(b,{class:"mb-4"}),e.config?.ingredients?(a(),w(E,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),w(u,{key:1,class:"mb-4"})):h("",!0)]),r("div",tt,[t(I,{value:e.consumption,service:e.service},null,8,["value","service"]),t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const st=$(Ze,[["render",ot]]),at=g({name:"VideoPlayer",components:{VuePlyr:ce},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),nt=["data-poster"],it=["src"];function lt(e,o,c,d,k,v){const p=s("vue-plyr");return a(),l("div",null,[t(p,{options:e.options,class:"video"},{default:m(()=>[r("video",{controls:"",playsinline:"",preload:"metadata","data-poster":e.modelValue?.image_url},[r("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,it)],8,nt)]),_:1},8,["options"])])}const rt=$(at,[["render",lt],["__scopeId","data-v-897d9fe0"]]),ct=g({name:"TaskPreview",components:{ElImage:me,CopyToClipboard:re,FontAwesomeIcon:A,ElAlert:ue,VideoPlayer:rt,ElTooltip:de,ElButton:L,ApiCodeButton:pe},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(c=>{let d=c;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,c=new URL(o.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),pt={class:"left"},dt={class:"main"},ut={class:"bot"},mt={class:"datetime"},ft={class:"info"},_t={key:0,class:"prompt mt-2"},ht={key:0},gt={key:1},$t={key:0,class:U({content:!0,failed:!0})},kt={class:"image-wrapper"},vt={key:0,class:U({operations:!0,"mt-2":!0})},bt={key:0,class:"description"},yt={class:"description"},wt={key:1,class:"description"},Vt={key:1,class:U({content:!0})},Et={class:"description"},It={class:"description"},St={key:0,class:"description"},Tt={class:"description"},Ct={key:2,class:U({content:!0})},Pt={class:"description"};function At(e,o,c,d,k,v){const p=s("el-image"),f=s("VideoPlayer"),i=s("el-button"),b=s("el-tooltip"),E=s("api-code-button"),u=s("font-awesome-icon"),I=s("copy-to-clipboard"),T=s("el-alert");return a(!0),l(S,null,C(e.videos,(y,q)=>(a(),l("div",{key:q,class:"preview"},[r("div",pt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),r("div",dt,[r("div",ut,[_(n(e.$t("pika.name.pikaBot"))+" ",1),r("span",mt,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",ft,[e.modelValue?.request?.prompt?(a(),l("p",_t,[_(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),l("span",ht," - ("+n(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"?(a(),l("span",gt," - ("+n(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",$t,[r("div",kt,[t(f,{"model-value":y},null,8,["model-value"])]),y?(a(),l("div",vt,[t(b,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),w(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:jt=>e.onDownload(y?.video_url)},{default:m(()=>[_(n(e.$t("pika.button.download")),1)]),_:1},8,["onClick"])):h("",!0)]),_:2},1032,["content"]),t(E,{path:"/pika/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[e.modelValue?.request?.model?(a(),l("p",bt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.model"))+": "+n(e.modelValue?.request?.model),1)])):h("",!0),r("p",yt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",wt,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),l("div",Vt,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[r("p",Et,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),r("p",It,[t(u,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("pika.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(I,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",St,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),r("p",Tt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(I,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),l("div",Ct,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[r("p",Pt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const Lt=$(ct,[["render",At],["__scopeId","data-v-86bc86fb"]]),Ut=g({name:"RecentPanel",components:{TaskPreview:Lt,BotPlaceholder:fe,NoTasks:se,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Rt={key:0},Gt={key:2,class:"w-full h-full flex items-center justify-center"};function Dt(e,o,c,d,k,v){const p=s("bot-placeholder"),f=s("task-preview"),i=s("scroll-list"),b=s("no-tasks");return a(),l(S,null,[e.tasks?.items===void 0?(a(),l("div",Rt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=E=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),l(S,null,C(e.tasks?.items,(E,u)=>(a(),w(f,{key:u,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),l("div",Gt,[t(b)])):h("",!0)],64)}const Mt=$(Ut,[["render",Dt]]),qt=z("pika"),Ot=g({name:"PikaIndex",components:{ConfigPanel:st,Layout:ve,RecentPanel:Mt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===P.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await W({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){N.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===le&&V.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:qt},o=this.credential?.token;if(!o){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),j("pika",F.generate(e,{token:o})).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===ie?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Bt(e,o,c,d,k,v){const p=s("config-panel"),f=s("recent-panel"),i=s("layout");return a(),w(i,null,{config:m(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Oo=$(Ot,[["render",Bt],["__scopeId","data-v-3cd7cf5b"]]);export{Oo as default};
|
|
1
|
+
import{F as A}from"./index.es-C8TbH2BC.js";import{E as L}from"./index-BVkFwr_L.js";import{E as O}from"./index-BSglm0Mh.js";import{d as g,H as l,E as r,z as R,C as t,y as m,D as s,q as a,F as n,O as S,N as C,x as w,I as _,J as h,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as $,bp as B,cs as j,aG as F,o as N,S as P,ct as z}from"./index-CX3Kkhe8.js";import{a as K,b as H,c as J}from"./pika-DpzVVVef.js";import{I as G,S as Q,l as W}from"./pagination-BCfNKuC9.js";import{E as X}from"./index-B5MFdHEY.js";import{E as D,a as M}from"./index-CxCN6BXU.js";import{a as Y,E as Z}from"./index-CkzdWDJ8.js";import{p as x}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ee}from"./ImagePreview-BKqMFwxZ.js";import{E as te}from"./index-D8d_EiGA.js";import{E as V}from"./index-CBGglJJ1.js";import{P as oe,N as se}from"./NoTasks-CF8uilN4.js";import{C as ae}from"./Consumption-DJb3Zq85.js";import{a as ne}from"./price-DyHd8y4L.js";import{b as ie,a as le}from"./errorCode-Cqj9Td_Z.js";import{C as re}from"./CopyToClipboard-DszAErjC.js";import{s as ce}from"./vue-plyr-BO2nlN4c.js";import{A as pe}from"./ApiCodeButton-CkgmddPY.js";import{E as de}from"./index-CKC1QXPY.js";import{E as ue}from"./index-CTe-d_6k.js";import{E as me}from"./index-DQOSv-tV.js";import{B as fe}from"./BotPlaceholder-s0833dXM.js";import"./use-form-item-DLYZ0lkO.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-DcfXaBeC.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-Dc1F-Mud.js";import"./index-B12SAORZ.js";import"./index-BPUUia6V.js";import"./typescript-Jtl3VF26.js";import"./strings-beZM2Y-f.js";import"./isEqual-C_dkvvUP.js";import"./_Uint8Array-dMcWmqZF.js";import"./castArray-mD4k-COw.js";import"./index-BfwtSiqw.js";import"./index-tO5MdGXt.js";import"./debounce-fzRpYvTx.js";import"./_baseIteratee-DulLK_c3.js";import"./index-Bumd8iDl.js";import"./index-B0tmHD6W.js";import"./_baseClone-DZKAu36s.js";import"./_initCloneObject-BsCXP6pc.js";import"./index-TJBAFmkH.js";const _e=g({name:"LayoutPika",components:{ElDrawer:O,ElButton:L,FontAwesomeIcon:A},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 ke(e,o,c,d,k,v){const p=s("font-awesome-icon"),f=s("el-button"),i=s("el-drawer");return a(),l("div",he,[r("div",ge,[R(e.$slots,"config",{},void 0,!0)]),r("div",$e,[R(e.$slots,"result",{},void 0,!0)]),t(f,{circle:"",class:"menu",onClick:o[0]||(o[0]=b=>e.drawer=!0)},{default:m(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(i,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=$(_e,[["render",ke],["__scopeId","data-v-10596416"]]),be=g({name:"IngredientsSelector",components:{ElSwitch:X,InfoIcon:G},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=K)}}),ye={class:"field"},we={class:"title font-bold"};function Ve(e,o,c,d,k,v){const p=s("el-switch"),f=s("info-icon");return a(),l("div",ye,[r("h2",we,n(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value"},null,8,["modelValue"]),t(f,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const Ee=$(be,[["render",Ve],["__scopeId","data-v-17c0af5c"]]),Ie=g({name:"EffectSelector",components:{ElSelect:M,ElOption:D},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),Se={class:"field"},Te={class:"title font-bold"},Ce={class:"float-left"};function Pe(e,o,c,d,k,v){const p=s("el-option"),f=s("el-select");return a(),l("div",Se,[r("h2",Te,n(e.$t("pika.name.effect")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.label,value:i.value},{default:m(()=>[r("span",Ce,n(i.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ae=$(Ie,[["render",Pe],["__scopeId","data-v-d1c54475"]]),Le=g({name:"IngredientsModelSelector",components:{ElRadioButton:Z,ElRadioGroup:Y},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=H)}}),Ue={class:"field"},Re={class:"title font-bold"};function Ge(e,o,c,d,k,v){const p=s("el-radio-button"),f=s("el-radio-group");return a(),l("div",Ue,[r("h2",Re,n(e.$t("pika.name.ingredientsModel")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"quality"},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.value},{default:m(()=>[_(n(i.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const De=$(Le,[["render",Ge],["__scopeId","data-v-b72865fa"]]),Me=g({name:"ModelSelector",components:{ElSelect:M,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=J)}}),qe={class:"field"},Oe={class:"title font-bold"};function Be(e,o,c,d,k,v){const p=s("el-option"),f=s("el-select");return a(),l("div",qe,[r("h2",Oe,n(e.$t("pika.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),l(S,null,C(e.options,i=>(a(),w(p,{key:i.value,label:i.label,value:i.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const je=$(Me,[["render",Be],["__scopeId","data-v-7b2e870a"]]),Fe=g({name:"ImageUrlInput",components:{ElUpload:te,ElButton:L,InfoIcon:G,ImagePreview:ee,FontAwesomeIcon:A},mixins:[x],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Ne={class:"field"},ze={class:"title font-bold"},Ke={class:"upload-wrapper"};function He(e,o,c,d,k,v){const p=s("image-preview"),f=s("font-awesome-icon"),i=s("el-button"),b=s("el-upload"),E=s("info-icon");return a(),l("div",Ne,[r("h2",ze,n(e.$t("pika.name.imageUrl")),1),r("div",Ke,[t(b,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:u})=>[t(p,{url:u.url||u.response?.file_url,name:u.name,percentage:u.percentage,onRemove:I=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])]),default:m(()=>[t(i,{size:"small",type:"primary",round:""},{default:m(()=>[t(f,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+n(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(E,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Je=$(Fe,[["render",He],["__scopeId","data-v-a948772f"]]),Qe="",We=g({name:"PromptInput",components:{PromptTextarea:oe},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Qe)}});function Xe(e,o,c,d,k,v){const p=s("prompt-textarea");return a(),w(p,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=f=>e.prompt=f),title:e.$t("pika.name.prompt"),info:e.$t("pika.description.prompt"),placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ye=$(We,[["render",Xe]]),Ze=g({name:"PresetPanel",components:{ImageUrlInput:Je,ElButton:L,FontAwesomeIcon:A,Consumption:ae,PromptInput:Ye,IngredientsSelector:Ee,IngredientsModelSelector:De,ModelSelector:je,EffectSelector:Ae},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),xe={class:"flex flex-col h-full"},et={class:"flex-1 overflow-y-auto p-5"},tt={class:"flex flex-col items-center justify-center px-5 pb-5"};function ot(e,o,c,d,k,v){const p=s("prompt-input"),f=s("model-selector"),i=s("ingredients-selector"),b=s("effect-selector"),E=s("image-url-input"),u=s("ingredients-model-selector"),I=s("consumption"),T=s("font-awesome-icon"),y=s("el-button");return a(),l("div",xe,[r("div",et,[t(p,{class:"mb-4"}),t(f,{class:"mb-4"}),t(i,{class:"mb-4"}),t(b,{class:"mb-4"}),e.config?.ingredients?(a(),w(E,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),w(u,{key:1,class:"mb-4"})):h("",!0)]),r("div",tt,[t(I,{value:e.consumption,service:e.service},null,8,["value","service"]),t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const st=$(Ze,[["render",ot]]),at=g({name:"VideoPlayer",components:{VuePlyr:ce},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:1080,options:[1080]}}}}}),nt=["data-poster"],it=["src"];function lt(e,o,c,d,k,v){const p=s("vue-plyr");return a(),l("div",null,[t(p,{options:e.options,class:"video"},{default:m(()=>[r("video",{controls:"",playsinline:"",preload:"metadata","data-poster":e.modelValue?.image_url},[r("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,it)],8,nt)]),_:1},8,["options"])])}const rt=$(at,[["render",lt],["__scopeId","data-v-897d9fe0"]]),ct=g({name:"TaskPreview",components:{ElImage:me,CopyToClipboard:re,FontAwesomeIcon:A,ElAlert:ue,VideoPlayer:rt,ElTooltip:de,ElButton:L,ApiCodeButton:pe},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(c=>{let d=c;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,c=new URL(o.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),pt={class:"left"},dt={class:"main"},ut={class:"bot"},mt={class:"datetime"},ft={class:"info"},_t={key:0,class:"prompt mt-2"},ht={key:0},gt={key:1},$t={key:0,class:U({content:!0,failed:!0})},kt={class:"image-wrapper"},vt={key:0,class:U({operations:!0,"mt-2":!0})},bt={key:0,class:"description"},yt={class:"description"},wt={key:1,class:"description"},Vt={key:1,class:U({content:!0})},Et={class:"description"},It={class:"description"},St={key:0,class:"description"},Tt={class:"description"},Ct={key:2,class:U({content:!0})},Pt={class:"description"};function At(e,o,c,d,k,v){const p=s("el-image"),f=s("VideoPlayer"),i=s("el-button"),b=s("el-tooltip"),E=s("api-code-button"),u=s("font-awesome-icon"),I=s("copy-to-clipboard"),T=s("el-alert");return a(!0),l(S,null,C(e.videos,(y,q)=>(a(),l("div",{key:q,class:"preview"},[r("div",pt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),r("div",dt,[r("div",ut,[_(n(e.$t("pika.name.pikaBot"))+" ",1),r("span",mt,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",ft,[e.modelValue?.request?.prompt?(a(),l("p",_t,[_(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),l("span",ht," - ("+n(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"?(a(),l("span",gt," - ("+n(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",$t,[r("div",kt,[t(f,{"model-value":y},null,8,["model-value"])]),y?(a(),l("div",vt,[t(b,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),w(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:jt=>e.onDownload(y?.video_url)},{default:m(()=>[_(n(e.$t("pika.button.download")),1)]),_:1},8,["onClick"])):h("",!0)]),_:2},1032,["content"]),t(E,{path:"/pika/videos",body:e.modelValue?.request},null,8,["body"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[e.modelValue?.request?.model?(a(),l("p",bt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.model"))+": "+n(e.modelValue?.request?.model),1)])):h("",!0),r("p",yt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",wt,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0)]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),l("div",Vt,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[r("p",Et,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),r("p",It,[t(u,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("pika.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(I,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),l("p",St,[t(u,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+n(e.$t("pika.name.elapsed"))+": "+n(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):h("",!0),r("p",Tt,[t(u,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("pika.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(I,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),l("div",Ct,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(u,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("pika.name.failure")),1)]),default:m(()=>[r("p",Pt,[t(u,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("pika.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(I,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const Lt=$(ct,[["render",At],["__scopeId","data-v-86bc86fb"]]),Ut=g({name:"RecentPanel",components:{TaskPreview:Lt,BotPlaceholder:fe,NoTasks:se,ScrollList:Q},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Rt={key:0},Gt={key:2,class:"w-full h-full flex items-center justify-center"};function Dt(e,o,c,d,k,v){const p=s("bot-placeholder"),f=s("task-preview"),i=s("scroll-list"),b=s("no-tasks");return a(),l(S,null,[e.tasks?.items===void 0?(a(),l("div",Rt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=E=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),l(S,null,C(e.tasks?.items,(E,u)=>(a(),w(f,{key:u,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),l("div",Gt,[t(b)])):h("",!0)],64)}const Mt=$(Ut,[["render",Dt]]),qt=z("pika"),Ot=g({name:"PikaIndex",components:{ConfigPanel:st,Layout:ve,RecentPanel:Mt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===P.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await W({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){N.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===le&&V.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:qt},o=this.credential?.token;if(!o){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),j("pika",F.generate(e,{token:o})).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===ie?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Bt(e,o,c,d,k,v){const p=s("config-panel"),f=s("recent-panel"),i=s("layout");return a(),w(i,null,{config:m(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(f,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Oo=$(Ot,[["render",Bt],["__scopeId","data-v-3cd7cf5b"]]);export{Oo as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{L as P}from"./Hailuo-DiPlgsJB.js";import{F as U}from"./index.es-BXqpwkqA.js";import{H as b,bp as A,cs as R,aS as M,S as L,ct as B}from"./index-BuJDkS44.js";import{a as j}from"./hailuo-C8Dw-0xR.js";import{E as D,a as q}from"./index-CyudTOvt.js";import{d as y,H as l,E as r,F as o,C as t,y as c,O as I,N as G,D as a,q as s,x as $,I as m,J as d,M as F,Q as T}from"./vendor-vue-NSDaktjZ.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{I as z,S as N,l as H}from"./pagination-Bukm0OON.js";import{I as J}from"./ImagePreview-B3CWsVuY.js";import{E as C}from"./index-CJJXga6X.js";import{E as K}from"./index-CPXiJxKP.js";import{E as k}from"./index-CPXG2GVO.js";import{P as Q,N as W}from"./NoTasks-meE6rr3b.js";import{C as X}from"./Consumption-olJH452p.js";import{a as Y}from"./price-CulrpxQT.js";import{b as Z}from"./errorCode-Cqj9Td_Z.js";import{C as x}from"./CopyToClipboard-DPa3E4GR.js";import{V as ee}from"./VideoPlayer-CLOYjGw9.js";import{A as te}from"./ApiCodeButton-C59fK0-P.js";import{E as oe}from"./index-Dw5_Z8kM.js";import{E as se}from"./index-DMsm9lCV.js";import{E as ae}from"./index-DH4oTCmN.js";import{B as ne}from"./BotPlaceholder-BK6VXpIO.js";import"./index-BHm7N755.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-HpTopfFP.js";import"./typescript-f8CZHruo.js";import"./index-I8l3O3OX.js";import"./strings-beZM2Y-f.js";import"./isEqual-Am6JmVzR.js";import"./_Uint8Array-CAXQwVOS.js";import"./castArray-o97GVNr8.js";import"./use-form-item-C0sdV2df.js";import"./index-CV-Q_DwW.js";import"./index-DSijVGKp.js";import"./debounce-IGDjJ0RI.js";import"./_baseIteratee-EfYP4TWi.js";import"./index-B0qFYAzt.js";import"./highlight-BJauIwLT.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CkvYcCVd.js";import"./index-BuyEbX8F.js";import"./_baseClone-DXPY_NNj.js";import"./_initCloneObject-DTxX8SUA.js";import"./vue-plyr-BO2nlN4c.js";import"./index-BAPAp6Xb.js";const le=y({name:"ModelSelector",components:{ElSelect:q,ElOption:D},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")},{value:"minimax-i2v-director",label:this.$t("hailuo.button.model3")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=j)}}),ie={class:"field"},re={class:"title font-bold"},ce={class:"float-left"};function ue(e,n,g,_,w,S){const h=a("el-option"),f=a("el-select");return s(),l("div",ie,[r("h2",re,o(e.$t("hailuo.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),l(I,null,G(e.options,u=>(s(),$(h,{key:u.value,label:u.label,value:u.value},{default:c(()=>[r("span",ce,o(u.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const me=b(le,[["render",ue],["__scopeId","data-v-a768fbd9"]]),de=y({name:"StartImageUrlInput",components:{ElUpload:K,ElButton:C,InfoIcon:z,ImagePreview:J},mixins:[O],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.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){k.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){k.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){k.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),pe={class:"relative"},he={class:"flex justify-between"},fe={class:"flex justify-start items-center"},ge={class:"text-sm font-bold"};function _e(e,n,g,_,w,S){const h=a("info-icon"),f=a("image-preview"),u=a("el-button"),v=a("el-upload");return s(),l("div",pe,[r("div",he,[r("div",fe,[r("span",ge,o(e.$t("hailuo.name.startImageUrl")),1),t(h,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(v,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(f,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:p=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:c(()=>[t(u,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[m(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const $e=b(de,[["render",_e],["__scopeId","data-v-48f4a681"]]),ve="",ke=y({name:"PromptInput",components:{PromptTextarea:Q},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ve)}});function be(e,n,g,_,w,S){const h=a("prompt-textarea");return s(),$(h,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=f=>e.prompt=f),title:e.$t("hailuo.name.prompt"),info:e.$t("hailuo.description.prompt"),placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const ye=b(ke,[["render",be]]),we=y({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:U,PromptInput:ye,StartImageUrlInput:$e,ModelSelector:me,Consumption:X},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return Y(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Se={class:"flex flex-col h-full"},Ve={class:"flex-1 overflow-y-auto p-5"},Te={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ee(e,n,g,_,w,S){const h=a("prompt-input"),f=a("model-selector"),u=a("start-image-url-input"),v=a("consumption"),i=a("font-awesome-icon"),p=a("el-button");return s(),l("div",Se,[r("div",Ve,[t(h,{class:"mb-4"}),t(f,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),$(u,{key:0,class:"mb-2"})):d("",!0)]),r("div",Te,[t(v,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),$(p,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),$(p,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Ie=b(we,[["render",Ee]]),Ce=y({name:"TaskPreview",components:{ElImage:ae,CopyToClipboard:x,FontAwesomeIcon:U,ElAlert:se,VideoPlayer:ee,ElTooltip:oe,ElButton:C,ApiCodeButton:te},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),Le={class:"preview"},Ue={class:"left"},Ge={class:"main"},Pe={class:"bot"},Ae={class:"datetime"},Re={class:"info"},Me={key:0,class:"prompt mt-2"},Be={key:0},je={key:1},De={key:0,class:T({content:!0,failed:!0})},qe={key:0,class:"mb-4"},Fe={key:1,class:T({operations:!0,"mt-2":!0})},Oe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ze={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ne={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},He={key:1,class:T({content:!0})},Je={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ke={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},We={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Xe={key:2,class:T({content:!0})},Ye={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Ze(e,n,g,_,w,S){const h=a("el-image"),f=a("video-player"),u=a("el-button"),v=a("el-tooltip"),i=a("api-code-button"),p=a("font-awesome-icon"),V=a("copy-to-clipboard"),E=a("el-alert");return s(),l("div",Le,[r("div",Ue,[t(h,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",Ge,[r("div",Pe,[m(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Ae,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",Re,[e.modelValue?.request?.prompt?(s(),l("p",Me,[m(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(s(),l("span",Be," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),l("span",je," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0?(s(),l("div",De,[e.video?.video_url?(s(),l("div",qe,[t(f,{src:e.video?.video_url},null,8,["src"])])):d("",!0),e.video?(s(),l("div",Fe,[t(v,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.video?.video_url?(s(),$(u,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=F(rt=>e.onDownload(e.video?.video_url),["stop"]))},{default:c(()=>[m(o(e.$t("hailuo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),t(i,{path:"/hailuo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),l("p",Oe,[t(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):d("",!0),r("p",ze,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ne,[t(p,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(s(),l("div",He,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",Je,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),r("p",Ke,[t(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Qe,[t(p,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),r("p",We,[t(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",Xe,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",Ye,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):d("",!0)])])}const xe=b(Ce,[["render",Ze],["__scopeId","data-v-d70b3e0b"]]),et=y({name:"RecentPanel",components:{TaskPreview:xe,BotPlaceholder:ne,NoTasks:W,ScrollList:N},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),tt={key:0},ot={key:2,class:"w-full h-full flex items-center justify-center"};function st(e,n,g,_,w,S){const h=a("bot-placeholder"),f=a("task-preview"),u=a("scroll-list"),v=a("no-tasks");return s(),l(I,null,[e.tasks?.items===void 0?(s(),l("div",tt,[t(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),l(I,null,G(e.tasks?.items,i=>(s(),$(f,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(s(),l("div",ot,[t(v)])):d("",!0)],64)}const at=b(et,[["render",st]]),nt=B("hailuo"),lt=y({name:"HailuoIndex",components:{ConfigPanel:Ie,Layout:P,RecentPanel:at},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await H({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:g,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",g,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:g,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:nt},n=this.credential?.token;if(!n){console.error("no token specified");return}k.info(this.$t("hailuo.message.startingTask")),R("hailuo",M.generate(e,{token:n})).then(()=>{k.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(g=>{g?.response?.data?.error?.code===Z?k.error(this.$t("hailuo.message.usedUp")):k.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function it(e,n,g,_,w,S){const h=a("config-panel"),f=a("recent-panel"),u=a("layout");return s(),$(u,null,{config:c(()=>[t(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(f,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ao=b(lt,[["render",it]]);export{ao as default};
|
|
1
|
+
import{L as P}from"./Hailuo-7_9fVHuN.js";import{F as U}from"./index.es-C8TbH2BC.js";import{H as b,bp as A,cs as R,aS as M,S as L,ct as B}from"./index-CX3Kkhe8.js";import{a as j}from"./hailuo-C8Dw-0xR.js";import{E as D,a as q}from"./index-CxCN6BXU.js";import{d as y,H as l,E as r,F as o,C as t,y as c,O as I,N as G,D as a,q as s,x as $,I as m,J as d,M as F,Q as T}from"./vendor-vue-NSDaktjZ.js";import{p as O}from"./pasteUploadMixin-BurWbGNQ.js";import{I as z,S as N,l as H}from"./pagination-BCfNKuC9.js";import{I as J}from"./ImagePreview-BKqMFwxZ.js";import{E as C}from"./index-BVkFwr_L.js";import{E as K}from"./index-D8d_EiGA.js";import{E as k}from"./index-CBGglJJ1.js";import{P as Q,N as W}from"./NoTasks-CF8uilN4.js";import{C as X}from"./Consumption-DJb3Zq85.js";import{a as Y}from"./price-DyHd8y4L.js";import{b as Z}from"./errorCode-Cqj9Td_Z.js";import{C as x}from"./CopyToClipboard-DszAErjC.js";import{V as ee}from"./VideoPlayer-B8hJJa4d.js";import{A as te}from"./ApiCodeButton-CkgmddPY.js";import{E as oe}from"./index-CKC1QXPY.js";import{E as se}from"./index-CTe-d_6k.js";import{E as ae}from"./index-DQOSv-tV.js";import{B as ne}from"./BotPlaceholder-s0833dXM.js";import"./index-BSglm0Mh.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BPUUia6V.js";import"./typescript-Jtl3VF26.js";import"./index-B12SAORZ.js";import"./strings-beZM2Y-f.js";import"./isEqual-C_dkvvUP.js";import"./_Uint8Array-dMcWmqZF.js";import"./castArray-mD4k-COw.js";import"./use-form-item-DLYZ0lkO.js";import"./index-BfwtSiqw.js";import"./index-tO5MdGXt.js";import"./debounce-fzRpYvTx.js";import"./_baseIteratee-DulLK_c3.js";import"./index-Bumd8iDl.js";import"./highlight-DcfXaBeC.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-B0tmHD6W.js";import"./index-BuyEbX8F.js";import"./_baseClone-DZKAu36s.js";import"./_initCloneObject-BsCXP6pc.js";import"./vue-plyr-BO2nlN4c.js";import"./index-TJBAFmkH.js";const le=y({name:"ModelSelector",components:{ElSelect:q,ElOption:D},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")},{value:"minimax-i2v-director",label:this.$t("hailuo.button.model3")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=j)}}),ie={class:"field"},re={class:"title font-bold"},ce={class:"float-left"};function ue(e,n,g,_,w,S){const h=a("el-option"),f=a("el-select");return s(),l("div",ie,[r("h2",re,o(e.$t("hailuo.name.model")),1),t(f,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:c(()=>[(s(!0),l(I,null,G(e.options,u=>(s(),$(h,{key:u.value,label:u.label,value:u.value},{default:c(()=>[r("span",ce,o(u.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const me=b(le,[["render",ue],["__scopeId","data-v-a768fbd9"]]),de=y({name:"StartImageUrlInput",components:{ElUpload:K,ElButton:C,InfoIcon:z,ImagePreview:J},mixins:[O],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.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){k.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){k.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){k.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),pe={class:"relative"},he={class:"flex justify-between"},fe={class:"flex justify-start items-center"},ge={class:"text-sm font-bold"};function _e(e,n,g,_,w,S){const h=a("info-icon"),f=a("image-preview"),u=a("el-button"),v=a("el-upload");return s(),l("div",pe,[r("div",he,[r("div",fe,[r("span",ge,o(e.$t("hailuo.name.startImageUrl")),1),t(h,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(v,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":n[0]||(n[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:i})=>[i.url&&i.percentage!==void 0?(s(),$(f,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:p=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:c(()=>[t(u,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:c(()=>[m(o(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const $e=b(de,[["render",_e],["__scopeId","data-v-48f4a681"]]),ve="",ke=y({name:"PromptInput",components:{PromptTextarea:Q},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ve)}});function be(e,n,g,_,w,S){const h=a("prompt-textarea");return s(),$(h,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||(n[0]=f=>e.prompt=f),title:e.$t("hailuo.name.prompt"),info:e.$t("hailuo.description.prompt"),placeholder:e.$t("hailuo.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const ye=b(ke,[["render",be]]),we=y({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:U,PromptInput:ye,StartImageUrlInput:$e,ModelSelector:me,Consumption:X},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return Y(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Se={class:"flex flex-col h-full"},Ve={class:"flex-1 overflow-y-auto p-5"},Te={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ee(e,n,g,_,w,S){const h=a("prompt-input"),f=a("model-selector"),u=a("start-image-url-input"),v=a("consumption"),i=a("font-awesome-icon"),p=a("el-button");return s(),l("div",Se,[r("div",Ve,[t(h,{class:"mb-4"}),t(f,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),$(u,{key:0,class:"mb-2"})):d("",!0)]),r("div",Te,[t(v,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),$(p,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),$(p,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[t(i,{icon:"fa-solid fa-magic",class:"mr-2"}),m(" "+o(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Ie=b(we,[["render",Ee]]),Ce=y({name:"TaskPreview",components:{ElImage:ae,CopyToClipboard:x,FontAwesomeIcon:U,ElAlert:se,VideoPlayer:ee,ElTooltip:oe,ElButton:C,ApiCodeButton:te},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),Le={class:"preview"},Ue={class:"left"},Ge={class:"main"},Pe={class:"bot"},Ae={class:"datetime"},Re={class:"info"},Me={key:0,class:"prompt mt-2"},Be={key:0},je={key:1},De={key:0,class:T({content:!0,failed:!0})},qe={key:0,class:"mb-4"},Fe={key:1,class:T({operations:!0,"mt-2":!0})},Oe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ze={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ne={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},He={key:1,class:T({content:!0})},Je={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ke={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qe={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},We={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Xe={key:2,class:T({content:!0})},Ye={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Ze(e,n,g,_,w,S){const h=a("el-image"),f=a("video-player"),u=a("el-button"),v=a("el-tooltip"),i=a("api-code-button"),p=a("font-awesome-icon"),V=a("copy-to-clipboard"),E=a("el-alert");return s(),l("div",Le,[r("div",Ue,[t(h,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),r("div",Ge,[r("div",Pe,[m(o(e.$t("hailuo.name.hailuoBot"))+" ",1),r("span",Ae,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",Re,[e.modelValue?.request?.prompt?(s(),l("p",Me,[m(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(s(),l("span",Be," - ("+o(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),l("span",je," - ("+o(e.$t("hailuo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0?(s(),l("div",De,[e.video?.video_url?(s(),l("div",qe,[t(f,{src:e.video?.video_url},null,8,["src"])])):d("",!0),e.video?(s(),l("div",Fe,[t(v,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.video?.video_url?(s(),$(u,{key:0,type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=F(rt=>e.onDownload(e.video?.video_url),["stop"]))},{default:c(()=>[m(o(e.$t("hailuo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"]),t(i,{path:"/hailuo/videos",body:e.modelValue?.request},null,8,["body"])])):d("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[e.modelValue?.request?.model?(s(),l("p",Oe,[t(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.model"))+": "+o(e.modelValue?.request?.model)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])):d("",!0),r("p",ze,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Ne,[t(p,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(s(),l("div",He,[t(E,{closable:!1,class:"failure"},{template:c(()=>[t(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",Je,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])]),r("p",Ke,[t(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),t(V,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),l("p",Qe,[t(p,{icon:"fa-solid fa-clock",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),r("p",We,[t(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),t(V,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",Xe,[t(E,{closable:!1,class:"info"},{template:c(()=>[t(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.failure")),1)]),default:c(()=>[r("p",Ye,[t(p,{icon:"fa-solid fa-magic",class:"mr-1"}),m(" "+o(e.$t("hailuo.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),t(V,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):d("",!0)])])}const xe=b(Ce,[["render",Ze],["__scopeId","data-v-d70b3e0b"]]),et=y({name:"RecentPanel",components:{TaskPreview:xe,BotPlaceholder:ne,NoTasks:W,ScrollList:N},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),tt={key:0},ot={key:2,class:"w-full h-full flex items-center justify-center"};function st(e,n,g,_,w,S){const h=a("bot-placeholder"),f=a("task-preview"),u=a("scroll-list"),v=a("no-tasks");return s(),l(I,null,[e.tasks?.items===void 0?(s(),l("div",tt,[t(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:c(()=>[(s(!0),l(I,null,G(e.tasks?.items,i=>(s(),$(f,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(s(),l("div",ot,[t(v)])):d("",!0)],64)}const at=b(et,[["render",st]]),nt=B("hailuo"),lt=y({name:"HailuoIndex",components:{ConfigPanel:Ie,Layout:P,RecentPanel:at},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===L.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,n){e?.items?.length>n?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await H({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:n=5,createdAtMin:g,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",g,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:n,createdAtMin:g,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:nt},n=this.credential?.token;if(!n){console.error("no token specified");return}k.info(this.$t("hailuo.message.startingTask")),R("hailuo",M.generate(e,{token:n})).then(()=>{k.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(g=>{g?.response?.data?.error?.code===Z?k.error(this.$t("hailuo.message.usedUp")):k.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function it(e,n,g,_,w,S){const h=a("config-panel"),f=a("recent-panel"),u=a("layout");return s(),$(u,null,{config:c(()=>[t(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[t(f,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ao=b(lt,[["render",it]]);export{ao as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as T}from"./index.es-BXqpwkqA.js";import{E as q}from"./index-CJJXga6X.js";import{E as K}from"./index-BHm7N755.js";import{d as y,H as l,E as u,z as O,C as a,y as b,D as s,q as n,x as k,F as o,I as c,O as N,N as E,J as p,M as H,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as J,cR as Q,cS as z,cT as P,cU as X,cV as S,cW as j,cX as D,cY as F,cs as Y,aW as Z,S as W,ct as ee}from"./index-BuJDkS44.js";import{P as te,N as ae}from"./NoTasks-meE6rr3b.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as B,S as ne,l as se}from"./pagination-Bukm0OON.js";import{I as x}from"./ImagePreview-B3CWsVuY.js";import{E as le}from"./index-CPXiJxKP.js";import{E as R}from"./index-CPXG2GVO.js";import{E as G,a as M}from"./index-CyudTOvt.js";import{C as re}from"./Consumption-olJH452p.js";import{a as ie}from"./price-CulrpxQT.js";import{b as ce}from"./errorCode-Cqj9Td_Z.js";import{C as ue}from"./CopyToClipboard-DPa3E4GR.js";import{I as me}from"./ImageWrapper-MfEE4bKQ.js";import{A as de}from"./ApiCodeButton-C59fK0-P.js";import{E as pe}from"./index-Dw5_Z8kM.js";import{E as fe}from"./index-DMsm9lCV.js";import{E as he}from"./index-DH4oTCmN.js";import{B as _e}from"./BotPlaceholder-BK6VXpIO.js";import"./use-form-item-C0sdV2df.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-CV-Q_DwW.js";import"./typescript-f8CZHruo.js";import"./index-I8l3O3OX.js";import"./index-DSijVGKp.js";import"./highlight-BJauIwLT.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-CkvYcCVd.js";import"./_baseClone-DXPY_NNj.js";import"./_Uint8Array-CAXQwVOS.js";import"./_initCloneObject-DTxX8SUA.js";import"./isEqual-Am6JmVzR.js";import"./index-HpTopfFP.js";import"./strings-beZM2Y-f.js";import"./castArray-o97GVNr8.js";import"./debounce-IGDjJ0RI.js";import"./_baseIteratee-EfYP4TWi.js";import"./index-B0qFYAzt.js";import"./index-BAPAp6Xb.js";const be=y({name:"LayoutNanobanana",components:{ElDrawer:K,ElButton:q,FontAwesomeIcon:T},data(){return{drawer:!1}}}),ge={class:"main flex flex-row flex-1"},$e={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 ke(e,t,$,r,g,f){const h=s("font-awesome-icon"),_=s("el-button"),d=s("el-drawer");return n(),l("div",ge,[u("div",$e,[O(e.$slots,"config",{},void 0,!0)]),u("div",ve,[O(e.$slots,"result",{},void 0,!0)]),a(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=m=>e.drawer=!0)},{default:b(()=>[a(h,{icon:"fa-solid fa-magic"})]),_:1}),a(d,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=m=>e.drawer=m),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:b(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ye=w(be,[["render",ke],["__scopeId","data-v-8ca1c212"]]),we="",Ve=y({name:"PromptInput",components:{PromptTextarea:te},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=we)}});function Ae(e,t,$,r,g,f){const h=s("prompt-textarea");return n(),k(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),title:e.$t("nanobanana.name.prompt"),info:e.$t("nanobanana.description.prompt"),placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ve,[["render",Ae]]),Ee=y({name:"ImageUrlsInput",components:{ElUpload:le,ElButton:q,InfoIcon:B,ImagePreview:x,FontAwesomeIcon:T},mixins:[oe],data(){return{fileList:[],uploadUrl:J()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(g=>!g?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const g=this.fileList.find(f=>f?.response?.file_url===r||f?.url===r);g?t.push(g):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(f=>f===r||f?.url===r?.url||f?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Re={class:"field flex items-center justify-between"},Le={class:"title font-bold text-[14px] mb-[10px]"},Ie={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Se={class:"controls flex items-center"},Te={class:"file-list flex flex-wrap gap-[10px]"};function qe(e,t,$,r,g,f){const h=s("font-awesome-icon"),_=s("el-button"),d=s("el-upload"),m=s("info-icon"),V=s("image-preview");return n(),l(N,null,[u("div",Re,[u("h2",Le,o(e.$t("nanobanana.name.imageUrls")),1),u("div",Ie,[u("div",Se,[a(d,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:b(()=>[a(_,{size:"small",type:"primary",round:""},{default:b(()=>[a(h,{icon:"fa-solid fa-upload",class:"mr-1"}),c(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(m,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),u("div",Te,[(n(!0),l(N,null,E(e.fileList,(v,i)=>(n(),k(V,{key:v.uid||v?.response?.file_url||v.url||i,url:v.url||v?.response?.file_url,name:v.name,percentage:v.percentage,onRemove:A=>e.onRemovePreview(i,v)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ue=w(Ee,[["render",qe]]),Ce=y({name:"AspectRatioSelector",components:{ElSelect:M,ElOption:G},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Oe={class:"field"},Pe={class:"title font-bold"};function Be(e,t,$,r,g,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Oe,[u("h2",Pe,o(e.$t("nanobanana.name.aspectRatio")),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,E(e.options,d=>(n(),k(h,{key:d,label:d,value:d},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=w(Ce,[["render",Be],["__scopeId","data-v-67f08a08"]]),Me=y({name:"NanobananaModelSelector",components:{ElSelect:M,ElOption:G,InfoIcon:B},data(){return{options:[{value:z,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:X,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),je={class:"field"},De={class:"label"},Fe={class:"box"},We={class:"title font-bold"};function ze(e,t,$,r,g,f){const h=s("info-icon"),_=s("el-option"),d=s("el-select");return n(),l("div",je,[u("div",De,[u("div",Fe,[u("h2",We,o(e.$t("nanobanana.name.model")),1),a(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,E(e.options,m=>(n(),k(_,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const xe=w(Me,[["render",ze],["__scopeId","data-v-94304d73"]]),Ke=y({name:"NanobananaResolutionSelector",components:{ElSelect:M,ElOption:G,InfoIcon:B},data(){return{cachedResolution:S,options:[{value:j,label:j},{value:D,label:D},{value:F,label:F}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==z}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),He={class:"field"},Je={class:"label"},Qe={class:"box"},Xe={class:"title font-bold"};function Ye(e,t,$,r,g,f){const h=s("info-icon"),_=s("el-option"),d=s("el-select");return n(),l("div",He,[u("div",Je,[u("div",Qe,[u("h2",Xe,o(e.$t("nanobanana.name.resolution")),1),a(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:b(()=>[(n(!0),l(N,null,E(e.options,m=>(n(),k(_,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Ze=w(Ke,[["render",Ye],["__scopeId","data-v-fd5ab393"]]),et=y({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:T,PromptInput:Ne,Consumption:re,ImageUrlsInput:Ue,AspectRatioSelector:Ge,ModelSelector:xe,ResolutionSelector:Ze},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return ie({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),tt={class:"flex flex-col h-full"},at={class:"flex-1 overflow-y-auto p-5"},ot={class:"flex flex-col items-center justify-center px-5 pb-5"};function nt(e,t,$,r,g,f){const h=s("model-selector"),_=s("resolution-selector"),d=s("prompt-input"),m=s("aspect-ratio-selector"),V=s("image-urls-input"),v=s("consumption"),i=s("font-awesome-icon"),A=s("el-button");return n(),l("div",tt,[u("div",at,[a(h,{class:"mb-4"}),a(_,{class:"mb-4"}),a(d,{class:"mb-4"}),a(m,{class:"mb-4"}),a(V,{class:"mb-4"})]),u("div",ot,[a(v,{value:e.consumption,service:e.service},null,8,["value","service"]),a(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:b(()=>[a(i,{icon:"fa-solid fa-magic",class:"mr-2"}),c(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const st=w(et,[["render",nt]]),lt=y({name:"TaskPreview",components:{ElImage:he,CopyToClipboard:ue,FontAwesomeIcon:T,ElAlert:fe,ImageWrapper:me,ElButton:q,ElTooltip:pe,ImagePreview:x,ApiCodeButton:de},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),rt={class:"preview"},it={class:"left"},ct={class:"main"},ut={class:"bot"},mt={class:"datetime"},dt={class:"info"},pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ft={key:1,class:"prompt mt-2"},ht={key:0},_t={key:0,class:U({content:!0,failed:!0})},bt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},gt={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},$t={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-2"},kt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Nt={key:1,class:U({content:!0})},Et={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ct={key:2,class:U({content:!0})},Ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function jt(e,t,$,r,g,f){const h=s("el-image"),_=s("image-preview"),d=s("image-wrapper"),m=s("el-button"),V=s("el-tooltip"),v=s("api-code-button"),i=s("font-awesome-icon"),A=s("copy-to-clipboard"),C=s("el-alert");return n(),l("div",rt,[u("div",it,[a(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),u("div",ct,[u("div",ut,[c(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),u("span",mt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),u("div",dt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",pt,[(n(!0),l(N,null,E(e.modelValue?.request?.image_urls,(L,I)=>(n(),k(_,{key:I,url:L,name:`image-${I+1}`,closable:!1},null,8,["url","name"]))),128))])):p("",!0),e.modelValue?.request?.prompt?(n(),l("p",ft,[c(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(n(),l("span",ht," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):p("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",_t,[u("div",bt,[(n(!0),l(N,null,E(e.images,(L,I)=>(n(),k(d,{key:I,src:L?.image_url,"raw-src":L?.image_url},null,8,["src","raw-src"]))),128))]),u("div",gt,[a(V,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:b(()=>[a(m,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(L=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:b(()=>[c(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),a(v,{path:"/nano-banana/images",body:e.modelValue?.request},null,8,["body"])]),a(C,{closable:!1,class:"mt-2 success"},{default:b(()=>[e.modelValue?.request?.model?(n(),l("p",$t,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",vt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",kt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",yt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",wt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",At,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):p("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Nt,[a(C,{closable:!1,class:"failure"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Et,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Rt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Lt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",It,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",St,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),u("p",Tt,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(A,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Ut,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):p("",!0)]),_:1})])):(n(),l("div",Ct,[a(C,{closable:!1,class:"info"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Ot,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Pt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Bt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",Gt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",Mt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Dt=w(lt,[["render",jt],["__scopeId","data-v-0ab492e0"]]),Ft=y({name:"RecentPanel",components:{TaskPreview:Dt,BotPlaceholder:_e,NoTasks:ae,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Wt={key:0},zt={key:2,class:"w-full h-full flex items-center justify-center"};function xt(e,t,$,r,g,f){const h=s("bot-placeholder"),_=s("task-preview"),d=s("scroll-list"),m=s("no-tasks");return n(),l(N,null,[e.tasks?.items===void 0?(n(),l("div",Wt,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),k(d,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=V=>e.$emit("reach-top"))},{default:b(()=>[(n(!0),l(N,null,E(e.tasks?.items,V=>(n(),k(_,{key:V.id,"model-value":V},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(n(),l("div",zt,[a(m)])):p("",!0)],64)}const Kt=w(Ft,[["render",xt]]),Ht=ee("nanobanana"),Jt=y({name:"NanobananaIndex",components:{ConfigPanel:st,Layout:ye,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===W.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===W.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await se({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:$,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=S);const $={...e,action:t?"edit":"generate",callback_url:Ht},r=this.credential?.token;if(!r){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),Y("nanobanana",Z.generate($,{token:r})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(g=>{const f=g?.response?.data;f?.error?.code===ce?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Qt(e,t,$,r,g,f){const h=s("config-panel"),_=s("recent-panel"),d=s("layout");return n(),k(d,null,{config:b(()=>[a(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:b(()=>[a(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Fa=w(Jt,[["render",Qt]]);export{Fa as default};
|
|
1
|
+
import{F as T}from"./index.es-C8TbH2BC.js";import{E as q}from"./index-BVkFwr_L.js";import{E as K}from"./index-BSglm0Mh.js";import{d as y,H as l,E as u,z as O,C as a,y as b,D as s,q as n,x as k,F as o,I as c,O as N,N as E,J as p,M as H,Q as U}from"./vendor-vue-NSDaktjZ.js";import{H as w,bp as J,cR as Q,cS as z,cT as P,cU as X,cV as S,cW as j,cX as D,cY as F,cs as Y,aW as Z,S as W,ct as ee}from"./index-CX3Kkhe8.js";import{P as te,N as ae}from"./NoTasks-CF8uilN4.js";import{p as oe}from"./pasteUploadMixin-BurWbGNQ.js";import{I as B,S as ne,l as se}from"./pagination-BCfNKuC9.js";import{I as x}from"./ImagePreview-BKqMFwxZ.js";import{E as le}from"./index-D8d_EiGA.js";import{E as R}from"./index-CBGglJJ1.js";import{E as G,a as M}from"./index-CxCN6BXU.js";import{C as re}from"./Consumption-DJb3Zq85.js";import{a as ie}from"./price-DyHd8y4L.js";import{b as ce}from"./errorCode-Cqj9Td_Z.js";import{C as ue}from"./CopyToClipboard-DszAErjC.js";import{I as me}from"./ImageWrapper-Dm7-bIgX.js";import{A as de}from"./ApiCodeButton-CkgmddPY.js";import{E as pe}from"./index-CKC1QXPY.js";import{E as fe}from"./index-CTe-d_6k.js";import{E as he}from"./index-DQOSv-tV.js";import{B as _e}from"./BotPlaceholder-s0833dXM.js";import"./use-form-item-DLYZ0lkO.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./index-BfwtSiqw.js";import"./typescript-Jtl3VF26.js";import"./index-B12SAORZ.js";import"./index-tO5MdGXt.js";import"./highlight-DcfXaBeC.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./index-B0tmHD6W.js";import"./_baseClone-DZKAu36s.js";import"./_Uint8Array-dMcWmqZF.js";import"./_initCloneObject-BsCXP6pc.js";import"./isEqual-C_dkvvUP.js";import"./index-BPUUia6V.js";import"./strings-beZM2Y-f.js";import"./castArray-mD4k-COw.js";import"./debounce-fzRpYvTx.js";import"./_baseIteratee-DulLK_c3.js";import"./index-Bumd8iDl.js";import"./index-TJBAFmkH.js";const be=y({name:"LayoutNanobanana",components:{ElDrawer:K,ElButton:q,FontAwesomeIcon:T},data(){return{drawer:!1}}}),ge={class:"main flex flex-row flex-1"},$e={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 ke(e,t,$,r,g,f){const h=s("font-awesome-icon"),_=s("el-button"),d=s("el-drawer");return n(),l("div",ge,[u("div",$e,[O(e.$slots,"config",{},void 0,!0)]),u("div",ve,[O(e.$slots,"result",{},void 0,!0)]),a(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=m=>e.drawer=!0)},{default:b(()=>[a(h,{icon:"fa-solid fa-magic"})]),_:1}),a(d,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=m=>e.drawer=m),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:b(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ye=w(be,[["render",ke],["__scopeId","data-v-8ca1c212"]]),we="",Ve=y({name:"PromptInput",components:{PromptTextarea:te},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=we)}});function Ae(e,t,$,r,g,f){const h=s("prompt-textarea");return n(),k(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),title:e.$t("nanobanana.name.prompt"),info:e.$t("nanobanana.description.prompt"),placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","title","info","placeholder"])}const Ne=w(Ve,[["render",Ae]]),Ee=y({name:"ImageUrlsInput",components:{ElUpload:le,ElButton:q,InfoIcon:B,ImagePreview:x,FontAwesomeIcon:T},mixins:[oe],data(){return{fileList:[],uploadUrl:J()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(g=>!g?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const g=this.fileList.find(f=>f?.response?.file_url===r||f?.url===r);g?t.push(g):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(f=>f===r||f?.url===r?.url||f?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){R.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){R.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Re={class:"field flex items-center justify-between"},Le={class:"title font-bold text-[14px] mb-[10px]"},Ie={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Se={class:"controls flex items-center"},Te={class:"file-list flex flex-wrap gap-[10px]"};function qe(e,t,$,r,g,f){const h=s("font-awesome-icon"),_=s("el-button"),d=s("el-upload"),m=s("info-icon"),V=s("image-preview");return n(),l(N,null,[u("div",Re,[u("h2",Le,o(e.$t("nanobanana.name.imageUrls")),1),u("div",Ie,[u("div",Se,[a(d,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:b(()=>[a(_,{size:"small",type:"primary",round:""},{default:b(()=>[a(h,{icon:"fa-solid fa-upload",class:"mr-1"}),c(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(m,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),u("div",Te,[(n(!0),l(N,null,E(e.fileList,(v,i)=>(n(),k(V,{key:v.uid||v?.response?.file_url||v.url||i,url:v.url||v?.response?.file_url,name:v.name,percentage:v.percentage,onRemove:A=>e.onRemovePreview(i,v)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ue=w(Ee,[["render",qe]]),Ce=y({name:"AspectRatioSelector",components:{ElSelect:M,ElOption:G},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Oe={class:"field"},Pe={class:"title font-bold"};function Be(e,t,$,r,g,f){const h=s("el-option"),_=s("el-select");return n(),l("div",Oe,[u("h2",Pe,o(e.$t("nanobanana.name.aspectRatio")),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,E(e.options,d=>(n(),k(h,{key:d,label:d,value:d},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=w(Ce,[["render",Be],["__scopeId","data-v-67f08a08"]]),Me=y({name:"NanobananaModelSelector",components:{ElSelect:M,ElOption:G,InfoIcon:B},data(){return{options:[{value:z,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:X,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=Q)}}),je={class:"field"},De={class:"label"},Fe={class:"box"},We={class:"title font-bold"};function ze(e,t,$,r,g,f){const h=s("info-icon"),_=s("el-option"),d=s("el-select");return n(),l("div",je,[u("div",De,[u("div",Fe,[u("h2",We,o(e.$t("nanobanana.name.model")),1),a(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:b(()=>[(n(!0),l(N,null,E(e.options,m=>(n(),k(_,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const xe=w(Me,[["render",ze],["__scopeId","data-v-94304d73"]]),Ke=y({name:"NanobananaResolutionSelector",components:{ElSelect:M,ElOption:G,InfoIcon:B},data(){return{cachedResolution:S,options:[{value:j,label:j},{value:D,label:D},{value:F,label:F}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==z}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),He={class:"field"},Je={class:"label"},Qe={class:"box"},Xe={class:"title font-bold"};function Ye(e,t,$,r,g,f){const h=s("info-icon"),_=s("el-option"),d=s("el-select");return n(),l("div",He,[u("div",Je,[u("div",Qe,[u("h2",Xe,o(e.$t("nanobanana.name.resolution")),1),a(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:b(()=>[(n(!0),l(N,null,E(e.options,m=>(n(),k(_,{key:m.value,label:m.label,value:m.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Ze=w(Ke,[["render",Ye],["__scopeId","data-v-fd5ab393"]]),et=y({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:T,PromptInput:Ne,Consumption:re,ImageUrlsInput:Ue,AspectRatioSelector:Ge,ModelSelector:xe,ResolutionSelector:Ze},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return ie({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),tt={class:"flex flex-col h-full"},at={class:"flex-1 overflow-y-auto p-5"},ot={class:"flex flex-col items-center justify-center px-5 pb-5"};function nt(e,t,$,r,g,f){const h=s("model-selector"),_=s("resolution-selector"),d=s("prompt-input"),m=s("aspect-ratio-selector"),V=s("image-urls-input"),v=s("consumption"),i=s("font-awesome-icon"),A=s("el-button");return n(),l("div",tt,[u("div",at,[a(h,{class:"mb-4"}),a(_,{class:"mb-4"}),a(d,{class:"mb-4"}),a(m,{class:"mb-4"}),a(V,{class:"mb-4"})]),u("div",ot,[a(v,{value:e.consumption,service:e.service},null,8,["value","service"]),a(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:b(()=>[a(i,{icon:"fa-solid fa-magic",class:"mr-2"}),c(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const st=w(et,[["render",nt]]),lt=y({name:"TaskPreview",components:{ElImage:he,CopyToClipboard:ue,FontAwesomeIcon:T,ElAlert:fe,ImageWrapper:me,ElButton:q,ElTooltip:pe,ImagePreview:x,ApiCodeButton:de},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),rt={class:"preview"},it={class:"left"},ct={class:"main"},ut={class:"bot"},mt={class:"datetime"},dt={class:"info"},pt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ft={key:1,class:"prompt mt-2"},ht={key:0},_t={key:0,class:U({content:!0,failed:!0})},bt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},gt={class:U({operations:!0,"mt-2":!0,"mb-2":!0})},$t={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-2"},kt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Nt={key:1,class:U({content:!0})},Et={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Lt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={key:5,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ct={key:2,class:U({content:!0})},Ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function jt(e,t,$,r,g,f){const h=s("el-image"),_=s("image-preview"),d=s("image-wrapper"),m=s("el-button"),V=s("el-tooltip"),v=s("api-code-button"),i=s("font-awesome-icon"),A=s("copy-to-clipboard"),C=s("el-alert");return n(),l("div",rt,[u("div",it,[a(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),u("div",ct,[u("div",ut,[c(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),u("span",mt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),u("div",dt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",pt,[(n(!0),l(N,null,E(e.modelValue?.request?.image_urls,(L,I)=>(n(),k(_,{key:I,url:L,name:`image-${I+1}`,closable:!1},null,8,["url","name"]))),128))])):p("",!0),e.modelValue?.request?.prompt?(n(),l("p",ft,[c(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(n(),l("span",ht," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):p("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",_t,[u("div",bt,[(n(!0),l(N,null,E(e.images,(L,I)=>(n(),k(d,{key:I,src:L?.image_url,"raw-src":L?.image_url},null,8,["src","raw-src"]))),128))]),u("div",gt,[a(V,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:b(()=>[a(m,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=H(L=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:b(()=>[c(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"]),a(v,{path:"/nano-banana/images",body:e.modelValue?.request},null,8,["body"])]),a(C,{closable:!1,class:"mt-2 success"},{default:b(()=>[e.modelValue?.request?.model?(n(),l("p",$t,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",vt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",kt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",yt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",wt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",At,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):p("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",Nt,[a(C,{closable:!1,class:"failure"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Et,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Rt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Lt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",It,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",St,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),u("p",Tt,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(A,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-clock",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),e.modelValue?.response?.trace_id?(n(),l("p",Ut,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(A,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):p("",!0)]),_:1})])):(n(),l("div",Ct,[a(C,{closable:!1,class:"info"},{template:b(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.failure")),1)]),default:b(()=>[e.modelValue?.request?.model?(n(),l("p",Ot,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):p("",!0),e.modelValue?.request?.resolution?(n(),l("p",Pt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):p("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Bt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):p("",!0),e.modelValue?.request?.action?(n(),l("p",Gt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):p("",!0),u("p",Mt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),c(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(A,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Dt=w(lt,[["render",jt],["__scopeId","data-v-0ab492e0"]]),Ft=y({name:"RecentPanel",components:{TaskPreview:Dt,BotPlaceholder:_e,NoTasks:ae,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Wt={key:0},zt={key:2,class:"w-full h-full flex items-center justify-center"};function xt(e,t,$,r,g,f){const h=s("bot-placeholder"),_=s("task-preview"),d=s("scroll-list"),m=s("no-tasks");return n(),l(N,null,[e.tasks?.items===void 0?(n(),l("div",Wt,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),k(d,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=V=>e.$emit("reach-top"))},{default:b(()=>[(n(!0),l(N,null,E(e.tasks?.items,V=>(n(),k(_,{key:V.id,"model-value":V},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(n(),l("div",zt,[a(m)])):p("",!0)],64)}const Kt=w(Ft,[["render",xt]]),Ht=ee("nanobanana"),Jt=y({name:"NanobananaIndex",components:{ConfigPanel:st,Layout:ye,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===W.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===W.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await se({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:$,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",$,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:$,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=S);const $={...e,action:t?"edit":"generate",callback_url:Ht},r=this.credential?.token;if(!r){console.error("no token specified");return}R.info(this.$t("nanobanana.message.startingTask")),Y("nanobanana",Z.generate($,{token:r})).then(()=>{R.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(g=>{const f=g?.response?.data;f?.error?.code===ce?R.error(this.$t("nanobanana.message.usedUp")):R.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Qt(e,t,$,r,g,f){const h=s("config-panel"),_=s("recent-panel"),d=s("layout");return n(),k(d,null,{config:b(()=>[a(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:b(()=>[a(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Fa=w(Jt,[["render",Qt]]);export{Fa as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as S}from"./index.es-BXqpwkqA.js";import{E as U}from"./index-CJJXga6X.js";import{E as N}from"./index-BHm7N755.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 p,M as F,Q as C,O as z,N as H}from"./vendor-vue-NSDaktjZ.js";import{H as y,bp as A,cs as x,aE as J,S as B,ct as K}from"./index-BuJDkS44.js";import{a as Q,b as W,c as X}from"./luma-DcySqBv2.js";import{I as L,S as Y,l as Z}from"./pagination-Bukm0OON.js";import{E as R}from"./index-QRYRN0ui.js";import{p as D}from"./pasteUploadMixin-BurWbGNQ.js";import{I as O}from"./ImagePreview-B3CWsVuY.js";import{E as P}from"./index-CPXiJxKP.js";import{E as b}from"./index-CPXG2GVO.js";import{F as ee}from"./FilePreview-D8mwFfzd.js";import{P as te,N as oe}from"./NoTasks-meE6rr3b.js";import{V as q}from"./VideoPlayer-CLOYjGw9.js";import{C as se}from"./Consumption-olJH452p.js";import{a as ne}from"./price-CulrpxQT.js";import{b as ae}from"./errorCode-Cqj9Td_Z.js";import{C as le}from"./CopyToClipboard-DPa3E4GR.js";import{A as ie}from"./ApiCodeButton-C59fK0-P.js";import{E as re}from"./index-Dw5_Z8kM.js";import{E as ce}from"./index-DMsm9lCV.js";import{E as me}from"./index-DH4oTCmN.js";import{B as ue}from"./BotPlaceholder-BK6VXpIO.js";import"./use-form-item-C0sdV2df.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-BJauIwLT.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-aW0kNVIp.js";import"./index-I8l3O3OX.js";import"./index-CkvYcCVd.js";import"./typescript-f8CZHruo.js";import"./_baseClone-DXPY_NNj.js";import"./_Uint8Array-CAXQwVOS.js";import"./_initCloneObject-DTxX8SUA.js";import"./isEqual-Am6JmVzR.js";import"./index-CV-Q_DwW.js";import"./index-DSijVGKp.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-IGDjJ0RI.js";import"./index-BAPAp6Xb.js";const de=k({name:"LayoutLuma",components:{ElDrawer:N,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},fe={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 he(e,t,f,h,w,E){const r=s("font-awesome-icon"),u=s("el-button"),d=s("el-drawer");return a(),m("div",pe,[l("div",fe,[j(e.$slots,"config",{},void 0,!0)]),l("div",_e,[j(e.$slots,"result",{},void 0,!0)]),o(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(d,{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 ge=y(de,[["render",he],["__scopeId","data-v-fdc8f36b"]]),$e=k({name:"EnhancementSelector",components:{ElSwitch:R,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=Q)}}),ve={class:"relative"},be={class:"flex justify-between"},ke={class:"flex justify-start items-center"},ye={class:"text-sm font-bold"},we={class:"flex justify-end items-center"};function Ee(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",ve,[l("div",be,[l("div",ke,[l("span",ye,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),l("div",we,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const Ve=y($e,[["render",Ee]]),Se=k({name:"CustomSelector",components:{ElSwitch:R,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=W)}}),Ue={class:"relative"},Le={class:"flex justify-between"},Te={class:"flex justify-start items-center"},Ie={class:"text-sm font-bold"},Ce={class:"flex justify-end items-center"};function je(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",Ue,[l("div",Le,[l("div",Te,[l("span",Ie,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),l("div",Ce,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const Ae=y(Se,[["render",je]]),Re=k({name:"LoopSelector",components:{ElSwitch:R,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=X)}}),Pe={class:"relative"},Ge={class:"flex justify-between"},Me={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"},ze={class:"flex justify-end items-center"};function Be(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",Pe,[l("div",Ge,[l("div",Me,[l("span",Fe,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),l("div",ze,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const De=y(Re,[["render",Be]]),Oe=k({name:"EndImage",components:{ElUpload:P,ElButton:U,ImagePreview:O,InfoIcon:L,FontAwesomeIcon:S},mixins:[D],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(){b.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){b.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()}}}),qe={class:"relative"},Ne={class:"flex justify-between"},He={class:"flex justify-start items-center"},xe={class:"text-sm font-bold"};function Je(e,t,f,h,w,E){const r=s("info-icon"),u=s("image-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",qe,[l("div",Ne,[l("div",He,[l("span",xe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(v,{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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 Ke=y(Oe,[["render",Je],["__scopeId","data-v-7a787b4d"]]),Qe=k({name:"StartImage",components:{ElUpload:P,ElButton:U,ImagePreview:O,InfoIcon:L,FontAwesomeIcon:S},mixins:[D],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(){b.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){b.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()}}}),We={class:"relative"},Xe={class:"flex justify-between"},Ye={class:"flex justify-start items-center"},Ze={class:"text-sm font-bold"};function et(e,t,f,h,w,E){const r=s("info-icon"),u=s("image-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",We,[l("div",Xe,[l("div",Ye,[l("span",Ze,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(v,{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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 tt=y(Qe,[["render",et],["__scopeId","data-v-8c5cfe84"]]),ot=k({name:"UploadVideo",components:{ElUpload:P,ElButton:U,InfoIcon:L,FilePreview:ee,FontAwesomeIcon:S},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(){b.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){b.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",f=e.size/1024/1024<10;return t?f?!0:(b.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(b.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()}}}),st={class:"relative"},nt={class:"flex justify-between"},at={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function it(e,t,f,h,w,E){const r=s("info-icon"),u=s("file-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",st,[l("div",nt,[l("div",at,[l("span",lt,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(v,{"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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 rt=y(ot,[["render",it],["__scopeId","data-v-74e51526"]]),ct="",mt=k({name:"PromptInput",components:{PromptTextarea:te},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=ct)}});function ut(e,t,f,h,w,E){const r=s("prompt-textarea");return a(),$(r,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),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 dt=y(mt,[["render",ut]]),pt=k({name:"ExtendFromInput",components:{VideoPlayer:q},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),ft={class:"relative"},_t={class:"flex mb-2"},ht={class:"text-sm font-bold"};function gt(e,t,f,h,w,E){const r=s("video-player");return a(),m("div",ft,[l("div",_t,[l("span",ht,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"])):p("",!0)])])}const $t=y(pt,[["render",gt]]),vt=k({name:"ConfigPanel",components:{LoopSelector:De,StartImageInput:tt,EndImageInput:Ke,EnhancementSelector:Ve,ElButton:U,FontAwesomeIcon:S,PromptInput:dt,ExtendFromInput:$t,CustomSelector:Ae,UploadVideo:rt,Consumption:se},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-5"},yt={class:"flex flex-col items-center justify-center px-5 pb-5"};function wt(e,t,f,h,w,E){const r=s("extend-from-input"),u=s("prompt-input"),d=s("custom-selector"),g=s("upload-video"),v=s("start-image-input"),n=s("end-image-input"),V=s("enhancement-selector"),T=s("loop-selector"),I=s("consumption"),G=s("font-awesome-icon"),M=s("el-button");return a(),m("div",bt,[l("div",kt,[e.config?.video_id||e.config?.video_url?(a(),$(r,{key:0,class:"mb-4"})):p("",!0),o(u,{class:"mb-4"}),e.config?.video_id?p("",!0):(a(),$(d,{key:1,class:"mb-4"})),e.config?.custom?(a(),$(g,{key:2,class:"mb-4"})):p("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),$(v,{key:3,class:"mb-4"})):p("",!0),o(n,{class:"mb-4"}),o(V,{class:"mb-4"}),o(T,{class:"mb-4"})]),l("div",yt,[o(I,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),$(M,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(G,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),$(M,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(G,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const Et=y(vt,[["render",wt]]),Vt=k({name:"TaskPreview",components:{ElImage:me,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:ce,VideoPlayer:q,ElTooltip:re,ElButton:U,ApiCodeButton:ie},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")}}}),St={class:"preview"},Ut={class:"left"},Lt={class:"main"},Tt={class:"bot"},It={class:"datetime"},Ct={class:"info"},jt={key:0,class:"prompt mt-2"},At={key:0},Rt={key:1},Pt={key:0,class:C({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},Mt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},zt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:C({content:!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ht={key:2,class:C({content:!0})},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Jt(e,t,f,h,w,E){const r=s("el-image"),u=s("video-player"),d=s("el-button"),g=s("el-tooltip"),v=s("api-code-button"),n=s("font-awesome-icon"),V=s("copy-to-clipboard"),T=s("el-alert");return a(),m("div",St,[l("div",Ut,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),l("div",Lt,[l("div",Tt,[_(i(e.$t("luma.name.lumaBot"))+" ",1),l("span",It,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Ct,[e.modelValue?.request?.prompt?(a(),m("p",jt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(a(),m("span",At," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Rt," - ("+i(e.$t("luma.status.processing"))+") ",1)):p("",!0)])):p("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Pt,[e.modelValue.response.video_url?(a(),m("div",Gt,[o(u,{src:e.modelValue.response.video_url},null,8,["src"])])):p("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Mt,[o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(d,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=F(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(d,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=F(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"]),o(v,{path:"/luma/videos",body:e.modelValue?.request},null,8,["body"])])):p("",!0),o(T,{closable:!1,class:"mt-2 success"},{default:c(()=>[l("p",Ft,[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",zt,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0)]),_:1})])):p("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",Bt,[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",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"])]),l("p",Ot,[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",qt,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),l("p",Nt,[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})])):p("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Ht,[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",xt,[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})])):p("",!0)])])}const Kt=y(Vt,[["render",Jt],["__scopeId","data-v-b96f3f79"]]),Qt=k({name:"RecentPanel",components:{BotPlaceholder:ue,TaskPreview:Kt,NoTasks:oe,ScrollList:Y},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?.()}}}),Wt={key:0},Xt={key:2,class:"w-full h-full flex items-center justify-center"};function Yt(e,t,f,h,w,E){const r=s("bot-placeholder"),u=s("task-preview"),d=s("scroll-list"),g=s("no-tasks");return a(),m(z,null,[e.tasks?.items===void 0?(a(),m("div",Wt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(d,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=v=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(z,null,H(e.tasks?.items,v=>(a(),$(u,{key:v.id,"model-value":v,onExtend:t[0]||(t[0]=n=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(a(),m("div",Xt,[o(g)])):p("",!0)],64)}const Zt=y(Qt,[["render",Yt]]),eo=K("luma"),to=k({name:"LumaIndex",components:{ConfigPanel:Et,Layout:ge,RecentPanel:Zt},inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===B.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===B.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 Z({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:f,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",f,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:f,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:eo};if(!this.hasText(e.prompt)){b.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}b.info(this.$t("luma.message.startingTask")),x("luma",J.generate(e,{token:t})).then(()=>{b.success(this.$t("luma.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===ae?b.error(this.$t("luma.message.usedUp")):b.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 oo(e,t,f,h,w,E){const r=s("config-panel"),u=s("recent-panel"),d=s("layout");return a(),$(d,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=g=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const Qo=y(to,[["render",oo]]);export{Qo as default};
|
|
1
|
+
import{F as S}from"./index.es-C8TbH2BC.js";import{E as U}from"./index-BVkFwr_L.js";import{E as N}from"./index-BSglm0Mh.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 p,M as F,Q as C,O as z,N as H}from"./vendor-vue-NSDaktjZ.js";import{H as y,bp as A,cs as x,aE as J,S as B,ct as K}from"./index-CX3Kkhe8.js";import{a as Q,b as W,c as X}from"./luma-DcySqBv2.js";import{I as L,S as Y,l as Z}from"./pagination-BCfNKuC9.js";import{E as R}from"./index-B5MFdHEY.js";import{p as D}from"./pasteUploadMixin-BurWbGNQ.js";import{I as O}from"./ImagePreview-BKqMFwxZ.js";import{E as P}from"./index-D8d_EiGA.js";import{E as b}from"./index-CBGglJJ1.js";import{F as ee}from"./FilePreview-a5f4UpE6.js";import{P as te,N as oe}from"./NoTasks-CF8uilN4.js";import{V as q}from"./VideoPlayer-B8hJJa4d.js";import{C as se}from"./Consumption-DJb3Zq85.js";import{a as ne}from"./price-DyHd8y4L.js";import{b as ae}from"./errorCode-Cqj9Td_Z.js";import{C as le}from"./CopyToClipboard-DszAErjC.js";import{A as ie}from"./ApiCodeButton-CkgmddPY.js";import{E as re}from"./index-CKC1QXPY.js";import{E as ce}from"./index-CTe-d_6k.js";import{E as me}from"./index-DQOSv-tV.js";import{B as ue}from"./BotPlaceholder-s0833dXM.js";import"./use-form-item-DLYZ0lkO.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Df5ITouH.js";import"./highlight-DcfXaBeC.js";import"./index-BLjywj98.js";import"./vendor-highlight-lEWW1Jxd.js";import"./validator-Dc1F-Mud.js";import"./index-B12SAORZ.js";import"./index-B0tmHD6W.js";import"./typescript-Jtl3VF26.js";import"./_baseClone-DZKAu36s.js";import"./_Uint8Array-dMcWmqZF.js";import"./_initCloneObject-BsCXP6pc.js";import"./isEqual-C_dkvvUP.js";import"./index-BfwtSiqw.js";import"./index-tO5MdGXt.js";import"./vue-plyr-BO2nlN4c.js";import"./debounce-fzRpYvTx.js";import"./index-TJBAFmkH.js";const de=k({name:"LayoutLuma",components:{ElDrawer:N,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),pe={class:"main flex flex-row flex-1"},fe={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 he(e,t,f,h,w,E){const r=s("font-awesome-icon"),u=s("el-button"),d=s("el-drawer");return a(),m("div",pe,[l("div",fe,[j(e.$slots,"config",{},void 0,!0)]),l("div",_e,[j(e.$slots,"result",{},void 0,!0)]),o(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(d,{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 ge=y(de,[["render",he],["__scopeId","data-v-fdc8f36b"]]),$e=k({name:"EnhancementSelector",components:{ElSwitch:R,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=Q)}}),ve={class:"relative"},be={class:"flex justify-between"},ke={class:"flex justify-start items-center"},ye={class:"text-sm font-bold"},we={class:"flex justify-end items-center"};function Ee(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",ve,[l("div",be,[l("div",ke,[l("span",ye,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),l("div",we,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const Ve=y($e,[["render",Ee]]),Se=k({name:"CustomSelector",components:{ElSwitch:R,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=W)}}),Ue={class:"relative"},Le={class:"flex justify-between"},Te={class:"flex justify-start items-center"},Ie={class:"text-sm font-bold"},Ce={class:"flex justify-end items-center"};function je(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",Ue,[l("div",Le,[l("div",Te,[l("span",Ie,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),l("div",Ce,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const Ae=y(Se,[["render",je]]),Re=k({name:"LoopSelector",components:{ElSwitch:R,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=X)}}),Pe={class:"relative"},Ge={class:"flex justify-between"},Me={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"},ze={class:"flex justify-end items-center"};function Be(e,t,f,h,w,E){const r=s("info-icon"),u=s("el-switch");return a(),m("div",Pe,[l("div",Ge,[l("div",Me,[l("span",Fe,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),l("div",ze,[o(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])])}const De=y(Re,[["render",Be]]),Oe=k({name:"EndImage",components:{ElUpload:P,ElButton:U,ImagePreview:O,InfoIcon:L,FontAwesomeIcon:S},mixins:[D],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(){b.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){b.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()}}}),qe={class:"relative"},Ne={class:"flex justify-between"},He={class:"flex justify-start items-center"},xe={class:"text-sm font-bold"};function Je(e,t,f,h,w,E){const r=s("info-icon"),u=s("image-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",qe,[l("div",Ne,[l("div",He,[l("span",xe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(v,{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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 Ke=y(Oe,[["render",Je],["__scopeId","data-v-7a787b4d"]]),Qe=k({name:"StartImage",components:{ElUpload:P,ElButton:U,ImagePreview:O,InfoIcon:L,FontAwesomeIcon:S},mixins:[D],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(){b.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){b.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()}}}),We={class:"relative"},Xe={class:"flex justify-between"},Ye={class:"flex justify-start items-center"},Ze={class:"text-sm font-bold"};function et(e,t,f,h,w,E){const r=s("info-icon"),u=s("image-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",We,[l("div",Xe,[l("div",Ye,[l("span",Ze,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(v,{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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 tt=y(Qe,[["render",et],["__scopeId","data-v-8c5cfe84"]]),ot=k({name:"UploadVideo",components:{ElUpload:P,ElButton:U,InfoIcon:L,FilePreview:ee,FontAwesomeIcon:S},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(){b.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){b.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",f=e.size/1024/1024<10;return t?f?!0:(b.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(b.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()}}}),st={class:"relative"},nt={class:"flex justify-between"},at={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function it(e,t,f,h,w,E){const r=s("info-icon"),u=s("file-preview"),d=s("font-awesome-icon"),g=s("el-button"),v=s("el-upload");return a(),m("div",st,[l("div",nt,[l("div",at,[l("span",lt,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(v,{"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(),$(u,{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"])):p("",!0)]),default:c(()=>[o(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(d,{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 rt=y(ot,[["render",it],["__scopeId","data-v-74e51526"]]),ct="",mt=k({name:"PromptInput",components:{PromptTextarea:te},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=ct)}});function ut(e,t,f,h,w,E){const r=s("prompt-textarea");return a(),$(r,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),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 dt=y(mt,[["render",ut]]),pt=k({name:"ExtendFromInput",components:{VideoPlayer:q},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),ft={class:"relative"},_t={class:"flex mb-2"},ht={class:"text-sm font-bold"};function gt(e,t,f,h,w,E){const r=s("video-player");return a(),m("div",ft,[l("div",_t,[l("span",ht,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"])):p("",!0)])])}const $t=y(pt,[["render",gt]]),vt=k({name:"ConfigPanel",components:{LoopSelector:De,StartImageInput:tt,EndImageInput:Ke,EnhancementSelector:Ve,ElButton:U,FontAwesomeIcon:S,PromptInput:dt,ExtendFromInput:$t,CustomSelector:Ae,UploadVideo:rt,Consumption:se},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-5"},yt={class:"flex flex-col items-center justify-center px-5 pb-5"};function wt(e,t,f,h,w,E){const r=s("extend-from-input"),u=s("prompt-input"),d=s("custom-selector"),g=s("upload-video"),v=s("start-image-input"),n=s("end-image-input"),V=s("enhancement-selector"),T=s("loop-selector"),I=s("consumption"),G=s("font-awesome-icon"),M=s("el-button");return a(),m("div",bt,[l("div",kt,[e.config?.video_id||e.config?.video_url?(a(),$(r,{key:0,class:"mb-4"})):p("",!0),o(u,{class:"mb-4"}),e.config?.video_id?p("",!0):(a(),$(d,{key:1,class:"mb-4"})),e.config?.custom?(a(),$(g,{key:2,class:"mb-4"})):p("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),$(v,{key:3,class:"mb-4"})):p("",!0),o(n,{class:"mb-4"}),o(V,{class:"mb-4"}),o(T,{class:"mb-4"})]),l("div",yt,[o(I,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),$(M,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(G,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),$(M,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(G,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const Et=y(vt,[["render",wt]]),Vt=k({name:"TaskPreview",components:{ElImage:me,CopyToClipboard:le,FontAwesomeIcon:S,ElAlert:ce,VideoPlayer:q,ElTooltip:re,ElButton:U,ApiCodeButton:ie},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")}}}),St={class:"preview"},Ut={class:"left"},Lt={class:"main"},Tt={class:"bot"},It={class:"datetime"},Ct={class:"info"},jt={key:0,class:"prompt mt-2"},At={key:0},Rt={key:1},Pt={key:0,class:C({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},Mt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},zt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:C({content:!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ht={key:2,class:C({content:!0})},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Jt(e,t,f,h,w,E){const r=s("el-image"),u=s("video-player"),d=s("el-button"),g=s("el-tooltip"),v=s("api-code-button"),n=s("font-awesome-icon"),V=s("copy-to-clipboard"),T=s("el-alert");return a(),m("div",St,[l("div",Ut,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),l("div",Lt,[l("div",Tt,[_(i(e.$t("luma.name.lumaBot"))+" ",1),l("span",It,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Ct,[e.modelValue?.request?.prompt?(a(),m("p",jt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?p("",!0):(a(),m("span",At," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Rt," - ("+i(e.$t("luma.status.processing"))+") ",1)):p("",!0)])):p("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Pt,[e.modelValue.response.video_url?(a(),m("div",Gt,[o(u,{src:e.modelValue.response.video_url},null,8,["src"])])):p("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Mt,[o(g,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(d,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=F(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(d,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=F(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[_(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"]),o(v,{path:"/luma/videos",body:e.modelValue?.request},null,8,["body"])])):p("",!0),o(T,{closable:!1,class:"mt-2 success"},{default:c(()=>[l("p",Ft,[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",zt,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0)]),_:1})])):p("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",Bt,[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",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"])]),l("p",Ot,[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",qt,[o(n,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+i(e.$t("luma.name.elapsed"))+": "+i(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):p("",!0),l("p",Nt,[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})])):p("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Ht,[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",xt,[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})])):p("",!0)])])}const Kt=y(Vt,[["render",Jt],["__scopeId","data-v-b96f3f79"]]),Qt=k({name:"RecentPanel",components:{BotPlaceholder:ue,TaskPreview:Kt,NoTasks:oe,ScrollList:Y},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?.()}}}),Wt={key:0},Xt={key:2,class:"w-full h-full flex items-center justify-center"};function Yt(e,t,f,h,w,E){const r=s("bot-placeholder"),u=s("task-preview"),d=s("scroll-list"),g=s("no-tasks");return a(),m(z,null,[e.tasks?.items===void 0?(a(),m("div",Wt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(d,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=v=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(z,null,H(e.tasks?.items,v=>(a(),$(u,{key:v.id,"model-value":v,onExtend:t[0]||(t[0]=n=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):p("",!0),e.tasks?.items?.length===0?(a(),m("div",Xt,[o(g)])):p("",!0)],64)}const Zt=y(Qt,[["render",Yt]]),eo=K("luma"),to=k({name:"LumaIndex",components:{ConfigPanel:Et,Layout:ge,RecentPanel:Zt},inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===B.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===B.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 Z({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:f,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",f,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:f,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:eo};if(!this.hasText(e.prompt)){b.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}b.info(this.$t("luma.message.startingTask")),x("luma",J.generate(e,{token:t})).then(()=>{b.success(this.$t("luma.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===ae?b.error(this.$t("luma.message.usedUp")):b.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 oo(e,t,f,h,w,E){const r=s("config-panel"),u=s("recent-panel"),d=s("layout");return a(),$(d,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=g=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const Qo=y(to,[["render",oo]]);export{Qo as default};
|