@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
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,tt as h,ut as g,v as _,x as v,y}from"./vendor-chart-mdwpew_o.js";import{t as b}from"./button-DWzbdjZV.js";import{F as x,X as S,Y as C,tt as w,z as T}from"./use-deprecated-CPfQu7wa.js";import{r as E,t as D}from"./select-DUQSa_dv.js";import{n as O,t as k}from"./tabs-CM47Khie.js";import{n as A,t as j}from"./form-D0aSFxDK.js";import{t as M}from"./upload-BbP3qVit.js";import{t as N}from"./tooltip-C3PYfh8V.js";import{t as P}from"./image-C1JYEL_e.js";import{t as F}from"./avatar-DJGt2zYX.js";import{t as I}from"./checkbox-hfJFSY6z.js";import{n as L,r as R,t as ee}from"./radio-IJQsW93X.js";import{n as te,t as ne}from"./collapse-Be4--o_J.js";import{t as z}from"./drawer-BvYPSxXh.js";import{n as B,r as re,t as V}from"./dropdown-ClFBH1K7.js";import{t as H}from"./input-number-CVD04ts_.js";import{t as ie}from"./popover-ziWceeAq.js";import{t as ae}from"./progress-Djs_fbqu.js";import{n as oe,t as se}from"./skeleton-Cn4UY-T8.js";import{t as ce}from"./slider-D-yKoeJR.js";import{t as le}from"./switch-DflwVy6G.js";import{Fn as ue,_i as U}from"./constants-BvG5EAGh.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-B7Ehq3WB.js";import{t as Z}from"./index.es-Cf1Nz1bg.js";import{n as ve}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Q,n as ye,r as be,t as xe}from"./pagination-CbQjtYtK.js";import{n as Se,t as Ce}from"./NoTasks-CrhfF4zj.js";import{t as we}from"./Consumption-D3EMWpgi.js";import{n as Te,r as $,t as Ee}from"./Player-2INZtHKM.js";var De=s({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(t,n,i,o,s,c){let l=f(`font-awesome-icon`),h=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,Oe,[r(`div`,ke,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,Ae,[e(t.$slots,`result`,{},void 0,!0)]),r(`div`,je,[e(t.$slots,`preview`,{},void 0,!0)]),g(a(h,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ne=W(De,[[`render`,Me],[`__scopeId`,`data-v-169b0449`]]),Pe=s({name:`TypeSelector`,components:{ElSelect:E,ElOption:D,ElSwitch:le},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||=ue}}),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(e,i,s,d,h,g){let _=f(`el-option`),y=f(`el-select`),b=f(`el-switch`);return u(),p(`div`,null,[r(`div`,Fe,[r(`div`,Ie,[r(`span`,Le,l(e.$t(`suno.name.model`)),1)]),a(y,{modelValue:e.model,"onUpdate:modelValue":i[0]||=t=>e.model=t,class:`w-full model-select`,size:`default`,placeholder:e.$t(`suno.placeholder.select`)},{default:m(()=>[(u(!0),p(v,null,c(e.options,e=>(u(),n(_,{key:e.value,label:e.label,value:e.value,class:t({"model-option-divider":e.dividerAfter})},{default:m(()=>[r(`div`,Re,[r(`div`,ze,[r(`span`,Be,l(e.label),1)]),r(`span`,Ve,l(e.desc),1)])]),_:2},1032,[`label`,`value`,`class`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),e.custom?(u(),p(`div`,He,[r(`span`,Ue,l(e.$t(`suno.name.instrumental`)),1),a(b,{modelValue:e.instrumental,"onUpdate:modelValue":i[1]||=t=>e.instrumental=t},null,8,[`modelValue`])])):o(``,!0)])}var Ge=W(Pe,[[`render`,We],[`__scopeId`,`data-v-16e4d6fc`]]),Ke=s({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,t,s,c,d,h){let g=f(`info-icon`),_=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-radio-button`),x=f(`el-radio-group`),S=f(`el-upload`),C=f(`el-tab-pane`),w=f(`el-tabs`),T=f(`el-dialog`);return u(),p(`div`,qe,[r(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`suno.name.referenceAudios`)),1),a(g,{content:e.$t(`suno.description.uploadAudios`)},null,8,[`content`])]),a(y,{round:``,type:`primary`,size:`small`,onClick:t[0]||=t=>e.dialogVisible=!0},{default:m(()=>[a(_,{icon:`fa-solid fa-plus`,class:`icon mr-1`}),i(` `+l(e.$t(`suno.button.addAudio`)),1)]),_:1})]),e.audioPreviewUrl?(u(),p(`div`,Ze,[r(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Qe)])):o(``,!0),e.hasUploadedAudio?(u(),p(`div`,$e,[a(x,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||=t=>e.uploadAction=t,size:`small`},{default:m(()=>[a(b,{value:`upload_extend`},{default:m(()=>[i(l(e.$t(`suno.button.extend`)),1)]),_:1}),a(b,{value:`upload_cover`},{default:m(()=>[i(l(e.$t(`suno.button.upload_cover`)),1)]),_:1})]),_:1},8,[`modelValue`])])):o(``,!0),a(T,{modelValue:e.dialogVisible,"onUpdate:modelValue":t[4]||=t=>e.dialogVisible=t,title:e.$t(`suno.name.addAudio`),width:`520px`,"close-on-click-modal":!1,"append-to-body":``},{default:m(()=>[a(w,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||=t=>e.activeTab=t,class:`add-audio-tabs`},{default:m(()=>[a(C,{name:`browse`,label:e.$t(`suno.tab.browse`)},{default:m(()=>[r(`div`,et,[a(S,{"file-list":e.fileList,"onUpdate:fileList":t[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:m(()=>[r(`div`,tt,[a(_,{icon:`fa-solid fa-upload`,class:`text-4xl text-gray-400 mb-3`}),r(`div`,nt,l(e.$t(`suno.description.dropAudioHere`)),1),r(`div`,rt,l(e.$t(`suno.description.audioFormats`)),1)])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])]),_:1},8,[`label`]),a(C,{name:`record`,label:e.$t(`suno.tab.record`)},{default:m(()=>[r(`div`,it,[r(`div`,at,[e.recording?(u(),p(`div`,ot,[t[5]||=r(`span`,{class:`recording-dot`},null,-1),r(`span`,st,l(e.formattedTime),1)])):e.recordedBlob?(u(),p(`div`,ct,[a(_,{icon:`fa-solid fa-check-circle`,class:`text-2xl mr-2`}),r(`span`,null,l(e.$t(`suno.message.recordingReady`))+` (`+l(e.formattedTime)+`)`,1)])):(u(),p(`div`,lt,`00:00`))]),e.recordedAudioUrl&&!e.recording?(u(),p(`div`,ut,[r(`audio`,{src:e.recordedAudioUrl,controls:``,class:`w-full`},null,8,dt)])):o(``,!0),r(`div`,ft,[!e.recording&&!e.recordedBlob?(u(),n(y,{key:0,type:`primary`,round:``,onClick:e.startRecording},{default:m(()=>[a(_,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.startRecord`)),1)]),_:1},8,[`onClick`])):o(``,!0),e.recording?(u(),n(y,{key:1,type:`danger`,round:``,onClick:e.stopRecording},{default:m(()=>[a(_,{icon:`fa-solid fa-stop`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.stopRecord`)),1)]),_:1},8,[`onClick`])):o(``,!0),e.recordedBlob&&!e.recording?(u(),p(v,{key:2},[a(y,{round:``,onClick:e.resetRecording},{default:m(()=>[a(_,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.reRecord`)),1)]),_:1},8,[`onClick`]),a(y,{type:`primary`,round:``,loading:e.uploadingRecord,onClick:e.uploadRecording},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.useRecording`)),1)]),_:1},8,[`loading`,`onClick`])],64)):o(``,!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=s({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(e,t,i,o,s,d){let h=f(`font-awesome-icon`),g=f(`prompt-textarea`);return u(),n(g,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||=t=>e.prompt=t,title:e.$t(`suno.name.songDescription`),info:e.$t(`suno.description.prompt`),placeholder:e.$t(`suno.placeholder.prompt`),"min-rows":5,"max-rows":14},{after:m(()=>[r(`div`,yt,[(u(!0),p(v,null,c(e.visibleTags,t=>(u(),p(`button`,{key:t.key,class:`inspo-tag`,onClick:n=>e.onTagClick(t)},l(t.label),9,bt))),128)),r(`button`,{class:`inspo-tag inspo-tag-refresh`,onClick:t[0]||=(...t)=>e.onRefreshTags&&e.onRefreshTags(...t)},[a(h,{icon:`fa-solid fa-arrows-rotate`})])])]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var St=W(vt,[[`render`,xt],[`__scopeId`,`data-v-58ffcd38`]]),Ct=s({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,t,s,c,d,h){let g=f(`info-icon`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-tooltip`),x=f(`el-input`),S=f(`el-dialog`);return u(),p(`div`,wt,[r(`div`,Tt,[r(`div`,Et,[r(`span`,Dt,l(e.$t(`suno.name.lyrics`)),1),a(g,{content:e.$t(`suno.description.lyrics`)},null,8,[`content`])]),r(`div`,Ot,[e.lyricHistory.length>0?(u(),n(b,{key:0,content:e.$t(`suno.button.undo`),placement:`top`},{default:m(()=>[a(y,{size:`small`,circle:``,onClick:e.onUndo},{default:m(()=>[a(v,{icon:`fa-solid fa-rotate-left`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):o(``,!0),e.lyric?(u(),n(b,{key:1,content:e.$t(`suno.button.clear_lyrics`),placement:`top`},{default:m(()=>[a(y,{size:`small`,circle:``,onClick:e.onClear},{default:m(()=>[a(v,{icon:`fa-solid fa-eraser`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):o(``,!0),a(b,{content:e.$t(`suno.button.expand_lyrics`),placement:`top`},{default:m(()=>[a(y,{size:`small`,circle:``,onClick:t[0]||=t=>e.expanded=!0},{default:m(()=>[a(v,{icon:`fa-solid fa-expand`})]),_:1})]),_:1},8,[`content`]),e.config?.action===`extend`?o(``,!0):(u(),n(y,{key:2,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:m(()=>[e.generatingLyrics?o(``,!0):(u(),n(v,{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`]))])]),r(`div`,kt,[e.config?.action===`extend`?(u(),n(x,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[2]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(u(),n(x,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`])),r(`div`,At,l(e.lyric?.length||0)+`/5000`,1)]),e.lyric&&e.config?.action!==`extend`?(u(),p(`div`,jt,[a(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[3]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:_(e.onEnhanceLyrics,[`enter`])},{append:m(()=>[a(y,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:m(()=>[e.enhancingLyrics?o(``,!0):(u(),n(v,{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`])])):o(``,!0),a(S,{modelValue:e.expanded,"onUpdate:modelValue":t[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:m(()=>[r(`div`,Nt,[r(`div`,Pt,[e.lyricHistory.length>0?(u(),n(y,{key:0,size:`small`,onClick:e.onUndo},{default:m(()=>[a(v,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.undo`)),1)]),_:1},8,[`onClick`])):o(``,!0),e.lyric?(u(),n(y,{key:1,size:`small`,onClick:e.onClear},{default:m(()=>[a(v,{icon:`fa-solid fa-eraser`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_lyrics`)),1)]),_:1},8,[`onClick`])):o(``,!0),e.config?.action===`extend`?o(``,!0):(u(),n(y,{key:2,size:`small`,loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:m(()=>[e.generatingLyrics?o(``,!0):(u(),n(v,{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`]))]),a(y,{type:`primary`,onClick:t[6]||=t=>e.expanded=!1},{default:m(()=>[i(l(e.$t(`common.button.confirm`)),1)]),_:1})])]),default:m(()=>[a(x,{modelValue:e.lyric,"onUpdate:modelValue":t[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`?o(``,!0):(u(),p(`div`,Mt,[a(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[5]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:_(e.onEnhanceLyrics,[`enter`])},{append:m(()=>[a(y,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:m(()=>[e.enhancingLyrics?o(``,!0):(u(),n(v,{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=s({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(e,t,s,d,h,g){let _=f(`info-icon`),y=f(`font-awesome-icon`),b=f(`el-button`),x=f(`el-input`);return u(),p(`div`,Vt,[r(`div`,Ht,[r(`div`,Ut,[r(`span`,Wt,l(e.$t(`suno.name.style`)),1),a(_,{content:e.$t(`suno.description.style`)},null,8,[`content`])]),a(b,{size:`small`,loading:e.optimizing,round:``,onClick:e.onOptimizeStyle},{default:m(()=>[e.optimizing?o(``,!0):(u(),n(y,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.optimize_style`)),1)]),_:1},8,[`loading`,`onClick`])]),r(`div`,Gt,[a(x,{modelValue:e.style,"onUpdate:modelValue":t[0]||=t=>e.style=t,rows:2,type:`textarea`,placeholder:e.$t(`suno.placeholder.style`)},null,8,[`modelValue`,`placeholder`]),r(`div`,Kt,l(e.style?.length||0)+`/1000`,1)]),r(`div`,qt,[(u(!0),p(v,null,c(e.visibleTags,t=>(u(),p(`button`,{key:t,class:`style-tag`,onClick:n=>e.onTagClick(t)},l(t),9,Jt))),128)),r(`button`,{class:`style-tag style-tag-refresh`,onClick:t[1]||=(...t)=>e.onRefreshTags&&e.onRefreshTags(...t)},[a(y,{icon:`fa-solid fa-arrows-rotate`})])])])}var Xt=W(Bt,[[`render`,Yt],[`__scopeId`,`data-v-ddebb076`]]),Zt=s({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,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-input`);return u(),p(`div`,Qt,[r(`div`,$t,[r(`span`,en,l(e.$t(`suno.name.title`)),1),a(c,{content:e.$t(`suno.description.title`)},null,8,[`content`])]),a(d,{modelValue:e.title,"onUpdate:modelValue":t[0]||=t=>e.title=t,placeholder:e.$t(`suno.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var nn=W(Zt,[[`render`,tn]]),rn=s({name:`ExtendFromInput`,components:{ElImage:P,ElIcon:w,ElInputNumber:H,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,t,n,i,s,c){let d=f(`el-input-number`),_=f(`el-image`),v=f(`video-pause`),y=f(`el-icon`),b=f(`video-play`),x=h(`loading`);return u(),p(`div`,an,[r(`div`,on,[r(`h2`,sn,l(e.$t(`suno.name.extend`)),1),r(`div`,cn,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[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`])])]),r(`div`,ln,[e.audio?(u(),p(`div`,{key:0,class:`audio`,onClick:t[3]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,un,[a(_,{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(),p(`div`,{key:0,class:`overlay`,onClick:t[1]||=t=>e.onPause(e.audio)},[a(y,null,{default:m(()=>[a(v)]),_:1})])):o(``,!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(),p(`div`,{key:1,class:`overlay`,onClick:t[2]||=t=>e.onPlay(e.audio)},[a(y,null,{default:m(()=>[a(b)]),_:1})])):o(``,!0),e.audio?.duration?(u(),p(`div`,dn,l(e.useFormatDuring(e.audio?.duration)),1)):o(``,!0)])),[[x,!e.audio?.audio_url]]),r(`div`,fn,[r(`h2`,pn,l(e.audio?.title),1),r(`p`,mn,l(e.audio?.style),1)])])):o(``,!0)])])}var gn=W(rn,[[`render`,hn],[`__scopeId`,`data-v-bcce4821`]]),_n=s({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,t,n,i,s,c){let d=f(`el-image`),_=f(`video-pause`),v=f(`el-icon`),y=f(`video-play`),b=h(`loading`);return u(),p(`div`,vn,[r(`div`,yn,[r(`h2`,bn,l(e.$t(`suno.name.cover`)),1)]),r(`div`,xn,[e.audio?(u(),p(`div`,{key:0,class:`audio`,onClick:t[2]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,Sn,[a(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(),p(`div`,{key:0,class:`overlay`,onClick:t[0]||=t=>e.onPause(e.audio)},[a(v,null,{default:m(()=>[a(_)]),_:1})])):o(``,!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(),p(`div`,{key:1,class:`overlay`,onClick:t[1]||=t=>e.onPlay(e.audio)},[a(v,null,{default:m(()=>[a(y)]),_:1})])):o(``,!0),e.audio?.duration?(u(),p(`div`,Cn,l(e.useFormatDuring(e.audio?.duration)),1)):o(``,!0)])),[[b,!e.audio?.audio_url]]),r(`div`,wn,[r(`h2`,Tn,l(e.audio?.title),1),r(`p`,En,l(e.audio?.style),1)])])):o(``,!0)])])}var On=W(_n,[[`render`,Dn],[`__scopeId`,`data-v-06640216`]]),kn=s({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,t,n,o,s,c){let d=f(`info-icon`),h=f(`el-radio-button`),g=f(`el-radio-group`);return u(),p(`div`,null,[r(`div`,An,[r(`span`,jn,l(e.$t(`suno.name.vocalGender`)),1),a(d,{content:e.$t(`suno.description.vocalGender`)},null,8,[`content`])]),a(g,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||=t=>e.vocalGender=t,size:`small`},{default:m(()=>[a(h,{value:``},{default:m(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),a(h,{value:`f`},{default:m(()=>[i(l(e.$t(`suno.gender.female`)),1)]),_:1}),a(h,{value:`m`},{default:m(()=>[i(l(e.$t(`suno.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Nn=W(kn,[[`render`,Mn]]),Pn=s({name:`AdvancedParams`,components:{ElCollapse:ne,ElCollapseItem:te,ElInput:G,ElSlider:ce,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,t,s,c,d,h){let g=f(`el-input`),_=f(`el-slider`),v=f(`el-radio-button`),y=f(`el-radio-group`),b=f(`el-collapse-item`),x=f(`el-collapse`);return u(),n(x,{modelValue:e.activeNames,"onUpdate:modelValue":t[7]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:m(()=>[a(b,{title:e.$t(`suno.name.advancedParams`),name:`advanced`},{default:m(()=>[e.config?.custom?(u(),p(`div`,Fn,[r(`div`,In,[r(`span`,Ln,l(e.$t(`suno.name.styleNegative`)),1)]),a(g,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`suno.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):o(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),p(`div`,Rn,[r(`div`,zn,[r(`span`,Bn,l(e.$t(`suno.name.lyricPrompt`)),1)]),a(g,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):o(``,!0),e.config?.custom?(u(),p(`div`,Vn,[r(`div`,Hn,[r(`span`,Un,l(e.$t(`suno.name.weirdness`)),1),r(`span`,Wn,l(e.weirdness??0),1)]),a(_,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):o(``,!0),e.config?.custom?(u(),p(`div`,Gn,[r(`div`,Kn,[r(`span`,qn,l(e.$t(`suno.name.styleInfluence`)),1),r(`span`,Jn,l(e.styleInfluence??.5),1)]),a(_,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||=t=>e.styleInfluence=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):o(``,!0),e.isV5OrAbove?(u(),p(`div`,Yn,[r(`div`,Xn,[r(`span`,Zn,l(e.$t(`suno.name.variationCategory`)),1)]),a(y,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||=t=>e.variationCategory=t,size:`small`},{default:m(()=>[a(v,{value:``},{default:m(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),a(v,{value:`high`},{default:m(()=>[i(l(e.$t(`suno.variation.high`)),1)]),_:1}),a(v,{value:`low`},{default:m(()=>[i(l(e.$t(`suno.variation.low`)),1)]),_:1})]),_:1},8,[`modelValue`])])):o(``,!0),e.config?.action===`cover`?(u(),p(`div`,Qn,[r(`div`,$n,[r(`span`,er,l(e.$t(`suno.name.audioWeight`)),1),r(`span`,tr,l(e.audioWeight??.5),1)]),a(_,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||=t=>e.audioWeight=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):o(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),p(`div`,nr,[r(`div`,rr,[r(`span`,ir,l(e.$t(`suno.name.lyricsMode`)),1)]),a(y,{modelValue:e.lyricsMode,"onUpdate:modelValue":t[6]||=t=>e.lyricsMode=t,size:`small`},{default:m(()=>[a(v,{value:`manual`},{default:m(()=>[i(l(e.$t(`suno.lyricsMode.manual`)),1)]),_:1}),a(v,{value:`auto`},{default:m(()=>[i(l(e.$t(`suno.lyricsMode.auto`)),1)]),_:1})]),_:1},8,[`modelValue`])])):o(``,!0)]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var or=W(Pn,[[`render`,ar],[`__scopeId`,`data-v-363599d3`]]),sr=s({name:`ReplaceSectionInput`,components:{ElInputNumber:H,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,t,n,i,s,c){let d=f(`info-icon`),m=f(`el-image`),_=f(`el-input-number`),v=h(`loading`);return u(),p(`div`,cr,[r(`div`,lr,[r(`h2`,ur,l(e.$t(`suno.name.replaceSection`)),1),a(d,{content:e.$t(`suno.description.replaceSection`)},null,8,[`content`])]),e.audio?(u(),p(`div`,dr,[r(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,fr,[a(m,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),r(`div`,pr,[r(`h2`,mr,l(e.audio?.title),1),r(`p`,hr,l(e.audio?.style),1)])])])):o(``,!0),r(`div`,gr,[a(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[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`]),a(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[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=s({name:`OverpaintingInput`,components:{ElInputNumber:H,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,t,n,i,s,c){let d=f(`info-icon`),m=f(`el-image`),_=f(`el-input-number`),v=h(`loading`);return u(),p(`div`,br,[r(`div`,xr,[r(`h2`,Sr,l(e.$t(`suno.name.overpaintingRange`)),1),a(d,{content:e.$t(`suno.description.overpainting`)},null,8,[`content`])]),e.audio?(u(),p(`div`,Cr,[r(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,wr,[a(m,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),r(`div`,Tr,[r(`h2`,Er,l(e.audio?.title),1),r(`p`,Dr,l(e.audio?.style),1)])])])):o(``,!0),r(`div`,Or,[a(_,{modelValue:e.overpaintingStart,"onUpdate:modelValue":t[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`]),a(_,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":t[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=s({name:`UnderpaintingInput`,components:{ElInputNumber:H,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,t,n,i,s,c){let d=f(`info-icon`),m=f(`el-image`),_=f(`el-input-number`),v=h(`loading`);return u(),p(`div`,Mr,[r(`div`,Nr,[r(`h2`,Pr,l(e.$t(`suno.name.underpaintingRange`)),1),a(d,{content:e.$t(`suno.description.underpainting`)},null,8,[`content`])]),e.audio?(u(),p(`div`,Fr,[r(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,Ir,[a(m,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),r(`div`,Lr,[r(`h2`,Rr,l(e.audio?.title),1),r(`p`,zr,l(e.audio?.style),1)])])])):o(``,!0),r(`div`,Br,[a(_,{modelValue:e.underpaintingStart,"onUpdate:modelValue":t[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`]),a(_,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":t[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=s({name:`SamplesInput`,components:{ElInputNumber:H,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,t,n,i,s,c){let d=f(`info-icon`),m=f(`el-image`),_=f(`el-input-number`),v=h(`loading`);return u(),p(`div`,Wr,[r(`div`,Gr,[r(`h2`,Kr,l(e.$t(`suno.name.samplesRange`)),1),a(d,{content:e.$t(`suno.description.samples`)},null,8,[`content`])]),e.audio?(u(),p(`div`,qr,[r(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,Jr,[a(m,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),r(`div`,Yr,[r(`h2`,Xr,l(e.audio?.title),1),r(`p`,Zr,l(e.audio?.style),1)])])])):o(``,!0),r(`div`,Qr,[a(_,{modelValue:e.samplesStart,"onUpdate:modelValue":t[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`]),a(_,{modelValue:e.samplesEnd,"onUpdate:modelValue":t[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=s({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(e,t,s,d,_,y){let b=f(`info-icon`),x=f(`el-image`),S=f(`el-radio-button`),C=f(`el-radio-group`),w=h(`loading`);return u(),p(`div`,ri,[r(`div`,ii,[r(`h2`,ai,l(e.$t(`suno.name.adjustSpeed`)),1),a(b,{content:e.$t(`suno.description.adjustSpeed`)},null,8,[`content`])]),e.audio?(u(),p(`div`,oi,[r(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[g((u(),p(`div`,si,[a(x,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[w,!e.audio?.audio_url]]),r(`div`,ci,[r(`h2`,li,l(e.audio?.title),1),r(`p`,ui,l(e.audio?.style),1)])])])):o(``,!0),a(C,{modelValue:e.speed,"onUpdate:modelValue":t[1]||=t=>e.speed=t,size:`small`,class:`speed-group`},{default:m(()=>[(u(!0),p(v,null,c(e.options,e=>(u(),n(S,{key:e,value:e},{default:m(()=>[i(l(e)+`x`,1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])])}var fi=W(ni,[[`render`,di],[`__scopeId`,`data-v-ba834628`]]),pi=s({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,r,s,c,d){let p=f(`el-input`),h=f(`el-form-item`),g=f(`el-radio`),_=f(`el-radio-group`),v=f(`el-form`),y=f(`el-button`),b=f(`el-dialog`);return u(),n(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:m(()=>[a(y,{onClick:e.onClose},{default:m(()=>[i(l(e.$t(`common.button.cancel`)),1)]),_:1},8,[`onClick`]),a(y,{type:`primary`,loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:m(()=>[i(l(e.$t(`suno.voice.create`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])]),default:m(()=>[a(v,{"label-position":`top`,class:`voice-create-form`},{default:m(()=>[a(h,{label:e.$t(`suno.voice.name`)},{default:m(()=>[a(p,{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`]),a(h,{label:e.$t(`suno.voice.description`)},{default:m(()=>[a(p,{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`]),a(h,{label:e.$t(`suno.voice.sourceType`)},{default:m(()=>[a(_,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||=t=>e.sourceType=t,class:`w-full`},{default:m(()=>[a(g,{value:`song`},{default:m(()=>[i(l(e.$t(`suno.voice.fromSong`)),1)]),_:1}),a(g,{value:`upload`},{default:m(()=>[i(l(e.$t(`suno.voice.fromUpload`)),1)]),_:1})]),_:1},8,[`modelValue`])]),_:1},8,[`label`]),e.sourceType===`song`?(u(),n(h,{key:0,label:e.$t(`suno.voice.audioId`)},{default:m(()=>[a(p,{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`])):o(``,!0),e.sourceType===`upload`?(u(),n(h,{key:1,label:e.$t(`suno.voice.audioUrl`)},{default:m(()=>[a(p,{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`])):o(``,!0)]),_:1})]),_:1},8,[`modelValue`,`title`,`onClose`])}var hi=s({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(e,n,s,d,h,g){let _=f(`font-awesome-icon`),b=f(`el-button`),x=f(`el-tab-pane`),S=f(`el-tabs`),C=f(`loading`),w=f(`el-icon`),T=f(`el-tooltip`),E=f(`voice-create-dialog`);return u(),p(`div`,gi,[r(`div`,_i,[r(`span`,vi,l(e.$t(`suno.voice.title`)),1),a(b,{type:`primary`,size:`small`,onClick:n[0]||=t=>e.showCreateDialog=!0},{default:m(()=>[a(_,{icon:`fa-solid fa-plus`,class:`mr-1`}),i(` `+l(e.$t(`suno.voice.create`)),1)]),_:1})]),a(S,{modelValue:e.activeTab,"onUpdate:modelValue":n[1]||=t=>e.activeTab=t,class:`voice-tabs`,size:`small`},{default:m(()=>[a(x,{name:`all`,label:e.$t(`suno.voice.tabAll`)+` (`+(e.personas?.length||0)+`)`},null,8,[`label`]),a(x,{name:`favorites`,label:e.$t(`suno.voice.tabFavorites`)+` (`+e.favoritePersonas.length+`)`},null,8,[`label`])]),_:1},8,[`modelValue`]),e.loading?(u(),p(`div`,yi,[a(w,{class:`is-loading`},{default:m(()=>[a(C)]),_:1})])):e.visiblePersonas.length===0?(u(),p(`div`,bi,l(e.activeTab===`favorites`?e.$t(`suno.voice.emptyFavorites`):e.$t(`suno.voice.empty`)),1)):(u(),p(`div`,xi,[(u(!0),p(v,null,c(e.visiblePersonas,s=>(u(),p(`div`,{key:s.persona_id,class:t([`voice-item`,{active:e.selectedPersonaId===s.persona_id}]),onClick:t=>e.selectPersona(s)},[r(`div`,Ci,[r(`div`,wi,[a(_,{icon:s.source_type===`voice`?`fa-solid fa-microphone`:`fa-solid fa-music`,class:`mr-1.5 text-xs opacity-60`},null,8,[`icon`]),i(` `+l(s.name||s.persona_id),1)]),s.description?(u(),p(`div`,Ti,l(s.description),1)):o(``,!0)]),r(`div`,{class:`voice-actions`,onClick:n[2]||=y(()=>{},[`stop`])},[a(T,{content:e.isFavorite(s.persona_id)?e.$t(`suno.voice.unfavorite`):e.$t(`suno.voice.favorite`),placement:`top`},{default:m(()=>[a(b,{size:`small`,text:``,class:t({"voice-fav-active":e.isFavorite(s.persona_id)}),onClick:t=>e.onToggleFavorite(s)},{default:m(()=>[a(_,{icon:e.isFavorite(s.persona_id)?`fa-solid fa-star`:`fa-regular fa-star`},null,8,[`icon`])]),_:2},1032,[`class`,`onClick`])]),_:2},1032,[`content`]),a(b,{type:`danger`,size:`small`,text:``,loading:e.deletingId===s.persona_id,onClick:t=>e.onDelete(s)},{default:m(()=>[a(_,{icon:`fa-solid fa-trash`})]),_:1},8,[`loading`,`onClick`])])],10,Si))),128))])),a(E,{modelValue:e.showCreateDialog,"onUpdate:modelValue":n[3]||=t=>e.showCreateDialog=t,onCreated:e.onCreated},null,8,[`modelValue`,`onCreated`])])}var Di=s({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(e,t,s,d,h,g){let _=f(`info-icon`),y=f(`font-awesome-icon`),b=f(`el-button`),x=f(`el-option`),S=f(`el-select`),C=f(`voice-manager`),w=f(`el-drawer`);return u(),p(`div`,Oi,[r(`div`,ki,[r(`div`,Ai,[r(`span`,ji,l(e.$t(`suno.name.persona`)),1),a(_,{content:e.$t(`suno.description.persona`)},null,8,[`content`])]),a(b,{size:`small`,round:``,onClick:t[0]||=t=>e.showManager=!0},{default:m(()=>[a(y,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.voice.manage`)),1)]),_:1})]),a(S,{modelValue:e.personaId,"onUpdate:modelValue":t[1]||=t=>e.personaId=t,placeholder:e.$t(`suno.placeholder.personaId`),clearable:``,filterable:``,class:`w-full`},{default:m(()=>[(u(!0),p(v,null,c(e.personas,e=>(u(),n(x,{key:e.persona_id||``,value:e.persona_id||``,label:e.name||e.persona_id||``},{default:m(()=>[r(`div`,Mi,[r(`span`,null,l(e.name||e.persona_id),1),e.source_type?(u(),p(`span`,Ni,l(e.source_type),1)):o(``,!0)])]),_:2},1032,[`value`,`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`]),a(w,{modelValue:e.showManager,"onUpdate:modelValue":t[2]||=t=>e.showManager=t,title:e.$t(`suno.voice.title`),size:`380px`,direction:`rtl`},{default:m(()=>[a(C)]),_:1},8,[`modelValue`,`title`])])}var Fi=s({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,t,s,c,d,h){let g=f(`type-selector`),_=f(`upload-audio`),v=f(`prompt-input`),y=f(`extend-from-input`),b=f(`cover-from-input`),x=f(`replace-section-input`),S=f(`overpainting-input`),C=f(`underpainting-input`),w=f(`samples-input`),T=f(`adjust-speed-input`),E=f(`advanced-params`),D=f(`el-tab-pane`),O=f(`lyric-input`),k=f(`style-input`),A=f(`title-input`),j=f(`vocal-gender-selector`),M=f(`persona-input`),N=f(`el-tabs`),P=f(`consumption`),F=f(`font-awesome-icon`),I=f(`el-button`);return u(),p(`div`,Ii,[r(`div`,Li,[a(N,{modelValue:e.mode,"onUpdate:modelValue":t[0]||=t=>e.mode=t,class:`suno-mode-tabs`,stretch:``},{default:m(()=>[a(D,{label:e.$t(`suno.mode.simple`),name:`simple`},{default:m(()=>[r(`div`,Ri,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),e.config?.action===`extend`?(u(),n(y,{key:0,class:`mb-4`})):o(``,!0),e.config?.action===`cover`?(u(),n(b,{key:1,class:`mb-4`})):o(``,!0),e.config?.action===`replace_section`?(u(),n(x,{key:2,class:`mb-4`})):o(``,!0),e.config?.action===`overpainting`?(u(),n(S,{key:3,class:`mb-4`})):o(``,!0),e.config?.action===`underpainting`?(u(),n(C,{key:4,class:`mb-4`})):o(``,!0),e.config?.action===`samples`?(u(),n(w,{key:5,class:`mb-4`})):o(``,!0),e.config?.action===`adjust_speed`?(u(),n(T,{key:6,class:`mb-4`})):o(``,!0),a(E,{class:`mb-4`})])]),_:1},8,[`label`]),a(D,{label:e.$t(`suno.mode.custom`),name:`custom`},{default:m(()=>[r(`div`,zi,[a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),e.config?.instrumental?o(``,!0):(u(),n(O,{key:0,class:`mb-4`})),a(k,{class:`mb-4`}),a(A,{class:`mb-4`}),!e.config?.instrumental&&e.supportsVocalGender?(u(),n(j,{key:1,class:`mb-4`})):o(``,!0),e.supportsPersona?(u(),n(M,{key:2,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(y,{key:3,class:`mb-4`})):o(``,!0),e.config?.action===`cover`?(u(),n(b,{key:4,class:`mb-4`})):o(``,!0),e.config?.action===`replace_section`?(u(),n(x,{key:5,class:`mb-4`})):o(``,!0),e.config?.action===`overpainting`?(u(),n(S,{key:6,class:`mb-4`})):o(``,!0),e.config?.action===`underpainting`?(u(),n(C,{key:7,class:`mb-4`})):o(``,!0),e.config?.action===`samples`?(u(),n(w,{key:8,class:`mb-4`})):o(``,!0),e.config?.action===`adjust_speed`?(u(),n(T,{key:9,class:`mb-4`})):o(``,!0),a(E,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),r(`div`,Bi,[a(P,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),r(`div`,Vi,[a(I,{class:`flex-1`,onClick:e.onClearAll},{default:m(()=>[a(F,{icon:`fa-solid fa-broom`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_all`)),1)]),_:1},8,[`onClick`]),a(I,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:m(()=>[a(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=U(`suno`),Ki=s({name:`TaskPreview`,components:{ElImage:P,ElIcon:w,ElTooltip:N,FontAwesomeIcon:Z,VideoPlay:S,VideoPause:C,ElDropdown:V,ElDropdownMenu:re,ElDropdownItem:B,ElInput:G,ElProgress:ae,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(e,s,d,b,x,S){let C=f(`el-checkbox`),w=f(`el-image`),T=f(`video-pause`),E=f(`el-icon`),D=f(`video-play`),O=f(`el-input`),k=f(`font-awesome-icon`),A=f(`el-progress`),j=f(`el-tooltip`),M=f(`Loading`),N=f(`el-dropdown-item`),P=f(`el-dropdown-menu`),F=f(`el-dropdown`),I=f(`api-code-dialog`),L=h(`loading`);return u(),p(`div`,qi,[(u(!0),p(v,null,c(e.audios,c=>(u(),p(`div`,{key:c.id,class:t([`audio`,{"mashup-selected":e.isMashupSelected(c)}]),onClick:y(t=>e.onClick(c),[`stop`])},[e.isMashupMode&&c?.audio_url?(u(),p(`div`,{key:0,class:`mashup-check`,onClick:y(t=>e.onToggleMashup(c),[`stop`])},[a(C,{"model-value":e.isMashupSelected(c),onClick:s[0]||=y(()=>{},[`stop`])},null,8,[`model-value`])],8,Yi)):o(``,!0),g((u(),p(`div`,Xi,[a(w,{src:c?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),c?.audio_url&&e.$store.state?.suno?.audio?.id===c.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),p(`div`,{key:0,class:`overlay`,onClick:y(t=>e.onPause(c),[`stop`])},[a(E,null,{default:m(()=>[a(T)]),_:1})],8,Zi)):o(``,!0),c?.audio_url&&(e.$store.state?.suno?.audio?.id!==c.id||e.$store.state?.suno?.audio?.id===c.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),p(`div`,{key:1,class:`overlay`,onClick:y(t=>e.onPlay(c),[`stop`])},[a(E,null,{default:m(()=>[a(D)]),_:1})],8,Qi)):o(``,!0),c?.duration?(u(),p(`div`,$i,l(e.useFormatDuring(c?.duration)),1)):o(``,!0)])),[[L,!c?.audio_url]]),r(`div`,ea,[e.editingAudioId===c.id?(u(),p(`div`,{key:0,class:`title-edit`,onClick:s[2]||=y(()=>{},[`stop`])},[a(O,{ref_for:!0,ref:`titleInput`,modelValue:e.editingTitle,"onUpdate:modelValue":s[1]||=t=>e.editingTitle=t,size:`small`,onKeyup:[_(t=>e.onSaveTitleEdit(c),[`enter`]),_(e.onCancelTitleEdit,[`escape`])],onBlur:t=>e.onSaveTitleEdit(c)},null,8,[`modelValue`,`onKeyup`,`onBlur`])])):(u(),p(`div`,ta,[r(`h2`,na,l(c?.title),1),c?.audio_url?(u(),n(k,{key:0,icon:`fa-solid fa-pen`,class:`edit-icon`,onClick:y(t=>e.onStartTitleEdit(c),[`stop`])},null,8,[`onClick`])):o(``,!0)])),r(`p`,ra,l(c?.style),1),!c?.audio_url&&c?.progress!=null&&c?.progress<100?(u(),p(`div`,ia,[a(A,{percentage:Math.round(c.progress),"stroke-width":4,"show-text":!1,status:`warning`,class:`progress-bar`},null,8,[`percentage`]),r(`span`,aa,l(e.$t(`suno.name.generating`))+` `+l(Math.round(c.progress))+`%`,1)])):o(``,!0)]),r(`div`,oa,[a(F,null,{dropdown:m(()=>[a(P,null,{default:m(()=>[a(N,{disabled:e.isFetchingVideoUrl,onClick:t=>e.handleVideoDownload(c)},{default:m(()=>[r(`div`,ca,[e.isFetchingVideoUrl?(u(),n(E,{key:0,class:`is-loading mr-2`},{default:m(()=>[a(M)]),_:1})):o(``,!0),r(`span`,null,l(e.$t(`suno.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),c?.audio_url?(u(),n(N,{key:0,onClick:y(t=>e.onDownload(t,c?.audio_url),[`stop`])},{default:m(()=>[i(l(e.$t(`suno.button.download_audio`)),1)]),_:1},8,[`onClick`])):o(``,!0),a(N,{disabled:e.isFetchingWav,onClick:t=>e.handleWavDownload(c)},{default:m(()=>[r(`div`,la,[e.isFetchingWav?(u(),n(E,{key:0,class:`is-loading mr-2`},{default:m(()=>[a(M)]),_:1})):o(``,!0),r(`span`,null,l(e.$t(`suno.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`]),a(N,{disabled:e.isFetchingMidi,onClick:t=>e.handleMidiDownload(c)},{default:m(()=>[r(`div`,ua,[e.isFetchingMidi?(u(),n(E,{key:0,class:`is-loading mr-2`},{default:m(()=>[a(M)]),_:1})):o(``,!0),r(`span`,null,l(e.$t(`suno.button.download_midi`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:m(()=>[r(`span`,sa,[a(j,{effect:`dark`,content:e.$t(`suno.button.download`),placement:`top`},{default:m(()=>[c?.audio_url||c?.video_url?(u(),n(k,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):o(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),a(F,null,{dropdown:m(()=>[a(P,{class:`suno-action-menu`},{default:m(()=>[c?.audio_url?(u(),n(N,{key:0,onClick:y(t=>e.onExtend(t,c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-forward`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.extend`)),1)]),_:1},8,[`onClick`])):o(``,!0),a(N,{onClick:y(t=>e.onCover(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-music`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.cover_music`)),1)]),_:1},8,[`onClick`]),c?.id?(u(),n(N,{key:1,onClick:y(t=>e.onMashup(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-shuffle`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.mashup`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id&&c?.action===`extend`?(u(),n(N,{key:2,onClick:y(t=>e.onConcatMusic(c?.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-link`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.concat_music`)),1)]),_:1},8,[`onClick`])):o(``,!0),s[4]||=r(`div`,{class:`menu-divider`},null,-1),c?.id?(u(),n(N,{key:3,onClick:y(t=>e.onReplaceSection(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-scissors`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.replace_section`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:4,onClick:y(t=>e.onOverpainting(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-microphone`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.overpainting`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:5,onClick:y(t=>e.onUnderpainting(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-guitar`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.underpainting`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:6,onClick:y(t=>e.onSamples(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-drum`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.samples`)),1)]),_:1},8,[`onClick`])):o(``,!0),s[5]||=r(`div`,{class:`menu-divider`},null,-1),c.id?(u(),n(N,{key:7,onClick:y(t=>e.onGetStems(c.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-layer-group`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.get_stems`)),1)]),_:1},8,[`onClick`])):o(``,!0),c.id?(u(),n(N,{key:8,onClick:y(t=>e.onGetAllStems(c.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-bars-staggered`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.all_stems`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:9,onClick:y(t=>e.onRemaster(c.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-wand-magic-sparkles`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.remaster`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:10,onClick:y(t=>e.onExtractVocals(c.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-headphones`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.extract_vocals`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:11,onClick:y(t=>e.onArtistConsistency(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-palette`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.artist_consistency`)),1)]),_:1},8,[`onClick`])):o(``,!0),c?.id?(u(),n(N,{key:12,onClick:y(t=>e.onAdjustSpeed(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-gauge-high`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.adjust_speed`)),1)]),_:1},8,[`onClick`])):o(``,!0),s[6]||=r(`div`,{class:`menu-divider`},null,-1),a(N,{onClick:y(t=>e.onReusePrompt(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-rotate-left`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.reuse_prompt`)),1)]),_:1},8,[`onClick`]),c?.id?(u(),n(N,{key:13,onClick:y(t=>e.onGetTiming(c.id),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-clock`,class:`menu-icon`}),i(` `+l(e.$t(`suno.button.get_timing`)),1)]),_:1},8,[`onClick`])):o(``,!0),a(N,{onClick:y(e.onViewCode,[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-code`,class:`menu-icon`}),i(` `+l(e.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`]),s[7]||=r(`div`,{class:`menu-divider`},null,-1),c?.id?(u(),n(N,{key:14,class:`delete-item`,onClick:y(t=>e.onDelete(c),[`stop`])},{default:m(()=>[a(k,{icon:`fa-solid fa-trash`,class:`menu-icon delete-icon`}),i(` `+l(e.$t(`suno.button.delete`)),1)]),_:1},8,[`onClick`])):o(``,!0)]),_:2},1024)]),default:m(()=>[r(`span`,da,[a(j,{effect:`dark`,content:e.$t(`suno.button.more`),placement:`top`},{default:m(()=>[c?.audio_url||c?.video_url?(u(),n(k,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):o(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],10,Ji))),128)),a(I,{visible:e.apiCodeVisible,"onUpdate:visible":s[3]||=t=>e.apiCodeVisible=t,method:`POST`,path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.suno?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var pa=s({name:`RecentPanel`,components:{ElSkeletonItem:oe,ElSkeleton:se,ElInput:G,ElButton:b,ElDropdown:V,ElDropdownMenu:re,ElDropdownItem:B,ElPopover:ie,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(e,s,h,_,y,b){let x=f(`el-skeleton-item`),S=f(`el-skeleton`),C=f(`font-awesome-icon`),w=f(`el-input`),T=f(`el-button`),E=f(`el-dropdown-item`),D=f(`el-dropdown-menu`),O=f(`el-dropdown`),k=f(`el-radio-button`),A=f(`el-radio-group`),j=f(`el-option`),M=f(`el-select`),N=f(`el-popover`),P=f(`task-preview`),F=f(`scroll-list`),I=f(`no-tasks`),L=f(`player`);return u(),p(v,null,[e.tasks?.items===void 0?(u(),p(`div`,ma,[(u(),p(v,null,c(3,e=>r(`div`,{key:e,class:`flex`},[r(`div`,ha,[a(S,{animated:``},{template:m(()=>[a(x,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),r(`div`,ga,[a(S,{animated:``},{template:m(()=>[a(x,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),a(x,{variant:`text`})]),_:1})])])),64))])):(u(),p(v,{key:1},[e.tasks?.items?.length?(u(),p(`div`,_a,[a(w,{modelValue:e.searchQuery,"onUpdate:modelValue":s[0]||=t=>e.searchQuery=t,size:`small`,placeholder:e.$t(`suno.placeholder.searchSongs`),clearable:``,class:`task-search`},{prefix:m(()=>[a(C,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs`})]),_:1},8,[`modelValue`,`placeholder`]),a(O,{trigger:`click`,onCommand:e.onSortChange},{dropdown:m(()=>[a(D,null,{default:m(()=>[a(E,{command:`newest`,class:t({"is-active":e.sortBy===`newest`})},{default:m(()=>[i(l(e.$t(`suno.sort.newest`)),1)]),_:1},8,[`class`]),a(E,{command:`oldest`,class:t({"is-active":e.sortBy===`oldest`})},{default:m(()=>[i(l(e.$t(`suno.sort.oldest`)),1)]),_:1},8,[`class`])]),_:1})]),default:m(()=>[a(T,{size:`small`,class:`sort-btn`},{default:m(()=>[a(C,{icon:`fa-solid fa-arrow-down-wide-short`,class:`mr-1`}),i(` `+l(e.sortLabel),1)]),_:1})]),_:1},8,[`onCommand`]),a(N,{trigger:`click`,placement:`bottom-end`,width:260},{reference:m(()=>[a(T,{size:`small`,class:t([`filter-btn`,{"has-active-filter":e.activeFilterCount>0}])},{default:m(()=>[a(C,{icon:`fa-solid fa-filter`,class:`mr-1`}),i(` `+l(e.$t(`suno.filter.title`))+` `,1),e.activeFilterCount>0?(u(),p(`span`,va,l(e.activeFilterCount),1)):o(``,!0)]),_:1},8,[`class`])]),default:m(()=>[r(`div`,ya,[r(`div`,ba,[r(`div`,xa,l(e.$t(`suno.filter.type`)),1),a(A,{modelValue:e.filterType,"onUpdate:modelValue":s[1]||=t=>e.filterType=t,size:`small`},{default:m(()=>[a(k,{value:`all`},{default:m(()=>[i(l(e.$t(`suno.filter.typeAll`)),1)]),_:1}),a(k,{value:`vocal`},{default:m(()=>[i(l(e.$t(`suno.filter.typeVocal`)),1)]),_:1}),a(k,{value:`instrumental`},{default:m(()=>[i(l(e.$t(`suno.filter.typeInstrumental`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r(`div`,Sa,[r(`div`,Ca,l(e.$t(`suno.filter.duration`)),1),a(A,{modelValue:e.filterDuration,"onUpdate:modelValue":s[2]||=t=>e.filterDuration=t,size:`small`},{default:m(()=>[a(k,{value:`all`},{default:m(()=>[i(l(e.$t(`suno.filter.durationAll`)),1)]),_:1}),a(k,{value:`short`},{default:m(()=>[i(l(e.$t(`suno.filter.durationShort`)),1)]),_:1}),a(k,{value:`medium`},{default:m(()=>[i(l(e.$t(`suno.filter.durationMedium`)),1)]),_:1}),a(k,{value:`long`},{default:m(()=>[i(l(e.$t(`suno.filter.durationLong`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r(`div`,wa,[r(`div`,Ta,l(e.$t(`suno.filter.video`)),1),a(A,{modelValue:e.filterVideo,"onUpdate:modelValue":s[3]||=t=>e.filterVideo=t,size:`small`},{default:m(()=>[a(k,{value:`all`},{default:m(()=>[i(l(e.$t(`suno.filter.videoAll`)),1)]),_:1}),a(k,{value:`with`},{default:m(()=>[i(l(e.$t(`suno.filter.videoWith`)),1)]),_:1}),a(k,{value:`without`},{default:m(()=>[i(l(e.$t(`suno.filter.videoWithout`)),1)]),_:1})]),_:1},8,[`modelValue`])]),e.availableModels.length>0?(u(),p(`div`,Ea,[r(`div`,Da,l(e.$t(`suno.filter.model`)),1),a(M,{modelValue:e.filterModel,"onUpdate:modelValue":s[4]||=t=>e.filterModel=t,size:`small`,placeholder:e.$t(`suno.filter.modelAll`),clearable:``},{default:m(()=>[a(j,{label:e.$t(`suno.filter.modelAll`),value:`all`},null,8,[`label`]),(u(!0),p(v,null,c(e.availableModels,e=>(u(),n(j,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):o(``,!0),r(`div`,Oa,[a(T,{size:`small`,text:``,onClick:e.onResetFilters},{default:m(()=>[i(l(e.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])])]),_:1})])):o(``,!0),e.filteredTasks?.length>0?(u(),n(F,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:e.loading,onReachTop:s[5]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(v,null,c(e.filteredTasks,(e,t)=>(u(),n(P,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):e.searchQuery&&e.tasks?.items?.length>0?(u(),p(`div`,ka,[r(`p`,Aa,l(e.$t(`suno.message.noSearchResults`)),1)])):e.activeFilterCount>0&&e.tasks?.items?.length>0?(u(),p(`div`,ja,[r(`p`,Ma,l(e.$t(`suno.message.noFilterResults`)),1),a(T,{size:`small`,text:``,onClick:e.onResetFilters},{default:m(()=>[i(l(e.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])):e.tasks?.items?.length===0?(u(),p(`div`,Na,[a(I)])):o(``,!0)],64)),g(r(`div`,Pa,[a(L,{namespace:`suno`})],512),[[d,!!e.$store?.state?.suno?.audio?.object]])],64)}var Ia=W(pa,[[`render`,Fa],[`__scopeId`,`data-v-6ce376c9`]]),La=s({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,t,n,i,o,s){let c=f(`icon-picture`),d=f(`el-icon`),h=f(`el-image`),g=f(`el-avatar`);return e.audio?.object?(u(),p(`div`,Ra,[r(`div`,za,[a(h,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:m(()=>[r(`div`,Ba,[a(d,{class:`text-3xl`},{default:m(()=>[a(c)]),_:1})])]),_:1},8,[`src`]),r(`h2`,Va,l(e.audio?.title),1)]),r(`div`,Ha,[r(`div`,Ua,[a(g,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),r(`span`,null,l(e.audio?.title),1)]),r(`p`,Wa,l(e.audio?.style),1),r(`p`,Ga,l(e.$dayjs.format(e.audio?.created_at)),1),r(`div`,Ka,[r(`p`,null,l(e.audio?.lyric),1)])])])):(u(),p(`div`,qa))}var Ya=W(La,[[`render`,Ja]]),Xa=U(`suno`),Za=s({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,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`preview-panel`),p=f(`layout`);return u(),n(p,null,{config:m(()=>[a(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:m(()=>[a(d)]),_:1})}var $a=W(Za,[[`render`,Qa],[`__scopeId`,`data-v-b9beee12`]]);export{$a as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,Ht as ee,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-DUQSa_dv.js";import{t as b}from"./upload-BbP3qVit.js";import{t as x}from"./tooltip-C3PYfh8V.js";import{t as S}from"./image-C1JYEL_e.js";import{t as C}from"./alert-BJj7gY4q.js";import{t as w}from"./drawer-BvYPSxXh.js";import{t as T}from"./switch-DflwVy6G.js";import{_i as E,cr as D,dr as O,fr as k,gr as A,lr as te,mr as j,pr as M,ur as N,vr as P}from"./constants-BvG5EAGh.js";import{At as F,E as I,Fn as ne,Ir as L,Nt as R,Ot as z,Sr as B,fn as V,jt as H,kr as U,kt as W,yr as G}from"./index-B7Ehq3WB.js";import{t as K}from"./index.es-Cf1Nz1bg.js";import{t as q}from"./CopyToClipboard-C4Zr_RWu.js";import{t as J}from"./ImagePreview-CuVgQnIV.js";import{n as Y}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as X}from"./BotPlaceholder-DmDddO0B.js";import{i as Z,n as re,t as ie}from"./pagination-CbQjtYtK.js";import{n as ae,t as oe}from"./NoTasks-CrhfF4zj.js";import{t as se}from"./Consumption-D3EMWpgi.js";import{t as ce}from"./ApiCodeButton-Dyr9-U56.js";import{t as Q}from"./VideoPlayer-CxSJ4zS_.js";var le=s({name:`LayoutVeo`,components:{ElDrawer:w,ElButton:_,FontAwesomeIcon:K},mixins:[Y]}),ue={class:`main flex flex-row flex-1`},de={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},fe={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function pe(t,n,ee,i,o,s){let c=f(`font-awesome-icon`),l=f(`el-button`),g=f(`el-drawer`);return u(),p(`div`,ue,[r(`div`,de,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,fe,[e(t.$slots,`result`,{},void 0,!0)]),h(a(l,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(c,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(g,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var me=I(le,[[`render`,pe],[`__scopeId`,`data-v-12b82bc3`]]),he=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:`veo2`,label:`veo2`},{value:`veo2-fast`,label:`veo2-fast`},{value:`veo3`,label:`veo3`},{value:`veo3-fast`,label:`veo3-fast`},{value:`veo31-fast`,label:`veo31-fast`},{value:`veo31`,label:`veo31`},{value:`veo31-fast-ingredients`,label:`veo31-fast-ingredients`}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||=O}}),ge={class:`field`},_e={class:`title font-bold`};function ve(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ge,[r(`h2`,_e,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ye=I(he,[[`render`,ve],[`__scopeId`,`data-v-a59d89c9`]]),be=s({name:`ActionSelector`,components:{ElSelect:v,ElOption:y},data(){return{}},computed:{options(){return[{value:`text2video`,label:this.$t(`veo.button.action1`)},{value:`image2video`,label:this.$t(`veo.button.action2`)},{value:`ingredients2video`,label:this.$t(`veo.button.actionIngredients`)},{value:`upsample`,label:this.$t(`veo.button.actionUpsample`)},{value:`extend`,label:this.$t(`veo.button.actionExtend`)},{value:`reshoot`,label:this.$t(`veo.button.actionReshoot`)},{value:`object_insert`,label:this.$t(`veo.button.actionObjectInsert`)},{value:`object_remove`,label:this.$t(`veo.button.actionObjectRemove`)}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||=D}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,xe,[r(`h2`,Se,l(e.$t(`veo.name.action`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,Ce,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=I(be,[[`render`,we],[`__scopeId`,`data-v-f4d8785c`]]),Ee=s({name:`TranslationSelector`,components:{ElSwitch:T,InfoIcon:Z},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug(`set translation`,e),this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),De={class:`relative`},Oe={class:`flex justify-between`},ke={class:`flex justify-start items-center`},Ae={class:`text-sm font-bold`},je={class:`flex justify-end items-center`};function Me(e,t,n,ee,i,o){let s=f(`info-icon`),c=f(`el-switch`);return u(),p(`div`,De,[r(`div`,Oe,[r(`div`,ke,[r(`span`,Ae,l(e.$t(`veo.name.translation`)),1),a(s,{content:e.$t(`veo.description.translation`)},null,8,[`content`])]),r(`div`,je,[a(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var Ne=I(Ee,[[`render`,Me]]),Pe=s({name:`AspectRatioSelector`,data(){return{options:[{value:`16:9`,label:`16:9`,width:25,height:13},{value:`9:16`,label:`9:16`,width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug(`set aspect_ratio`,e),this.$store.commit(`veo/setConfig`,{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||=te}}),Fe={class:`text-sm font-bold mb-2 block`},Ie={class:`items`},Le=[`onClick`],Re={class:`name`};function ze(e,n,i,a,o,s){return u(),p(`div`,null,[r(`span`,Fe,l(e.$t(`veo.name.ratio`)),1),r(`div`,Ie,[(u(!0),p(g,null,c(e.options,(n,i)=>(u(),p(`div`,{key:i,class:t({active:e.active===i,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.label])},[r(`div`,{class:`rect`,style:ee({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Re,l(n.label),1)],10,Le))),128))])])}var Be=I(Pe,[[`render`,ze],[`__scopeId`,`data-v-28c472c4`]]),Ve=s({name:`VideoFromInput`,components:{VideoPlayer:Q},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:`1080p`}}}},computed:{config(){return this.$store.state.veo?.config}}}),He={class:`relative`},Ue={class:`flex mb-2`},We={class:`text-sm font-bold`};function Ge(e,t,ee,i,a,s){let c=f(`video-player`);return u(),p(`div`,He,[r(`div`,Ue,[r(`span`,We,l(e.$t(`veo.name.action3`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(c,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var Ke=I(Ve,[[`render`,Ge]]),qe=s({name:`VideoIdInput`,components:{ElInput:L},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,video_id:e})}}}}),Je={class:`field`},Ye={class:`title font-bold`};function Xe(e,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,Je,[r(`h2`,Ye,l(e.$t(`veo.name.videoId`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.videoId`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var Ze=I(qe,[[`render`,Xe],[`__scopeId`,`data-v-6eba4026`]]),Qe=s({name:`StartEndImage`,components:{ElUpload:b,ElButton:_,InfoIcon:Z,FontAwesomeIcon:K,ImagePreview:J},mixins:[H,W],emits:[`change`],data(){return{fileList:[],uploadUrl:B()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||=void 0,this.onSetStartEndImageUrl()},methods:{onExceed(){U.warning(this.$t(`veo.message.uploadReferencesExceed`))},onError(){U.error(this.$t(`veo.message.uploadReferencesError`))},onSetStartEndImageUrl(){let e=this.urls;this.$store.commit(`veo/setConfig`,{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),$e={class:`relative`},et={class:`flex justify-between`},tt={class:`flex justify-start items-center`},nt={class:`text-sm font-bold`};function rt(e,t,ee,s,c,d){let h=f(`info-icon`),g=f(`image-preview`),_=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`);return u(),p(`div`,$e,[r(`div`,et,[r(`div`,tt,[r(`span`,nt,l(e.$t(`veo.name.startEndImage`)),1),a(h,{content:e.$t(`veo.description.uploadStartEndImage`)},null,8,[`content`])])]),a(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:2,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(g,{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`])):o(``,!0)]),default:m(()=>[a(v,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`veo.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var it=I(Qe,[[`render`,rt],[`__scopeId`,`data-v-f9a79b4a`]]),at=s({name:`UpsampleActionSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return P.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||=M}}),ot={class:`field`},st={class:`title font-bold`};function ct(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ot,[r(`h2`,st,l(e.$t(`veo.name.upsampleAction`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var lt=I(at,[[`render`,ct],[`__scopeId`,`data-v-8b74a7ae`]]),ut=s({name:`ExtendModelSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return j.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,model:e})}}},mounted(){(!this.value||!j.includes(this.value))&&(this.value=N)}}),dt={class:`field`},ft={class:`title font-bold`};function pt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,dt,[r(`h2`,ft,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var mt=I(ut,[[`render`,pt],[`__scopeId`,`data-v-cc3f9355`]]),ht=s({name:`MotionTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return A.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||=k}}),gt={class:`field`},_t={class:`title font-bold`};function vt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,gt,[r(`h2`,_t,l(e.$t(`veo.name.motionType`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),filterable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var yt=I(ht,[[`render`,vt],[`__scopeId`,`data-v-3affff3c`]]),bt=s({name:`ImageMaskInput`,components:{ElInput:L},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,image_mask:e})}}}}),xt={class:`field`},St={class:`title font-bold`};function Ct(e,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,xt,[r(`h2`,St,l(e.$t(`veo.name.imageMask`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.imageMask`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var wt=I(bt,[[`render`,Ct],[`__scopeId`,`data-v-6cc27c68`]]),Tt=s({name:`PromptInput`,components:{PromptTextarea:ae},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Et(e,t,r,ee,i,a){let o=f(`prompt-textarea`);return u(),n(o,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`veo.name.prompt`),info:e.$t(`veo.description.prompt`),placeholder:e.$t(`veo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Dt=I(Tt,[[`render`,Et]]),Ot=[`upsample`,`extend`,`reshoot`,`object_insert`,`object_remove`,`get1080p`],kt=[`text2video`,`image2video`,`ingredients2video`],At=s({name:`ConfigPanel`,components:{ElButton:_,Consumption:se,FontAwesomeIcon:K,PromptInput:Dt,ModelSelector:ye,StartEndImage:it,ActionSelector:Te,VideoFromInput:Ke,VideoIdInput:Ze,UpsampleActionSelector:lt,ExtendModelSelector:mt,MotionTypeSelector:yt,ImageMaskInput:wt,TranslationSelector:Ne,AspectRatioSelector:Be},emits:[`generate`],computed:{config(){return this.$store.state.veo?.config},consumption(){return R(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Ot.includes(this.config?.action??``)},isGeneration(){return kt.includes(this.config?.action??``)}},methods:{onGenerate(){this.$emit(`generate`)}}}),jt={class:`flex flex-col h-full`},Mt={class:`flex-1 overflow-y-auto p-5`},Nt={class:`flex flex-col items-center justify-center px-5 pb-5`};function Pt(e,t,ee,s,c,d){let h=f(`action-selector`),_=f(`video-from-input`),v=f(`video-id-input`),y=f(`upsample-action-selector`),b=f(`extend-model-selector`),x=f(`prompt-input`),S=f(`motion-type-selector`),C=f(`image-mask-input`),w=f(`translation-selector`),T=f(`aspect-ratio-selector`),E=f(`model-selector`),D=f(`start-end-image`),O=f(`consumption`),k=f(`font-awesome-icon`),A=f(`el-button`);return u(),p(`div`,jt,[r(`div`,Mt,[a(h,{class:`mb-4`}),e.isPostProcessing?(u(),p(g,{key:0},[e.config?.video_url?(u(),n(_,{key:0,class:`mb-4`})):o(``,!0),a(v,{class:`mb-4`})],64)):o(``,!0),e.config?.action===`upsample`?(u(),n(y,{key:1,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(b,{key:2,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(x,{key:3,class:`mb-4`})):o(``,!0),e.config?.action===`reshoot`?(u(),n(S,{key:4,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`?(u(),n(x,{key:5,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`||e.config?.action===`object_remove`?(u(),n(C,{key:6,class:`mb-4`})):o(``,!0),e.config?.action===`object_remove`?(u(),n(x,{key:7,class:`mb-4`})):o(``,!0),e.isGeneration?(u(),p(g,{key:8},[a(w,{class:`mb-4`}),a(T,{class:`mb-4`}),a(x,{class:`mb-4`}),e.config?.action===`ingredients2video`?o(``,!0):(u(),n(E,{key:0,class:`mb-4`})),e.config?.action===`image2video`||e.config?.action===`ingredients2video`?(u(),n(D,{key:1,class:`mb-2`})):o(``,!0)],64)):o(``,!0)]),r(`div`,Nt,[a(O,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(A,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(k,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`veo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Ft=I(At,[[`render`,Pt]]),It=s({name:`TaskPreview`,components:{ElImage:S,CopyToClipboard:q,FontAwesomeIcon:K,ElAlert:C,VideoPlayer:Q,ElTooltip:x,ElButton:_,ApiCodeButton:ce},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,t,n,r){console.debug(`seed config from preview`,{action:n,upsampleAction:r,response:t}),this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,action:n,video_id:t?.data?.[0]?.id,video_url:t?.data?.[0]?.video_url,...r?{upsample_action:r}:{}})},onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenVideo(e){window.open(e,`_blank`)}}}),Lt={class:`preview`},Rt={class:`left`},zt={class:`main`},Bt={class:`bot`},Vt={class:`datetime`},Ht={class:`info`},Ut={key:0,class:`prompt mt-2`},Wt={key:0},Gt={key:1},Kt={key:0,class:t({content:!0,failed:!0})},qt={key:0,class:`mb-4`},Jt={key:1,class:t({operations:!0,"mt-2":!0})},Yt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Xt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Zt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Qt={key:1,class:t({content:!0})},$t={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},en={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},tn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},nn={key:2,class:t({content:!0})},rn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},an={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function on(e,t,ee,s,c,d){let h=f(`el-image`),g=f(`video-player`),_=f(`el-button`),v=f(`el-tooltip`),y=f(`api-code-button`),b=f(`font-awesome-icon`),x=f(`copy-to-clipboard`),S=f(`el-alert`);return u(),p(`div`,Lt,[r(`div`,Rt,[a(h,{src:`https://cdn.acedata.cloud/8nxyy9.jpg`,class:`avatar`})]),r(`div`,zt,[r(`div`,Bt,[i(l(e.$t(`veo.name.veoBot`))+` `,1),r(`span`,Vt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Ht,[e.modelValue?.request?.prompt?(u(),p(`p`,Ut,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,Wt,` - (`+l(e.$t(`veo.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`running`?(u(),p(`span`,Gt,` - (`+l(e.$t(`veo.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(u(),p(`div`,Kt,[e.modelValue?.response?.data[0]?.video_url?(u(),p(`div`,qt,[a(g,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response.success?(u(),p(`div`,Jt,[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`1080p`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample1080p`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:1,type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`4k`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample4k`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:2,type:`info`,size:`small`,class:`btn-action`,onClick:t[2]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`gif`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsampleGif`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:3,type:`info`,size:`small`,class:`btn-action`,onClick:t[3]||=t=>e.onPickAction(t,e.modelValue?.response,`extend`)},{default:m(()=>[i(l(e.$t(`veo.button.actionExtend`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:4,type:`info`,size:`small`,class:`btn-action`,onClick:t[4]||=t=>e.onPickAction(t,e.modelValue?.response,`reshoot`)},{default:m(()=>[i(l(e.$t(`veo.button.actionReshoot`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:5,type:`info`,size:`small`,class:`btn-action`,onClick:t[5]||=t=>e.onPickAction(t,e.modelValue?.response,`object_insert`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectInsert`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:6,type:`info`,size:`small`,class:`btn-action`,onClick:t[6]||=t=>e.onPickAction(t,e.modelValue?.response,`object_remove`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectRemove`)),1)]),_:1})):o(``,!0),a(v,{class:`box-item`,effect:`dark`,content:e.$t(`veo.message.downloadVideo`),placement:`top-start`},{default:m(()=>[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[7]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:m(()=>[i(l(e.$t(`veo.button.download`)),1)]),_:1})):o(``,!0)]),_:1},8,[`content`]),a(y,{path:`/veo/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(S,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Yt,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.model`))+`: `+l(e.modelValue?.request?.model),1)]),r(`p`,Xt,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Zt,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,Qt,[a(S,{closable:!1,class:`failure`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,$t,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,en,[a(b,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(x,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,tn,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===void 0?(u(),p(`div`,nn,[a(S,{closable:!1,class:`info`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,rn,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(u(),p(`p`,an,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0)])])}var sn=s({name:`RecentPanel`,components:{TaskPreview:I(It,[[`render`,on],[`__scopeId`,`data-v-9698fe5f`]]),NoTasks:oe,BotPlaceholder:X,ScrollList:re},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),cn={key:0},ln={key:2,class:`w-full h-full flex items-center justify-center`};function un(e,t,r,ee,i,s){let l=f(`bot-placeholder`),d=f(`task-preview`),h=f(`scroll-list`),_=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,cn,[a(l)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(h,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,(e,t)=>(u(),n(d,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,ln,[a(_)])):o(``,!0)],64)}var dn=I(sn,[[`render`,un]]),fn=E(`veo`),pn=s({name:`VeoIndex`,components:{ConfigPanel:Ft,Layout:me,RecentPanel:dn},mixins:[F],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===G.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,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 ie({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`veo/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`veo/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();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(`veo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!z(this.uploadTracker,e=>this.$t(e),e=>U.warning(e)))return;let e={...this.config,callback_url:fn},t=this.credential?.token;if(!t){console.error(`no token specified`);return}if(e.action===`image2video`&&!(e.image_urls&&e.image_urls.length>0)){U.warning(this.$t(`veo.message.imageRequired`));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,U.info(this.$t(`veo.message.startingTask`)),ne(`veo`,V.generate(e,{token:t})).then(()=>{U.success(this.$t(`veo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?U.error(this.$t(`veo.message.usedUp`)):U.error(this.$t(`veo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function mn(e,t,r,ee,i,o){let s=f(`config-panel`),c=f(`recent-panel`),l=f(`layout`);return u(),n(l,null,{config:m(()=>[a(s,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(c,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var hn=I(pn,[[`render`,mn]]);export{hn as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{n as y,r as b,t as x}from"./select-DUQSa_dv.js";import{t as S}from"./upload-BbP3qVit.js";import{t as C}from"./tooltip-C3PYfh8V.js";import{t as w}from"./image-C1JYEL_e.js";import{t as T}from"./alert-BJj7gY4q.js";import{t as E}from"./drawer-BvYPSxXh.js";import{t as D}from"./input-number-CVD04ts_.js";import{t as O}from"./switch-DflwVy6G.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-BvG5EAGh.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-B7Ehq3WB.js";import{t as q}from"./index.es-Cf1Nz1bg.js";import{t as J}from"./CopyToClipboard-C4Zr_RWu.js";import{t as Y}from"./ImagePreview-CuVgQnIV.js";import{n as ae}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as oe}from"./BotPlaceholder-DmDddO0B.js";import{i as X,n as se,t as ce}from"./pagination-CbQjtYtK.js";import{n as le,t as ue}from"./NoTasks-CrhfF4zj.js";import{t as de}from"./Consumption-D3EMWpgi.js";import{t as fe}from"./ApiCodeButton-Dyr9-U56.js";import{t as pe}from"./ImageWrapper-Bf4G9gSN.js";var me=s({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(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,he,[r(`div`,ge,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,_e,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var ye=R(me,[[`render`,ve],[`__scopeId`,`data-v-cca80bbd`]]),be=s({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,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(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=s({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(e,t,o,s,d,h){let _=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`),b=f(`info-icon`),x=f(`image-preview`);return u(),p(g,null,[r(`div`,we,[r(`h2`,Te,l(e.$t(`openaiimage.name.imageUrls`)),1),r(`div`,Ee,[r(`div`,De,[a(y,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,name:`file`,class:`value`,limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:m(()=>[a(v,{size:`small`,type:`primary`,round:``},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.button.uploadImageUrls`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-change`,`on-remove`,`headers`]),a(b,{content:e.$t(`openaiimage.description.imageUrls`),class:`ml-2`},null,8,[`content`])])])]),r(`div`,Oe,[(u(!0),p(g,null,c(e.fileList,(t,r)=>(u(),n(x,{key:t.uid||t?.response?.file_url||t.url||r,url:t.url||t?.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.onRemovePreview(r,t)},null,8,[`url`,`name`,`percentage`,`onRemove`]))),128))])],64)}var Ae=R(Ce,[[`render`,ke]]),je=s({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(e,t,i,o,s,d){let h=f(`info-icon`),_=f(`el-option`),v=f(`el-select`);return u(),p(`div`,Me,[r(`div`,Ne,[r(`div`,Pe,[r(`h2`,Fe,l(e.$t(`openaiimage.name.model`)),1),a(h,{content:e.modelDescription,class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(_,{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=s({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(e,t,i,s,d,h){let _=f(`info-icon`),v=f(`el-option`),y=f(`el-option-group`),b=f(`el-select`),x=f(`el-switch`),S=f(`el-input-number`);return u(),p(`div`,ze,[r(`div`,Be,[r(`div`,Ve,[r(`div`,He,[r(`h2`,Ue,l(e.$t(`openaiimage.name.size`)),1),a(_,{content:e.$t(`openaiimage.description.size`),class:`info`},null,8,[`content`])])]),a(b,{modelValue:e.presetValue,"onUpdate:modelValue":t[0]||=t=>e.presetValue=t,class:`value`,placeholder:e.$t(`openaiimage.placeholder.select`),disabled:e.useCustom},{default:m(()=>[a(v,{label:e.$t(`suno.gender.auto`),value:e.emptySizeValue},null,8,[`label`,`value`]),(u(!0),p(g,null,c(e.presetGroups,e=>(u(),n(y,{key:e.label,label:e.label},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(v,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:2},1032,[`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`disabled`])]),e.customSupported?(u(),p(g,{key:0},[r(`div`,We,[r(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,l(e.$t(`openaiimage.name.customSize`)),1),a(_,{content:e.$t(`openaiimage.description.customSize`),class:`info`},null,8,[`content`])])]),a(x,{modelValue:e.useCustom,"onUpdate:modelValue":t[1]||=t=>e.useCustom=t,class:`value-switch`},null,8,[`modelValue`])]),e.useCustom?(u(),p(`div`,Je,[r(`div`,Ye,[r(`span`,Xe,l(e.$t(`openaiimage.name.width`)),1),a(S,{modelValue:e.customWidth,"onUpdate:modelValue":t[2]||=t=>e.customWidth=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),r(`div`,Ze,[r(`span`,Qe,l(e.$t(`openaiimage.name.height`)),1),a(S,{modelValue:e.customHeight,"onUpdate:modelValue":t[3]||=t=>e.customHeight=t,class:`row-input`,min:e.minSide,max:e.maxSide,step:e.multiple,"step-strictly":!0,"controls-position":`right`},null,8,[`modelValue`,`min`,`max`,`step`])]),e.customError?(u(),p(`div`,$e,l(e.customError),1)):o(``,!0)])):o(``,!0)],64)):o(``,!0)])}var tt=s({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,t,n,o,s,c){let d=f(`model-selector`),h=f(`resolution-selector`),g=f(`prompt-input`),_=f(`image-urls-input`),v=f(`consumption`),y=f(`font-awesome-icon`),b=f(`el-button`);return u(),p(`div`,nt,[r(`div`,rt,[a(d,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`})]),r(`div`,it,[a(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(b,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(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=s({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:t({content:!0,failed:!0})},vt={class:`flex justify-start items-center gap-4 w-full overflow-x-auto`},yt={class:t({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:t({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:t({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(e,t,s,d,h,v){let y=f(`el-image`),b=f(`image-preview`),x=f(`image-wrapper`),S=f(`el-button`),C=f(`el-tooltip`),w=f(`api-code-button`),T=f(`font-awesome-icon`),E=f(`copy-to-clipboard`),D=f(`el-alert`);return u(),p(`div`,ct,[r(`div`,lt,[a(y,{src:e.OPENAIIMAGE_LOGO,class:`avatar`},null,8,[`src`])]),r(`div`,ut,[r(`div`,dt,[i(l(e.$t(`openaiimage.name.openaiimageBot`))+` `,1),r(`span`,ft,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,pt,[e.referenceImages.length>0?(u(),p(`div`,mt,[(u(!0),p(g,null,c(e.referenceImages,(e,t)=>(u(),n(b,{key:t,url:e,name:`image-${t+1}`,closable:!1},null,8,[`url`,`name`]))),128))])):o(``,!0),e.modelValue?.request?.prompt?(u(),p(`p`,ht,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,gt,` - (`+l(e.$t(`openaiimage.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,_t,[r(`div`,vt,[(u(!0),p(g,null,c(e.images,(e,t)=>(u(),n(x,{key:t,src:e?.image_url||e?.url||``,"raw-src":e?.image_url||e?.url||``},null,8,[`src`,`raw-src`]))),128))]),r(`div`,yt,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`common.button.edit`),placement:`top-start`},{default:m(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),[`stop`])},{default:m(()=>[i(l(e.$t(`common.button.edit`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:e.openaiimagePath,body:e.openaiimageCodeBody},null,8,[`path`,`body`])]),a(D,{closable:!1,class:`mt-2 success`},{default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,bt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,xt,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,St,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Ct,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,wt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Tt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),p(`div`,Et,[a(D,{closable:!1,class:`failure`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Dt,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ot,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,kt,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,At,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])]),r(`p`,jt,[a(T,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(E,{content:e.modelValue?.response?.error?.message,class:`btn-copy`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Mt,[a(T,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,Nt,[a(T,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(E,{content:e.modelValue?.response?.trace_id,class:`btn-copy`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),p(`div`,Pt,[a(D,{closable:!1,class:`info`},{template:m(()=>[a(T,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.failure`)),1)]),default:m(()=>[e.modelValue?.request?.model?(u(),p(`p`,Q,[a(T,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.modelValue?.request?.size?(u(),p(`p`,Ft,[a(T,{icon:`fa-solid fa-image`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.size`))+`: `+l(e.modelValue?.request?.size),1)])):o(``,!0),e.showTaskType?(u(),p(`p`,It,[a(T,{icon:`fa-solid fa-bolt`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.task`))+`: `+l(e.taskTypeLabel),1)])):o(``,!0),r(`p`,Lt,[a(T,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`openaiimage.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(E,{content:e.modelValue?.id,class:`btn-copy`},null,8,[`content`])])]),_:1})]))])])}var zt=s({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(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Bt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,e=>(u(),n(h,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Vt,[a(v)])):o(``,!0)],64)}var Ut=R(zt,[[`render`,Ht]]),$=j(`openaiimage`),Wt=s({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,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loading,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Kt=R(Wt,[[`render`,Gt]]);export{Kt as default};
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,v as m,x as h,y as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-DUQSa_dv.js";import{n as b,t as x}from"./tabs-CM47Khie.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-C1JYEL_e.js";import{t as w}from"./alert-BJj7gY4q.js";import{n as T,r as E}from"./radio-IJQsW93X.js";import{n as D,t as O}from"./collapse-Be4--o_J.js";import{t as k}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-CVD04ts_.js";import{t as te}from"./switch-DflwVy6G.js";import"./constants-BvG5EAGh.js";import{E as A,Ir as j,Nt as M,kr as N,yr as P}from"./index-B7Ehq3WB.js";import{t as F}from"./index.es-Cf1Nz1bg.js";import{t as I}from"./CopyToClipboard-C4Zr_RWu.js";import{t as L}from"./Consumption-D3EMWpgi.js";var R=o({name:`LayoutWebextrator`,components:{ElDrawer:k,ElButton:_,FontAwesomeIcon:F},data(){return{drawer:!1}}}),z={class:`main flex flex-row flex-1`},B={class:`config w-[340px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},V={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function H(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,z,[n(`div`,B,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,V,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-sliders`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var U=A(R,[[`render`,H],[`__scopeId`,`data-v-f9e97e78`]]),W=o({name:`ModeSelector`,components:{ElRadioGroup:E,ElRadioButton:T,FontAwesomeIcon:F},computed:{value:{get(){return this.$store.state.webextrator?.config?.mode},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,mode:e})}}}}),G={class:`field`},K={class:`title font-bold`};function q(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-radio-button`),g=u(`el-radio-group`);return l(),f(`div`,G,[n(`h2`,K,c(e.$t(`webextrator.name.mode`)),1),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value w-full`},{default:p(()=>[i(h,{label:`extract`,value:`extract`},{default:p(()=>[i(m,{icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.extract`)),1)]),_:1}),i(h,{label:`render`,value:`render`},{default:p(()=>[i(m,{icon:`fa-solid fa-globe`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.render`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var J=A(W,[[`render`,q],[`__scopeId`,`data-v-31e6c11d`]]),Y=o({name:`UrlInput`,components:{ElInput:j},emits:[`submit`],computed:{url:{get(){return this.$store.state.webextrator?.config?.url||``},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,url:e})}}},methods:{onEnter(){this.$emit(`submit`)}}}),X={class:`field`},Z={class:`title font-bold`};function Q(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,X,[n(`h2`,Z,c(e.$t(`webextrator.name.url`)),1),i(d,{modelValue:e.url,"onUpdate:modelValue":t[0]||=t=>e.url=t,type:`textarea`,rows:2,class:`prompt`,placeholder:e.$t(`webextrator.placeholder.url`),onKeydown:m(g(e.onEnter,[`exact`,`prevent`]),[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeydown`])])}var ne=A(Y,[[`render`,Q],[`__scopeId`,`data-v-18488009`]]),re=o({name:`ExpectedTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{value:{get(){return this.$store.state.webextrator?.config?.expected_type},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,expected_type:e})}}},mounted(){this.value||=`general`}}),ie={class:`field`},ae={class:`title font-bold`};function oe(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,ie,[n(`h2`,ae,c(e.$t(`webextrator.name.expectedType`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`general`,label:e.$t(`webextrator.expectedType.general`)},null,8,[`label`]),i(d,{value:`article`,label:e.$t(`webextrator.expectedType.article`)},null,8,[`label`]),i(d,{value:`product`,label:e.$t(`webextrator.expectedType.product`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var se=A(re,[[`render`,oe],[`__scopeId`,`data-v-3b572c49`]]),ce=o({name:`LlmToggle`,components:{ElSwitch:te,ElTooltip:S,FontAwesomeIcon:F},computed:{value:{get(){return!!this.$store.state.webextrator?.config?.enable_llm},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,enable_llm:e})}}}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-tooltip`),g=u(`el-switch`);return l(),f(`div`,le,[n(`h2`,ue,[r(c(e.$t(`webextrator.name.enableLlm`))+` `,1),i(h,{effect:`dark`,content:e.$t(`webextrator.description.enableLlm`),placement:`top`},{default:p(()=>[i(m,{icon:`fa-solid fa-circle-info`,class:`ml-1 text-[var(--el-text-color-secondary)] text-xs`})]),_:1},8,[`content`])]),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-32fa7c89`]]),pe=[`image`,`font`,`media`,`stylesheet`,`xhr`,`fetch`],me=o({name:`AdvancedOptions`,components:{ElCollapse:O,ElCollapseItem:D,ElInput:j,ElInputNumber:ee,ElSelect:v,ElOption:y},data(){return{active:[]}},computed:{resourceKinds(){return pe},waitUntil:{get(){return this.$store.state.webextrator?.config?.wait_until||`networkidle`},set(e){this.commit({wait_until:e})}},waitForSelector:{get(){return this.$store.state.webextrator?.config?.wait_for_selector||``},set(e){this.commit({wait_for_selector:e})}},timeout:{get(){return this.$store.state.webextrator?.config?.timeout??30},set(e){this.commit({timeout:e})}},delay:{get(){return this.$store.state.webextrator?.config?.delay??0},set(e){this.commit({delay:e})}},blockResources:{get(){return this.$store.state.webextrator?.config?.block_resources||[]},set(e){this.commit({block_resources:e})}}},methods:{commit(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,...e})}}}),he={class:`field`},ge={class:`sub-title`},_e={class:`field`},ve={class:`sub-title`},ye={class:`field`},be={class:`sub-title`},xe={class:`field`},Se={class:`sub-title`},Ce={class:`field`},we={class:`sub-title`};function Te(e,r,a,o,d,m){let g=u(`el-option`),_=u(`el-select`),v=u(`el-input`),y=u(`el-input-number`),b=u(`el-collapse-item`),x=u(`el-collapse`);return l(),t(x,{modelValue:e.active,"onUpdate:modelValue":r[5]||=t=>e.active=t,class:`advanced`},{default:p(()=>[i(b,{title:e.$t(`webextrator.name.advanced`),name:`advanced`},{default:p(()=>[n(`div`,he,[n(`h2`,ge,c(e.$t(`webextrator.name.waitUntil`)),1),i(_,{modelValue:e.waitUntil,"onUpdate:modelValue":r[0]||=t=>e.waitUntil=t,class:`value`},{default:p(()=>[i(g,{value:`networkidle`,label:e.$t(`webextrator.waitUntil.networkidle`)},null,8,[`label`]),i(g,{value:`load`,label:e.$t(`webextrator.waitUntil.load`)},null,8,[`label`]),i(g,{value:`domcontentloaded`,label:e.$t(`webextrator.waitUntil.domcontentloaded`)},null,8,[`label`]),i(g,{value:`commit`,label:e.$t(`webextrator.waitUntil.commit`)},null,8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,_e,[n(`h2`,ve,c(e.$t(`webextrator.name.waitForSelector`)),1),i(v,{modelValue:e.waitForSelector,"onUpdate:modelValue":r[1]||=t=>e.waitForSelector=t,placeholder:e.$t(`webextrator.placeholder.waitForSelector`)},null,8,[`modelValue`,`placeholder`])]),n(`div`,ye,[n(`h2`,be,c(e.$t(`webextrator.name.timeout`)),1),i(y,{modelValue:e.timeout,"onUpdate:modelValue":r[2]||=t=>e.timeout=t,min:1,max:120,step:5,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,xe,[n(`h2`,Se,c(e.$t(`webextrator.name.delay`)),1),i(y,{modelValue:e.delay,"onUpdate:modelValue":r[3]||=t=>e.delay=t,min:0,max:30,step:1,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,Ce,[n(`h2`,we,c(e.$t(`webextrator.name.blockResources`)),1),i(_,{modelValue:e.blockResources,"onUpdate:modelValue":r[4]||=t=>e.blockResources=t,multiple:``,"collapse-tags":``,placeholder:e.$t(`webextrator.placeholder.blockResources`),class:`w-full`},{default:p(()=>[(l(!0),f(h,null,s(e.resourceKinds,n=>(l(),t(g,{key:n,label:e.$t(`webextrator.blockResource.${n}`),value:n},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var Ee=o({name:`WebextratorConfigPanel`,components:{ElButton:_,FontAwesomeIcon:F,ModeSelector:J,UrlInput:ne,ExpectedTypeSelector:se,LlmToggle:fe,AdvancedOptions:A(me,[[`render`,Te],[`__scopeId`,`data-v-8f36d2df`]]),Consumption:L},emits:[`run`],computed:{config(){return this.$store.state.webextrator?.config},service(){return this.$store.state.webextrator?.service},consumption(){return M(this.config||{},this.service?.cost)},running(){return this.$store.state.webextrator?.status?.run===P.Request},isExtract(){return(this.config?.mode||`extract`)===`extract`},canRun(){let e=(this.config?.url||``).trim();return/^https?:\/\//i.test(e)}},methods:{onRun(){this.canRun&&this.$emit(`run`)}}}),De={class:`flex flex-col h-full`},Oe={class:`flex-1 overflow-y-auto p-5`},ke={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ae(e,t,o,s,d,m){let g=u(`mode-selector`),_=u(`url-input`),v=u(`expected-type-selector`),y=u(`llm-toggle`),b=u(`advanced-options`),x=u(`consumption`),S=u(`font-awesome-icon`),C=u(`el-button`);return l(),f(`div`,De,[n(`div`,Oe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`,onSubmit:e.onRun},null,8,[`onSubmit`]),e.isExtract?(l(),f(h,{key:0},[i(v,{class:`mb-4`}),i(y,{class:`mb-4`})],64)):a(``,!0),i(b,{class:`mb-4`})]),n(`div`,ke,[i(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(C,{type:`primary`,class:`w-full`,round:``,loading:e.running,disabled:!e.canRun,onClick:e.onRun},{default:p(()=>[i(S,{icon:`fa-solid fa-bolt`,class:`mr-2`}),r(` `+c(e.$t(e.isExtract?`webextrator.button.extract`:`webextrator.button.render`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])])}var je=A(Ee,[[`render`,Ae]]),Me=e=>!!e&&e.kind!==`render`,Ne=o({name:`WebextratorResultPanel`,components:{ElAlert:w,ElImage:C,ElTabs:b,ElTabPane:x,FontAwesomeIcon:F,CopyToClipboard:I},data(){return{activeTab:`markdown`}},computed:{response(){return this.$store.state.webextrator?.response},running(){return this.$store.state.webextrator?.status?.run===P.Request},data(){return this.response?.data},renderData(){return this.data&&this.data.kind===`render`?this.data:void 0},extractData(){return Me(this.data)?this.data:void 0},finalUrl(){let e=this.data;return e?.finalUrl||e?.final_url||e?.url},contentTypeLabel(){let e=this.data;return e?.contentType||e?.content_type||e?.expected_type},screenshotSrc(){let e=this.data?.screenshot;if(e)return e.startsWith(`data:`)||e.startsWith(`http`)?e:`data:image/png;base64,${e}`},markdown(){let e=this.data;return e?.markdown||e?.content||``},plainText(){return this.data?.text||``},html(){return this.data?.html||``},links(){return Array.isArray(this.data?.links)?this.data.links:[]},linksPlain(){return this.links.join(`
|
|
2
|
-
`)},images(){return Array.isArray(this.data?.images)?this.data.images:[]},structuredPretty(){return this.extractData?.structured?JSON.stringify(this.extractData.structured,null,2):``},rawPretty(){return this.response?JSON.stringify(this.response,null,2):``},errorMessage(){if(this.response?.success===!1){let e=this.response?.error;return e?.message||e?.code||this.$t(`webextrator.message.failed`)}}},watch:{response:{handler(){this.resetTab()},immediate:!0}},methods:{resetTab(){this.markdown?this.activeTab=`markdown`:this.extractData?.structured?this.activeTab=`structured`:this.plainText?this.activeTab=`text`:this.html?this.activeTab=`html`:this.activeTab=`raw`}}}),Pe={class:`h-full overflow-y-auto p-6`},Fe={key:0,class:`max-w-4xl mx-auto py-4`},Ie={class:`flex items-center gap-2 mb-3 text-[var(--el-color-primary)] text-sm`},Le={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Re={class:`text-base mb-1`},ze={class:`text-xs opacity-70`},Be={key:2,class:`max-w-4xl mx-auto py-4`},Ve={class:`text-xs whitespace-pre-wrap break-words`},He={key:3,class:`max-w-4xl mx-auto`},Ue={class:`mb-4`},We={class:`text-xl font-semibold leading-snug mb-1 break-words text-[var(--el-text-color-primary)]`},Ge={class:`flex flex-wrap items-center gap-x-3 gap-y-1 text-xs text-[var(--el-text-color-secondary)]`},Ke=[`href`],qe={key:1},Je={key:2},Ye={key:3},Xe={key:0,class:`mt-2 text-sm text-[var(--el-text-color-regular)] leading-relaxed line-clamp-3`},Ze={key:0,class:`mb-5`},Qe={class:`tab-toolbar`},$e={class:`content-block`},et={class:`tab-toolbar`},tt={class:`content-block`},$={class:`tab-toolbar`},nt={class:`content-block code`},rt={class:`tab-toolbar`},it={class:`links-list`},at=[`href`],ot={class:`grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-2`},st={class:`tab-toolbar`},ct={class:`content-block code`},lt={class:`tab-toolbar`},ut={class:`content-block code`};function dt(e,o,m,g,_,v){let y=u(`font-awesome-icon`),b=u(`el-alert`),x=u(`el-image`),S=u(`copy-to-clipboard`),C=u(`el-tab-pane`),w=u(`el-tabs`);return l(),f(`div`,Pe,[e.running?(l(),f(`div`,Fe,[n(`div`,Ie,[i(y,{icon:`fa-solid fa-circle-notch`,spin:``}),n(`span`,null,c(e.$t(`webextrator.message.running`)),1)]),o[1]||=d(`<div class="mb-6 animate-pulse" data-v-b05b4db0><div class="h-5 w-3/5 rounded bg-[var(--el-fill-color-dark)] mb-2" data-v-b05b4db0></div><div class="h-3 w-2/5 rounded bg-[var(--el-fill-color)] mb-4" data-v-b05b4db0></div><div class="h-64 w-full rounded bg-[var(--el-fill-color)] mb-3" data-v-b05b4db0></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-4/6 rounded bg-[var(--el-fill-color)]" data-v-b05b4db0></div></div>`,1)])):!e.response&&!e.errorMessage?(l(),f(`div`,Le,[i(y,{icon:`fa-solid fa-globe`,class:`text-6xl mb-4 opacity-30`}),n(`p`,Re,c(e.$t(`webextrator.description.intro`)),1),n(`p`,ze,c(e.$t(`webextrator.description.introHint`)),1)])):e.errorMessage?(l(),f(`div`,Be,[i(b,{type:`error`,closable:!1,"show-icon":``,title:e.$t(`webextrator.message.failed`)},{default:p(()=>[n(`pre`,Ve,c(e.errorMessage),1)]),_:1},8,[`title`])])):e.data?(l(),f(`div`,He,[n(`header`,Ue,[n(`h1`,We,c(e.data.title||e.$t(`webextrator.message.untitled`)),1),n(`div`,Ge,[e.finalUrl?(l(),f(`a`,{key:0,href:e.finalUrl,target:`_blank`,rel:`noopener`,class:`hover:underline truncate max-w-[60%]`},[i(y,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),r(c(e.finalUrl),1)],8,Ke)):a(``,!0),e.renderData?.status?(l(),f(`span`,qe,[i(y,{icon:`fa-solid fa-signal`,class:`mr-1`}),r(c(e.renderData.status),1)])):a(``,!0),e.response?.elapsed?(l(),f(`span`,Je,[i(y,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(c(e.response.elapsed.toFixed(2))+`s `,1)])):a(``,!0),e.contentTypeLabel?(l(),f(`span`,Ye,[i(y,{icon:`fa-solid fa-tag`,class:`mr-1`}),r(c(e.contentTypeLabel),1)])):a(``,!0)]),e.extractData?.description?(l(),f(`p`,Xe,c(e.extractData.description),1)):a(``,!0)]),e.screenshotSrc?(l(),f(`figure`,Ze,[i(x,{src:e.screenshotSrc,fit:`contain`,"preview-src-list":[e.screenshotSrc],"preview-teleported":``,"hide-on-click-modal":``,class:`w-full max-h-[480px] rounded border border-[var(--app-border-subtle)] bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`])])):a(``,!0),i(w,{modelValue:e.activeTab,"onUpdate:modelValue":o[0]||=t=>e.activeTab=t,class:`result-tabs`},{default:p(()=>[e.markdown?(l(),t(C,{key:0,label:e.$t(`webextrator.tab.markdown`),name:`markdown`},{default:p(()=>[n(`div`,Qe,[i(S,{content:e.markdown},null,8,[`content`])]),n(`pre`,$e,c(e.markdown),1)]),_:1},8,[`label`])):a(``,!0),e.plainText?(l(),t(C,{key:1,label:e.$t(`webextrator.tab.text`),name:`text`},{default:p(()=>[n(`div`,et,[i(S,{content:e.plainText},null,8,[`content`])]),n(`pre`,tt,c(e.plainText),1)]),_:1},8,[`label`])):a(``,!0),e.extractData?.structured?(l(),t(C,{key:2,label:e.$t(`webextrator.tab.structured`),name:`structured`},{default:p(()=>[n(`div`,$,[i(S,{content:e.structuredPretty},null,8,[`content`])]),n(`pre`,nt,c(e.structuredPretty),1)]),_:1},8,[`label`])):a(``,!0),e.links.length?(l(),t(C,{key:3,label:`${e.$t(`webextrator.tab.links`)} (${e.links.length})`,name:`links`},{default:p(()=>[n(`div`,rt,[i(S,{content:e.linksPlain},null,8,[`content`])]),n(`ul`,it,[(l(!0),f(h,null,s(e.links,(e,t)=>(l(),f(`li`,{key:t,class:`truncate`},[n(`a`,{href:e,target:`_blank`,rel:`noopener`},c(e),9,at)]))),128))])]),_:1},8,[`label`])):a(``,!0),e.images.length?(l(),t(C,{key:4,label:`${e.$t(`webextrator.tab.images`)} (${e.images.length})`,name:`images`},{default:p(()=>[n(`div`,ot,[(l(!0),f(h,null,s(e.images,(n,r)=>(l(),t(x,{key:r,src:n,fit:`cover`,loading:`lazy`,"preview-src-list":e.images,"initial-index":r,"preview-teleported":``,"hide-on-click-modal":``,class:`aspect-square w-full rounded bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`,`initial-index`]))),128))])]),_:1},8,[`label`])):a(``,!0),e.html?(l(),t(C,{key:5,label:e.$t(`webextrator.tab.html`),name:`html`},{default:p(()=>[n(`div`,st,[i(S,{content:e.html},null,8,[`content`])]),n(`pre`,ct,c(e.html),1)]),_:1},8,[`label`])):a(``,!0),i(C,{label:e.$t(`webextrator.tab.raw`),name:`raw`},{default:p(()=>[n(`div`,lt,[i(S,{content:e.rawPretty},null,8,[`content`])]),n(`pre`,ut,c(e.rawPretty),1)]),_:1},8,[`label`])]),_:1},8,[`modelValue`])])):a(``,!0)])}var ft=o({name:`WebextratorIndex`,components:{Layout:U,ConfigPanel:je,ResultPanel:A(Ne,[[`render`,dt],[`__scopeId`,`data-v-b05b4db0`]])},inject:[`initialized`],async mounted(){await this.$store.dispatch(`webextrator/getService`)},methods:{async onRun(){let e=this.$store.state.webextrator?.config;if(!e?.url)return;let t=(e.mode||`extract`)===`extract`;N.info(this.$t(t?`webextrator.message.extracting`:`webextrator.message.rendering`));try{await this.$store.dispatch(`webextrator/run`),N.success(this.$t(`webextrator.message.success`))}catch(e){let t=e?.response?.data?.error?.code||e?.response?.data?.code;t===`used_up`?N.error(this.$t(`webextrator.message.usedUp`)):t===`too_many_requests`?N.error(this.$t(`webextrator.message.busy`)):t===`timeout`?N.error(this.$t(`webextrator.message.timeout`)):N.error(this.$t(`webextrator.message.failed`))}}}});function pt(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onRun:e.onRun},null,8,[`onRun`])]),result:p(()=>[i(d)]),_:1})}var mt=A(ft,[[`render`,pt]]);export{mt as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.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"./drawer-BvYPSxXh.js";import{t as w}from"./switch-DflwVy6G.js";import{_i as T}from"./constants-BvG5EAGh.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-B7Ehq3WB.js";import{t as I}from"./index.es-Cf1Nz1bg.js";import{t as te}from"./CopyToClipboard-C4Zr_RWu.js";import{t as L}from"./FilePreview-erEvFoLk.js";import{t as R}from"./ImagePreview-CuVgQnIV.js";import{n as z}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as B}from"./BotPlaceholder-DmDddO0B.js";import{i as V,n as H,t as U}from"./pagination-CbQjtYtK.js";import{n as W,t as G}from"./NoTasks-CrhfF4zj.js";import{t as K}from"./Consumption-D3EMWpgi.js";import{t as q}from"./ApiCodeButton-Dyr9-U56.js";import{t as J}from"./VideoPlayer-CxSJ4zS_.js";var Y=s({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(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,X,[r(`div`,Z,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,Q,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var re=D(Y,[[`render`,ne],[`__scopeId`,`data-v-da4bcd3a`]]),ie=s({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,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,ae,[r(`div`,oe,[r(`div`,se,[r(`span`,ce,l(e.$t(`luma.name.enhancement`)),1),a(c,{content:e.$t(`luma.description.enhancement`)},null,8,[`content`])]),r(`div`,le,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var de=D(ie,[[`render`,ue]]),fe=s({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,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,pe,[r(`div`,me,[r(`div`,he,[r(`span`,ge,l(e.$t(`luma.name.custom`)),1),a(c,{content:e.$t(`luma.description.custom`)},null,8,[`content`])]),r(`div`,_e,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var ye=D(fe,[[`render`,ve]]),be=s({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,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,xe,[r(`div`,Se,[r(`div`,Ce,[r(`span`,we,l(e.$t(`luma.name.loop`)),1),a(c,{content:e.$t(`luma.description.loop`)},null,8,[`content`])]),r(`div`,Te,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var De=D(be,[[`render`,Ee]]),Oe=s({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,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,ke,[r(`div`,Ae,[r(`div`,je,[r(`span`,Me,l(e.$t(`luma.name.endImageUrl`)),1),a(g,{content:e.$t(`luma.description.endImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[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:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(_,{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`])):o(``,!0)]),default:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(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=s({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,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ie,[r(`div`,Le,[r(`div`,Re,[r(`span`,ze,l(e.$t(`luma.name.startImageUrl`)),1),a(g,{content:e.$t(`luma.description.startImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[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:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{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:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(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=s({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,t,s,c,d,h){let g=f(`info-icon`),_=f(`file-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ue,[r(`div`,We,[r(`div`,Ge,[r(`span`,Ke,l(e.$t(`luma.name.videoUrl`)),1),a(g,{content:e.$t(`luma.description.videoUrl`)},null,8,[`content`])])]),a(b,{"file-list":e.fileList,"onUpdate:fileList":t[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:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{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:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(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=s({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,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(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=s({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,t,i,a,s,c){let d=f(`video-player`);return u(),p(`div`,$e,[r(`div`,et,[r(`span`,tt,l(e.$t(`luma.name.extend`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(d,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var rt=s({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,t,s,c,d,h){let g=f(`extend-from-input`),_=f(`prompt-input`),v=f(`custom-selector`),y=f(`upload-video`),b=f(`start-image-input`),x=f(`end-image-input`),S=f(`enhancement-selector`),C=f(`loop-selector`),w=f(`consumption`),T=f(`font-awesome-icon`),E=f(`el-button`);return u(),p(`div`,it,[r(`div`,at,[e.config?.video_id||e.config?.video_url?(u(),n(g,{key:0,class:`mb-4`})):o(``,!0),a(_,{class:`mb-4`}),e.config?.video_id?o(``,!0):(u(),n(v,{key:1,class:`mb-4`})),e.config?.custom?(u(),n(y,{key:2,class:`mb-4`})):o(``,!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(u(),n(b,{key:3,class:`mb-4`})):o(``,!0),a(x,{class:`mb-4`}),a(S,{class:`mb-4`}),a(C,{class:`mb-4`})]),r(`div`,ot,[a(w,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(u(),n(E,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.extend`)),1)]),_:1},8,[`onClick`])):(u(),n(E,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(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=s({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:t({content:!0,failed:!0})},bt={key:0,class:`mb-4`},xt={key:1,class:t({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:t({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:t({content:!0})},kt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function At(e,t,n,s,c,d){let h=f(`el-image`),g=f(`video-player`),v=f(`el-button`),y=f(`el-tooltip`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,ut,[r(`div`,dt,[a(h,{src:`https://cdn.acedata.cloud/ahjfwi.png`,class:`avatar`})]),r(`div`,ft,[r(`div`,pt,[i(l(e.$t(`luma.name.lumaBot`))+` `,1),r(`span`,mt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,ht,[e.modelValue?.request?.prompt?(u(),p(`p`,gt,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,_t,` - (`+l(e.$t(`luma.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`span`,vt,` - (`+l(e.$t(`luma.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,yt,[e.modelValue.response.video_url?(u(),p(`div`,bt,[a(g,{src:e.modelValue.response.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response&&!e.config?.custom?(u(),p(`div`,xt,[a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.extendVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onExtend(t,e.modelValue?.response),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.extend`)),1)]),_:1})]),_:1},8,[`content`]),a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.downloadVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=_(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(b,{path:`/luma/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,St,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Ct,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.state===`failed`||e.modelValue?.response?.success===!1?(u(),p(`div`,wt,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,Tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,Et,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,Dt,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.traceId`))+`: `+l(e.modelValue?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):o(``,!0),!e.modelValue?.response||e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`div`,Ot,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,kt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var jt=s({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(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Mt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:t[1]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,r=>(u(),n(h,{key:r.id,"model-value":r,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Nt,[a(v)])):o(``,!0)],64)}var Ft=D(jt,[[`render`,Pt]]),It=T(`luma`),Lt=s({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,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(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 +0,0 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,_ as u,et as d,k as f,lt as p,tt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{F as y,X as b,Y as x,tt as S,z as C}from"./use-deprecated-CPfQu7wa.js";import{r as w,t as T}from"./select-DUQSa_dv.js";import{n as E,t as D}from"./tabs-CM47Khie.js";import{t as O}from"./upload-BbP3qVit.js";import{t as k}from"./tooltip-C3PYfh8V.js";import{t as A}from"./image-C1JYEL_e.js";import{t as j}from"./avatar-DJGt2zYX.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as ee,t as P}from"./collapse-Be4--o_J.js";import{t as F}from"./drawer-BvYPSxXh.js";import{n as I,r as te,t as ne}from"./dropdown-ClFBH1K7.js";import{t as L}from"./input-number-CVD04ts_.js";import{n as re,t as ie}from"./skeleton-Cn4UY-T8.js";import{t as ae}from"./slider-D-yKoeJR.js";import{t as oe}from"./switch-DflwVy6G.js";import{Mn as se,_i as R}from"./constants-BvG5EAGh.js";import{An as z,At as B,E as V,Fn as H,Ir as U,Nt as W,Ot as G,Sr as K,kr as q,kt as ce,nn as J,yr as Y}from"./index-B7Ehq3WB.js";import{t as X}from"./index.es-Cf1Nz1bg.js";import{n as le}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Z,n as ue,r as de,t as fe}from"./pagination-CbQjtYtK.js";import{n as pe,t as me}from"./NoTasks-CrhfF4zj.js";import{t as he}from"./Consumption-D3EMWpgi.js";import{n as ge,r as Q,t as _e}from"./Player-2INZtHKM.js";var ve=o({name:`LayoutProducer`,components:{ElDrawer:F,ElButton:v,FontAwesomeIcon:X},mixins:[le],data(){return{preview:!1}},computed:{}}),ye={class:`main flex flex-row flex-1`},be={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},xe={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},Se={class:`preview h-full w-[300px] flex flex-col`};function Ce(t,r,a,o,s,c){let m=d(`font-awesome-icon`),g=d(`el-button`),_=d(`el-drawer`);return l(),f(`div`,ye,[n(`div`,be,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,xe,[e(t.$slots,`result`,{},void 0,!0)]),n(`div`,Se,[e(t.$slots,`preview`,{},void 0,!0)]),h(i(g,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(m,{icon:`fa-solid fa-magic`})]),_:1},512),[[u,!t.tasksEmpty]]),i(_,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var we=V(ve,[[`render`,Ce],[`__scopeId`,`data-v-cc984c6f`]]),Te=o({name:`TypeSelector`,components:{ElSelect:w,ElOption:T,ElSwitch:oe,InfoIcon:Z},data(){return{options:[{label:`FUZZ-2.0 Pro`,value:`FUZZ-2.0 Pro`,desc:this.$t(`producer.model.fuzz20proDesc`)},{label:`FUZZ-2.0`,value:`FUZZ-2.0`,desc:this.$t(`producer.model.fuzz20desc`)},{label:`FUZZ-2.0 Raw`,value:`FUZZ-2.0 Raw`,desc:this.$t(`producer.model.fuzz20rawDesc`)},{label:`FUZZ-1.1 Pro`,value:`FUZZ-1.1 Pro`,desc:this.$t(`producer.model.fuzz11proDesc`)},{label:`FUZZ-1.1`,value:`FUZZ-1.1`,desc:this.$t(`producer.model.fuzz11desc`)},{label:`FUZZ-1.0 Pro`,value:`FUZZ-1.0 Pro`,desc:this.$t(`producer.model.fuzz10proDesc`)},{label:`FUZZ-1.0`,value:`FUZZ-1.0`,desc:this.$t(`producer.model.fuzz10desc`)},{label:`FUZZ-0.8`,value:`FUZZ-0.8`,desc:this.$t(`producer.model.fuzz08desc`)}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||=se}}),Ee={class:`mb-3`},De={class:`flex items-center mb-1`},Oe={class:`text-sm font-bold`},ke={class:`model-option`},Ae={class:`model-option-name`},je={class:`model-option-desc`},Me={key:0,class:`flex items-center justify-between mb-3`},Ne={class:`flex items-center`},Pe={class:`text-sm font-bold`};function Fe(e,r,o,u,m,h){let _=d(`el-option`),v=d(`el-select`),y=d(`info-icon`),b=d(`el-switch`);return l(),f(`div`,null,[n(`div`,Ee,[n(`div`,De,[n(`span`,Oe,c(e.$t(`producer.name.model`)),1)]),i(v,{modelValue:e.model,"onUpdate:modelValue":r[0]||=t=>e.model=t,class:`w-full model-select`,size:`default`,placeholder:e.$t(`producer.placeholder.select`)},{default:p(()=>[(l(!0),f(g,null,s(e.options,e=>(l(),t(_,{key:e.value,label:e.label,value:e.value},{default:p(()=>[n(`div`,ke,[n(`span`,Ae,c(e.label),1),n(`span`,je,c(e.desc),1)])]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),e.custom?(l(),f(`div`,Me,[n(`div`,Ne,[n(`span`,Pe,c(e.$t(`producer.name.instrumental`)),1),i(y,{content:e.$t(`producer.description.instrumental`)},null,8,[`content`])]),i(b,{modelValue:e.instrumental,"onUpdate:modelValue":r[1]||=t=>e.instrumental=t},null,8,[`modelValue`])])):a(``,!0)])}var Ie=V(Te,[[`render`,Fe],[`__scopeId`,`data-v-42496b9a`]]),Le=o({name:`UploadAudio`,components:{ElUpload:O,ElButton:v,ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z,FontAwesomeIcon:X},mixins:[ce],emits:[`change`],data(){return{fileList:[],uploadUrl:K()+`/api/v1/files/`,audioPreviewUrl:null,uploading:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},hasUploadedAudio(){let e=this.$store.state.producer?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.producer?.config?.action||`upload_extend`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},methods:{onExceed(){q.warning(this.$t(`producer.message.uploadReferencesExceed`))},onError(){this.uploading=!1,q.error(this.$t(`producer.message.uploadReferencesError`))},async onSuccess(){let e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`),this.uploading=!1;return}this.uploading=!0,q.info(this.$t(`producer.message.startingUploadAudio`));try{let e=(await J.upload(t,{token:n})).data?.data.audio_id;this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,audio_id:e,action:`upload_extend`}),q.success(this.$t(`producer.message.startUploadAudioSuccess`))}catch(e){q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startUploadAudioFailed`))}finally{this.uploading=!1}}}}),Re={class:`relative`},ze={class:`flex justify-between items-center mb-2`},Be={class:`flex justify-start items-center`},Ve={class:`text-sm font-bold`},He={key:0,class:`mb-2`},Ue=[`src`],We={key:1,class:`mt-1`};function Ge(e,t,o,s,u,m){let h=d(`info-icon`),g=d(`font-awesome-icon`),_=d(`el-button`),v=d(`el-upload`),y=d(`el-radio-button`),b=d(`el-radio-group`);return l(),f(`div`,Re,[n(`div`,ze,[n(`div`,Be,[n(`span`,Ve,c(e.$t(`producer.name.referenceAudios`)),1),i(h,{content:e.$t(`producer.description.uploadAudios`)},null,8,[`content`])]),i(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper inline-upload`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[i(_,{round:``,type:`primary`,size:`small`,loading:e.uploading},{default:p(()=>[i(g,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),r(` `+c(e.$t(`producer.button.uploadAudios`)),1)]),_:1},8,[`loading`])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])]),e.audioPreviewUrl?(l(),f(`div`,He,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Ue)])):a(``,!0),e.hasUploadedAudio?(l(),f(`div`,We,[i(b,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||=t=>e.uploadAction=t,size:`small`},{default:p(()=>[i(y,{value:`upload_extend`},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1}),i(y,{value:`upload_cover`},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1})]),_:1},8,[`modelValue`])])):a(``,!0)])}var Ke=V(Le,[[`render`,Ge],[`__scopeId`,`data-v-7fd0580a`]]),qe=o({name:`PromptInput`,components:{PromptTextarea:pe},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Je(e,n,r,i,a,o){let s=d(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`producer.name.songDescription`),info:e.$t(`producer.description.prompt`),placeholder:e.$t(`producer.placeholder.prompt`),"min-rows":5,"max-rows":14},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ye=V(qe,[[`render`,Je]]),Xe=o({name:`LyricInput`,components:{ElInput:U,ElButton:v,FontAwesomeIcon:X,InfoIcon:Z},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||=``},methods:{async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t=this.config?.style||this.config?.title||`a beautiful song`;this.generatingLyrics=!0,q.info(this.$t(`producer.message.generatingLyrics`));try{let n=(await J.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:n.text,title:n.title}),q.success(this.$t(`producer.message.generateLyricsSuccess`)))}catch{q.error(this.$t(`producer.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}),Ze={class:`field`},Qe={class:`flex items-center justify-between mb-1`},$e={class:`flex items-center`},et={class:`text-sm font-bold`};function tt(e,o,s,u,m,h){let g=d(`info-icon`),_=d(`font-awesome-icon`),v=d(`el-button`),y=d(`el-input`);return l(),f(`div`,Ze,[n(`div`,Qe,[n(`div`,$e,[n(`span`,et,c(e.$t(`producer.name.lyrics`)),1),i(g,{content:e.$t(`producer.description.lyrics`)},null,8,[`content`])]),e.config?.action===`extend`?a(``,!0):(l(),t(v,{key:0,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:p(()=>[e.generatingLyrics?a(``,!0):(l(),t(_,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),r(` `+c(e.$t(`producer.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),e.config?.action===`extend`?(l(),t(y,{key:1,modelValue:e.lyric,"onUpdate:modelValue":o[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(l(),t(y,{key:0,modelValue:e.lyric,"onUpdate:modelValue":o[0]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`]))])}var nt=V(Xe,[[`render`,tt],[`__scopeId`,`data-v-88c6da2b`]]),rt=o({name:`StyleInput`,components:{ElInput:U,InfoIcon:Z},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style:e})}}}}),it={class:`field`},at={class:`flex items-center justify-between mb-1`},ot={class:`flex items-center`},st={class:`text-sm font-bold`};function ct(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,it,[n(`div`,at,[n(`div`,ot,[n(`span`,st,c(e.$t(`producer.name.style`)),1),i(u,{content:e.$t(`producer.description.style`)},null,8,[`content`])])]),i(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||=t=>e.style=t,rows:2,type:`textarea`,placeholder:e.$t(`producer.placeholder.style`)},null,8,[`modelValue`,`placeholder`])])}var lt=V(rt,[[`render`,ct]]),ut=o({name:`TitleInput`,components:{ElInput:U,InfoIcon:Z},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,title:e})}}}}),dt={class:`field`},ft={class:`flex items-center mb-1`},pt={class:`text-sm font-bold`};function mt(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,dt,[n(`div`,ft,[n(`span`,pt,c(e.$t(`producer.name.title`)),1),i(u,{content:e.$t(`producer.description.title`)},null,8,[`content`])]),i(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||=t=>e.title=t,placeholder:e.$t(`producer.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var ht=V(ut,[[`render`,mt]]),gt=o({name:`ExtendFromInput`,components:{ElImage:A,ElIcon:S,ElInputNumber:L,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),_t={class:`field`},vt={class:`box`},yt={class:`title font-bold`},bt={class:`input-wrapper`},xt={class:`task`},St={class:`left`},Ct={key:2,class:`duration`},wt={class:`info`},Tt={class:`title`},Et={class:`style`};function Dt(e,t,r,o,s,u){let g=d(`el-input-number`),_=d(`el-image`),v=d(`video-pause`),y=d(`el-icon`),b=d(`video-play`),x=m(`loading`);return l(),f(`div`,_t,[n(`div`,vt,[n(`h2`,yt,c(e.$t(`producer.name.extend`)),1),n(`div`,bt,[i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,xt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[3]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,St,[i(_,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[1]||=t=>e.onPause(e.audio)},[i(y,null,{default:p(()=>[i(v)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[2]||=t=>e.onPlay(e.audio)},[i(y,null,{default:p(()=>[i(b)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ct,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,wt,[n(`h2`,Tt,c(e.audio?.title),1),n(`p`,Et,c(e.audio?.style),1)])])):a(``,!0)])])}var Ot=V(gt,[[`render`,Dt],[`__scopeId`,`data-v-26d43480`]]),kt=o({name:`CoverFromInput`,components:{ElImage:A,ElIcon:S,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),At={class:`field`},jt={class:`box`},Mt={class:`title font-bold`},Nt={class:`task`},Pt={class:`left`},Ft={key:2,class:`duration`},It={class:`info`},Lt={class:`title`},Rt={class:`style`};function zt(e,t,r,o,s,u){let g=d(`el-image`),_=d(`video-pause`),v=d(`el-icon`),y=d(`video-play`),b=m(`loading`);return l(),f(`div`,At,[n(`div`,jt,[n(`h2`,Mt,c(e.$t(`producer.name.cover`)),1)]),n(`div`,Nt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[2]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,Pt,[i(g,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[0]||=t=>e.onPause(e.audio)},[i(v,null,{default:p(()=>[i(_)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[1]||=t=>e.onPlay(e.audio)},[i(v,null,{default:p(()=>[i(y)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ft,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,It,[n(`h2`,Lt,c(e.audio?.title),1),n(`p`,Rt,c(e.audio?.style),1)])])):a(``,!0)])])}var Bt=V(kt,[[`render`,zt],[`__scopeId`,`data-v-d8a8e583`]]),Vt=o({name:`VocalGenderSelector`,components:{ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),Ht={class:`mb-2`},Ut={class:`flex items-center mb-1`},Wt={class:`text-sm font-bold`};function Gt(e,t,a,o,s,u){let m=d(`info-icon`),h=d(`el-radio-button`),g=d(`el-radio-group`);return l(),f(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,c(e.$t(`producer.name.vocalGender`)),1),i(m,{content:e.$t(`producer.description.vocalGender`)},null,8,[`content`])]),i(g,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||=t=>e.vocalGender=t},{default:p(()=>[i(h,{value:``},{default:p(()=>[r(c(e.$t(`producer.gender.auto`)),1)]),_:1}),i(h,{value:`f`},{default:p(()=>[r(c(e.$t(`producer.gender.female`)),1)]),_:1}),i(h,{value:`m`},{default:p(()=>[r(c(e.$t(`producer.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Kt=V(Vt,[[`render`,Gt]]),qt=o({name:`AdvancedParams`,components:{ElCollapse:P,ElCollapseItem:ee,ElInput:U,ElSlider:ae,ElInputNumber:L,InfoIcon:Z},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??.5},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,weirdness:e})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,seed:e})}}},mounted(){let e=this.$store.state.producer?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.sound_strength==`number`&&e.sound_strength>1&&(t.sound_strength=e.sound_strength/100),typeof e.lyrics_strength==`number`&&e.lyrics_strength>1&&(t.lyrics_strength=e.lyrics_strength/100),Object.keys(t).length>0&&this.$store.commit(`producer/setConfig`,{...e,...t})}}),Jt={key:0,class:`mb-3`},Yt={class:`flex items-center mb-1`},Xt={class:`text-xs font-bold`},Zt={key:1,class:`mb-3`},Qt={class:`flex items-center mb-1`},$t={class:`text-xs font-bold`},en={class:`mb-3`},tn={class:`flex items-center justify-between mb-1`},nn={class:`flex items-center`},rn={class:`text-xs font-bold`},an={class:`text-xs text-[var(--el-text-color-secondary)]`},on={class:`mb-3`},sn={class:`flex items-center justify-between mb-1`},cn={class:`flex items-center`},ln={class:`text-xs font-bold`},un={class:`text-xs text-[var(--el-text-color-secondary)]`},dn={key:2,class:`mb-3`},fn={class:`flex items-center justify-between mb-1`},pn={class:`flex items-center`},mn={class:`text-xs font-bold`},hn={class:`text-xs text-[var(--el-text-color-secondary)]`},gn={class:`mb-3`},_n={class:`flex items-center mb-1`},vn={class:`text-xs font-bold`};function yn(e,r,o,s,u,m){let h=d(`info-icon`),g=d(`el-input`),_=d(`el-slider`),v=d(`el-input-number`),y=d(`el-collapse-item`),b=d(`el-collapse`);return l(),t(b,{modelValue:e.activeNames,"onUpdate:modelValue":r[6]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:p(()=>[i(y,{title:e.$t(`producer.name.advancedParams`),name:`advanced`},{default:p(()=>[e.config?.custom?(l(),f(`div`,Jt,[n(`div`,Yt,[n(`span`,Xt,c(e.$t(`producer.name.styleNegative`)),1),i(h,{content:e.$t(`producer.description.styleNegative`)},null,8,[`content`])]),i(g,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`producer.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,Zt,[n(`div`,Qt,[n(`span`,$t,c(e.$t(`producer.name.lyricPrompt`)),1),i(h,{content:e.$t(`producer.description.lyricPrompt`)},null,8,[`content`])]),i(g,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`producer.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),n(`div`,en,[n(`div`,tn,[n(`div`,nn,[n(`span`,rn,c(e.$t(`producer.name.weirdness`)),1),i(h,{content:e.$t(`producer.description.weirdness`)},null,8,[`content`])]),n(`span`,an,c(e.weirdness??.5),1)]),i(_,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])]),n(`div`,on,[n(`div`,sn,[n(`div`,cn,[n(`span`,ln,c(e.$t(`producer.name.soundStrength`)),1),i(h,{content:e.$t(`producer.description.soundStrength`)},null,8,[`content`])]),n(`span`,un,c(e.soundStrength??.7),1)]),i(_,{modelValue:e.soundStrength,"onUpdate:modelValue":r[3]||=t=>e.soundStrength=t,min:.2,max:1,step:.01},null,8,[`modelValue`])]),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,dn,[n(`div`,fn,[n(`div`,pn,[n(`span`,mn,c(e.$t(`producer.name.lyricsStrength`)),1),i(h,{content:e.$t(`producer.description.lyricsStrength`)},null,8,[`content`])]),n(`span`,hn,c(e.lyricsStrength??.7),1)]),i(_,{modelValue:e.lyricsStrength,"onUpdate:modelValue":r[4]||=t=>e.lyricsStrength=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):a(``,!0),n(`div`,gn,[n(`div`,_n,[n(`span`,vn,c(e.$t(`producer.name.seed`)),1),i(h,{content:e.$t(`producer.description.seed`)},null,8,[`content`])]),i(v,{modelValue:e.seed,"onUpdate:modelValue":r[5]||=t=>e.seed=t,min:0,controls:!1,size:`small`,placeholder:e.$t(`producer.placeholder.seed`),class:`w-full`},null,8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var bn=V(qt,[[`render`,yn],[`__scopeId`,`data-v-f9296888`]]),xn=o({name:`ReplaceSectionInput`,components:{ElInputNumber:L,ElImage:A,InfoIcon:Z},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`})}}}),Sn={class:`field`},Cn={class:`flex items-center mb-2`},wn={class:`text-sm font-bold m-0`},Tn={key:0,class:`task mb-2`},En={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Dn={class:`info flex-1 min-w-0`},On={class:`text-sm font-bold m-0 truncate`},kn={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},An={class:`flex gap-2`};function jn(e,t,r,o,s,u){let p=d(`info-icon`),g=d(`el-image`),_=d(`el-input-number`),v=m(`loading`);return l(),f(`div`,Sn,[n(`div`,Cn,[n(`h2`,wn,c(e.$t(`producer.name.replaceSection`)),1),i(p,{content:e.$t(`producer.description.replaceSection`)},null,8,[`content`])]),e.audio?(l(),f(`div`,Tn,[n(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,En,[i(g,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Dn,[n(`h2`,On,c(e.audio?.title),1),n(`p`,kn,c(e.audio?.style),1)])])])):a(``,!0),n(`div`,An,[i(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),i(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Mn=o({name:`PresetPanel`,components:{TypeSelector:Ie,PromptInput:Ye,LyricInput:nt,StyleInput:lt,TitleInput:ht,ExtendFromInput:Ot,CoverFromInput:Bt,UploadAudio:Ke,VocalGenderSelector:Kt,AdvancedParams:bn,ReplaceSectionInput:V(xn,[[`render`,jn]]),FontAwesomeIcon:X,ElButton:v,ElTabs:E,ElTabPane:D,Consumption:he},emits:[`generate`],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e===`custom`})}},consumption(){return W(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){let e=this.config?.action;return e===`extend`||e===`upload_extend`?this.$t(`producer.button.extend`):e===`cover`||e===`upload_cover`?this.$t(`producer.button.cover_music`):e===`variation`?this.$t(`producer.button.variation`):e===`replace_section`?this.$t(`producer.button.replace_section`):e===`stems`?this.$t(`producer.button.get_stems`):e===`swap_vocals`?this.$t(`producer.button.swap_vocals`):e===`swap_instrumentals`?this.$t(`producer.button.swap_instrumentals`):this.$t(`producer.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`producer/setConfig`,{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:``,lyric:``,style:``,title:``,model:this.$store.state.producer?.config?.model})}}}),Nn={class:`flex flex-col h-full`},Pn={class:`flex-1 overflow-y-auto p-5`},Fn={class:`pt-2 px-1`},In={class:`pt-2 px-1`},Ln={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Rn={class:`flex gap-2 w-full`};function zn(e,o,s,u,m,h){let g=d(`type-selector`),_=d(`upload-audio`),v=d(`prompt-input`),y=d(`extend-from-input`),b=d(`cover-from-input`),x=d(`replace-section-input`),S=d(`advanced-params`),C=d(`el-tab-pane`),w=d(`lyric-input`),T=d(`style-input`),E=d(`title-input`),D=d(`vocal-gender-selector`),O=d(`el-tabs`),k=d(`consumption`),A=d(`font-awesome-icon`),j=d(`el-button`);return l(),f(`div`,Nn,[n(`div`,Pn,[i(O,{modelValue:e.mode,"onUpdate:modelValue":o[0]||=t=>e.mode=t,class:`producer-mode-tabs`,stretch:``},{default:p(()=>[i(C,{label:e.$t(`producer.mode.simple`),name:`simple`},{default:p(()=>[n(`div`,Fn,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),i(v,{class:`mb-4`}),e.config?.action===`extend`?(l(),t(y,{key:0,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:1,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:2,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`]),i(C,{label:e.$t(`producer.mode.custom`),name:`custom`},{default:p(()=>[n(`div`,In,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(w,{key:0,class:`mb-4`})),i(T,{class:`mb-4`}),i(E,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(D,{key:1,class:`mb-4`})),e.config?.action===`extend`?(l(),t(y,{key:2,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:3,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:4,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Ln,[i(k,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Rn,[i(j,{class:`flex-1`,onClick:e.onClearAll},{default:p(()=>[i(A,{icon:`fa-solid fa-broom`,class:`mr-1`}),r(` `+c(e.$t(`producer.button.clear_all`)),1)]),_:1},8,[`onClick`]),i(j,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:p(()=>[i(A,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Bn=V(Mn,[[`render`,zn],[`__scopeId`,`data-v-4a4b209e`]]),Vn=ge(),Hn=R(`producer`),Un=o({name:`TaskPreview`,components:{ElImage:A,ElIcon:S,ElTooltip:k,FontAwesomeIcon:X,VideoPlay:b,VideoPause:x,ElDropdown:ne,ElDropdownMenu:te,ElDropdownItem:I,Loading:y,ApiCodeDialog:de},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,apiCodeVisible:!1,apiCodePath:`/producer/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===Y.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.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.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:Q,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=`/producer/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.debug(`set config`,t),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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();let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);fetch(t).then(e=>e.blob()).then(e=>{(0,Vn.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),q.error(this.$t(`producer.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}J.video(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(),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},onVariation(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:`variation`,audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl(`swap_vocals`,e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl(`swap_instrumentals`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,q.info(this.$t(`producer.message.fetchingWav`));let n=(await J.wav({audio_id:e.id},{token:t})).data?.data,r=Array.isArray(n)?n[0]?.file_url:n?.file_url||n?.audio_url;r?this.onDownload(null,r):q.error(this.$t(`producer.message.fetchWavFailed`))}catch{q.error(this.$t(`producer.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Hn},r=this.credential?.token;if(!r){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),J.audio(n,{token:r}).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`producer/getTasks`,{limit:30,offset:0})}}}),Wn={class:`task`},Gn=[`onClick`],Kn={class:`left`},qn=[`onClick`],Jn=[`onClick`],Yn={key:2,class:`duration`},Xn={class:`info`},Zn={class:`title`},Qn={class:`style`},$n={class:`right`},er={class:`el-dropdown-link`},tr={class:`flex items-center min-w-[120px]`},nr={class:`flex items-center min-w-[120px]`},rr={class:`el-dropdown-link`};function ir(e,o,u,v,y,b){let x=d(`el-image`),S=d(`video-pause`),C=d(`el-icon`),w=d(`video-play`),T=d(`font-awesome-icon`),E=d(`el-tooltip`),D=d(`Loading`),O=d(`el-dropdown-item`),k=d(`el-dropdown-menu`),A=d(`el-dropdown`),j=d(`api-code-dialog`),M=m(`loading`);return l(),f(`div`,Wn,[(l(!0),f(g,null,s(e.audios,o=>(l(),f(`div`,{key:o.id,class:`audio`,onClick:_(t=>e.onClick(o),[`stop`])},[h((l(),f(`div`,Kn,[i(x,{src:o?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),o?.audio_url&&e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:_(t=>e.onPause(o),[`stop`])},[i(C,null,{default:p(()=>[i(S)]),_:1})],8,qn)):a(``,!0),o?.audio_url&&(e.$store.state?.producer?.audio?.id!==o.id||e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:_(t=>e.onPlay(o),[`stop`])},[i(C,null,{default:p(()=>[i(w)]),_:1})],8,Jn)):a(``,!0),o?.duration?(l(),f(`div`,Yn,c(e.useFormatDuring(o?.duration)),1)):a(``,!0)])),[[M,!o?.audio_url]]),n(`div`,Xn,[n(`h2`,Zn,c(o?.title),1),n(`p`,Qn,c(o?.style),1)]),n(`div`,$n,[i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[i(O,{disabled:e.isFetchingVideoUrl,onClick:t=>e.handleVideoDownload(o)},{default:p(()=>[n(`div`,tr,[e.isFetchingVideoUrl?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onDownload(t,o?.audio_url),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.download_audio`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{disabled:e.isFetchingWav,onClick:t=>e.handleWavDownload(o)},{default:p(()=>[n(`div`,nr,[e.isFetchingWav?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,er,[i(E,{effect:`dark`,content:e.$t(`producer.button.download`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onExtend(t,o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:1,onClick:_(t=>e.onGetStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.get_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:2,onClick:_(t=>e.onGetAllStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.all_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(t=>e.onCover(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1},8,[`onClick`]),o?.id?(l(),t(O,{key:3,onClick:_(t=>e.onVariation(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.variation`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:4,onClick:_(t=>e.onSwapVocals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_vocals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:5,onClick:_(t=>e.onSwapInstrumentals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_instrumentals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:6,onClick:_(t=>e.onReplaceSection(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.replace_section`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(e.onViewCode,[`stop`])},{default:p(()=>[i(T,{icon:`fa-solid fa-code`,class:`mr-1`}),r(` `+c(e.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,rr,[i(E,{effect:`dark`,content:e.$t(`producer.button.more`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],8,Gn))),128)),i(j,{visible:e.apiCodeVisible,"onUpdate:visible":o[0]||=t=>e.apiCodeVisible=t,method:`POST`,path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.producer?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var ar=o({name:`RecentPanel`,components:{ElSkeletonItem:re,ElSkeleton:ie,TaskPreview:V(Un,[[`render`,ir]]),Player:_e,NoTasks:me,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),or={key:0,class:`tasks`},sr={class:`left w-[70px] p-[10px] flex items-center`},$={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},cr={key:2,class:`w-full flex-1 flex items-center justify-center`},lr={class:`h-20`};function ur(e,r,o,c,m,_){let v=d(`el-skeleton-item`),y=d(`el-skeleton`),b=d(`task-preview`),x=d(`scroll-list`),S=d(`no-tasks`),C=d(`player`);return l(),f(g,null,[e.tasks?.items===void 0?(l(),f(`div`,or,[(l(),f(g,null,s(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,sr,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,$,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),i(v,{variant:`text`})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(x,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:e.loading,onReachTop:r[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(l(!0),f(g,null,s(e.tasks?.items,(e,n)=>(l(),t(b,{key:n,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),f(`div`,cr,[i(S)])):a(``,!0),h(n(`div`,lr,[i(C,{namespace:`producer`})],512),[[u,!!e.$store?.state?.producer?.audio?.object]])],64)}var dr=V(ar,[[`render`,ur]]),fr=o({name:`TaskPreview`,components:{IconPicture:C,ElImage:A,ElAvatar:j,ElIcon:S},computed:{audio(){return this.$store.state.producer?.audio}}}),pr={key:0,class:`size-full overflow-hidden`},mr={class:`relative h-[300px]`},hr={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},gr={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`},_r={class:`p-4`},vr={class:`flex items-center font-bold mb-2`},yr={class:`text-[var(--el-text-color-regular)] mb-2`},br={class:`text-xs text-[var(--el-text-color-regular)]`},xr={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},Sr={key:1,class:`w-full h-full`};function Cr(e,t,r,a,o,s){let u=d(`icon-picture`),m=d(`el-icon`),h=d(`el-image`),g=d(`el-avatar`);return e.audio?.object?(l(),f(`div`,pr,[n(`div`,mr,[i(h,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:p(()=>[n(`div`,hr,[i(m,{class:`text-3xl`},{default:p(()=>[i(u)]),_:1})])]),_:1},8,[`src`]),n(`h2`,gr,c(e.audio?.title),1)]),n(`div`,_r,[n(`div`,vr,[i(g,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,c(e.audio?.title),1)]),n(`p`,yr,c(e.audio?.style),1),n(`p`,br,c(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,xr,[n(`p`,null,c(e.audio?.lyric),1)])])])):(l(),f(`div`,Sr))}var wr=V(fr,[[`render`,Cr]]),Tr=R(`producer`),Er=o({name:`ProducerIndex`,components:{Layout:we,ConfigPanel:Bn,RecentPanel:dr,PreviewPanel:wr},mixins:[B],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===Y.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===Y.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===Y.Request},needApply(){return this.$store.state.producer.status.getApplications===Y.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.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 fe({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(`producer/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`producer/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){z.create({application:this.application}).then(({data:e})=>{this.application=e,q.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&q.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(`producer/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!G(this.uploadTracker,e=>this.$t(e),e=>q.warning(e)))return;let e={...this.config,callback_url:Tr},t=this.credential?.token;if(!t){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),H(`producer`,J.audio(e,{token:t})).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Dr(e,n,r,a,o,s){let c=d(`config-panel`),u=d(`recent-panel`),f=d(`preview-panel`),m=d(`layout`);return l(),t(m,null,{config:p(()=>[i(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:p(()=>[i(u,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:p(()=>[i(f)]),_:1})}var Or=V(Er,[[`render`,Dr],[`__scopeId`,`data-v-a766e27a`]]);export{Or as default};
|