@acedatacloud/nexior 3.161.0 → 3.162.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{Auth-CpcLt2vT.js → Auth-CWHfE0Bh.js} +1 -1
- package/dist/assets/{BotPlaceholder-CgQaozFd.js → BotPlaceholder-CXwVfZf3.js} +1 -1
- package/dist/assets/{Callback-XIcKtgeu.js → Callback-Dw23ybg2.js} +1 -1
- package/dist/assets/{Console-iGDAn1AB.js → Console-Bg3a295D.js} +1 -1
- package/dist/assets/{Consumption-BAuQo1e2.js → Consumption-B9gj7rI5.js} +1 -1
- package/dist/assets/{Conversation-D2MzdiXP.js → Conversation-DmfA3sxW.js} +1 -1
- package/dist/assets/{CopyToClipboard-xH0KM_v3.js → CopyToClipboard-DDFChBm_.js} +1 -1
- package/dist/assets/{Detail-DeyunG35.js → Detail-T7f3rgnJ.js} +2 -2
- package/dist/assets/{EditArray-B-nopcci.js → EditArray-bLEJluIK.js} +1 -1
- package/dist/assets/{Extra-Be5RFlxq.js → Extra-Ckc1_mtB.js} +1 -1
- package/dist/assets/{FilePreview-DoxaIVT3.js → FilePreview-DyYhukMl.js} +1 -1
- package/dist/assets/{History-SVl25gkj.js → History-CpZWNn_D.js} +1 -1
- package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-ATzwHgJm.js → IconPark.vue_vue_type_script_setup_true_lang-CcuE7020.js} +1 -1
- package/dist/assets/{ImagePreview-DGZ7oqeM.js → ImagePreview-B4dl6UUl.js} +1 -1
- package/dist/assets/{ImageWrapper-VTIP1F-X.js → ImageWrapper-C7KzvBjb.js} +1 -1
- package/dist/assets/{Index-DdIutAqa.js → Index-B-Rv66fr.js} +1 -1
- package/dist/assets/{Index-DJd9CohY.js → Index-B1WMh0J2.js} +1 -1
- package/dist/assets/{Index-DxqgZ26w.js → Index-B6CaUc6p.js} +1 -1
- package/dist/assets/{Index-DsN81EaJ.js → Index-BKKy5L-L.js} +1 -1
- package/dist/assets/{Index-B93bGWwB.js → Index-BhyqSwgS.js} +1 -1
- package/dist/assets/{Index-DhJs8imW.js → Index-Bm4QYO2z.js} +1 -1
- package/dist/assets/{Index-zGrnmQPw.js → Index-BnqYI8B1.js} +1 -1
- package/dist/assets/{Index-CqQYaTWz.js → Index-BrI905TY.js} +1 -1
- package/dist/assets/{Index-Dek7Kv__.js → Index-C8m5rWSy.js} +1 -1
- package/dist/assets/{Index-bSFLv51I.js → Index-CGu_vtvZ.js} +1 -1
- package/dist/assets/{Index-B1AhHCTX.js → Index-CNz_7K-8.js} +1 -1
- package/dist/assets/{Index-DsN14gKA.js → Index-CbE8WDa2.js} +1 -1
- package/dist/assets/{Index-Dan8kHKu.js → Index-CnakrVzF.js} +1 -1
- package/dist/assets/{Index-CHdMILNr.js → Index-D7kqYKA9.js} +1 -1
- package/dist/assets/{Index-CAs9UwfR.js → Index-D7qfY-Vs.js} +1 -1
- package/dist/assets/{Index-CieypG1m.js → Index-DCOvvWff.js} +1 -1
- package/dist/assets/{Index-DCK3-tkl.js → Index-DT0U1fYz.js} +1 -1
- package/dist/assets/{Index-dFPw-bPh.js → Index-EiKae0LE.js} +1 -1
- package/dist/assets/{Index-p4zdKBty.css → Index-L6J0zIbC.css} +1 -1
- package/dist/assets/{Index-BT4PtX1H.js → Index-Y8KKS5YR.js} +1 -1
- package/dist/assets/Index-h7_qcwYp.js +4 -0
- package/dist/assets/{Index-BKrTisc3.js → Index-iAMtAGA1.js} +1 -1
- package/dist/assets/{Index-Dp5RvHAQ.js → Index-lJMndMZ7.js} +1 -1
- package/dist/assets/{Index-DjcLbhz1.js → Index-nAlGJ2aj.js} +1 -1
- package/dist/assets/{Index-BHYSuOLZ.js → Index-uP5bcZ9C.js} +1 -1
- package/dist/assets/{Invitees-Ceigs5q5.js → Invitees-CXmMeXs_.js} +1 -1
- package/dist/assets/{List-DIh4RYuR.js → List-BCqzCUGp.js} +1 -1
- package/dist/assets/{List-Dgr4ALG5.js → List-BqMcDV57.js} +1 -1
- package/dist/assets/{List-Bb7-iXMj.js → List-C5_DWyZb.js} +1 -1
- package/dist/assets/{Main-CKt4YLzV.js → Main-DUe8uFEY.js} +1 -1
- package/dist/assets/{Navigator-BnT-MYC7.js → Navigator-caj9NvyO.js} +1 -1
- package/dist/assets/{NoTasks-DU0uzui_.js → NoTasks-C0_ki8Ur.js} +1 -1
- package/dist/assets/{NotFound-BK3ymGrm.js → NotFound-BZ0PjgkI.js} +1 -1
- package/dist/assets/{OAuthCallback-CMYTmd8z.js → OAuthCallback-rJGNyWEb.js} +1 -1
- package/dist/assets/{Pagination-CbgzDlhE.js → Pagination-3WwpcEG-.js} +1 -1
- package/dist/assets/{Status-D8FxOB1-.js → Status-B-3tIyiq.js} +1 -1
- package/dist/assets/{Subscribe-CJeecCn1.js → Subscribe-BzCSim6_.js} +1 -1
- package/dist/assets/{VideoPlayer-DgUHZO4e.js → VideoPlayer-lbflQfYO.js} +1 -1
- package/dist/assets/{_Uint8Array-2EjSTOVM.js → _Uint8Array-rxEgK7pZ.js} +1 -1
- package/dist/assets/{_baseClone-2UOH3err.js → _baseClone-CoFSI4Xz.js} +1 -1
- package/dist/assets/{_baseIteratee-DVlaYH87.js → _baseIteratee-BP_fhl98.js} +1 -1
- package/dist/assets/{_initCloneObject-DAZlR5GD.js → _initCloneObject-CSU1ND3o.js} +1 -1
- package/dist/assets/{add-I3t7GHIL.js → add-C-CLMzx4.js} +1 -1
- package/dist/assets/{all-wallets-7Sk0dMqZ.js → all-wallets-Dh-3cIg_.js} +1 -1
- package/dist/assets/{app-store-Cw0T_98Q.js → app-store-CdSIGe2k.js} +1 -1
- package/dist/assets/{apple-C2WfoOKP.js → apple-DoADcqi3.js} +1 -1
- package/dist/assets/{arrow-bottom-CwKUPE1n.js → arrow-bottom-CyFvfalx.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-RWPUYPdV.js → arrow-bottom-circle-BR8RckwT.js} +1 -1
- package/dist/assets/{arrow-left-DQE0G8Mm.js → arrow-left-BH_EVnIw.js} +1 -1
- package/dist/assets/{arrow-right-C29RE3GX.js → arrow-right-DZJdpv__.js} +1 -1
- package/dist/assets/{arrow-top-ByMT0KNT.js → arrow-top-Bl_NWuCO.js} +1 -1
- package/dist/assets/{avatar-xpMTiIN5.js → avatar-Cxest084.js} +1 -1
- package/dist/assets/{bank-tCExOHgi.js → bank-CtFLQcXv.js} +1 -1
- package/dist/assets/{basic-C_GetQST.js → basic-CN6GoObg.js} +1 -1
- package/dist/assets/{browser-DLQ_b3OP.js → browser-DnMqFLoO.js} +1 -1
- package/dist/assets/{byokCredential-a8CIByf1.js → byokCredential-BxxS0esT.js} +1 -1
- package/dist/assets/{card-dSKSJVcP.js → card-B8cMPY-O.js} +1 -1
- package/dist/assets/{castArray-D6XtIb4l.js → castArray-B2H9FWSG.js} +1 -1
- package/dist/assets/{chat-BZiF8CyO.js → chat-BDzBUqAR.js} +1 -1
- package/dist/assets/{checkmark-CxgXVVO6.js → checkmark-BYdSr5Xt.js} +1 -1
- package/dist/assets/{checkmark-bold-Bszgrz3E.js → checkmark-bold-AuGKAxQn.js} +1 -1
- package/dist/assets/{chevron-bottom-DD7tXe7i.js → chevron-bottom-BRHconub.js} +1 -1
- package/dist/assets/{chevron-left-DCO7_CZs.js → chevron-left-CNrelQQT.js} +1 -1
- package/dist/assets/{chevron-right-RU-vUzJw.js → chevron-right-D8pwAoEL.js} +1 -1
- package/dist/assets/{chevron-top-D8I609WR.js → chevron-top-DLsAFSc5.js} +1 -1
- package/dist/assets/{chrome-store-Dkc6TYe-.js → chrome-store-Cd-rdHtd.js} +1 -1
- package/dist/assets/{clock-D-gIMdDp.js → clock-CDKOVWN3.js} +1 -1
- package/dist/assets/{close-BqRefEjl.js → close-DA6-jRe4.js} +1 -1
- package/dist/assets/{coinPlaceholder-CVmWc3vH.js → coinPlaceholder-CkJiixxL.js} +1 -1
- package/dist/assets/{compass-B-GzJTCl.js → compass-B9Z1VADa.js} +1 -1
- package/dist/assets/{copy-fgfnUt6T.js → copy-C_pc6iuN.js} +1 -1
- package/dist/assets/{createTaskActions-B4PvZTT2.js → createTaskActions-Dl49i_JA.js} +1 -1
- package/dist/assets/{cursor-eiY2b9bj.js → cursor-DHA3q7im.js} +1 -1
- package/dist/assets/{cursor-transparent-gU1IASKK.js → cursor-transparent-CAkIxYll.js} +1 -1
- package/dist/assets/{debounce-B0cNnAb0.js → debounce-BCcGKj6U.js} +1 -1
- package/dist/assets/{desktop-Cl0FW9s9.js → desktop-Oal_Kgcg.js} +1 -1
- package/dist/assets/{disconnect-DM3lVWr-.js → disconnect-BCyBuxxI.js} +1 -1
- package/dist/assets/{discord-BgpvWQJl.js → discord-CR2jyXtu.js} +1 -1
- package/dist/assets/{distribution-DlLX3VKX.js → distribution-XQH4Lhk5.js} +1 -1
- package/dist/assets/{dropdown-BtMIJ752.js → dropdown-8Ina1NwG.js} +1 -1
- package/dist/assets/{etherscan-CDu0uBuq.js → etherscan-CzaUnJ8A.js} +1 -1
- package/dist/assets/{exclamation-triangle-nS7swnIX.js → exclamation-triangle-DDijLHzr.js} +1 -1
- package/dist/assets/{extension-D8e-WYOn.js → extension-CSnCETai.js} +1 -1
- package/dist/assets/{external-link-DeNj9ya2.js → external-link-CyYDZYYR.js} +1 -1
- package/dist/assets/{facebook-C95gRhCM.js → facebook-C6OPBKIT.js} +1 -1
- package/dist/assets/{farcaster-_yD9EJN_.js → farcaster-NItkH33M.js} +1 -1
- package/dist/assets/{filters-BmRxULI-.js → filters-D70SWWN6.js} +1 -1
- package/dist/assets/{github-C3Yoy6HZ.js → github-BD6D60VA.js} +1 -1
- package/dist/assets/{google-B2AayU98.js → google-CL4CHBLv.js} +1 -1
- package/dist/assets/{help-circle-Fe1adh5-.js → help-circle-Bb4YjXkd.js} +1 -1
- package/dist/assets/{id-DRbeQYiu.js → id-Bg7DotmK.js} +1 -1
- package/dist/assets/{image-Dg3pn3jA.js → image-COisjBw3.js} +1 -1
- package/dist/assets/{index-VDjEZxyM.js → index-AyRUBxd4.js} +1 -1
- package/dist/assets/{index-DxfhxYM4.js → index-BEXNUoMv.js} +1 -1
- package/dist/assets/{index-DBD1EdKB.js → index-BIiWMqeL.js} +1 -1
- package/dist/assets/{index-Dp0pjyQ0.js → index-BKDppBCe.js} +1 -1
- package/dist/assets/{index-fPj0tuiF.js → index-BKKI0C_o.js} +1 -1
- package/dist/assets/{index-BMk-Pl3g.js → index-BalKdl4I.js} +1 -1
- package/dist/assets/{index-DOAkon7d.js → index-BcQ33bMX.js} +1 -1
- package/dist/assets/{index-hcePUtjE.js → index-Bil93Tro.js} +1 -1
- package/dist/assets/{index-yALECCM6.js → index-Bn-yW66l.js} +1 -1
- package/dist/assets/{index-LoWJ4KKR.js → index-Bn6bJIWW.js} +1 -1
- package/dist/assets/{index-DX8zNYsa.js → index-BqvdpzbI.js} +1 -1
- package/dist/assets/{index-M_ZJ9Qlm.js → index-BrOvr1pb.js} +1 -1
- package/dist/assets/{index-Bvlr6bsR.js → index-BtzJAibB.js} +1 -1
- package/dist/assets/{index-Pzo9boTC.js → index-Bwrk7Ay6.js} +1 -1
- package/dist/assets/{index-DG99WPjV.js → index-BzQJoc4N.js} +1 -1
- package/dist/assets/{index-C2BPUvws.js → index-C1nFLlUB.js} +1 -1
- package/dist/assets/{index-D07JwD1d.js → index-C5h9Q8MC.js} +1 -1
- package/dist/assets/{index-DfU567fa.js → index-C7UOzYYd.js} +1 -1
- package/dist/assets/{index-DSNKkQGC.js → index-CBWw2dqX.js} +1 -1
- package/dist/assets/{index-Dt21I4XP.js → index-CCYrnVY8.js} +1 -1
- package/dist/assets/{index-4EfdjHi4.js → index-CF1ww37w.js} +1 -1
- package/dist/assets/{index-DS1vID1S.js → index-CG04RGrn.js} +1 -1
- package/dist/assets/{index-ArWqC8tb.js → index-CHYLT97t.js} +1 -1
- package/dist/assets/{index-DT2j3exg.js → index-COuezDm-.js} +1 -1
- package/dist/assets/{index-kI_SRykN.js → index-CQbxCkA3.js} +1 -1
- package/dist/assets/{index-CdGHWSQH.js → index-CRznp8jk.js} +1 -1
- package/dist/assets/{index-8pPfeJLV.js → index-CYDHERfE.js} +1 -1
- package/dist/assets/{index-BUpZCQK_.js → index-CYL-RFc_.js} +1 -1
- package/dist/assets/{index-edzWiPyh.js → index-Cm5OjimQ.js} +1 -1
- package/dist/assets/{index-CjeotSID.js → index-CpzfV0pW.js} +1 -1
- package/dist/assets/{index-DmXTqBpY.js → index-Cu2Po3TS.js} +1 -1
- package/dist/assets/{index-DWHfebYD.js → index-CuDB9gdd.js} +1 -1
- package/dist/assets/{index-Cc68OwIQ.js → index-Cyxq6Qua.js} +2 -2
- package/dist/assets/{index-CO6cZXtz.js → index-D5rOlNGq.js} +1 -1
- package/dist/assets/{index-BjyoQSky.js → index-D7HrNCd6.js} +1 -1
- package/dist/assets/{index-B1PmZ-Iv.js → index-DAqtSXwe.js} +1 -1
- package/dist/assets/{index-NVe0BNO7.js → index-DLqlJAfA.js} +1 -1
- package/dist/assets/{index-BjU0US3H.js → index-DQ7BtYvz.js} +1 -1
- package/dist/assets/{index-DCmJO0II.js → index-DRXhgLGg.js} +1 -1
- package/dist/assets/{index-DOgVrFpt.js → index-DfBSnkgR.js} +1 -1
- package/dist/assets/{index-ClganCen.js → index-Dh-jNQrR.js} +1 -1
- package/dist/assets/{index-BsybLqXJ.js → index-DnRc5FMB.js} +1 -1
- package/dist/assets/{index-DMx4rfx5.js → index-Do96V_OF.js} +3 -3
- package/dist/assets/{index-BFo_7vC0.js → index-DpZxJ0M6.js} +1 -1
- package/dist/assets/{index-ChCvgMG8.js → index-DtdH4elb.js} +1 -1
- package/dist/assets/{index-CmJw_And.js → index-DvFXOuuR.js} +1 -1
- package/dist/assets/{index-DoOEsk7K.js → index-FOpEkA01.js} +1 -1
- package/dist/assets/{index-J_i8qnoy.js → index-JI-AWDGe.js} +1 -1
- package/dist/assets/{index-CSaI_dNr.js → index-L20hlNKs.js} +1 -1
- package/dist/assets/{index-wGx3TVaC.js → index-RD-mMB30.js} +1 -1
- package/dist/assets/{index-CjoIDD-m.js → index-UzoKOEii.js} +1 -1
- package/dist/assets/{index-DGVo3tsQ.js → index-XdDjb_qZ.js} +1 -1
- package/dist/assets/{index-DRAEmvEe.js → index-Xv72FIVH.js} +4 -4
- package/dist/assets/{index-DSs-PC8-.js → index-ZTLaZITs.js} +1 -1
- package/dist/assets/{index-DtYZFyNQ.js → index-aZuO1MNl.js} +1 -1
- package/dist/assets/{index-BVvt3gwI.js → index-b2PBMUP6.js} +1 -1
- package/dist/assets/{index-Cnbd1x_y.js → index-luTn-W_l.js} +1 -1
- package/dist/assets/{index-BvsaGt86.js → index-mHJfpS-g.js} +5 -5
- package/dist/assets/{index-BbNbrIc9.js → index-n8xs681c.js} +1 -1
- package/dist/assets/{index-culWwCup.js → index-oZSQuc3z.js} +1 -1
- package/dist/assets/{index.browser.esm-CsWWCj92.js → index.browser.esm-C0AjK3ok.js} +1 -1
- package/dist/assets/{index.es-D_EPO5M5.js → index.es-DD6X2EPt.js} +1 -1
- package/dist/assets/{info-DaKQ2KCT.js → info-C4KMlAq1.js} +1 -1
- package/dist/assets/{info-circle-2EZ3G5yw.js → info-circle-DGSR70Sk.js} +1 -1
- package/dist/assets/{isEqual-Djts47Qq.js → isEqual-CbZBrtf3.js} +1 -1
- package/dist/assets/{isPlainObject-CwrPn4To.js → isPlainObject-D2wVAlac.js} +1 -1
- package/dist/assets/{lightbulb-DLjrDKzm.js → lightbulb-DY3RCbyM.js} +1 -1
- package/dist/assets/{mail-B51tKB2H.js → mail-SdbEDESl.js} +1 -1
- package/dist/assets/{midjourney-kgYBaYP_.js → midjourney-_lDhk07O.js} +1 -1
- package/dist/assets/{mobile-Dl7zUoDd.js → mobile-EgH74Rl2.js} +1 -1
- package/dist/assets/{more-DbNI4Bya.js → more-C960U83D.js} +1 -1
- package/dist/assets/{network-placeholder-CxHY1Z8E.js → network-placeholder-ilnAmgqr.js} +1 -1
- package/dist/assets/{nftPlaceholder-BRhNVyad.js → nftPlaceholder-Csn0_dzo.js} +1 -1
- package/dist/assets/{off-6N6RBlhz.js → off-DROmGaJg.js} +1 -1
- package/dist/assets/{order-BxnzxMEa.js → order-BiuGmqe-.js} +1 -1
- package/dist/assets/{pagination-6N8Zy2ln.js → pagination-DI9u8VbS.js} +1 -1
- package/dist/assets/{play-store-CQlGE7tu.js → play-store-C8S-7L4p.js} +1 -1
- package/dist/assets/{plus-BAAts9zS.js → plus-B6Adqxdl.js} +1 -1
- package/dist/assets/{price-D9OTezDw.js → price-DnUP-rdM.js} +1 -1
- package/dist/assets/{producer-CvaNdA04.js → producer-DYPve2Lw.js} +1 -1
- package/dist/assets/{qr-code-BnSNgbhV.js → qr-code-L3f67Lhc.js} +1 -1
- package/dist/assets/{recycle-horizontal-BzZJE4io.js → recycle-horizontal-BOptpUSq.js} +1 -1
- package/dist/assets/{refresh-Cux-Tv6g.js → refresh-Dg1bee-F.js} +1 -1
- package/dist/assets/{reown-logo-CSjlTqKj.js → reown-logo-OHOdgqET.js} +1 -1
- package/dist/assets/{search-DRrWaqaJ.js → search-qTm4Fy3p.js} +1 -1
- package/dist/assets/{secp256k1-R9Jakyzr.js → secp256k1-CCOfCah1.js} +1 -1
- package/dist/assets/{secp256k1-CSBvE1SJ.js → secp256k1-DyBLShZg.js} +1 -1
- package/dist/assets/{seedream-D1V8Yyvw.js → seedream-B_e-kC75.js} +1 -1
- package/dist/assets/{send-2B5lJBII.js → send-Cng2Agiv.js} +1 -1
- package/dist/assets/{service-CUzkZhtA.js → service-DCBP4w6C.js} +1 -1
- package/dist/assets/{solana-wallets-r6KthkHj.js → solana-wallets-CHdd2Soi.js} +2 -2
- package/dist/assets/{solana-wallets-vue-DHVG3Tx3.js → solana-wallets-vue-DXdQA3wF.js} +1 -1
- package/dist/assets/{suno-DfNwyKU0.js → suno-Bk-Q7Yhc.js} +1 -1
- package/dist/assets/{suno-CpZzO8rh.js → suno-BrgQ_BvV.js} +1 -1
- package/dist/assets/{suno-DPJDiEzx.js → suno-VHZnREr3.js} +1 -1
- package/dist/assets/{swapHorizontal-C1IV4Lld.js → swapHorizontal-ClcM19xY.js} +1 -1
- package/dist/assets/{swapHorizontalBold-D8Fp8FGA.js → swapHorizontalBold-C2zOVAGI.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-DRP9-j70.js → swapHorizontalMedium-DfWzT06C.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-DCpP0wfg.js → swapHorizontalRoundedBold-CzWrlugC.js} +1 -1
- package/dist/assets/{swapVertical-DzaHmjrA.js → swapVertical-BEuzT43E.js} +1 -1
- package/dist/assets/{telegram-Crco7bSr.js → telegram-Vz49BmbI.js} +1 -1
- package/dist/assets/{three-dots-DwxWDCDz.js → three-dots-DIxrWEUM.js} +1 -1
- package/dist/assets/{twitch-DG-RN6s7.js → twitch-NB_CnOrf.js} +1 -1
- package/dist/assets/{twitterIcon-iDs2w_6E.js → twitterIcon-CurNDEql.js} +1 -1
- package/dist/assets/{typescript-Ds5Nsy-o.js → typescript-B81uJgVE.js} +1 -1
- package/dist/assets/{use-form-item-DYeima3c.js → use-form-item-C7Jxi2ST.js} +1 -1
- package/dist/assets/validator-DtSW4gh2.js +1 -0
- package/dist/assets/{verify-BTyHKiKz.js → verify-7dT2G6tU.js} +1 -1
- package/dist/assets/{verify-filled-Cfp0V02M.js → verify-filled-HokfQN4y.js} +1 -1
- package/dist/assets/{w3m-modal-pSvj7Gbk.js → w3m-modal-BX4u6n70.js} +1 -1
- package/dist/assets/{wallet-COThotjS.js → wallet-DxYDyUIW.js} +1 -1
- package/dist/assets/{wallet-placeholder-BBWnPJ9E.js → wallet-placeholder-gz3NJUtM.js} +1 -1
- package/dist/assets/{walletconnect-D0UE1by-.js → walletconnect-2MoQnfGl.js} +1 -1
- package/dist/assets/{warning-circle-hB3nocYG.js → warning-circle-BjICCYBI.js} +1 -1
- package/dist/assets/{web-BLXcEe-x.js → web-CaAeAsJT.js} +1 -1
- package/dist/assets/{web-CvLX5Atw.js → web-Dm4lgJzB.js} +1 -1
- package/dist/assets/{x-CApun9Ic.js → x-BFi7xuLm.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Index-ChYSYjFQ.js +0 -4
- package/dist/assets/validator-6aZKx5Gq.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as P}from"./index.es-D_EPO5M5.js";import{E as U}from"./index-J_i8qnoy.js";import{E as X}from"./index-DfU567fa.js";import{d as b,H as i,E as r,z as L,C as a,y as p,D as n,q as t,F as l,O as E,N as T,x as m,Q as C,R as Y,J as d,I as _}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as Q,cr as W,aJ as K,S as M,cs as Z}from"./index-DRAEmvEe.js";import{a as x,b as ee,c as oe,d as te,e as se,f as ne,g as G,h as ae,i as le,j as ie}from"./veo-Dg8Zhpd-.js";import{E as A,a as O}from"./index-Bvlr6bsR.js";import{I as j,S as re,l as ce}from"./pagination-6N8Zy2ln.js";import{E as de}from"./index-B1PmZ-Iv.js";import{V as D}from"./VideoPlayer-DgUHZO4e.js";import{E as R}from"./index-8pPfeJLV.js";import{p as ue}from"./pasteUploadMixin-BurWbGNQ.js";import{I as pe}from"./ImagePreview-DGZ7oqeM.js";import{E as me}from"./index-CSaI_dNr.js";import{E as I}from"./index-DSs-PC8-.js";import{C as ve}from"./Consumption-BAuQo1e2.js";import{a as fe}from"./price-D9OTezDw.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as he}from"./CopyToClipboard-xH0KM_v3.js";import{E as $e}from"./index-CdGHWSQH.js";import{E as ge}from"./index-BbNbrIc9.js";import{E as be}from"./index-DWHfebYD.js";import{B as ke}from"./BotPlaceholder-CgQaozFd.js";import{N as ye}from"./NoTasks-DU0uzui_.js";import"./use-form-item-DYeima3c.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-DS1vID1S.js";import"./typescript-Ds5Nsy-o.js";import"./index-BUpZCQK_.js";import"./strings-beZM2Y-f.js";import"./isEqual-Djts47Qq.js";import"./_Uint8Array-2EjSTOVM.js";import"./castArray-D6XtIb4l.js";import"./debounce-B0cNnAb0.js";import"./_baseIteratee-DVlaYH87.js";import"./index-4EfdjHi4.js";import"./validator-6aZKx5Gq.js";import"./vue-plyr-BO2nlN4c.js";import"./index-DoOEsk7K.js";import"./index-CjoIDD-m.js";import"./_baseClone-2UOH3err.js";import"./_initCloneObject-DAZlR5GD.js";import"./index-ArWqC8tb.js";const Ve=b({name:"LayoutVeo",components:{ElDrawer:X,ElButton:U,FontAwesomeIcon:P},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ee={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ie={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Te(e,o,v,f,y,V){const c=n("font-awesome-icon"),u=n("el-button"),s=n("el-drawer");return t(),i("div",we,[r("div",Ee,[L(e.$slots,"config",{},void 0,!0)]),r("div",Ie,[L(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:p(()=>[a(c,{icon:"fa-solid fa-magic"})]),_:1}),a(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Se=k(Ve,[["render",Te],["__scopeId","data-v-816b984c"]]),Ce=b({name:"ModelSelector",components:{ElSelect:O,ElOption:A},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=x)}}),Ae={class:"field"},Oe={class:"title font-bold"};function Pe(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Ae,[r("h2",Oe,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=k(Ce,[["render",Pe],["__scopeId","data-v-a59d89c9"]]),Le=b({name:"ActionSelector",components:{ElSelect:O,ElOption:A},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),je={class:"field"},Re={class:"title font-bold"},Me={class:"float-left"};function Ge(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",je,[r("h2",Re,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},{default:p(()=>[r("span",Me,l(s.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=k(Le,[["render",Ge],["__scopeId","data-v-f4d8785c"]]),Ne=b({name:"TranslationSelector",components:{ElSwitch:de,InfoIcon:j},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=oe)}}),Fe={class:"relative"},ze={class:"flex justify-between"},Be={class:"flex justify-start items-center"},qe={class:"text-sm font-bold"},He={class:"flex justify-end items-center"};function Je(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-switch");return t(),i("div",Fe,[r("div",ze,[r("div",Be,[r("span",qe,l(e.$t("veo.name.translation")),1),a(c,{content:e.$t("veo.description.translation")},null,8,["content"])]),r("div",He,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value"},null,8,["modelValue"])])])])}const Xe=k(Ne,[["render",Je]]),Ye=b({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),Qe={class:"text-sm font-bold mb-2 block"},We={class:"items"},Ke=["onClick"],Ze={class:"name"};function xe(e,o,v,f,y,V){return t(),i("div",null,[r("span",Qe,l(e.$t("veo.name.ratio")),1),r("div",We,[(t(!0),i(E,null,T(e.options,(c,u)=>(t(),i("div",{key:u,class:C({active:e.active===u,item:!0}),onClick:s=>e.value=c.value},[r("div",{class:C(["preview",c.label])},[r("div",{class:"rect",style:Y({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",Ze,l(c.label),1)],10,Ke))),128))])])}const eo=k(Ye,[["render",xe],["__scopeId","data-v-0f16be77"]]),oo=b({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),to={class:"relative"},so={class:"flex mb-2"},no={class:"text-sm font-bold"};function ao(e,o,v,f,y,V){const c=n("video-player");return t(),i("div",to,[r("div",so,[r("span",no,l(e.$t("veo.name.action3")),1)]),r("div",null,[e.config?.video_url?(t(),m(c,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const lo=k(oo,[["render",ao]]),io=b({name:"VideoIdInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),ro={class:"field"},co={class:"title font-bold"};function uo(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",ro,[r("h2",co,l(e.$t("veo.name.videoId")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const po=k(io,[["render",uo],["__scopeId","data-v-6eba4026"]]),mo=b({name:"StartEndImage",components:{ElUpload:me,ElButton:U,InfoIcon:j,FontAwesomeIcon:P,ImagePreview:pe},mixins:[ue],emits:["change"],data(){return{fileList:[],uploadUrl:Q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),vo={class:"relative"},fo={class:"flex justify-between"},_o={class:"flex justify-start items-center"},ho={class:"text-sm font-bold"};function $o(e,o,v,f,y,V){const c=n("info-icon"),u=n("image-preview"),s=n("font-awesome-icon"),w=n("el-button"),$=n("el-upload");return t(),i("div",vo,[r("div",fo,[r("div",_o,[r("span",ho,l(e.$t("veo.name.startEndImage")),1),a(c,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a($,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=h=>e.fileList=h),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:h})=>[h.url&&h.percentage!==void 0?(t(),m(u,{key:0,url:h.url,name:h.name,percentage:h.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(s,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const go=k(mo,[["render",$o],["__scopeId","data-v-b8ddb8fb"]]),bo=b({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return ne.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=se)}}),ko={class:"field"},yo={class:"title font-bold"};function Vo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",ko,[r("h2",yo,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const wo=k(bo,[["render",Vo],["__scopeId","data-v-8b74a7ae"]]),Eo=b({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return G.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!G.includes(this.value))&&(this.value=ae)}}),Io={class:"field"},To={class:"title font-bold"};function So(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Io,[r("h2",To,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Co=k(Eo,[["render",So],["__scopeId","data-v-cc3f9355"]]),Ao=b({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return ie.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=le)}}),Oo={class:"field"},Po={class:"title font-bold"};function Uo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Oo,[r("h2",Po,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Lo=k(Ao,[["render",Uo],["__scopeId","data-v-3affff3c"]]),jo=b({name:"ImageMaskInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),Ro={class:"field"},Mo={class:"title font-bold"};function Go(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",Ro,[r("h2",Mo,l(e.$t("veo.name.imageMask")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const Do=k(jo,[["render",Go],["__scopeId","data-v-6cc27c68"]]),No="",Fo=b({name:"PromptInput",components:{ElInput:R,InfoIcon:j},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=No)}}),zo={class:"field"},Bo={class:"box"},qo={class:"title font-bold"};function Ho(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-input");return t(),i("div",zo,[r("div",Bo,[r("h2",qo,l(e.$t("veo.name.prompt")),1),a(c,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),a(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Jo=k(Fo,[["render",Ho],["__scopeId","data-v-84c55ea0"]]),Xo=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Yo=["text2video","image2video","ingredients2video"],Qo=b({name:"ConfigPanel",components:{ElButton:U,Consumption:ve,FontAwesomeIcon:P,PromptInput:Jo,ModelSelector:Ue,StartEndImage:go,ActionSelector:De,VideoFromInput:lo,VideoIdInput:po,UpsampleActionSelector:wo,ExtendModelSelector:Co,MotionTypeSelector:Lo,ImageMaskInput:Do,TranslationSelector:Xe,AspectRatioSelector:eo},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return fe(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Xo.includes(this.config?.action??"")},isGeneration(){return Yo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Wo={class:"flex flex-col h-full"},Ko={class:"flex-1 overflow-y-auto p-5"},Zo={class:"flex flex-col items-center justify-center px-5 pb-5"};function xo(e,o,v,f,y,V){const c=n("action-selector"),u=n("video-from-input"),s=n("video-id-input"),w=n("upsample-action-selector"),$=n("extend-model-selector"),h=n("prompt-input"),S=n("motion-type-selector"),g=n("image-mask-input"),N=n("translation-selector"),F=n("aspect-ratio-selector"),z=n("model-selector"),B=n("start-end-image"),q=n("consumption"),H=n("font-awesome-icon"),J=n("el-button");return t(),i("div",Wo,[r("div",Ko,[a(c,{class:"mb-4"}),e.isPostProcessing?(t(),i(E,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(s,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(w,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m($,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(h,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(S,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(h,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(g,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(h,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(E,{key:8},[a(N,{class:"mb-4"}),a(F,{class:"mb-4"}),a(h,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:0,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:1,class:"mb-2"})):d("",!0)],64)):d("",!0)]),r("div",Zo,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(J,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const et=k(Qo,[["render",xo]]),ot=b({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:he,FontAwesomeIcon:P,ElAlert:ge,VideoPlayer:D,ElTooltip:$e,ElButton:U},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,f){console.debug("seed config from preview",{action:v,upsampleAction:f,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,...f?{upsample_action:f}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),tt={class:"preview"},st={class:"left"},nt={class:"main"},at={class:"bot"},lt={class:"datetime"},it={class:"info"},rt={key:0,class:"prompt mt-2"},ct={key:0},dt={key:1},ut={key:0,class:C({content:!0,failed:!0})},pt={key:0,class:"mb-4"},mt={key:1,class:C({operations:!0,"mt-2":!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:C({content:!0})},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},yt={key:2,class:C({content:!0})},Vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Et(e,o,v,f,y,V){const c=n("el-image"),u=n("video-player"),s=n("el-button"),w=n("el-tooltip"),$=n("font-awesome-icon"),h=n("copy-to-clipboard"),S=n("el-alert");return t(),i("div",tt,[r("div",st,[a(c,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),r("div",nt,[r("div",at,[_(l(e.$t("veo.name.veoBot"))+" ",1),r("span",lt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",it,[e.modelValue?.request?.prompt?(t(),i("p",rt,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",ct," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",dt," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",ut,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",pt,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",mt,[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=g=>e.onPickAction(g,e.modelValue?.response,"extend"))},{default:p(()=>[_(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=g=>e.onPickAction(g,e.modelValue?.response,"reshoot"))},{default:p(()=>[_(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=g=>e.onPickAction(g,e.modelValue?.response,"object_insert"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=g=>e.onPickAction(g,e.modelValue?.response,"object_remove"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=g=>e.onDownload(g,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[_(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"])])):d("",!0),a(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[r("p",vt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",ft,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",_t,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",ht,[a(S,{closable:!1,class:"failure"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",$t,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),r("p",gt,[a($,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(h,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",bt,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",kt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",yt,[a(S,{closable:!1,class:"info"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",Vt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",wt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const It=k(ot,[["render",Et],["__scopeId","data-v-83f2991f"]]),Tt=b({name:"RecentPanel",components:{TaskPreview:It,NoTasks:ye,BotPlaceholder:ke,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),St={key:0},Ct={key:2,class:"w-full h-full flex items-center justify-center"};function At(e,o,v,f,y,V){const c=n("bot-placeholder"),u=n("task-preview"),s=n("scroll-list"),w=n("no-tasks");return t(),i(E,null,[e.tasks?.items===void 0?(t(),i("div",St,[a(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(s,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=$=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(E,null,T(e.tasks?.items,($,h)=>(t(),m(u,{key:h,"model-value":$},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",Ct,[a(w)])):d("",!0)],64)}const Ot=k(Tt,[["render",At]]),Pt=Z("veo"),Ut=b({name:"VeoIndex",components:{ConfigPanel:et,Layout:Se,RecentPanel:Ot},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:f}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Pt},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),W("veo",K.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===_e?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Lt(e,o,v,f,y,V){const c=n("config-panel"),u=n("recent-panel"),s=n("layout");return t(),m(s,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ts=k(Ut,[["render",Lt]]);export{Ts as default};
|
|
1
|
+
import{F as P}from"./index.es-DD6X2EPt.js";import{E as U}from"./index-JI-AWDGe.js";import{E as X}from"./index-C7UOzYYd.js";import{d as b,H as i,E as r,z as L,C as a,y as p,D as n,q as t,F as l,O as E,N as T,x as m,Q as C,R as Y,J as d,I as _}from"./vendor-vue-NSDaktjZ.js";import{G as k,bl as Q,cr as W,aJ as K,S as M,cs as Z}from"./index-Xv72FIVH.js";import{a as x,b as ee,c as oe,d as te,e as se,f as ne,g as G,h as ae,i as le,j as ie}from"./veo-Dg8Zhpd-.js";import{E as A,a as O}from"./index-BtzJAibB.js";import{I as j,S as re,l as ce}from"./pagination-DI9u8VbS.js";import{E as de}from"./index-DAqtSXwe.js";import{V as D}from"./VideoPlayer-lbflQfYO.js";import{E as R}from"./index-CYDHERfE.js";import{p as ue}from"./pasteUploadMixin-BurWbGNQ.js";import{I as pe}from"./ImagePreview-B4dl6UUl.js";import{E as me}from"./index-L20hlNKs.js";import{E as I}from"./index-ZTLaZITs.js";import{C as ve}from"./Consumption-B9gj7rI5.js";import{a as fe}from"./price-DnUP-rdM.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as he}from"./CopyToClipboard-DDFChBm_.js";import{E as $e}from"./index-CRznp8jk.js";import{E as ge}from"./index-n8xs681c.js";import{E as be}from"./index-CuDB9gdd.js";import{B as ke}from"./BotPlaceholder-CXwVfZf3.js";import{N as ye}from"./NoTasks-C0_ki8Ur.js";import"./use-form-item-C7Jxi2ST.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-CG04RGrn.js";import"./typescript-B81uJgVE.js";import"./index-CYL-RFc_.js";import"./strings-beZM2Y-f.js";import"./isEqual-CbZBrtf3.js";import"./_Uint8Array-rxEgK7pZ.js";import"./castArray-B2H9FWSG.js";import"./debounce-BCcGKj6U.js";import"./_baseIteratee-BP_fhl98.js";import"./index-CF1ww37w.js";import"./validator-DtSW4gh2.js";import"./vue-plyr-BO2nlN4c.js";import"./index-FOpEkA01.js";import"./index-UzoKOEii.js";import"./_baseClone-CoFSI4Xz.js";import"./_initCloneObject-CSU1ND3o.js";import"./index-CHYLT97t.js";const Ve=b({name:"LayoutVeo",components:{ElDrawer:X,ElButton:U,FontAwesomeIcon:P},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ee={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ie={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Te(e,o,v,f,y,V){const c=n("font-awesome-icon"),u=n("el-button"),s=n("el-drawer");return t(),i("div",we,[r("div",Ee,[L(e.$slots,"config",{},void 0,!0)]),r("div",Ie,[L(e.$slots,"result",{},void 0,!0)]),a(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:p(()=>[a(c,{icon:"fa-solid fa-magic"})]),_:1}),a(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Se=k(Ve,[["render",Te],["__scopeId","data-v-816b984c"]]),Ce=b({name:"ModelSelector",components:{ElSelect:O,ElOption:A},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=x)}}),Ae={class:"field"},Oe={class:"title font-bold"};function Pe(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Ae,[r("h2",Oe,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=k(Ce,[["render",Pe],["__scopeId","data-v-a59d89c9"]]),Le=b({name:"ActionSelector",components:{ElSelect:O,ElOption:A},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"ingredients2video",label:this.$t("veo.button.actionIngredients")},{value:"upsample",label:this.$t("veo.button.actionUpsample")},{value:"extend",label:this.$t("veo.button.actionExtend")},{value:"reshoot",label:this.$t("veo.button.actionReshoot")},{value:"object_insert",label:this.$t("veo.button.actionObjectInsert")},{value:"object_remove",label:this.$t("veo.button.actionObjectRemove")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),je={class:"field"},Re={class:"title font-bold"},Me={class:"float-left"};function Ge(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",je,[r("h2",Re,l(e.$t("veo.name.action")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},{default:p(()=>[r("span",Me,l(s.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=k(Le,[["render",Ge],["__scopeId","data-v-f4d8785c"]]),Ne=b({name:"TranslationSelector",components:{ElSwitch:de,InfoIcon:j},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=oe)}}),Fe={class:"relative"},ze={class:"flex justify-between"},Be={class:"flex justify-start items-center"},qe={class:"text-sm font-bold"},He={class:"flex justify-end items-center"};function Je(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-switch");return t(),i("div",Fe,[r("div",ze,[r("div",Be,[r("span",qe,l(e.$t("veo.name.translation")),1),a(c,{content:e.$t("veo.description.translation")},null,8,["content"])]),r("div",He,[a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value"},null,8,["modelValue"])])])])}const Xe=k(Ne,[["render",Je]]),Ye=b({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),Qe={class:"text-sm font-bold mb-2 block"},We={class:"items"},Ke=["onClick"],Ze={class:"name"};function xe(e,o,v,f,y,V){return t(),i("div",null,[r("span",Qe,l(e.$t("veo.name.ratio")),1),r("div",We,[(t(!0),i(E,null,T(e.options,(c,u)=>(t(),i("div",{key:u,class:C({active:e.active===u,item:!0}),onClick:s=>e.value=c.value},[r("div",{class:C(["preview",c.label])},[r("div",{class:"rect",style:Y({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",Ze,l(c.label),1)],10,Ke))),128))])])}const eo=k(Ye,[["render",xe],["__scopeId","data-v-0f16be77"]]),oo=b({name:"VideoFromInput",components:{VideoPlayer:D},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),to={class:"relative"},so={class:"flex mb-2"},no={class:"text-sm font-bold"};function ao(e,o,v,f,y,V){const c=n("video-player");return t(),i("div",to,[r("div",so,[r("span",no,l(e.$t("veo.name.action3")),1)]),r("div",null,[e.config?.video_url?(t(),m(c,{key:0,src:e.config?.video_url},null,8,["src"])):d("",!0)])])}const lo=k(oo,[["render",ao]]),io=b({name:"VideoIdInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,video_id:e})}}}}),ro={class:"field"},co={class:"title font-bold"};function uo(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",ro,[r("h2",co,l(e.$t("veo.name.videoId")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.videoId"),clearable:""},null,8,["modelValue","placeholder"])])}const po=k(io,[["render",uo],["__scopeId","data-v-6eba4026"]]),mo=b({name:"StartEndImage",components:{ElUpload:me,ElButton:U,InfoIcon:j,FontAwesomeIcon:P,ImagePreview:pe},mixins:[ue],emits:["change"],data(){return{fileList:[],uploadUrl:Q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){I.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){I.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),vo={class:"relative"},fo={class:"flex justify-between"},_o={class:"flex justify-start items-center"},ho={class:"text-sm font-bold"};function $o(e,o,v,f,y,V){const c=n("info-icon"),u=n("image-preview"),s=n("font-awesome-icon"),w=n("el-button"),$=n("el-upload");return t(),i("div",vo,[r("div",fo,[r("div",_o,[r("span",ho,l(e.$t("veo.name.startEndImage")),1),a(c,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),a($,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=h=>e.fileList=h),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:h})=>[h.url&&h.percentage!==void 0?(t(),m(u,{key:0,url:h.url,name:h.name,percentage:h.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(h),1)},null,8,["url","name","percentage","onRemove"])):d("",!0)]),default:p(()=>[a(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[a(s,{icon:"fa-solid fa-upload",class:"icon mr-1"}),_(" "+l(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const go=k(mo,[["render",$o],["__scopeId","data-v-b8ddb8fb"]]),bo=b({name:"UpsampleActionSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return ne.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||(this.value=se)}}),ko={class:"field"},yo={class:"title font-bold"};function Vo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",ko,[r("h2",yo,l(e.$t("veo.name.upsampleAction")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const wo=k(bo,[["render",Vo],["__scopeId","data-v-8b74a7ae"]]),Eo=b({name:"ExtendModelSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return G.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!G.includes(this.value))&&(this.value=ae)}}),Io={class:"field"},To={class:"title font-bold"};function So(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Io,[r("h2",To,l(e.$t("veo.name.model")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Co=k(Eo,[["render",So],["__scopeId","data-v-cc3f9355"]]),Ao=b({name:"MotionTypeSelector",components:{ElSelect:O,ElOption:A},computed:{options(){return ie.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||(this.value=le)}}),Oo={class:"field"},Po={class:"title font-bold"};function Uo(e,o,v,f,y,V){const c=n("el-option"),u=n("el-select");return t(),i("div",Oo,[r("h2",Po,l(e.$t("veo.name.motionType")),1),a(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("veo.placeholder.select"),filterable:""},{default:p(()=>[(t(!0),i(E,null,T(e.options,s=>(t(),m(c,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Lo=k(Ao,[["render",Uo],["__scopeId","data-v-3affff3c"]]),jo=b({name:"ImageMaskInput",components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,image_mask:e})}}}}),Ro={class:"field"},Mo={class:"title font-bold"};function Go(e,o,v,f,y,V){const c=n("el-input");return t(),i("div",Ro,[r("h2",Mo,l(e.$t("veo.name.imageMask")),1),a(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),class:"value",type:"text",placeholder:e.$t("veo.placeholder.imageMask"),clearable:""},null,8,["modelValue","placeholder"])])}const Do=k(jo,[["render",Go],["__scopeId","data-v-6cc27c68"]]),No="",Fo=b({name:"PromptInput",components:{ElInput:R,InfoIcon:j},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=No)}}),zo={class:"field"},Bo={class:"box"},qo={class:"title font-bold"};function Ho(e,o,v,f,y,V){const c=n("info-icon"),u=n("el-input");return t(),i("div",zo,[r("div",Bo,[r("h2",qo,l(e.$t("veo.name.prompt")),1),a(c,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),a(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Jo=k(Fo,[["render",Ho],["__scopeId","data-v-84c55ea0"]]),Xo=["upsample","extend","reshoot","object_insert","object_remove","get1080p"],Yo=["text2video","image2video","ingredients2video"],Qo=b({name:"ConfigPanel",components:{ElButton:U,Consumption:ve,FontAwesomeIcon:P,PromptInput:Jo,ModelSelector:Ue,StartEndImage:go,ActionSelector:De,VideoFromInput:lo,VideoIdInput:po,UpsampleActionSelector:wo,ExtendModelSelector:Co,MotionTypeSelector:Lo,ImageMaskInput:Do,TranslationSelector:Xe,AspectRatioSelector:eo},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return fe(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Xo.includes(this.config?.action??"")},isGeneration(){return Yo.includes(this.config?.action??"")}},methods:{onGenerate(){this.$emit("generate")}}}),Wo={class:"flex flex-col h-full"},Ko={class:"flex-1 overflow-y-auto p-5"},Zo={class:"flex flex-col items-center justify-center px-5 pb-5"};function xo(e,o,v,f,y,V){const c=n("action-selector"),u=n("video-from-input"),s=n("video-id-input"),w=n("upsample-action-selector"),$=n("extend-model-selector"),h=n("prompt-input"),S=n("motion-type-selector"),g=n("image-mask-input"),N=n("translation-selector"),F=n("aspect-ratio-selector"),z=n("model-selector"),B=n("start-end-image"),q=n("consumption"),H=n("font-awesome-icon"),J=n("el-button");return t(),i("div",Wo,[r("div",Ko,[a(c,{class:"mb-4"}),e.isPostProcessing?(t(),i(E,{key:0},[e.config?.video_url?(t(),m(u,{key:0,class:"mb-4"})):d("",!0),a(s,{class:"mb-4"})],64)):d("",!0),e.config?.action==="upsample"?(t(),m(w,{key:1,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m($,{key:2,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(t(),m(h,{key:3,class:"mb-4"})):d("",!0),e.config?.action==="reshoot"?(t(),m(S,{key:4,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"?(t(),m(h,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="object_insert"||e.config?.action==="object_remove"?(t(),m(g,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="object_remove"?(t(),m(h,{key:7,class:"mb-4"})):d("",!0),e.isGeneration?(t(),i(E,{key:8},[a(N,{class:"mb-4"}),a(F,{class:"mb-4"}),a(h,{class:"mb-4"}),e.config?.action!=="ingredients2video"?(t(),m(z,{key:0,class:"mb-4"})):d("",!0),e.config?.action==="image2video"||e.config?.action==="ingredients2video"?(t(),m(B,{key:1,class:"mb-2"})):d("",!0)],64)):d("",!0)]),r("div",Zo,[a(q,{value:e.consumption,service:e.service},null,8,["value","service"]),a(J,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[a(H,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const et=k(Qo,[["render",xo]]),ot=b({name:"TaskPreview",components:{ElImage:be,CopyToClipboard:he,FontAwesomeIcon:P,ElAlert:ge,VideoPlayer:D,ElTooltip:$e,ElButton:U},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,o,v,f){console.debug("seed config from preview",{action:v,upsampleAction:f,response:o}),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:v,video_id:o?.data?.[0]?.id,video_url:o?.data?.[0]?.video_url,...f?{upsample_action:f}:{}})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),tt={class:"preview"},st={class:"left"},nt={class:"main"},at={class:"bot"},lt={class:"datetime"},it={class:"info"},rt={key:0,class:"prompt mt-2"},ct={key:0},dt={key:1},ut={key:0,class:C({content:!0,failed:!0})},pt={key:0,class:"mb-4"},mt={key:1,class:C({operations:!0,"mt-2":!0})},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:C({content:!0})},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},yt={key:2,class:C({content:!0})},Vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Et(e,o,v,f,y,V){const c=n("el-image"),u=n("video-player"),s=n("el-button"),w=n("el-tooltip"),$=n("font-awesome-icon"),h=n("copy-to-clipboard"),S=n("el-alert");return t(),i("div",tt,[r("div",st,[a(c,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),r("div",nt,[r("div",at,[_(l(e.$t("veo.name.veoBot"))+" ",1),r("span",lt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",it,[e.modelValue?.request?.prompt?(t(),i("p",rt,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?d("",!0):(t(),i("span",ct," - ("+l(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(t(),i("span",dt," - ("+l(e.$t("veo.status.processing"))+") ",1)):d("",!0)])):d("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(t(),i("div",ut,[e.modelValue?.response?.data[0]?.video_url?(t(),i("div",pt,[a(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):d("",!0),e.modelValue?.response.success?(t(),i("div",mt,[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","1080p"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample1080p")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:1,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","4k"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsample4k")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:2,type:"info",size:"small",class:"btn-action",onClick:o[2]||(o[2]=g=>e.onPickAction(g,e.modelValue?.response,"upsample","gif"))},{default:p(()=>[_(l(e.$t("veo.button.actionUpsampleGif")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:3,type:"info",size:"small",class:"btn-action",onClick:o[3]||(o[3]=g=>e.onPickAction(g,e.modelValue?.response,"extend"))},{default:p(()=>[_(l(e.$t("veo.button.actionExtend")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:4,type:"info",size:"small",class:"btn-action",onClick:o[4]||(o[4]=g=>e.onPickAction(g,e.modelValue?.response,"reshoot"))},{default:p(()=>[_(l(e.$t("veo.button.actionReshoot")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:5,type:"info",size:"small",class:"btn-action",onClick:o[5]||(o[5]=g=>e.onPickAction(g,e.modelValue?.response,"object_insert"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectInsert")),1)]),_:1})):d("",!0),e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:6,type:"info",size:"small",class:"btn-action",onClick:o[6]||(o[6]=g=>e.onPickAction(g,e.modelValue?.response,"object_remove"))},{default:p(()=>[_(l(e.$t("veo.button.actionObjectRemove")),1)]),_:1})):d("",!0),a(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(t(),m(s,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[7]||(o[7]=g=>e.onDownload(g,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[_(l(e.$t("veo.button.download")),1)]),_:1})):d("",!0)]),_:1},8,["content"])])):d("",!0),a(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[r("p",vt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",ft,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",_t,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===!1?(t(),i("div",ht,[a(S,{closable:!1,class:"failure"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",$t,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),r("p",gt,[a($,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("veo.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),a(h,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(t(),i("p",bt,[a($,{icon:"fa-solid fa-clock",class:"mr-1"}),_(" "+l(e.$t("veo.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):d("",!0),e.modelValue?.response?.trace_id?(t(),i("p",kt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0),e.modelValue?.response?.success===void 0?(t(),i("div",yt,[a(S,{closable:!1,class:"info"},{template:p(()=>[a($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("veo.name.failure")),1)]),default:p(()=>[r("p",Vt,[a($,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("veo.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),a(h,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(t(),i("p",wt,[a($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("veo.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),a(h,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):d("",!0)]),_:1})])):d("",!0)])])}const It=k(ot,[["render",Et],["__scopeId","data-v-83f2991f"]]),Tt=b({name:"RecentPanel",components:{TaskPreview:It,NoTasks:ye,BotPlaceholder:ke,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),St={key:0},Ct={key:2,class:"w-full h-full flex items-center justify-center"};function At(e,o,v,f,y,V){const c=n("bot-placeholder"),u=n("task-preview"),s=n("scroll-list"),w=n("no-tasks");return t(),i(E,null,[e.tasks?.items===void 0?(t(),i("div",St,[a(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(t(),m(s,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=$=>e.$emit("reach-top"))},{default:p(()=>[(t(!0),i(E,null,T(e.tasks?.items,($,h)=>(t(),m(u,{key:h,"model-value":$},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(t(),i("div",Ct,[a(w)])):d("",!0)],64)}const Ot=k(Tt,[["render",At]]),Pt=Z("veo"),Ut=b({name:"VeoIndex",components:{ConfigPanel:et,Layout:Se,RecentPanel:Ot},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===M.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===M.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:v,createdAtMax:f}=e||{};console.debug("limit",o,"createdAtMin",v,"createdAtMax",f),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:v,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Pt},o=this.credential?.token;if(!o){console.error("no token specified");return}if(e.action==="image2video"&&!(e.image_urls&&e.image_urls.length>0)){I.warning(this.$t("veo.message.imageRequired"));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,I.info(this.$t("veo.message.startingTask")),W("veo",K.generate(e,{token:o})).then(()=>{I.success(this.$t("veo.message.startTaskSuccess"))}).catch(v=>{v?.response?.data?.error?.code===_e?I.error(this.$t("veo.message.usedUp")):I.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Lt(e,o,v,f,y,V){const c=n("config-panel"),u=n("recent-panel"),s=n("layout");return t(),m(s,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[a(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ts=k(Ut,[["render",Lt]]);export{Ts as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as T}from"./index.es-D_EPO5M5.js";import{E as L}from"./index-J_i8qnoy.js";import{E as Z}from"./index-DfU567fa.js";import{d as S,H as n,E as l,z as O,C as s,y as $,D as i,q as a,F as o,I as u,O as k,N as A,x as I,J as g,M as x,Q as P}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as K,cw as U,cx as X,cy as J,cz as W,cA as M,cB as R,cC as Q,cD as Y,cE as ee,cF as te,cG as se,cH as oe,cI as q,cJ as ae,cK as ie,cr as ne,aY as N,S as D,cs as le}from"./index-DRAEmvEe.js";import{I as C,S as re,l as me}from"./pagination-6N8Zy2ln.js";import{E as ce}from"./index-8pPfeJLV.js";import{I as B}from"./ImagePreview-DGZ7oqeM.js";import{E as ue}from"./index-CSaI_dNr.js";import{E as G}from"./index-DSs-PC8-.js";import{C as pe}from"./Consumption-BAuQo1e2.js";import{a as de}from"./price-D9OTezDw.js";import{E as F,a as H,b as ge}from"./index-Bvlr6bsR.js";import{E as he}from"./index-Pzo9boTC.js";import{E as fe}from"./index-B1PmZ-Iv.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as $e}from"./CopyToClipboard-xH0KM_v3.js";import{I as be}from"./ImageWrapper-VTIP1F-X.js";import{E as ve}from"./index-CdGHWSQH.js";import{E as Ee}from"./index-BbNbrIc9.js";import{E as ke}from"./index-DWHfebYD.js";import{B as Ie}from"./BotPlaceholder-CgQaozFd.js";import{N as Se}from"./NoTasks-DU0uzui_.js";import"./use-form-item-DYeima3c.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-Ds5Nsy-o.js";import"./index-BUpZCQK_.js";import"./index-DoOEsk7K.js";import"./index-CjoIDD-m.js";import"./_baseClone-2UOH3err.js";import"./_Uint8Array-2EjSTOVM.js";import"./_initCloneObject-DAZlR5GD.js";import"./isEqual-Djts47Qq.js";import"./index-DS1vID1S.js";import"./strings-beZM2Y-f.js";import"./castArray-D6XtIb4l.js";import"./debounce-B0cNnAb0.js";import"./_baseIteratee-DVlaYH87.js";import"./index-4EfdjHi4.js";import"./index-Cu41y2Fl.js";import"./validator-6aZKx5Gq.js";import"./index-ArWqC8tb.js";const ye=S({name:"LayoutNanobanana",components:{ElDrawer:Z,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ae={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ge(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-drawer");return a(),n("div",we,[l("div",Ve,[O(e.$slots,"config",{},void 0,!0)]),l("div",Ae,[O(e.$slots,"result",{},void 0,!0)]),s(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=_=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(b,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Me=y(ye,[["render",Ge],["__scopeId","data-v-bfe5cd4b"]]),ze="",Te=S({name:"PromptInput",components:{ElInput:ce,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}}),Le={class:"field"},Pe={class:"box"},Ce={class:"title font-bold"};function Oe(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-input");return a(),n("div",Le,[l("div",Pe,[l("h2",Ce,o(e.$t("openaiimage.name.prompt")),1),s(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),s(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=b=>e.prompt=b),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ue=y(Te,[["render",Oe],["__scopeId","data-v-92f61e4a"]]),Re=S({name:"ImageUrlsInput",components:{ElUpload:ue,ElButton:L,InfoIcon:C,ImagePreview:B,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(f=>!f?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const f=this.fileList.find(v=>v?.response?.file_url===r||v?.url===r);f?t.push(f):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(v=>v===r||v?.url===r?.url||v?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){G.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){G.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),qe={class:"field flex items-center justify-between"},Ne={class:"title font-bold text-[14px] mb-[10px]"},De={class:"upload-wrapper flex flex-col items-start gap-[8px]"},je={class:"controls flex items-center"},We={class:"file-list flex flex-wrap gap-[10px]"};function Be(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-upload"),_=i("info-icon"),E=i("image-preview");return a(),n(k,null,[l("div",qe,[l("h2",Ne,o(e.$t("openaiimage.name.imageUrls")),1),l("div",De,[l("div",je,[s(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[s(h,{size:"small",type:"primary",round:""},{default:$(()=>[s(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(_,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",We,[(a(!0),n(k,null,A(e.fileList,(m,p)=>(a(),I(E,{key:m.uid||m?.response?.file_url||m.url||p,url:m.url||m?.response?.file_url,name:m.name,percentage:m.percentage,onRemove:w=>e.onRemovePreview(p,m)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Fe=y(Re,[["render",Be]]),He=S({name:"OpenAIImageModelSelector",components:{ElSelect:H,ElOption:F,InfoIcon:C},data(){return{options:[{value:X,label:this.$t("openaiimage.model.gptImage1")},{value:J,label:this.$t("openaiimage.model.gptImage15")},{value:W,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ze={class:"field"},xe={class:"label"},Ke={class:"box"},Xe={class:"title font-bold"};function Je(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-select");return a(),n("div",Ze,[l("div",xe,[l("div",Ke,[l("h2",Xe,o(e.$t("openaiimage.name.model")),1),s(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(b,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),n(k,null,A(e.options,_=>(a(),I(h,{key:_.value,label:_.label,value:_.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Qe=y(He,[["render",Je],["__scopeId","data-v-cec771bd"]]);function Ye(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const et=S({name:"OpenAIImageSizeSelector",components:{ElSelect:H,ElOption:F,ElOptionGroup:ge,ElSwitch:fe,ElInputNumber:he,InfoIcon:C},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ae.includes(this.model)},presets(){return q[this.model]??q[U]??[]},presetGroups(){return this.model===W?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:te},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:oe}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??M;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??M},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return ee},minSide(){return Y},maxSide(){return Q},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>R?this.$t("openaiimage.error.customSizePixels",{pixels:R.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??M);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??M)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??M);return}const e=Ye(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),tt={class:"resolution"},st={class:"field"},ot={class:"label"},at={class:"box"},it={class:"title font-bold"},nt={class:"field custom-toggle"},lt={class:"label"},rt={class:"box"},mt={class:"title font-bold"},ct={key:0,class:"custom-inputs"},ut={class:"row"},pt={class:"row-label"},dt={class:"row"},gt={class:"row-label"},ht={key:0,class:"error"};function ft(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-option-group"),_=i("el-select"),E=i("el-switch"),m=i("el-input-number");return a(),n("div",tt,[l("div",st,[l("div",ot,[l("div",at,[l("h2",it,o(e.$t("openaiimage.name.size")),1),s(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(_,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=p=>e.presetValue=p),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:$(()=>[(a(!0),n(k,null,A(e.presetGroups,p=>(a(),I(b,{key:p.label,label:p.label},{default:$(()=>[(a(!0),n(k,null,A(p.options,w=>(a(),I(h,{key:w,label:w,value:w},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(k,{key:0},[l("div",nt,[l("div",lt,[l("div",rt,[l("h2",mt,o(e.$t("openaiimage.name.customSize")),1),s(d,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(E,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=p=>e.useCustom=p),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ct,[l("div",ut,[l("span",pt,o(e.$t("openaiimage.name.width")),1),s(m,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=p=>e.customWidth=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),l("div",dt,[l("span",gt,o(e.$t("openaiimage.name.height")),1),s(m,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=p=>e.customHeight=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",ht,o(e.customError),1)):g("",!0)])):g("",!0)],64)):g("",!0)])}const _t=y(et,[["render",ft],["__scopeId","data-v-218b58cb"]]),$t=S({name:"ConfigPanel",components:{ElButton:L,FontAwesomeIcon:T,PromptInput:Ue,Consumption:pe,ImageUrlsInput:Fe,ModelSelector:Qe,ResolutionSelector:_t},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return de({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},vt={class:"flex-1 overflow-y-auto p-5"},Et={class:"flex flex-col items-center justify-center px-5 pb-5"};function kt(e,t,c,r,f,v){const d=i("model-selector"),h=i("resolution-selector"),b=i("prompt-input"),_=i("image-urls-input"),E=i("consumption"),m=i("font-awesome-icon"),p=i("el-button");return a(),n("div",bt,[l("div",vt,[s(d,{class:"mb-4"}),s(h,{class:"mb-4"}),s(b,{class:"mb-4"}),s(_,{class:"mb-4"})]),l("div",Et,[s(E,{value:e.consumption,service:e.service},null,8,["value","service"]),s(p,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(m,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const It=y($t,[["render",kt]]),St=S({name:"TaskPreview",components:{ElImage:ke,CopyToClipboard:$e,FontAwesomeIcon:T,ElAlert:Ee,ImageWrapper:be,ElButton:L,ElTooltip:ve,ImagePreview:B},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ie}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),yt={class:"preview"},wt={class:"left"},Vt={class:"main"},At={class:"bot"},Gt={class:"datetime"},Mt={class:"info"},zt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Tt={key:1,class:"prompt mt-2"},Lt={key:0},Pt={key:0,class:P({content:!0,failed:!0})},Ct={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ot={class:P({operations:!0,"mt-2":!0,"mb-2":!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Wt={key:1,class:P({content:!0})},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Jt={key:2,class:P({content:!0})},Qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},es={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function ss(e,t,c,r,f,v){const d=i("el-image"),h=i("image-preview"),b=i("image-wrapper"),_=i("el-button"),E=i("el-tooltip"),m=i("font-awesome-icon"),p=i("copy-to-clipboard"),w=i("el-alert");return a(),n("div",yt,[l("div",wt,[s(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),l("div",Vt,[l("div",At,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),l("span",Gt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Mt,[e.referenceImages.length>0?(a(),n("div",zt,[(a(!0),n(k,null,A(e.referenceImages,(V,z)=>(a(),I(h,{key:z,url:V,name:`image-${z+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(a(),n("p",Tt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),n("span",Lt," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Pt,[l("div",Ct,[(a(!0),n(k,null,A(e.images,(V,z)=>(a(),I(b,{key:z,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),l("div",Ot,[s(E,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[s(_,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=x(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(w,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Ut,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",qt,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Nt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Dt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",jt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Wt,[s(w,{closable:!1,class:"failure"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Bt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Ft,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",Ht,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Zt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",xt,[s(m,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Kt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Xt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(a(),n("div",Jt,[s(w,{closable:!1,class:"info"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Qt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Yt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",es,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",ts,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const os=y(St,[["render",ss],["__scopeId","data-v-87775c45"]]),as=S({name:"RecentPanel",components:{TaskPreview:os,BotPlaceholder:Ie,NoTasks:Se,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),is={key:0},ns={key:2,class:"w-full h-full flex items-center justify-center"};function ls(e,t,c,r,f,v){const d=i("bot-placeholder"),h=i("task-preview"),b=i("scroll-list"),_=i("no-tasks");return a(),n(k,null,[e.tasks?.items===void 0?(a(),n("div",is,[s(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(b,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=E=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),n(k,null,A(e.tasks?.items,E=>(a(),I(h,{key:E.id,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),n("div",ns,[s(_)])):g("",!0)],64)}const rs=y(as,[["render",ls]]),j=le("openaiimage"),ms=S({name:"OpenAIImageIndex",components:{ConfigPanel:It,Layout:Me,RecentPanel:rs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===D.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:j},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:j},f=this.credential?.token;if(!f){console.error("no token specified");return}G.info(this.$t("openaiimage.message.startingTask")),ne("openaiimage",t?N.edit(r,{token:f}):N.generate(c,{token:f})).then(d=>{console.debug("task accepted",d.data?.task_id),G.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===_e?G.error(this.$t("openaiimage.message.usedUp")):G.error(this.$t("openaiimage.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function cs(e,t,c,r,f,v){const d=i("config-panel"),h=i("recent-panel"),b=i("layout");return a(),I(b,null,{config:$(()=>[s(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[s(h,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const so=y(ms,[["render",cs]]);export{so as default};
|
|
1
|
+
import{F as T}from"./index.es-DD6X2EPt.js";import{E as L}from"./index-JI-AWDGe.js";import{E as Z}from"./index-C7UOzYYd.js";import{d as S,H as n,E as l,z as O,C as s,y as $,D as i,q as a,F as o,I as u,O as k,N as A,x as I,J as g,M as x,Q as P}from"./vendor-vue-NSDaktjZ.js";import{G as y,bl as K,cw as U,cx as X,cy as J,cz as W,cA as M,cB as R,cC as Q,cD as Y,cE as ee,cF as te,cG as se,cH as oe,cI as q,cJ as ae,cK as ie,cr as ne,aY as N,S as D,cs as le}from"./index-Xv72FIVH.js";import{I as C,S as re,l as me}from"./pagination-DI9u8VbS.js";import{E as ce}from"./index-CYDHERfE.js";import{I as B}from"./ImagePreview-B4dl6UUl.js";import{E as ue}from"./index-L20hlNKs.js";import{E as G}from"./index-ZTLaZITs.js";import{C as pe}from"./Consumption-B9gj7rI5.js";import{a as de}from"./price-DnUP-rdM.js";import{E as F,a as H,b as ge}from"./index-BtzJAibB.js";import{E as he}from"./index-Bwrk7Ay6.js";import{E as fe}from"./index-DAqtSXwe.js";import{b as _e}from"./errorCode-Cqj9Td_Z.js";import{C as $e}from"./CopyToClipboard-DDFChBm_.js";import{I as be}from"./ImageWrapper-C7KzvBjb.js";import{E as ve}from"./index-CRznp8jk.js";import{E as Ee}from"./index-n8xs681c.js";import{E as ke}from"./index-CuDB9gdd.js";import{B as Ie}from"./BotPlaceholder-CXwVfZf3.js";import{N as Se}from"./NoTasks-C0_ki8Ur.js";import"./use-form-item-C7Jxi2ST.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-B81uJgVE.js";import"./index-CYL-RFc_.js";import"./index-FOpEkA01.js";import"./index-UzoKOEii.js";import"./_baseClone-CoFSI4Xz.js";import"./_Uint8Array-rxEgK7pZ.js";import"./_initCloneObject-CSU1ND3o.js";import"./isEqual-CbZBrtf3.js";import"./index-CG04RGrn.js";import"./strings-beZM2Y-f.js";import"./castArray-B2H9FWSG.js";import"./debounce-BCcGKj6U.js";import"./_baseIteratee-BP_fhl98.js";import"./index-CF1ww37w.js";import"./index-Cu41y2Fl.js";import"./validator-DtSW4gh2.js";import"./index-CHYLT97t.js";const ye=S({name:"LayoutNanobanana",components:{ElDrawer:Z,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),we={class:"main flex flex-row flex-1"},Ve={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Ae={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ge(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-drawer");return a(),n("div",we,[l("div",Ve,[O(e.$slots,"config",{},void 0,!0)]),l("div",Ae,[O(e.$slots,"result",{},void 0,!0)]),s(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=_=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(b,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[O(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Me=y(ye,[["render",Ge],["__scopeId","data-v-bfe5cd4b"]]),ze="",Te=S({name:"PromptInput",components:{ElInput:ce,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}}),Le={class:"field"},Pe={class:"box"},Ce={class:"title font-bold"};function Oe(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-input");return a(),n("div",Le,[l("div",Pe,[l("h2",Ce,o(e.$t("openaiimage.name.prompt")),1),s(d,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),s(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=b=>e.prompt=b),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ue=y(Te,[["render",Oe],["__scopeId","data-v-92f61e4a"]]),Re=S({name:"ImageUrlsInput",components:{ElUpload:ue,ElButton:L,InfoIcon:C,ImagePreview:B,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(f=>!f?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const f=this.fileList.find(v=>v?.response?.file_url===r||v?.url===r);f?t.push(f):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(v=>v===r||v?.url===r?.url||v?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){G.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){G.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),qe={class:"field flex items-center justify-between"},Ne={class:"title font-bold text-[14px] mb-[10px]"},De={class:"upload-wrapper flex flex-col items-start gap-[8px]"},je={class:"controls flex items-center"},We={class:"file-list flex flex-wrap gap-[10px]"};function Be(e,t,c,r,f,v){const d=i("font-awesome-icon"),h=i("el-button"),b=i("el-upload"),_=i("info-icon"),E=i("image-preview");return a(),n(k,null,[l("div",qe,[l("h2",Ne,o(e.$t("openaiimage.name.imageUrls")),1),l("div",De,[l("div",je,[s(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[s(h,{size:"small",type:"primary",round:""},{default:$(()=>[s(d,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),s(_,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",We,[(a(!0),n(k,null,A(e.fileList,(m,p)=>(a(),I(E,{key:m.uid||m?.response?.file_url||m.url||p,url:m.url||m?.response?.file_url,name:m.name,percentage:m.percentage,onRemove:w=>e.onRemovePreview(p,m)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Fe=y(Re,[["render",Be]]),He=S({name:"OpenAIImageModelSelector",components:{ElSelect:H,ElOption:F,InfoIcon:C},data(){return{options:[{value:X,label:this.$t("openaiimage.model.gptImage1")},{value:J,label:this.$t("openaiimage.model.gptImage15")},{value:W,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=U)}}),Ze={class:"field"},xe={class:"label"},Ke={class:"box"},Xe={class:"title font-bold"};function Je(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-select");return a(),n("div",Ze,[l("div",xe,[l("div",Ke,[l("h2",Xe,o(e.$t("openaiimage.name.model")),1),s(d,{content:e.modelDescription,class:"info"},null,8,["content"])])]),s(b,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),n(k,null,A(e.options,_=>(a(),I(h,{key:_.value,label:_.label,value:_.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Qe=y(He,[["render",Je],["__scopeId","data-v-cec771bd"]]);function Ye(e){if(!e)return;const t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}const et=S({name:"OpenAIImageSizeSelector",components:{ElSelect:H,ElOption:F,ElOptionGroup:ge,ElSwitch:fe,ElInputNumber:he,InfoIcon:C},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||U},storedSize(){return this.$store.state.openaiimage?.config?.size},customSupported(){return ae.includes(this.model)},presets(){return q[this.model]??q[U]??[]},presetGroups(){return this.model===W?[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:te},{label:this.$t("openaiimage.sizeGroup.preset2k"),options:se},{label:this.$t("openaiimage.sizeGroup.preset4k"),options:oe}]:[{label:this.$t("openaiimage.sizeGroup.standard1k"),options:this.presets}]},useCustom:{get(){return this.customSupported&&this.customMode},set(e){if(!(e&&!this.customSupported))if(this.customMode=e,e){if(this.customError)return;this.commitSize(`${this.customWidth}x${this.customHeight}`)}else{const t=this.presets[0]??M;this.commitSize(t)}}},presetValue:{get(){const e=this.storedSize;return e&&this.presets.includes(e)?e:this.presets[0]??M},set(e){this.customMode=!1,this.commitSize(e)}},multiple(){return ee},minSide(){return Y},maxSide(){return Q},customError(){const e=this.customWidth,t=this.customHeight;return!Number.isFinite(e)||!Number.isFinite(t)||e<=0||t<=0?this.$t("openaiimage.error.customSizePositive"):e%this.multiple!==0||t%this.multiple!==0?this.$t("openaiimage.error.customSizeMultiple",{multiple:this.multiple}):e<this.minSide||t<this.minSide?this.$t("openaiimage.error.customSizeMin",{min:this.minSide}):Math.max(e,t)>this.maxSide?this.$t("openaiimage.error.customSizeMax",{max:this.maxSide}):e*t>R?this.$t("openaiimage.error.customSizePixels",{pixels:R.toLocaleString()}):""}},watch:{model:{immediate:!1,handler(){if(!this.customSupported){this.customMode=!1;const t=this.storedSize;(!t||!this.presets.includes(t))&&this.commitSize(this.presets[0]??M);return}const e=this.storedSize;if(this.customMode&&!this.customError){this.commitSize(`${this.customWidth}x${this.customHeight}`);return}(!e||!this.presets.includes(e))&&this.commitSize(this.presets[0]??M)}},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){if(!this.storedSize){this.commitSize(this.presets[0]??M);return}const e=Ye(this.storedSize);e&&this.customSupported&&!this.presets.includes(this.storedSize)&&(this.customMode=!0,this.customWidth=e.w,this.customHeight=e.h)},methods:{commitSize(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),tt={class:"resolution"},st={class:"field"},ot={class:"label"},at={class:"box"},it={class:"title font-bold"},nt={class:"field custom-toggle"},lt={class:"label"},rt={class:"box"},mt={class:"title font-bold"},ct={key:0,class:"custom-inputs"},ut={class:"row"},pt={class:"row-label"},dt={class:"row"},gt={class:"row-label"},ht={key:0,class:"error"};function ft(e,t,c,r,f,v){const d=i("info-icon"),h=i("el-option"),b=i("el-option-group"),_=i("el-select"),E=i("el-switch"),m=i("el-input-number");return a(),n("div",tt,[l("div",st,[l("div",ot,[l("div",at,[l("h2",it,o(e.$t("openaiimage.name.size")),1),s(d,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),s(_,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||(t[0]=p=>e.presetValue=p),class:"value",placeholder:e.$t("openaiimage.placeholder.select"),disabled:e.useCustom},{default:$(()=>[(a(!0),n(k,null,A(e.presetGroups,p=>(a(),I(b,{key:p.label,label:p.label},{default:$(()=>[(a(!0),n(k,null,A(p.options,w=>(a(),I(h,{key:w,label:w,value:w},null,8,["label","value"]))),128))]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.customSupported?(a(),n(k,{key:0},[l("div",nt,[l("div",lt,[l("div",rt,[l("h2",mt,o(e.$t("openaiimage.name.customSize")),1),s(d,{content:e.$t("openaiimage.description.customSize"),class:"info"},null,8,["content"])])]),s(E,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||(t[1]=p=>e.useCustom=p),class:"value-switch"},null,8,["modelValue"])]),e.useCustom?(a(),n("div",ct,[l("div",ut,[l("span",pt,o(e.$t("openaiimage.name.width")),1),s(m,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||(t[2]=p=>e.customWidth=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),l("div",dt,[l("span",gt,o(e.$t("openaiimage.name.height")),1),s(m,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||(t[3]=p=>e.customHeight=p),class:"row-input",min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":"right"},null,8,["modelValue","min","max","step"])]),e.customError?(a(),n("div",ht,o(e.customError),1)):g("",!0)])):g("",!0)],64)):g("",!0)])}const _t=y(et,[["render",ft],["__scopeId","data-v-218b58cb"]]),$t=S({name:"ConfigPanel",components:{ElButton:L,FontAwesomeIcon:T,PromptInput:Ue,Consumption:pe,ImageUrlsInput:Fe,ModelSelector:Qe,ResolutionSelector:_t},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return de({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),bt={class:"flex flex-col h-full"},vt={class:"flex-1 overflow-y-auto p-5"},Et={class:"flex flex-col items-center justify-center px-5 pb-5"};function kt(e,t,c,r,f,v){const d=i("model-selector"),h=i("resolution-selector"),b=i("prompt-input"),_=i("image-urls-input"),E=i("consumption"),m=i("font-awesome-icon"),p=i("el-button");return a(),n("div",bt,[l("div",vt,[s(d,{class:"mb-4"}),s(h,{class:"mb-4"}),s(b,{class:"mb-4"}),s(_,{class:"mb-4"})]),l("div",Et,[s(E,{value:e.consumption,service:e.service},null,8,["value","service"]),s(p,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(m,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const It=y($t,[["render",kt]]),St=S({name:"TaskPreview",components:{ElImage:ke,CopyToClipboard:$e,FontAwesomeIcon:T,ElAlert:Ee,ImageWrapper:be,ElButton:L,ElTooltip:ve,ImagePreview:B},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:ie}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const c=t;if(c?.image_url||c?.url){e.push(c);return}c?.b64_json&&e.push({...c,url:`data:image/png;base64,${c.b64_json}`})}),e},referenceImages(){const e=this.modelValue?.request;if(!e)return[];const t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(r=>typeof r=="string"&&r.length>0);const c=e.image;return Array.isArray(c)?c.filter(r=>typeof r=="string"&&r.length>0):typeof c=="string"&&c.length>0?[c]:[]}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),yt={class:"preview"},wt={class:"left"},Vt={class:"main"},At={class:"bot"},Gt={class:"datetime"},Mt={class:"info"},zt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Tt={key:1,class:"prompt mt-2"},Lt={key:0},Pt={key:0,class:P({content:!0,failed:!0})},Ct={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ot={class:P({operations:!0,"mt-2":!0,"mb-2":!0})},Ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},jt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Wt={key:1,class:P({content:!0})},Bt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ht={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},xt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Kt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Jt={key:2,class:P({content:!0})},Qt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Yt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},es={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ts={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function ss(e,t,c,r,f,v){const d=i("el-image"),h=i("image-preview"),b=i("image-wrapper"),_=i("el-button"),E=i("el-tooltip"),m=i("font-awesome-icon"),p=i("copy-to-clipboard"),w=i("el-alert");return a(),n("div",yt,[l("div",wt,[s(d,{src:e.OPENAIIMAGE_LOGO,class:"avatar"},null,8,["src"])]),l("div",Vt,[l("div",At,[u(o(e.$t("openaiimage.name.openaiimageBot"))+" ",1),l("span",Gt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Mt,[e.referenceImages.length>0?(a(),n("div",zt,[(a(!0),n(k,null,A(e.referenceImages,(V,z)=>(a(),I(h,{key:z,url:V,name:`image-${z+1}`,closable:!1},null,8,["url","name"]))),128))])):g("",!0),e.modelValue?.request?.prompt?(a(),n("p",Tt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),n("span",Lt," - ("+o(e.$t("openaiimage.status.pending"))+") ",1))])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),n("div",Pt,[l("div",Ct,[(a(!0),n(k,null,A(e.images,(V,z)=>(a(),I(b,{key:z,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),l("div",Ot,[s(E,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[s(_,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=x(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(w,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Ut,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Rt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",qt,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Nt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Dt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",jt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):g("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),n("div",Wt,[s(w,{closable:!1,class:"failure"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Bt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Ft,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",Ht,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",Zt,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",xt,[s(m,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.elapsed?(a(),n("p",Kt,[s(m,{icon:"fa-solid fa-clock",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.elapsed"))+": "+o(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):g("",!0),e.modelValue?.response?.trace_id?(a(),n("p",Xt,[s(m,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):g("",!0)]),_:1})])):(a(),n("div",Jt,[s(w,{closable:!1,class:"info"},{template:$(()=>[s(m,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),n("p",Qt,[s(m,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.model"))+": "+o(e.modelValue?.request?.model),1)])):g("",!0),e.modelValue?.request?.size?(a(),n("p",Yt,[s(m,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.size"))+": "+o(e.modelValue?.request?.size),1)])):g("",!0),e.modelValue?.request?.action?(a(),n("p",es,[s(m,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):g("",!0),l("p",ts,[s(m,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("openaiimage.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const os=y(St,[["render",ss],["__scopeId","data-v-87775c45"]]),as=S({name:"RecentPanel",components:{TaskPreview:os,BotPlaceholder:Ie,NoTasks:Se,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),is={key:0},ns={key:2,class:"w-full h-full flex items-center justify-center"};function ls(e,t,c,r,f,v){const d=i("bot-placeholder"),h=i("task-preview"),b=i("scroll-list"),_=i("no-tasks");return a(),n(k,null,[e.tasks?.items===void 0?(a(),n("div",is,[s(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(b,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=E=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),n(k,null,A(e.tasks?.items,E=>(a(),I(h,{key:E.id,"model-value":E},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),n("div",ns,[s(_)])):g("",!0)],64)}const rs=y(as,[["render",ls]]),j=le("openaiimage"),ms=S({name:"OpenAIImageIndex",components:{ConfigPanel:It,Layout:Me,RecentPanel:rs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===D.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loading,setLoading:e=>this.loading=e,isBlocked:()=>this.tasksLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:c,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",c,"createdAtMax",r),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:c,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const c={...e,action:"generate",callback_url:j},r={action:"edit",model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:j},f=this.credential?.token;if(!f){console.error("no token specified");return}G.info(this.$t("openaiimage.message.startingTask")),ne("openaiimage",t?N.edit(r,{token:f}):N.generate(c,{token:f})).then(d=>{console.debug("task accepted",d.data?.task_id),G.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===_e?G.error(this.$t("openaiimage.message.usedUp")):G.error(this.$t("openaiimage.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function cs(e,t,c,r,f,v){const d=i("config-panel"),h=i("recent-panel"),b=i("layout");return a(),I(b,null,{config:$(()=>[s(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[s(h,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const so=y(ms,[["render",cs]]);export{so as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as x}from"./index.es-D_EPO5M5.js";import{E as A}from"./index-J_i8qnoy.js";import{E as O}from"./index-DfU567fa.js";import{d as h,H as o,E as r,z as E,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{G as m,S as V}from"./index-DRAEmvEe.js";import{E as U}from"./index-8pPfeJLV.js";import{E as N,a as P}from"./index-Bvlr6bsR.js";import{C as G}from"./Consumption-BAuQo1e2.js";import{a as L}from"./price-D9OTezDw.js";import{E as B,a as D}from"./index-Dt21I4XP.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-DSs-PC8-.js";import"./use-form-item-DYeima3c.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-Ds5Nsy-o.js";import"./index-BUpZCQK_.js";import"./index-DoOEsk7K.js";import"./index-CdGHWSQH.js";import"./index-DS1vID1S.js";import"./strings-beZM2Y-f.js";import"./isEqual-Djts47Qq.js";import"./_Uint8Array-2EjSTOVM.js";import"./castArray-D6XtIb4l.js";import"./debounce-B0cNnAb0.js";import"./_baseIteratee-DVlaYH87.js";import"./index-4EfdjHi4.js";import"./index-DT2j3exg.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[E(e.$slots,"config",{},void 0,!0)]),r("div",J,[E(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=m(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,_,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=m(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:G},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return L(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,_,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ce={class:"flex-1 min-w-0"},Ee={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,_,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ce,[e.data.type?(t(),o("div",Ee,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const ze=m(xe,[["render",Oe]]),Ne=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Ge={key:0,class:"flex items-center gap-2 mb-1.5"},Le=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Ge,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Le),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",He,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,_,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=m(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},mt={class:"flex-1 min-w-0"},_t={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,_,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",mt,[r("div",_t,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=m(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Et={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,_,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Ct,a(s.title),1),r("div",Et,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Gt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Lt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Gt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Lt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Ht,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,C=>r("div",{key:C,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)])])),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===T?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,_,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const Gs=m(is,[["render",cs]]);export{Gs as default};
|
|
1
|
+
import{F as x}from"./index.es-DD6X2EPt.js";import{E as A}from"./index-JI-AWDGe.js";import{E as O}from"./index-C7UOzYYd.js";import{d as h,H as o,E as r,z as E,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{G as m,S as V}from"./index-Xv72FIVH.js";import{E as U}from"./index-CYDHERfE.js";import{E as N,a as P}from"./index-BtzJAibB.js";import{C as G}from"./Consumption-B9gj7rI5.js";import{a as L}from"./price-DnUP-rdM.js";import{E as B,a as D}from"./index-CCYrnVY8.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-ZTLaZITs.js";import"./use-form-item-C7Jxi2ST.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-B81uJgVE.js";import"./index-CYL-RFc_.js";import"./index-FOpEkA01.js";import"./index-CRznp8jk.js";import"./index-CG04RGrn.js";import"./strings-beZM2Y-f.js";import"./isEqual-CbZBrtf3.js";import"./_Uint8Array-rxEgK7pZ.js";import"./castArray-B2H9FWSG.js";import"./debounce-BCcGKj6U.js";import"./_baseIteratee-BP_fhl98.js";import"./index-CF1ww37w.js";import"./index-COuezDm-.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[E(e.$slots,"config",{},void 0,!0)]),r("div",J,[E(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=m(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,_,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=m(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:G},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return L(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,_,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ce={class:"flex-1 min-w-0"},Ee={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,_,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ce,[e.data.type?(t(),o("div",Ee,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const ze=m(xe,[["render",Oe]]),Ne=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Ge={key:0,class:"flex items-center gap-2 mb-1.5"},Le=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Ge,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Le),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",He,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,_,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=m(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},mt={class:"flex-1 min-w-0"},_t={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,_,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",mt,[r("div",_t,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=m(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Et={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,_,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Ct,a(s.title),1),r("div",Et,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Gt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Lt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Gt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Lt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Ht,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,C=>r("div",{key:C,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)])])),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===T?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,_,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const Gs=m(is,[["render",cs]]);export{Gs as default};
|