@acedatacloud/nexior 3.278.0 → 3.278.1
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 → ApiCodeButton-C3W4LtUB.js} +1 -1
- package/dist/assets/{AskUserQuestionCard-CJ6FK-eQ.js → AskUserQuestionCard-j_jmA0-D.js} +1 -1
- package/dist/assets/{Auth-oy_cDrjB.js → Auth-DyQfWyhU.js} +1 -1
- package/dist/assets/{Bare-BjzQECGk.js → Bare-C7SSO2HH.js} +1 -1
- package/dist/assets/{BotPlaceholder-BpLIwwxA.js → BotPlaceholder-E0Ur6LDD.js} +1 -1
- package/dist/assets/{BottomFooter-CPL1TUJk.js → BottomFooter-Coy8gUiq.js} +1 -1
- package/dist/assets/{Callback-DZA2XoEn.js → Callback-CHQhX-NO.js} +1 -1
- package/dist/assets/{Console-lGda8cJF.js → Console-B1hCGk76.js} +1 -1
- package/dist/assets/{Consumption-D_CAQaSB.js → Consumption-C3v4xGTO.js} +1 -1
- package/dist/assets/{Conversation-BBLuEQqB.js → Conversation-DIHoVLoF.js} +1 -1
- package/dist/assets/{CopyToClipboard-DG5cx0Ex.js → CopyToClipboard-D1o-dyv3.js} +1 -1
- package/dist/assets/{Detail-LUdxtiDf.js → Detail-DabGL3Du.js} +2 -2
- package/dist/assets/{Extra-C51gCPia.js → Extra-BnMUwI-A.js} +1 -1
- package/dist/assets/{FilePreview-BFkQVXth.js → FilePreview-BOcejUda.js} +1 -1
- package/dist/assets/{Hailuo-DIHiST1a.js → Hailuo-CcLZYOcQ.js} +1 -1
- package/dist/assets/{History-BGPVkHOY.js → History-YiNxOFaO.js} +1 -1
- package/dist/assets/{ImagePreview-CeyNx3jd.js → ImagePreview-B_BmQP_E.js} +1 -1
- package/dist/assets/{ImageWrapper-C6BTBymE.js → ImageWrapper-CqgtUTt-.js} +1 -1
- package/dist/assets/{Index-DWMFhERT.js → Index-986_h1HR.js} +1 -1
- package/dist/assets/{Index-B4luoYiJ.js → Index-B9ijpbgE.js} +1 -1
- package/dist/assets/{Index-BIi8lQVb.js → Index-BBpMtv81.js} +1 -1
- package/dist/assets/{Index-BJ7bU2Ap.js → Index-Bcup2f8Z.js} +1 -1
- package/dist/assets/{Index-C4hy7nVp.js → Index-BqTTlCSO.js} +1 -1
- package/dist/assets/{Index-DZZdzKP6.js → Index-BrMouoyr.js} +1 -1
- package/dist/assets/{Index-KKuLrOV7.js → Index-BvznbM3d.js} +1 -1
- package/dist/assets/{Index-D6ein8tv.js → Index-C2fUDB7K.js} +1 -1
- package/dist/assets/{Index-BUutMSDI.js → Index-CEiKF6Kk.js} +1 -1
- package/dist/assets/{Index-DVoOVUco.js → Index-CFGYwjjq.js} +1 -1
- package/dist/assets/{Index-Cc-RhfD0.js → Index-CMV5f9-W.js} +1 -1
- package/dist/assets/{Index-zXeYOts6.js → Index-CPGOW6pf.js} +1 -1
- package/dist/assets/{Index-aNTiBE8l.js → Index-CQxivBoi.js} +1 -1
- package/dist/assets/{Index-CxLS2qO0.js → Index-Ci3q4Cf_.js} +1 -1
- package/dist/assets/{Index-D4VgA6LH.js → Index-CnZM1TNE.js} +1 -1
- package/dist/assets/{Index-HS9ewrHk.js → Index-CwxRL1cp.js} +1 -1
- package/dist/assets/{Index-BFpKx82w.js → Index-DDCtkGKq.js} +1 -1
- package/dist/assets/{Index-Bk_tFQBc.js → Index-DKdty6BX.js} +1 -1
- package/dist/assets/{Index-BwIw__H4.js → Index-DNsW7q_P.js} +1 -1
- package/dist/assets/{Index-Cz1SEEJn.js → Index-DTx7keCo.js} +1 -1
- package/dist/assets/{Index-DaSVJxjM.js → Index-Dtt_uKlb.js} +1 -1
- package/dist/assets/{Index-C8N6BHY-.js → Index-Dz6e5mDD.js} +1 -1
- package/dist/assets/{Index-CPJu847J.js → Index-MK-8kZ9k.js} +1 -1
- package/dist/assets/{Index-DcccGmiE.js → Index-b6E_eZVx.js} +1 -1
- package/dist/assets/{Index-DiBqXC2W.js → Index-wCq1UOIl.js} +1 -1
- package/dist/assets/{Index-BpIXOTSD.js → Index-xq9bdCfV.js} +1 -1
- package/dist/assets/{Invitees-CDdin_zl.js → Invitees-DId6aoxP.js} +1 -1
- package/dist/assets/{List-aru9FNfS.js → List-CfSWYHJD.js} +1 -1
- package/dist/assets/{List-CMovwYjB.js → List-CnWG35Cv.js} +1 -1
- package/dist/assets/{List-C358Vzd4.js → List-N9MHUGLT.js} +1 -1
- package/dist/assets/{Main-B5RiswqX.js → Main-V4yM61gG.js} +1 -1
- package/dist/assets/{Model-CtN4cAoL.js → Model-Ca-nHvzH.js} +1 -1
- package/dist/assets/{Navigator-DjUbPnUI.js → Navigator-E58cuse1.js} +1 -1
- package/dist/assets/{NoTasks-BOopjPtL.js → NoTasks-Czm65vJ4.js} +1 -1
- package/dist/assets/{NotFound-m-5oeC2J.js → NotFound-BjA9ykZE.js} +1 -1
- package/dist/assets/{Pagination-CbbWdJIl.js → Pagination-DeCHT-PM.js} +1 -1
- package/dist/assets/{Pay-CgS135WT.js → Pay-DSvvY9KB.js} +1 -1
- package/dist/assets/{Player-DvgjC7c5.js → Player-C7Zoyb-g.js} +1 -1
- package/dist/assets/{Seedance-cdIlG9x0.js → Seedance-Dsqi6eXq.js} +1 -1
- package/dist/assets/{Status-CeZgC2Ye.js → Status-CJKkKwsI.js} +1 -1
- package/dist/assets/{Subscribe-Ci-2Fv2D.js → Subscribe-BdnJ-I5j.js} +1 -1
- package/dist/assets/{TabSwitcher-be-vKwWY.js → TabSwitcher-DaGfiNGh.js} +1 -1
- package/dist/assets/{Tts-D28gFP1B.js → Tts-DjdS_pkj.js} +1 -1
- package/dist/assets/{VideoPlayer-CD9PlOS8.js → VideoPlayer-C5F3Jf17.js} +1 -1
- package/dist/assets/{avatar-BK3H5LlO.js → avatar-CGS2cO-x.js} +1 -1
- package/dist/assets/{basic-D2PYpKX5.js → basic-BaLHvxkw.js} +1 -1
- package/dist/assets/{chat-C1EUkJXK.js → chat-DjIgeGDG.js} +1 -1
- package/dist/assets/{codingBridge-DEvwc0PR.js → codingBridge-CiyyRbRb.js} +1 -1
- package/dist/assets/{codingBridgeNotify-DKoA2JP9.js → codingBridgeNotify-CjCpVg4Q.js} +2 -2
- package/dist/assets/{collapse-BxNTm00O.js → collapse-zZjSyR53.js} +1 -1
- package/dist/assets/constants-CwLEZ_AF.js +3 -0
- package/dist/assets/{createTaskActions-CvBFHmmD.js → createTaskActions-CFfeCrRN.js} +1 -1
- package/dist/assets/{date-picker-CiLjAJPo.js → date-picker-CpTCVLld.js} +1 -1
- package/dist/assets/{dropdown-CG4l8dKx.js → dropdown-DhpaHW0b.js} +1 -1
- package/dist/assets/{esm-BqiBebi7.js → esm-B5K_w4bp.js} +1 -1
- package/dist/assets/{esm-D2sFB5nS.js → esm-BwfXY7Jp.js} +2 -2
- package/dist/assets/{esm-CWSmgMpA.js → esm-C37xRURN.js} +3 -3
- package/dist/assets/esm-C882q9Kl.js +1 -0
- package/dist/assets/{esm-Cj99PCoU.js → esm-CMH1tVLr.js} +1 -1
- package/dist/assets/{esm-DRxku3NW.js → esm-CeezYReU.js} +2 -2
- package/dist/assets/{esm-CWP9r0G2.js → esm-Ck02AWWr.js} +1 -1
- package/dist/assets/{fish-BP62Jr0O.js → fish-D_IZAI95.js} +1 -1
- package/dist/assets/{flux-CDZygm05.js → flux-BBB_MZCf.js} +1 -1
- package/dist/assets/{grokvideo-C53uzPoZ.js → grokvideo-Cd6Pej_-.js} +1 -1
- package/dist/assets/{hailuo-CWOkLsy0.js → hailuo-BW0HNO8M.js} +1 -1
- package/dist/assets/{headshots-C7l2OtHq.js → headshots-CEAWyKQo.js} +1 -1
- package/dist/assets/{image-r_Sil4Yc.js → image-BLdTdN6v.js} +1 -1
- package/dist/assets/{index-1hhw9POE.js → index-CxBOJBZd.js} +4 -4
- package/dist/assets/{index.browser.esm-BXdtHnHu.js → index.browser.esm-Dr5lQ_WG.js} +1 -1
- package/dist/assets/{index.es-Ds6M0PuH.js → index.es-Dw2lhymn.js} +1 -1
- package/dist/assets/{input-number-Bg1zmr12.js → input-number-DIoKTD0e.js} +1 -1
- package/dist/assets/{kling-DvkijwuP.js → kling-28InUIKx.js} +1 -1
- package/dist/assets/{luma-DC40B8tL.js → luma-DvnCAypL.js} +1 -1
- package/dist/assets/{midjourney-XBP74pFR.js → midjourney-BmPZMs3O.js} +1 -1
- package/dist/assets/{nanobanana-DHolv0td.js → nanobanana-ByMIuP8G.js} +1 -1
- package/dist/assets/{openaiimage-COmDdgg9.js → openaiimage-BfkdmvD5.js} +1 -1
- package/dist/assets/{pagination-DH5leY8A.js → pagination-DC4Eh4yG.js} +1 -1
- package/dist/assets/{pika--x6r8JlL.js → pika-RDuFQTZH.js} +1 -1
- package/dist/assets/{pixverse-B5tqJ_b9.js → pixverse-DfJ8R_7A.js} +1 -1
- package/dist/assets/{popover-Cpr0N2Z1.js → popover-DCGISZxg.js} +1 -1
- package/dist/assets/{producer-CrblN48L.js → producer-DoTFIJf8.js} +1 -1
- package/dist/assets/{qrart-Dfku4NkR.js → qrart-BXSZR12y.js} +1 -1
- package/dist/assets/{row-bfsY0Sup.js → row-d76bUVm3.js} +1 -1
- package/dist/assets/{seedance-BvTouhw7.js → seedance-sRwpzrHn.js} +1 -1
- package/dist/assets/{seedream-C0OkbFis.js → seedream-DoGCfHzA.js} +1 -1
- package/dist/assets/{select-CxvkoR_I.js → select-B1uV_nnl.js} +1 -1
- package/dist/assets/{serp-DKGjlmaC.js → serp-BivtyZn7.js} +1 -1
- package/dist/assets/{slider-CfcYZR4R.js → slider-DqJsYqiE.js} +1 -1
- package/dist/assets/{solana-wallets-CrItVnUL.js → solana-wallets-DV4PzTa7.js} +2 -2
- package/dist/assets/{solana-wallets-vue-Cfl3r9NB.js → solana-wallets-vue-Bfs5wP1l.js} +1 -1
- package/dist/assets/{sora-Bk3RvCXZ.js → sora-jRE0-dso.js} +1 -1
- package/dist/assets/{suno-Bbnp6P4i.js → suno-CwNsysp6.js} +1 -1
- package/dist/assets/{switch-BUEiwneZ.js → switch-BXfqi_p8.js} +1 -1
- package/dist/assets/{tabs-dRngkdRx.js → tabs-D9l1-5D5.js} +1 -1
- package/dist/assets/{upload-cn_TUU3N.js → upload-SS_pZz4k.js} +1 -1
- package/dist/assets/{veo-Cunbs9e5.js → veo-CT03Jgwu.js} +1 -1
- package/dist/assets/{wan-GH45xAZP.js → wan-CNWQl-J0.js} +1 -1
- package/dist/assets/{web-CXzkL4Px.js → web-Bafgko4b.js} +1 -1
- package/dist/assets/{web-CG6DXPr0.js → web-BuRFWZZM.js} +1 -1
- package/dist/assets/{web-C9aK-R5v.js → web-Cuvolsnb.js} +1 -1
- package/dist/assets/{web-Cx3VD86e.js → web-D7nDzK4F.js} +1 -1
- package/dist/assets/{web-C_klyBjH.js → web-D_grrLKi.js} +1 -1
- package/dist/assets/{webextrator-CI0OahQs.js → webextrator-UWXgV4-n.js} +1 -1
- package/dist/index.html +2 -2
- package/package.json +2 -2
- package/dist/assets/constants-DwFseFmM.js +0 -3
- package/dist/assets/esm-CDp0Qf7i.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,nt as h,tt as g,ut as _,v,y}from"./vendor-chart-BJCvKk8-.js";import{t as b}from"./button-DfsQodL-.js";import{F as x,X as S,Y as C,tt as w,z as T}from"./use-deprecated-BzKQGDXN.js";import{r as E,t as D}from"./select-CxvkoR_I.js";import{n as O,t as k}from"./tabs-dRngkdRx.js";import{n as A,t as j}from"./form-DnBQT-zH.js";import{t as M}from"./upload-cn_TUU3N.js";import{t as N}from"./tooltip-BLwTovWL.js";import{t as P}from"./image-r_Sil4Yc.js";import{t as F}from"./avatar-CTHa5OEM.js";import{t as I}from"./checkbox-BAeQdLeW.js";import{n as L,r as R,t as ee}from"./radio-BmBXySlN.js";import{n as te,t as ne}from"./collapse-BxNTm00O.js";import{t as z}from"./drawer-Dpuj2uIl.js";import{n as B,r as V,t as H}from"./dropdown-CG4l8dKx.js";import{t as U}from"./input-number-Bg1zmr12.js";import{t as re}from"./popover-Cpr0N2Z1.js";import{t as ie}from"./progress-C3UHYIHi.js";import{n as ae,t as oe}from"./skeleton-C4sltx62.js";import{t as se}from"./slider-CfcYZR4R.js";import{t as ce}from"./switch-BUEiwneZ.js";import{Fn as le,_i as ue}from"./constants-DwFseFmM.js";import{An as de,At as fe,E as W,Fn as pe,Ir as G,Mr as K,Nt as me,Or as q,Ot as he,Sr as ge,kr as J,kt as _e,rn as Y,yr as X}from"./index-1hhw9POE.js";import{t as Z}from"./index.es-Ds6M0PuH.js";import{n as ve}from"./taskDrawerMixin-DEgO_R5H.js";import{i as Q,n as ye,r as be,t as xe}from"./pagination-DH5leY8A.js";import{n as Se,t as Ce}from"./NoTasks-BOopjPtL.js";import{t as we}from"./Consumption-D_CAQaSB.js";import{n as Te,r as $,t as Ee}from"./Player-DvgjC7c5.js";var De=r({name:`LayoutSuno`,components:{ElDrawer:z,ElButton:b,FontAwesomeIcon:Z},mixins:[ve],data(){return{preview:!1}},computed:{}}),Oe={class:`main flex flex-row flex-1`},ke={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Ae={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},je={class:`preview h-full w-[300px] flex flex-col`};function Me(e,r,i,a,s,c){let l=g(`font-awesome-icon`),d=g(`el-button`),m=g(`el-drawer`);return u(),t(`div`,Oe,[n(`div`,ke,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,Ae,[p(e.$slots,`result`,{},void 0,!0)]),n(`div`,je,[p(e.$slots,`preview`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:_(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[v,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:_(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ne=W(De,[[`render`,Me],[`__scopeId`,`data-v-169b0449`]]),Pe=r({name:`TypeSelector`,components:{ElSelect:E,ElOption:D,ElSwitch:ce},data(){return{options:[{label:`v5.5`,value:`chirp-v5-5`,desc:this.$t(`suno.model.v55desc`)},{label:`v5`,value:`chirp-v5`,desc:this.$t(`suno.model.v5desc`)},{label:`v4.5+`,value:`chirp-v4-5-plus`,desc:this.$t(`suno.model.v45plusdesc`)},{label:`v4.5`,value:`chirp-v4-5`,desc:this.$t(`suno.model.v45desc`),dividerAfter:!0},{label:`v4`,value:`chirp-v4`,desc:this.$t(`suno.model.v4desc`)},{label:`v3.5`,value:`chirp-v3-5`,desc:this.$t(`suno.model.v35desc`)},{label:`v3`,value:`chirp-v3-0`,desc:this.$t(`suno.model.v3desc`)}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||=le}}),Fe={class:`mb-3`},Ie={class:`flex items-center mb-1`},Le={class:`text-sm font-bold`},Re={class:`model-option`},ze={class:`model-option-left`},Be={class:`model-option-name`},Ve={class:`model-option-desc`},He={key:0,class:`flex items-center justify-between mb-3`},Ue={class:`text-sm font-bold`};function We(r,i,d,f,p,h){let v=g(`el-option`),y=g(`el-select`),b=g(`el-switch`);return u(),t(`div`,null,[n(`div`,Fe,[n(`div`,Ie,[n(`span`,Le,l(r.$t(`suno.name.model`)),1)]),o(y,{modelValue:r.model,"onUpdate:modelValue":i[0]||=e=>r.model=e,class:`w-full model-select`,size:`default`,placeholder:r.$t(`suno.placeholder.select`)},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e.value,label:e.label,value:e.value,class:c({"model-option-divider":e.dividerAfter})},{default:_(()=>[n(`div`,Re,[n(`div`,ze,[n(`span`,Be,l(e.label),1)]),n(`span`,Ve,l(e.desc),1)])]),_:2},1032,[`label`,`value`,`class`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),r.custom?(u(),t(`div`,He,[n(`span`,Ue,l(r.$t(`suno.name.instrumental`)),1),o(b,{modelValue:r.instrumental,"onUpdate:modelValue":i[1]||=e=>r.instrumental=e},null,8,[`modelValue`])])):m(``,!0)])}var Ge=W(Pe,[[`render`,We],[`__scopeId`,`data-v-16e4d6fc`]]),Ke=r({name:`UploadAudio`,components:{ElUpload:M,ElButton:b,ElDialog:K,ElTabs:O,ElTabPane:k,InfoIcon:Q,FontAwesomeIcon:Z,ElRadioGroup:R,ElRadioButton:L},mixins:[_e],emits:[`change`],data(){return{fileList:[],uploadUrl:ge()+`/api/v1/files/`,dialogVisible:!1,activeTab:`browse`,recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){let e=this.$store.state.suno?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.suno?.config?.action||`upload_extend`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,action:e})}},formattedTime(){return`${Math.floor(this.recordSeconds/60).toString().padStart(2,`0`)}:${(this.recordSeconds%60).toString().padStart(2,`0`)}`}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){J.warning(this.$t(`suno.message.uploadReferencesExceed`))},onError(){J.error(this.$t(`suno.message.uploadReferencesError`))},async onBrowseSuccess(){let e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingUploadAudio`));try{let e=await Y.upload(t,{token:n});console.debug(`get upload music success`,e.data);let r=e.data?.data.audio_id;this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_id:r,action:`upload_extend`}),J.success(this.$t(`suno.message.startUploadAudioSuccess`))}catch(e){J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startUploadAudioFailed`))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>`u`){J.error(this.$t(`suno.message.recordingUnsupported`));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{let e=new Blob(this.recordedChunks,{type:`audio/webm`});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error(`record error`,e),J.error(this.$t(`suno.message.recordingPermissionDenied`))}},stopRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.mediaRecorder&&this.mediaRecorder.state!==`inactive`&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{let e=new FormData,t=`recording-${Date.now()}.webm`;e.append(`file`,this.recordedBlob,t);let n=await fetch(this.uploadUrl,{method:`POST`,headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!n.ok)throw Error(`upload failed: ${n.status}`);let r=await n.json(),i=r?.file_url||r?.data?.file_url;if(!i)throw Error(`no file_url in response`);this.audioPreviewUrl=i,await this.onGenerateAudioId(i),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),J.error(e?.message||this.$t(`suno.message.uploadReferencesError`))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&=(this.mediaStream.getTracks().forEach(e=>e.stop()),null)},cleanupRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.releaseStream(),this.recordedAudioUrl&&=(URL.revokeObjectURL(this.recordedAudioUrl),null)}}}),qe={class:`relative`},Je={class:`flex justify-between items-center mb-2`},Ye={class:`flex justify-start items-center`},Xe={class:`text-sm font-bold`},Ze={key:0,class:`mb-2`},Qe=[`src`],$e={key:1,class:`mt-2`},et={class:`py-4`},tt={class:`text-center py-6`},nt={class:`text-sm`},rt={class:`text-xs text-gray-400 mt-1`},it={class:`py-4 text-center`},at={class:`recorder-display mb-4`},ot={key:0,class:`text-red-500 flex items-center justify-center gap-2`},st={class:`text-2xl font-mono`},ct={key:1,class:`text-green-600`},lt={key:2,class:`text-gray-400 text-2xl font-mono`},ut={key:0,class:`mb-4`},dt=[`src`],ft={class:`flex justify-center gap-3`};function pt(e,r,c,d,f,p){let h=g(`info-icon`),v=g(`font-awesome-icon`),y=g(`el-button`),b=g(`el-radio-button`),x=g(`el-radio-group`),S=g(`el-upload`),C=g(`el-tab-pane`),w=g(`el-tabs`),T=g(`el-dialog`);return u(),t(`div`,qe,[n(`div`,Je,[n(`div`,Ye,[n(`span`,Xe,l(e.$t(`suno.name.referenceAudios`)),1),o(h,{content:e.$t(`suno.description.uploadAudios`)},null,8,[`content`])]),o(y,{round:``,type:`primary`,size:`small`,onClick:r[0]||=t=>e.dialogVisible=!0},{default:_(()=>[o(v,{icon:`fa-solid fa-plus`,class:`icon mr-1`}),i(` `+l(e.$t(`suno.button.addAudio`)),1)]),_:1})]),e.audioPreviewUrl?(u(),t(`div`,Ze,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Qe)])):m(``,!0),e.hasUploadedAudio?(u(),t(`div`,$e,[o(x,{modelValue:e.uploadAction,"onUpdate:modelValue":r[1]||=t=>e.uploadAction=t,size:`small`},{default:_(()=>[o(b,{value:`upload_extend`},{default:_(()=>[i(l(e.$t(`suno.button.extend`)),1)]),_:1}),o(b,{value:`upload_cover`},{default:_(()=>[i(l(e.$t(`suno.button.upload_cover`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),o(T,{modelValue:e.dialogVisible,"onUpdate:modelValue":r[4]||=t=>e.dialogVisible=t,title:e.$t(`suno.name.addAudio`),width:`520px`,"close-on-click-modal":!1,"append-to-body":``},{default:_(()=>[o(w,{modelValue:e.activeTab,"onUpdate:modelValue":r[3]||=t=>e.activeTab=t,class:`add-audio-tabs`},{default:_(()=>[o(C,{name:`browse`,label:e.$t(`suno.tab.browse`)},{default:_(()=>[n(`div`,et,[o(S,{"file-list":e.fileList,"onUpdate:fileList":r[2]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:``},{default:_(()=>[n(`div`,tt,[o(v,{icon:`fa-solid fa-upload`,class:`text-4xl text-gray-400 mb-3`}),n(`div`,nt,l(e.$t(`suno.description.dropAudioHere`)),1),n(`div`,rt,l(e.$t(`suno.description.audioFormats`)),1)])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])]),_:1},8,[`label`]),o(C,{name:`record`,label:e.$t(`suno.tab.record`)},{default:_(()=>[n(`div`,it,[n(`div`,at,[e.recording?(u(),t(`div`,ot,[r[5]||=n(`span`,{class:`recording-dot`},null,-1),n(`span`,st,l(e.formattedTime),1)])):e.recordedBlob?(u(),t(`div`,ct,[o(v,{icon:`fa-solid fa-check-circle`,class:`text-2xl mr-2`}),n(`span`,null,l(e.$t(`suno.message.recordingReady`))+` (`+l(e.formattedTime)+`)`,1)])):(u(),t(`div`,lt,`00:00`))]),e.recordedAudioUrl&&!e.recording?(u(),t(`div`,ut,[n(`audio`,{src:e.recordedAudioUrl,controls:``,class:`w-full`},null,8,dt)])):m(``,!0),n(`div`,ft,[!e.recording&&!e.recordedBlob?(u(),a(y,{key:0,type:`primary`,round:``,onClick:e.startRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.startRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recording?(u(),a(y,{key:1,type:`danger`,round:``,onClick:e.stopRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-stop`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.stopRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recordedBlob&&!e.recording?(u(),t(s,{key:2},[o(y,{round:``,onClick:e.resetRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.reRecord`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,round:``,loading:e.uploadingRecord,onClick:e.uploadRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.useRecording`)),1)]),_:1},8,[`loading`,`onClick`])],64)):m(``,!0)])])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`])])}var mt=W(Ke,[[`render`,pt],[`__scopeId`,`data-v-5f17a1f4`]]),ht=[{key:`lofi`,label:`🎧 Lo-fi Chill`,prompt:`a relaxing lo-fi hip hop beat for studying`},{key:`pop-love`,label:`💕 Pop Love Song`,prompt:`a catchy pop love song with sweet melodies`},{key:`rock-anthem`,label:`🎸 Rock Anthem`,prompt:`an energetic rock anthem with electric guitars`},{key:`jazz-night`,label:`🎷 Jazz Night`,prompt:`a smooth late-night jazz piece with saxophone`},{key:`edm-drop`,label:`⚡ EDM Drop`,prompt:`an intense EDM track with a massive drop`},{key:`folk-story`,label:`🪕 Folk Story`,prompt:`a warm folk song telling a story about traveling`},{key:`rnb-groove`,label:`🎤 R&B Groove`,prompt:`a smooth R&B groove with soulful vocals`},{key:`classical`,label:`🎻 Classical`,prompt:`an elegant classical piece for orchestra`},{key:`hip-hop`,label:`🎤 Hip Hop`,prompt:`a hard-hitting hip hop beat with bass`},{key:`country`,label:`🤠 Country`,prompt:`an upbeat country song with acoustic guitar and banjo`},{key:`reggae`,label:`🌴 Reggae`,prompt:`a laid-back reggae tune with island vibes`},{key:`latin`,label:`💃 Latin`,prompt:`a vibrant Latin dance track with percussion`},{key:`ambient`,label:`🌊 Ambient`,prompt:`a dreamy ambient soundscape for relaxation`},{key:`metal`,label:`🤘 Metal`,prompt:`a powerful metal song with heavy riffs and double bass drums`},{key:`soul`,label:`🎵 Soul`,prompt:`a heartfelt soul ballad with gospel harmonies`},{key:`synthwave`,label:`🌃 Synthwave`,prompt:`a retro synthwave track with 80s vibes`},{key:`kpop`,label:`🇰🇷 K-Pop`,prompt:`a catchy K-pop dance track with hook`},{key:`lullaby`,label:`🌙 Lullaby`,prompt:`a gentle lullaby for bedtime with soft piano`},{key:`cinematic`,label:`🎬 Cinematic`,prompt:`an epic cinematic orchestral score for a movie trailer`},{key:`blues`,label:`🎸 Blues`,prompt:`a soulful blues song with electric guitar bends`},{key:`disco`,label:`🕺 Disco`,prompt:`a funky disco track with groovy bassline`},{key:`punk`,label:`🔥 Punk Rock`,prompt:`a fast punk rock song with raw energy`},{key:`gospel`,label:`⛪ Gospel`,prompt:`an uplifting gospel choir song with piano`},{key:`trap`,label:`🔊 Trap`,prompt:`a dark trap beat with 808s and hi-hats`},{key:`bossa`,label:`☕ Bossa Nova`,prompt:`a gentle bossa nova with nylon guitar`},{key:`indie`,label:`🎶 Indie`,prompt:`a dreamy indie track with ethereal vocals`},{key:`cpop`,label:`🇨🇳 C-Pop`,prompt:`a beautiful Chinese pop ballad with emotional vocals`},{key:`jpop`,label:`🇯🇵 J-Pop`,prompt:`a cheerful J-pop song with anime vibes`},{key:`afrobeat`,label:`🥁 Afrobeat`,prompt:`a groovy Afrobeat track with layered percussion`},{key:`game`,label:`🎮 Game BGM`,prompt:`an adventurous video game background music`}],gt=8;function _t(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var vt=r({name:`PromptInput`,components:{FontAwesomeIcon:Z,PromptTextarea:Se},data(){return{shuffledTags:_t(ht)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,gt)}},mounted(){this.prompt||=``},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=_t(ht)}}}),yt={class:`inspo-tags`},bt=[`onClick`];function xt(r,i,c,d,f,p){let m=g(`font-awesome-icon`),h=g(`prompt-textarea`);return u(),a(h,{modelValue:r.prompt,"onUpdate:modelValue":i[1]||=e=>r.prompt=e,title:r.$t(`suno.name.songDescription`),info:r.$t(`suno.description.prompt`),placeholder:r.$t(`suno.placeholder.prompt`),"min-rows":5,"max-rows":14},{after:_(()=>[n(`div`,yt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e.key,class:`inspo-tag`,onClick:t=>r.onTagClick(e)},l(e.label),9,bt))),128)),n(`button`,{class:`inspo-tag inspo-tag-refresh`,onClick:i[0]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(m,{icon:`fa-solid fa-arrows-rotate`})])])]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var St=W(vt,[[`render`,xt],[`__scopeId`,`data-v-58ffcd38`]]),Ct=r({name:`LyricInput`,components:{ElInput:G,ElButton:b,ElTooltip:N,ElDialog:K,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:``,lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||=``},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){let e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=``},async onEnhanceLyrics(){let e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,J.info(this.$t(`suno.message.enhancingLyrics`));try{let t=`${this.enhancePrompt}\n\nOriginal lyrics:\n${this.lyric}`,n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,this.enhancePrompt=``,J.success(this.$t(`suno.message.enhanceLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.enhanceLyricsFailed`))}finally{this.enhancingLyrics=!1}}},async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t;try{t=((await q.prompt(this.$t(`suno.message.lyricsThemePromptMessage`),this.$t(`suno.message.lyricsThemePromptTitle`),{confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`),inputPlaceholder:this.$t(`suno.placeholder.lyricsTheme`),inputValue:this.config?.title||``,inputType:`textarea`,inputValidator:e=>typeof e==`string`&&e.trim().length>0||this.$t(`suno.message.lyricsThemeRequired`)})).value||``).trim()}catch{return}if(t){this.pushHistory(),this.generatingLyrics=!0,J.info(this.$t(`suno.message.generatingLyrics`));try{let n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:n.text,title:n.title}),J.success(this.$t(`suno.message.generateLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}}),wt={class:`field`},Tt={class:`flex items-center justify-between mb-1`},Et={class:`flex items-center`},Dt={class:`text-sm font-bold`},Ot={class:`flex items-center gap-1`},kt={class:`relative`},At={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},jt={key:0,class:`enhance-bar`},Mt={key:0,class:`enhance-bar mt-3`},Nt={class:`flex items-center justify-between`},Pt={class:`flex items-center gap-1`};function Ft(e,r,s,c,d,f){let p=g(`info-icon`),h=g(`font-awesome-icon`),v=g(`el-button`),b=g(`el-tooltip`),x=g(`el-input`),S=g(`el-dialog`);return u(),t(`div`,wt,[n(`div`,Tt,[n(`div`,Et,[n(`span`,Dt,l(e.$t(`suno.name.lyrics`)),1),o(p,{content:e.$t(`suno.description.lyrics`)},null,8,[`content`])]),n(`div`,Ot,[e.lyricHistory.length>0?(u(),a(b,{key:0,content:e.$t(`suno.button.undo`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),e.lyric?(u(),a(b,{key:1,content:e.$t(`suno.button.clear_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),o(b,{content:e.$t(`suno.button.expand_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:r[0]||=t=>e.expanded=!0},{default:_(()=>[o(h,{icon:`fa-solid fa-expand`})]),_:1})]),_:1},8,[`content`]),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))])]),n(`div`,kt,[e.config?.action===`extend`?(u(),a(x,{key:1,modelValue:e.lyric,"onUpdate:modelValue":r[2]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(u(),a(x,{key:0,modelValue:e.lyric,"onUpdate:modelValue":r[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`])),n(`div`,At,l(e.lyric?.length||0)+`/5000`,1)]),e.lyric&&e.config?.action!==`extend`?(u(),t(`div`,jt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[3]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])])):m(``,!0),o(S,{modelValue:e.expanded,"onUpdate:modelValue":r[7]||=t=>e.expanded=t,title:e.$t(`suno.name.lyrics`),width:`720px`,top:`5vh`,"close-on-click-modal":!1,class:`lyrics-expand-dialog`},{footer:_(()=>[n(`div`,Nt,[n(`div`,Pt,[e.lyricHistory.length>0?(u(),a(v,{key:0,size:`small`,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.undo`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.lyric?(u(),a(v,{key:1,size:`small`,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_lyrics`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),o(v,{type:`primary`,onClick:r[6]||=t=>e.expanded=!1},{default:_(()=>[i(l(e.$t(`common.button.confirm`)),1)]),_:1})])]),default:_(()=>[o(x,{modelValue:e.lyric,"onUpdate:modelValue":r[4]||=t=>e.lyric=t,type:`textarea`,rows:20,class:`lyrics-expanded`,placeholder:e.$t(`suno.placeholder.lyrics`),autofocus:``},null,8,[`modelValue`,`placeholder`]),e.config?.action===`extend`?m(``,!0):(u(),t(`div`,Mt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[5]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])]))]),_:1},8,[`modelValue`,`title`])])}var It=W(Ct,[[`render`,Ft],[`__scopeId`,`data-v-d7d2ec74`]]),Lt=`Pop.Rock.Jazz.R&B.Hip Hop.Lo-fi.Electronic.Classical.Country.Blues.Folk.Reggae.Metal.Punk.Soul.Funk.Ambient.Indie.Latin.Acoustic.Dance.Disco.Gospel.K-Pop.J-Pop.C-Pop.Bossa Nova.Trap.Drill.House.Techno.Dubstep.Synthwave.Chill.Dreamy.Upbeat.Melancholic.Romantic.Epic.Cinematic.Orchestral.Piano.Guitar.Saxophone.Violin.Tribal.World Music.Afrobeat.Ska.Grunge`.split(`.`),Rt=12;function zt(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var Bt=r({name:`StyleInput`,components:{ElInput:G,ElButton:b,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{optimizing:!1,shuffledTags:zt(Lt)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,Rt)}},methods:{onTagClick(e){let t=this.style||``;t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=zt(Lt)},async onOptimizeStyle(){let e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,J.info(this.$t(`suno.message.optimizingStyle`));try{let t=await Y.style({prompt:this.style},{token:e}),n=t.data?.text||t.data?.data?.text;n&&(this.style=n,J.success(this.$t(`suno.message.optimizeStyleSuccess`)))}catch{J.error(this.$t(`suno.message.optimizeStyleFailed`))}finally{this.optimizing=!1}}}}}),Vt={class:`field`},Ht={class:`flex items-center justify-between mb-1`},Ut={class:`flex items-center`},Wt={class:`text-sm font-bold`},Gt={class:`relative`},Kt={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},qt={class:`style-tags`},Jt=[`onClick`];function Yt(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-input`);return u(),t(`div`,Vt,[n(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,l(r.$t(`suno.name.style`)),1),o(v,{content:r.$t(`suno.description.style`)},null,8,[`content`])]),o(b,{size:`small`,loading:r.optimizing,round:``,onClick:r.onOptimizeStyle},{default:_(()=>[r.optimizing?m(``,!0):(u(),a(y,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(r.$t(`suno.button.optimize_style`)),1)]),_:1},8,[`loading`,`onClick`])]),n(`div`,Gt,[o(x,{modelValue:r.style,"onUpdate:modelValue":c[0]||=e=>r.style=e,rows:2,type:`textarea`,placeholder:r.$t(`suno.placeholder.style`)},null,8,[`modelValue`,`placeholder`]),n(`div`,Kt,l(r.style?.length||0)+`/1000`,1)]),n(`div`,qt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e,class:`style-tag`,onClick:t=>r.onTagClick(e)},l(e),9,Jt))),128)),n(`button`,{class:`style-tag style-tag-refresh`,onClick:c[1]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(y,{icon:`fa-solid fa-arrows-rotate`})])])])}var Xt=W(Bt,[[`render`,Yt],[`__scopeId`,`data-v-ddebb076`]]),Zt=r({name:`TitleInput`,components:{ElInput:G,InfoIcon:Q},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,title:e})}}}}),Qt={class:`field`},$t={class:`flex items-center mb-1`},en={class:`text-sm font-bold`};function tn(e,r,i,a,s,c){let d=g(`info-icon`),f=g(`el-input`);return u(),t(`div`,Qt,[n(`div`,$t,[n(`span`,en,l(e.$t(`suno.name.title`)),1),o(d,{content:e.$t(`suno.description.title`)},null,8,[`content`])]),o(f,{modelValue:e.title,"onUpdate:modelValue":r[0]||=t=>e.title=t,placeholder:e.$t(`suno.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var nn=W(Zt,[[`render`,tn]]),rn=r({name:`ExtendFromInput`,components:{ElImage:P,ElIcon:w,ElInputNumber:U,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),an={class:`field`},on={class:`box`},sn={class:`title font-bold`},cn={class:`input-wrapper`},ln={class:`task`},un={class:`left`},dn={key:2,class:`duration`},fn={class:`info`},pn={class:`title`},mn={class:`style`};function hn(e,r,i,a,s,c){let d=g(`el-input-number`),p=g(`el-image`),v=g(`video-pause`),y=g(`el-icon`),b=g(`video-play`),x=h(`loading`);return u(),t(`div`,an,[n(`div`,on,[n(`h2`,sn,l(e.$t(`suno.name.extend`)),1),n(`div`,cn,[o(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,ln,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[3]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,un,[o(p,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[1]||=t=>e.onPause(e.audio)},[o(y,null,{default:_(()=>[o(v)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[2]||=t=>e.onPlay(e.audio)},[o(y,null,{default:_(()=>[o(b)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,dn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,fn,[n(`h2`,pn,l(e.audio?.title),1),n(`p`,mn,l(e.audio?.style),1)])])):m(``,!0)])])}var gn=W(rn,[[`render`,hn],[`__scopeId`,`data-v-bcce4821`]]),_n=r({name:`CoverFromInput`,components:{ElImage:P,ElIcon:w,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),vn={class:`field`},yn={class:`box`},bn={class:`title font-bold`},xn={class:`task`},Sn={class:`left`},Cn={key:2,class:`duration`},wn={class:`info`},Tn={class:`title`},En={class:`style`};function Dn(e,r,i,a,s,c){let d=g(`el-image`),p=g(`video-pause`),v=g(`el-icon`),y=g(`video-play`),b=h(`loading`);return u(),t(`div`,vn,[n(`div`,yn,[n(`h2`,bn,l(e.$t(`suno.name.cover`)),1)]),n(`div`,xn,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[2]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Sn,[o(d,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[0]||=t=>e.onPause(e.audio)},[o(v,null,{default:_(()=>[o(p)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[1]||=t=>e.onPlay(e.audio)},[o(v,null,{default:_(()=>[o(y)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,Cn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,wn,[n(`h2`,Tn,l(e.audio?.title),1),n(`p`,En,l(e.audio?.style),1)])])):m(``,!0)])])}var On=W(_n,[[`render`,Dn],[`__scopeId`,`data-v-06640216`]]),kn=r({name:`VocalGenderSelector`,components:{ElRadioGroup:R,ElRadioButton:L,InfoIcon:Q},computed:{vocalGender:{get(){return this.$store.state.suno?.config?.vocal_gender||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,vocal_gender:e||void 0})}}}}),An={class:`flex items-center mb-1`},jn={class:`text-sm font-bold`};function Mn(e,r,a,s,c,d){let f=g(`info-icon`),p=g(`el-radio-button`),m=g(`el-radio-group`);return u(),t(`div`,null,[n(`div`,An,[n(`span`,jn,l(e.$t(`suno.name.vocalGender`)),1),o(f,{content:e.$t(`suno.description.vocalGender`)},null,8,[`content`])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":r[0]||=t=>e.vocalGender=t,size:`small`},{default:_(()=>[o(p,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(p,{value:`f`},{default:_(()=>[i(l(e.$t(`suno.gender.female`)),1)]),_:1}),o(p,{value:`m`},{default:_(()=>[i(l(e.$t(`suno.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Nn=W(kn,[[`render`,Mn]]),Pn=r({name:`AdvancedParams`,components:{ElCollapse:ne,ElCollapseItem:te,ElInput:G,ElSlider:se,ElRadioGroup:R,ElRadioButton:L},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){let e=this.config?.model||``;return[`chirp-v5`,`chirp-v5-5`].includes(e)},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_weight:e})}},lyricsMode:{get(){return this.$store.state.suno?.config?.lyrics_mode||`manual`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyrics_mode:e})}}},mounted(){let e=this.$store.state.suno?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.style_influence==`number`&&e.style_influence>1&&(t.style_influence=e.style_influence/100),typeof e.audio_weight==`number`&&e.audio_weight>1&&(t.audio_weight=e.audio_weight/100),Object.keys(t).length>0&&this.$store.commit(`suno/setConfig`,{...e,...t})}}),Fn={key:0,class:`mb-3`},In={class:`flex items-center mb-1`},Ln={class:`text-xs font-bold`},Rn={key:1,class:`mb-3`},zn={class:`flex items-center mb-1`},Bn={class:`text-xs font-bold`},Vn={key:2,class:`mb-3`},Hn={class:`flex items-center justify-between mb-1`},Un={class:`text-xs font-bold`},Wn={class:`text-xs text-[var(--el-text-color-secondary)]`},Gn={key:3,class:`mb-3`},Kn={class:`flex items-center justify-between mb-1`},qn={class:`text-xs font-bold`},Jn={class:`text-xs text-[var(--el-text-color-secondary)]`},Yn={key:4,class:`mb-3`},Xn={class:`flex items-center mb-1`},Zn={class:`text-xs font-bold`},Qn={key:5,class:`mb-3`},$n={class:`flex items-center justify-between mb-1`},er={class:`text-xs font-bold`},tr={class:`text-xs text-[var(--el-text-color-secondary)]`},nr={key:6,class:`mb-3`},rr={class:`flex items-center mb-1`},ir={class:`text-xs font-bold`};function ar(e,r,s,c,d,f){let p=g(`el-input`),h=g(`el-slider`),v=g(`el-radio-button`),y=g(`el-radio-group`),b=g(`el-collapse-item`),x=g(`el-collapse`);return u(),a(x,{modelValue:e.activeNames,"onUpdate:modelValue":r[7]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:_(()=>[o(b,{title:e.$t(`suno.name.advancedParams`),name:`advanced`},{default:_(()=>[e.config?.custom?(u(),t(`div`,Fn,[n(`div`,In,[n(`span`,Ln,l(e.$t(`suno.name.styleNegative`)),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`suno.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,Rn,[n(`div`,zn,[n(`span`,Bn,l(e.$t(`suno.name.lyricPrompt`)),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Vn,[n(`div`,Hn,[n(`span`,Un,l(e.$t(`suno.name.weirdness`)),1),n(`span`,Wn,l(e.weirdness??0),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Gn,[n(`div`,Kn,[n(`span`,qn,l(e.$t(`suno.name.styleInfluence`)),1),n(`span`,Jn,l(e.styleInfluence??.5),1)]),o(h,{modelValue:e.styleInfluence,"onUpdate:modelValue":r[3]||=t=>e.styleInfluence=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.isV5OrAbove?(u(),t(`div`,Yn,[n(`div`,Xn,[n(`span`,Zn,l(e.$t(`suno.name.variationCategory`)),1)]),o(y,{modelValue:e.variationCategory,"onUpdate:modelValue":r[4]||=t=>e.variationCategory=t,size:`small`},{default:_(()=>[o(v,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(v,{value:`high`},{default:_(()=>[i(l(e.$t(`suno.variation.high`)),1)]),_:1}),o(v,{value:`low`},{default:_(()=>[i(l(e.$t(`suno.variation.low`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),e.config?.action===`cover`?(u(),t(`div`,Qn,[n(`div`,$n,[n(`span`,er,l(e.$t(`suno.name.audioWeight`)),1),n(`span`,tr,l(e.audioWeight??.5),1)]),o(h,{modelValue:e.audioWeight,"onUpdate:modelValue":r[5]||=t=>e.audioWeight=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,nr,[n(`div`,rr,[n(`span`,ir,l(e.$t(`suno.name.lyricsMode`)),1)]),o(y,{modelValue:e.lyricsMode,"onUpdate:modelValue":r[6]||=t=>e.lyricsMode=t,size:`small`},{default:_(()=>[o(v,{value:`manual`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.manual`)),1)]),_:1}),o(v,{value:`auto`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.auto`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0)]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var or=W(Pn,[[`render`,ar],[`__scopeId`,`data-v-363599d3`]]),sr=r({name:`ReplaceSectionInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},replaceSectionStart:{get(){return this.$store.state.suno?.config?.replace_section_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.suno?.config?.replace_section_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),cr={class:`field`},lr={class:`flex items-center mb-2`},ur={class:`text-sm font-bold m-0`},dr={key:0,class:`task mb-2`},fr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},pr={class:`info flex-1 min-w-0`},mr={class:`text-sm font-bold m-0 truncate`},hr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},gr={class:`flex gap-2`};function _r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,cr,[n(`div`,lr,[n(`h2`,ur,l(e.$t(`suno.name.replaceSection`)),1),o(d,{content:e.$t(`suno.description.replaceSection`)},null,8,[`content`])]),e.audio?(u(),t(`div`,dr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,fr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,pr,[n(`h2`,mr,l(e.audio?.title),1),n(`p`,hr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,gr,[o(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":r[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":r[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var vr=W(sr,[[`render`,_r]]),yr=r({name:`OverpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},overpaintingStart:{get(){return this.$store.state.suno?.config?.overpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_start:e})}},overpaintingEnd:{get(){return this.$store.state.suno?.config?.overpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),br={class:`field`},xr={class:`flex items-center mb-2`},Sr={class:`text-sm font-bold m-0`},Cr={key:0,class:`task mb-2`},wr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Tr={class:`info flex-1 min-w-0`},Er={class:`text-sm font-bold m-0 truncate`},Dr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Or={class:`flex gap-2`};function kr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,br,[n(`div`,xr,[n(`h2`,Sr,l(e.$t(`suno.name.overpaintingRange`)),1),o(d,{content:e.$t(`suno.description.overpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Cr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,wr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Tr,[n(`h2`,Er,l(e.audio?.title),1),n(`p`,Dr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Or,[o(_,{modelValue:e.overpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.overpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.overpaintingEnd=t,class:`flex-1`,size:`small`,min:e.overpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Ar=W(yr,[[`render`,kr]]),jr=r({name:`UnderpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},underpaintingStart:{get(){return this.$store.state.suno?.config?.underpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_start:e})}},underpaintingEnd:{get(){return this.$store.state.suno?.config?.underpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Mr={class:`field`},Nr={class:`flex items-center mb-2`},Pr={class:`text-sm font-bold m-0`},Fr={key:0,class:`task mb-2`},Ir={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Lr={class:`info flex-1 min-w-0`},Rr={class:`text-sm font-bold m-0 truncate`},zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Br={class:`flex gap-2`};function Vr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Mr,[n(`div`,Nr,[n(`h2`,Pr,l(e.$t(`suno.name.underpaintingRange`)),1),o(d,{content:e.$t(`suno.description.underpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Fr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Ir,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Lr,[n(`h2`,Rr,l(e.audio?.title),1),n(`p`,zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Br,[o(_,{modelValue:e.underpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.underpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.underpaintingEnd=t,class:`flex-1`,size:`small`,min:e.underpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Hr=W(jr,[[`render`,Vr]]),Ur=r({name:`SamplesInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},samplesStart:{get(){return this.$store.state.suno?.config?.samples_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_start:e})}},samplesEnd:{get(){return this.$store.state.suno?.config?.samples_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Wr={class:`field`},Gr={class:`flex items-center mb-2`},Kr={class:`text-sm font-bold m-0`},qr={key:0,class:`task mb-2`},Jr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Yr={class:`info flex-1 min-w-0`},Xr={class:`text-sm font-bold m-0 truncate`},Zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Qr={class:`flex gap-2`};function $r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Wr,[n(`div`,Gr,[n(`h2`,Kr,l(e.$t(`suno.name.samplesRange`)),1),o(d,{content:e.$t(`suno.description.samples`)},null,8,[`content`])]),e.audio?(u(),t(`div`,qr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Jr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Yr,[n(`h2`,Xr,l(e.audio?.title),1),n(`p`,Zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Qr,[o(_,{modelValue:e.samplesStart,"onUpdate:modelValue":r[1]||=t=>e.samplesStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.samplesEnd,"onUpdate:modelValue":r[2]||=t=>e.samplesEnd=t,class:`flex-1`,size:`small`,min:e.samplesStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var ei=W(Ur,[[`render`,$r]]),ti=[.5,.75,1,1.25,1.5,2],ni=r({name:`AdjustSpeedInput`,components:{ElRadioGroup:R,ElRadioButton:L,ElImage:P,InfoIcon:Q},data(){return{options:ti}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){let e=this.$store.state.suno?.config?.speed;return typeof e==`number`?e:1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),ri={class:`field`},ii={class:`flex items-center mb-2`},ai={class:`text-sm font-bold m-0`},oi={key:0,class:`task mb-2`},si={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},ci={class:`info flex-1 min-w-0`},li={class:`text-sm font-bold m-0 truncate`},ui={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`};function di(r,c,d,p,v,y){let b=g(`info-icon`),x=g(`el-image`),S=g(`el-radio-button`),C=g(`el-radio-group`),w=h(`loading`);return u(),t(`div`,ri,[n(`div`,ii,[n(`h2`,ai,l(r.$t(`suno.name.adjustSpeed`)),1),o(b,{content:r.$t(`suno.description.adjustSpeed`)},null,8,[`content`])]),r.audio?(u(),t(`div`,oi,[n(`div`,{class:`audio flex items-center`,onClick:c[0]||=e=>r.onClick(r.audio)},[f((u(),t(`div`,si,[o(x,{src:r.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[w,!r.audio?.audio_url]]),n(`div`,ci,[n(`h2`,li,l(r.audio?.title),1),n(`p`,ui,l(r.audio?.style),1)])])])):m(``,!0),o(C,{modelValue:r.speed,"onUpdate:modelValue":c[1]||=e=>r.speed=e,size:`small`,class:`speed-group`},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(S,{key:e,value:e},{default:_(()=>[i(l(e)+`x`,1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])])}var fi=W(ni,[[`render`,di],[`__scopeId`,`data-v-ba834628`]]),pi=r({name:`VoiceCreateDialog`,components:{ElDialog:K,ElForm:j,ElFormItem:A,ElInput:G,ElButton:b,ElRadioGroup:R,ElRadio:ee},props:{modelValue:{type:Boolean,default:!1}},emits:[`update:modelValue`,`created`],data(){return{sourceType:`song`,form:{name:``,description:``,audio_id:``,audio_url:``},loading:!1}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit(`update:modelValue`,e)}},token(){return this.$store.state.suno?.credential?.token},canSubmit(){return!(!this.form.name||this.sourceType===`song`&&!this.form.audio_id||this.sourceType===`upload`&&!this.form.audio_url)}},methods:{onClose(){this.visible=!1,this.resetForm()},resetForm(){this.form={name:``,description:``,audio_id:``,audio_url:``},this.sourceType=`song`},async onSubmit(){if(this.token){this.loading=!0;try{this.sourceType===`song`?await Y.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await Y.voices({audio_url:this.form.audio_url,name:this.form.name,description:this.form.description},{token:this.token}),J.success(this.$t(`suno.voice.createSuccess`)),this.$emit(`created`),this.onClose()}catch{J.error(this.$t(`suno.voice.createFailed`))}finally{this.loading=!1}}}}});function mi(e,t,n,r,s,c){let d=g(`el-input`),f=g(`el-form-item`),p=g(`el-radio`),h=g(`el-radio-group`),v=g(`el-form`),y=g(`el-button`),b=g(`el-dialog`);return u(),a(b,{modelValue:e.visible,"onUpdate:modelValue":t[5]||=t=>e.visible=t,title:e.$t(`suno.voice.createTitle`),width:`480px`,"close-on-click-modal":!1,onClose:e.onClose},{footer:_(()=>[o(y,{onClick:e.onClose},{default:_(()=>[i(l(e.$t(`common.button.cancel`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:_(()=>[i(l(e.$t(`suno.voice.create`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])]),default:_(()=>[o(v,{"label-position":`top`,class:`voice-create-form`},{default:_(()=>[o(f,{label:e.$t(`suno.voice.name`)},{default:_(()=>[o(d,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||=t=>e.form.name=t,placeholder:e.$t(`suno.voice.namePlaceholder`),maxlength:`50`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.description`)},{default:_(()=>[o(d,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||=t=>e.form.description=t,type:`textarea`,rows:2,placeholder:e.$t(`suno.voice.descriptionPlaceholder`),maxlength:`200`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.sourceType`)},{default:_(()=>[o(h,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||=t=>e.sourceType=t,class:`w-full`},{default:_(()=>[o(p,{value:`song`},{default:_(()=>[i(l(e.$t(`suno.voice.fromSong`)),1)]),_:1}),o(p,{value:`upload`},{default:_(()=>[i(l(e.$t(`suno.voice.fromUpload`)),1)]),_:1})]),_:1},8,[`modelValue`])]),_:1},8,[`label`]),e.sourceType===`song`?(u(),a(f,{key:0,label:e.$t(`suno.voice.audioId`)},{default:_(()=>[o(d,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||=t=>e.form.audio_id=t,placeholder:e.$t(`suno.voice.audioIdPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0),e.sourceType===`upload`?(u(),a(f,{key:1,label:e.$t(`suno.voice.audioUrl`)},{default:_(()=>[o(d,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||=t=>e.form.audio_url=t,placeholder:e.$t(`suno.voice.audioUrlPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0)]),_:1})]),_:1},8,[`modelValue`,`title`,`onClose`])}var hi=r({name:`VoiceManager`,components:{ElButton:b,ElIcon:w,ElTabs:O,ElTabPane:k,ElTooltip:N,Loading:x,FontAwesomeIcon:Z,VoiceCreateDialog:W(pi,[[`render`,mi]])},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:`all`}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab===`favorites`?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch(`suno/getPersonas`)}finally{this.loading=!1}}},selectPersona(e){let t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch(`suno/setConfig`,t)},async onDelete(e){try{await q.confirm(this.$t(`suno.voice.confirmDelete`),this.$t(`suno.voice.delete`),{type:`warning`,confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`)})}catch{return}if(!e.persona_id)return;this.deletingId=e.persona_id;let t=await this.$store.dispatch(`suno/deletePersona`,e.persona_id);if(this.deletingId=null,t){if(J.success(this.$t(`suno.voice.deleteSuccess`)),this.selectedPersonaId===e.persona_id){let e={...this.$store.state.suno?.config,persona_id:void 0};this.$store.dispatch(`suno/setConfig`,e)}this.favoriteIds.includes(e.persona_id)&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)}else J.error(this.$t(`suno.voice.deleteFailed`))},async onCreated(){await this.loadPersonas()}}}),gi={class:`voice-manager`},_i={class:`flex items-center justify-between mb-3`},vi={class:`text-sm font-medium`},yi={key:0,class:`text-center py-6`},bi={key:1,class:`text-center py-6 text-gray-400 text-sm`},xi={key:2,class:`voice-list`},Si=[`onClick`],Ci={class:`flex-1 min-w-0`},wi={class:`voice-name`},Ti={key:0,class:`voice-desc`};function Ei(r,a,f,p,h,v){let y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-tab-pane`),S=g(`el-tabs`),C=g(`loading`),w=g(`el-icon`),T=g(`el-tooltip`),E=g(`voice-create-dialog`);return u(),t(`div`,gi,[n(`div`,_i,[n(`span`,vi,l(r.$t(`suno.voice.title`)),1),o(b,{type:`primary`,size:`small`,onClick:a[0]||=e=>r.showCreateDialog=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-plus`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.create`)),1)]),_:1})]),o(S,{modelValue:r.activeTab,"onUpdate:modelValue":a[1]||=e=>r.activeTab=e,class:`voice-tabs`,size:`small`},{default:_(()=>[o(x,{name:`all`,label:r.$t(`suno.voice.tabAll`)+` (`+(r.personas?.length||0)+`)`},null,8,[`label`]),o(x,{name:`favorites`,label:r.$t(`suno.voice.tabFavorites`)+` (`+r.favoritePersonas.length+`)`},null,8,[`label`])]),_:1},8,[`modelValue`]),r.loading?(u(),t(`div`,yi,[o(w,{class:`is-loading`},{default:_(()=>[o(C)]),_:1})])):r.visiblePersonas.length===0?(u(),t(`div`,bi,l(r.activeTab===`favorites`?r.$t(`suno.voice.emptyFavorites`):r.$t(`suno.voice.empty`)),1)):(u(),t(`div`,xi,[(u(!0),t(s,null,e(r.visiblePersonas,e=>(u(),t(`div`,{key:e.persona_id,class:c([`voice-item`,{active:r.selectedPersonaId===e.persona_id}]),onClick:t=>r.selectPersona(e)},[n(`div`,Ci,[n(`div`,wi,[o(y,{icon:e.source_type===`voice`?`fa-solid fa-microphone`:`fa-solid fa-music`,class:`mr-1.5 text-xs opacity-60`},null,8,[`icon`]),i(` `+l(e.name||e.persona_id),1)]),e.description?(u(),t(`div`,Ti,l(e.description),1)):m(``,!0)]),n(`div`,{class:`voice-actions`,onClick:a[2]||=d(()=>{},[`stop`])},[o(T,{content:r.isFavorite(e.persona_id)?r.$t(`suno.voice.unfavorite`):r.$t(`suno.voice.favorite`),placement:`top`},{default:_(()=>[o(b,{size:`small`,text:``,class:c({"voice-fav-active":r.isFavorite(e.persona_id)}),onClick:t=>r.onToggleFavorite(e)},{default:_(()=>[o(y,{icon:r.isFavorite(e.persona_id)?`fa-solid fa-star`:`fa-regular fa-star`},null,8,[`icon`])]),_:2},1032,[`class`,`onClick`])]),_:2},1032,[`content`]),o(b,{type:`danger`,size:`small`,text:``,loading:r.deletingId===e.persona_id,onClick:t=>r.onDelete(e)},{default:_(()=>[o(y,{icon:`fa-solid fa-trash`})]),_:1},8,[`loading`,`onClick`])])],10,Si))),128))])),o(E,{modelValue:r.showCreateDialog,"onUpdate:modelValue":a[3]||=e=>r.showCreateDialog=e,onCreated:r.onCreated},null,8,[`modelValue`,`onCreated`])])}var Di=r({name:`PersonaInput`,components:{ElSelect:E,ElOption:D,ElButton:b,ElDrawer:z,FontAwesomeIcon:Z,InfoIcon:Q,VoiceManager:W(hi,[[`render`,Ei],[`__scopeId`,`data-v-8b8e36d9`]])},data(){return{showManager:!1}},computed:{personaId:{get(){return this.$store.state.suno?.config?.persona_id||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,persona_id:e||void 0})}},personas(){return this.$store.state.suno?.personas||[]}}}),Oi={class:`field`},ki={class:`flex items-center justify-between mb-2`},Ai={class:`flex items-center`},ji={class:`text-sm font-bold`},Mi={class:`flex items-center justify-between w-full`},Ni={key:0,class:`text-xs text-gray-400 ml-2`};function Pi(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-option`),S=g(`el-select`),C=g(`voice-manager`),w=g(`el-drawer`);return u(),t(`div`,Oi,[n(`div`,ki,[n(`div`,Ai,[n(`span`,ji,l(r.$t(`suno.name.persona`)),1),o(v,{content:r.$t(`suno.description.persona`)},null,8,[`content`])]),o(b,{size:`small`,round:``,onClick:c[0]||=e=>r.showManager=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.manage`)),1)]),_:1})]),o(S,{modelValue:r.personaId,"onUpdate:modelValue":c[1]||=e=>r.personaId=e,placeholder:r.$t(`suno.placeholder.personaId`),clearable:``,filterable:``,class:`w-full`},{default:_(()=>[(u(!0),t(s,null,e(r.personas,e=>(u(),a(x,{key:e.persona_id||``,value:e.persona_id||``,label:e.name||e.persona_id||``},{default:_(()=>[n(`div`,Mi,[n(`span`,null,l(e.name||e.persona_id),1),e.source_type?(u(),t(`span`,Ni,l(e.source_type),1)):m(``,!0)])]),_:2},1032,[`value`,`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`]),o(w,{modelValue:r.showManager,"onUpdate:modelValue":c[2]||=e=>r.showManager=e,title:r.$t(`suno.voice.title`),size:`380px`,direction:`rtl`},{default:_(()=>[o(C)]),_:1},8,[`modelValue`,`title`])])}var Fi=r({name:`PresetPanel`,components:{TypeSelector:Ge,PromptInput:St,LyricInput:It,StyleInput:Xt,TitleInput:nn,ExtendFromInput:gn,CoverFromInput:On,UploadAudio:mt,VocalGenderSelector:Nn,AdvancedParams:or,ReplaceSectionInput:vr,OverpaintingInput:Ar,UnderpaintingInput:Hr,SamplesInput:ei,AdjustSpeedInput:fi,PersonaInput:W(Di,[[`render`,Pi]]),FontAwesomeIcon:Z,ElButton:b,ElTabs:O,ElTabPane:k,Consumption:we},emits:[`generate`],computed:{config(){return this.$store.state.suno?.config},mode:{get(){return this.$store.state.suno?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e===`custom`})}},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){let e=this.config?.model||``;return[`chirp-v4-5-plus`,`chirp-v5`,`chirp-v5-5`].includes(e)},supportsPersona(){let e=this.config?.action;return!e||e===`generate`||e===`artist_consistency`||e===`artist_consistency_vox`},generateButtonText(){let e=this.config?.action;return e===`extend`?this.$t(`suno.button.extend`):e===`cover`?this.$t(`suno.button.cover_music`):e===`remaster`?this.$t(`suno.button.remaster`):e===`replace_section`?this.$t(`suno.button.replace_section`):e===`mashup`?this.$t(`suno.button.mashup`):e===`stems`?this.$t(`suno.button.get_stems`):e===`concat`?this.$t(`suno.button.concat_music`):e===`upload_cover`?this.$t(`suno.button.upload_cover`):e===`artist_consistency`?this.$t(`suno.button.artist_consistency`):e===`artist_consistency_vox`?this.$t(`suno.button.artist_consistency_vox`):e===`overpainting`?this.$t(`suno.button.overpainting`):e===`underpainting`?this.$t(`suno.button.underpainting`):e===`samples`?this.$t(`suno.button.samples`):e===`adjust_speed`?this.$t(`suno.button.adjust_speed`):this.$t(`suno.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`suno/setConfig`,{custom:!1,sounds:!1,instrumental:!1,lyric:``,style:``,title:``,lyrics_mode:`manual`,model:this.$store.state.suno?.config?.model})}}}),Ii={class:`flex flex-col h-full`},Li={class:`flex-1 overflow-y-auto p-5`},Ri={class:`pt-2 px-1`},zi={class:`pt-2 px-1`},Bi={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Vi={class:`flex gap-2 w-full`};function Hi(e,r,s,c,d,f){let p=g(`type-selector`),h=g(`upload-audio`),v=g(`prompt-input`),y=g(`extend-from-input`),b=g(`cover-from-input`),x=g(`replace-section-input`),S=g(`overpainting-input`),C=g(`underpainting-input`),w=g(`samples-input`),T=g(`adjust-speed-input`),E=g(`advanced-params`),D=g(`el-tab-pane`),O=g(`lyric-input`),k=g(`style-input`),A=g(`title-input`),j=g(`vocal-gender-selector`),M=g(`persona-input`),N=g(`el-tabs`),P=g(`consumption`),F=g(`font-awesome-icon`),I=g(`el-button`);return u(),t(`div`,Ii,[n(`div`,Li,[o(N,{modelValue:e.mode,"onUpdate:modelValue":r[0]||=t=>e.mode=t,class:`suno-mode-tabs`,stretch:``},{default:_(()=>[o(D,{label:e.$t(`suno.mode.simple`),name:`simple`},{default:_(()=>[n(`div`,Ri,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),o(v,{class:`mb-4`}),e.config?.action===`extend`?(u(),a(y,{key:0,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:1,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:6,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`]),o(D,{label:e.$t(`suno.mode.custom`),name:`custom`},{default:_(()=>[n(`div`,zi,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),e.config?.instrumental?m(``,!0):(u(),a(O,{key:0,class:`mb-4`})),o(k,{class:`mb-4`}),o(A,{class:`mb-4`}),!e.config?.instrumental&&e.supportsVocalGender?(u(),a(j,{key:1,class:`mb-4`})):m(``,!0),e.supportsPersona?(u(),a(M,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(u(),a(y,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:6,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:7,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:8,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:9,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Bi,[o(P,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Vi,[o(I,{class:`flex-1`,onClick:e.onClearAll},{default:_(()=>[o(F,{icon:`fa-solid fa-broom`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_all`)),1)]),_:1},8,[`onClick`]),o(I,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:_(()=>[o(F,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Ui=W(Fi,[[`render`,Hi],[`__scopeId`,`data-v-c62324e6`]]),Wi=Te(),Gi=ue(`suno`),Ki=r({name:`TaskPreview`,components:{ElImage:P,ElIcon:w,ElTooltip:N,FontAwesomeIcon:Z,VideoPlay:S,VideoPause:C,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElInput:G,ElProgress:ie,ElCheckbox:I,Loading:x,ApiCodeDialog:be},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:``,apiCodeVisible:!1,apiCodePath:`/suno/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){let e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(e=>({...e,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action===`mashup`},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:$,onViewCode(){let e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([e,n])=>{e===`application_id`||e===`callback_url`||n!=null&&(typeof n==`string`&&n===``||Array.isArray(n)&&n.length===0||(t[e]=n))}),this.apiCodeBody=t,this.apiCodePath=`/suno/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.log(`on extend`),console.debug(`set config`,t),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:`extend`,audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e?.stopPropagation(),console.log(`on download`,t);let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);console.log(`on preview`,r),fetch(t).then(e=>e.blob()).then(e=>{(0,Wi.saveAs)(e,r)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;let t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(e){console.error(`get videoUrl failed:`,e),J.error(this.$t(`suno.message.getVideoUrlFailed`))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,n)=>{let r={audio_id:e},i=this.credential?.token;if(!i){console.error(`no token specified`),n(Error(`No token specified`));return}Y.mp4(r,{token:i}).then(e=>{let r=e.data?.data?.video_url;r?t(r):n(Error(`Video URL not found in response`))}).catch(e=>{n(e)})})},onPreview(e,t){e?.stopPropagation(),console.log(`on preview`,t),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){console.log(`on cover`),console.debug(`set config`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl(`concat`,e)},async onRemaster(e){await this.onGenerateAudioUrl(`remaster`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`replace_section`,audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`mashup`,audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`overpainting`,audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`underpainting`,audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`samples`,audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`artist_consistency`,audio:e,audio_id:e.id})},onAdjustSpeed(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`adjust_speed`,audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){let t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){J.warning(this.$t(`suno.message.reusePromptEmpty`));return}this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??``,lyric:t.lyric??``,lyric_prompt:t.lyric_prompt??``,lyrics_mode:t.lyrics_mode??`manual`,title:t.title??``,style:t.style??``,style_negative:t.style_negative??``,vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),J.success(this.$t(`suno.message.reusePromptSuccess`))},async onExtractVocals(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.extractingVocals`)),Y.vox({audio_id:e,callback_url:Gi},{token:t}).then(()=>{J.success(this.$t(`suno.message.extractVocalsSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.extractVocalsFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.fetchingTiming`)),Y.timing({audio_id:e},{token:t}).then(e=>{J.success(this.$t(`suno.message.fetchTimingSuccess`)),console.debug(`timing data`,e.data)}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.fetchTimingFailed`))}))},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,J.info(this.$t(`suno.message.fetchingWav`));let n=(await Y.wav({audio_id:e.id},{token:t})).data?.data?.[0]?.file_url;n?this.onDownload(null,n):J.error(this.$t(`suno.message.fetchWavFailed`))}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;let t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,J.info(this.$t(`suno.message.fetchingMidi`));let n=(await Y.midi({audio_id:e.id},{token:t})).data?.data;if(!n?.length){J.error(this.$t(`suno.message.fetchMidiFailed`));return}let r=(e.title||e.id||`suno`).replace(/[^\w.-]+/g,`_`)+`.json`;(0,Wi.saveAs)(new Blob([JSON.stringify(n,null,2)],{type:`application/json`}),r)}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchMidiFailed`))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Gi},r=this.credential?.token;if(!r){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),Y.audio(n,{token:r}).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},isMashupSelected(e){return!!e.id&&this.mashupAudioIds.includes(e.id)},onToggleMashup(e){if(!e.id)return;let t=[...this.mashupAudioIds],n=t.indexOf(e.id);n===-1?t.push(e.id):t.splice(n,1),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,mashup_audio_ids:t})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},onStartTitleEdit(e){this.editingAudioId=e.id??null,this.editingTitle=e.title||``,this.$nextTick(()=>{this.$refs.titleInput?.focus?.()})},onSaveTitleEdit(e){if(this.editingAudioId!==e.id)return;let t=this.editingTitle.trim();if(t&&t!==e.title){let n=this.$store.state.suno?.tasks;if(n?.items)for(let r of n.items){let n=(r?.response?.data??[]).find(t=>t.id===e.id);if(n){n.title=t;break}}}this.editingAudioId=null,this.editingTitle=``},onCancelTitleEdit(){this.editingAudioId=null,this.editingTitle=``},async onDelete(e){try{await q.confirm(this.$t(`suno.message.confirmDelete`),{confirmButtonText:this.$t(`suno.button.delete`),cancelButtonText:this.$t(`common.button.cancel`),type:`warning`})}catch{return}let t=this.$store.state.suno?.tasks;if(t?.items)for(let n of t.items){let r=n?.response?.data??[],i=r.findIndex(t=>t.id===e.id);if(i!==-1){if(r.splice(i,1),r.length===0){let e=t.items.indexOf(n);e!==-1&&t.items.splice(e,1)}break}}this.$store.state?.suno?.audio?.id===e.id&&this.$store.dispatch(`suno/setAudio`,null),J.success(this.$t(`suno.message.deleteSuccess`))},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`suno/getTasks`,{limit:30,offset:0})}}}),qi={class:`task`},Ji=[`onClick`],Yi=[`onClick`],Xi={class:`left`},Zi=[`onClick`],Qi=[`onClick`],$i={key:2,class:`duration`},ea={class:`info`},ta={key:1,class:`title-row`},na={class:`title`},ra={class:`style`},ia={key:2,class:`progress-row`},aa={class:`progress-text`},oa={class:`right`},sa={class:`el-dropdown-link`},ca={class:`flex items-center min-w-[120px]`},la={class:`flex items-center min-w-[120px]`},ua={class:`flex items-center min-w-[120px]`},da={class:`el-dropdown-link`};function fa(r,p,v,b,x,S){let C=g(`el-checkbox`),w=g(`el-image`),T=g(`video-pause`),E=g(`el-icon`),D=g(`video-play`),O=g(`el-input`),k=g(`font-awesome-icon`),A=g(`el-progress`),j=g(`el-tooltip`),M=g(`Loading`),N=g(`el-dropdown-item`),P=g(`el-dropdown-menu`),F=g(`el-dropdown`),I=g(`api-code-dialog`),L=h(`loading`);return u(),t(`div`,qi,[(u(!0),t(s,null,e(r.audios,e=>(u(),t(`div`,{key:e.id,class:c([`audio`,{"mashup-selected":r.isMashupSelected(e)}]),onClick:d(t=>r.onClick(e),[`stop`])},[r.isMashupMode&&e?.audio_url?(u(),t(`div`,{key:0,class:`mashup-check`,onClick:d(t=>r.onToggleMashup(e),[`stop`])},[o(C,{"model-value":r.isMashupSelected(e),onClick:p[0]||=d(()=>{},[`stop`])},null,8,[`model-value`])],8,Yi)):m(``,!0),f((u(),t(`div`,Xi,[o(w,{src:e?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),e?.audio_url&&r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:d(t=>r.onPause(e),[`stop`])},[o(E,null,{default:_(()=>[o(T)]),_:1})],8,Zi)):m(``,!0),e?.audio_url&&(r.$store.state?.suno?.audio?.id!==e.id||r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:d(t=>r.onPlay(e),[`stop`])},[o(E,null,{default:_(()=>[o(D)]),_:1})],8,Qi)):m(``,!0),e?.duration?(u(),t(`div`,$i,l(r.useFormatDuring(e?.duration)),1)):m(``,!0)])),[[L,!e?.audio_url]]),n(`div`,ea,[r.editingAudioId===e.id?(u(),t(`div`,{key:0,class:`title-edit`,onClick:p[2]||=d(()=>{},[`stop`])},[o(O,{ref_for:!0,ref:`titleInput`,modelValue:r.editingTitle,"onUpdate:modelValue":p[1]||=e=>r.editingTitle=e,size:`small`,onKeyup:[y(t=>r.onSaveTitleEdit(e),[`enter`]),y(r.onCancelTitleEdit,[`escape`])],onBlur:t=>r.onSaveTitleEdit(e)},null,8,[`modelValue`,`onKeyup`,`onBlur`])])):(u(),t(`div`,ta,[n(`h2`,na,l(e?.title),1),e?.audio_url?(u(),a(k,{key:0,icon:`fa-solid fa-pen`,class:`edit-icon`,onClick:d(t=>r.onStartTitleEdit(e),[`stop`])},null,8,[`onClick`])):m(``,!0)])),n(`p`,ra,l(e?.style),1),!e?.audio_url&&e?.progress!=null&&e?.progress<100?(u(),t(`div`,ia,[o(A,{percentage:Math.round(e.progress),"stroke-width":4,"show-text":!1,status:`warning`,class:`progress-bar`},null,8,[`percentage`]),n(`span`,aa,l(r.$t(`suno.name.generating`))+` `+l(Math.round(e.progress))+`%`,1)])):m(``,!0)]),n(`div`,oa,[o(F,null,{dropdown:_(()=>[o(P,null,{default:_(()=>[o(N,{disabled:r.isFetchingVideoUrl,onClick:t=>r.handleVideoDownload(e)},{default:_(()=>[n(`div`,ca,[r.isFetchingVideoUrl?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onDownload(t,e?.audio_url),[`stop`])},{default:_(()=>[i(l(r.$t(`suno.button.download_audio`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{disabled:r.isFetchingWav,onClick:t=>r.handleWavDownload(e)},{default:_(()=>[n(`div`,la,[r.isFetchingWav?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`]),o(N,{disabled:r.isFetchingMidi,onClick:t=>r.handleMidiDownload(e)},{default:_(()=>[n(`div`,ua,[r.isFetchingMidi?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_midi`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:_(()=>[n(`span`,sa,[o(j,{effect:`dark`,content:r.$t(`suno.button.download`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),o(F,null,{dropdown:_(()=>[o(P,{class:`suno-action-menu`},{default:_(()=>[e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onExtend(t,e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-forward`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extend`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(t=>r.onCover(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-music`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.cover_music`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:1,onClick:d(t=>r.onMashup(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-shuffle`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.mashup`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id&&e?.action===`extend`?(u(),a(N,{key:2,onClick:d(t=>r.onConcatMusic(e?.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-link`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.concat_music`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[4]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:3,onClick:d(t=>r.onReplaceSection(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-scissors`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.replace_section`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:4,onClick:d(t=>r.onOverpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-microphone`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.overpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:5,onClick:d(t=>r.onUnderpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-guitar`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.underpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:6,onClick:d(t=>r.onSamples(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-drum`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.samples`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[5]||=n(`div`,{class:`menu-divider`},null,-1),e.id?(u(),a(N,{key:7,onClick:d(t=>r.onGetStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-layer-group`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.id?(u(),a(N,{key:8,onClick:d(t=>r.onGetAllStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-bars-staggered`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.all_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:9,onClick:d(t=>r.onRemaster(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-wand-magic-sparkles`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.remaster`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:10,onClick:d(t=>r.onExtractVocals(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-headphones`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extract_vocals`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:11,onClick:d(t=>r.onArtistConsistency(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-palette`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.artist_consistency`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:12,onClick:d(t=>r.onAdjustSpeed(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-gauge-high`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.adjust_speed`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[6]||=n(`div`,{class:`menu-divider`},null,-1),o(N,{onClick:d(t=>r.onReusePrompt(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-rotate-left`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.reuse_prompt`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:13,onClick:d(t=>r.onGetTiming(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-clock`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_timing`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(r.onViewCode,[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-code`,class:`menu-icon`}),i(` `+l(r.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`]),p[7]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:14,class:`delete-item`,onClick:d(t=>r.onDelete(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-trash`,class:`menu-icon delete-icon`}),i(` `+l(r.$t(`suno.button.delete`)),1)]),_:1},8,[`onClick`])):m(``,!0)]),_:2},1024)]),default:_(()=>[n(`span`,da,[o(j,{effect:`dark`,content:r.$t(`suno.button.more`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],10,Ji))),128)),o(I,{visible:r.apiCodeVisible,"onUpdate:visible":p[3]||=e=>r.apiCodeVisible=e,method:`POST`,path:r.apiCodePath,body:r.apiCodeBody,token:r.$store.state.suno?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var pa=r({name:`RecentPanel`,components:{ElSkeletonItem:ae,ElSkeleton:oe,ElInput:G,ElButton:b,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElPopover:re,ElRadioGroup:R,ElRadioButton:L,ElSelect:E,ElOption:D,FontAwesomeIcon:Z,TaskPreview:W(Ki,[[`render`,fa]]),Player:Ee,NoTasks:Ce,ScrollList:ye},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0,searchQuery:``,sortBy:`newest`,filterType:`all`,filterDuration:`all`,filterVideo:`all`,filterModel:`all`}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}},sortLabel(){return this.sortBy===`newest`?this.$t(`suno.sort.newest`):this.$t(`suno.sort.oldest`)},activeFilterCount(){let e=0;return this.filterType!==`all`&&e++,this.filterDuration!==`all`&&e++,this.filterVideo!==`all`&&e++,this.filterModel&&this.filterModel!==`all`&&e++,e},availableModels(){let e=this.tasks?.items||[],t=new Set;for(let n of e){let e=n?.response?.data??[];for(let n of e)n.model&&t.add(n.model)}return Array.from(t).sort()},filteredTasks(){let e=this.tasks?.items||[];if(this.searchQuery){let t=this.searchQuery.toLowerCase();e=e.filter(e=>(e?.response?.data??[]).some(e=>e.title?.toLowerCase().includes(t)||e.style?.toLowerCase().includes(t)||e.prompt?.toLowerCase().includes(t)))}return this.activeFilterCount>0&&(e=e.filter(e=>{let t=e?.request??{},n=e?.response?.data??[];return this.filterType===`vocal`&&t.instrumental===!0||this.filterType===`instrumental`&&t.instrumental!==!0?!1:this.filterDuration!==`all`||this.filterVideo!==`all`||this.filterModel&&this.filterModel!==`all`?n.some(e=>!(this.filterDuration===`short`&&!(typeof e.duration==`number`&&e.duration<60)||this.filterDuration===`medium`&&!(typeof e.duration==`number`&&e.duration>=60&&e.duration<=180)||this.filterDuration===`long`&&!(typeof e.duration==`number`&&e.duration>180)||this.filterVideo===`with`&&!e.video_url||this.filterVideo===`without`&&e.video_url||this.filterModel&&this.filterModel!==`all`&&e.model!==this.filterModel)):!0})),this.sortBy===`oldest`&&(e=[...e].reverse()),e}},methods:{onSortChange(e){this.sortBy=e},onResetFilters(){this.filterType=`all`,this.filterDuration=`all`,this.filterVideo=`all`,this.filterModel=`all`},getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ma={key:0,class:`tasks`},ha={class:`left w-[70px] p-[10px] flex items-center`},ga={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},_a={key:0,class:`task-toolbar`},va={key:0,class:`filter-badge`},ya={class:`filter-popover`},ba={class:`filter-row`},xa={class:`filter-label`},Sa={class:`filter-row`},Ca={class:`filter-label`},wa={class:`filter-row`},Ta={class:`filter-label`},Ea={key:0,class:`filter-row`},Da={class:`filter-label`},Oa={class:`filter-actions`},ka={key:2,class:`w-full flex-1 flex items-center justify-center`},Aa={class:`text-sm text-gray-400`},ja={key:3,class:`w-full flex-1 flex flex-col items-center justify-center gap-2`},Ma={class:`text-sm text-gray-400`},Na={key:4,class:`w-full flex-1 flex items-center justify-center`},Pa={class:`h-20`};function Fa(r,d,p,h,y,b){let x=g(`el-skeleton-item`),S=g(`el-skeleton`),C=g(`font-awesome-icon`),w=g(`el-input`),T=g(`el-button`),E=g(`el-dropdown-item`),D=g(`el-dropdown-menu`),O=g(`el-dropdown`),k=g(`el-radio-button`),A=g(`el-radio-group`),j=g(`el-option`),M=g(`el-select`),N=g(`el-popover`),P=g(`task-preview`),F=g(`scroll-list`),I=g(`no-tasks`),L=g(`player`);return u(),t(s,null,[r.tasks?.items===void 0?(u(),t(`div`,ma,[(u(),t(s,null,e(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,ha,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,ga,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),o(x,{variant:`text`})]),_:1})])])),64))])):(u(),t(s,{key:1},[r.tasks?.items?.length?(u(),t(`div`,_a,[o(w,{modelValue:r.searchQuery,"onUpdate:modelValue":d[0]||=e=>r.searchQuery=e,size:`small`,placeholder:r.$t(`suno.placeholder.searchSongs`),clearable:``,class:`task-search`},{prefix:_(()=>[o(C,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs`})]),_:1},8,[`modelValue`,`placeholder`]),o(O,{trigger:`click`,onCommand:r.onSortChange},{dropdown:_(()=>[o(D,null,{default:_(()=>[o(E,{command:`newest`,class:c({"is-active":r.sortBy===`newest`})},{default:_(()=>[i(l(r.$t(`suno.sort.newest`)),1)]),_:1},8,[`class`]),o(E,{command:`oldest`,class:c({"is-active":r.sortBy===`oldest`})},{default:_(()=>[i(l(r.$t(`suno.sort.oldest`)),1)]),_:1},8,[`class`])]),_:1})]),default:_(()=>[o(T,{size:`small`,class:`sort-btn`},{default:_(()=>[o(C,{icon:`fa-solid fa-arrow-down-wide-short`,class:`mr-1`}),i(` `+l(r.sortLabel),1)]),_:1})]),_:1},8,[`onCommand`]),o(N,{trigger:`click`,placement:`bottom-end`,width:260},{reference:_(()=>[o(T,{size:`small`,class:c([`filter-btn`,{"has-active-filter":r.activeFilterCount>0}])},{default:_(()=>[o(C,{icon:`fa-solid fa-filter`,class:`mr-1`}),i(` `+l(r.$t(`suno.filter.title`))+` `,1),r.activeFilterCount>0?(u(),t(`span`,va,l(r.activeFilterCount),1)):m(``,!0)]),_:1},8,[`class`])]),default:_(()=>[n(`div`,ya,[n(`div`,ba,[n(`div`,xa,l(r.$t(`suno.filter.type`)),1),o(A,{modelValue:r.filterType,"onUpdate:modelValue":d[1]||=e=>r.filterType=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.typeAll`)),1)]),_:1}),o(k,{value:`vocal`},{default:_(()=>[i(l(r.$t(`suno.filter.typeVocal`)),1)]),_:1}),o(k,{value:`instrumental`},{default:_(()=>[i(l(r.$t(`suno.filter.typeInstrumental`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,Sa,[n(`div`,Ca,l(r.$t(`suno.filter.duration`)),1),o(A,{modelValue:r.filterDuration,"onUpdate:modelValue":d[2]||=e=>r.filterDuration=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.durationAll`)),1)]),_:1}),o(k,{value:`short`},{default:_(()=>[i(l(r.$t(`suno.filter.durationShort`)),1)]),_:1}),o(k,{value:`medium`},{default:_(()=>[i(l(r.$t(`suno.filter.durationMedium`)),1)]),_:1}),o(k,{value:`long`},{default:_(()=>[i(l(r.$t(`suno.filter.durationLong`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,wa,[n(`div`,Ta,l(r.$t(`suno.filter.video`)),1),o(A,{modelValue:r.filterVideo,"onUpdate:modelValue":d[3]||=e=>r.filterVideo=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.videoAll`)),1)]),_:1}),o(k,{value:`with`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWith`)),1)]),_:1}),o(k,{value:`without`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWithout`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r.availableModels.length>0?(u(),t(`div`,Ea,[n(`div`,Da,l(r.$t(`suno.filter.model`)),1),o(M,{modelValue:r.filterModel,"onUpdate:modelValue":d[4]||=e=>r.filterModel=e,size:`small`,placeholder:r.$t(`suno.filter.modelAll`),clearable:``},{default:_(()=>[o(j,{label:r.$t(`suno.filter.modelAll`),value:`all`},null,8,[`label`]),(u(!0),t(s,null,e(r.availableModels,e=>(u(),a(j,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0),n(`div`,Oa,[o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])])]),_:1})])):m(``,!0),r.filteredTasks?.length>0?(u(),a(F,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:r.loading,onReachTop:d[5]||=e=>r.$emit(`reach-top`)},{default:_(()=>[(u(!0),t(s,null,e(r.filteredTasks,(e,t)=>(u(),a(P,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):r.searchQuery&&r.tasks?.items?.length>0?(u(),t(`div`,ka,[n(`p`,Aa,l(r.$t(`suno.message.noSearchResults`)),1)])):r.activeFilterCount>0&&r.tasks?.items?.length>0?(u(),t(`div`,ja,[n(`p`,Ma,l(r.$t(`suno.message.noFilterResults`)),1),o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])):r.tasks?.items?.length===0?(u(),t(`div`,Na,[o(I)])):m(``,!0)],64)),f(n(`div`,Pa,[o(L,{namespace:`suno`})],512),[[v,!!r.$store?.state?.suno?.audio?.object]])],64)}var Ia=W(pa,[[`render`,Fa],[`__scopeId`,`data-v-6ce376c9`]]),La=r({name:`TaskPreview`,components:{IconPicture:T,ElImage:P,ElAvatar:F,ElIcon:w},computed:{audio(){return this.$store.state.suno?.audio}}}),Ra={key:0,class:`size-full overflow-hidden`},za={class:`relative h-[300px]`},Ba={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},Va={class:`absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent`},Ha={class:`p-4`},Ua={class:`flex items-center font-bold mb-2`},Wa={class:`text-[var(--el-text-color-regular)] mb-2`},Ga={class:`text-xs text-[var(--el-text-color-regular)]`},Ka={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},qa={key:1,class:`w-full h-full`};function Ja(e,r,i,a,s,c){let d=g(`icon-picture`),f=g(`el-icon`),p=g(`el-image`),m=g(`el-avatar`);return e.audio?.object?(u(),t(`div`,Ra,[n(`div`,za,[o(p,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:_(()=>[n(`div`,Ba,[o(f,{class:`text-3xl`},{default:_(()=>[o(d)]),_:1})])]),_:1},8,[`src`]),n(`h2`,Va,l(e.audio?.title),1)]),n(`div`,Ha,[n(`div`,Ua,[o(m,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,l(e.audio?.title),1)]),n(`p`,Wa,l(e.audio?.style),1),n(`p`,Ga,l(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,Ka,[n(`p`,null,l(e.audio?.lyric),1)])])])):(u(),t(`div`,qa))}var Ya=W(La,[[`render`,Ja]]),Xa=ue(`suno`),Za=r({name:`SunoIndex`,components:{Layout:Ne,ConfigPanel:Ui,RecentPanel:Ia,PreviewPanel:Ya},mixins:[fe],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await xe({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`suno/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`suno/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){de.create({application:this.application}).then(({data:e})=>{this.application=e,J.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&J.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`suno/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!he(this.uploadTracker,e=>this.$t(e),e=>J.warning(e)))return;let e={...this.config,callback_url:Xa};if(!this.hasSunoInput(e)){J.error(this.$t(`suno.message.promptRequired`));return}this.hasText(e.prompt)&&(e.prompt=e.prompt.trim());let t=this.credential?.token;if(!t){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),pe(`suno`,Y.audio(e,{token:t})).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0},hasSunoInput(e){return[e.prompt,e.lyric,e.lyric_prompt,e.style,e.title].some(e=>this.hasText(e))||this.hasText(e.audio_id)||Array.isArray(e.mashup_audio_ids)&&e.mashup_audio_ids.length>0}}});function Qa(e,t,n,r,i,s){let c=g(`config-panel`),l=g(`recent-panel`),d=g(`preview-panel`),f=g(`layout`);return u(),a(f,null,{config:_(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:_(()=>[o(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:_(()=>[o(d)]),_:1})}var $a=W(Za,[[`render`,Qa],[`__scopeId`,`data-v-b9beee12`]]);export{$a as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,nt as h,tt as g,ut as _,v,y}from"./vendor-chart-BJCvKk8-.js";import{t as b}from"./button-DfsQodL-.js";import{F as x,X as S,Y as C,tt as w,z as T}from"./use-deprecated-BzKQGDXN.js";import{r as E,t as D}from"./select-B1uV_nnl.js";import{n as O,t as k}from"./tabs-D9l1-5D5.js";import{n as A,t as j}from"./form-DnBQT-zH.js";import{t as M}from"./upload-SS_pZz4k.js";import{t as N}from"./tooltip-BLwTovWL.js";import{t as P}from"./image-BLdTdN6v.js";import{t as F}from"./avatar-CTHa5OEM.js";import{t as I}from"./checkbox-BAeQdLeW.js";import{n as L,r as R,t as ee}from"./radio-BmBXySlN.js";import{n as te,t as ne}from"./collapse-zZjSyR53.js";import{t as z}from"./drawer-Dpuj2uIl.js";import{n as B,r as V,t as H}from"./dropdown-DhpaHW0b.js";import{t as U}from"./input-number-DIoKTD0e.js";import{t as re}from"./popover-DCGISZxg.js";import{t as ie}from"./progress-C3UHYIHi.js";import{n as ae,t as oe}from"./skeleton-C4sltx62.js";import{t as se}from"./slider-DqJsYqiE.js";import{t as ce}from"./switch-BXfqi_p8.js";import{Fn as le,_i as ue}from"./constants-CwLEZ_AF.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-CxBOJBZd.js";import{t as Z}from"./index.es-Dw2lhymn.js";import{n as ve}from"./taskDrawerMixin-DEgO_R5H.js";import{i as Q,n as ye,r as be,t as xe}from"./pagination-DC4Eh4yG.js";import{n as Se,t as Ce}from"./NoTasks-Czm65vJ4.js";import{t as we}from"./Consumption-C3v4xGTO.js";import{n as Te,r as $,t as Ee}from"./Player-C7Zoyb-g.js";var De=r({name:`LayoutSuno`,components:{ElDrawer:z,ElButton:b,FontAwesomeIcon:Z},mixins:[ve],data(){return{preview:!1}},computed:{}}),Oe={class:`main flex flex-row flex-1`},ke={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Ae={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},je={class:`preview h-full w-[300px] flex flex-col`};function Me(e,r,i,a,s,c){let l=g(`font-awesome-icon`),d=g(`el-button`),m=g(`el-drawer`);return u(),t(`div`,Oe,[n(`div`,ke,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,Ae,[p(e.$slots,`result`,{},void 0,!0)]),n(`div`,je,[p(e.$slots,`preview`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:_(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[v,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:_(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ne=W(De,[[`render`,Me],[`__scopeId`,`data-v-169b0449`]]),Pe=r({name:`TypeSelector`,components:{ElSelect:E,ElOption:D,ElSwitch:ce},data(){return{options:[{label:`v5.5`,value:`chirp-v5-5`,desc:this.$t(`suno.model.v55desc`)},{label:`v5`,value:`chirp-v5`,desc:this.$t(`suno.model.v5desc`)},{label:`v4.5+`,value:`chirp-v4-5-plus`,desc:this.$t(`suno.model.v45plusdesc`)},{label:`v4.5`,value:`chirp-v4-5`,desc:this.$t(`suno.model.v45desc`),dividerAfter:!0},{label:`v4`,value:`chirp-v4`,desc:this.$t(`suno.model.v4desc`)},{label:`v3.5`,value:`chirp-v3-5`,desc:this.$t(`suno.model.v35desc`)},{label:`v3`,value:`chirp-v3-0`,desc:this.$t(`suno.model.v3desc`)}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||=le}}),Fe={class:`mb-3`},Ie={class:`flex items-center mb-1`},Le={class:`text-sm font-bold`},Re={class:`model-option`},ze={class:`model-option-left`},Be={class:`model-option-name`},Ve={class:`model-option-desc`},He={key:0,class:`flex items-center justify-between mb-3`},Ue={class:`text-sm font-bold`};function We(r,i,d,f,p,h){let v=g(`el-option`),y=g(`el-select`),b=g(`el-switch`);return u(),t(`div`,null,[n(`div`,Fe,[n(`div`,Ie,[n(`span`,Le,l(r.$t(`suno.name.model`)),1)]),o(y,{modelValue:r.model,"onUpdate:modelValue":i[0]||=e=>r.model=e,class:`w-full model-select`,size:`default`,placeholder:r.$t(`suno.placeholder.select`)},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e.value,label:e.label,value:e.value,class:c({"model-option-divider":e.dividerAfter})},{default:_(()=>[n(`div`,Re,[n(`div`,ze,[n(`span`,Be,l(e.label),1)]),n(`span`,Ve,l(e.desc),1)])]),_:2},1032,[`label`,`value`,`class`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),r.custom?(u(),t(`div`,He,[n(`span`,Ue,l(r.$t(`suno.name.instrumental`)),1),o(b,{modelValue:r.instrumental,"onUpdate:modelValue":i[1]||=e=>r.instrumental=e},null,8,[`modelValue`])])):m(``,!0)])}var Ge=W(Pe,[[`render`,We],[`__scopeId`,`data-v-16e4d6fc`]]),Ke=r({name:`UploadAudio`,components:{ElUpload:M,ElButton:b,ElDialog:K,ElTabs:O,ElTabPane:k,InfoIcon:Q,FontAwesomeIcon:Z,ElRadioGroup:R,ElRadioButton:L},mixins:[_e],emits:[`change`],data(){return{fileList:[],uploadUrl:ge()+`/api/v1/files/`,dialogVisible:!1,activeTab:`browse`,recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){let e=this.$store.state.suno?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.suno?.config?.action||`upload_extend`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,action:e})}},formattedTime(){return`${Math.floor(this.recordSeconds/60).toString().padStart(2,`0`)}:${(this.recordSeconds%60).toString().padStart(2,`0`)}`}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){J.warning(this.$t(`suno.message.uploadReferencesExceed`))},onError(){J.error(this.$t(`suno.message.uploadReferencesError`))},async onBrowseSuccess(){let e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingUploadAudio`));try{let e=await Y.upload(t,{token:n});console.debug(`get upload music success`,e.data);let r=e.data?.data.audio_id;this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_id:r,action:`upload_extend`}),J.success(this.$t(`suno.message.startUploadAudioSuccess`))}catch(e){J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startUploadAudioFailed`))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>`u`){J.error(this.$t(`suno.message.recordingUnsupported`));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{let e=new Blob(this.recordedChunks,{type:`audio/webm`});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error(`record error`,e),J.error(this.$t(`suno.message.recordingPermissionDenied`))}},stopRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.mediaRecorder&&this.mediaRecorder.state!==`inactive`&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{let e=new FormData,t=`recording-${Date.now()}.webm`;e.append(`file`,this.recordedBlob,t);let n=await fetch(this.uploadUrl,{method:`POST`,headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!n.ok)throw Error(`upload failed: ${n.status}`);let r=await n.json(),i=r?.file_url||r?.data?.file_url;if(!i)throw Error(`no file_url in response`);this.audioPreviewUrl=i,await this.onGenerateAudioId(i),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),J.error(e?.message||this.$t(`suno.message.uploadReferencesError`))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&=(this.mediaStream.getTracks().forEach(e=>e.stop()),null)},cleanupRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.releaseStream(),this.recordedAudioUrl&&=(URL.revokeObjectURL(this.recordedAudioUrl),null)}}}),qe={class:`relative`},Je={class:`flex justify-between items-center mb-2`},Ye={class:`flex justify-start items-center`},Xe={class:`text-sm font-bold`},Ze={key:0,class:`mb-2`},Qe=[`src`],$e={key:1,class:`mt-2`},et={class:`py-4`},tt={class:`text-center py-6`},nt={class:`text-sm`},rt={class:`text-xs text-gray-400 mt-1`},it={class:`py-4 text-center`},at={class:`recorder-display mb-4`},ot={key:0,class:`text-red-500 flex items-center justify-center gap-2`},st={class:`text-2xl font-mono`},ct={key:1,class:`text-green-600`},lt={key:2,class:`text-gray-400 text-2xl font-mono`},ut={key:0,class:`mb-4`},dt=[`src`],ft={class:`flex justify-center gap-3`};function pt(e,r,c,d,f,p){let h=g(`info-icon`),v=g(`font-awesome-icon`),y=g(`el-button`),b=g(`el-radio-button`),x=g(`el-radio-group`),S=g(`el-upload`),C=g(`el-tab-pane`),w=g(`el-tabs`),T=g(`el-dialog`);return u(),t(`div`,qe,[n(`div`,Je,[n(`div`,Ye,[n(`span`,Xe,l(e.$t(`suno.name.referenceAudios`)),1),o(h,{content:e.$t(`suno.description.uploadAudios`)},null,8,[`content`])]),o(y,{round:``,type:`primary`,size:`small`,onClick:r[0]||=t=>e.dialogVisible=!0},{default:_(()=>[o(v,{icon:`fa-solid fa-plus`,class:`icon mr-1`}),i(` `+l(e.$t(`suno.button.addAudio`)),1)]),_:1})]),e.audioPreviewUrl?(u(),t(`div`,Ze,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Qe)])):m(``,!0),e.hasUploadedAudio?(u(),t(`div`,$e,[o(x,{modelValue:e.uploadAction,"onUpdate:modelValue":r[1]||=t=>e.uploadAction=t,size:`small`},{default:_(()=>[o(b,{value:`upload_extend`},{default:_(()=>[i(l(e.$t(`suno.button.extend`)),1)]),_:1}),o(b,{value:`upload_cover`},{default:_(()=>[i(l(e.$t(`suno.button.upload_cover`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),o(T,{modelValue:e.dialogVisible,"onUpdate:modelValue":r[4]||=t=>e.dialogVisible=t,title:e.$t(`suno.name.addAudio`),width:`520px`,"close-on-click-modal":!1,"append-to-body":``},{default:_(()=>[o(w,{modelValue:e.activeTab,"onUpdate:modelValue":r[3]||=t=>e.activeTab=t,class:`add-audio-tabs`},{default:_(()=>[o(C,{name:`browse`,label:e.$t(`suno.tab.browse`)},{default:_(()=>[n(`div`,et,[o(S,{"file-list":e.fileList,"onUpdate:fileList":r[2]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:``},{default:_(()=>[n(`div`,tt,[o(v,{icon:`fa-solid fa-upload`,class:`text-4xl text-gray-400 mb-3`}),n(`div`,nt,l(e.$t(`suno.description.dropAudioHere`)),1),n(`div`,rt,l(e.$t(`suno.description.audioFormats`)),1)])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])]),_:1},8,[`label`]),o(C,{name:`record`,label:e.$t(`suno.tab.record`)},{default:_(()=>[n(`div`,it,[n(`div`,at,[e.recording?(u(),t(`div`,ot,[r[5]||=n(`span`,{class:`recording-dot`},null,-1),n(`span`,st,l(e.formattedTime),1)])):e.recordedBlob?(u(),t(`div`,ct,[o(v,{icon:`fa-solid fa-check-circle`,class:`text-2xl mr-2`}),n(`span`,null,l(e.$t(`suno.message.recordingReady`))+` (`+l(e.formattedTime)+`)`,1)])):(u(),t(`div`,lt,`00:00`))]),e.recordedAudioUrl&&!e.recording?(u(),t(`div`,ut,[n(`audio`,{src:e.recordedAudioUrl,controls:``,class:`w-full`},null,8,dt)])):m(``,!0),n(`div`,ft,[!e.recording&&!e.recordedBlob?(u(),a(y,{key:0,type:`primary`,round:``,onClick:e.startRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.startRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recording?(u(),a(y,{key:1,type:`danger`,round:``,onClick:e.stopRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-stop`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.stopRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recordedBlob&&!e.recording?(u(),t(s,{key:2},[o(y,{round:``,onClick:e.resetRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.reRecord`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,round:``,loading:e.uploadingRecord,onClick:e.uploadRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.useRecording`)),1)]),_:1},8,[`loading`,`onClick`])],64)):m(``,!0)])])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`])])}var mt=W(Ke,[[`render`,pt],[`__scopeId`,`data-v-5f17a1f4`]]),ht=[{key:`lofi`,label:`🎧 Lo-fi Chill`,prompt:`a relaxing lo-fi hip hop beat for studying`},{key:`pop-love`,label:`💕 Pop Love Song`,prompt:`a catchy pop love song with sweet melodies`},{key:`rock-anthem`,label:`🎸 Rock Anthem`,prompt:`an energetic rock anthem with electric guitars`},{key:`jazz-night`,label:`🎷 Jazz Night`,prompt:`a smooth late-night jazz piece with saxophone`},{key:`edm-drop`,label:`⚡ EDM Drop`,prompt:`an intense EDM track with a massive drop`},{key:`folk-story`,label:`🪕 Folk Story`,prompt:`a warm folk song telling a story about traveling`},{key:`rnb-groove`,label:`🎤 R&B Groove`,prompt:`a smooth R&B groove with soulful vocals`},{key:`classical`,label:`🎻 Classical`,prompt:`an elegant classical piece for orchestra`},{key:`hip-hop`,label:`🎤 Hip Hop`,prompt:`a hard-hitting hip hop beat with bass`},{key:`country`,label:`🤠 Country`,prompt:`an upbeat country song with acoustic guitar and banjo`},{key:`reggae`,label:`🌴 Reggae`,prompt:`a laid-back reggae tune with island vibes`},{key:`latin`,label:`💃 Latin`,prompt:`a vibrant Latin dance track with percussion`},{key:`ambient`,label:`🌊 Ambient`,prompt:`a dreamy ambient soundscape for relaxation`},{key:`metal`,label:`🤘 Metal`,prompt:`a powerful metal song with heavy riffs and double bass drums`},{key:`soul`,label:`🎵 Soul`,prompt:`a heartfelt soul ballad with gospel harmonies`},{key:`synthwave`,label:`🌃 Synthwave`,prompt:`a retro synthwave track with 80s vibes`},{key:`kpop`,label:`🇰🇷 K-Pop`,prompt:`a catchy K-pop dance track with hook`},{key:`lullaby`,label:`🌙 Lullaby`,prompt:`a gentle lullaby for bedtime with soft piano`},{key:`cinematic`,label:`🎬 Cinematic`,prompt:`an epic cinematic orchestral score for a movie trailer`},{key:`blues`,label:`🎸 Blues`,prompt:`a soulful blues song with electric guitar bends`},{key:`disco`,label:`🕺 Disco`,prompt:`a funky disco track with groovy bassline`},{key:`punk`,label:`🔥 Punk Rock`,prompt:`a fast punk rock song with raw energy`},{key:`gospel`,label:`⛪ Gospel`,prompt:`an uplifting gospel choir song with piano`},{key:`trap`,label:`🔊 Trap`,prompt:`a dark trap beat with 808s and hi-hats`},{key:`bossa`,label:`☕ Bossa Nova`,prompt:`a gentle bossa nova with nylon guitar`},{key:`indie`,label:`🎶 Indie`,prompt:`a dreamy indie track with ethereal vocals`},{key:`cpop`,label:`🇨🇳 C-Pop`,prompt:`a beautiful Chinese pop ballad with emotional vocals`},{key:`jpop`,label:`🇯🇵 J-Pop`,prompt:`a cheerful J-pop song with anime vibes`},{key:`afrobeat`,label:`🥁 Afrobeat`,prompt:`a groovy Afrobeat track with layered percussion`},{key:`game`,label:`🎮 Game BGM`,prompt:`an adventurous video game background music`}],gt=8;function _t(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var vt=r({name:`PromptInput`,components:{FontAwesomeIcon:Z,PromptTextarea:Se},data(){return{shuffledTags:_t(ht)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,gt)}},mounted(){this.prompt||=``},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=_t(ht)}}}),yt={class:`inspo-tags`},bt=[`onClick`];function xt(r,i,c,d,f,p){let m=g(`font-awesome-icon`),h=g(`prompt-textarea`);return u(),a(h,{modelValue:r.prompt,"onUpdate:modelValue":i[1]||=e=>r.prompt=e,title:r.$t(`suno.name.songDescription`),info:r.$t(`suno.description.prompt`),placeholder:r.$t(`suno.placeholder.prompt`),"min-rows":5,"max-rows":14},{after:_(()=>[n(`div`,yt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e.key,class:`inspo-tag`,onClick:t=>r.onTagClick(e)},l(e.label),9,bt))),128)),n(`button`,{class:`inspo-tag inspo-tag-refresh`,onClick:i[0]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(m,{icon:`fa-solid fa-arrows-rotate`})])])]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var St=W(vt,[[`render`,xt],[`__scopeId`,`data-v-58ffcd38`]]),Ct=r({name:`LyricInput`,components:{ElInput:G,ElButton:b,ElTooltip:N,ElDialog:K,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:``,lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||=``},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){let e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=``},async onEnhanceLyrics(){let e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,J.info(this.$t(`suno.message.enhancingLyrics`));try{let t=`${this.enhancePrompt}\n\nOriginal lyrics:\n${this.lyric}`,n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,this.enhancePrompt=``,J.success(this.$t(`suno.message.enhanceLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.enhanceLyricsFailed`))}finally{this.enhancingLyrics=!1}}},async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t;try{t=((await q.prompt(this.$t(`suno.message.lyricsThemePromptMessage`),this.$t(`suno.message.lyricsThemePromptTitle`),{confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`),inputPlaceholder:this.$t(`suno.placeholder.lyricsTheme`),inputValue:this.config?.title||``,inputType:`textarea`,inputValidator:e=>typeof e==`string`&&e.trim().length>0||this.$t(`suno.message.lyricsThemeRequired`)})).value||``).trim()}catch{return}if(t){this.pushHistory(),this.generatingLyrics=!0,J.info(this.$t(`suno.message.generatingLyrics`));try{let n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:n.text,title:n.title}),J.success(this.$t(`suno.message.generateLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}}),wt={class:`field`},Tt={class:`flex items-center justify-between mb-1`},Et={class:`flex items-center`},Dt={class:`text-sm font-bold`},Ot={class:`flex items-center gap-1`},kt={class:`relative`},At={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},jt={key:0,class:`enhance-bar`},Mt={key:0,class:`enhance-bar mt-3`},Nt={class:`flex items-center justify-between`},Pt={class:`flex items-center gap-1`};function Ft(e,r,s,c,d,f){let p=g(`info-icon`),h=g(`font-awesome-icon`),v=g(`el-button`),b=g(`el-tooltip`),x=g(`el-input`),S=g(`el-dialog`);return u(),t(`div`,wt,[n(`div`,Tt,[n(`div`,Et,[n(`span`,Dt,l(e.$t(`suno.name.lyrics`)),1),o(p,{content:e.$t(`suno.description.lyrics`)},null,8,[`content`])]),n(`div`,Ot,[e.lyricHistory.length>0?(u(),a(b,{key:0,content:e.$t(`suno.button.undo`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),e.lyric?(u(),a(b,{key:1,content:e.$t(`suno.button.clear_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),o(b,{content:e.$t(`suno.button.expand_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:r[0]||=t=>e.expanded=!0},{default:_(()=>[o(h,{icon:`fa-solid fa-expand`})]),_:1})]),_:1},8,[`content`]),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))])]),n(`div`,kt,[e.config?.action===`extend`?(u(),a(x,{key:1,modelValue:e.lyric,"onUpdate:modelValue":r[2]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(u(),a(x,{key:0,modelValue:e.lyric,"onUpdate:modelValue":r[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`])),n(`div`,At,l(e.lyric?.length||0)+`/5000`,1)]),e.lyric&&e.config?.action!==`extend`?(u(),t(`div`,jt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[3]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])])):m(``,!0),o(S,{modelValue:e.expanded,"onUpdate:modelValue":r[7]||=t=>e.expanded=t,title:e.$t(`suno.name.lyrics`),width:`720px`,top:`5vh`,"close-on-click-modal":!1,class:`lyrics-expand-dialog`},{footer:_(()=>[n(`div`,Nt,[n(`div`,Pt,[e.lyricHistory.length>0?(u(),a(v,{key:0,size:`small`,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.undo`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.lyric?(u(),a(v,{key:1,size:`small`,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_lyrics`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),o(v,{type:`primary`,onClick:r[6]||=t=>e.expanded=!1},{default:_(()=>[i(l(e.$t(`common.button.confirm`)),1)]),_:1})])]),default:_(()=>[o(x,{modelValue:e.lyric,"onUpdate:modelValue":r[4]||=t=>e.lyric=t,type:`textarea`,rows:20,class:`lyrics-expanded`,placeholder:e.$t(`suno.placeholder.lyrics`),autofocus:``},null,8,[`modelValue`,`placeholder`]),e.config?.action===`extend`?m(``,!0):(u(),t(`div`,Mt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[5]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])]))]),_:1},8,[`modelValue`,`title`])])}var It=W(Ct,[[`render`,Ft],[`__scopeId`,`data-v-d7d2ec74`]]),Lt=`Pop.Rock.Jazz.R&B.Hip Hop.Lo-fi.Electronic.Classical.Country.Blues.Folk.Reggae.Metal.Punk.Soul.Funk.Ambient.Indie.Latin.Acoustic.Dance.Disco.Gospel.K-Pop.J-Pop.C-Pop.Bossa Nova.Trap.Drill.House.Techno.Dubstep.Synthwave.Chill.Dreamy.Upbeat.Melancholic.Romantic.Epic.Cinematic.Orchestral.Piano.Guitar.Saxophone.Violin.Tribal.World Music.Afrobeat.Ska.Grunge`.split(`.`),Rt=12;function zt(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var Bt=r({name:`StyleInput`,components:{ElInput:G,ElButton:b,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{optimizing:!1,shuffledTags:zt(Lt)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,Rt)}},methods:{onTagClick(e){let t=this.style||``;t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=zt(Lt)},async onOptimizeStyle(){let e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,J.info(this.$t(`suno.message.optimizingStyle`));try{let t=await Y.style({prompt:this.style},{token:e}),n=t.data?.text||t.data?.data?.text;n&&(this.style=n,J.success(this.$t(`suno.message.optimizeStyleSuccess`)))}catch{J.error(this.$t(`suno.message.optimizeStyleFailed`))}finally{this.optimizing=!1}}}}}),Vt={class:`field`},Ht={class:`flex items-center justify-between mb-1`},Ut={class:`flex items-center`},Wt={class:`text-sm font-bold`},Gt={class:`relative`},Kt={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},qt={class:`style-tags`},Jt=[`onClick`];function Yt(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-input`);return u(),t(`div`,Vt,[n(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,l(r.$t(`suno.name.style`)),1),o(v,{content:r.$t(`suno.description.style`)},null,8,[`content`])]),o(b,{size:`small`,loading:r.optimizing,round:``,onClick:r.onOptimizeStyle},{default:_(()=>[r.optimizing?m(``,!0):(u(),a(y,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(r.$t(`suno.button.optimize_style`)),1)]),_:1},8,[`loading`,`onClick`])]),n(`div`,Gt,[o(x,{modelValue:r.style,"onUpdate:modelValue":c[0]||=e=>r.style=e,rows:2,type:`textarea`,placeholder:r.$t(`suno.placeholder.style`)},null,8,[`modelValue`,`placeholder`]),n(`div`,Kt,l(r.style?.length||0)+`/1000`,1)]),n(`div`,qt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e,class:`style-tag`,onClick:t=>r.onTagClick(e)},l(e),9,Jt))),128)),n(`button`,{class:`style-tag style-tag-refresh`,onClick:c[1]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(y,{icon:`fa-solid fa-arrows-rotate`})])])])}var Xt=W(Bt,[[`render`,Yt],[`__scopeId`,`data-v-ddebb076`]]),Zt=r({name:`TitleInput`,components:{ElInput:G,InfoIcon:Q},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,title:e})}}}}),Qt={class:`field`},$t={class:`flex items-center mb-1`},en={class:`text-sm font-bold`};function tn(e,r,i,a,s,c){let d=g(`info-icon`),f=g(`el-input`);return u(),t(`div`,Qt,[n(`div`,$t,[n(`span`,en,l(e.$t(`suno.name.title`)),1),o(d,{content:e.$t(`suno.description.title`)},null,8,[`content`])]),o(f,{modelValue:e.title,"onUpdate:modelValue":r[0]||=t=>e.title=t,placeholder:e.$t(`suno.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var nn=W(Zt,[[`render`,tn]]),rn=r({name:`ExtendFromInput`,components:{ElImage:P,ElIcon:w,ElInputNumber:U,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),an={class:`field`},on={class:`box`},sn={class:`title font-bold`},cn={class:`input-wrapper`},ln={class:`task`},un={class:`left`},dn={key:2,class:`duration`},fn={class:`info`},pn={class:`title`},mn={class:`style`};function hn(e,r,i,a,s,c){let d=g(`el-input-number`),p=g(`el-image`),v=g(`video-pause`),y=g(`el-icon`),b=g(`video-play`),x=h(`loading`);return u(),t(`div`,an,[n(`div`,on,[n(`h2`,sn,l(e.$t(`suno.name.extend`)),1),n(`div`,cn,[o(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,ln,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[3]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,un,[o(p,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[1]||=t=>e.onPause(e.audio)},[o(y,null,{default:_(()=>[o(v)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[2]||=t=>e.onPlay(e.audio)},[o(y,null,{default:_(()=>[o(b)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,dn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,fn,[n(`h2`,pn,l(e.audio?.title),1),n(`p`,mn,l(e.audio?.style),1)])])):m(``,!0)])])}var gn=W(rn,[[`render`,hn],[`__scopeId`,`data-v-bcce4821`]]),_n=r({name:`CoverFromInput`,components:{ElImage:P,ElIcon:w,VideoPlay:S,VideoPause:C},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||=void 0},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),vn={class:`field`},yn={class:`box`},bn={class:`title font-bold`},xn={class:`task`},Sn={class:`left`},Cn={key:2,class:`duration`},wn={class:`info`},Tn={class:`title`},En={class:`style`};function Dn(e,r,i,a,s,c){let d=g(`el-image`),p=g(`video-pause`),v=g(`el-icon`),y=g(`video-play`),b=h(`loading`);return u(),t(`div`,vn,[n(`div`,yn,[n(`h2`,bn,l(e.$t(`suno.name.cover`)),1)]),n(`div`,xn,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[2]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Sn,[o(d,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[0]||=t=>e.onPause(e.audio)},[o(v,null,{default:_(()=>[o(p)]),_:1})])):m(``,!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[1]||=t=>e.onPlay(e.audio)},[o(v,null,{default:_(()=>[o(y)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,Cn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,wn,[n(`h2`,Tn,l(e.audio?.title),1),n(`p`,En,l(e.audio?.style),1)])])):m(``,!0)])])}var On=W(_n,[[`render`,Dn],[`__scopeId`,`data-v-06640216`]]),kn=r({name:`VocalGenderSelector`,components:{ElRadioGroup:R,ElRadioButton:L,InfoIcon:Q},computed:{vocalGender:{get(){return this.$store.state.suno?.config?.vocal_gender||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,vocal_gender:e||void 0})}}}}),An={class:`flex items-center mb-1`},jn={class:`text-sm font-bold`};function Mn(e,r,a,s,c,d){let f=g(`info-icon`),p=g(`el-radio-button`),m=g(`el-radio-group`);return u(),t(`div`,null,[n(`div`,An,[n(`span`,jn,l(e.$t(`suno.name.vocalGender`)),1),o(f,{content:e.$t(`suno.description.vocalGender`)},null,8,[`content`])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":r[0]||=t=>e.vocalGender=t,size:`small`},{default:_(()=>[o(p,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(p,{value:`f`},{default:_(()=>[i(l(e.$t(`suno.gender.female`)),1)]),_:1}),o(p,{value:`m`},{default:_(()=>[i(l(e.$t(`suno.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Nn=W(kn,[[`render`,Mn]]),Pn=r({name:`AdvancedParams`,components:{ElCollapse:ne,ElCollapseItem:te,ElInput:G,ElSlider:se,ElRadioGroup:R,ElRadioButton:L},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){let e=this.config?.model||``;return[`chirp-v5`,`chirp-v5-5`].includes(e)},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_weight:e})}},lyricsMode:{get(){return this.$store.state.suno?.config?.lyrics_mode||`manual`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyrics_mode:e})}}},mounted(){let e=this.$store.state.suno?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.style_influence==`number`&&e.style_influence>1&&(t.style_influence=e.style_influence/100),typeof e.audio_weight==`number`&&e.audio_weight>1&&(t.audio_weight=e.audio_weight/100),Object.keys(t).length>0&&this.$store.commit(`suno/setConfig`,{...e,...t})}}),Fn={key:0,class:`mb-3`},In={class:`flex items-center mb-1`},Ln={class:`text-xs font-bold`},Rn={key:1,class:`mb-3`},zn={class:`flex items-center mb-1`},Bn={class:`text-xs font-bold`},Vn={key:2,class:`mb-3`},Hn={class:`flex items-center justify-between mb-1`},Un={class:`text-xs font-bold`},Wn={class:`text-xs text-[var(--el-text-color-secondary)]`},Gn={key:3,class:`mb-3`},Kn={class:`flex items-center justify-between mb-1`},qn={class:`text-xs font-bold`},Jn={class:`text-xs text-[var(--el-text-color-secondary)]`},Yn={key:4,class:`mb-3`},Xn={class:`flex items-center mb-1`},Zn={class:`text-xs font-bold`},Qn={key:5,class:`mb-3`},$n={class:`flex items-center justify-between mb-1`},er={class:`text-xs font-bold`},tr={class:`text-xs text-[var(--el-text-color-secondary)]`},nr={key:6,class:`mb-3`},rr={class:`flex items-center mb-1`},ir={class:`text-xs font-bold`};function ar(e,r,s,c,d,f){let p=g(`el-input`),h=g(`el-slider`),v=g(`el-radio-button`),y=g(`el-radio-group`),b=g(`el-collapse-item`),x=g(`el-collapse`);return u(),a(x,{modelValue:e.activeNames,"onUpdate:modelValue":r[7]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:_(()=>[o(b,{title:e.$t(`suno.name.advancedParams`),name:`advanced`},{default:_(()=>[e.config?.custom?(u(),t(`div`,Fn,[n(`div`,In,[n(`span`,Ln,l(e.$t(`suno.name.styleNegative`)),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`suno.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,Rn,[n(`div`,zn,[n(`span`,Bn,l(e.$t(`suno.name.lyricPrompt`)),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Vn,[n(`div`,Hn,[n(`span`,Un,l(e.$t(`suno.name.weirdness`)),1),n(`span`,Wn,l(e.weirdness??0),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Gn,[n(`div`,Kn,[n(`span`,qn,l(e.$t(`suno.name.styleInfluence`)),1),n(`span`,Jn,l(e.styleInfluence??.5),1)]),o(h,{modelValue:e.styleInfluence,"onUpdate:modelValue":r[3]||=t=>e.styleInfluence=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.isV5OrAbove?(u(),t(`div`,Yn,[n(`div`,Xn,[n(`span`,Zn,l(e.$t(`suno.name.variationCategory`)),1)]),o(y,{modelValue:e.variationCategory,"onUpdate:modelValue":r[4]||=t=>e.variationCategory=t,size:`small`},{default:_(()=>[o(v,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(v,{value:`high`},{default:_(()=>[i(l(e.$t(`suno.variation.high`)),1)]),_:1}),o(v,{value:`low`},{default:_(()=>[i(l(e.$t(`suno.variation.low`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),e.config?.action===`cover`?(u(),t(`div`,Qn,[n(`div`,$n,[n(`span`,er,l(e.$t(`suno.name.audioWeight`)),1),n(`span`,tr,l(e.audioWeight??.5),1)]),o(h,{modelValue:e.audioWeight,"onUpdate:modelValue":r[5]||=t=>e.audioWeight=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,nr,[n(`div`,rr,[n(`span`,ir,l(e.$t(`suno.name.lyricsMode`)),1)]),o(y,{modelValue:e.lyricsMode,"onUpdate:modelValue":r[6]||=t=>e.lyricsMode=t,size:`small`},{default:_(()=>[o(v,{value:`manual`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.manual`)),1)]),_:1}),o(v,{value:`auto`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.auto`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0)]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var or=W(Pn,[[`render`,ar],[`__scopeId`,`data-v-363599d3`]]),sr=r({name:`ReplaceSectionInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},replaceSectionStart:{get(){return this.$store.state.suno?.config?.replace_section_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.suno?.config?.replace_section_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),cr={class:`field`},lr={class:`flex items-center mb-2`},ur={class:`text-sm font-bold m-0`},dr={key:0,class:`task mb-2`},fr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},pr={class:`info flex-1 min-w-0`},mr={class:`text-sm font-bold m-0 truncate`},hr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},gr={class:`flex gap-2`};function _r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,cr,[n(`div`,lr,[n(`h2`,ur,l(e.$t(`suno.name.replaceSection`)),1),o(d,{content:e.$t(`suno.description.replaceSection`)},null,8,[`content`])]),e.audio?(u(),t(`div`,dr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,fr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,pr,[n(`h2`,mr,l(e.audio?.title),1),n(`p`,hr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,gr,[o(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":r[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":r[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var vr=W(sr,[[`render`,_r]]),yr=r({name:`OverpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},overpaintingStart:{get(){return this.$store.state.suno?.config?.overpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_start:e})}},overpaintingEnd:{get(){return this.$store.state.suno?.config?.overpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,overpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),br={class:`field`},xr={class:`flex items-center mb-2`},Sr={class:`text-sm font-bold m-0`},Cr={key:0,class:`task mb-2`},wr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Tr={class:`info flex-1 min-w-0`},Er={class:`text-sm font-bold m-0 truncate`},Dr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Or={class:`flex gap-2`};function kr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,br,[n(`div`,xr,[n(`h2`,Sr,l(e.$t(`suno.name.overpaintingRange`)),1),o(d,{content:e.$t(`suno.description.overpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Cr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,wr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Tr,[n(`h2`,Er,l(e.audio?.title),1),n(`p`,Dr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Or,[o(_,{modelValue:e.overpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.overpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.overpaintingEnd=t,class:`flex-1`,size:`small`,min:e.overpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.overpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Ar=W(yr,[[`render`,kr]]),jr=r({name:`UnderpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},underpaintingStart:{get(){return this.$store.state.suno?.config?.underpainting_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_start:e})}},underpaintingEnd:{get(){return this.$store.state.suno?.config?.underpainting_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,underpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Mr={class:`field`},Nr={class:`flex items-center mb-2`},Pr={class:`text-sm font-bold m-0`},Fr={key:0,class:`task mb-2`},Ir={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Lr={class:`info flex-1 min-w-0`},Rr={class:`text-sm font-bold m-0 truncate`},zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Br={class:`flex gap-2`};function Vr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Mr,[n(`div`,Nr,[n(`h2`,Pr,l(e.$t(`suno.name.underpaintingRange`)),1),o(d,{content:e.$t(`suno.description.underpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Fr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Ir,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Lr,[n(`h2`,Rr,l(e.audio?.title),1),n(`p`,zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Br,[o(_,{modelValue:e.underpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.underpaintingStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.underpaintingEnd=t,class:`flex-1`,size:`small`,min:e.underpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.underpaintingEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Hr=W(jr,[[`render`,Vr]]),Ur=r({name:`SamplesInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},computed:{audio(){return this.$store.state.suno?.config?.audio},samplesStart:{get(){return this.$store.state.suno?.config?.samples_start},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_start:e})}},samplesEnd:{get(){return this.$store.state.suno?.config?.samples_end},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,samples_end:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),Wr={class:`field`},Gr={class:`flex items-center mb-2`},Kr={class:`text-sm font-bold m-0`},qr={key:0,class:`task mb-2`},Jr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Yr={class:`info flex-1 min-w-0`},Xr={class:`text-sm font-bold m-0 truncate`},Zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Qr={class:`flex gap-2`};function $r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Wr,[n(`div`,Gr,[n(`h2`,Kr,l(e.$t(`suno.name.samplesRange`)),1),o(d,{content:e.$t(`suno.description.samples`)},null,8,[`content`])]),e.audio?(u(),t(`div`,qr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Jr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Yr,[n(`h2`,Xr,l(e.audio?.title),1),n(`p`,Zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Qr,[o(_,{modelValue:e.samplesStart,"onUpdate:modelValue":r[1]||=t=>e.samplesStart=t,class:`flex-1`,size:`small`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.samplesEnd,"onUpdate:modelValue":r[2]||=t=>e.samplesEnd=t,class:`flex-1`,size:`small`,min:e.samplesStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.samplesEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var ei=W(Ur,[[`render`,$r]]),ti=[.5,.75,1,1.25,1.5,2],ni=r({name:`AdjustSpeedInput`,components:{ElRadioGroup:R,ElRadioButton:L,ElImage:P,InfoIcon:Q},data(){return{options:ti}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){let e=this.$store.state.suno?.config?.speed;return typeof e==`number`?e:1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),ri={class:`field`},ii={class:`flex items-center mb-2`},ai={class:`text-sm font-bold m-0`},oi={key:0,class:`task mb-2`},si={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},ci={class:`info flex-1 min-w-0`},li={class:`text-sm font-bold m-0 truncate`},ui={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`};function di(r,c,d,p,v,y){let b=g(`info-icon`),x=g(`el-image`),S=g(`el-radio-button`),C=g(`el-radio-group`),w=h(`loading`);return u(),t(`div`,ri,[n(`div`,ii,[n(`h2`,ai,l(r.$t(`suno.name.adjustSpeed`)),1),o(b,{content:r.$t(`suno.description.adjustSpeed`)},null,8,[`content`])]),r.audio?(u(),t(`div`,oi,[n(`div`,{class:`audio flex items-center`,onClick:c[0]||=e=>r.onClick(r.audio)},[f((u(),t(`div`,si,[o(x,{src:r.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[w,!r.audio?.audio_url]]),n(`div`,ci,[n(`h2`,li,l(r.audio?.title),1),n(`p`,ui,l(r.audio?.style),1)])])])):m(``,!0),o(C,{modelValue:r.speed,"onUpdate:modelValue":c[1]||=e=>r.speed=e,size:`small`,class:`speed-group`},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(S,{key:e,value:e},{default:_(()=>[i(l(e)+`x`,1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])])}var fi=W(ni,[[`render`,di],[`__scopeId`,`data-v-ba834628`]]),pi=r({name:`VoiceCreateDialog`,components:{ElDialog:K,ElForm:j,ElFormItem:A,ElInput:G,ElButton:b,ElRadioGroup:R,ElRadio:ee},props:{modelValue:{type:Boolean,default:!1}},emits:[`update:modelValue`,`created`],data(){return{sourceType:`song`,form:{name:``,description:``,audio_id:``,audio_url:``},loading:!1}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit(`update:modelValue`,e)}},token(){return this.$store.state.suno?.credential?.token},canSubmit(){return!(!this.form.name||this.sourceType===`song`&&!this.form.audio_id||this.sourceType===`upload`&&!this.form.audio_url)}},methods:{onClose(){this.visible=!1,this.resetForm()},resetForm(){this.form={name:``,description:``,audio_id:``,audio_url:``},this.sourceType=`song`},async onSubmit(){if(this.token){this.loading=!0;try{this.sourceType===`song`?await Y.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await Y.voices({audio_url:this.form.audio_url,name:this.form.name,description:this.form.description},{token:this.token}),J.success(this.$t(`suno.voice.createSuccess`)),this.$emit(`created`),this.onClose()}catch{J.error(this.$t(`suno.voice.createFailed`))}finally{this.loading=!1}}}}});function mi(e,t,n,r,s,c){let d=g(`el-input`),f=g(`el-form-item`),p=g(`el-radio`),h=g(`el-radio-group`),v=g(`el-form`),y=g(`el-button`),b=g(`el-dialog`);return u(),a(b,{modelValue:e.visible,"onUpdate:modelValue":t[5]||=t=>e.visible=t,title:e.$t(`suno.voice.createTitle`),width:`480px`,"close-on-click-modal":!1,onClose:e.onClose},{footer:_(()=>[o(y,{onClick:e.onClose},{default:_(()=>[i(l(e.$t(`common.button.cancel`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:_(()=>[i(l(e.$t(`suno.voice.create`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])]),default:_(()=>[o(v,{"label-position":`top`,class:`voice-create-form`},{default:_(()=>[o(f,{label:e.$t(`suno.voice.name`)},{default:_(()=>[o(d,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||=t=>e.form.name=t,placeholder:e.$t(`suno.voice.namePlaceholder`),maxlength:`50`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.description`)},{default:_(()=>[o(d,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||=t=>e.form.description=t,type:`textarea`,rows:2,placeholder:e.$t(`suno.voice.descriptionPlaceholder`),maxlength:`200`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.sourceType`)},{default:_(()=>[o(h,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||=t=>e.sourceType=t,class:`w-full`},{default:_(()=>[o(p,{value:`song`},{default:_(()=>[i(l(e.$t(`suno.voice.fromSong`)),1)]),_:1}),o(p,{value:`upload`},{default:_(()=>[i(l(e.$t(`suno.voice.fromUpload`)),1)]),_:1})]),_:1},8,[`modelValue`])]),_:1},8,[`label`]),e.sourceType===`song`?(u(),a(f,{key:0,label:e.$t(`suno.voice.audioId`)},{default:_(()=>[o(d,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||=t=>e.form.audio_id=t,placeholder:e.$t(`suno.voice.audioIdPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0),e.sourceType===`upload`?(u(),a(f,{key:1,label:e.$t(`suno.voice.audioUrl`)},{default:_(()=>[o(d,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||=t=>e.form.audio_url=t,placeholder:e.$t(`suno.voice.audioUrlPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0)]),_:1})]),_:1},8,[`modelValue`,`title`,`onClose`])}var hi=r({name:`VoiceManager`,components:{ElButton:b,ElIcon:w,ElTabs:O,ElTabPane:k,ElTooltip:N,Loading:x,FontAwesomeIcon:Z,VoiceCreateDialog:W(pi,[[`render`,mi]])},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:`all`}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab===`favorites`?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch(`suno/getPersonas`)}finally{this.loading=!1}}},selectPersona(e){let t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch(`suno/setConfig`,t)},async onDelete(e){try{await q.confirm(this.$t(`suno.voice.confirmDelete`),this.$t(`suno.voice.delete`),{type:`warning`,confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`)})}catch{return}if(!e.persona_id)return;this.deletingId=e.persona_id;let t=await this.$store.dispatch(`suno/deletePersona`,e.persona_id);if(this.deletingId=null,t){if(J.success(this.$t(`suno.voice.deleteSuccess`)),this.selectedPersonaId===e.persona_id){let e={...this.$store.state.suno?.config,persona_id:void 0};this.$store.dispatch(`suno/setConfig`,e)}this.favoriteIds.includes(e.persona_id)&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)}else J.error(this.$t(`suno.voice.deleteFailed`))},async onCreated(){await this.loadPersonas()}}}),gi={class:`voice-manager`},_i={class:`flex items-center justify-between mb-3`},vi={class:`text-sm font-medium`},yi={key:0,class:`text-center py-6`},bi={key:1,class:`text-center py-6 text-gray-400 text-sm`},xi={key:2,class:`voice-list`},Si=[`onClick`],Ci={class:`flex-1 min-w-0`},wi={class:`voice-name`},Ti={key:0,class:`voice-desc`};function Ei(r,a,f,p,h,v){let y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-tab-pane`),S=g(`el-tabs`),C=g(`loading`),w=g(`el-icon`),T=g(`el-tooltip`),E=g(`voice-create-dialog`);return u(),t(`div`,gi,[n(`div`,_i,[n(`span`,vi,l(r.$t(`suno.voice.title`)),1),o(b,{type:`primary`,size:`small`,onClick:a[0]||=e=>r.showCreateDialog=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-plus`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.create`)),1)]),_:1})]),o(S,{modelValue:r.activeTab,"onUpdate:modelValue":a[1]||=e=>r.activeTab=e,class:`voice-tabs`,size:`small`},{default:_(()=>[o(x,{name:`all`,label:r.$t(`suno.voice.tabAll`)+` (`+(r.personas?.length||0)+`)`},null,8,[`label`]),o(x,{name:`favorites`,label:r.$t(`suno.voice.tabFavorites`)+` (`+r.favoritePersonas.length+`)`},null,8,[`label`])]),_:1},8,[`modelValue`]),r.loading?(u(),t(`div`,yi,[o(w,{class:`is-loading`},{default:_(()=>[o(C)]),_:1})])):r.visiblePersonas.length===0?(u(),t(`div`,bi,l(r.activeTab===`favorites`?r.$t(`suno.voice.emptyFavorites`):r.$t(`suno.voice.empty`)),1)):(u(),t(`div`,xi,[(u(!0),t(s,null,e(r.visiblePersonas,e=>(u(),t(`div`,{key:e.persona_id,class:c([`voice-item`,{active:r.selectedPersonaId===e.persona_id}]),onClick:t=>r.selectPersona(e)},[n(`div`,Ci,[n(`div`,wi,[o(y,{icon:e.source_type===`voice`?`fa-solid fa-microphone`:`fa-solid fa-music`,class:`mr-1.5 text-xs opacity-60`},null,8,[`icon`]),i(` `+l(e.name||e.persona_id),1)]),e.description?(u(),t(`div`,Ti,l(e.description),1)):m(``,!0)]),n(`div`,{class:`voice-actions`,onClick:a[2]||=d(()=>{},[`stop`])},[o(T,{content:r.isFavorite(e.persona_id)?r.$t(`suno.voice.unfavorite`):r.$t(`suno.voice.favorite`),placement:`top`},{default:_(()=>[o(b,{size:`small`,text:``,class:c({"voice-fav-active":r.isFavorite(e.persona_id)}),onClick:t=>r.onToggleFavorite(e)},{default:_(()=>[o(y,{icon:r.isFavorite(e.persona_id)?`fa-solid fa-star`:`fa-regular fa-star`},null,8,[`icon`])]),_:2},1032,[`class`,`onClick`])]),_:2},1032,[`content`]),o(b,{type:`danger`,size:`small`,text:``,loading:r.deletingId===e.persona_id,onClick:t=>r.onDelete(e)},{default:_(()=>[o(y,{icon:`fa-solid fa-trash`})]),_:1},8,[`loading`,`onClick`])])],10,Si))),128))])),o(E,{modelValue:r.showCreateDialog,"onUpdate:modelValue":a[3]||=e=>r.showCreateDialog=e,onCreated:r.onCreated},null,8,[`modelValue`,`onCreated`])])}var Di=r({name:`PersonaInput`,components:{ElSelect:E,ElOption:D,ElButton:b,ElDrawer:z,FontAwesomeIcon:Z,InfoIcon:Q,VoiceManager:W(hi,[[`render`,Ei],[`__scopeId`,`data-v-8b8e36d9`]])},data(){return{showManager:!1}},computed:{personaId:{get(){return this.$store.state.suno?.config?.persona_id||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,persona_id:e||void 0})}},personas(){return this.$store.state.suno?.personas||[]}}}),Oi={class:`field`},ki={class:`flex items-center justify-between mb-2`},Ai={class:`flex items-center`},ji={class:`text-sm font-bold`},Mi={class:`flex items-center justify-between w-full`},Ni={key:0,class:`text-xs text-gray-400 ml-2`};function Pi(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-option`),S=g(`el-select`),C=g(`voice-manager`),w=g(`el-drawer`);return u(),t(`div`,Oi,[n(`div`,ki,[n(`div`,Ai,[n(`span`,ji,l(r.$t(`suno.name.persona`)),1),o(v,{content:r.$t(`suno.description.persona`)},null,8,[`content`])]),o(b,{size:`small`,round:``,onClick:c[0]||=e=>r.showManager=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.manage`)),1)]),_:1})]),o(S,{modelValue:r.personaId,"onUpdate:modelValue":c[1]||=e=>r.personaId=e,placeholder:r.$t(`suno.placeholder.personaId`),clearable:``,filterable:``,class:`w-full`},{default:_(()=>[(u(!0),t(s,null,e(r.personas,e=>(u(),a(x,{key:e.persona_id||``,value:e.persona_id||``,label:e.name||e.persona_id||``},{default:_(()=>[n(`div`,Mi,[n(`span`,null,l(e.name||e.persona_id),1),e.source_type?(u(),t(`span`,Ni,l(e.source_type),1)):m(``,!0)])]),_:2},1032,[`value`,`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`]),o(w,{modelValue:r.showManager,"onUpdate:modelValue":c[2]||=e=>r.showManager=e,title:r.$t(`suno.voice.title`),size:`380px`,direction:`rtl`},{default:_(()=>[o(C)]),_:1},8,[`modelValue`,`title`])])}var Fi=r({name:`PresetPanel`,components:{TypeSelector:Ge,PromptInput:St,LyricInput:It,StyleInput:Xt,TitleInput:nn,ExtendFromInput:gn,CoverFromInput:On,UploadAudio:mt,VocalGenderSelector:Nn,AdvancedParams:or,ReplaceSectionInput:vr,OverpaintingInput:Ar,UnderpaintingInput:Hr,SamplesInput:ei,AdjustSpeedInput:fi,PersonaInput:W(Di,[[`render`,Pi]]),FontAwesomeIcon:Z,ElButton:b,ElTabs:O,ElTabPane:k,Consumption:we},emits:[`generate`],computed:{config(){return this.$store.state.suno?.config},mode:{get(){return this.$store.state.suno?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e===`custom`})}},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){let e=this.config?.model||``;return[`chirp-v4-5-plus`,`chirp-v5`,`chirp-v5-5`].includes(e)},supportsPersona(){let e=this.config?.action;return!e||e===`generate`||e===`artist_consistency`||e===`artist_consistency_vox`},generateButtonText(){let e=this.config?.action;return e===`extend`?this.$t(`suno.button.extend`):e===`cover`?this.$t(`suno.button.cover_music`):e===`remaster`?this.$t(`suno.button.remaster`):e===`replace_section`?this.$t(`suno.button.replace_section`):e===`mashup`?this.$t(`suno.button.mashup`):e===`stems`?this.$t(`suno.button.get_stems`):e===`concat`?this.$t(`suno.button.concat_music`):e===`upload_cover`?this.$t(`suno.button.upload_cover`):e===`artist_consistency`?this.$t(`suno.button.artist_consistency`):e===`artist_consistency_vox`?this.$t(`suno.button.artist_consistency_vox`):e===`overpainting`?this.$t(`suno.button.overpainting`):e===`underpainting`?this.$t(`suno.button.underpainting`):e===`samples`?this.$t(`suno.button.samples`):e===`adjust_speed`?this.$t(`suno.button.adjust_speed`):this.$t(`suno.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`suno/setConfig`,{custom:!1,sounds:!1,instrumental:!1,lyric:``,style:``,title:``,lyrics_mode:`manual`,model:this.$store.state.suno?.config?.model})}}}),Ii={class:`flex flex-col h-full`},Li={class:`flex-1 overflow-y-auto p-5`},Ri={class:`pt-2 px-1`},zi={class:`pt-2 px-1`},Bi={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Vi={class:`flex gap-2 w-full`};function Hi(e,r,s,c,d,f){let p=g(`type-selector`),h=g(`upload-audio`),v=g(`prompt-input`),y=g(`extend-from-input`),b=g(`cover-from-input`),x=g(`replace-section-input`),S=g(`overpainting-input`),C=g(`underpainting-input`),w=g(`samples-input`),T=g(`adjust-speed-input`),E=g(`advanced-params`),D=g(`el-tab-pane`),O=g(`lyric-input`),k=g(`style-input`),A=g(`title-input`),j=g(`vocal-gender-selector`),M=g(`persona-input`),N=g(`el-tabs`),P=g(`consumption`),F=g(`font-awesome-icon`),I=g(`el-button`);return u(),t(`div`,Ii,[n(`div`,Li,[o(N,{modelValue:e.mode,"onUpdate:modelValue":r[0]||=t=>e.mode=t,class:`suno-mode-tabs`,stretch:``},{default:_(()=>[o(D,{label:e.$t(`suno.mode.simple`),name:`simple`},{default:_(()=>[n(`div`,Ri,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),o(v,{class:`mb-4`}),e.config?.action===`extend`?(u(),a(y,{key:0,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:1,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:6,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`]),o(D,{label:e.$t(`suno.mode.custom`),name:`custom`},{default:_(()=>[n(`div`,zi,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),e.config?.instrumental?m(``,!0):(u(),a(O,{key:0,class:`mb-4`})),o(k,{class:`mb-4`}),o(A,{class:`mb-4`}),!e.config?.instrumental&&e.supportsVocalGender?(u(),a(j,{key:1,class:`mb-4`})):m(``,!0),e.supportsPersona?(u(),a(M,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(u(),a(y,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:6,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:7,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:8,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:9,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Bi,[o(P,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Vi,[o(I,{class:`flex-1`,onClick:e.onClearAll},{default:_(()=>[o(F,{icon:`fa-solid fa-broom`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_all`)),1)]),_:1},8,[`onClick`]),o(I,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:_(()=>[o(F,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Ui=W(Fi,[[`render`,Hi],[`__scopeId`,`data-v-c62324e6`]]),Wi=Te(),Gi=ue(`suno`),Ki=r({name:`TaskPreview`,components:{ElImage:P,ElIcon:w,ElTooltip:N,FontAwesomeIcon:Z,VideoPlay:S,VideoPause:C,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElInput:G,ElProgress:ie,ElCheckbox:I,Loading:x,ApiCodeDialog:be},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:``,apiCodeVisible:!1,apiCodePath:`/suno/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){let e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(e=>({...e,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action===`mashup`},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:$,onViewCode(){let e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([e,n])=>{e===`application_id`||e===`callback_url`||n!=null&&(typeof n==`string`&&n===``||Array.isArray(n)&&n.length===0||(t[e]=n))}),this.apiCodeBody=t,this.apiCodePath=`/suno/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.log(`on extend`),console.debug(`set config`,t),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:`extend`,audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e?.stopPropagation(),console.log(`on download`,t);let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);console.log(`on preview`,r),fetch(t).then(e=>e.blob()).then(e=>{(0,Wi.saveAs)(e,r)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;let t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(e){console.error(`get videoUrl failed:`,e),J.error(this.$t(`suno.message.getVideoUrlFailed`))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,n)=>{let r={audio_id:e},i=this.credential?.token;if(!i){console.error(`no token specified`),n(Error(`No token specified`));return}Y.mp4(r,{token:i}).then(e=>{let r=e.data?.data?.video_url;r?t(r):n(Error(`Video URL not found in response`))}).catch(e=>{n(e)})})},onPreview(e,t){e?.stopPropagation(),console.log(`on preview`,t),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){console.log(`on cover`),console.debug(`set config`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl(`concat`,e)},async onRemaster(e){await this.onGenerateAudioUrl(`remaster`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`replace_section`,audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`mashup`,audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`overpainting`,audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`underpainting`,audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`samples`,audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`artist_consistency`,audio:e,audio_id:e.id})},onAdjustSpeed(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`adjust_speed`,audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){let t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){J.warning(this.$t(`suno.message.reusePromptEmpty`));return}this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??``,lyric:t.lyric??``,lyric_prompt:t.lyric_prompt??``,lyrics_mode:t.lyrics_mode??`manual`,title:t.title??``,style:t.style??``,style_negative:t.style_negative??``,vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),J.success(this.$t(`suno.message.reusePromptSuccess`))},async onExtractVocals(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.extractingVocals`)),Y.vox({audio_id:e,callback_url:Gi},{token:t}).then(()=>{J.success(this.$t(`suno.message.extractVocalsSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.extractVocalsFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.fetchingTiming`)),Y.timing({audio_id:e},{token:t}).then(e=>{J.success(this.$t(`suno.message.fetchTimingSuccess`)),console.debug(`timing data`,e.data)}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.fetchTimingFailed`))}))},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,J.info(this.$t(`suno.message.fetchingWav`));let n=(await Y.wav({audio_id:e.id},{token:t})).data?.data?.[0]?.file_url;n?this.onDownload(null,n):J.error(this.$t(`suno.message.fetchWavFailed`))}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;let t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,J.info(this.$t(`suno.message.fetchingMidi`));let n=(await Y.midi({audio_id:e.id},{token:t})).data?.data;if(!n?.length){J.error(this.$t(`suno.message.fetchMidiFailed`));return}let r=(e.title||e.id||`suno`).replace(/[^\w.-]+/g,`_`)+`.json`;(0,Wi.saveAs)(new Blob([JSON.stringify(n,null,2)],{type:`application/json`}),r)}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchMidiFailed`))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Gi},r=this.credential?.token;if(!r){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),Y.audio(n,{token:r}).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},isMashupSelected(e){return!!e.id&&this.mashupAudioIds.includes(e.id)},onToggleMashup(e){if(!e.id)return;let t=[...this.mashupAudioIds],n=t.indexOf(e.id);n===-1?t.push(e.id):t.splice(n,1),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,mashup_audio_ids:t})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},onStartTitleEdit(e){this.editingAudioId=e.id??null,this.editingTitle=e.title||``,this.$nextTick(()=>{this.$refs.titleInput?.focus?.()})},onSaveTitleEdit(e){if(this.editingAudioId!==e.id)return;let t=this.editingTitle.trim();if(t&&t!==e.title){let n=this.$store.state.suno?.tasks;if(n?.items)for(let r of n.items){let n=(r?.response?.data??[]).find(t=>t.id===e.id);if(n){n.title=t;break}}}this.editingAudioId=null,this.editingTitle=``},onCancelTitleEdit(){this.editingAudioId=null,this.editingTitle=``},async onDelete(e){try{await q.confirm(this.$t(`suno.message.confirmDelete`),{confirmButtonText:this.$t(`suno.button.delete`),cancelButtonText:this.$t(`common.button.cancel`),type:`warning`})}catch{return}let t=this.$store.state.suno?.tasks;if(t?.items)for(let n of t.items){let r=n?.response?.data??[],i=r.findIndex(t=>t.id===e.id);if(i!==-1){if(r.splice(i,1),r.length===0){let e=t.items.indexOf(n);e!==-1&&t.items.splice(e,1)}break}}this.$store.state?.suno?.audio?.id===e.id&&this.$store.dispatch(`suno/setAudio`,null),J.success(this.$t(`suno.message.deleteSuccess`))},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`suno/getTasks`,{limit:30,offset:0})}}}),qi={class:`task`},Ji=[`onClick`],Yi=[`onClick`],Xi={class:`left`},Zi=[`onClick`],Qi=[`onClick`],$i={key:2,class:`duration`},ea={class:`info`},ta={key:1,class:`title-row`},na={class:`title`},ra={class:`style`},ia={key:2,class:`progress-row`},aa={class:`progress-text`},oa={class:`right`},sa={class:`el-dropdown-link`},ca={class:`flex items-center min-w-[120px]`},la={class:`flex items-center min-w-[120px]`},ua={class:`flex items-center min-w-[120px]`},da={class:`el-dropdown-link`};function fa(r,p,v,b,x,S){let C=g(`el-checkbox`),w=g(`el-image`),T=g(`video-pause`),E=g(`el-icon`),D=g(`video-play`),O=g(`el-input`),k=g(`font-awesome-icon`),A=g(`el-progress`),j=g(`el-tooltip`),M=g(`Loading`),N=g(`el-dropdown-item`),P=g(`el-dropdown-menu`),F=g(`el-dropdown`),I=g(`api-code-dialog`),L=h(`loading`);return u(),t(`div`,qi,[(u(!0),t(s,null,e(r.audios,e=>(u(),t(`div`,{key:e.id,class:c([`audio`,{"mashup-selected":r.isMashupSelected(e)}]),onClick:d(t=>r.onClick(e),[`stop`])},[r.isMashupMode&&e?.audio_url?(u(),t(`div`,{key:0,class:`mashup-check`,onClick:d(t=>r.onToggleMashup(e),[`stop`])},[o(C,{"model-value":r.isMashupSelected(e),onClick:p[0]||=d(()=>{},[`stop`])},null,8,[`model-value`])],8,Yi)):m(``,!0),f((u(),t(`div`,Xi,[o(w,{src:e?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),e?.audio_url&&r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:d(t=>r.onPause(e),[`stop`])},[o(E,null,{default:_(()=>[o(T)]),_:1})],8,Zi)):m(``,!0),e?.audio_url&&(r.$store.state?.suno?.audio?.id!==e.id||r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:d(t=>r.onPlay(e),[`stop`])},[o(E,null,{default:_(()=>[o(D)]),_:1})],8,Qi)):m(``,!0),e?.duration?(u(),t(`div`,$i,l(r.useFormatDuring(e?.duration)),1)):m(``,!0)])),[[L,!e?.audio_url]]),n(`div`,ea,[r.editingAudioId===e.id?(u(),t(`div`,{key:0,class:`title-edit`,onClick:p[2]||=d(()=>{},[`stop`])},[o(O,{ref_for:!0,ref:`titleInput`,modelValue:r.editingTitle,"onUpdate:modelValue":p[1]||=e=>r.editingTitle=e,size:`small`,onKeyup:[y(t=>r.onSaveTitleEdit(e),[`enter`]),y(r.onCancelTitleEdit,[`escape`])],onBlur:t=>r.onSaveTitleEdit(e)},null,8,[`modelValue`,`onKeyup`,`onBlur`])])):(u(),t(`div`,ta,[n(`h2`,na,l(e?.title),1),e?.audio_url?(u(),a(k,{key:0,icon:`fa-solid fa-pen`,class:`edit-icon`,onClick:d(t=>r.onStartTitleEdit(e),[`stop`])},null,8,[`onClick`])):m(``,!0)])),n(`p`,ra,l(e?.style),1),!e?.audio_url&&e?.progress!=null&&e?.progress<100?(u(),t(`div`,ia,[o(A,{percentage:Math.round(e.progress),"stroke-width":4,"show-text":!1,status:`warning`,class:`progress-bar`},null,8,[`percentage`]),n(`span`,aa,l(r.$t(`suno.name.generating`))+` `+l(Math.round(e.progress))+`%`,1)])):m(``,!0)]),n(`div`,oa,[o(F,null,{dropdown:_(()=>[o(P,null,{default:_(()=>[o(N,{disabled:r.isFetchingVideoUrl,onClick:t=>r.handleVideoDownload(e)},{default:_(()=>[n(`div`,ca,[r.isFetchingVideoUrl?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onDownload(t,e?.audio_url),[`stop`])},{default:_(()=>[i(l(r.$t(`suno.button.download_audio`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{disabled:r.isFetchingWav,onClick:t=>r.handleWavDownload(e)},{default:_(()=>[n(`div`,la,[r.isFetchingWav?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`]),o(N,{disabled:r.isFetchingMidi,onClick:t=>r.handleMidiDownload(e)},{default:_(()=>[n(`div`,ua,[r.isFetchingMidi?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_midi`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:_(()=>[n(`span`,sa,[o(j,{effect:`dark`,content:r.$t(`suno.button.download`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),o(F,null,{dropdown:_(()=>[o(P,{class:`suno-action-menu`},{default:_(()=>[e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onExtend(t,e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-forward`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extend`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(t=>r.onCover(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-music`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.cover_music`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:1,onClick:d(t=>r.onMashup(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-shuffle`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.mashup`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id&&e?.action===`extend`?(u(),a(N,{key:2,onClick:d(t=>r.onConcatMusic(e?.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-link`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.concat_music`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[4]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:3,onClick:d(t=>r.onReplaceSection(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-scissors`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.replace_section`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:4,onClick:d(t=>r.onOverpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-microphone`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.overpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:5,onClick:d(t=>r.onUnderpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-guitar`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.underpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:6,onClick:d(t=>r.onSamples(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-drum`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.samples`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[5]||=n(`div`,{class:`menu-divider`},null,-1),e.id?(u(),a(N,{key:7,onClick:d(t=>r.onGetStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-layer-group`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.id?(u(),a(N,{key:8,onClick:d(t=>r.onGetAllStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-bars-staggered`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.all_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:9,onClick:d(t=>r.onRemaster(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-wand-magic-sparkles`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.remaster`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:10,onClick:d(t=>r.onExtractVocals(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-headphones`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extract_vocals`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:11,onClick:d(t=>r.onArtistConsistency(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-palette`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.artist_consistency`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:12,onClick:d(t=>r.onAdjustSpeed(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-gauge-high`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.adjust_speed`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[6]||=n(`div`,{class:`menu-divider`},null,-1),o(N,{onClick:d(t=>r.onReusePrompt(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-rotate-left`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.reuse_prompt`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:13,onClick:d(t=>r.onGetTiming(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-clock`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_timing`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(r.onViewCode,[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-code`,class:`menu-icon`}),i(` `+l(r.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`]),p[7]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:14,class:`delete-item`,onClick:d(t=>r.onDelete(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-trash`,class:`menu-icon delete-icon`}),i(` `+l(r.$t(`suno.button.delete`)),1)]),_:1},8,[`onClick`])):m(``,!0)]),_:2},1024)]),default:_(()=>[n(`span`,da,[o(j,{effect:`dark`,content:r.$t(`suno.button.more`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],10,Ji))),128)),o(I,{visible:r.apiCodeVisible,"onUpdate:visible":p[3]||=e=>r.apiCodeVisible=e,method:`POST`,path:r.apiCodePath,body:r.apiCodeBody,token:r.$store.state.suno?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var pa=r({name:`RecentPanel`,components:{ElSkeletonItem:ae,ElSkeleton:oe,ElInput:G,ElButton:b,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElPopover:re,ElRadioGroup:R,ElRadioButton:L,ElSelect:E,ElOption:D,FontAwesomeIcon:Z,TaskPreview:W(Ki,[[`render`,fa]]),Player:Ee,NoTasks:Ce,ScrollList:ye},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0,searchQuery:``,sortBy:`newest`,filterType:`all`,filterDuration:`all`,filterVideo:`all`,filterModel:`all`}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}},sortLabel(){return this.sortBy===`newest`?this.$t(`suno.sort.newest`):this.$t(`suno.sort.oldest`)},activeFilterCount(){let e=0;return this.filterType!==`all`&&e++,this.filterDuration!==`all`&&e++,this.filterVideo!==`all`&&e++,this.filterModel&&this.filterModel!==`all`&&e++,e},availableModels(){let e=this.tasks?.items||[],t=new Set;for(let n of e){let e=n?.response?.data??[];for(let n of e)n.model&&t.add(n.model)}return Array.from(t).sort()},filteredTasks(){let e=this.tasks?.items||[];if(this.searchQuery){let t=this.searchQuery.toLowerCase();e=e.filter(e=>(e?.response?.data??[]).some(e=>e.title?.toLowerCase().includes(t)||e.style?.toLowerCase().includes(t)||e.prompt?.toLowerCase().includes(t)))}return this.activeFilterCount>0&&(e=e.filter(e=>{let t=e?.request??{},n=e?.response?.data??[];return this.filterType===`vocal`&&t.instrumental===!0||this.filterType===`instrumental`&&t.instrumental!==!0?!1:this.filterDuration!==`all`||this.filterVideo!==`all`||this.filterModel&&this.filterModel!==`all`?n.some(e=>!(this.filterDuration===`short`&&!(typeof e.duration==`number`&&e.duration<60)||this.filterDuration===`medium`&&!(typeof e.duration==`number`&&e.duration>=60&&e.duration<=180)||this.filterDuration===`long`&&!(typeof e.duration==`number`&&e.duration>180)||this.filterVideo===`with`&&!e.video_url||this.filterVideo===`without`&&e.video_url||this.filterModel&&this.filterModel!==`all`&&e.model!==this.filterModel)):!0})),this.sortBy===`oldest`&&(e=[...e].reverse()),e}},methods:{onSortChange(e){this.sortBy=e},onResetFilters(){this.filterType=`all`,this.filterDuration=`all`,this.filterVideo=`all`,this.filterModel=`all`},getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ma={key:0,class:`tasks`},ha={class:`left w-[70px] p-[10px] flex items-center`},ga={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},_a={key:0,class:`task-toolbar`},va={key:0,class:`filter-badge`},ya={class:`filter-popover`},ba={class:`filter-row`},xa={class:`filter-label`},Sa={class:`filter-row`},Ca={class:`filter-label`},wa={class:`filter-row`},Ta={class:`filter-label`},Ea={key:0,class:`filter-row`},Da={class:`filter-label`},Oa={class:`filter-actions`},ka={key:2,class:`w-full flex-1 flex items-center justify-center`},Aa={class:`text-sm text-gray-400`},ja={key:3,class:`w-full flex-1 flex flex-col items-center justify-center gap-2`},Ma={class:`text-sm text-gray-400`},Na={key:4,class:`w-full flex-1 flex items-center justify-center`},Pa={class:`h-20`};function Fa(r,d,p,h,y,b){let x=g(`el-skeleton-item`),S=g(`el-skeleton`),C=g(`font-awesome-icon`),w=g(`el-input`),T=g(`el-button`),E=g(`el-dropdown-item`),D=g(`el-dropdown-menu`),O=g(`el-dropdown`),k=g(`el-radio-button`),A=g(`el-radio-group`),j=g(`el-option`),M=g(`el-select`),N=g(`el-popover`),P=g(`task-preview`),F=g(`scroll-list`),I=g(`no-tasks`),L=g(`player`);return u(),t(s,null,[r.tasks?.items===void 0?(u(),t(`div`,ma,[(u(),t(s,null,e(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,ha,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,ga,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),o(x,{variant:`text`})]),_:1})])])),64))])):(u(),t(s,{key:1},[r.tasks?.items?.length?(u(),t(`div`,_a,[o(w,{modelValue:r.searchQuery,"onUpdate:modelValue":d[0]||=e=>r.searchQuery=e,size:`small`,placeholder:r.$t(`suno.placeholder.searchSongs`),clearable:``,class:`task-search`},{prefix:_(()=>[o(C,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs`})]),_:1},8,[`modelValue`,`placeholder`]),o(O,{trigger:`click`,onCommand:r.onSortChange},{dropdown:_(()=>[o(D,null,{default:_(()=>[o(E,{command:`newest`,class:c({"is-active":r.sortBy===`newest`})},{default:_(()=>[i(l(r.$t(`suno.sort.newest`)),1)]),_:1},8,[`class`]),o(E,{command:`oldest`,class:c({"is-active":r.sortBy===`oldest`})},{default:_(()=>[i(l(r.$t(`suno.sort.oldest`)),1)]),_:1},8,[`class`])]),_:1})]),default:_(()=>[o(T,{size:`small`,class:`sort-btn`},{default:_(()=>[o(C,{icon:`fa-solid fa-arrow-down-wide-short`,class:`mr-1`}),i(` `+l(r.sortLabel),1)]),_:1})]),_:1},8,[`onCommand`]),o(N,{trigger:`click`,placement:`bottom-end`,width:260},{reference:_(()=>[o(T,{size:`small`,class:c([`filter-btn`,{"has-active-filter":r.activeFilterCount>0}])},{default:_(()=>[o(C,{icon:`fa-solid fa-filter`,class:`mr-1`}),i(` `+l(r.$t(`suno.filter.title`))+` `,1),r.activeFilterCount>0?(u(),t(`span`,va,l(r.activeFilterCount),1)):m(``,!0)]),_:1},8,[`class`])]),default:_(()=>[n(`div`,ya,[n(`div`,ba,[n(`div`,xa,l(r.$t(`suno.filter.type`)),1),o(A,{modelValue:r.filterType,"onUpdate:modelValue":d[1]||=e=>r.filterType=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.typeAll`)),1)]),_:1}),o(k,{value:`vocal`},{default:_(()=>[i(l(r.$t(`suno.filter.typeVocal`)),1)]),_:1}),o(k,{value:`instrumental`},{default:_(()=>[i(l(r.$t(`suno.filter.typeInstrumental`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,Sa,[n(`div`,Ca,l(r.$t(`suno.filter.duration`)),1),o(A,{modelValue:r.filterDuration,"onUpdate:modelValue":d[2]||=e=>r.filterDuration=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.durationAll`)),1)]),_:1}),o(k,{value:`short`},{default:_(()=>[i(l(r.$t(`suno.filter.durationShort`)),1)]),_:1}),o(k,{value:`medium`},{default:_(()=>[i(l(r.$t(`suno.filter.durationMedium`)),1)]),_:1}),o(k,{value:`long`},{default:_(()=>[i(l(r.$t(`suno.filter.durationLong`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,wa,[n(`div`,Ta,l(r.$t(`suno.filter.video`)),1),o(A,{modelValue:r.filterVideo,"onUpdate:modelValue":d[3]||=e=>r.filterVideo=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.videoAll`)),1)]),_:1}),o(k,{value:`with`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWith`)),1)]),_:1}),o(k,{value:`without`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWithout`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r.availableModels.length>0?(u(),t(`div`,Ea,[n(`div`,Da,l(r.$t(`suno.filter.model`)),1),o(M,{modelValue:r.filterModel,"onUpdate:modelValue":d[4]||=e=>r.filterModel=e,size:`small`,placeholder:r.$t(`suno.filter.modelAll`),clearable:``},{default:_(()=>[o(j,{label:r.$t(`suno.filter.modelAll`),value:`all`},null,8,[`label`]),(u(!0),t(s,null,e(r.availableModels,e=>(u(),a(j,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0),n(`div`,Oa,[o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])])]),_:1})])):m(``,!0),r.filteredTasks?.length>0?(u(),a(F,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:r.loading,onReachTop:d[5]||=e=>r.$emit(`reach-top`)},{default:_(()=>[(u(!0),t(s,null,e(r.filteredTasks,(e,t)=>(u(),a(P,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):r.searchQuery&&r.tasks?.items?.length>0?(u(),t(`div`,ka,[n(`p`,Aa,l(r.$t(`suno.message.noSearchResults`)),1)])):r.activeFilterCount>0&&r.tasks?.items?.length>0?(u(),t(`div`,ja,[n(`p`,Ma,l(r.$t(`suno.message.noFilterResults`)),1),o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])):r.tasks?.items?.length===0?(u(),t(`div`,Na,[o(I)])):m(``,!0)],64)),f(n(`div`,Pa,[o(L,{namespace:`suno`})],512),[[v,!!r.$store?.state?.suno?.audio?.object]])],64)}var Ia=W(pa,[[`render`,Fa],[`__scopeId`,`data-v-6ce376c9`]]),La=r({name:`TaskPreview`,components:{IconPicture:T,ElImage:P,ElAvatar:F,ElIcon:w},computed:{audio(){return this.$store.state.suno?.audio}}}),Ra={key:0,class:`size-full overflow-hidden`},za={class:`relative h-[300px]`},Ba={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},Va={class:`absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent`},Ha={class:`p-4`},Ua={class:`flex items-center font-bold mb-2`},Wa={class:`text-[var(--el-text-color-regular)] mb-2`},Ga={class:`text-xs text-[var(--el-text-color-regular)]`},Ka={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},qa={key:1,class:`w-full h-full`};function Ja(e,r,i,a,s,c){let d=g(`icon-picture`),f=g(`el-icon`),p=g(`el-image`),m=g(`el-avatar`);return e.audio?.object?(u(),t(`div`,Ra,[n(`div`,za,[o(p,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:_(()=>[n(`div`,Ba,[o(f,{class:`text-3xl`},{default:_(()=>[o(d)]),_:1})])]),_:1},8,[`src`]),n(`h2`,Va,l(e.audio?.title),1)]),n(`div`,Ha,[n(`div`,Ua,[o(m,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,l(e.audio?.title),1)]),n(`p`,Wa,l(e.audio?.style),1),n(`p`,Ga,l(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,Ka,[n(`p`,null,l(e.audio?.lyric),1)])])])):(u(),t(`div`,qa))}var Ya=W(La,[[`render`,Ja]]),Xa=ue(`suno`),Za=r({name:`SunoIndex`,components:{Layout:Ne,ConfigPanel:Ui,RecentPanel:Ia,PreviewPanel:Ya},mixins:[fe],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await xe({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`suno/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`suno/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){de.create({application:this.application}).then(({data:e})=>{this.application=e,J.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&J.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug(`loading`);return}console.debug(`start onGetTasks`,e);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`suno/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!he(this.uploadTracker,e=>this.$t(e),e=>J.warning(e)))return;let e={...this.config,callback_url:Xa};if(!this.hasSunoInput(e)){J.error(this.$t(`suno.message.promptRequired`));return}this.hasText(e.prompt)&&(e.prompt=e.prompt.trim());let t=this.credential?.token;if(!t){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),pe(`suno`,Y.audio(e,{token:t})).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0},hasSunoInput(e){return[e.prompt,e.lyric,e.lyric_prompt,e.style,e.title].some(e=>this.hasText(e))||this.hasText(e.audio_id)||Array.isArray(e.mashup_audio_ids)&&e.mashup_audio_ids.length>0}}});function Qa(e,t,n,r,i,s){let c=g(`config-panel`),l=g(`recent-panel`),d=g(`preview-panel`),f=g(`layout`);return u(),a(f,null,{config:_(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:_(()=>[o(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:_(()=>[o(d)]),_:1})}var $a=W(Za,[[`render`,Qa],[`__scopeId`,`data-v-b9beee12`]]);export{$a as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,M as i,N as a,O as o,P as s,S as c,Wt as l,Z as u,et as d,k as f,tt as p,ut as m}from"./vendor-chart-BJCvKk8-.js";import{t as h}from"./button-DfsQodL-.js";import{r as g,t as _}from"./select-CxvkoR_I.js";import{n as v,t as y}from"./collapse-BxNTm00O.js";import{t as b}from"./drawer-Dpuj2uIl.js";import"./constants-DwFseFmM.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-1hhw9POE.js";import{t as E}from"./index.es-Ds6M0PuH.js";import{t as ee}from"./Consumption-D_CAQaSB.js";var te=r({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(e,r,i,a,o,c){let l=p(`font-awesome-icon`),f=p(`el-button`),h=p(`el-drawer`);return u(),t(`div`,D,[n(`div`,O,[d(e.$slots,`config`,{},void 0,!0)]),n(`div`,k,[d(e.$slots,`result`,{},void 0,!0)]),s(f,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:m(()=>[s(l,{icon:`fa-solid fa-search`})]),_:1}),s(h,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[d(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=r({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,N,[n(`div`,P,[n(`h2`,F,l(e.$t(`serp.name.query`)),1)]),s(d,{modelValue:e.query,"onUpdate:modelValue":r[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=r({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,r,i,a,o,c){let d=p(`el-option`),f=p(`el-select`);return u(),t(`div`,z,[n(`h2`,B,l(e.$t(`serp.name.type`)),1),s(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},{default:m(()=>[s(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),s(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),s(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),s(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=r({name:`CountryInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,W,[n(`h2`,G,l(e.$t(`serp.name.country`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=r({name:`LanguageInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,Y,[n(`h2`,X,l(e.$t(`serp.name.language`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=r({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,r,i,o,c,d){let f=p(`query-input`),h=p(`type-selector`),g=p(`country-input`),_=p(`language-input`),v=p(`consumption`),y=p(`font-awesome-icon`),b=p(`el-button`);return u(),t(`div`,ne,[n(`div`,re,[s(f,{class:`mb-4`}),s(h,{class:`mb-4`}),s(g,{class:`mb-4`}),s(_,{class:`mb-4`})]),n(`div`,ie,[s(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),s(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:m(()=>[s(y,{icon:`fa-solid fa-search`,class:`mr-2`}),a(` `+l(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=r({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(r,i,o,s,d,p){return u(),t(`div`,ce,[n(`div`,le,[r.data.image_url?(u(),t(`img`,{key:0,src:r.data.image_url,alt:r.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):f(``,!0),n(`div`,de,[r.data.type?(u(),t(`div`,fe,l(r.data.type),1)):f(``,!0),n(`h3`,pe,l(r.data.title),1),r.data.description?(u(),t(`p`,me,[a(l(r.data.description)+` `,1),r.data.description_link?(u(),t(`a`,{key:0,href:r.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},l(r.data.description_source||`Source`),9,he)):f(``,!0)])):f(``,!0),r.data.attributes&&Object.keys(r.data.attributes).length?(u(),t(`div`,ge,[(u(!0),t(c,null,e(r.data.attributes,(e,r)=>(u(),t(`div`,{key:r,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,l(r)+`:`,1),n(`span`,ve,l(e),1)]))),128))])):f(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=r({name:`OrganicResult`,props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return``;try{return new URL(this.data.link).hostname}catch{return``}},pathname(){if(!this.data.link)return``;try{let e=new URL(this.data.link).pathname;return e===`/`?``:e}catch{return``}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?``:`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display=`none`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(r,i,a,o,s,d){return u(),t(`div`,Se,[r.displayUrl?(u(),t(`div`,Ce,[n(`img`,{src:r.faviconUrl,alt:r.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:i[0]||=(...e)=>r.onFaviconError&&r.onFaviconError(...e)},null,40,we),n(`span`,Te,l(r.hostname),1),n(`span`,Ee,l(r.pathname),1)])):f(``,!0),n(`a`,{href:r.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},l(r.data.title),9,De),r.data.date?(u(),t(`div`,Oe,l(r.data.date),1)):f(``,!0),r.data.snippet?(u(),t(`p`,ke,l(r.data.snippet),1)):f(``,!0),r.data.sitelinks?.length?(u(),t(`div`,Ae,[(u(!0),t(c,null,e(r.data.sitelinks,(e,n)=>(u(),t(`a`,{key:n,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors`},l(e.title),9,je))),128))])):f(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=r({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={class:`absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200`},Ve={class:`text-xs text-white line-clamp-2`};function He(r,i,a,o,s,d){return u(),t(`div`,Fe,[n(`h3`,Ie,l(r.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):f(``,!0),n(`div`,Be,[n(`span`,Ve,l(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=r({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,Ge,l(r.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):f(``,!0),e.duration?(u(),t(`div`,Xe,l(e.duration),1)):f(``,!0)]),n(`div`,Ze,[n(`div`,Qe,l(e.title),1),n(`div`,$e,[e.source?(u(),t(`span`,et,l(e.source),1)):f(``,!0),e.channel?(u(),t(`span`,tt,` · `+l(e.channel),1)):f(``,!0),e.date?(u(),t(`span`,nt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,rt,l(e.snippet),1)):f(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=r({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,st,l(r.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,l(e.title),1),n(`div`,ft,[e.source?(u(),t(`span`,pt,l(e.source),1)):f(``,!0),e.date?(u(),t(`span`,mt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,ht,l(e.snippet),1)):f(``,!0)]),e.image_url?(u(),t(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):f(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=r({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(r,i,a,d,h,g){let _=p(`el-collapse-item`),v=p(`el-collapse`);return u(),t(`div`,xt,[n(`h3`,St,l(r.$t(`serp.name.peopleAlsoAsk`)),1),s(v,null,{default:m(()=>[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),o(_,{key:n,title:e.question||e.title||``},{default:m(()=>[e.snippet?(u(),t(`p`,Ct,l(e.snippet),1)):f(``,!0),e.link?(u(),t(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},l(e.title||e.link),9,wt)):f(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=r({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(r,i,o,d,f,m){let h=p(`font-awesome-icon`);return u(),t(`div`,Ot,[n(`h3`,kt,l(r.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),t(`button`,{key:n,class:`inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none`,onClick:t=>r.onSearch(e.query)},[s(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),a(` `+l(e.query),1)],8,jt))),128))])])}var Nt=r({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit(`related-search`,e)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(r,a,d,m,h,g){let _=p(`font-awesome-icon`),v=p(`knowledge-graph`),y=p(`organic-result`),b=p(`image-results`),x=p(`video-results`),S=p(`news-results`),C=p(`people-also-ask`),w=p(`related-searches`);return u(),t(`div`,$,[r.searching?(u(),t(`div`,Pt,[(u(),t(c,null,e(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...a[0]||=[i(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):r.noResults?(u(),t(`div`,Ft,[s(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,l(r.$t(`serp.message.noResults`)),1)])):r.results?(u(),t(`div`,Lt,[r.results.knowledge_graph?.title?(u(),o(v,{key:0,data:r.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.organic?.length?(u(),t(`div`,Rt,[(u(!0),t(c,null,e(r.results.organic,(e,t)=>(u(),o(y,{key:t,data:e,class:`mb-1`},null,8,[`data`]))),128))])):f(``,!0),r.results.images?.length?(u(),o(b,{key:2,data:r.results.images,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.videos?.length?(u(),o(x,{key:3,data:r.results.videos,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.news?.length?(u(),o(S,{key:4,data:r.results.news,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.people_also_ask?.length?(u(),o(C,{key:5,data:r.results.people_also_ask,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.related_searches?.length?(u(),o(w,{key:6,data:r.results.related_searches,class:`mb-6`,onSearch:r.onRelatedSearch},null,8,[`data`,`onSearch`])):f(``,!0)])):(u(),t(`div`,zt,[s(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,l(r.$t(`serp.description.query`)),1)]))])}var Ht=r({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},inject:[`initialized`],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`serp/getService`),console.debug(`end onGetService`)},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t(`serp.message.searching`));try{await this.$store.dispatch(`serp/search`),w.success(this.$t(`serp.message.searchSuccess`))}catch(e){(e?.response?.data)?.error?.code===`used_up`?w.error(this.$t(`serp.message.usedUp`)):w.error(this.$t(`serp.message.searchFailed`))}}},async onRelatedSearch(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function Ut(e,t,n,r,i,a){let c=p(`search-panel`),l=p(`result-panel`),d=p(`layout`);return u(),o(d,null,{config:m(()=>[s(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:m(()=>[s(l,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,M as i,N as a,O as o,P as s,S as c,Wt as l,Z as u,et as d,k as f,tt as p,ut as m}from"./vendor-chart-BJCvKk8-.js";import{t as h}from"./button-DfsQodL-.js";import{r as g,t as _}from"./select-B1uV_nnl.js";import{n as v,t as y}from"./collapse-zZjSyR53.js";import{t as b}from"./drawer-Dpuj2uIl.js";import"./constants-CwLEZ_AF.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-CxBOJBZd.js";import{t as E}from"./index.es-Dw2lhymn.js";import{t as ee}from"./Consumption-C3v4xGTO.js";var te=r({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(e,r,i,a,o,c){let l=p(`font-awesome-icon`),f=p(`el-button`),h=p(`el-drawer`);return u(),t(`div`,D,[n(`div`,O,[d(e.$slots,`config`,{},void 0,!0)]),n(`div`,k,[d(e.$slots,`result`,{},void 0,!0)]),s(f,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:m(()=>[s(l,{icon:`fa-solid fa-search`})]),_:1}),s(h,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[d(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=r({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,N,[n(`div`,P,[n(`h2`,F,l(e.$t(`serp.name.query`)),1)]),s(d,{modelValue:e.query,"onUpdate:modelValue":r[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=r({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,r,i,a,o,c){let d=p(`el-option`),f=p(`el-select`);return u(),t(`div`,z,[n(`h2`,B,l(e.$t(`serp.name.type`)),1),s(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},{default:m(()=>[s(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),s(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),s(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),s(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=r({name:`CountryInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,W,[n(`h2`,G,l(e.$t(`serp.name.country`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=r({name:`LanguageInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,Y,[n(`h2`,X,l(e.$t(`serp.name.language`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=r({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,r,i,o,c,d){let f=p(`query-input`),h=p(`type-selector`),g=p(`country-input`),_=p(`language-input`),v=p(`consumption`),y=p(`font-awesome-icon`),b=p(`el-button`);return u(),t(`div`,ne,[n(`div`,re,[s(f,{class:`mb-4`}),s(h,{class:`mb-4`}),s(g,{class:`mb-4`}),s(_,{class:`mb-4`})]),n(`div`,ie,[s(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),s(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:m(()=>[s(y,{icon:`fa-solid fa-search`,class:`mr-2`}),a(` `+l(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=r({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(r,i,o,s,d,p){return u(),t(`div`,ce,[n(`div`,le,[r.data.image_url?(u(),t(`img`,{key:0,src:r.data.image_url,alt:r.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):f(``,!0),n(`div`,de,[r.data.type?(u(),t(`div`,fe,l(r.data.type),1)):f(``,!0),n(`h3`,pe,l(r.data.title),1),r.data.description?(u(),t(`p`,me,[a(l(r.data.description)+` `,1),r.data.description_link?(u(),t(`a`,{key:0,href:r.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},l(r.data.description_source||`Source`),9,he)):f(``,!0)])):f(``,!0),r.data.attributes&&Object.keys(r.data.attributes).length?(u(),t(`div`,ge,[(u(!0),t(c,null,e(r.data.attributes,(e,r)=>(u(),t(`div`,{key:r,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,l(r)+`:`,1),n(`span`,ve,l(e),1)]))),128))])):f(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=r({name:`OrganicResult`,props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return``;try{return new URL(this.data.link).hostname}catch{return``}},pathname(){if(!this.data.link)return``;try{let e=new URL(this.data.link).pathname;return e===`/`?``:e}catch{return``}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?``:`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display=`none`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(r,i,a,o,s,d){return u(),t(`div`,Se,[r.displayUrl?(u(),t(`div`,Ce,[n(`img`,{src:r.faviconUrl,alt:r.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:i[0]||=(...e)=>r.onFaviconError&&r.onFaviconError(...e)},null,40,we),n(`span`,Te,l(r.hostname),1),n(`span`,Ee,l(r.pathname),1)])):f(``,!0),n(`a`,{href:r.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},l(r.data.title),9,De),r.data.date?(u(),t(`div`,Oe,l(r.data.date),1)):f(``,!0),r.data.snippet?(u(),t(`p`,ke,l(r.data.snippet),1)):f(``,!0),r.data.sitelinks?.length?(u(),t(`div`,Ae,[(u(!0),t(c,null,e(r.data.sitelinks,(e,n)=>(u(),t(`a`,{key:n,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors`},l(e.title),9,je))),128))])):f(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=r({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={class:`absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200`},Ve={class:`text-xs text-white line-clamp-2`};function He(r,i,a,o,s,d){return u(),t(`div`,Fe,[n(`h3`,Ie,l(r.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):f(``,!0),n(`div`,Be,[n(`span`,Ve,l(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=r({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,Ge,l(r.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):f(``,!0),e.duration?(u(),t(`div`,Xe,l(e.duration),1)):f(``,!0)]),n(`div`,Ze,[n(`div`,Qe,l(e.title),1),n(`div`,$e,[e.source?(u(),t(`span`,et,l(e.source),1)):f(``,!0),e.channel?(u(),t(`span`,tt,` · `+l(e.channel),1)):f(``,!0),e.date?(u(),t(`span`,nt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,rt,l(e.snippet),1)):f(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=r({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,st,l(r.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,l(e.title),1),n(`div`,ft,[e.source?(u(),t(`span`,pt,l(e.source),1)):f(``,!0),e.date?(u(),t(`span`,mt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,ht,l(e.snippet),1)):f(``,!0)]),e.image_url?(u(),t(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):f(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=r({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(r,i,a,d,h,g){let _=p(`el-collapse-item`),v=p(`el-collapse`);return u(),t(`div`,xt,[n(`h3`,St,l(r.$t(`serp.name.peopleAlsoAsk`)),1),s(v,null,{default:m(()=>[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),o(_,{key:n,title:e.question||e.title||``},{default:m(()=>[e.snippet?(u(),t(`p`,Ct,l(e.snippet),1)):f(``,!0),e.link?(u(),t(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},l(e.title||e.link),9,wt)):f(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=r({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(r,i,o,d,f,m){let h=p(`font-awesome-icon`);return u(),t(`div`,Ot,[n(`h3`,kt,l(r.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),t(`button`,{key:n,class:`inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none`,onClick:t=>r.onSearch(e.query)},[s(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),a(` `+l(e.query),1)],8,jt))),128))])])}var Nt=r({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit(`related-search`,e)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(r,a,d,m,h,g){let _=p(`font-awesome-icon`),v=p(`knowledge-graph`),y=p(`organic-result`),b=p(`image-results`),x=p(`video-results`),S=p(`news-results`),C=p(`people-also-ask`),w=p(`related-searches`);return u(),t(`div`,$,[r.searching?(u(),t(`div`,Pt,[(u(),t(c,null,e(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...a[0]||=[i(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):r.noResults?(u(),t(`div`,Ft,[s(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,l(r.$t(`serp.message.noResults`)),1)])):r.results?(u(),t(`div`,Lt,[r.results.knowledge_graph?.title?(u(),o(v,{key:0,data:r.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.organic?.length?(u(),t(`div`,Rt,[(u(!0),t(c,null,e(r.results.organic,(e,t)=>(u(),o(y,{key:t,data:e,class:`mb-1`},null,8,[`data`]))),128))])):f(``,!0),r.results.images?.length?(u(),o(b,{key:2,data:r.results.images,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.videos?.length?(u(),o(x,{key:3,data:r.results.videos,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.news?.length?(u(),o(S,{key:4,data:r.results.news,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.people_also_ask?.length?(u(),o(C,{key:5,data:r.results.people_also_ask,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.related_searches?.length?(u(),o(w,{key:6,data:r.results.related_searches,class:`mb-6`,onSearch:r.onRelatedSearch},null,8,[`data`,`onSearch`])):f(``,!0)])):(u(),t(`div`,zt,[s(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,l(r.$t(`serp.description.query`)),1)]))])}var Ht=r({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},inject:[`initialized`],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`serp/getService`),console.debug(`end onGetService`)},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t(`serp.message.searching`));try{await this.$store.dispatch(`serp/search`),w.success(this.$t(`serp.message.searchSuccess`))}catch(e){(e?.response?.data)?.error?.code===`used_up`?w.error(this.$t(`serp.message.usedUp`)):w.error(this.$t(`serp.message.searchFailed`))}}},async onRelatedSearch(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function Ut(e,t,n,r,i,a){let c=p(`search-panel`),l=p(`result-panel`),d=p(`layout`);return u(),o(d,null,{config:m(()=>[s(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:m(()=>[s(l,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{A as e,F as t,Z as n}from"./vendor-chart-BJCvKk8-.js";import{E as r}from"./index-
|
|
1
|
+
import{A as e,F as t,Z as n}from"./vendor-chart-BJCvKk8-.js";import{E as r}from"./index-CxBOJBZd.js";var i=t({name:`SettingsIndex`,mounted(){let e=this.$route.query.tab||``;window.dispatchEvent(new CustomEvent(`open-user-settings`,{detail:{tab:e}}))}}),a={class:`settings-page`};function o(t,r,i,o,s,c){return n(),e(`div`,a)}var s=r(i,[[`render`,o]]);export{s as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{D as e,F as t,O as n,P as r,Wt as i,Z as a,dt as o,nt as s,tt as c,ut as l}from"./vendor-chart-BJCvKk8-.js";import{n as u,t as d}from"./table-lRQt4LGt.js";import{t as f}from"./card-DjyfNde2.js";import{n as p,t as m}from"./row-
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{D as e,F as t,O as n,P as r,Wt as i,Z as a,dt as o,nt as s,tt as c,ut as l}from"./vendor-chart-BJCvKk8-.js";import{n as u,t as d}from"./table-lRQt4LGt.js";import{t as f}from"./card-DjyfNde2.js";import{n as p,t as m}from"./row-d76bUVm3.js";import{t as h}from"./Pagination-DeCHT-PM.js";import{E as g,kn as _}from"./index-CxBOJBZd.js";import{t as v}from"./CopyToClipboard-D1o-dyv3.js";var y=t({name:`ConsoleDistributionInvitees`,components:{Pagination:h,CopyToClipboard:v,ElRow:m,ElCol:p,ElTable:d,ElTableColumn:u,ElCard:f},data(){return{invitees:[],loading:!1,total:void 0,limit:10}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData()},methods:{onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{page:e}})},onFetchData(){this.loading=!0,Promise.all([this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onFetchInvitees(){let{data:e}=await _.getInvitees({limit:this.limit,offset:(this.page-1)*this.limit,ordering:`-created_at`});this.invitees=e.items,this.total=e.count}}}),b={class:`title`},x={class:`key`},S={class:`copy`},C={class:`description`},w={class:`description`},T={class:`description`},E={class:`created-at`},D={class:`pagination m-v-lg`};function O(t,u,d,f,p,m){let h=c(`el-col`),g=c(`el-row`),_=c(`copy-to-clipboard`),v=c(`el-table-column`),y=c(`el-table`),O=c(`el-card`),k=c(`pagination`),A=s(`loading`);return a(),n(g,{class:`panel`},{default:l(()=>[r(h,{span:24},{default:l(()=>[r(g,null,{default:l(()=>[r(h,{span:24},{default:l(()=>[e(`h2`,b,i(t.$t(`common.title.invitee`)),1)]),_:1})]),_:1}),r(g,null,{default:l(()=>[r(h,{span:24},{default:l(()=>[r(O,{shadow:`hover`},{default:l(()=>[o((a(),n(y,{data:t.invitees,stripe:``},{default:l(()=>[r(v,{prop:`id`,label:t.$t(`user.field.id`),"class-name":`text-center`,width:`350px`},{default:l(t=>[e(`span`,x,i(t.row.id),1),e(`span`,S,[r(_,{content:t.row.id},null,8,[`content`])])]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.username`),width:`300px`},{default:l(t=>[e(`span`,C,i(t.row?.username),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.email`),width:`300px`},{default:l(t=>[e(`span`,w,i(t.row?.email),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.nickname`),width:`200px`},{default:l(t=>[e(`span`,T,i(t.row.nickname),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.dateJoined`)},{default:l(n=>[e(`span`,E,i(t.$dayjs.format(n.row.date_joined)),1)]),_:1},8,[`label`])]),_:1},8,[`data`])),[[A,t.loading]])]),_:1})]),_:1})]),_:1}),r(g,null,{default:l(()=>[r(h,{span:10,offset:14},{default:l(()=>[e(`div`,D,[r(k,{"current-page":t.page,"page-size":t.limit,total:t.total,onChange:t.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var k=g(y,[[`render`,O],[`__scopeId`,`data-v-4556864d`]]);export{k as default};
|