@acedatacloud/nexior 3.277.8 → 3.278.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/ApiCodeButton-CXoLQXC2.js +1 -0
- package/dist/assets/{AskUserQuestionCard-DpVf5R3L.js → AskUserQuestionCard-CJ6FK-eQ.js} +2 -2
- package/dist/assets/Auth-oy_cDrjB.js +1 -0
- package/dist/assets/Bare-BjzQECGk.js +1 -0
- package/dist/assets/BotPlaceholder-BpLIwwxA.js +1 -0
- package/dist/assets/BottomFooter-CPL1TUJk.js +1 -0
- package/dist/assets/{Callback-BttIeatM.js → Callback-DZA2XoEn.js} +1 -1
- package/dist/assets/{Console-6jjIf0R4.js → Console-lGda8cJF.js} +1 -1
- package/dist/assets/Consumption-D_CAQaSB.js +1 -0
- package/dist/assets/Conversation-BBLuEQqB.js +3 -0
- package/dist/assets/CopyToClipboard-DG5cx0Ex.js +1 -0
- package/dist/assets/{Detail-95MlCPRb.js → Detail-LUdxtiDf.js} +2 -2
- package/dist/assets/Extra-C51gCPia.js +1 -0
- package/dist/assets/{FilePreview-erEvFoLk.js → FilePreview-BFkQVXth.js} +1 -1
- package/dist/assets/Hailuo-DIHiST1a.js +1 -0
- package/dist/assets/History-BGPVkHOY.js +1 -0
- package/dist/assets/ImagePreview-CeyNx3jd.js +1 -0
- package/dist/assets/ImageWrapper-C6BTBymE.js +1 -0
- package/dist/assets/Index-B4luoYiJ.js +1 -0
- package/dist/assets/Index-BFpKx82w.js +1 -0
- package/dist/assets/Index-BIi8lQVb.js +1 -0
- package/dist/assets/{Index-BthVK3cD.js → Index-BJ7bU2Ap.js} +1 -1
- package/dist/assets/Index-BUutMSDI.js +1 -0
- package/dist/assets/Index-Bk_tFQBc.js +2 -0
- package/dist/assets/Index-BpIXOTSD.js +1 -0
- package/dist/assets/Index-BwIw__H4.js +1 -0
- package/dist/assets/Index-C4hy7nVp.js +1 -0
- package/dist/assets/Index-C8N6BHY-.js +1 -0
- package/dist/assets/Index-CPJu847J.js +1 -0
- package/dist/assets/Index-Cc-RhfD0.js +1 -0
- package/dist/assets/Index-CxLS2qO0.js +1 -0
- package/dist/assets/Index-Cz1SEEJn.js +1 -0
- package/dist/assets/Index-D4VgA6LH.js +1 -0
- package/dist/assets/Index-D6ein8tv.js +1 -0
- package/dist/assets/Index-DVoOVUco.js +1 -0
- package/dist/assets/Index-DWMFhERT.js +1 -0
- package/dist/assets/Index-DZZdzKP6.js +1 -0
- package/dist/assets/Index-DaSVJxjM.js +1 -0
- package/dist/assets/Index-DcccGmiE.js +1 -0
- package/dist/assets/Index-DiBqXC2W.js +1 -0
- package/dist/assets/Index-HS9ewrHk.js +1 -0
- package/dist/assets/Index-KKuLrOV7.js +1 -0
- package/dist/assets/{Index-C3KdMtuJ.js → Index-aNTiBE8l.js} +1 -1
- package/dist/assets/Index-zXeYOts6.js +1 -0
- package/dist/assets/Invitees-CDdin_zl.js +1 -0
- package/dist/assets/List-C358Vzd4.js +1 -0
- package/dist/assets/{List-CpmsTN-x.js → List-CMovwYjB.js} +1 -1
- package/dist/assets/List-aru9FNfS.js +1 -0
- package/dist/assets/{Login-D8lHpp8_.js → Login-ZkRB_fWm.js} +1 -1
- package/dist/assets/Main-B5RiswqX.js +1 -0
- package/dist/assets/Main-DC6pe9Hl.css +1 -0
- package/dist/assets/Model-CtN4cAoL.js +1 -0
- package/dist/assets/Navigator-DjUbPnUI.js +4 -0
- package/dist/assets/NoTasks-BOopjPtL.js +1 -0
- package/dist/assets/NotFound-m-5oeC2J.js +1 -0
- package/dist/assets/Pagination-CbbWdJIl.js +1 -0
- package/dist/assets/Pay-CgS135WT.js +1 -0
- package/dist/assets/{Player-2INZtHKM.js → Player-DvgjC7c5.js} +1 -1
- package/dist/assets/Seedance-cdIlG9x0.js +1 -0
- package/dist/assets/Status-CeZgC2Ye.js +1 -0
- package/dist/assets/{Subscribe-zzALuzD_.js → Subscribe-Ci-2Fv2D.js} +1 -1
- package/dist/assets/TabSwitcher-be-vKwWY.js +1 -0
- package/dist/assets/{Tts-OssDK7g2.js → Tts-D28gFP1B.js} +1 -1
- package/dist/assets/VideoPlayer-CD9PlOS8.js +1 -0
- package/dist/assets/{_Uint8Array-0UxlbjS_.js → _Uint8Array-3-KsyGhc.js} +1 -1
- package/dist/assets/{_baseClone-7uTPqT6Z.js → _baseClone-BG8qyJTx.js} +1 -1
- package/dist/assets/{_baseIteratee-Bt4PVrpe.js → _baseIteratee-jiBmvyYc.js} +1 -1
- package/dist/assets/{_initCloneObject-BJVAPsyT.js → _initCloneObject-ClDbGB1c.js} +1 -1
- package/dist/assets/alert-OvnfgMB-.js +1 -0
- package/dist/assets/avatar-BK3H5LlO.js +1 -0
- package/dist/assets/avatar-CTHa5OEM.js +1 -0
- package/dist/assets/{basic-DjOEpDHb.js → basic-D2PYpKX5.js} +1 -1
- package/dist/assets/button-DfsQodL-.js +1 -0
- package/dist/assets/card-DjyfNde2.js +1 -0
- package/dist/assets/castArray-BbtsObcD.js +1 -0
- package/dist/assets/{chat-Bd1MhKHM.js → chat-C1EUkJXK.js} +1 -1
- package/dist/assets/checkbox-BAeQdLeW.js +1 -0
- package/dist/assets/{click-outside-DSZqOY28.js → click-outside-Bc_xOTXp.js} +1 -1
- package/dist/assets/{codingBridge-B25WgdE9.js → codingBridge-DEvwc0PR.js} +1 -1
- package/dist/assets/{codingBridgeNotify-DX5ZVYs5.js → codingBridgeNotify-DKoA2JP9.js} +2 -2
- package/dist/assets/collapse-BxNTm00O.js +1 -0
- package/dist/assets/collapse-transition-C9jp2nDh.js +1 -0
- package/dist/assets/{constants-BvG5EAGh.js → constants-DwFseFmM.js} +2 -2
- package/dist/assets/container-BgEH5azS.js +1 -0
- package/dist/assets/{createTaskActions-Bd0lV_LE.js → createTaskActions-CvBFHmmD.js} +1 -1
- package/dist/assets/date-picker-CiLjAJPo.js +1 -0
- package/dist/assets/{debounce-BY7z7rFy.js → debounce-DDZaE3JE.js} +1 -1
- package/dist/assets/divider-LA__Fty9.js +1 -0
- package/dist/assets/drawer-Dpuj2uIl.js +1 -0
- package/dist/assets/dropdown-CG4l8dKx.js +1 -0
- package/dist/assets/empty-DA4nlQUv.js +1 -0
- package/dist/assets/{esm-DQNcBaaX.js → esm-BqiBebi7.js} +1 -1
- package/dist/assets/esm-CDp0Qf7i.js +1 -0
- package/dist/assets/{esm-C8j0AbsO.js → esm-CWP9r0G2.js} +1 -1
- package/dist/assets/{esm-pnxjl399.js → esm-CWSmgMpA.js} +3 -3
- package/dist/assets/{esm-DjrqYIbY.js → esm-Cj99PCoU.js} +1 -1
- package/dist/assets/esm-D2sFB5nS.js +2 -0
- package/dist/assets/{esm-CMBbOElR.js → esm-DRxku3NW.js} +2 -2
- package/dist/assets/{fish-DHt-p1tt.js → fish-BP62Jr0O.js} +1 -1
- package/dist/assets/{flux-Bxi_3rRn.js → flux-CDZygm05.js} +1 -1
- package/dist/assets/{form-D0aSFxDK.js → form-DnBQT-zH.js} +2 -2
- package/dist/assets/{grokvideo-rpcw-A9h.js → grokvideo-C53uzPoZ.js} +1 -1
- package/dist/assets/{hailuo-BAeFLJMK.js → hailuo-CWOkLsy0.js} +1 -1
- package/dist/assets/{headshots-UqFyWOgH.js → headshots-C7l2OtHq.js} +1 -1
- package/dist/assets/image-r_Sil4Yc.js +1 -0
- package/dist/assets/index-1hhw9POE.js +570 -0
- package/dist/assets/{index.browser.esm-C-8P0-KG.js → index.browser.esm-BXdtHnHu.js} +1 -1
- package/dist/assets/{index.es-Cf1Nz1bg.js → index.es-Ds6M0PuH.js} +2 -2
- package/dist/assets/input-number-Bg1zmr12.js +1 -0
- package/dist/assets/{install-ClulZuUd.js → install-CmiepWqE.js} +1 -1
- package/dist/assets/{isEqual-XQKSKR3y.js → isEqual-CE_hv887.js} +1 -1
- package/dist/assets/isPlainObject-Bo35bFi4.js +1 -0
- package/dist/assets/{kling-D5QJB_Ng.js → kling-DvkijwuP.js} +1 -1
- package/dist/assets/{luma-5t28HDaV.js → luma-DC40B8tL.js} +1 -1
- package/dist/assets/{midjourney-DnrYNkPc.js → midjourney-XBP74pFR.js} +1 -1
- package/dist/assets/{nanobanana-CDURxwbr.js → nanobanana-DHolv0td.js} +1 -1
- package/dist/assets/{openaiimage-ANQQWpAt.js → openaiimage-COmDdgg9.js} +1 -1
- package/dist/assets/{pagination-CbQjtYtK.js → pagination-DH5leY8A.js} +3 -3
- package/dist/assets/{pika-BM1je10R.js → pika--x6r8JlL.js} +1 -1
- package/dist/assets/{pixverse-CgcozPhg.js → pixverse-B5tqJ_b9.js} +1 -1
- package/dist/assets/popover-Cpr0N2Z1.js +1 -0
- package/dist/assets/{producer-DtORxhGG.js → producer-CrblN48L.js} +1 -1
- package/dist/assets/progress-C3UHYIHi.js +6 -0
- package/dist/assets/{qrart-CNr8OmUX.js → qrart-Dfku4NkR.js} +1 -1
- package/dist/assets/radio-BmBXySlN.js +1 -0
- package/dist/assets/raf-NSjkkBtT.js +1 -0
- package/dist/assets/{repeat-click-bdfKzhUt.js → repeat-click-DbK3DhkT.js} +1 -1
- package/dist/assets/row-bfsY0Sup.js +1 -0
- package/dist/assets/{runtime-Cvku-lF9.js → runtime-B1Eal4u3.js} +1 -1
- package/dist/assets/{scroll-Dk1pKbmY.js → scroll-ChHyik37.js} +1 -1
- package/dist/assets/scrollbar-DcyQ_b2c.js +1 -0
- package/dist/assets/{seedance-DGLoxsts.js → seedance-BvTouhw7.js} +1 -1
- package/dist/assets/{seedream-CKWZ17SP.js → seedream-C0OkbFis.js} +1 -1
- package/dist/assets/select-CxvkoR_I.js +1 -0
- package/dist/assets/{serp-B8Rpd6O4.js → serp-DKGjlmaC.js} +1 -1
- package/dist/assets/skeleton-C4sltx62.js +1 -0
- package/dist/assets/slider-CfcYZR4R.js +1 -0
- package/dist/assets/solana-wallets-CrItVnUL.js +2 -0
- package/dist/assets/solana-wallets-vue-Cfl3r9NB.js +16 -0
- package/dist/assets/{sora-CSIXZI_k.js → sora-Bk3RvCXZ.js} +1 -1
- package/dist/assets/strings-CaTtp-gD.js +1 -0
- package/dist/assets/{suno-Cb7b-6Sf.js → suno-Bbnp6P4i.js} +1 -1
- package/dist/assets/switch-BUEiwneZ.js +1 -0
- package/dist/assets/table-lRQt4LGt.js +1 -0
- package/dist/assets/tabs-dRngkdRx.js +1 -0
- package/dist/assets/{taskDrawerMixin-Cr17Yxqk.js → taskDrawerMixin-DEgO_R5H.js} +1 -1
- package/dist/assets/teleport-CVHCI9MK.js +1 -0
- package/dist/assets/{tooltip-C3PYfh8V.js → tooltip-BLwTovWL.js} +1 -1
- package/dist/assets/upload-cn_TUU3N.js +1 -0
- package/dist/assets/{use-aria-B1wQLdcx.js → use-aria-ldhUoRRB.js} +1 -1
- package/dist/assets/use-deprecated-BzKQGDXN.js +1 -0
- package/dist/assets/use-dialog-CLGp3CMB.js +1 -0
- package/dist/assets/{vendor-chart-mdwpew_o.js → vendor-chart-BJCvKk8-.js} +1 -1
- package/dist/assets/{vendor-vue-router-ChMPprnO.js → vendor-vue-router-WDnlh53U.js} +1 -1
- package/dist/assets/{veo-Za6Gk4fK.js → veo-Cunbs9e5.js} +1 -1
- package/dist/assets/vnode-BC_9e2sB.js +1 -0
- package/dist/assets/{wan-BT-iTbG4.js → wan-GH45xAZP.js} +1 -1
- package/dist/assets/{web-erWkQ-Dp.js → web-C9aK-R5v.js} +1 -1
- package/dist/assets/{web-BFrJpl1z.js → web-CG6DXPr0.js} +1 -1
- package/dist/assets/{web-_E9nJCZ3.js → web-CXzkL4Px.js} +1 -1
- package/dist/assets/{web-CFOQGlil.js → web-C_klyBjH.js} +1 -1
- package/dist/assets/{web-BBMJGHZS.js → web-Cx3VD86e.js} +1 -1
- package/dist/assets/{webextrator-2SD1N0gE.js → webextrator-CI0OahQs.js} +1 -1
- package/dist/assets/wechat-CBB0_nqe.js +1 -0
- package/dist/index.html +15 -13
- package/package.json +5 -2
- package/dist/assets/ApiCodeButton-Dyr9-U56.js +0 -1
- package/dist/assets/Auth-BdsnpmLJ.js +0 -1
- package/dist/assets/Bare-hFRd7IO1.js +0 -1
- package/dist/assets/BotPlaceholder-DmDddO0B.js +0 -1
- package/dist/assets/BottomFooter-DGKDzEmp.js +0 -1
- package/dist/assets/Consumption-D3EMWpgi.js +0 -1
- package/dist/assets/Conversation-DAIM2BYP.js +0 -3
- package/dist/assets/CopyToClipboard-C4Zr_RWu.js +0 -1
- package/dist/assets/Extra-Cttm57lA.js +0 -1
- package/dist/assets/Hailuo-B8VUskl6.js +0 -1
- package/dist/assets/History-zzejzvEe.js +0 -1
- package/dist/assets/ImagePreview-CuVgQnIV.js +0 -1
- package/dist/assets/ImageWrapper-Bf4G9gSN.js +0 -1
- package/dist/assets/Index-5igHqNRC.js +0 -1
- package/dist/assets/Index-8qLmowmm.js +0 -1
- package/dist/assets/Index-BK2POOz0.js +0 -1
- package/dist/assets/Index-BdKkl_jH.js +0 -1
- package/dist/assets/Index-Bz1_IjnQ.js +0 -1
- package/dist/assets/Index-C0ao45MD.js +0 -1
- package/dist/assets/Index-CAeieVBr.js +0 -1
- package/dist/assets/Index-CO1u616n.js +0 -1
- package/dist/assets/Index-CPbaU9RK.js +0 -1
- package/dist/assets/Index-CTRSmb24.js +0 -2
- package/dist/assets/Index-CVodcuY9.js +0 -1
- package/dist/assets/Index-ChLTmZK7.js +0 -1
- package/dist/assets/Index-Cr4kH5Om.js +0 -1
- package/dist/assets/Index-D-A_jLra.js +0 -1
- package/dist/assets/Index-D2IlIft3.js +0 -1
- package/dist/assets/Index-D9LWwVll.js +0 -1
- package/dist/assets/Index-DCU3TFxy.js +0 -1
- package/dist/assets/Index-D_VW1YEV.js +0 -1
- package/dist/assets/Index-Dp_I3Nni.js +0 -1
- package/dist/assets/Index-Dwoz4UEF.js +0 -1
- package/dist/assets/Index-ngN1x09i.js +0 -1
- package/dist/assets/Index-qdsD9sWK.js +0 -1
- package/dist/assets/Index-u4T-lPNZ.js +0 -1
- package/dist/assets/Index-vy04B0L7.js +0 -1
- package/dist/assets/Invitees--UohfA0r.js +0 -1
- package/dist/assets/List-CIIP32Zq.js +0 -1
- package/dist/assets/List-Cq_clXpY.js +0 -1
- package/dist/assets/Main-wcORSNMH.js +0 -1
- package/dist/assets/Main-y41dJXZG.css +0 -1
- package/dist/assets/Model-B-VLRqLL.js +0 -1
- package/dist/assets/Navigator-Cf5cwtpn.js +0 -4
- package/dist/assets/NoTasks-CrhfF4zj.js +0 -1
- package/dist/assets/NotFound-Bp6bwi_I.js +0 -1
- package/dist/assets/Pagination-D4JXV_fZ.js +0 -1
- package/dist/assets/Pay-D6OORk21.js +0 -1
- package/dist/assets/Seedance-CgoG1hAA.js +0 -1
- package/dist/assets/Status-BmjcnykJ.js +0 -1
- package/dist/assets/TabSwitcher-BDBh-Zw9.js +0 -1
- package/dist/assets/VideoPlayer-CxSJ4zS_.js +0 -1
- package/dist/assets/alert-BJj7gY4q.js +0 -1
- package/dist/assets/avatar-D3aeuhVV.js +0 -1
- package/dist/assets/avatar-DJGt2zYX.js +0 -1
- package/dist/assets/button-DWzbdjZV.js +0 -1
- package/dist/assets/card-B1OoUKT4.js +0 -1
- package/dist/assets/castArray-BFcmUPBb.js +0 -1
- package/dist/assets/checkbox-hfJFSY6z.js +0 -1
- package/dist/assets/collapse-Be4--o_J.js +0 -1
- package/dist/assets/collapse-transition-C7m30vMg.js +0 -1
- package/dist/assets/container-DUnSq7iO.js +0 -1
- package/dist/assets/date-picker-DetLi8Z0.js +0 -1
- package/dist/assets/divider-Ba_Z3oBh.js +0 -1
- package/dist/assets/drawer-BvYPSxXh.js +0 -1
- package/dist/assets/dropdown-ClFBH1K7.js +0 -1
- package/dist/assets/empty-D5eN5M0S.js +0 -1
- package/dist/assets/esm-BDMJkg33.js +0 -1
- package/dist/assets/esm-WUH0q0co.js +0 -2
- package/dist/assets/image-C1JYEL_e.js +0 -1
- package/dist/assets/index-B7Ehq3WB.js +0 -570
- package/dist/assets/input-number-CVD04ts_.js +0 -1
- package/dist/assets/isPlainObject-2p88HvQz.js +0 -1
- package/dist/assets/popover-ziWceeAq.js +0 -1
- package/dist/assets/progress-Djs_fbqu.js +0 -6
- package/dist/assets/radio-IJQsW93X.js +0 -1
- package/dist/assets/raf-Bo8-dFzL.js +0 -1
- package/dist/assets/row-BCC3U-kp.js +0 -1
- package/dist/assets/scrollbar-BkgtdYMt.js +0 -1
- package/dist/assets/select-DUQSa_dv.js +0 -1
- package/dist/assets/skeleton-Cn4UY-T8.js +0 -1
- package/dist/assets/slider-D-yKoeJR.js +0 -1
- package/dist/assets/solana-wallets-BuXFTmyL.js +0 -2
- package/dist/assets/solana-wallets-vue-D4aMli4w.js +0 -16
- package/dist/assets/strings-DaYxHDzK.js +0 -1
- package/dist/assets/switch-DflwVy6G.js +0 -1
- package/dist/assets/table-fY8LUehs.js +0 -1
- package/dist/assets/tabs-CM47Khie.js +0 -1
- package/dist/assets/teleport-B3tPbGeJ.js +0 -1
- package/dist/assets/upload-BbP3qVit.js +0 -1
- package/dist/assets/use-deprecated-CPfQu7wa.js +0 -1
- package/dist/assets/use-dialog-Daprv7SC.js +0 -1
- package/dist/assets/vnode-BMVwTmkF.js +0 -1
- package/dist/assets/wechat-iv-pzVEX.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,nt as h,tt as g,ut as _,v,y}from"./vendor-chart-BJCvKk8-.js";import{t as b}from"./button-DfsQodL-.js";import{F as x,X as S,Y as C,tt as w,z as T}from"./use-deprecated-BzKQGDXN.js";import{r as E,t as D}from"./select-CxvkoR_I.js";import{n as O,t as k}from"./tabs-dRngkdRx.js";import{n as A,t as j}from"./form-DnBQT-zH.js";import{t as M}from"./upload-cn_TUU3N.js";import{t as N}from"./tooltip-BLwTovWL.js";import{t as P}from"./image-r_Sil4Yc.js";import{t as F}from"./avatar-CTHa5OEM.js";import{t as I}from"./checkbox-BAeQdLeW.js";import{n as L,r as R,t as ee}from"./radio-BmBXySlN.js";import{n as te,t as ne}from"./collapse-BxNTm00O.js";import{t as z}from"./drawer-Dpuj2uIl.js";import{n as B,r as V,t as H}from"./dropdown-CG4l8dKx.js";import{t as U}from"./input-number-Bg1zmr12.js";import{t as re}from"./popover-Cpr0N2Z1.js";import{t as ie}from"./progress-C3UHYIHi.js";import{n as ae,t as oe}from"./skeleton-C4sltx62.js";import{t as se}from"./slider-CfcYZR4R.js";import{t as ce}from"./switch-BUEiwneZ.js";import{Fn as le,_i as ue}from"./constants-DwFseFmM.js";import{An as de,At as fe,E as W,Fn as pe,Ir as G,Mr as K,Nt as me,Or as q,Ot as he,Sr as ge,kr as J,kt as _e,rn as Y,yr as X}from"./index-1hhw9POE.js";import{t as Z}from"./index.es-Ds6M0PuH.js";import{n as ve}from"./taskDrawerMixin-DEgO_R5H.js";import{i as Q,n as ye,r as be,t as xe}from"./pagination-DH5leY8A.js";import{n as Se,t as Ce}from"./NoTasks-BOopjPtL.js";import{t as we}from"./Consumption-D_CAQaSB.js";import{n as Te,r as $,t as Ee}from"./Player-DvgjC7c5.js";var De=r({name:`LayoutSuno`,components:{ElDrawer:z,ElButton:b,FontAwesomeIcon:Z},mixins:[ve],data(){return{preview:!1}},computed:{}}),Oe={class:`main flex flex-row flex-1`},ke={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 flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},je={class:`preview h-full w-[300px] flex flex-col`};function Me(e,r,i,a,s,c){let l=g(`font-awesome-icon`),d=g(`el-button`),m=g(`el-drawer`);return u(),t(`div`,Oe,[n(`div`,ke,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,Ae,[p(e.$slots,`result`,{},void 0,!0)]),n(`div`,je,[p(e.$slots,`preview`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:_(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[v,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:_(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ne=W(De,[[`render`,Me],[`__scopeId`,`data-v-169b0449`]]),Pe=r({name:`TypeSelector`,components:{ElSelect:E,ElOption:D,ElSwitch:ce},data(){return{options:[{label:`v5.5`,value:`chirp-v5-5`,desc:this.$t(`suno.model.v55desc`)},{label:`v5`,value:`chirp-v5`,desc:this.$t(`suno.model.v5desc`)},{label:`v4.5+`,value:`chirp-v4-5-plus`,desc:this.$t(`suno.model.v45plusdesc`)},{label:`v4.5`,value:`chirp-v4-5`,desc:this.$t(`suno.model.v45desc`),dividerAfter:!0},{label:`v4`,value:`chirp-v4`,desc:this.$t(`suno.model.v4desc`)},{label:`v3.5`,value:`chirp-v3-5`,desc:this.$t(`suno.model.v35desc`)},{label:`v3`,value:`chirp-v3-0`,desc:this.$t(`suno.model.v3desc`)}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||=le}}),Fe={class:`mb-3`},Ie={class:`flex items-center mb-1`},Le={class:`text-sm font-bold`},Re={class:`model-option`},ze={class:`model-option-left`},Be={class:`model-option-name`},Ve={class:`model-option-desc`},He={key:0,class:`flex items-center justify-between mb-3`},Ue={class:`text-sm font-bold`};function We(r,i,d,f,p,h){let v=g(`el-option`),y=g(`el-select`),b=g(`el-switch`);return u(),t(`div`,null,[n(`div`,Fe,[n(`div`,Ie,[n(`span`,Le,l(r.$t(`suno.name.model`)),1)]),o(y,{modelValue:r.model,"onUpdate:modelValue":i[0]||=e=>r.model=e,class:`w-full model-select`,size:`default`,placeholder:r.$t(`suno.placeholder.select`)},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e.value,label:e.label,value:e.value,class:c({"model-option-divider":e.dividerAfter})},{default:_(()=>[n(`div`,Re,[n(`div`,ze,[n(`span`,Be,l(e.label),1)]),n(`span`,Ve,l(e.desc),1)])]),_:2},1032,[`label`,`value`,`class`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),r.custom?(u(),t(`div`,He,[n(`span`,Ue,l(r.$t(`suno.name.instrumental`)),1),o(b,{modelValue:r.instrumental,"onUpdate:modelValue":i[1]||=e=>r.instrumental=e},null,8,[`modelValue`])])):m(``,!0)])}var Ge=W(Pe,[[`render`,We],[`__scopeId`,`data-v-16e4d6fc`]]),Ke=r({name:`UploadAudio`,components:{ElUpload:M,ElButton:b,ElDialog:K,ElTabs:O,ElTabPane:k,InfoIcon:Q,FontAwesomeIcon:Z,ElRadioGroup:R,ElRadioButton:L},mixins:[_e],emits:[`change`],data(){return{fileList:[],uploadUrl:ge()+`/api/v1/files/`,dialogVisible:!1,activeTab:`browse`,recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){let e=this.$store.state.suno?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.suno?.config?.action||`upload_extend`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,action:e})}},formattedTime(){return`${Math.floor(this.recordSeconds/60).toString().padStart(2,`0`)}:${(this.recordSeconds%60).toString().padStart(2,`0`)}`}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){J.warning(this.$t(`suno.message.uploadReferencesExceed`))},onError(){J.error(this.$t(`suno.message.uploadReferencesError`))},async onBrowseSuccess(){let e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingUploadAudio`));try{let e=await Y.upload(t,{token:n});console.debug(`get upload music success`,e.data);let r=e.data?.data.audio_id;this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_id:r,action:`upload_extend`}),J.success(this.$t(`suno.message.startUploadAudioSuccess`))}catch(e){J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startUploadAudioFailed`))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>`u`){J.error(this.$t(`suno.message.recordingUnsupported`));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{let e=new Blob(this.recordedChunks,{type:`audio/webm`});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error(`record error`,e),J.error(this.$t(`suno.message.recordingPermissionDenied`))}},stopRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.mediaRecorder&&this.mediaRecorder.state!==`inactive`&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{let e=new FormData,t=`recording-${Date.now()}.webm`;e.append(`file`,this.recordedBlob,t);let n=await fetch(this.uploadUrl,{method:`POST`,headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!n.ok)throw Error(`upload failed: ${n.status}`);let r=await n.json(),i=r?.file_url||r?.data?.file_url;if(!i)throw Error(`no file_url in response`);this.audioPreviewUrl=i,await this.onGenerateAudioId(i),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),J.error(e?.message||this.$t(`suno.message.uploadReferencesError`))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&=(this.mediaStream.getTracks().forEach(e=>e.stop()),null)},cleanupRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.releaseStream(),this.recordedAudioUrl&&=(URL.revokeObjectURL(this.recordedAudioUrl),null)}}}),qe={class:`relative`},Je={class:`flex justify-between items-center mb-2`},Ye={class:`flex justify-start items-center`},Xe={class:`text-sm font-bold`},Ze={key:0,class:`mb-2`},Qe=[`src`],$e={key:1,class:`mt-2`},et={class:`py-4`},tt={class:`text-center py-6`},nt={class:`text-sm`},rt={class:`text-xs text-gray-400 mt-1`},it={class:`py-4 text-center`},at={class:`recorder-display mb-4`},ot={key:0,class:`text-red-500 flex items-center justify-center gap-2`},st={class:`text-2xl font-mono`},ct={key:1,class:`text-green-600`},lt={key:2,class:`text-gray-400 text-2xl font-mono`},ut={key:0,class:`mb-4`},dt=[`src`],ft={class:`flex justify-center gap-3`};function pt(e,r,c,d,f,p){let h=g(`info-icon`),v=g(`font-awesome-icon`),y=g(`el-button`),b=g(`el-radio-button`),x=g(`el-radio-group`),S=g(`el-upload`),C=g(`el-tab-pane`),w=g(`el-tabs`),T=g(`el-dialog`);return u(),t(`div`,qe,[n(`div`,Je,[n(`div`,Ye,[n(`span`,Xe,l(e.$t(`suno.name.referenceAudios`)),1),o(h,{content:e.$t(`suno.description.uploadAudios`)},null,8,[`content`])]),o(y,{round:``,type:`primary`,size:`small`,onClick:r[0]||=t=>e.dialogVisible=!0},{default:_(()=>[o(v,{icon:`fa-solid fa-plus`,class:`icon mr-1`}),i(` `+l(e.$t(`suno.button.addAudio`)),1)]),_:1})]),e.audioPreviewUrl?(u(),t(`div`,Ze,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Qe)])):m(``,!0),e.hasUploadedAudio?(u(),t(`div`,$e,[o(x,{modelValue:e.uploadAction,"onUpdate:modelValue":r[1]||=t=>e.uploadAction=t,size:`small`},{default:_(()=>[o(b,{value:`upload_extend`},{default:_(()=>[i(l(e.$t(`suno.button.extend`)),1)]),_:1}),o(b,{value:`upload_cover`},{default:_(()=>[i(l(e.$t(`suno.button.upload_cover`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),o(T,{modelValue:e.dialogVisible,"onUpdate:modelValue":r[4]||=t=>e.dialogVisible=t,title:e.$t(`suno.name.addAudio`),width:`520px`,"close-on-click-modal":!1,"append-to-body":``},{default:_(()=>[o(w,{modelValue:e.activeTab,"onUpdate:modelValue":r[3]||=t=>e.activeTab=t,class:`add-audio-tabs`},{default:_(()=>[o(C,{name:`browse`,label:e.$t(`suno.tab.browse`)},{default:_(()=>[n(`div`,et,[o(S,{"file-list":e.fileList,"onUpdate:fileList":r[2]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:``},{default:_(()=>[n(`div`,tt,[o(v,{icon:`fa-solid fa-upload`,class:`text-4xl text-gray-400 mb-3`}),n(`div`,nt,l(e.$t(`suno.description.dropAudioHere`)),1),n(`div`,rt,l(e.$t(`suno.description.audioFormats`)),1)])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])]),_:1},8,[`label`]),o(C,{name:`record`,label:e.$t(`suno.tab.record`)},{default:_(()=>[n(`div`,it,[n(`div`,at,[e.recording?(u(),t(`div`,ot,[r[5]||=n(`span`,{class:`recording-dot`},null,-1),n(`span`,st,l(e.formattedTime),1)])):e.recordedBlob?(u(),t(`div`,ct,[o(v,{icon:`fa-solid fa-check-circle`,class:`text-2xl mr-2`}),n(`span`,null,l(e.$t(`suno.message.recordingReady`))+` (`+l(e.formattedTime)+`)`,1)])):(u(),t(`div`,lt,`00:00`))]),e.recordedAudioUrl&&!e.recording?(u(),t(`div`,ut,[n(`audio`,{src:e.recordedAudioUrl,controls:``,class:`w-full`},null,8,dt)])):m(``,!0),n(`div`,ft,[!e.recording&&!e.recordedBlob?(u(),a(y,{key:0,type:`primary`,round:``,onClick:e.startRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.startRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recording?(u(),a(y,{key:1,type:`danger`,round:``,onClick:e.stopRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-stop`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.stopRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recordedBlob&&!e.recording?(u(),t(s,{key:2},[o(y,{round:``,onClick:e.resetRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.reRecord`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,round:``,loading:e.uploadingRecord,onClick:e.uploadRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.useRecording`)),1)]),_:1},8,[`loading`,`onClick`])],64)):m(``,!0)])])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`])])}var mt=W(Ke,[[`render`,pt],[`__scopeId`,`data-v-5f17a1f4`]]),ht=[{key:`lofi`,label:`🎧 Lo-fi Chill`,prompt:`a relaxing lo-fi hip hop beat for studying`},{key:`pop-love`,label:`💕 Pop Love Song`,prompt:`a catchy pop love song with sweet melodies`},{key:`rock-anthem`,label:`🎸 Rock Anthem`,prompt:`an energetic rock anthem with electric guitars`},{key:`jazz-night`,label:`🎷 Jazz Night`,prompt:`a smooth late-night jazz piece with saxophone`},{key:`edm-drop`,label:`⚡ EDM Drop`,prompt:`an intense EDM track with a massive drop`},{key:`folk-story`,label:`🪕 Folk Story`,prompt:`a warm folk song telling a story about traveling`},{key:`rnb-groove`,label:`🎤 R&B Groove`,prompt:`a smooth R&B groove with soulful vocals`},{key:`classical`,label:`🎻 Classical`,prompt:`an elegant classical piece for orchestra`},{key:`hip-hop`,label:`🎤 Hip Hop`,prompt:`a hard-hitting hip hop beat with bass`},{key:`country`,label:`🤠 Country`,prompt:`an upbeat country song with acoustic guitar and banjo`},{key:`reggae`,label:`🌴 Reggae`,prompt:`a laid-back reggae tune with island vibes`},{key:`latin`,label:`💃 Latin`,prompt:`a vibrant Latin dance track with percussion`},{key:`ambient`,label:`🌊 Ambient`,prompt:`a dreamy ambient soundscape for relaxation`},{key:`metal`,label:`🤘 Metal`,prompt:`a powerful metal song with heavy riffs and double bass drums`},{key:`soul`,label:`🎵 Soul`,prompt:`a heartfelt soul ballad with gospel harmonies`},{key:`synthwave`,label:`🌃 Synthwave`,prompt:`a retro synthwave track with 80s vibes`},{key:`kpop`,label:`🇰🇷 K-Pop`,prompt:`a catchy K-pop dance track with hook`},{key:`lullaby`,label:`🌙 Lullaby`,prompt:`a gentle lullaby for bedtime with soft piano`},{key:`cinematic`,label:`🎬 Cinematic`,prompt:`an epic cinematic orchestral score for a movie trailer`},{key:`blues`,label:`🎸 Blues`,prompt:`a soulful blues song with electric guitar bends`},{key:`disco`,label:`🕺 Disco`,prompt:`a funky disco track with groovy bassline`},{key:`punk`,label:`🔥 Punk Rock`,prompt:`a fast punk rock song with raw energy`},{key:`gospel`,label:`⛪ Gospel`,prompt:`an uplifting gospel choir song with piano`},{key:`trap`,label:`🔊 Trap`,prompt:`a dark trap beat with 808s and hi-hats`},{key:`bossa`,label:`☕ Bossa Nova`,prompt:`a gentle bossa nova with nylon guitar`},{key:`indie`,label:`🎶 Indie`,prompt:`a dreamy indie track with ethereal vocals`},{key:`cpop`,label:`🇨🇳 C-Pop`,prompt:`a beautiful Chinese pop ballad with emotional vocals`},{key:`jpop`,label:`🇯🇵 J-Pop`,prompt:`a cheerful J-pop song with anime vibes`},{key:`afrobeat`,label:`🥁 Afrobeat`,prompt:`a groovy Afrobeat track with layered percussion`},{key:`game`,label:`🎮 Game BGM`,prompt:`an adventurous video game background music`}],gt=8;function _t(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var vt=r({name:`PromptInput`,components:{FontAwesomeIcon:Z,PromptTextarea:Se},data(){return{shuffledTags:_t(ht)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,gt)}},mounted(){this.prompt||=``},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=_t(ht)}}}),yt={class:`inspo-tags`},bt=[`onClick`];function xt(r,i,c,d,f,p){let m=g(`font-awesome-icon`),h=g(`prompt-textarea`);return u(),a(h,{modelValue:r.prompt,"onUpdate:modelValue":i[1]||=e=>r.prompt=e,title:r.$t(`suno.name.songDescription`),info:r.$t(`suno.description.prompt`),placeholder:r.$t(`suno.placeholder.prompt`),"min-rows":5,"max-rows":14},{after:_(()=>[n(`div`,yt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e.key,class:`inspo-tag`,onClick:t=>r.onTagClick(e)},l(e.label),9,bt))),128)),n(`button`,{class:`inspo-tag inspo-tag-refresh`,onClick:i[0]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(m,{icon:`fa-solid fa-arrows-rotate`})])])]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var St=W(vt,[[`render`,xt],[`__scopeId`,`data-v-58ffcd38`]]),Ct=r({name:`LyricInput`,components:{ElInput:G,ElButton:b,ElTooltip:N,ElDialog:K,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:``,lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||=``},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){let e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=``},async onEnhanceLyrics(){let e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,J.info(this.$t(`suno.message.enhancingLyrics`));try{let t=`${this.enhancePrompt}\n\nOriginal lyrics:\n${this.lyric}`,n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,this.enhancePrompt=``,J.success(this.$t(`suno.message.enhanceLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.enhanceLyricsFailed`))}finally{this.enhancingLyrics=!1}}},async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t;try{t=((await q.prompt(this.$t(`suno.message.lyricsThemePromptMessage`),this.$t(`suno.message.lyricsThemePromptTitle`),{confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`),inputPlaceholder:this.$t(`suno.placeholder.lyricsTheme`),inputValue:this.config?.title||``,inputType:`textarea`,inputValidator:e=>typeof e==`string`&&e.trim().length>0||this.$t(`suno.message.lyricsThemeRequired`)})).value||``).trim()}catch{return}if(t){this.pushHistory(),this.generatingLyrics=!0,J.info(this.$t(`suno.message.generatingLyrics`));try{let n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:n.text,title:n.title}),J.success(this.$t(`suno.message.generateLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}}),wt={class:`field`},Tt={class:`flex items-center justify-between mb-1`},Et={class:`flex items-center`},Dt={class:`text-sm font-bold`},Ot={class:`flex items-center gap-1`},kt={class:`relative`},At={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},jt={key:0,class:`enhance-bar`},Mt={key:0,class:`enhance-bar mt-3`},Nt={class:`flex items-center justify-between`},Pt={class:`flex items-center gap-1`};function Ft(e,r,s,c,d,f){let p=g(`info-icon`),h=g(`font-awesome-icon`),v=g(`el-button`),b=g(`el-tooltip`),x=g(`el-input`),S=g(`el-dialog`);return u(),t(`div`,wt,[n(`div`,Tt,[n(`div`,Et,[n(`span`,Dt,l(e.$t(`suno.name.lyrics`)),1),o(p,{content:e.$t(`suno.description.lyrics`)},null,8,[`content`])]),n(`div`,Ot,[e.lyricHistory.length>0?(u(),a(b,{key:0,content:e.$t(`suno.button.undo`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),e.lyric?(u(),a(b,{key:1,content:e.$t(`suno.button.clear_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),o(b,{content:e.$t(`suno.button.expand_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:r[0]||=t=>e.expanded=!0},{default:_(()=>[o(h,{icon:`fa-solid fa-expand`})]),_:1})]),_:1},8,[`content`]),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))])]),n(`div`,kt,[e.config?.action===`extend`?(u(),a(x,{key:1,modelValue:e.lyric,"onUpdate:modelValue":r[2]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(u(),a(x,{key:0,modelValue:e.lyric,"onUpdate:modelValue":r[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`])),n(`div`,At,l(e.lyric?.length||0)+`/5000`,1)]),e.lyric&&e.config?.action!==`extend`?(u(),t(`div`,jt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[3]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])])):m(``,!0),o(S,{modelValue:e.expanded,"onUpdate:modelValue":r[7]||=t=>e.expanded=t,title:e.$t(`suno.name.lyrics`),width:`720px`,top:`5vh`,"close-on-click-modal":!1,class:`lyrics-expand-dialog`},{footer:_(()=>[n(`div`,Nt,[n(`div`,Pt,[e.lyricHistory.length>0?(u(),a(v,{key:0,size:`small`,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.undo`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.lyric?(u(),a(v,{key:1,size:`small`,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_lyrics`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),o(v,{type:`primary`,onClick:r[6]||=t=>e.expanded=!1},{default:_(()=>[i(l(e.$t(`common.button.confirm`)),1)]),_:1})])]),default:_(()=>[o(x,{modelValue:e.lyric,"onUpdate:modelValue":r[4]||=t=>e.lyric=t,type:`textarea`,rows:20,class:`lyrics-expanded`,placeholder:e.$t(`suno.placeholder.lyrics`),autofocus:``},null,8,[`modelValue`,`placeholder`]),e.config?.action===`extend`?m(``,!0):(u(),t(`div`,Mt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[5]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])]))]),_:1},8,[`modelValue`,`title`])])}var It=W(Ct,[[`render`,Ft],[`__scopeId`,`data-v-d7d2ec74`]]),Lt=`Pop.Rock.Jazz.R&B.Hip Hop.Lo-fi.Electronic.Classical.Country.Blues.Folk.Reggae.Metal.Punk.Soul.Funk.Ambient.Indie.Latin.Acoustic.Dance.Disco.Gospel.K-Pop.J-Pop.C-Pop.Bossa Nova.Trap.Drill.House.Techno.Dubstep.Synthwave.Chill.Dreamy.Upbeat.Melancholic.Romantic.Epic.Cinematic.Orchestral.Piano.Guitar.Saxophone.Violin.Tribal.World Music.Afrobeat.Ska.Grunge`.split(`.`),Rt=12;function zt(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var Bt=r({name:`StyleInput`,components:{ElInput:G,ElButton:b,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{optimizing:!1,shuffledTags:zt(Lt)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,Rt)}},methods:{onTagClick(e){let t=this.style||``;t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=zt(Lt)},async onOptimizeStyle(){let e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,J.info(this.$t(`suno.message.optimizingStyle`));try{let t=await Y.style({prompt:this.style},{token:e}),n=t.data?.text||t.data?.data?.text;n&&(this.style=n,J.success(this.$t(`suno.message.optimizeStyleSuccess`)))}catch{J.error(this.$t(`suno.message.optimizeStyleFailed`))}finally{this.optimizing=!1}}}}}),Vt={class:`field`},Ht={class:`flex items-center justify-between mb-1`},Ut={class:`flex items-center`},Wt={class:`text-sm font-bold`},Gt={class:`relative`},Kt={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},qt={class:`style-tags`},Jt=[`onClick`];function Yt(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-input`);return u(),t(`div`,Vt,[n(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,l(r.$t(`suno.name.style`)),1),o(v,{content:r.$t(`suno.description.style`)},null,8,[`content`])]),o(b,{size:`small`,loading:r.optimizing,round:``,onClick:r.onOptimizeStyle},{default:_(()=>[r.optimizing?m(``,!0):(u(),a(y,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(r.$t(`suno.button.optimize_style`)),1)]),_:1},8,[`loading`,`onClick`])]),n(`div`,Gt,[o(x,{modelValue:r.style,"onUpdate:modelValue":c[0]||=e=>r.style=e,rows:2,type:`textarea`,placeholder:r.$t(`suno.placeholder.style`)},null,8,[`modelValue`,`placeholder`]),n(`div`,Kt,l(r.style?.length||0)+`/1000`,1)]),n(`div`,qt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e,class:`style-tag`,onClick:t=>r.onTagClick(e)},l(e),9,Jt))),128)),n(`button`,{class:`style-tag style-tag-refresh`,onClick:c[1]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(y,{icon:`fa-solid fa-arrows-rotate`})])])])}var Xt=W(Bt,[[`render`,Yt],[`__scopeId`,`data-v-ddebb076`]]),Zt=r({name:`TitleInput`,components:{ElInput:G,InfoIcon:Q},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,title:e})}}}}),Qt={class:`field`},$t={class:`flex items-center mb-1`},en={class:`text-sm font-bold`};function tn(e,r,i,a,s,c){let d=g(`info-icon`),f=g(`el-input`);return u(),t(`div`,Qt,[n(`div`,$t,[n(`span`,en,l(e.$t(`suno.name.title`)),1),o(d,{content:e.$t(`suno.description.title`)},null,8,[`content`])]),o(f,{modelValue:e.title,"onUpdate:modelValue":r[0]||=t=>e.title=t,placeholder:e.$t(`suno.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var nn=W(Zt,[[`render`,tn]]),rn=r({name:`ExtendFromInput`,components:{ElImage:P,ElIcon:w,ElInputNumber:U,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),an={class:`field`},on={class:`box`},sn={class:`title font-bold`},cn={class:`input-wrapper`},ln={class:`task`},un={class:`left`},dn={key:2,class:`duration`},fn={class:`info`},pn={class:`title`},mn={class:`style`};function hn(e,r,i,a,s,c){let d=g(`el-input-number`),p=g(`el-image`),v=g(`video-pause`),y=g(`el-icon`),b=g(`video-play`),x=h(`loading`);return u(),t(`div`,an,[n(`div`,on,[n(`h2`,sn,l(e.$t(`suno.name.extend`)),1),n(`div`,cn,[o(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,ln,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[3]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,un,[o(p,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[1]||=t=>e.onPause(e.audio)},[o(y,null,{default:_(()=>[o(v)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[2]||=t=>e.onPlay(e.audio)},[o(y,null,{default:_(()=>[o(b)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,dn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,fn,[n(`h2`,pn,l(e.audio?.title),1),n(`p`,mn,l(e.audio?.style),1)])])):m(``,!0)])])}var gn=W(rn,[[`render`,hn],[`__scopeId`,`data-v-bcce4821`]]),_n=r({name:`CoverFromInput`,components:{ElImage:P,ElIcon:w,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),vn={class:`field`},yn={class:`box`},bn={class:`title font-bold`},xn={class:`task`},Sn={class:`left`},Cn={key:2,class:`duration`},wn={class:`info`},Tn={class:`title`},En={class:`style`};function Dn(e,r,i,a,s,c){let d=g(`el-image`),p=g(`video-pause`),v=g(`el-icon`),y=g(`video-play`),b=h(`loading`);return u(),t(`div`,vn,[n(`div`,yn,[n(`h2`,bn,l(e.$t(`suno.name.cover`)),1)]),n(`div`,xn,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[2]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Sn,[o(d,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[0]||=t=>e.onPause(e.audio)},[o(v,null,{default:_(()=>[o(p)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[1]||=t=>e.onPlay(e.audio)},[o(v,null,{default:_(()=>[o(y)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,Cn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,wn,[n(`h2`,Tn,l(e.audio?.title),1),n(`p`,En,l(e.audio?.style),1)])])):m(``,!0)])])}var On=W(_n,[[`render`,Dn],[`__scopeId`,`data-v-06640216`]]),kn=r({name:`VocalGenderSelector`,components:{ElRadioGroup:R,ElRadioButton:L,InfoIcon:Q},computed:{vocalGender:{get(){return this.$store.state.suno?.config?.vocal_gender||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,vocal_gender:e||void 0})}}}}),An={class:`flex items-center mb-1`},jn={class:`text-sm font-bold`};function Mn(e,r,a,s,c,d){let f=g(`info-icon`),p=g(`el-radio-button`),m=g(`el-radio-group`);return u(),t(`div`,null,[n(`div`,An,[n(`span`,jn,l(e.$t(`suno.name.vocalGender`)),1),o(f,{content:e.$t(`suno.description.vocalGender`)},null,8,[`content`])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":r[0]||=t=>e.vocalGender=t,size:`small`},{default:_(()=>[o(p,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(p,{value:`f`},{default:_(()=>[i(l(e.$t(`suno.gender.female`)),1)]),_:1}),o(p,{value:`m`},{default:_(()=>[i(l(e.$t(`suno.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Nn=W(kn,[[`render`,Mn]]),Pn=r({name:`AdvancedParams`,components:{ElCollapse:ne,ElCollapseItem:te,ElInput:G,ElSlider:se,ElRadioGroup:R,ElRadioButton:L},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){let e=this.config?.model||``;return[`chirp-v5`,`chirp-v5-5`].includes(e)},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_weight:e})}},lyricsMode:{get(){return this.$store.state.suno?.config?.lyrics_mode||`manual`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyrics_mode:e})}}},mounted(){let e=this.$store.state.suno?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.style_influence==`number`&&e.style_influence>1&&(t.style_influence=e.style_influence/100),typeof e.audio_weight==`number`&&e.audio_weight>1&&(t.audio_weight=e.audio_weight/100),Object.keys(t).length>0&&this.$store.commit(`suno/setConfig`,{...e,...t})}}),Fn={key:0,class:`mb-3`},In={class:`flex items-center mb-1`},Ln={class:`text-xs font-bold`},Rn={key:1,class:`mb-3`},zn={class:`flex items-center mb-1`},Bn={class:`text-xs font-bold`},Vn={key:2,class:`mb-3`},Hn={class:`flex items-center justify-between mb-1`},Un={class:`text-xs font-bold`},Wn={class:`text-xs text-[var(--el-text-color-secondary)]`},Gn={key:3,class:`mb-3`},Kn={class:`flex items-center justify-between mb-1`},qn={class:`text-xs font-bold`},Jn={class:`text-xs text-[var(--el-text-color-secondary)]`},Yn={key:4,class:`mb-3`},Xn={class:`flex items-center mb-1`},Zn={class:`text-xs font-bold`},Qn={key:5,class:`mb-3`},$n={class:`flex items-center justify-between mb-1`},er={class:`text-xs font-bold`},tr={class:`text-xs text-[var(--el-text-color-secondary)]`},nr={key:6,class:`mb-3`},rr={class:`flex items-center mb-1`},ir={class:`text-xs font-bold`};function ar(e,r,s,c,d,f){let p=g(`el-input`),h=g(`el-slider`),v=g(`el-radio-button`),y=g(`el-radio-group`),b=g(`el-collapse-item`),x=g(`el-collapse`);return u(),a(x,{modelValue:e.activeNames,"onUpdate:modelValue":r[7]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:_(()=>[o(b,{title:e.$t(`suno.name.advancedParams`),name:`advanced`},{default:_(()=>[e.config?.custom?(u(),t(`div`,Fn,[n(`div`,In,[n(`span`,Ln,l(e.$t(`suno.name.styleNegative`)),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`suno.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,Rn,[n(`div`,zn,[n(`span`,Bn,l(e.$t(`suno.name.lyricPrompt`)),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Vn,[n(`div`,Hn,[n(`span`,Un,l(e.$t(`suno.name.weirdness`)),1),n(`span`,Wn,l(e.weirdness??0),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Gn,[n(`div`,Kn,[n(`span`,qn,l(e.$t(`suno.name.styleInfluence`)),1),n(`span`,Jn,l(e.styleInfluence??.5),1)]),o(h,{modelValue:e.styleInfluence,"onUpdate:modelValue":r[3]||=t=>e.styleInfluence=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.isV5OrAbove?(u(),t(`div`,Yn,[n(`div`,Xn,[n(`span`,Zn,l(e.$t(`suno.name.variationCategory`)),1)]),o(y,{modelValue:e.variationCategory,"onUpdate:modelValue":r[4]||=t=>e.variationCategory=t,size:`small`},{default:_(()=>[o(v,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(v,{value:`high`},{default:_(()=>[i(l(e.$t(`suno.variation.high`)),1)]),_:1}),o(v,{value:`low`},{default:_(()=>[i(l(e.$t(`suno.variation.low`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),e.config?.action===`cover`?(u(),t(`div`,Qn,[n(`div`,$n,[n(`span`,er,l(e.$t(`suno.name.audioWeight`)),1),n(`span`,tr,l(e.audioWeight??.5),1)]),o(h,{modelValue:e.audioWeight,"onUpdate:modelValue":r[5]||=t=>e.audioWeight=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,nr,[n(`div`,rr,[n(`span`,ir,l(e.$t(`suno.name.lyricsMode`)),1)]),o(y,{modelValue:e.lyricsMode,"onUpdate:modelValue":r[6]||=t=>e.lyricsMode=t,size:`small`},{default:_(()=>[o(v,{value:`manual`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.manual`)),1)]),_:1}),o(v,{value:`auto`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.auto`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0)]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var or=W(Pn,[[`render`,ar],[`__scopeId`,`data-v-363599d3`]]),sr=r({name:`ReplaceSectionInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},replaceSectionStart:{get(){return this.$store.state.suno?.config?.replace_section_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.suno?.config?.replace_section_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),cr={class:`field`},lr={class:`flex items-center mb-2`},ur={class:`text-sm font-bold m-0`},dr={key:0,class:`task mb-2`},fr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},pr={class:`info flex-1 min-w-0`},mr={class:`text-sm font-bold m-0 truncate`},hr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},gr={class:`flex gap-2`};function _r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,cr,[n(`div`,lr,[n(`h2`,ur,l(e.$t(`suno.name.replaceSection`)),1),o(d,{content:e.$t(`suno.description.replaceSection`)},null,8,[`content`])]),e.audio?(u(),t(`div`,dr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,fr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,pr,[n(`h2`,mr,l(e.audio?.title),1),n(`p`,hr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,gr,[o(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":r[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":r[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var vr=W(sr,[[`render`,_r]]),yr=r({name:`OverpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},overpaintingStart:{get(){return this.$store.state.suno?.config?.overpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_start:e})}},overpaintingEnd:{get(){return this.$store.state.suno?.config?.overpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),br={class:`field`},xr={class:`flex items-center mb-2`},Sr={class:`text-sm font-bold m-0`},Cr={key:0,class:`task mb-2`},wr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Tr={class:`info flex-1 min-w-0`},Er={class:`text-sm font-bold m-0 truncate`},Dr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Or={class:`flex gap-2`};function kr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,br,[n(`div`,xr,[n(`h2`,Sr,l(e.$t(`suno.name.overpaintingRange`)),1),o(d,{content:e.$t(`suno.description.overpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Cr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,wr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Tr,[n(`h2`,Er,l(e.audio?.title),1),n(`p`,Dr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Or,[o(_,{modelValue:e.overpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.overpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.overpaintingEnd=t,class:`flex-1`,size:`small`,min:e.overpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Ar=W(yr,[[`render`,kr]]),jr=r({name:`UnderpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},underpaintingStart:{get(){return this.$store.state.suno?.config?.underpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_start:e})}},underpaintingEnd:{get(){return this.$store.state.suno?.config?.underpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Mr={class:`field`},Nr={class:`flex items-center mb-2`},Pr={class:`text-sm font-bold m-0`},Fr={key:0,class:`task mb-2`},Ir={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Lr={class:`info flex-1 min-w-0`},Rr={class:`text-sm font-bold m-0 truncate`},zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Br={class:`flex gap-2`};function Vr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Mr,[n(`div`,Nr,[n(`h2`,Pr,l(e.$t(`suno.name.underpaintingRange`)),1),o(d,{content:e.$t(`suno.description.underpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Fr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Ir,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Lr,[n(`h2`,Rr,l(e.audio?.title),1),n(`p`,zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Br,[o(_,{modelValue:e.underpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.underpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.underpaintingEnd=t,class:`flex-1`,size:`small`,min:e.underpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Hr=W(jr,[[`render`,Vr]]),Ur=r({name:`SamplesInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},samplesStart:{get(){return this.$store.state.suno?.config?.samples_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_start:e})}},samplesEnd:{get(){return this.$store.state.suno?.config?.samples_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Wr={class:`field`},Gr={class:`flex items-center mb-2`},Kr={class:`text-sm font-bold m-0`},qr={key:0,class:`task mb-2`},Jr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Yr={class:`info flex-1 min-w-0`},Xr={class:`text-sm font-bold m-0 truncate`},Zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Qr={class:`flex gap-2`};function $r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Wr,[n(`div`,Gr,[n(`h2`,Kr,l(e.$t(`suno.name.samplesRange`)),1),o(d,{content:e.$t(`suno.description.samples`)},null,8,[`content`])]),e.audio?(u(),t(`div`,qr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Jr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Yr,[n(`h2`,Xr,l(e.audio?.title),1),n(`p`,Zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Qr,[o(_,{modelValue:e.samplesStart,"onUpdate:modelValue":r[1]||=t=>e.samplesStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.samplesEnd,"onUpdate:modelValue":r[2]||=t=>e.samplesEnd=t,class:`flex-1`,size:`small`,min:e.samplesStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var ei=W(Ur,[[`render`,$r]]),ti=[.5,.75,1,1.25,1.5,2],ni=r({name:`AdjustSpeedInput`,components:{ElRadioGroup:R,ElRadioButton:L,ElImage:P,InfoIcon:Q},data(){return{options:ti}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){let e=this.$store.state.suno?.config?.speed;return typeof e==`number`?e:1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),ri={class:`field`},ii={class:`flex items-center mb-2`},ai={class:`text-sm font-bold m-0`},oi={key:0,class:`task mb-2`},si={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},ci={class:`info flex-1 min-w-0`},li={class:`text-sm font-bold m-0 truncate`},ui={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`};function di(r,c,d,p,v,y){let b=g(`info-icon`),x=g(`el-image`),S=g(`el-radio-button`),C=g(`el-radio-group`),w=h(`loading`);return u(),t(`div`,ri,[n(`div`,ii,[n(`h2`,ai,l(r.$t(`suno.name.adjustSpeed`)),1),o(b,{content:r.$t(`suno.description.adjustSpeed`)},null,8,[`content`])]),r.audio?(u(),t(`div`,oi,[n(`div`,{class:`audio flex items-center`,onClick:c[0]||=e=>r.onClick(r.audio)},[f((u(),t(`div`,si,[o(x,{src:r.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[w,!r.audio?.audio_url]]),n(`div`,ci,[n(`h2`,li,l(r.audio?.title),1),n(`p`,ui,l(r.audio?.style),1)])])])):m(``,!0),o(C,{modelValue:r.speed,"onUpdate:modelValue":c[1]||=e=>r.speed=e,size:`small`,class:`speed-group`},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(S,{key:e,value:e},{default:_(()=>[i(l(e)+`x`,1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])])}var fi=W(ni,[[`render`,di],[`__scopeId`,`data-v-ba834628`]]),pi=r({name:`VoiceCreateDialog`,components:{ElDialog:K,ElForm:j,ElFormItem:A,ElInput:G,ElButton:b,ElRadioGroup:R,ElRadio:ee},props:{modelValue:{type:Boolean,default:!1}},emits:[`update:modelValue`,`created`],data(){return{sourceType:`song`,form:{name:``,description:``,audio_id:``,audio_url:``},loading:!1}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit(`update:modelValue`,e)}},token(){return this.$store.state.suno?.credential?.token},canSubmit(){return!(!this.form.name||this.sourceType===`song`&&!this.form.audio_id||this.sourceType===`upload`&&!this.form.audio_url)}},methods:{onClose(){this.visible=!1,this.resetForm()},resetForm(){this.form={name:``,description:``,audio_id:``,audio_url:``},this.sourceType=`song`},async onSubmit(){if(this.token){this.loading=!0;try{this.sourceType===`song`?await Y.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await Y.voices({audio_url:this.form.audio_url,name:this.form.name,description:this.form.description},{token:this.token}),J.success(this.$t(`suno.voice.createSuccess`)),this.$emit(`created`),this.onClose()}catch{J.error(this.$t(`suno.voice.createFailed`))}finally{this.loading=!1}}}}});function mi(e,t,n,r,s,c){let d=g(`el-input`),f=g(`el-form-item`),p=g(`el-radio`),h=g(`el-radio-group`),v=g(`el-form`),y=g(`el-button`),b=g(`el-dialog`);return u(),a(b,{modelValue:e.visible,"onUpdate:modelValue":t[5]||=t=>e.visible=t,title:e.$t(`suno.voice.createTitle`),width:`480px`,"close-on-click-modal":!1,onClose:e.onClose},{footer:_(()=>[o(y,{onClick:e.onClose},{default:_(()=>[i(l(e.$t(`common.button.cancel`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:_(()=>[i(l(e.$t(`suno.voice.create`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])]),default:_(()=>[o(v,{"label-position":`top`,class:`voice-create-form`},{default:_(()=>[o(f,{label:e.$t(`suno.voice.name`)},{default:_(()=>[o(d,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||=t=>e.form.name=t,placeholder:e.$t(`suno.voice.namePlaceholder`),maxlength:`50`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.description`)},{default:_(()=>[o(d,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||=t=>e.form.description=t,type:`textarea`,rows:2,placeholder:e.$t(`suno.voice.descriptionPlaceholder`),maxlength:`200`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.sourceType`)},{default:_(()=>[o(h,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||=t=>e.sourceType=t,class:`w-full`},{default:_(()=>[o(p,{value:`song`},{default:_(()=>[i(l(e.$t(`suno.voice.fromSong`)),1)]),_:1}),o(p,{value:`upload`},{default:_(()=>[i(l(e.$t(`suno.voice.fromUpload`)),1)]),_:1})]),_:1},8,[`modelValue`])]),_:1},8,[`label`]),e.sourceType===`song`?(u(),a(f,{key:0,label:e.$t(`suno.voice.audioId`)},{default:_(()=>[o(d,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||=t=>e.form.audio_id=t,placeholder:e.$t(`suno.voice.audioIdPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0),e.sourceType===`upload`?(u(),a(f,{key:1,label:e.$t(`suno.voice.audioUrl`)},{default:_(()=>[o(d,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||=t=>e.form.audio_url=t,placeholder:e.$t(`suno.voice.audioUrlPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0)]),_:1})]),_:1},8,[`modelValue`,`title`,`onClose`])}var hi=r({name:`VoiceManager`,components:{ElButton:b,ElIcon:w,ElTabs:O,ElTabPane:k,ElTooltip:N,Loading:x,FontAwesomeIcon:Z,VoiceCreateDialog:W(pi,[[`render`,mi]])},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:`all`}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab===`favorites`?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch(`suno/getPersonas`)}finally{this.loading=!1}}},selectPersona(e){let t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch(`suno/setConfig`,t)},async onDelete(e){try{await q.confirm(this.$t(`suno.voice.confirmDelete`),this.$t(`suno.voice.delete`),{type:`warning`,confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`)})}catch{return}if(!e.persona_id)return;this.deletingId=e.persona_id;let t=await this.$store.dispatch(`suno/deletePersona`,e.persona_id);if(this.deletingId=null,t){if(J.success(this.$t(`suno.voice.deleteSuccess`)),this.selectedPersonaId===e.persona_id){let e={...this.$store.state.suno?.config,persona_id:void 0};this.$store.dispatch(`suno/setConfig`,e)}this.favoriteIds.includes(e.persona_id)&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)}else J.error(this.$t(`suno.voice.deleteFailed`))},async onCreated(){await this.loadPersonas()}}}),gi={class:`voice-manager`},_i={class:`flex items-center justify-between mb-3`},vi={class:`text-sm font-medium`},yi={key:0,class:`text-center py-6`},bi={key:1,class:`text-center py-6 text-gray-400 text-sm`},xi={key:2,class:`voice-list`},Si=[`onClick`],Ci={class:`flex-1 min-w-0`},wi={class:`voice-name`},Ti={key:0,class:`voice-desc`};function Ei(r,a,f,p,h,v){let y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-tab-pane`),S=g(`el-tabs`),C=g(`loading`),w=g(`el-icon`),T=g(`el-tooltip`),E=g(`voice-create-dialog`);return u(),t(`div`,gi,[n(`div`,_i,[n(`span`,vi,l(r.$t(`suno.voice.title`)),1),o(b,{type:`primary`,size:`small`,onClick:a[0]||=e=>r.showCreateDialog=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-plus`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.create`)),1)]),_:1})]),o(S,{modelValue:r.activeTab,"onUpdate:modelValue":a[1]||=e=>r.activeTab=e,class:`voice-tabs`,size:`small`},{default:_(()=>[o(x,{name:`all`,label:r.$t(`suno.voice.tabAll`)+` (`+(r.personas?.length||0)+`)`},null,8,[`label`]),o(x,{name:`favorites`,label:r.$t(`suno.voice.tabFavorites`)+` (`+r.favoritePersonas.length+`)`},null,8,[`label`])]),_:1},8,[`modelValue`]),r.loading?(u(),t(`div`,yi,[o(w,{class:`is-loading`},{default:_(()=>[o(C)]),_:1})])):r.visiblePersonas.length===0?(u(),t(`div`,bi,l(r.activeTab===`favorites`?r.$t(`suno.voice.emptyFavorites`):r.$t(`suno.voice.empty`)),1)):(u(),t(`div`,xi,[(u(!0),t(s,null,e(r.visiblePersonas,e=>(u(),t(`div`,{key:e.persona_id,class:c([`voice-item`,{active:r.selectedPersonaId===e.persona_id}]),onClick:t=>r.selectPersona(e)},[n(`div`,Ci,[n(`div`,wi,[o(y,{icon:e.source_type===`voice`?`fa-solid fa-microphone`:`fa-solid fa-music`,class:`mr-1.5 text-xs opacity-60`},null,8,[`icon`]),i(` `+l(e.name||e.persona_id),1)]),e.description?(u(),t(`div`,Ti,l(e.description),1)):m(``,!0)]),n(`div`,{class:`voice-actions`,onClick:a[2]||=d(()=>{},[`stop`])},[o(T,{content:r.isFavorite(e.persona_id)?r.$t(`suno.voice.unfavorite`):r.$t(`suno.voice.favorite`),placement:`top`},{default:_(()=>[o(b,{size:`small`,text:``,class:c({"voice-fav-active":r.isFavorite(e.persona_id)}),onClick:t=>r.onToggleFavorite(e)},{default:_(()=>[o(y,{icon:r.isFavorite(e.persona_id)?`fa-solid fa-star`:`fa-regular fa-star`},null,8,[`icon`])]),_:2},1032,[`class`,`onClick`])]),_:2},1032,[`content`]),o(b,{type:`danger`,size:`small`,text:``,loading:r.deletingId===e.persona_id,onClick:t=>r.onDelete(e)},{default:_(()=>[o(y,{icon:`fa-solid fa-trash`})]),_:1},8,[`loading`,`onClick`])])],10,Si))),128))])),o(E,{modelValue:r.showCreateDialog,"onUpdate:modelValue":a[3]||=e=>r.showCreateDialog=e,onCreated:r.onCreated},null,8,[`modelValue`,`onCreated`])])}var Di=r({name:`PersonaInput`,components:{ElSelect:E,ElOption:D,ElButton:b,ElDrawer:z,FontAwesomeIcon:Z,InfoIcon:Q,VoiceManager:W(hi,[[`render`,Ei],[`__scopeId`,`data-v-8b8e36d9`]])},data(){return{showManager:!1}},computed:{personaId:{get(){return this.$store.state.suno?.config?.persona_id||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,persona_id:e||void 0})}},personas(){return this.$store.state.suno?.personas||[]}}}),Oi={class:`field`},ki={class:`flex items-center justify-between mb-2`},Ai={class:`flex items-center`},ji={class:`text-sm font-bold`},Mi={class:`flex items-center justify-between w-full`},Ni={key:0,class:`text-xs text-gray-400 ml-2`};function Pi(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-option`),S=g(`el-select`),C=g(`voice-manager`),w=g(`el-drawer`);return u(),t(`div`,Oi,[n(`div`,ki,[n(`div`,Ai,[n(`span`,ji,l(r.$t(`suno.name.persona`)),1),o(v,{content:r.$t(`suno.description.persona`)},null,8,[`content`])]),o(b,{size:`small`,round:``,onClick:c[0]||=e=>r.showManager=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.manage`)),1)]),_:1})]),o(S,{modelValue:r.personaId,"onUpdate:modelValue":c[1]||=e=>r.personaId=e,placeholder:r.$t(`suno.placeholder.personaId`),clearable:``,filterable:``,class:`w-full`},{default:_(()=>[(u(!0),t(s,null,e(r.personas,e=>(u(),a(x,{key:e.persona_id||``,value:e.persona_id||``,label:e.name||e.persona_id||``},{default:_(()=>[n(`div`,Mi,[n(`span`,null,l(e.name||e.persona_id),1),e.source_type?(u(),t(`span`,Ni,l(e.source_type),1)):m(``,!0)])]),_:2},1032,[`value`,`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`]),o(w,{modelValue:r.showManager,"onUpdate:modelValue":c[2]||=e=>r.showManager=e,title:r.$t(`suno.voice.title`),size:`380px`,direction:`rtl`},{default:_(()=>[o(C)]),_:1},8,[`modelValue`,`title`])])}var Fi=r({name:`PresetPanel`,components:{TypeSelector:Ge,PromptInput:St,LyricInput:It,StyleInput:Xt,TitleInput:nn,ExtendFromInput:gn,CoverFromInput:On,UploadAudio:mt,VocalGenderSelector:Nn,AdvancedParams:or,ReplaceSectionInput:vr,OverpaintingInput:Ar,UnderpaintingInput:Hr,SamplesInput:ei,AdjustSpeedInput:fi,PersonaInput:W(Di,[[`render`,Pi]]),FontAwesomeIcon:Z,ElButton:b,ElTabs:O,ElTabPane:k,Consumption:we},emits:[`generate`],computed:{config(){return this.$store.state.suno?.config},mode:{get(){return this.$store.state.suno?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e===`custom`})}},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){let e=this.config?.model||``;return[`chirp-v4-5-plus`,`chirp-v5`,`chirp-v5-5`].includes(e)},supportsPersona(){let e=this.config?.action;return!e||e===`generate`||e===`artist_consistency`||e===`artist_consistency_vox`},generateButtonText(){let e=this.config?.action;return e===`extend`?this.$t(`suno.button.extend`):e===`cover`?this.$t(`suno.button.cover_music`):e===`remaster`?this.$t(`suno.button.remaster`):e===`replace_section`?this.$t(`suno.button.replace_section`):e===`mashup`?this.$t(`suno.button.mashup`):e===`stems`?this.$t(`suno.button.get_stems`):e===`concat`?this.$t(`suno.button.concat_music`):e===`upload_cover`?this.$t(`suno.button.upload_cover`):e===`artist_consistency`?this.$t(`suno.button.artist_consistency`):e===`artist_consistency_vox`?this.$t(`suno.button.artist_consistency_vox`):e===`overpainting`?this.$t(`suno.button.overpainting`):e===`underpainting`?this.$t(`suno.button.underpainting`):e===`samples`?this.$t(`suno.button.samples`):e===`adjust_speed`?this.$t(`suno.button.adjust_speed`):this.$t(`suno.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`suno/setConfig`,{custom:!1,sounds:!1,instrumental:!1,lyric:``,style:``,title:``,lyrics_mode:`manual`,model:this.$store.state.suno?.config?.model})}}}),Ii={class:`flex flex-col h-full`},Li={class:`flex-1 overflow-y-auto p-5`},Ri={class:`pt-2 px-1`},zi={class:`pt-2 px-1`},Bi={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Vi={class:`flex gap-2 w-full`};function Hi(e,r,s,c,d,f){let p=g(`type-selector`),h=g(`upload-audio`),v=g(`prompt-input`),y=g(`extend-from-input`),b=g(`cover-from-input`),x=g(`replace-section-input`),S=g(`overpainting-input`),C=g(`underpainting-input`),w=g(`samples-input`),T=g(`adjust-speed-input`),E=g(`advanced-params`),D=g(`el-tab-pane`),O=g(`lyric-input`),k=g(`style-input`),A=g(`title-input`),j=g(`vocal-gender-selector`),M=g(`persona-input`),N=g(`el-tabs`),P=g(`consumption`),F=g(`font-awesome-icon`),I=g(`el-button`);return u(),t(`div`,Ii,[n(`div`,Li,[o(N,{modelValue:e.mode,"onUpdate:modelValue":r[0]||=t=>e.mode=t,class:`suno-mode-tabs`,stretch:``},{default:_(()=>[o(D,{label:e.$t(`suno.mode.simple`),name:`simple`},{default:_(()=>[n(`div`,Ri,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),o(v,{class:`mb-4`}),e.config?.action===`extend`?(u(),a(y,{key:0,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:1,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:6,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`]),o(D,{label:e.$t(`suno.mode.custom`),name:`custom`},{default:_(()=>[n(`div`,zi,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),e.config?.instrumental?m(``,!0):(u(),a(O,{key:0,class:`mb-4`})),o(k,{class:`mb-4`}),o(A,{class:`mb-4`}),!e.config?.instrumental&&e.supportsVocalGender?(u(),a(j,{key:1,class:`mb-4`})):m(``,!0),e.supportsPersona?(u(),a(M,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(u(),a(y,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:6,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:7,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:8,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:9,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Bi,[o(P,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Vi,[o(I,{class:`flex-1`,onClick:e.onClearAll},{default:_(()=>[o(F,{icon:`fa-solid fa-broom`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_all`)),1)]),_:1},8,[`onClick`]),o(I,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:_(()=>[o(F,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Ui=W(Fi,[[`render`,Hi],[`__scopeId`,`data-v-c62324e6`]]),Wi=Te(),Gi=ue(`suno`),Ki=r({name:`TaskPreview`,components:{ElImage:P,ElIcon:w,ElTooltip:N,FontAwesomeIcon:Z,VideoPlay:S,VideoPause:C,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElInput:G,ElProgress:ie,ElCheckbox:I,Loading:x,ApiCodeDialog:be},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:``,apiCodeVisible:!1,apiCodePath:`/suno/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){let e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(e=>({...e,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action===`mashup`},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:$,onViewCode(){let e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([e,n])=>{e===`application_id`||e===`callback_url`||n!=null&&(typeof n==`string`&&n===``||Array.isArray(n)&&n.length===0||(t[e]=n))}),this.apiCodeBody=t,this.apiCodePath=`/suno/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.log(`on extend`),console.debug(`set config`,t),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:`extend`,audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e?.stopPropagation(),console.log(`on download`,t);let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);console.log(`on preview`,r),fetch(t).then(e=>e.blob()).then(e=>{(0,Wi.saveAs)(e,r)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;let t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(e){console.error(`get videoUrl failed:`,e),J.error(this.$t(`suno.message.getVideoUrlFailed`))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,n)=>{let r={audio_id:e},i=this.credential?.token;if(!i){console.error(`no token specified`),n(Error(`No token specified`));return}Y.mp4(r,{token:i}).then(e=>{let r=e.data?.data?.video_url;r?t(r):n(Error(`Video URL not found in response`))}).catch(e=>{n(e)})})},onPreview(e,t){e?.stopPropagation(),console.log(`on preview`,t),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){console.log(`on cover`),console.debug(`set config`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl(`concat`,e)},async onRemaster(e){await this.onGenerateAudioUrl(`remaster`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`replace_section`,audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`mashup`,audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`overpainting`,audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`underpainting`,audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`samples`,audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`artist_consistency`,audio:e,audio_id:e.id})},onAdjustSpeed(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`adjust_speed`,audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){let t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){J.warning(this.$t(`suno.message.reusePromptEmpty`));return}this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??``,lyric:t.lyric??``,lyric_prompt:t.lyric_prompt??``,lyrics_mode:t.lyrics_mode??`manual`,title:t.title??``,style:t.style??``,style_negative:t.style_negative??``,vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),J.success(this.$t(`suno.message.reusePromptSuccess`))},async onExtractVocals(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.extractingVocals`)),Y.vox({audio_id:e,callback_url:Gi},{token:t}).then(()=>{J.success(this.$t(`suno.message.extractVocalsSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.extractVocalsFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.fetchingTiming`)),Y.timing({audio_id:e},{token:t}).then(e=>{J.success(this.$t(`suno.message.fetchTimingSuccess`)),console.debug(`timing data`,e.data)}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.fetchTimingFailed`))}))},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,J.info(this.$t(`suno.message.fetchingWav`));let n=(await Y.wav({audio_id:e.id},{token:t})).data?.data?.[0]?.file_url;n?this.onDownload(null,n):J.error(this.$t(`suno.message.fetchWavFailed`))}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;let t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,J.info(this.$t(`suno.message.fetchingMidi`));let n=(await Y.midi({audio_id:e.id},{token:t})).data?.data;if(!n?.length){J.error(this.$t(`suno.message.fetchMidiFailed`));return}let r=(e.title||e.id||`suno`).replace(/[^\w.-]+/g,`_`)+`.json`;(0,Wi.saveAs)(new Blob([JSON.stringify(n,null,2)],{type:`application/json`}),r)}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchMidiFailed`))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Gi},r=this.credential?.token;if(!r){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),Y.audio(n,{token:r}).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},isMashupSelected(e){return!!e.id&&this.mashupAudioIds.includes(e.id)},onToggleMashup(e){if(!e.id)return;let t=[...this.mashupAudioIds],n=t.indexOf(e.id);n===-1?t.push(e.id):t.splice(n,1),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,mashup_audio_ids:t})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},onStartTitleEdit(e){this.editingAudioId=e.id??null,this.editingTitle=e.title||``,this.$nextTick(()=>{this.$refs.titleInput?.focus?.()})},onSaveTitleEdit(e){if(this.editingAudioId!==e.id)return;let t=this.editingTitle.trim();if(t&&t!==e.title){let n=this.$store.state.suno?.tasks;if(n?.items)for(let r of n.items){let n=(r?.response?.data??[]).find(t=>t.id===e.id);if(n){n.title=t;break}}}this.editingAudioId=null,this.editingTitle=``},onCancelTitleEdit(){this.editingAudioId=null,this.editingTitle=``},async onDelete(e){try{await q.confirm(this.$t(`suno.message.confirmDelete`),{confirmButtonText:this.$t(`suno.button.delete`),cancelButtonText:this.$t(`common.button.cancel`),type:`warning`})}catch{return}let t=this.$store.state.suno?.tasks;if(t?.items)for(let n of t.items){let r=n?.response?.data??[],i=r.findIndex(t=>t.id===e.id);if(i!==-1){if(r.splice(i,1),r.length===0){let e=t.items.indexOf(n);e!==-1&&t.items.splice(e,1)}break}}this.$store.state?.suno?.audio?.id===e.id&&this.$store.dispatch(`suno/setAudio`,null),J.success(this.$t(`suno.message.deleteSuccess`))},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`suno/getTasks`,{limit:30,offset:0})}}}),qi={class:`task`},Ji=[`onClick`],Yi=[`onClick`],Xi={class:`left`},Zi=[`onClick`],Qi=[`onClick`],$i={key:2,class:`duration`},ea={class:`info`},ta={key:1,class:`title-row`},na={class:`title`},ra={class:`style`},ia={key:2,class:`progress-row`},aa={class:`progress-text`},oa={class:`right`},sa={class:`el-dropdown-link`},ca={class:`flex items-center min-w-[120px]`},la={class:`flex items-center min-w-[120px]`},ua={class:`flex items-center min-w-[120px]`},da={class:`el-dropdown-link`};function fa(r,p,v,b,x,S){let C=g(`el-checkbox`),w=g(`el-image`),T=g(`video-pause`),E=g(`el-icon`),D=g(`video-play`),O=g(`el-input`),k=g(`font-awesome-icon`),A=g(`el-progress`),j=g(`el-tooltip`),M=g(`Loading`),N=g(`el-dropdown-item`),P=g(`el-dropdown-menu`),F=g(`el-dropdown`),I=g(`api-code-dialog`),L=h(`loading`);return u(),t(`div`,qi,[(u(!0),t(s,null,e(r.audios,e=>(u(),t(`div`,{key:e.id,class:c([`audio`,{"mashup-selected":r.isMashupSelected(e)}]),onClick:d(t=>r.onClick(e),[`stop`])},[r.isMashupMode&&e?.audio_url?(u(),t(`div`,{key:0,class:`mashup-check`,onClick:d(t=>r.onToggleMashup(e),[`stop`])},[o(C,{"model-value":r.isMashupSelected(e),onClick:p[0]||=d(()=>{},[`stop`])},null,8,[`model-value`])],8,Yi)):m(``,!0),f((u(),t(`div`,Xi,[o(w,{src:e?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),e?.audio_url&&r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:d(t=>r.onPause(e),[`stop`])},[o(E,null,{default:_(()=>[o(T)]),_:1})],8,Zi)):m(``,!0),e?.audio_url&&(r.$store.state?.suno?.audio?.id!==e.id||r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:d(t=>r.onPlay(e),[`stop`])},[o(E,null,{default:_(()=>[o(D)]),_:1})],8,Qi)):m(``,!0),e?.duration?(u(),t(`div`,$i,l(r.useFormatDuring(e?.duration)),1)):m(``,!0)])),[[L,!e?.audio_url]]),n(`div`,ea,[r.editingAudioId===e.id?(u(),t(`div`,{key:0,class:`title-edit`,onClick:p[2]||=d(()=>{},[`stop`])},[o(O,{ref_for:!0,ref:`titleInput`,modelValue:r.editingTitle,"onUpdate:modelValue":p[1]||=e=>r.editingTitle=e,size:`small`,onKeyup:[y(t=>r.onSaveTitleEdit(e),[`enter`]),y(r.onCancelTitleEdit,[`escape`])],onBlur:t=>r.onSaveTitleEdit(e)},null,8,[`modelValue`,`onKeyup`,`onBlur`])])):(u(),t(`div`,ta,[n(`h2`,na,l(e?.title),1),e?.audio_url?(u(),a(k,{key:0,icon:`fa-solid fa-pen`,class:`edit-icon`,onClick:d(t=>r.onStartTitleEdit(e),[`stop`])},null,8,[`onClick`])):m(``,!0)])),n(`p`,ra,l(e?.style),1),!e?.audio_url&&e?.progress!=null&&e?.progress<100?(u(),t(`div`,ia,[o(A,{percentage:Math.round(e.progress),"stroke-width":4,"show-text":!1,status:`warning`,class:`progress-bar`},null,8,[`percentage`]),n(`span`,aa,l(r.$t(`suno.name.generating`))+` `+l(Math.round(e.progress))+`%`,1)])):m(``,!0)]),n(`div`,oa,[o(F,null,{dropdown:_(()=>[o(P,null,{default:_(()=>[o(N,{disabled:r.isFetchingVideoUrl,onClick:t=>r.handleVideoDownload(e)},{default:_(()=>[n(`div`,ca,[r.isFetchingVideoUrl?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onDownload(t,e?.audio_url),[`stop`])},{default:_(()=>[i(l(r.$t(`suno.button.download_audio`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{disabled:r.isFetchingWav,onClick:t=>r.handleWavDownload(e)},{default:_(()=>[n(`div`,la,[r.isFetchingWav?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`]),o(N,{disabled:r.isFetchingMidi,onClick:t=>r.handleMidiDownload(e)},{default:_(()=>[n(`div`,ua,[r.isFetchingMidi?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_midi`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:_(()=>[n(`span`,sa,[o(j,{effect:`dark`,content:r.$t(`suno.button.download`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),o(F,null,{dropdown:_(()=>[o(P,{class:`suno-action-menu`},{default:_(()=>[e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onExtend(t,e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-forward`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extend`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(t=>r.onCover(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-music`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.cover_music`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:1,onClick:d(t=>r.onMashup(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-shuffle`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.mashup`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id&&e?.action===`extend`?(u(),a(N,{key:2,onClick:d(t=>r.onConcatMusic(e?.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-link`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.concat_music`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[4]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:3,onClick:d(t=>r.onReplaceSection(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-scissors`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.replace_section`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:4,onClick:d(t=>r.onOverpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-microphone`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.overpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:5,onClick:d(t=>r.onUnderpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-guitar`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.underpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:6,onClick:d(t=>r.onSamples(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-drum`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.samples`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[5]||=n(`div`,{class:`menu-divider`},null,-1),e.id?(u(),a(N,{key:7,onClick:d(t=>r.onGetStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-layer-group`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.id?(u(),a(N,{key:8,onClick:d(t=>r.onGetAllStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-bars-staggered`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.all_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:9,onClick:d(t=>r.onRemaster(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-wand-magic-sparkles`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.remaster`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:10,onClick:d(t=>r.onExtractVocals(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-headphones`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extract_vocals`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:11,onClick:d(t=>r.onArtistConsistency(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-palette`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.artist_consistency`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:12,onClick:d(t=>r.onAdjustSpeed(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-gauge-high`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.adjust_speed`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[6]||=n(`div`,{class:`menu-divider`},null,-1),o(N,{onClick:d(t=>r.onReusePrompt(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-rotate-left`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.reuse_prompt`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:13,onClick:d(t=>r.onGetTiming(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-clock`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_timing`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(r.onViewCode,[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-code`,class:`menu-icon`}),i(` `+l(r.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`]),p[7]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:14,class:`delete-item`,onClick:d(t=>r.onDelete(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-trash`,class:`menu-icon delete-icon`}),i(` `+l(r.$t(`suno.button.delete`)),1)]),_:1},8,[`onClick`])):m(``,!0)]),_:2},1024)]),default:_(()=>[n(`span`,da,[o(j,{effect:`dark`,content:r.$t(`suno.button.more`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],10,Ji))),128)),o(I,{visible:r.apiCodeVisible,"onUpdate:visible":p[3]||=e=>r.apiCodeVisible=e,method:`POST`,path:r.apiCodePath,body:r.apiCodeBody,token:r.$store.state.suno?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var pa=r({name:`RecentPanel`,components:{ElSkeletonItem:ae,ElSkeleton:oe,ElInput:G,ElButton:b,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElPopover:re,ElRadioGroup:R,ElRadioButton:L,ElSelect:E,ElOption:D,FontAwesomeIcon:Z,TaskPreview:W(Ki,[[`render`,fa]]),Player:Ee,NoTasks:Ce,ScrollList:ye},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0,searchQuery:``,sortBy:`newest`,filterType:`all`,filterDuration:`all`,filterVideo:`all`,filterModel:`all`}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}},sortLabel(){return this.sortBy===`newest`?this.$t(`suno.sort.newest`):this.$t(`suno.sort.oldest`)},activeFilterCount(){let e=0;return this.filterType!==`all`&&e++,this.filterDuration!==`all`&&e++,this.filterVideo!==`all`&&e++,this.filterModel&&this.filterModel!==`all`&&e++,e},availableModels(){let e=this.tasks?.items||[],t=new Set;for(let n of e){let e=n?.response?.data??[];for(let n of e)n.model&&t.add(n.model)}return Array.from(t).sort()},filteredTasks(){let e=this.tasks?.items||[];if(this.searchQuery){let t=this.searchQuery.toLowerCase();e=e.filter(e=>(e?.response?.data??[]).some(e=>e.title?.toLowerCase().includes(t)||e.style?.toLowerCase().includes(t)||e.prompt?.toLowerCase().includes(t)))}return this.activeFilterCount>0&&(e=e.filter(e=>{let t=e?.request??{},n=e?.response?.data??[];return this.filterType===`vocal`&&t.instrumental===!0||this.filterType===`instrumental`&&t.instrumental!==!0?!1:this.filterDuration!==`all`||this.filterVideo!==`all`||this.filterModel&&this.filterModel!==`all`?n.some(e=>!(this.filterDuration===`short`&&!(typeof e.duration==`number`&&e.duration<60)||this.filterDuration===`medium`&&!(typeof e.duration==`number`&&e.duration>=60&&e.duration<=180)||this.filterDuration===`long`&&!(typeof e.duration==`number`&&e.duration>180)||this.filterVideo===`with`&&!e.video_url||this.filterVideo===`without`&&e.video_url||this.filterModel&&this.filterModel!==`all`&&e.model!==this.filterModel)):!0})),this.sortBy===`oldest`&&(e=[...e].reverse()),e}},methods:{onSortChange(e){this.sortBy=e},onResetFilters(){this.filterType=`all`,this.filterDuration=`all`,this.filterVideo=`all`,this.filterModel=`all`},getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ma={key:0,class:`tasks`},ha={class:`left w-[70px] p-[10px] flex items-center`},ga={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},_a={key:0,class:`task-toolbar`},va={key:0,class:`filter-badge`},ya={class:`filter-popover`},ba={class:`filter-row`},xa={class:`filter-label`},Sa={class:`filter-row`},Ca={class:`filter-label`},wa={class:`filter-row`},Ta={class:`filter-label`},Ea={key:0,class:`filter-row`},Da={class:`filter-label`},Oa={class:`filter-actions`},ka={key:2,class:`w-full flex-1 flex items-center justify-center`},Aa={class:`text-sm text-gray-400`},ja={key:3,class:`w-full flex-1 flex flex-col items-center justify-center gap-2`},Ma={class:`text-sm text-gray-400`},Na={key:4,class:`w-full flex-1 flex items-center justify-center`},Pa={class:`h-20`};function Fa(r,d,p,h,y,b){let x=g(`el-skeleton-item`),S=g(`el-skeleton`),C=g(`font-awesome-icon`),w=g(`el-input`),T=g(`el-button`),E=g(`el-dropdown-item`),D=g(`el-dropdown-menu`),O=g(`el-dropdown`),k=g(`el-radio-button`),A=g(`el-radio-group`),j=g(`el-option`),M=g(`el-select`),N=g(`el-popover`),P=g(`task-preview`),F=g(`scroll-list`),I=g(`no-tasks`),L=g(`player`);return u(),t(s,null,[r.tasks?.items===void 0?(u(),t(`div`,ma,[(u(),t(s,null,e(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,ha,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,ga,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),o(x,{variant:`text`})]),_:1})])])),64))])):(u(),t(s,{key:1},[r.tasks?.items?.length?(u(),t(`div`,_a,[o(w,{modelValue:r.searchQuery,"onUpdate:modelValue":d[0]||=e=>r.searchQuery=e,size:`small`,placeholder:r.$t(`suno.placeholder.searchSongs`),clearable:``,class:`task-search`},{prefix:_(()=>[o(C,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs`})]),_:1},8,[`modelValue`,`placeholder`]),o(O,{trigger:`click`,onCommand:r.onSortChange},{dropdown:_(()=>[o(D,null,{default:_(()=>[o(E,{command:`newest`,class:c({"is-active":r.sortBy===`newest`})},{default:_(()=>[i(l(r.$t(`suno.sort.newest`)),1)]),_:1},8,[`class`]),o(E,{command:`oldest`,class:c({"is-active":r.sortBy===`oldest`})},{default:_(()=>[i(l(r.$t(`suno.sort.oldest`)),1)]),_:1},8,[`class`])]),_:1})]),default:_(()=>[o(T,{size:`small`,class:`sort-btn`},{default:_(()=>[o(C,{icon:`fa-solid fa-arrow-down-wide-short`,class:`mr-1`}),i(` `+l(r.sortLabel),1)]),_:1})]),_:1},8,[`onCommand`]),o(N,{trigger:`click`,placement:`bottom-end`,width:260},{reference:_(()=>[o(T,{size:`small`,class:c([`filter-btn`,{"has-active-filter":r.activeFilterCount>0}])},{default:_(()=>[o(C,{icon:`fa-solid fa-filter`,class:`mr-1`}),i(` `+l(r.$t(`suno.filter.title`))+` `,1),r.activeFilterCount>0?(u(),t(`span`,va,l(r.activeFilterCount),1)):m(``,!0)]),_:1},8,[`class`])]),default:_(()=>[n(`div`,ya,[n(`div`,ba,[n(`div`,xa,l(r.$t(`suno.filter.type`)),1),o(A,{modelValue:r.filterType,"onUpdate:modelValue":d[1]||=e=>r.filterType=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.typeAll`)),1)]),_:1}),o(k,{value:`vocal`},{default:_(()=>[i(l(r.$t(`suno.filter.typeVocal`)),1)]),_:1}),o(k,{value:`instrumental`},{default:_(()=>[i(l(r.$t(`suno.filter.typeInstrumental`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,Sa,[n(`div`,Ca,l(r.$t(`suno.filter.duration`)),1),o(A,{modelValue:r.filterDuration,"onUpdate:modelValue":d[2]||=e=>r.filterDuration=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.durationAll`)),1)]),_:1}),o(k,{value:`short`},{default:_(()=>[i(l(r.$t(`suno.filter.durationShort`)),1)]),_:1}),o(k,{value:`medium`},{default:_(()=>[i(l(r.$t(`suno.filter.durationMedium`)),1)]),_:1}),o(k,{value:`long`},{default:_(()=>[i(l(r.$t(`suno.filter.durationLong`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,wa,[n(`div`,Ta,l(r.$t(`suno.filter.video`)),1),o(A,{modelValue:r.filterVideo,"onUpdate:modelValue":d[3]||=e=>r.filterVideo=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.videoAll`)),1)]),_:1}),o(k,{value:`with`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWith`)),1)]),_:1}),o(k,{value:`without`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWithout`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r.availableModels.length>0?(u(),t(`div`,Ea,[n(`div`,Da,l(r.$t(`suno.filter.model`)),1),o(M,{modelValue:r.filterModel,"onUpdate:modelValue":d[4]||=e=>r.filterModel=e,size:`small`,placeholder:r.$t(`suno.filter.modelAll`),clearable:``},{default:_(()=>[o(j,{label:r.$t(`suno.filter.modelAll`),value:`all`},null,8,[`label`]),(u(!0),t(s,null,e(r.availableModels,e=>(u(),a(j,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0),n(`div`,Oa,[o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])])]),_:1})])):m(``,!0),r.filteredTasks?.length>0?(u(),a(F,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:r.loading,onReachTop:d[5]||=e=>r.$emit(`reach-top`)},{default:_(()=>[(u(!0),t(s,null,e(r.filteredTasks,(e,t)=>(u(),a(P,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):r.searchQuery&&r.tasks?.items?.length>0?(u(),t(`div`,ka,[n(`p`,Aa,l(r.$t(`suno.message.noSearchResults`)),1)])):r.activeFilterCount>0&&r.tasks?.items?.length>0?(u(),t(`div`,ja,[n(`p`,Ma,l(r.$t(`suno.message.noFilterResults`)),1),o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])):r.tasks?.items?.length===0?(u(),t(`div`,Na,[o(I)])):m(``,!0)],64)),f(n(`div`,Pa,[o(L,{namespace:`suno`})],512),[[v,!!r.$store?.state?.suno?.audio?.object]])],64)}var Ia=W(pa,[[`render`,Fa],[`__scopeId`,`data-v-6ce376c9`]]),La=r({name:`TaskPreview`,components:{IconPicture:T,ElImage:P,ElAvatar:F,ElIcon:w},computed:{audio(){return this.$store.state.suno?.audio}}}),Ra={key:0,class:`size-full overflow-hidden`},za={class:`relative h-[300px]`},Ba={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},Va={class:`absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent`},Ha={class:`p-4`},Ua={class:`flex items-center font-bold mb-2`},Wa={class:`text-[var(--el-text-color-regular)] mb-2`},Ga={class:`text-xs text-[var(--el-text-color-regular)]`},Ka={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},qa={key:1,class:`w-full h-full`};function Ja(e,r,i,a,s,c){let d=g(`icon-picture`),f=g(`el-icon`),p=g(`el-image`),m=g(`el-avatar`);return e.audio?.object?(u(),t(`div`,Ra,[n(`div`,za,[o(p,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:_(()=>[n(`div`,Ba,[o(f,{class:`text-3xl`},{default:_(()=>[o(d)]),_:1})])]),_:1},8,[`src`]),n(`h2`,Va,l(e.audio?.title),1)]),n(`div`,Ha,[n(`div`,Ua,[o(m,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,l(e.audio?.title),1)]),n(`p`,Wa,l(e.audio?.style),1),n(`p`,Ga,l(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,Ka,[n(`p`,null,l(e.audio?.lyric),1)])])])):(u(),t(`div`,qa))}var Ya=W(La,[[`render`,Ja]]),Xa=ue(`suno`),Za=r({name:`SunoIndex`,components:{Layout:Ne,ConfigPanel:Ui,RecentPanel:Ia,PreviewPanel:Ya},mixins:[fe],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await xe({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(`suno/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`suno/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){de.create({application:this.application}).then(({data:e})=>{this.application=e,J.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&J.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let 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);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`suno/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!he(this.uploadTracker,e=>this.$t(e),e=>J.warning(e)))return;let e={...this.config,callback_url:Xa};if(!this.hasSunoInput(e)){J.error(this.$t(`suno.message.promptRequired`));return}this.hasText(e.prompt)&&(e.prompt=e.prompt.trim());let t=this.credential?.token;if(!t){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),pe(`suno`,Y.audio(e,{token:t})).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0},hasSunoInput(e){return[e.prompt,e.lyric,e.lyric_prompt,e.style,e.title].some(e=>this.hasText(e))||this.hasText(e.audio_id)||Array.isArray(e.mashup_audio_ids)&&e.mashup_audio_ids.length>0}}});function Qa(e,t,n,r,i,s){let c=g(`config-panel`),l=g(`recent-panel`),d=g(`preview-panel`),f=g(`layout`);return u(),a(f,null,{config:_(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:_(()=>[o(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:_(()=>[o(d)]),_:1})}var $a=W(Za,[[`render`,Qa],[`__scopeId`,`data-v-b9beee12`]]);export{$a as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,M as i,N as a,O as o,P as s,S as c,Wt as l,Z as u,et as d,k as f,tt as p,ut as m}from"./vendor-chart-BJCvKk8-.js";import{t as h}from"./button-DfsQodL-.js";import{r as g,t as _}from"./select-CxvkoR_I.js";import{n as v,t as y}from"./collapse-BxNTm00O.js";import{t as b}from"./drawer-Dpuj2uIl.js";import"./constants-DwFseFmM.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-1hhw9POE.js";import{t as E}from"./index.es-Ds6M0PuH.js";import{t as ee}from"./Consumption-D_CAQaSB.js";var te=r({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(e,r,i,a,o,c){let l=p(`font-awesome-icon`),f=p(`el-button`),h=p(`el-drawer`);return u(),t(`div`,D,[n(`div`,O,[d(e.$slots,`config`,{},void 0,!0)]),n(`div`,k,[d(e.$slots,`result`,{},void 0,!0)]),s(f,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:m(()=>[s(l,{icon:`fa-solid fa-search`})]),_:1}),s(h,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[d(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=r({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,N,[n(`div`,P,[n(`h2`,F,l(e.$t(`serp.name.query`)),1)]),s(d,{modelValue:e.query,"onUpdate:modelValue":r[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=r({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},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||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,r,i,a,o,c){let d=p(`el-option`),f=p(`el-select`);return u(),t(`div`,z,[n(`h2`,B,l(e.$t(`serp.name.type`)),1),s(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},{default:m(()=>[s(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),s(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),s(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),s(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=r({name:`CountryInput`,components:{ElInput:S},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||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,W,[n(`h2`,G,l(e.$t(`serp.name.country`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=r({name:`LanguageInput`,components:{ElInput:S},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||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,Y,[n(`h2`,X,l(e.$t(`serp.name.language`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=r({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,r,i,o,c,d){let f=p(`query-input`),h=p(`type-selector`),g=p(`country-input`),_=p(`language-input`),v=p(`consumption`),y=p(`font-awesome-icon`),b=p(`el-button`);return u(),t(`div`,ne,[n(`div`,re,[s(f,{class:`mb-4`}),s(h,{class:`mb-4`}),s(g,{class:`mb-4`}),s(_,{class:`mb-4`})]),n(`div`,ie,[s(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),s(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:m(()=>[s(y,{icon:`fa-solid fa-search`,class:`mr-2`}),a(` `+l(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=r({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(r,i,o,s,d,p){return u(),t(`div`,ce,[n(`div`,le,[r.data.image_url?(u(),t(`img`,{key:0,src:r.data.image_url,alt:r.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):f(``,!0),n(`div`,de,[r.data.type?(u(),t(`div`,fe,l(r.data.type),1)):f(``,!0),n(`h3`,pe,l(r.data.title),1),r.data.description?(u(),t(`p`,me,[a(l(r.data.description)+` `,1),r.data.description_link?(u(),t(`a`,{key:0,href:r.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},l(r.data.description_source||`Source`),9,he)):f(``,!0)])):f(``,!0),r.data.attributes&&Object.keys(r.data.attributes).length?(u(),t(`div`,ge,[(u(!0),t(c,null,e(r.data.attributes,(e,r)=>(u(),t(`div`,{key:r,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,l(r)+`:`,1),n(`span`,ve,l(e),1)]))),128))])):f(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=r({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{let 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`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(r,i,a,o,s,d){return u(),t(`div`,Se,[r.displayUrl?(u(),t(`div`,Ce,[n(`img`,{src:r.faviconUrl,alt:r.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:i[0]||=(...e)=>r.onFaviconError&&r.onFaviconError(...e)},null,40,we),n(`span`,Te,l(r.hostname),1),n(`span`,Ee,l(r.pathname),1)])):f(``,!0),n(`a`,{href:r.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},l(r.data.title),9,De),r.data.date?(u(),t(`div`,Oe,l(r.data.date),1)):f(``,!0),r.data.snippet?(u(),t(`p`,ke,l(r.data.snippet),1)):f(``,!0),r.data.sitelinks?.length?(u(),t(`div`,Ae,[(u(!0),t(c,null,e(r.data.sitelinks,(e,n)=>(u(),t(`a`,{key:n,href:e.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`},l(e.title),9,je))),128))])):f(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=r({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={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`},Ve={class:`text-xs text-white line-clamp-2`};function He(r,i,a,o,s,d){return u(),t(`div`,Fe,[n(`h3`,Ie,l(r.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):f(``,!0),n(`div`,Be,[n(`span`,Ve,l(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=r({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,Ge,l(r.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):f(``,!0),e.duration?(u(),t(`div`,Xe,l(e.duration),1)):f(``,!0)]),n(`div`,Ze,[n(`div`,Qe,l(e.title),1),n(`div`,$e,[e.source?(u(),t(`span`,et,l(e.source),1)):f(``,!0),e.channel?(u(),t(`span`,tt,` · `+l(e.channel),1)):f(``,!0),e.date?(u(),t(`span`,nt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,rt,l(e.snippet),1)):f(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=r({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,st,l(r.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,l(e.title),1),n(`div`,ft,[e.source?(u(),t(`span`,pt,l(e.source),1)):f(``,!0),e.date?(u(),t(`span`,mt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,ht,l(e.snippet),1)):f(``,!0)]),e.image_url?(u(),t(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):f(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=r({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(r,i,a,d,h,g){let _=p(`el-collapse-item`),v=p(`el-collapse`);return u(),t(`div`,xt,[n(`h3`,St,l(r.$t(`serp.name.peopleAlsoAsk`)),1),s(v,null,{default:m(()=>[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),o(_,{key:n,title:e.question||e.title||``},{default:m(()=>[e.snippet?(u(),t(`p`,Ct,l(e.snippet),1)):f(``,!0),e.link?(u(),t(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},l(e.title||e.link),9,wt)):f(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=r({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(r,i,o,d,f,m){let h=p(`font-awesome-icon`);return u(),t(`div`,Ot,[n(`h3`,kt,l(r.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),t(`button`,{key:n,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:t=>r.onSearch(e.query)},[s(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),a(` `+l(e.query),1)],8,jt))),128))])])}var Nt=r({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.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)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(r,a,d,m,h,g){let _=p(`font-awesome-icon`),v=p(`knowledge-graph`),y=p(`organic-result`),b=p(`image-results`),x=p(`video-results`),S=p(`news-results`),C=p(`people-also-ask`),w=p(`related-searches`);return u(),t(`div`,$,[r.searching?(u(),t(`div`,Pt,[(u(),t(c,null,e(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...a[0]||=[i(`<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))])):r.noResults?(u(),t(`div`,Ft,[s(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,l(r.$t(`serp.message.noResults`)),1)])):r.results?(u(),t(`div`,Lt,[r.results.knowledge_graph?.title?(u(),o(v,{key:0,data:r.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.organic?.length?(u(),t(`div`,Rt,[(u(!0),t(c,null,e(r.results.organic,(e,t)=>(u(),o(y,{key:t,data:e,class:`mb-1`},null,8,[`data`]))),128))])):f(``,!0),r.results.images?.length?(u(),o(b,{key:2,data:r.results.images,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.videos?.length?(u(),o(x,{key:3,data:r.results.videos,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.news?.length?(u(),o(S,{key:4,data:r.results.news,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.people_also_ask?.length?(u(),o(C,{key:5,data:r.results.people_also_ask,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.related_searches?.length?(u(),o(w,{key:6,data:r.results.related_searches,class:`mb-6`,onSearch:r.onRelatedSearch},null,8,[`data`,`onSearch`])):f(``,!0)])):(u(),t(`div`,zt,[s(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,l(r.$t(`serp.description.query`)),1)]))])}var Ht=r({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},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(e){(e?.response?.data)?.error?.code===`used_up`?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 Ut(e,t,n,r,i,a){let c=p(`search-panel`),l=p(`result-panel`),d=p(`layout`);return u(),o(d,null,{config:m(()=>[s(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:m(()=>[s(l,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{n as y,r as b,t as x}from"./select-CxvkoR_I.js";import{t as S}from"./upload-cn_TUU3N.js";import{t as C}from"./tooltip-BLwTovWL.js";import{t as w}from"./image-r_Sil4Yc.js";import{t as T}from"./alert-OvnfgMB-.js";import{t as E}from"./drawer-Dpuj2uIl.js";import{t as D}from"./input-number-Bg1zmr12.js";import{t as O}from"./switch-BUEiwneZ.js";import{Cn as k,Tn as A,_i as j,_n as M,bn as N,gn as P,hn as ee,mn as te,pn as ne,vn as re,wn as ie,xn as F,yn as I}from"./constants-DwFseFmM.js";import{At as L,E as R,Fn as z,Nt as B,Ot as V,Sr as H,en as U,kr as W,kt as G,yr as K}from"./index-1hhw9POE.js";import{t as q}from"./index.es-Ds6M0PuH.js";import{t as J}from"./CopyToClipboard-DG5cx0Ex.js";import{t as Y}from"./ImagePreview-CeyNx3jd.js";import{n as ae}from"./taskDrawerMixin-DEgO_R5H.js";import{t as oe}from"./BotPlaceholder-BpLIwwxA.js";import{i as X,n as se,t as ce}from"./pagination-DH5leY8A.js";import{n as le,t as ue}from"./NoTasks-BOopjPtL.js";import{t as de}from"./Consumption-D_CAQaSB.js";import{t as fe}from"./ApiCodeButton-CXoLQXC2.js";import{t as pe}from"./ImageWrapper-C6BTBymE.js";var me=r({name:`LayoutNanobanana`,components:{ElDrawer:E,ElButton:v,FontAwesomeIcon:q},mixins:[ae]}),he={class:`main flex flex-row flex-1`},ge={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},_e={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ve(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,he,[n(`div`,ge,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,_e,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=r({name:`PromptInput`,components:{PromptTextarea:le},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){this.$store.commit(`openaiimage/setConfig`,{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||=``}});function xe(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`openaiimage.name.prompt`),info:e.$t(`openaiimage.description.prompt`),placeholder:e.$t(`openaiimage.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Se=R(be,[[`render`,xe]]),Ce=r({name:`ImageUrlsInput`,components:{ElUpload:S,ElButton:v,InfoIcon:X,ImagePreview:Y,FontAwesomeIcon:q},mixins:[G],data(){return{fileList:[],uploadUrl:H()+`/api/v1/files/`,suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){let e=(this.fileList||[]).filter(e=>!e?.response?.file_url);this.fileList=e.length?e:[];return}let t=[];e.forEach(e=>{let n=this.fileList.find(t=>t?.response?.file_url===e||t?.url===e);n?t.push(n):t.push({name:e.split(`/`).pop()||e,url:e,status:`success`,percentage:100,response:{file_url:e}})}),(this.fileList||[]).filter(e=>!e?.response?.file_url).forEach(e=>{t.some(t=>t===e||t?.url===e?.url||t?.response?.file_url===e?.response?.file_url)||t.push(e)}),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(){W.warning(this.$t(`openaiimage.message.uploadImageExceed`))},onError(){W.error(this.$t(`openaiimage.message.uploadImageError`))},onSetImageUrls(){let 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()}}}),we={class:`field flex items-center justify-between`},Te={class:`title font-bold text-[14px] mb-[10px]`},Ee={class:`upload-wrapper flex flex-col items-start gap-[8px]`},De={class:`controls flex items-center`},Oe={class:`file-list flex flex-wrap gap-[10px]`};function ke(r,c,d,f,p,m){let _=h(`font-awesome-icon`),v=h(`el-button`),y=h(`el-upload`),b=h(`info-icon`),x=h(`image-preview`);return u(),t(s,null,[n(`div`,we,[n(`h2`,Te,l(r.$t(`openaiimage.name.imageUrls`)),1),n(`div`,Ee,[n(`div`,De,[o(y,{"file-list":r.fileList,"onUpdate:fileList":c[0]||=e=>r.fileList=e,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:r.uploadUrl,"on-exceed":r.onExceed,"on-error":r.onError,"on-success":r.onSuccess,"on-change":r.onChange,"on-remove":r.onRemove,headers:r.headers},{default:g(()=>[o(v,{size:`small`,type:`primary`,round:``},{default:g(()=>[o(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),o(b,{content:r.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),n(`div`,Oe,[(u(!0),t(s,null,e(r.fileList,(e,t)=>(u(),a(x,{key:e.uid||e?.response?.file_url||e.url||t,url:e.url||e?.response?.file_url,name:e.name,percentage:e.percentage,onRemove:n=>r.onRemovePreview(t,e)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=r({name:`OpenAIImageModelSelector`,components:{ElSelect:b,ElOption:x,InfoIcon:X},data(){return{options:[{value:re,label:this.$t(`openaiimage.model.gptImage1`)},{value:I,label:this.$t(`openaiimage.model.gptImage15`)},{value:N,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||=P}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(r,i,c,d,f,p){let m=h(`info-icon`),_=h(`el-option`),v=h(`el-select`);return u(),t(`div`,Me,[n(`div`,Ne,[n(`div`,Pe,[n(`h2`,Fe,l(r.$t(`openaiimage.name.model`)),1),o(m,{content:r.modelDescription,class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`openaiimage.placeholder.select`)},{default:g(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=R(je,[[`render`,Ie],[`__scopeId`,`data-v-cec771bd`]]);function Z(e){if(!e)return;let t=/^(\d+)x(\d+)$/.exec(e);if(t)return{w:Number(t[1]),h:Number(t[2])}}var Re=r({name:`OpenAIImageSizeSelector`,components:{ElSelect:b,ElOption:x,ElOptionGroup:y,ElSwitch:O,ElInputNumber:D,InfoIcon:X},data(){return{customMode:!1,customWidth:1024,customHeight:1024}},computed:{model(){return this.$store.state.openaiimage?.config?.model||`gpt-image-2`},storedSize(){return this.$store.state.openaiimage?.config?.size},emptySizeValue(){return``},customSupported(){return ee.includes(this.model)},presets(){return F[this.model]??F[`gpt-image-2`]??[]},presetGroups(){return this.model===`gpt-image-2`?[{label:this.$t(`openaiimage.sizeGroup.standard1k`),options:k},{label:this.$t(`openaiimage.sizeGroup.preset2k`),options:ie},{label:this.$t(`openaiimage.sizeGroup.preset4k`),options:A}]:[{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 this.commitSize()}},presetValue:{get(){let e=this.storedSize;return e&&this.presets.includes(e)?e:this.emptySizeValue},set(e){this.customMode=!1,this.commitSize(e||void 0)}},multiple(){return 16},minSide(){return 256},maxSide(){return ne},customError(){let 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>8294400?this.$t(`openaiimage.error.customSizePixels`,{pixels:te.toLocaleString()}):``}},watch:{model:{immediate:!1,handler(){this.customSupported||(this.customMode=!1);let e=this.storedSize;if(!e||this.presets.includes(e))return;let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h,!this.customError)||this.commitSize()}},storedSize(e){if(!e){this.customMode=!1;return}if(this.presets.includes(e)){this.customMode=!1;return}let t=Z(e);t&&this.customSupported&&(this.customMode=!0,this.customWidth!==t.w&&(this.customWidth=t.w),this.customHeight!==t.h&&(this.customHeight=t.h))},customWidth(){this.syncCustomToStore()},customHeight(){this.syncCustomToStore()}},mounted(){let e=this.storedSize,t=Z(e);e&&t&&this.customSupported&&!this.presets.includes(e)&&(this.customMode=!0,this.customWidth=t.w,this.customHeight=t.h)},methods:{commitSize(e){let t={...this.$store.state.openaiimage?.config};e?t.size=e:delete t.size,this.$store.commit(`openaiimage/setConfig`,t)},syncCustomToStore(){this.useCustom&&(this.customError||this.commitSize(`${this.customWidth}x${this.customHeight}`))}}}),ze={class:`resolution`},Be={class:`field`},Ve={class:`label`},He={class:`box`},Ue={class:`title font-bold`},We={class:`field custom-toggle`},Ge={class:`label`},Ke={class:`box`},qe={class:`title font-bold`},Je={key:0,class:`custom-inputs`},Ye={class:`row`},Xe={class:`row-label`},Ze={class:`row`},Qe={class:`row-label`},$e={key:0,class:`error`};function et(r,i,c,d,f,p){let _=h(`info-icon`),v=h(`el-option`),y=h(`el-option-group`),b=h(`el-select`),x=h(`el-switch`),S=h(`el-input-number`);return u(),t(`div`,ze,[n(`div`,Be,[n(`div`,Ve,[n(`div`,He,[n(`h2`,Ue,l(r.$t(`openaiimage.name.size`)),1),o(_,{content:r.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),o(b,{modelValue:r.presetValue,"onUpdate:modelValue":i[0]||=e=>r.presetValue=e,class:`value`,placeholder:r.$t(`openaiimage.placeholder.select`),disabled:r.useCustom},{default:g(()=>[o(v,{label:r.$t(`suno.gender.auto`),value:r.emptySizeValue},null,8,[`label`,`value`]),(u(!0),t(s,null,e(r.presetGroups,n=>(u(),a(y,{key:n.label,label:n.label},{default:g(()=>[(u(!0),t(s,null,e(n.options,e=>(u(),a(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),r.customSupported?(u(),t(s,{key:0},[n(`div`,We,[n(`div`,Ge,[n(`div`,Ke,[n(`h2`,qe,l(r.$t(`openaiimage.name.customSize`)),1),o(_,{content:r.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),o(x,{modelValue:r.useCustom,"onUpdate:modelValue":i[1]||=e=>r.useCustom=e,class:`value-switch`},null,8,[`modelValue`])]),r.useCustom?(u(),t(`div`,Je,[n(`div`,Ye,[n(`span`,Xe,l(r.$t(`openaiimage.name.width`)),1),o(S,{modelValue:r.customWidth,"onUpdate:modelValue":i[2]||=e=>r.customWidth=e,class:`row-input`,min:r.minSide,max:r.maxSide,step:r.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),n(`div`,Ze,[n(`span`,Qe,l(r.$t(`openaiimage.name.height`)),1),o(S,{modelValue:r.customHeight,"onUpdate:modelValue":i[3]||=e=>r.customHeight=e,class:`row-input`,min:r.minSide,max:r.maxSide,step:r.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r.customError?(u(),t(`div`,$e,l(r.customError),1)):m(``,!0)])):m(``,!0)],64)):m(``,!0)])}var tt=r({name:`ConfigPanel`,components:{ElButton:v,FontAwesomeIcon:q,PromptInput:Se,Consumption:de,ImageUrlsInput:Ae,ModelSelector:Le,ResolutionSelector:R(Re,[[`render`,et],[`__scopeId`,`data-v-d5544d69`]])},emits:[`generate`],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){return B({...this.config||{}},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),nt={class:`flex flex-col h-full`},rt={class:`flex-1 overflow-y-auto p-5`},it={class:`flex flex-col items-center justify-center px-5 pb-5`};function at(e,r,a,s,c,d){let f=h(`model-selector`),p=h(`resolution-selector`),m=h(`prompt-input`),_=h(`image-urls-input`),v=h(`consumption`),y=h(`font-awesome-icon`),b=h(`el-button`);return u(),t(`div`,nt,[n(`div`,rt,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(m,{class:`mb-4`}),o(_,{class:`mb-4`})]),n(`div`,it,[o(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(y,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`openaiimage.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ot=R(tt,[[`render`,at]]),st=r({name:`TaskPreview`,components:{ElImage:w,CopyToClipboard:J,FontAwesomeIcon:q,ElAlert:T,ImageWrapper:pe,ElButton:v,ElTooltip:C,ImagePreview:Y,ApiCodeButton:fe},props:{modelValue:{type:Object,required:!0}},setup(){return{OPENAIIMAGE_LOGO:M}},computed:{isEditRequest(){let e=this.modelValue?.request;return this.modelValue?.type===`images_edits`||e?.action===`edit`||this.referenceImages.length>0},showTaskType(){return!!(this.modelValue?.request?.action||this.modelValue?.type||this.referenceImages.length>0)},taskTypeLabel(){return this.isEditRequest?this.$t(`openaiimage.name.edits`):this.$t(`openaiimage.name.generate`)},openaiimagePath(){return this.isEditRequest?`/openai/images/edits`:`/openai/images/generations`},openaiimageCodeBody(){let e=this.modelValue?.request;if(!e)return;let t={...e};if(delete t.action,delete t.callback_url,this.isEditRequest){delete t.image_urls,delete t.image;let e=this.referenceImages;e.length===1?t.image=e[0]:e.length>1&&(t.image=e)}else delete t.image_urls,delete t.image;return t},images(){let e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{let n=t;if(n?.image_url||n?.url){e.push(n);return}n?.b64_json&&e.push({...n,url:`data:image/png;base64,${n.b64_json}`})}),e},referenceImages(){let e=this.modelValue?.request;if(!e)return[];let t=Array.isArray(e.image_urls)?e.image_urls:[];if(t.length>0)return t.filter(e=>typeof e==`string`&&e.length>0);let n=e.image;return Array.isArray(n)?n.filter(e=>typeof e==`string`&&e.length>0):typeof n==`string`&&n.length>0?[n]:Array.isArray(e.images)?e.images.map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`)return e.image_url}).filter(e=>typeof e==`string`&&e.length>0):[]}},methods:{onEdit(e){if(!e)return;console.debug(`Edit image:`,e);let t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit(`openaiimage/setConfig`,t)}}}),ct={class:`preview`},lt={class:`left`},ut={class:`main`},dt={class:`bot`},ft={class:`datetime`},pt={class:`info`},mt={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ht={key:1,class:`prompt mt-2`},gt={key:0},_t={key:0,class:c({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:c({operations:!0,"mt-2":!0,"mb-2":!0})},bt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Et={key:1,class:c({content:!0})},Dt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ot={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},At={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},jt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Mt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nt={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Pt={key:2,class:c({content:!0})},Q={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`},It={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Lt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`};function Rt(r,c,f,p,_,v){let y=h(`el-image`),b=h(`image-preview`),x=h(`image-wrapper`),S=h(`el-button`),C=h(`el-tooltip`),w=h(`api-code-button`),T=h(`font-awesome-icon`),E=h(`copy-to-clipboard`),D=h(`el-alert`);return u(),t(`div`,ct,[n(`div`,lt,[o(y,{src:r.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),n(`div`,ut,[n(`div`,dt,[i(l(r.$t(`openaiimage.name.openaiimageBot`))+` `,1),n(`span`,ft,l(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,pt,[r.referenceImages.length>0?(u(),t(`div`,mt,[(u(!0),t(s,null,e(r.referenceImages,(e,t)=>(u(),a(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):m(``,!0),r.modelValue?.request?.prompt?(u(),t(`p`,ht,[i(l(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?m(``,!0):(u(),t(`span`,gt,` - (`+l(r.$t(`openaiimage.status.pending`))+`) `,1))])):m(``,!0)]),r.modelValue?.response?.success===!0?(u(),t(`div`,_t,[n(`div`,vt,[(u(!0),t(s,null,e(r.images,(e,t)=>(u(),a(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),n(`div`,yt,[o(C,{class:`box-item`,effect:`dark`,content:r.$t(`common.button.edit`),placement:`top-start`},{default:g(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=d(e=>r.onEdit(r.images?.[0]?.image_url||r.images?.[0]?.url),[`stop`])},{default:g(()=>[i(l(r.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:r.openaiimagePath,body:r.openaiimageCodeBody},null,8,[`path`,`body`])]),o(D,{closable:!1,class:`mt-2 success`},{default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,bt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,xt,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),r.showTaskType?(u(),t(`p`,St,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.task`))+`: `+l(r.taskTypeLabel),1)])):m(``,!0),n(`p`,Ct,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,wt,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,Tt,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):m(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(u(),t(`div`,Et,[o(D,{closable:!1,class:`failure`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,Dt,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,Ot,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),r.showTaskType?(u(),t(`p`,kt,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.task`))+`: `+l(r.taskTypeLabel),1)])):m(``,!0),n(`p`,At,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),n(`p`,jt,[o(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.failureReason`))+`: `+l(r.modelValue?.response?.error?.message)+` `,1),o(E,{content:r.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),r.modelValue?.elapsed?(u(),t(`p`,Mt,[o(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.elapsed`))+`: `+l(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),r.modelValue?.response?.trace_id?(u(),t(`p`,Nt,[o(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.traceId`))+`: `+l(r.modelValue?.response?.trace_id)+` `,1),o(E,{content:r.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):m(``,!0)]),_:1})])):(u(),t(`div`,Pt,[o(D,{closable:!1,class:`info`},{template:g(()=>[o(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.failure`)),1)]),default:g(()=>[r.modelValue?.request?.model?(u(),t(`p`,Q,[o(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.model`))+`: `+l(r.modelValue?.request?.model),1)])):m(``,!0),r.modelValue?.request?.size?(u(),t(`p`,Ft,[o(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.size`))+`: `+l(r.modelValue?.request?.size),1)])):m(``,!0),r.showTaskType?(u(),t(`p`,It,[o(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.task`))+`: `+l(r.taskTypeLabel),1)])):m(``,!0),n(`p`,Lt,[o(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(r.$t(`openaiimage.name.taskId`))+`: `+l(r.modelValue?.id)+` `,1),o(E,{content:r.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=r({name:`RecentPanel`,components:{TaskPreview:R(st,[[`render`,Rt],[`__scopeId`,`data-v-8ee5fb87`]]),BotPlaceholder:oe,NoTasks:ue,ScrollList:se},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?.()}}}),Bt={key:0},Vt={key:2,class:`w-full h-full flex items-center justify-center`};function Ht(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,Bt,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Vt,[o(v)])):m(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=j(`openaiimage`),Wt=r({name:`OpenAIImageIndex`,components:{ConfigPanel:ot,Layout:ye,RecentPanel:Ut},mixins:[L],inject:[`initialized`],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===K.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===K.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 ce({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();let 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);let{limit:t=20,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),await this.$store.dispatch(`openaiimage/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})},async onGenerate(){if(!V(this.uploadTracker,e=>this.$t(e),e=>W.warning(e)))return;let e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;if(!this.hasText(e.prompt)){W.error(this.$t(`openaiimage.message.promptRequired`));return}e.prompt=e.prompt.trim(),!t&&`image_urls`in e&&delete e.image_urls,e.size||delete e.size;let n={...e,action:`generate`,callback_url:$},r={action:`edit`,model:e?.model,prompt:e?.prompt,size:e?.size,image_urls:e?.image_urls||[],callback_url:$},i=this.credential?.token;if(!i){console.error(`no token specified`);return}W.info(this.$t(`openaiimage.message.startingTask`)),z(`openaiimage`,t?U.edit(r,{token:i}):U.generate(n,{token:i})).then(e=>{console.debug(`task accepted`,e.data?.task_id),W.success(this.$t(`openaiimage.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?W.error(this.$t(`openaiimage.message.usedUp`)):W.error(this.$t(`openaiimage.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Gt(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{t as y}from"./upload-cn_TUU3N.js";import{t as b}from"./tooltip-BLwTovWL.js";import{t as x}from"./image-r_Sil4Yc.js";import{t as S}from"./alert-OvnfgMB-.js";import{t as C}from"./drawer-Dpuj2uIl.js";import{t as w}from"./switch-BUEiwneZ.js";import{_i as T}from"./constants-DwFseFmM.js";import{At as E,E as D,Fn as O,Nt as ee,Ot as k,Sr as A,hn as j,jt as M,kr as N,kt as P,yr as F}from"./index-1hhw9POE.js";import{t as I}from"./index.es-Ds6M0PuH.js";import{t as te}from"./CopyToClipboard-DG5cx0Ex.js";import{t as L}from"./FilePreview-BFkQVXth.js";import{t as R}from"./ImagePreview-CeyNx3jd.js";import{n as z}from"./taskDrawerMixin-DEgO_R5H.js";import{t as B}from"./BotPlaceholder-BpLIwwxA.js";import{i as V,n as H,t as U}from"./pagination-DH5leY8A.js";import{n as W,t as G}from"./NoTasks-BOopjPtL.js";import{t as K}from"./Consumption-D_CAQaSB.js";import{t as q}from"./ApiCodeButton-CXoLQXC2.js";import{t as J}from"./VideoPlayer-CD9PlOS8.js";var Y=r({name:`LayoutLuma`,components:{ElDrawer:C,ElButton:v,FontAwesomeIcon:I},mixins:[z]}),X={class:`main flex flex-row flex-1`},Z={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Q={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ne(e,r,i,a,s,c){let l=h(`font-awesome-icon`),d=h(`el-button`),m=h(`el-drawer`);return u(),t(`div`,X,[n(`div`,Z,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,Q,[p(e.$slots,`result`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`350px`,class:`drawer`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var re=D(Y,[[`render`,ne],[`__scopeId`,`data-v-da4bcd3a`]]),ie=r({name:`EnhancementSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug(`set enhancement`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=!0)}}),ae={class:`relative`},oe={class:`flex justify-between`},se={class:`flex justify-start items-center`},ce={class:`text-sm font-bold`},le={class:`flex justify-end items-center`};function ue(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-switch`);return u(),t(`div`,ae,[n(`div`,oe,[n(`div`,se,[n(`span`,ce,l(e.$t(`luma.name.enhancement`)),1),o(d,{content:e.$t(`luma.description.enhancement`)},null,8,[`content`])]),n(`div`,le,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var de=D(ie,[[`render`,ue]]),fe=r({name:`CustomSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug(`set custom`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),pe={class:`relative`},me={class:`flex justify-between`},he={class:`flex justify-start items-center`},ge={class:`text-sm font-bold`},_e={class:`flex justify-end items-center`};function ve(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-switch`);return u(),t(`div`,pe,[n(`div`,me,[n(`div`,he,[n(`span`,ge,l(e.$t(`luma.name.custom`)),1),o(d,{content:e.$t(`luma.description.custom`)},null,8,[`content`])]),n(`div`,_e,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var ye=D(fe,[[`render`,ve]]),be=r({name:`LoopSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug(`set loop`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),xe={class:`relative`},Se={class:`flex justify-between`},Ce={class:`flex justify-start items-center`},we={class:`text-sm font-bold`},Te={class:`flex justify-end items-center`};function Ee(e,r,i,a,s,c){let d=h(`info-icon`),f=h(`el-switch`);return u(),t(`div`,xe,[n(`div`,Se,[n(`div`,Ce,[n(`span`,we,l(e.$t(`luma.name.loop`)),1),o(d,{content:e.$t(`luma.description.loop`)},null,8,[`content`])]),n(`div`,Te,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var De=D(be,[[`render`,Ee]]),Oe=r({name:`EndImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetEndImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetEndImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ke={class:`relative`},Ae={class:`flex justify-between`},je={class:`flex justify-start items-center`},Me={class:`text-sm font-bold`};function Ne(e,r,s,c,d,f){let p=h(`info-icon`),_=h(`image-preview`),v=h(`font-awesome-icon`),y=h(`el-button`),b=h(`el-upload`);return u(),t(`div`,ke,[n(`div`,Ae,[n(`div`,je,[n(`span`,Me,l(e.$t(`luma.name.endImageUrl`)),1),o(p,{content:e.$t(`luma.description.endImageUrl`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:g(({file:t})=>[t.url&&t.percentage!==void 0?(u(),a(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):m(``,!0)]),default:g(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:g(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadEndImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Pe=D(Oe,[[`render`,Ne],[`__scopeId`,`data-v-cd768b26`]]),Fe=r({name:`StartImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ie={class:`relative`},Le={class:`flex justify-between`},Re={class:`flex justify-start items-center`},ze={class:`text-sm font-bold`};function Be(e,r,s,c,d,f){let p=h(`info-icon`),_=h(`image-preview`),v=h(`font-awesome-icon`),y=h(`el-button`),b=h(`el-upload`);return u(),t(`div`,Ie,[n(`div`,Le,[n(`div`,Re,[n(`span`,ze,l(e.$t(`luma.name.startImageUrl`)),1),o(p,{content:e.$t(`luma.description.startImageUrl`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:g(({file:t})=>[t.percentage==null?m(``,!0):(u(),a(_,{key:0,url:t.url||t.response.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:g(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:g(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Ve=D(Fe,[[`render`,Be],[`__scopeId`,`data-v-4d03e978`]]),He=r({name:`UploadVideo`,components:{ElUpload:y,ElButton:v,InfoIcon:V,FilePreview:L,FontAwesomeIcon:I},mixins:[P],data(){return{fileList:[],uploadUrl:A()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||=void 0},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadVideoExceed`))},onError(){N.error(this.$t(`luma.message.uploadVideoError`))},beforeUpload(e){let t=e.type===`video/mp4`,n=e.size/1024/1024<10;return t?n?!0:(N.error(this.$t(`luma.message.uploadVideoSizeExceed`)),!1):(N.error(this.$t(`luma.message.uploadVideoTypeFailed`)),!1)},onSetVideoUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e,action:`extend`})},async onSuccess(){this.onSetVideoUrl()}}}),Ue={class:`relative`},We={class:`flex justify-between`},Ge={class:`flex justify-start items-center`},Ke={class:`text-sm font-bold`};function qe(e,r,s,c,d,f){let p=h(`info-icon`),_=h(`file-preview`),v=h(`font-awesome-icon`),y=h(`el-button`),b=h(`el-upload`);return u(),t(`div`,Ue,[n(`div`,We,[n(`div`,Ge,[n(`span`,Ke,l(e.$t(`luma.name.videoUrl`)),1),o(p,{content:e.$t(`luma.description.videoUrl`)},null,8,[`content`])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,accept:`.mp4`,name:`file`,class:`value`,"show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:g(({file:t})=>[t.percentage==null?m(``,!0):(u(),a(_,{key:0,url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:g(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:g(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadVideoUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`before-upload`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Je=D(He,[[`render`,qe],[`__scopeId`,`data-v-b4c637fa`]]),Ye=r({name:`PromptInput`,components:{PromptTextarea:W},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Xe(e,t,n,r,i,o){let s=h(`prompt-textarea`);return u(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`luma.name.prompt`),info:e.$t(`luma.description.prompt`),placeholder:e.$t(`luma.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ze=D(Ye,[[`render`,Xe]]),Qe=r({name:`ExtendFromInput`,components:{VideoPlayer:J},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:`1080p`}}}},computed:{config(){return this.$store.state.luma?.config}}}),$e={class:`relative`},et={class:`flex mb-2`},tt={class:`text-sm font-bold`};function nt(e,r,i,o,s,c){let d=h(`video-player`);return u(),t(`div`,$e,[n(`div`,et,[n(`span`,tt,l(e.$t(`luma.name.extend`)),1)]),n(`div`,null,[e.config?.video_url?(u(),a(d,{key:0,src:e.config?.video_url},null,8,[`src`])):m(``,!0)])])}var rt=r({name:`ConfigPanel`,components:{LoopSelector:De,StartImageInput:Ve,EndImageInput:Pe,EnhancementSelector:de,ElButton:v,FontAwesomeIcon:I,PromptInput:Ze,ExtendFromInput:D(Qe,[[`render`,nt]]),CustomSelector:ye,UploadVideo:Je,Consumption:K},emits:[`generate`],computed:{config(){return this.$store.state.luma?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),it={class:`flex flex-col h-full`},at={class:`flex-1 overflow-y-auto p-5`},ot={class:`flex flex-col items-center justify-center px-5 pb-5`};function st(e,r,s,c,d,f){let p=h(`extend-from-input`),_=h(`prompt-input`),v=h(`custom-selector`),y=h(`upload-video`),b=h(`start-image-input`),x=h(`end-image-input`),S=h(`enhancement-selector`),C=h(`loop-selector`),w=h(`consumption`),T=h(`font-awesome-icon`),E=h(`el-button`);return u(),t(`div`,it,[n(`div`,at,[e.config?.video_id||e.config?.video_url?(u(),a(p,{key:0,class:`mb-4`})):m(``,!0),o(_,{class:`mb-4`}),e.config?.video_id?m(``,!0):(u(),a(v,{key:1,class:`mb-4`})),e.config?.custom?(u(),a(y,{key:2,class:`mb-4`})):m(``,!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(u(),a(b,{key:3,class:`mb-4`})):m(``,!0),o(x,{class:`mb-4`}),o(S,{class:`mb-4`}),o(C,{class:`mb-4`})]),n(`div`,ot,[o(w,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(u(),a(E,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.extend`)),1)]),_:1},8,[`onClick`])):(u(),a(E,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var ct=D(rt,[[`render`,st]]),lt=r({name:`TaskPreview`,components:{ElImage:x,CopyToClipboard:te,FontAwesomeIcon:I,ElAlert:S,VideoPlayer:J,ElTooltip:b,ElButton:v,ApiCodeButton:q},props:{modelValue:{type:Object,required:!0}},emits:[`extend`],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug(`set config`,t),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:`extend`,thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit(`extend`)},onDownload(e){window.open(e,`_blank`)}}}),ut={class:`preview`},dt={class:`left`},ft={class:`main`},pt={class:`bot`},mt={class:`datetime`},ht={class:`info`},gt={key:0,class:`prompt mt-2`},_t={key:0},vt={key:1},yt={key:0,class:c({content:!0,failed:!0})},bt={key:0,class:`mb-4`},xt={key:1,class:c({operations:!0,"mt-2":!0,"mb-4":!0})},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},wt={key:1,class:c({content:!0})},Tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ot={key:2,class:c({content:!0})},kt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function At(e,r,a,s,c,f){let p=h(`el-image`),_=h(`video-player`),v=h(`el-button`),y=h(`el-tooltip`),b=h(`api-code-button`),x=h(`font-awesome-icon`),S=h(`copy-to-clipboard`),C=h(`el-alert`);return u(),t(`div`,ut,[n(`div`,dt,[o(p,{src:`https://cdn.acedata.cloud/ahjfwi.png`,class:`avatar`})]),n(`div`,ft,[n(`div`,pt,[i(l(e.$t(`luma.name.lumaBot`))+` `,1),n(`span`,mt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ht,[e.modelValue?.request?.prompt?(u(),t(`p`,gt,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?m(``,!0):(u(),t(`span`,_t,` - (`+l(e.$t(`luma.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),t(`span`,vt,` - (`+l(e.$t(`luma.status.processing`))+`) `,1)):m(``,!0)])):m(``,!0)]),e.modelValue?.response?.success===!0?(u(),t(`div`,yt,[e.modelValue.response.video_url?(u(),t(`div`,bt,[o(_,{src:e.modelValue.response.video_url},null,8,[`src`])])):m(``,!0),e.modelValue?.response&&!e.config?.custom?(u(),t(`div`,xt,[o(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.extendVideo`),placement:`top-start`},{default:g(()=>[o(v,{type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=d(t=>e.onExtend(t,e.modelValue?.response),[`stop`])},{default:g(()=>[i(l(e.$t(`luma.button.extend`)),1)]),_:1})]),_:1},8,[`content`]),o(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.downloadVideo`),placement:`top-start`},{default:g(()=>[o(v,{type:`info`,size:`small`,class:`btn-action`,onClick:r[1]||=d(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:g(()=>[i(l(e.$t(`luma.button.download`)),1)]),_:1})]),_:1},8,[`content`]),o(b,{path:`/luma/videos`,body:e.modelValue?.request},null,8,[`body`])])):m(``,!0),o(C,{closable:!1,class:`mt-2 success`},{default:g(()=>[n(`p`,St,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),t(`p`,Ct,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0)]),_:1})])):m(``,!0),e.modelValue?.response?.state===`failed`||e.modelValue?.response?.success===!1?(u(),t(`div`,wt,[o(C,{closable:!1,class:`failure`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:g(()=>[n(`p`,Tt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,Et,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),o(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),t(`p`,$,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),n(`p`,Dt,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.traceId`))+`: `+l(e.modelValue?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):m(``,!0),!e.modelValue?.response||e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),t(`div`,Ot,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:g(()=>[n(`p`,kt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):m(``,!0)])])}var jt=r({name:`RecentPanel`,components:{BotPlaceholder:B,TaskPreview:D(lt,[[`render`,At],[`__scopeId`,`data-v-9c354ffe`]]),NoTasks:G,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`,`extend`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mt={key:0},Nt={key:2,class:`w-full h-full flex items-center justify-center`};function Pt(n,r,i,c,l,d){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return u(),t(s,null,[n.tasks?.items===void 0?(u(),t(`div`,Mt,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(u(),a(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:n.loading,onReachTop:r[1]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(u(!0),t(s,null,e(n.tasks?.items,e=>(u(),a(p,{key:e.id,"model-value":e,onExtend:r[0]||=e=>n.$emit(`extend`)},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(u(),t(`div`,Nt,[o(v)])):m(``,!0)],64)}var Ft=D(jt,[[`render`,Pt]]),It=T(`luma`),Lt=r({name:`LumaIndex`,components:{ConfigPanel:ct,Layout:re,RecentPanel:Ft},mixins:[E],inject:[`initialized`],emits:[`extend`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===F.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await U({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`luma/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`luma/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){console.debug(`scrolling down`),await this.$nextTick();let 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);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`luma/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!k(this.uploadTracker,e=>this.$t(e),e=>N.warning(e)))return;let e={...this.config,callback_url:It};if(!this.hasText(e.prompt)){N.error(this.$t(`luma.message.promptRequired`));return}e.prompt=e.prompt?.trim();let t=this.credential?.token;if(!t){console.error(`no token specified`);return}N.info(this.$t(`luma.message.startingTask`)),O(`luma`,j.generate(e,{token:t})).then(()=>{N.success(this.$t(`luma.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?N.error(this.$t(`luma.message.usedUp`)):N.error(this.$t(`luma.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Rt(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),d=h(`layout`);return u(),a(d,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`loading`,`onReachTop`])]),_:1})}var zt=D(Lt,[[`render`,Rt]]);export{zt as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,Ht as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,et as d,k as f,lt as p,x as m,y as h}from"./vendor-chart-mdwpew_o.js";import{t as g}from"./button-DWzbdjZV.js";import{r as _,t as v}from"./select-DUQSa_dv.js";import{t as y}from"./upload-BbP3qVit.js";import{t as b}from"./tooltip-C3PYfh8V.js";import{t as x}from"./image-C1JYEL_e.js";import{t as S}from"./alert-BJj7gY4q.js";import{t as C}from"./input-number-CVD04ts_.js";import{t as w}from"./switch-DflwVy6G.js";import{$t as T,At as E,Bt as D,Ft as O,Gt as k,Ht as ee,It as A,Jt as j,Kt as M,Lt as te,Nt as ne,Pt as re,Qt as ie,Rt as ae,Ut as oe,Vt as se,Wt as ce,Yt as N,Zt as le,_i as P,jt as F,qt as I,zt as L}from"./constants-BvG5EAGh.js";import{At as R,E as z,Fn as B,Nt as V,Ot as H,Qt as U,Sr as W,jt as G,kr as K,kt as q,yr as J}from"./index-B7Ehq3WB.js";import{t as Y}from"./index.es-Cf1Nz1bg.js";import{t as ue}from"./CopyToClipboard-C4Zr_RWu.js";import{t as X}from"./ImagePreview-CuVgQnIV.js";import{t as de}from"./BotPlaceholder-DmDddO0B.js";import{i as Z,n as fe,t as pe}from"./pagination-CbQjtYtK.js";import{n as me,t as he}from"./NoTasks-CrhfF4zj.js";import{t as ge}from"./Consumption-D3EMWpgi.js";import{t as _e}from"./ApiCodeButton-Dyr9-U56.js";import{t as ve}from"./ImageWrapper-Bf4G9gSN.js";import{t as ye}from"./Seedance-CgoG1hAA.js";import{t as be}from"./VideoPlayer-CxSJ4zS_.js";var xe=s({name:`SeedancePromptInput`,components:{PromptTextarea:me},computed:{prompt:{get(){return this.$store.state.seedance?.config?.prompt},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Se(e,n,r,i,a,o){let s=d(`prompt-textarea`);return u(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`seedance.name.prompt`),info:e.$t(`seedance.description.prompt`),placeholder:e.$t(`seedance.placeholder.prompt`),"min-rows":5},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ce=z(xe,[[`render`,Se]]),we=s({name:`SeedanceModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:D,label:this.$t(`seedance.model.seedance20`)},{value:se,label:this.$t(`seedance.model.seedance20Fast`)},{value:L,label:this.$t(`seedance.model.seedance15pro`)},{value:te,label:this.$t(`seedance.model.seedance10pro`)},{value:ae,label:this.$t(`seedance.model.seedance10proFast`)},{value:A,label:this.$t(`seedance.model.seedance10liteT2v`)},{value:O,label:this.$t(`seedance.model.seedance10liteI2v`)}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.model},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,model:e})}}},mounted(){this.value||=E}}),Te={class:`field`},Ee={class:`label`},De={class:`box`},Oe={class:`title font-bold`};function ke(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,Te,[n(`div`,Ee,[n(`div`,De,[n(`h2`,Oe,l(e.$t(`seedance.name.model`)),1),a(g,{content:e.$t(`seedance.description.model`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`seedance.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ae=z(we,[[`render`,ke],[`__scopeId`,`data-v-61816a81`]]),je=s({name:`SeedanceDurationSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:2,label:`2s`},{value:3,label:`3s`},{value:4,label:`4s`},{value:5,label:`5s`},{value:6,label:`6s`},{value:7,label:`7s`},{value:8,label:`8s`},{value:9,label:`9s`},{value:10,label:`10s`},{value:11,label:`11s`},{value:12,label:`12s`}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.duration},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,duration:e})}}},mounted(){this.value||=5}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,Me,[n(`div`,Ne,[n(`div`,Pe,[n(`h2`,Fe,l(e.$t(`seedance.name.duration`)),1),a(g,{content:e.$t(`seedance.description.duration`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`seedance.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=z(je,[[`render`,Ie],[`__scopeId`,`data-v-5c809a72`]]),Re=N,Q={[j]:0,[N]:1,[I]:2},ze=s({name:`SeedanceResolutionSelector`,components:{InfoIcon:Z,ElTooltip:b},computed:{model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},isLiteModel(){return typeof this.model==`string`&&this.model.includes(`-lite-`)},options(){let e=[{value:j,label:`480p`},{value:N,label:`720p`},{value:I,label:`1080p`}],t=this.isLiteModel;return e.map(e=>({...e,disabled:t&&Q[e.value]>Q[Re]}))},value:{get(){return this.$store.state.seedance?.config?.resolution},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,resolution:e})}}},watch:{model(){this.clampValue()}},mounted(){this.value?this.clampValue():this.value=this.capability.defaultResolution||`720p`},methods:{onSelect(e){e.disabled||(this.value=e.value)},clampValue(){let e=this.value,t=this.options.find(t=>t.value===e);(!e||t&&t.disabled)&&(this.value=this.capability.defaultResolution||`720p`)}}}),Be={class:`resolution`},Ve={class:`header`},He={class:`title font-bold`},Ue={class:`items`},We=[`onClick`];function Ge(r,i,o,s,h,g){let _=d(`info-icon`),v=d(`el-tooltip`);return u(),f(`div`,Be,[n(`div`,Ve,[n(`h2`,He,l(r.$t(`seedance.name.resolution`)),1),a(_,{content:r.$t(`seedance.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,Ue,[(u(!0),f(m,null,c(r.options,i=>(u(),t(v,{key:i.value,content:r.$t(`seedance.message.resolutionNotSupported`),disabled:!i.disabled,placement:`top`},{default:p(()=>[n(`div`,{class:e([`item`,{active:r.value===i.value,disabled:i.disabled}]),onClick:e=>r.onSelect(i)},l(i.label),11,We)]),_:2},1032,[`content`,`disabled`]))),128))])])}var Ke=z(ze,[[`render`,Ge],[`__scopeId`,`data-v-fd8d4e4b`]]),qe=s({name:`SeedanceRatioSelector`,components:{InfoIcon:Z},computed:{options(){return[{value:oe,label:`16:9`,w:32,h:18},{value:k,label:`9:16`,w:18,h:32},{value:`4:3`,label:`4:3`,w:28,h:21},{value:`3:4`,label:`3:4`,w:21,h:28},{value:`1:1`,label:`1:1`,w:24,h:24},{value:ce,label:`21:9`,w:34,h:14},{value:M,label:this.$t(`seedance.ratio.adaptive`),w:0,h:0}]},value:{get(){return this.$store.state.seedance?.config?.ratio},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,ratio:e})}}},mounted(){this.value||=F}}),Je={class:`ratio`},Ye={class:`header`},Xe={class:`title font-bold`},Ze={class:`items`},Qe=[`onClick`],$e={class:`preview`},et={key:1,class:`rect rect-auto`},tt={class:`name`};function nt(t,i,o,s,p,h){let g=d(`info-icon`);return u(),f(`div`,Je,[n(`div`,Ye,[n(`h2`,Xe,l(t.$t(`seedance.name.ratio`)),1),a(g,{content:t.$t(`seedance.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Ze,[(u(!0),f(m,null,c(t.options,i=>(u(),f(`div`,{key:i.value,class:e([`item`,{active:t.value===i.value}]),onClick:e=>t.value=i.value},[n(`div`,$e,[i.w&&i.h?(u(),f(`div`,{key:0,class:`rect`,style:r({width:i.w+`px`,height:i.h+`px`})},null,4)):(u(),f(`div`,et,`A`))]),n(`div`,tt,l(i.label),1)],10,Qe))),128))])])}var rt=z(qe,[[`render`,nt],[`__scopeId`,`data-v-8ddec2dd`]]),it=s({name:`SeedanceGenerateAudioSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{isSupported(){let e=this.$store.state.seedance?.config?.model;return T(e).acceptsAudio},value:{get(){return this.$store.state.seedance?.config?.generate_audio??!1},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,generate_audio:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=!1)}}),at={key:0,class:`field`},ot={class:`label`},st={class:`box`},ct={class:`title font-bold`},lt={class:`value`};function ut(e,t,r,i,s,c){let p=d(`info-icon`),m=d(`el-switch`);return e.isSupported?(u(),f(`div`,at,[n(`div`,ot,[n(`div`,st,[n(`h2`,ct,l(e.$t(`seedance.name.generateAudio`)),1),a(p,{content:e.$t(`seedance.description.generateAudio`),class:`info`},null,8,[`content`])])]),n(`div`,lt,[a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])):o(``,!0)}var dt=z(it,[[`render`,ut],[`__scopeId`,`data-v-df51dfbd`]]),ft=s({name:`SeedanceCameraFixedSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{value:{get(){return this.$store.state.seedance?.config?.camerafixed??!1},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,camerafixed:e})}}},mounted(){this.$store.state.seedance?.config?.camerafixed===void 0&&(this.value=!1)}}),pt={class:`field`},mt={class:`label`},ht={class:`box`},gt={class:`title font-bold`},_t={class:`value`};function vt(e,t,r,i,o,s){let c=d(`info-icon`),p=d(`el-switch`);return u(),f(`div`,pt,[n(`div`,mt,[n(`div`,ht,[n(`h2`,gt,l(e.$t(`seedance.name.cameraFixed`)),1),a(c,{content:e.$t(`seedance.description.cameraFixed`),class:`info`},null,8,[`content`])])]),n(`div`,_t,[a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])}var yt=z(ft,[[`render`,vt],[`__scopeId`,`data-v-ae777d61`]]),bt=s({name:`SeedanceFirstFrameImage`,components:{ElUpload:y,ElButton:g,InfoIcon:Z,FontAwesomeIcon:Y,ImagePreview:X},mixins:[G,q],data(){return{fileList:[],uploadUrl:W()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{"capability.acceptsImage"(e){e||(this.fileList=[],this.onSetFirstFrameUrl())}},methods:{onExceed(){K.warning(this.$t(`seedance.message.uploadExceed`))},onError(){K.error(this.$t(`seedance.message.uploadError`))},onSetFirstFrameUrl(){let e=this.urls?.[0],t=(this.$store.state.seedance?.config?.images||[]).filter(e=>e?.role!==`first_frame`);e&&t.push({url:e,role:`first_frame`}),this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,images:t.length>0?t:void 0})},async onSuccess(){this.onSetFirstFrameUrl()},async onRemove(){this.onSetFirstFrameUrl()}}}),xt={key:0,class:`relative`},St={class:`flex justify-between`},Ct={class:`flex justify-start items-center`},wt={class:`text-sm font-bold`},Tt={key:0,class:`required-badge`};function Et(e,r,s,c,m,h){let g=d(`info-icon`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`el-button`),b=d(`el-upload`);return e.capability.acceptsImage?(u(),f(`div`,xt,[n(`div`,St,[n(`div`,Ct,[n(`span`,wt,l(e.$t(`seedance.name.firstFrame`)),1),e.capability.requiresImage?(u(),f(`span`,Tt,l(e.$t(`seedance.name.required`)),1)):o(``,!0),a(g,{content:e.$t(`seedance.description.firstFrame`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:n})=>[n.url&&n.percentage!==void 0?(u(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:p(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:p(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`seedance.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])):o(``,!0)}var Dt=z(bt,[[`render`,Et],[`__scopeId`,`data-v-e2597f23`]]),Ot=s({name:`SeedanceLastFrameImage`,components:{ElUpload:y,ElButton:g,ImagePreview:X,InfoIcon:Z,FontAwesomeIcon:Y},mixins:[G,q],data(){return{fileList:[],uploadUrl:W()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{"capability.acceptsLastFrame"(e){e||(this.fileList=[],this.onSetLastFrameUrl())}},methods:{onExceed(){K.warning(this.$t(`seedance.message.uploadExceed`))},onError(){K.error(this.$t(`seedance.message.uploadError`))},onSetLastFrameUrl(){let e=this.urls?.[0],t=(this.$store.state.seedance?.config?.images||[]).filter(e=>e?.role!==`last_frame`);e&&t.push({url:e,role:`last_frame`}),this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,images:t.length>0?t:void 0})},async onSuccess(){this.onSetLastFrameUrl()},async onRemove(){this.onSetLastFrameUrl()}}}),kt={key:0,class:`relative`},At={class:`flex justify-between`},jt={class:`flex justify-start items-center`},Mt={class:`text-sm font-bold`};function Nt(e,r,s,c,m,h){let g=d(`info-icon`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`el-button`),b=d(`el-upload`);return e.capability.acceptsLastFrame?(u(),f(`div`,kt,[n(`div`,At,[n(`div`,jt,[n(`span`,Mt,l(e.$t(`seedance.name.lastFrame`)),1),a(g,{content:e.$t(`seedance.description.lastFrame`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:n})=>[n.url&&n.percentage!==void 0?(u(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:p(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:p(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`seedance.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])):o(``,!0)}var Pt=z(Ot,[[`render`,Nt],[`__scopeId`,`data-v-3a191e51`]]),Ft=s({name:`SeedanceServiceTierSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:le,label:this.$t(`seedance.serviceTier.default`)},{value:ie,label:this.$t(`seedance.serviceTier.flex`)}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.service_tier},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,service_tier:e})}}},mounted(){this.value||=ne}}),It={class:`field`},Lt={class:`label`},Rt={class:`box`},zt={class:`title font-bold`};function Bt(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,It,[n(`div`,Lt,[n(`div`,Rt,[n(`h2`,zt,l(e.$t(`seedance.name.serviceTier`)),1),a(g,{content:e.$t(`seedance.description.serviceTier`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`seedance.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Vt=z(Ft,[[`render`,Bt],[`__scopeId`,`data-v-cc938de2`]]),Ht=s({name:`SeedanceReturnLastFrameSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{model(){return this.$store.state.seedance?.config?.model},isSupported(){return T(this.model).acceptsReturnLastFrame},value:{get(){return this.$store.state.seedance?.config?.return_last_frame},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,return_last_frame:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=!1)}}),Ut={key:0,class:`field`},Wt={class:`label`},Gt={class:`box`},Kt={class:`title font-bold`},qt={class:`value`};function Jt(e,t,r,i,s,c){let p=d(`info-icon`),m=d(`el-switch`);return e.isSupported?(u(),f(`div`,Ut,[n(`div`,Wt,[n(`div`,Gt,[n(`h2`,Kt,l(e.$t(`seedance.name.returnLastFrame`)),1),a(p,{content:e.$t(`seedance.description.returnLastFrame`),class:`info`},null,8,[`content`])])]),n(`div`,qt,[a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])):o(``,!0)}var Yt=z(Ht,[[`render`,Jt],[`__scopeId`,`data-v-edea5451`]]),Xt=s({name:`SeedanceSeedInput`,components:{ElInputNumber:C,InfoIcon:Z},computed:{value:{get(){let e=this.$store.state.seedance?.config?.seed;return typeof e==`number`?e:-1},set(e){let t={...this.$store.state.seedance?.config||{}};t.seed=typeof e==`number`&&Number.isInteger(e)?e:-1,this.$store.commit(`seedance/setConfig`,t)}}}}),Zt={class:`field`},Qt={class:`label`},$t={class:`box`},en={class:`title font-bold`},tn={class:`value`};function nn(e,t,r,i,o,s){let c=d(`info-icon`),p=d(`el-input-number`);return u(),f(`div`,Zt,[n(`div`,Qt,[n(`div`,$t,[n(`h2`,en,l(e.$t(`seedance.name.seed`)),1),a(c,{content:e.$t(`seedance.description.seed`),class:`info`},null,8,[`content`])])]),n(`div`,tn,[a(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,min:-1,max:2147483647,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])}var rn=s({name:`SeedanceConfigPanel`,components:{ElButton:g,FontAwesomeIcon:Y,PromptInput:Ce,ModelSelector:Ae,DurationSelector:Le,ResolutionSelector:Ke,RatioSelector:rt,GenerateAudioSwitch:dt,CameraFixedSwitch:yt,ServiceTierSelector:Vt,ReturnLastFrameSwitch:Yt,SeedInput:z(Xt,[[`render`,nn],[`__scopeId`,`data-v-685a9869`]]),FirstFrameImage:Dt,LastFrameImage:Pt,Consumption:ge},emits:[`generate`],computed:{config(){return this.$store.state.seedance?.config},consumption(){return V(this.config,this.service?.cost)},service(){return this.$store.state.seedance?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),an={class:`flex flex-col h-full`},on={class:`flex-1 overflow-y-auto p-5`},sn={class:`flex flex-col items-center justify-center px-5 pb-5`};function cn(e,t,r,o,s,c){let m=d(`prompt-input`),h=d(`model-selector`),g=d(`ratio-selector`),_=d(`resolution-selector`),v=d(`duration-selector`),y=d(`service-tier-selector`),b=d(`generate-audio-switch`),x=d(`camera-fixed-switch`),S=d(`return-last-frame-switch`),C=d(`seed-input`),w=d(`first-frame-image`),T=d(`last-frame-image`),E=d(`consumption`),D=d(`font-awesome-icon`),O=d(`el-button`);return u(),f(`div`,an,[n(`div`,on,[a(m,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),a(y,{class:`mb-4`}),a(b,{class:`mb-4`}),a(x,{class:`mb-4`}),a(S,{class:`mb-4`}),a(C,{class:`mb-4`}),a(w,{class:`mb-2`}),a(T,{class:`mb-2`})]),n(`div`,sn,[a(E,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(O,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:p(()=>[a(D,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`seedance.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ln=z(rn,[[`render`,cn]]),un=s({name:`SeedanceTaskPreview`,components:{ElImage:x,CopyToClipboard:ue,FontAwesomeIcon:Y,ElAlert:S,VideoPlayer:be,ElTooltip:b,ElButton:g,ImageWrapper:ve,ImagePreview:X,ApiCodeButton:_e},props:{modelValue:{type:Object,required:!0}},data(){return{seedanceLogo:re}},computed:{video(){return this.modelValue?.response?.data},referenceImages(){let e=this.modelValue?.request?.images;if(!Array.isArray(e))return[];let t=[],n=e.find(e=>e?.role===`first_frame`);n?.url&&t.push({url:n.url,name:`first-frame`});let r=e.find(e=>e?.role===`last_frame`);return r?.url&&t.push({url:r.url,name:`last-frame`}),e.forEach((e,n)=>{e?.url&&e.role!==`first_frame`&&e.role!==`last_frame`&&t.push({url:e.url,name:e.role||`image-${n}`})}),t}},methods:{onDownload(e){window.open(e,`_blank`)}}}),dn={class:`preview`},fn={class:`left`},pn={class:`main`},mn={class:`bot`},hn={class:`datetime`},gn={class:`info`},_n={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},vn={key:1,class:`prompt mt-2`},yn={key:0},bn={key:1},xn={key:0,class:e({content:!0})},Sn={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Cn={key:1,class:e({content:!0})},wn={key:0,class:`mb-4`},Tn={key:1,class:`mb-4`},En={key:2,class:e({operations:!0,"mt-2":!0,"mb-2":!0})},Dn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},On={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},An={key:0},jn={key:1},Mn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pn={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Fn={key:2,class:e({content:!0})},In={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ln={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Rn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},zn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Bn={key:3,class:e({content:!0})},Vn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Hn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Un(e,r,s,g,_,v){let y=d(`el-image`),b=d(`image-preview`),x=d(`font-awesome-icon`),S=d(`copy-to-clipboard`),C=d(`el-alert`),w=d(`video-player`),T=d(`image-wrapper`),E=d(`el-button`),D=d(`el-tooltip`),O=d(`api-code-button`);return u(),f(`div`,dn,[n(`div`,fn,[a(y,{src:e.seedanceLogo,class:`avatar`},null,8,[`src`])]),n(`div`,pn,[n(`div`,mn,[i(l(e.$t(`seedance.name.seedanceBot`))+` `,1),n(`span`,hn,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,gn,[e.referenceImages.length>0?(u(),f(`div`,_n,[(u(!0),f(m,null,c(e.referenceImages,(e,n)=>(u(),t(b,{key:n,url:e.url,name:e.name,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),f(`p`,vn,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.status===`processing`||e.video?.status===`pending`?(u(),f(`span`,bn,` - (`+l(e.$t(`seedance.status.processing`))+`) `,1)):o(``,!0):(u(),f(`span`,yn,` - (`+l(e.$t(`seedance.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(u(),f(`div`,Cn,[e.video?.video_url?(u(),f(`div`,wn,[a(w,{src:e.video?.video_url},null,8,[`src`])])):o(``,!0),e.video?.last_frame_url?(u(),f(`div`,Tn,[a(T,{src:e.video?.last_frame_url,"raw-src":e.video?.last_frame_url},null,8,[`src`,`raw-src`])])):o(``,!0),e.video?.video_url?(u(),f(`div`,En,[a(D,{class:`box-item`,effect:`dark`,content:e.$t(`seedance.message.downloadVideo`),placement:`top-start`},{default:p(()=>[a(E,{type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=h(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:p(()=>[i(l(e.$t(`seedance.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(O,{path:`/seedance/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:p(()=>[e.modelValue?.request?.model?(u(),f(`p`,Dn,[a(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.video?.duration?(u(),f(`p`,On,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.duration`))+`: `+l(e.video?.duration)+`s `,1)])):o(``,!0),e.video?.resolution?(u(),f(`p`,kn,[a(x,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.resolution`))+`: `+l(e.video?.resolution)+` `,1),e.video?.ratio?(u(),f(`span`,An,` · `+l(e.video?.ratio),1)):o(``,!0),e.video?.framespersecond?(u(),f(`span`,jn,` · `+l(e.video?.framespersecond)+`fps`,1)):o(``,!0)])):o(``,!0),e.modelValue?.request?.generate_audio?(u(),f(`p`,Mn,[a(x,{icon:`fa-solid fa-volume-up`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.generateAudio`))+`: `+l(e.$t(`seedance.button.on`)),1)])):o(``,!0),n(`p`,Nn,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),f(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,Pn,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),f(`div`,Fn,[a(C,{closable:!1,class:`failure`},{template:p(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.failure`)),1)]),default:p(()=>[n(`p`,In,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(u(),f(`p`,Ln,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0),e.modelValue?.elapsed?(u(),f(`p`,Rn,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,zn,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),f(`div`,Bn,[a(C,{closable:!1,class:`info`},{template:p(()=>[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.status`)),1)]),default:p(()=>[n(`p`,Vn,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.trace_id?(u(),f(`p`,Hn,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),f(`div`,xn,[a(C,{closable:!1,class:`info`},{template:p(()=>[a(x,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`seedance.status.pending`)),1)]),default:p(()=>[n(`p`,Sn,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`seedance.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var Wn=s({name:`SeedanceRecentPanel`,components:{TaskPreview:z(un,[[`render`,Un],[`__scopeId`,`data-v-8b7e10f0`]]),BotPlaceholder:de,NoTasks:he,ScrollList:fe},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.seedance?.tasks,items:this.$store.state.seedance?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Gn={key:0},Kn={key:2,class:`w-full h-full flex items-center justify-center`};function qn(e,n,r,i,s,l){let h=d(`bot-placeholder`),g=d(`task-preview`),_=d(`scroll-list`),v=d(`no-tasks`);return u(),f(m,null,[e.tasks?.items===void 0?(u(),f(`div`,Gn,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(u(!0),f(m,null,c(e.tasks?.items,e=>(u(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),f(`div`,Kn,[a(v)])):o(``,!0)],64)}var Jn=z(Wn,[[`render`,qn]]),Yn=P(`seedance`),Xn=s({name:`SeedanceIndex`,components:{ConfigPanel:ln,Layout:ye,RecentPanel:Jn},mixins:[R],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.seedance?.status?.getApplications===J.Request},tasksLoading(){return this.$store.state.seedance?.status?.getTasks===J.Request||this.fetchingTasks},credential(){return this.$store.state.seedance?.credential},config(){return this.$store.state.seedance?.config},tasks(){return this.$store.state.seedance?.tasks}},watch:{initialized:{async handler(e){e&&(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 pe({tasks: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(){await this.$store.dispatch(`seedance/getService`)},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch(`seedance/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!H(this.uploadTracker,e=>this.$t(e),e=>K.warning(e)))return;let e={...this.config||{}};if(typeof e?.prompt==`string`&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),Array.isArray(e?.images)){e.images=e.images.filter(e=>!!e?.url);let t=e.images.some(e=>e?.role===`first_frame`),n=e.images.some(e=>e?.role===`last_frame`);!t&&n&&(e.images=e.images.map(e=>e?.role===`last_frame`?{...e,role:`first_frame`}:e))}let t=Array.isArray(e?.images)&&e.images.length>0;if(!t&&`images`in e&&delete e.images,e?.model&&!ee[e.model]){K.warning(this.$t(`seedance.message.modelUnsupported`));return}let n=T(e?.model);if(n.requiresImage&&!t){K.warning(this.$t(`seedance.message.modelRequiresImage`));return}if(!n.acceptsImage&&t){K.warning(this.$t(`seedance.message.modelRejectsImage`));return}if(!n.acceptsText&&!t){K.warning(this.$t(`seedance.message.modelRequiresImage`));return}!n.acceptsAudio&&e.generate_audio&&(e.generate_audio=!1),!n.acceptsReturnLastFrame&&e.return_last_frame&&(e.return_last_frame=!1),!n.acceptsLastFrame&&t&&(e.images=e.images.filter(e=>e?.role!==`last_frame`));let r={...e,callback_url:Yn},i=this.credential?.token;if(!i){console.error(`no token specified`);return}K.info(this.$t(`seedance.message.startingTask`)),B(`seedance`,U.generate(r,{token:i})).then(()=>{K.success(this.$t(`seedance.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?K.error(this.$t(`seedance.message.usedUp`)):K.error(this.$t(`seedance.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Zn(e,n,r,i,o,s){let c=d(`config-panel`),l=d(`recent-panel`),f=d(`layout`);return u(),t(f,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:p(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Qn=z(Xn,[[`render`,Zn]]);export{Qn as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Ut as c,Vt as l,Wt as u,Z as d,b as f,k as p,tt as m,ut as h}from"./vendor-chart-BJCvKk8-.js";import{t as g}from"./button-DfsQodL-.js";import{r as _,t as v}from"./select-CxvkoR_I.js";import{t as y}from"./upload-cn_TUU3N.js";import{t as b}from"./tooltip-BLwTovWL.js";import{t as x}from"./image-r_Sil4Yc.js";import{t as S}from"./alert-OvnfgMB-.js";import{t as C}from"./input-number-Bg1zmr12.js";import{t as w}from"./switch-BUEiwneZ.js";import{$t as T,At as E,Bt as D,Ft as O,Gt as k,Ht as ee,It as A,Jt as j,Kt as M,Lt as te,Nt as ne,Pt as re,Qt as ie,Rt as ae,Ut as oe,Vt as se,Wt as ce,Yt as N,Zt as le,_i as P,jt as F,qt as I,zt as L}from"./constants-DwFseFmM.js";import{At as R,E as z,Fn as B,Nt as V,Ot as H,Qt as U,Sr as W,jt as G,kr as K,kt as q,yr as J}from"./index-1hhw9POE.js";import{t as Y}from"./index.es-Ds6M0PuH.js";import{t as ue}from"./CopyToClipboard-DG5cx0Ex.js";import{t as X}from"./ImagePreview-CeyNx3jd.js";import{t as de}from"./BotPlaceholder-BpLIwwxA.js";import{i as Z,n as fe,t as pe}from"./pagination-DH5leY8A.js";import{n as me,t as he}from"./NoTasks-BOopjPtL.js";import{t as ge}from"./Consumption-D_CAQaSB.js";import{t as _e}from"./ApiCodeButton-CXoLQXC2.js";import{t as ve}from"./ImageWrapper-C6BTBymE.js";import{t as ye}from"./Seedance-cdIlG9x0.js";import{t as be}from"./VideoPlayer-CD9PlOS8.js";var xe=r({name:`SeedancePromptInput`,components:{PromptTextarea:me},computed:{prompt:{get(){return this.$store.state.seedance?.config?.prompt},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Se(e,t,n,r,i,o){let s=m(`prompt-textarea`);return d(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`seedance.name.prompt`),info:e.$t(`seedance.description.prompt`),placeholder:e.$t(`seedance.placeholder.prompt`),"min-rows":5},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ce=z(xe,[[`render`,Se]]),we=r({name:`SeedanceModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:D,label:this.$t(`seedance.model.seedance20`)},{value:se,label:this.$t(`seedance.model.seedance20Fast`)},{value:L,label:this.$t(`seedance.model.seedance15pro`)},{value:te,label:this.$t(`seedance.model.seedance10pro`)},{value:ae,label:this.$t(`seedance.model.seedance10proFast`)},{value:A,label:this.$t(`seedance.model.seedance10liteT2v`)},{value:O,label:this.$t(`seedance.model.seedance10liteI2v`)}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.model},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,model:e})}}},mounted(){this.value||=E}}),Te={class:`field`},Ee={class:`label`},De={class:`box`},Oe={class:`title font-bold`};function ke(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,Te,[n(`div`,Ee,[n(`div`,De,[n(`h2`,Oe,u(r.$t(`seedance.name.model`)),1),o(g,{content:r.$t(`seedance.description.model`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedance.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Ae=z(we,[[`render`,ke],[`__scopeId`,`data-v-61816a81`]]),je=r({name:`SeedanceDurationSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:2,label:`2s`},{value:3,label:`3s`},{value:4,label:`4s`},{value:5,label:`5s`},{value:6,label:`6s`},{value:7,label:`7s`},{value:8,label:`8s`},{value:9,label:`9s`},{value:10,label:`10s`},{value:11,label:`11s`},{value:12,label:`12s`}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.duration},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,duration:e})}}},mounted(){this.value||=5}}),Me={class:`field`},Ne={class:`label`},Pe={class:`box`},Fe={class:`title font-bold`};function Ie(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,Me,[n(`div`,Ne,[n(`div`,Pe,[n(`h2`,Fe,u(r.$t(`seedance.name.duration`)),1),o(g,{content:r.$t(`seedance.description.duration`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedance.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Le=z(je,[[`render`,Ie],[`__scopeId`,`data-v-5c809a72`]]),Re=N,Q={[j]:0,[N]:1,[I]:2},ze=r({name:`SeedanceResolutionSelector`,components:{InfoIcon:Z,ElTooltip:b},computed:{model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},isLiteModel(){return typeof this.model==`string`&&this.model.includes(`-lite-`)},options(){let e=[{value:j,label:`480p`},{value:N,label:`720p`},{value:I,label:`1080p`}],t=this.isLiteModel;return e.map(e=>({...e,disabled:t&&Q[e.value]>Q[Re]}))},value:{get(){return this.$store.state.seedance?.config?.resolution},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,resolution:e})}}},watch:{model(){this.clampValue()}},mounted(){this.value?this.clampValue():this.value=this.capability.defaultResolution||`720p`},methods:{onSelect(e){e.disabled||(this.value=e.value)},clampValue(){let e=this.value,t=this.options.find(t=>t.value===e);(!e||t&&t.disabled)&&(this.value=this.capability.defaultResolution||`720p`)}}}),Be={class:`resolution`},Ve={class:`header`},He={class:`title font-bold`},Ue={class:`items`},We=[`onClick`];function Ge(r,i,c,f,p,g){let _=m(`info-icon`),v=m(`el-tooltip`);return d(),t(`div`,Be,[n(`div`,Ve,[n(`h2`,He,u(r.$t(`seedance.name.resolution`)),1),o(_,{content:r.$t(`seedance.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,Ue,[(d(!0),t(s,null,e(r.options,e=>(d(),a(v,{key:e.value,content:r.$t(`seedance.message.resolutionNotSupported`),disabled:!e.disabled,placement:`top`},{default:h(()=>[n(`div`,{class:l([`item`,{active:r.value===e.value,disabled:e.disabled}]),onClick:t=>r.onSelect(e)},u(e.label),11,We)]),_:2},1032,[`content`,`disabled`]))),128))])])}var Ke=z(ze,[[`render`,Ge],[`__scopeId`,`data-v-fd8d4e4b`]]),qe=r({name:`SeedanceRatioSelector`,components:{InfoIcon:Z},computed:{options(){return[{value:oe,label:`16:9`,w:32,h:18},{value:k,label:`9:16`,w:18,h:32},{value:`4:3`,label:`4:3`,w:28,h:21},{value:`3:4`,label:`3:4`,w:21,h:28},{value:`1:1`,label:`1:1`,w:24,h:24},{value:ce,label:`21:9`,w:34,h:14},{value:M,label:this.$t(`seedance.ratio.adaptive`),w:0,h:0}]},value:{get(){return this.$store.state.seedance?.config?.ratio},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,ratio:e})}}},mounted(){this.value||=F}}),Je={class:`ratio`},Ye={class:`header`},Xe={class:`title font-bold`},Ze={class:`items`},Qe=[`onClick`],$e={class:`preview`},et={key:1,class:`rect rect-auto`},tt={class:`name`};function nt(r,i,a,f,p,h){let g=m(`info-icon`);return d(),t(`div`,Je,[n(`div`,Ye,[n(`h2`,Xe,u(r.$t(`seedance.name.ratio`)),1),o(g,{content:r.$t(`seedance.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Ze,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},[n(`div`,$e,[e.w&&e.h?(d(),t(`div`,{key:0,class:`rect`,style:c({width:e.w+`px`,height:e.h+`px`})},null,4)):(d(),t(`div`,et,`A`))]),n(`div`,tt,u(e.label),1)],10,Qe))),128))])])}var rt=z(qe,[[`render`,nt],[`__scopeId`,`data-v-8ddec2dd`]]),it=r({name:`SeedanceGenerateAudioSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{isSupported(){let e=this.$store.state.seedance?.config?.model;return T(e).acceptsAudio},value:{get(){return this.$store.state.seedance?.config?.generate_audio??!1},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,generate_audio:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=!1)}}),at={key:0,class:`field`},ot={class:`label`},st={class:`box`},ct={class:`title font-bold`},lt={class:`value`};function ut(e,r,i,a,s,c){let l=m(`info-icon`),f=m(`el-switch`);return e.isSupported?(d(),t(`div`,at,[n(`div`,ot,[n(`div`,st,[n(`h2`,ct,u(e.$t(`seedance.name.generateAudio`)),1),o(l,{content:e.$t(`seedance.description.generateAudio`),class:`info`},null,8,[`content`])])]),n(`div`,lt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])):p(``,!0)}var dt=z(it,[[`render`,ut],[`__scopeId`,`data-v-df51dfbd`]]),ft=r({name:`SeedanceCameraFixedSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{value:{get(){return this.$store.state.seedance?.config?.camerafixed??!1},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,camerafixed:e})}}},mounted(){this.$store.state.seedance?.config?.camerafixed===void 0&&(this.value=!1)}}),pt={class:`field`},mt={class:`label`},ht={class:`box`},gt={class:`title font-bold`},_t={class:`value`};function vt(e,r,i,a,s,c){let l=m(`info-icon`),f=m(`el-switch`);return d(),t(`div`,pt,[n(`div`,mt,[n(`div`,ht,[n(`h2`,gt,u(e.$t(`seedance.name.cameraFixed`)),1),o(l,{content:e.$t(`seedance.description.cameraFixed`),class:`info`},null,8,[`content`])])]),n(`div`,_t,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])}var yt=z(ft,[[`render`,vt],[`__scopeId`,`data-v-ae777d61`]]),bt=r({name:`SeedanceFirstFrameImage`,components:{ElUpload:y,ElButton:g,InfoIcon:Z,FontAwesomeIcon:Y,ImagePreview:X},mixins:[G,q],data(){return{fileList:[],uploadUrl:W()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{"capability.acceptsImage"(e){e||(this.fileList=[],this.onSetFirstFrameUrl())}},methods:{onExceed(){K.warning(this.$t(`seedance.message.uploadExceed`))},onError(){K.error(this.$t(`seedance.message.uploadError`))},onSetFirstFrameUrl(){let e=this.urls?.[0],t=(this.$store.state.seedance?.config?.images||[]).filter(e=>e?.role!==`first_frame`);e&&t.push({url:e,role:`first_frame`}),this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,images:t.length>0?t:void 0})},async onSuccess(){this.onSetFirstFrameUrl()},async onRemove(){this.onSetFirstFrameUrl()}}}),xt={key:0,class:`relative`},St={class:`flex justify-between`},Ct={class:`flex justify-start items-center`},wt={class:`text-sm font-bold`},Tt={key:0,class:`required-badge`};function Et(e,r,s,c,l,f){let g=m(`info-icon`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`el-button`),b=m(`el-upload`);return e.capability.acceptsImage?(d(),t(`div`,xt,[n(`div`,St,[n(`div`,Ct,[n(`span`,wt,u(e.$t(`seedance.name.firstFrame`)),1),e.capability.requiresImage?(d(),t(`span`,Tt,u(e.$t(`seedance.name.required`)),1)):p(``,!0),o(g,{content:e.$t(`seedance.description.firstFrame`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):p(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+u(e.$t(`seedance.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])):p(``,!0)}var Dt=z(bt,[[`render`,Et],[`__scopeId`,`data-v-e2597f23`]]),Ot=r({name:`SeedanceLastFrameImage`,components:{ElUpload:y,ElButton:g,ImagePreview:X,InfoIcon:Z,FontAwesomeIcon:Y},mixins:[G,q],data(){return{fileList:[],uploadUrl:W()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},model(){return this.$store.state.seedance?.config?.model},capability(){return T(this.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{"capability.acceptsLastFrame"(e){e||(this.fileList=[],this.onSetLastFrameUrl())}},methods:{onExceed(){K.warning(this.$t(`seedance.message.uploadExceed`))},onError(){K.error(this.$t(`seedance.message.uploadError`))},onSetLastFrameUrl(){let e=this.urls?.[0],t=(this.$store.state.seedance?.config?.images||[]).filter(e=>e?.role!==`last_frame`);e&&t.push({url:e,role:`last_frame`}),this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,images:t.length>0?t:void 0})},async onSuccess(){this.onSetLastFrameUrl()},async onRemove(){this.onSetLastFrameUrl()}}}),kt={key:0,class:`relative`},At={class:`flex justify-between`},jt={class:`flex justify-start items-center`},Mt={class:`text-sm font-bold`};function Nt(e,r,s,c,l,f){let g=m(`info-icon`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`el-button`),b=m(`el-upload`);return e.capability.acceptsLastFrame?(d(),t(`div`,kt,[n(`div`,At,[n(`div`,jt,[n(`span`,Mt,u(e.$t(`seedance.name.lastFrame`)),1),o(g,{content:e.$t(`seedance.description.lastFrame`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):p(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+u(e.$t(`seedance.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])):p(``,!0)}var Pt=z(Ot,[[`render`,Nt],[`__scopeId`,`data-v-3a191e51`]]),Ft=r({name:`SeedanceServiceTierSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:Z},data(){return{options:[{value:le,label:this.$t(`seedance.serviceTier.default`)},{value:ie,label:this.$t(`seedance.serviceTier.flex`)}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.service_tier},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,service_tier:e})}}},mounted(){this.value||=ne}}),It={class:`field`},Lt={class:`label`},Rt={class:`box`},zt={class:`title font-bold`};function Bt(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,It,[n(`div`,Lt,[n(`div`,Rt,[n(`h2`,zt,u(r.$t(`seedance.name.serviceTier`)),1),o(g,{content:r.$t(`seedance.description.serviceTier`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`seedance.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Vt=z(Ft,[[`render`,Bt],[`__scopeId`,`data-v-cc938de2`]]),Ht=r({name:`SeedanceReturnLastFrameSwitch`,components:{ElSwitch:w,InfoIcon:Z},computed:{model(){return this.$store.state.seedance?.config?.model},isSupported(){return T(this.model).acceptsReturnLastFrame},value:{get(){return this.$store.state.seedance?.config?.return_last_frame},set(e){this.$store.commit(`seedance/setConfig`,{...this.$store.state.seedance?.config,return_last_frame:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=!1)}}),Ut={key:0,class:`field`},Wt={class:`label`},Gt={class:`box`},Kt={class:`title font-bold`},qt={class:`value`};function Jt(e,r,i,a,s,c){let l=m(`info-icon`),f=m(`el-switch`);return e.isSupported?(d(),t(`div`,Ut,[n(`div`,Wt,[n(`div`,Gt,[n(`h2`,Kt,u(e.$t(`seedance.name.returnLastFrame`)),1),o(l,{content:e.$t(`seedance.description.returnLastFrame`),class:`info`},null,8,[`content`])])]),n(`div`,qt,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,"inline-prompt":``,"active-text":e.$t(`seedance.button.on`),"inactive-text":e.$t(`seedance.button.off`)},null,8,[`modelValue`,`active-text`,`inactive-text`])])])):p(``,!0)}var Yt=z(Ht,[[`render`,Jt],[`__scopeId`,`data-v-edea5451`]]),Xt=r({name:`SeedanceSeedInput`,components:{ElInputNumber:C,InfoIcon:Z},computed:{value:{get(){let e=this.$store.state.seedance?.config?.seed;return typeof e==`number`?e:-1},set(e){let t={...this.$store.state.seedance?.config||{}};t.seed=typeof e==`number`&&Number.isInteger(e)?e:-1,this.$store.commit(`seedance/setConfig`,t)}}}}),Zt={class:`field`},Qt={class:`label`},$t={class:`box`},en={class:`title font-bold`},tn={class:`value`};function nn(e,r,i,a,s,c){let l=m(`info-icon`),f=m(`el-input-number`);return d(),t(`div`,Zt,[n(`div`,Qt,[n(`div`,$t,[n(`h2`,en,u(e.$t(`seedance.name.seed`)),1),o(l,{content:e.$t(`seedance.description.seed`),class:`info`},null,8,[`content`])])]),n(`div`,tn,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,min:-1,max:2147483647,step:1,size:`default`,"controls-position":`right`,class:`counter`},null,8,[`modelValue`])])])}var rn=r({name:`SeedanceConfigPanel`,components:{ElButton:g,FontAwesomeIcon:Y,PromptInput:Ce,ModelSelector:Ae,DurationSelector:Le,ResolutionSelector:Ke,RatioSelector:rt,GenerateAudioSwitch:dt,CameraFixedSwitch:yt,ServiceTierSelector:Vt,ReturnLastFrameSwitch:Yt,SeedInput:z(Xt,[[`render`,nn],[`__scopeId`,`data-v-685a9869`]]),FirstFrameImage:Dt,LastFrameImage:Pt,Consumption:ge},emits:[`generate`],computed:{config(){return this.$store.state.seedance?.config},consumption(){return V(this.config,this.service?.cost)},service(){return this.$store.state.seedance?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),an={class:`flex flex-col h-full`},on={class:`flex-1 overflow-y-auto p-5`},sn={class:`flex flex-col items-center justify-center px-5 pb-5`};function cn(e,r,a,s,c,l){let f=m(`prompt-input`),p=m(`model-selector`),g=m(`ratio-selector`),_=m(`resolution-selector`),v=m(`duration-selector`),y=m(`service-tier-selector`),b=m(`generate-audio-switch`),x=m(`camera-fixed-switch`),S=m(`return-last-frame-switch`),C=m(`seed-input`),w=m(`first-frame-image`),T=m(`last-frame-image`),E=m(`consumption`),D=m(`font-awesome-icon`),O=m(`el-button`);return d(),t(`div`,an,[n(`div`,on,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),o(S,{class:`mb-4`}),o(C,{class:`mb-4`}),o(w,{class:`mb-2`}),o(T,{class:`mb-2`})]),n(`div`,sn,[o(E,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(O,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(D,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`seedance.button.generate`)),1)]),_:1},8,[`onClick`])])])}var ln=z(rn,[[`render`,cn]]),un=r({name:`SeedanceTaskPreview`,components:{ElImage:x,CopyToClipboard:ue,FontAwesomeIcon:Y,ElAlert:S,VideoPlayer:be,ElTooltip:b,ElButton:g,ImageWrapper:ve,ImagePreview:X,ApiCodeButton:_e},props:{modelValue:{type:Object,required:!0}},data(){return{seedanceLogo:re}},computed:{video(){return this.modelValue?.response?.data},referenceImages(){let e=this.modelValue?.request?.images;if(!Array.isArray(e))return[];let t=[],n=e.find(e=>e?.role===`first_frame`);n?.url&&t.push({url:n.url,name:`first-frame`});let r=e.find(e=>e?.role===`last_frame`);return r?.url&&t.push({url:r.url,name:`last-frame`}),e.forEach((e,n)=>{e?.url&&e.role!==`first_frame`&&e.role!==`last_frame`&&t.push({url:e.url,name:e.role||`image-${n}`})}),t}},methods:{onDownload(e){window.open(e,`_blank`)}}}),dn={class:`preview`},fn={class:`left`},pn={class:`main`},mn={class:`bot`},hn={class:`datetime`},gn={class:`info`},_n={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},vn={key:1,class:`prompt mt-2`},yn={key:0},bn={key:1},xn={key:0,class:l({content:!0})},Sn={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Cn={key:1,class:l({content:!0})},wn={key:0,class:`mb-4`},Tn={key:1,class:`mb-4`},En={key:2,class:l({operations:!0,"mt-2":!0,"mb-2":!0})},Dn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},On={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},kn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},An={key:0},jn={key:1},Mn={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Nn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Pn={key:5,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Fn={key:2,class:l({content:!0})},In={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ln={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Rn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},zn={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Bn={key:3,class:l({content:!0})},Vn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Hn={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Un(r,c,l,g,_,v){let y=m(`el-image`),b=m(`image-preview`),x=m(`font-awesome-icon`),S=m(`copy-to-clipboard`),C=m(`el-alert`),w=m(`video-player`),T=m(`image-wrapper`),E=m(`el-button`),D=m(`el-tooltip`),O=m(`api-code-button`);return d(),t(`div`,dn,[n(`div`,fn,[o(y,{src:r.seedanceLogo,class:`avatar`},null,8,[`src`])]),n(`div`,pn,[n(`div`,mn,[i(u(r.$t(`seedance.name.seedanceBot`))+` `,1),n(`span`,hn,u(r.$dayjs.format(``+new Date(parseFloat((r.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,gn,[r.referenceImages.length>0?(d(),t(`div`,_n,[(d(!0),t(s,null,e(r.referenceImages,(e,t)=>(d(),a(b,{key:t,url:e.url,name:e.name,closable:!1},null,8,[`url`,`name`]))),128))])):p(``,!0),r.modelValue?.request?.prompt?(d(),t(`p`,vn,[i(u(r.modelValue?.request?.prompt)+` `,1),r.modelValue?.response?r.video?.status===`processing`||r.video?.status===`pending`?(d(),t(`span`,bn,` - (`+u(r.$t(`seedance.status.processing`))+`) `,1)):p(``,!0):(d(),t(`span`,yn,` - (`+u(r.$t(`seedance.status.pending`))+`) `,1))])):p(``,!0)]),r.modelValue?.response?r.modelValue?.response?.success===!0?(d(),t(`div`,Cn,[r.video?.video_url?(d(),t(`div`,wn,[o(w,{src:r.video?.video_url},null,8,[`src`])])):p(``,!0),r.video?.last_frame_url?(d(),t(`div`,Tn,[o(T,{src:r.video?.last_frame_url,"raw-src":r.video?.last_frame_url},null,8,[`src`,`raw-src`])])):p(``,!0),r.video?.video_url?(d(),t(`div`,En,[o(D,{class:`box-item`,effect:`dark`,content:r.$t(`seedance.message.downloadVideo`),placement:`top-start`},{default:h(()=>[o(E,{type:`info`,size:`small`,class:`btn-action`,onClick:c[0]||=f(e=>r.onDownload(r.video?.video_url),[`stop`])},{default:h(()=>[i(u(r.$t(`seedance.button.download`)),1)]),_:1})]),_:1},8,[`content`]),o(O,{path:`/seedance/videos`,body:r.modelValue?.request},null,8,[`body`])])):p(``,!0),o(C,{closable:!1,class:`mt-2 success`},{default:h(()=>[r.modelValue?.request?.model?(d(),t(`p`,Dn,[o(x,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.model`))+`: `+u(r.modelValue?.request?.model),1)])):p(``,!0),r.video?.duration?(d(),t(`p`,On,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.duration`))+`: `+u(r.video?.duration)+`s `,1)])):p(``,!0),r.video?.resolution?(d(),t(`p`,kn,[o(x,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.resolution`))+`: `+u(r.video?.resolution)+` `,1),r.video?.ratio?(d(),t(`span`,An,` · `+u(r.video?.ratio),1)):p(``,!0),r.video?.framespersecond?(d(),t(`span`,jn,` · `+u(r.video?.framespersecond)+`fps`,1)):p(``,!0)])):p(``,!0),r.modelValue?.request?.generate_audio?(d(),t(`p`,Mn,[o(x,{icon:`fa-solid fa-volume-up`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.generateAudio`))+`: `+u(r.$t(`seedance.button.on`)),1)])):p(``,!0),n(`p`,Nn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.taskId`))+`: `+u(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.elapsed?(d(),t(`p`,$,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.elapsed`))+`: `+u(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):p(``,!0),r.modelValue?.response?.trace_id?(d(),t(`p`,Pn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.traceId`))+`: `+u(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):r.modelValue?.response?.success===!1?(d(),t(`div`,Fn,[o(C,{closable:!1,class:`failure`},{template:h(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.failure`)),1)]),default:h(()=>[n(`p`,In,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.taskId`))+`: `+u(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.response?.error?.message?(d(),t(`p`,Ln,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.failureReason`))+`: `+u(r.modelValue?.response?.error?.message)+` `,1),o(S,{content:r.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0),r.modelValue?.elapsed?(d(),t(`p`,Rn,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.elapsed`))+`: `+u(r.modelValue?.elapsed?.toFixed(2))+`s `,1)])):p(``,!0),r.modelValue?.response?.trace_id?(d(),t(`p`,zn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.traceId`))+`: `+u(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):(d(),t(`div`,Bn,[o(C,{closable:!1,class:`info`},{template:h(()=>[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.status`)),1)]),default:h(()=>[n(`p`,Vn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.taskId`))+`: `+u(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),r.modelValue?.response?.trace_id?(d(),t(`p`,Hn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.traceId`))+`: `+u(r.modelValue?.response?.trace_id)+` `,1),o(S,{content:r.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):(d(),t(`div`,xn,[o(C,{closable:!1,class:`info`},{template:h(()=>[o(x,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+u(r.$t(`seedance.status.pending`)),1)]),default:h(()=>[n(`p`,Sn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(r.$t(`seedance.name.taskId`))+`: `+u(r.modelValue?.id)+` `,1),o(S,{content:r.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var Wn=r({name:`SeedanceRecentPanel`,components:{TaskPreview:z(un,[[`render`,Un],[`__scopeId`,`data-v-8b7e10f0`]]),BotPlaceholder:de,NoTasks:he,ScrollList:fe},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.seedance?.tasks,items:this.$store.state.seedance?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Gn={key:0},Kn={key:2,class:`w-full h-full flex items-center justify-center`};function qn(n,r,i,c,l,u){let f=m(`bot-placeholder`),g=m(`task-preview`),_=m(`scroll-list`),v=m(`no-tasks`);return d(),t(s,null,[n.tasks?.items===void 0?(d(),t(`div`,Gn,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(d(),a(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:h(()=>[(d(!0),t(s,null,e(n.tasks?.items,e=>(d(),a(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):p(``,!0),n.tasks?.items?.length===0?(d(),t(`div`,Kn,[o(v)])):p(``,!0)],64)}var Jn=z(Wn,[[`render`,qn]]),Yn=P(`seedance`),Xn=r({name:`SeedanceIndex`,components:{ConfigPanel:ln,Layout:ye,RecentPanel:Jn},mixins:[R],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.seedance?.status?.getApplications===J.Request},tasksLoading(){return this.$store.state.seedance?.status?.getTasks===J.Request||this.fetchingTasks},credential(){return this.$store.state.seedance?.credential},config(){return this.$store.state.seedance?.config},tasks(){return this.$store.state.seedance?.tasks}},watch:{initialized:{async handler(e){e&&(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 pe({tasks: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(){await this.$store.dispatch(`seedance/getService`)},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch(`seedance/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!H(this.uploadTracker,e=>this.$t(e),e=>K.warning(e)))return;let e={...this.config||{}};if(typeof e?.prompt==`string`&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),Array.isArray(e?.images)){e.images=e.images.filter(e=>!!e?.url);let t=e.images.some(e=>e?.role===`first_frame`),n=e.images.some(e=>e?.role===`last_frame`);!t&&n&&(e.images=e.images.map(e=>e?.role===`last_frame`?{...e,role:`first_frame`}:e))}let t=Array.isArray(e?.images)&&e.images.length>0;if(!t&&`images`in e&&delete e.images,e?.model&&!ee[e.model]){K.warning(this.$t(`seedance.message.modelUnsupported`));return}let n=T(e?.model);if(n.requiresImage&&!t){K.warning(this.$t(`seedance.message.modelRequiresImage`));return}if(!n.acceptsImage&&t){K.warning(this.$t(`seedance.message.modelRejectsImage`));return}if(!n.acceptsText&&!t){K.warning(this.$t(`seedance.message.modelRequiresImage`));return}!n.acceptsAudio&&e.generate_audio&&(e.generate_audio=!1),!n.acceptsReturnLastFrame&&e.return_last_frame&&(e.return_last_frame=!1),!n.acceptsLastFrame&&t&&(e.images=e.images.filter(e=>e?.role!==`last_frame`));let r={...e,callback_url:Yn},i=this.credential?.token;if(!i){console.error(`no token specified`);return}K.info(this.$t(`seedance.message.startingTask`)),B(`seedance`,U.generate(r,{token:i})).then(()=>{K.success(this.$t(`seedance.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?K.error(this.$t(`seedance.message.usedUp`)):K.error(this.$t(`seedance.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Zn(e,t,n,r,i,s){let c=m(`config-panel`),l=m(`recent-panel`),u=m(`layout`);return d(),a(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Qn=z(Xn,[[`render`,Zn]]);export{Qn as default};
|