@acedatacloud/nexior 3.26.2 → 3.28.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{Auth-DcpGIqwi.js → Auth-CKgx69lg.js} +1 -1
- package/dist/assets/{BotPlaceholder-Drm6xiuT.js → BotPlaceholder-BA4i65l4.js} +1 -1
- package/dist/assets/{Callback-REiOMkuD.js → Callback-CQUelAiG.js} +1 -1
- package/dist/assets/Console-Dl4hlofP.js +1 -0
- package/dist/assets/Conversation-JdOWk9fk.js +2 -0
- package/dist/assets/{CopyToClipboard-CBliPgeP.js → CopyToClipboard-BqFSadU9.js} +1 -1
- package/dist/assets/{Detail-Dnd4Nd0T.js → Detail-CnRTBwJJ.js} +1 -1
- package/dist/assets/{EditArray-KYrcEW6W.js → EditArray-CBm5KJ-K.js} +1 -1
- package/dist/assets/Extra-DnJrYfev.js +1 -0
- package/dist/assets/FilePreview-BBdjPKEP.js +1 -0
- package/dist/assets/{History-CeaaKZfy.js → History-c2ENkbMd.js} +1 -1
- package/dist/assets/{ImagePreview-BnQhS1sy.js → ImagePreview-CGACVsa5.js} +1 -1
- package/dist/assets/{ImageWrapper-LkV6h7vR.js → ImageWrapper-un-KLqfT.js} +1 -1
- package/dist/assets/{Index-DhUCvaCi.js → Index-2k3Mx99m.js} +1 -1
- package/dist/assets/{Index-CLEC89Jo.js → Index-B_4HK3Aa.js} +1 -1
- package/dist/assets/{Index-BPs_CTLK.js → Index-B_ZTe-X9.js} +1 -1
- package/dist/assets/{Index-BWPDDqlj.js → Index-BjcHYTxP.js} +1 -1
- package/dist/assets/Index-BnfIxLqg.js +1 -0
- package/dist/assets/{Index-6xzU8HJN.js → Index-BoRIPlmI.js} +1 -1
- package/dist/assets/Index-BuWsdzqC.css +1 -0
- package/dist/assets/{Index-CqoL0s33.js → Index-BuecK55z.js} +1 -1
- package/dist/assets/{Index-DC_YoIhM.js → Index-BxGDNe0H.js} +1 -1
- package/dist/assets/Index-CScLeGbw.js +1 -0
- package/dist/assets/{Index-xa7bNKA9.js → Index-Cbe8yM6k.js} +1 -1
- package/dist/assets/{Index-CLBa1eAb.js → Index-Cf_9AsIJ.js} +1 -1
- package/dist/assets/{Index-CaI6zBZ3.js → Index-Cr59hhnT.js} +1 -1
- package/dist/assets/Index-DICPM4zM.css +1 -0
- package/dist/assets/Index-DRfMbnUx.css +1 -0
- package/dist/assets/{Index-DjI-ZL96.js → Index-DrjNWPyQ.js} +1 -1
- package/dist/assets/{Index-E1wsWno5.js → Index-DsQw14S4.js} +1 -1
- package/dist/assets/{Index-CRTcv7xy.js → Index-KY3i1fI4.js} +1 -1
- package/dist/assets/{Index-B17LFoFo.js → Index-MhhxeK5x.js} +1 -1
- package/dist/assets/Index-RYUTR7xN.js +1 -0
- package/dist/assets/{Index-VAxSP8lV.js → Index-bASnRn4N.js} +1 -1
- package/dist/assets/{Invitees-BdKbK4gL.js → Invitees-DIKvvhGa.js} +1 -1
- package/dist/assets/{List-DURh04Gf.js → List-CjwJw7FD.js} +1 -1
- package/dist/assets/{List-4_OW5KaJ.js → List-ClAjNyDW.js} +1 -1
- package/dist/assets/List-D0uTUiwL.js +1 -0
- package/dist/assets/Main-CfA2RB2w.js +1 -0
- package/dist/assets/Navigator-BV1q9HcH.js +1 -0
- package/dist/assets/{Navigator-uXDelqaG.css → Navigator-YFB2f3eV.css} +1 -1
- package/dist/assets/{NoTasks-3Z1b05wG.js → NoTasks-DjsZiiOP.js} +1 -1
- package/dist/assets/{Pagination-DXYXr-Qm.js → Pagination-BpYLj791.js} +1 -1
- package/dist/assets/{ScrollList-BkRXLc_a.js → ScrollList-CZI70Mqs.js} +1 -1
- package/dist/assets/Status-C8yB_Nxb.js +1 -0
- package/dist/assets/Subscribe-DUkTgiWZ.js +1 -0
- package/dist/assets/{VideoPlayer-Ci_7fcAo.js → VideoPlayer-B9VH6gxB.js} +1 -1
- package/dist/assets/common-BI0LhzSA.js +1 -0
- package/dist/assets/common-BZm0QYo9.js +1 -0
- package/dist/assets/common-B_PmT7TM.js +1 -0
- package/dist/assets/common-Bcx_BuZz.js +1 -0
- package/dist/assets/common-BeAEyklZ.js +1 -0
- package/dist/assets/{common-Bj1QcGsP.js → common-BjxSss9r.js} +1 -1
- package/dist/assets/common-C4PrbbM4.js +1 -0
- package/dist/assets/common-CDLAbQQ3.js +1 -0
- package/dist/assets/common-CGNSiMOk.js +1 -0
- package/dist/assets/common-CH8h4IdQ.js +1 -0
- package/dist/assets/common-CILlPjke.js +1 -0
- package/dist/assets/common-CWvsYwT3.js +1 -0
- package/dist/assets/{common-C9eXfUEo.js → common-CogTVkeR.js} +1 -1
- package/dist/assets/common-DF-bVCeJ.js +1 -0
- package/dist/assets/common-DMKFGH3m.js +1 -0
- package/dist/assets/common-DWvZ0iLq.js +1 -0
- package/dist/assets/common-Dor4ISLG.js +1 -0
- package/dist/assets/common-opQd1j77.js +1 -0
- package/dist/assets/{distribution-zXeAGkCu.js → distribution-D2uFDwGl.js} +1 -1
- package/dist/assets/index-wwpmx6zW.js +3 -0
- package/dist/assets/{order-CCQxecEz.js → order-D3C49qOJ.js} +1 -1
- package/dist/assets/{price-7kPhVK1M.js → price-BhobpaMO.js} +1 -1
- package/dist/assets/seedance-AnsihtIj.js +1 -0
- package/dist/assets/seedance-B6dBTNgm.js +1 -0
- package/dist/assets/seedance-B6f4XmIA.js +1 -0
- package/dist/assets/seedance-B8F_qZdM.js +1 -0
- package/dist/assets/seedance-BDqaGwRr.js +1 -0
- package/dist/assets/seedance-BE7oMOQE.js +1 -0
- package/dist/assets/seedance-BrPtBqgE.js +1 -0
- package/dist/assets/seedance-BretSuo5.js +1 -0
- package/dist/assets/seedance-Byj_hTQM.js +1 -0
- package/dist/assets/seedance-CXmwBwwO.js +1 -0
- package/dist/assets/seedance-D-azcSOL.js +1 -0
- package/dist/assets/seedance-D6T3LEXH.js +1 -0
- package/dist/assets/seedance-DBsvf-IB.js +1 -0
- package/dist/assets/seedance-DKyDfWeT.js +1 -0
- package/dist/assets/seedance-DrsmZxns.js +1 -0
- package/dist/assets/seedance-EU03IQt8.js +1 -0
- package/dist/assets/seedance-She0JWii.js +1 -0
- package/dist/assets/seedance-b_hRKF1n.js +1 -0
- package/dist/assets/seedance-yK0TntAo.js +1 -0
- package/dist/assets/seedream-9HGQrnmQ.js +1 -0
- package/dist/assets/seedream-BEQqbfFP.js +1 -0
- package/dist/assets/seedream-BJvUKBMX.js +1 -0
- package/dist/assets/seedream-BzuZ9hds.js +1 -0
- package/dist/assets/seedream-C6rINsxU.js +1 -0
- package/dist/assets/seedream-C8bJfp7Y.js +1 -0
- package/dist/assets/seedream-CffIOH3S.js +1 -0
- package/dist/assets/seedream-CgXKrCnZ.js +1 -0
- package/dist/assets/seedream-D05SQiHI.js +1 -0
- package/dist/assets/seedream-DCfjNk41.js +1 -0
- package/dist/assets/seedream-DLhhcuXI.js +1 -0
- package/dist/assets/seedream-DNZIPdbv.js +1 -0
- package/dist/assets/seedream-DPAubfF6.js +1 -0
- package/dist/assets/seedream-DS_yjXKY.js +1 -0
- package/dist/assets/seedream-D_xiuCd2.js +1 -0
- package/dist/assets/seedream-Dpkzm6Hz.js +1 -0
- package/dist/assets/seedream-U4U12u73.js +1 -0
- package/dist/assets/seedream-Vmqg9HQO.js +1 -0
- package/dist/assets/site-4iqz8_DA.js +1 -0
- package/dist/assets/site-55ppI4T-.js +1 -0
- package/dist/assets/site-BOvSZod0.js +1 -0
- package/dist/assets/site-BToY4pDJ.js +1 -0
- package/dist/assets/site-BbiBmtgk.js +1 -0
- package/dist/assets/site-BjefqfUj.js +1 -0
- package/dist/assets/site-BjfA71I2.js +1 -0
- package/dist/assets/site-Btp5Ha7f.js +1 -0
- package/dist/assets/site-BwCaBH7a.js +1 -0
- package/dist/assets/site-BzBwAuD5.js +1 -0
- package/dist/assets/site-CMUQEyEt.js +1 -0
- package/dist/assets/site-Co5l2JxL.js +1 -0
- package/dist/assets/site-D47nORF0.js +1 -0
- package/dist/assets/site-DKlIZ3ul.js +1 -0
- package/dist/assets/site-Dh1MiTgO.js +1 -0
- package/dist/assets/site-cRD3uvaR.js +1 -0
- package/dist/assets/site-lF_qw_wu.js +1 -0
- package/dist/assets/site-ngPqPggL.js +1 -0
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Console-BrjF9_It.js +0 -1
- package/dist/assets/Conversation-Clf-3NQi.js +0 -2
- package/dist/assets/Extra-y_XywERF.js +0 -1
- package/dist/assets/FilePreview-Bz-RkJBC.js +0 -1
- package/dist/assets/Index-CZVUVmvo.css +0 -1
- package/dist/assets/Index-DcyyV6Sz.js +0 -1
- package/dist/assets/List-B9hq6lUq.js +0 -1
- package/dist/assets/Main-F_4zsEk0.js +0 -1
- package/dist/assets/Navigator-CGT5cZ47.js +0 -1
- package/dist/assets/Status-D-2VRcqL.js +0 -1
- package/dist/assets/Subscribe-B5VcnrBh.js +0 -1
- package/dist/assets/common-B-EGiyep.js +0 -1
- package/dist/assets/common-B_8azNNB.js +0 -1
- package/dist/assets/common-BjCDdbb-.js +0 -1
- package/dist/assets/common-BkT5tE0t.js +0 -1
- package/dist/assets/common-C-IzjSKC.js +0 -1
- package/dist/assets/common-CRr8UPV-.js +0 -1
- package/dist/assets/common-CSbTh7Es.js +0 -1
- package/dist/assets/common-CnDyLF8c.js +0 -1
- package/dist/assets/common-CpvsNb6Z.js +0 -1
- package/dist/assets/common-DCBdMh4C.js +0 -1
- package/dist/assets/common-DEzGcp3u.js +0 -1
- package/dist/assets/common-Dfjl8VXX.js +0 -1
- package/dist/assets/common-DgsCAY9A.js +0 -1
- package/dist/assets/common-giBfYpVG.js +0 -1
- package/dist/assets/common-ifG7Jngn.js +0 -1
- package/dist/assets/common-oJuxEHvM.js +0 -1
- package/dist/assets/index-Dn72Szn0.js +0 -3
- package/dist/assets/site-30as7Eeg.js +0 -1
- package/dist/assets/site-BAkQ9Ebj.js +0 -1
- package/dist/assets/site-BGJJwm3f.js +0 -1
- package/dist/assets/site-BQAPnMQd.js +0 -1
- package/dist/assets/site-B_Erv7Zj.js +0 -1
- package/dist/assets/site-Bim3ymPz.js +0 -1
- package/dist/assets/site-BisuSdQk.js +0 -1
- package/dist/assets/site-C-W6v7PI.js +0 -1
- package/dist/assets/site-C3e25vk6.js +0 -1
- package/dist/assets/site-CMWmjdtE.js +0 -1
- package/dist/assets/site-DTaSBDt2.js +0 -1
- package/dist/assets/site-Dhz6GeYq.js +0 -1
- package/dist/assets/site-Dp9WkF7a.js +0 -1
- package/dist/assets/site-PQi6t6Pz.js +0 -1
- package/dist/assets/site-PmEEuVq1.js +0 -1
- package/dist/assets/site-cZxo4Kq3.js +0 -1
- package/dist/assets/site-gT_romL1.js +0 -1
- package/dist/assets/site-up7No6yR.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bG as B,bS as Y,bT as H,l as oe,bU as se,bV as D,bW as ne,bX as ie,bY as ae,bZ as le}from"./vendor-BVnhgPs4.js";import{o as Z,N as re,j as ee,J as ce,K as ue,q as de,r as k,p as N,P as pe,e as W,i as X,f as me,g as he,h as _e,n as fe,Q as te,U as $e,G as ge,T as ve,V as ye}from"./vendor-element-plus-BUOzLm6W.js";import{d as y,c as d,a as s,l as o,P as M,S as p,al as a,o as i,Z as m,F as j,ai as O,R as v,Y as I,W as g,U as K,as as J,a1 as T,b as E,z as S,w as ke,X as we,_ as be}from"./vendor-vue-Bb02XvLT.js";import{_ as w,bz as Q,bA as q,S as Ce,a3 as L,X as Ve,a2 as Ae}from"./index-Dn72Szn0.js";import{I as F,S as Pe}from"./ScrollList-BkRXLc_a.js";import{C as Se,N as Te}from"./NoTasks-3Z1b05wG.js";import{a as Ie}from"./price-7kPhVK1M.js";import{l as Ee}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const Ue=y({name:"LayoutSuno",components:{ElDrawer:re,ElButton:Z,FontAwesomeIcon:B},data(){return{drawer:!1,preview:!1}},computed:{}}),Le={class:"main flex flex-row flex-1"},je={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},Ge={class:"result h-full flex flex-col flex-1 border-r border-[var(--el-border-color)]"},De={class:"preview h-full w-[300px] flex flex-col"};function Fe(e,t,l,n,u,r){const c=a("font-awesome-icon"),h=a("el-button"),_=a("el-drawer");return i(),d("div",Le,[s("div",je,[M(e.$slots,"config",{},void 0,!0)]),s("div",Ge,[M(e.$slots,"result",{},void 0,!0)]),s("div",De,[M(e.$slots,"preview",{},void 0,!0)]),o(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:p(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:p(()=>[M(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Re=w(Ue,[["render",Fe],["__scopeId","data-v-6cc632e5"]]),ze=y({name:"VersionSelector",components:{ElSelect:ue,ElOption:ce,ElSwitch:ee},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("suno.model.model1"),value:"chirp-v2-xxl-alpha"},{label:this.$t("suno.model.model2"),value:"chirp-v3-0"},{label:this.$t("suno.model.model3"),value:"chirp-v3-5"},{label:this.$t("suno.model.model4"),value:"chirp-v4"},{label:this.$t("suno.model.model45"),value:"chirp-v4-5"},{label:this.$t("suno.model.model45plus"),value:"chirp-v4-5-plus"},{label:this.$t("suno.model.model5"),value:"chirp-v5"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){console.debug("set model",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(console.debug("set default type",Q),this.model=Q)}}),Me={class:"field"},Oe={class:"title font-bold"};function qe(e,t,l,n,u,r){const c=a("el-switch"),h=a("el-option"),_=a("el-select");return i(),d("div",Me,[s("h2",Oe,m(e.$t("suno.name.type")),1),o(c,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=f=>e.custom=f),class:"value"},null,8,["modelValue"]),o(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=f=>e.model=f),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:p(()=>[(i(!0),d(j,null,O(e.options,f=>(i(),v(h,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Be=w(ze,[["render",qe],["__scopeId","data-v-5ebe40d6"]]),Ne=y({name:"UploadAudio",components:{ElUpload:de,ElButton:Z,InfoIcon:F,FontAwesomeIcon:B},emits:["change"],data(){return{fileList:[],uploadUrl:Ce()+"/api/v1/files/"}},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(){}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){k.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){k.error(this.$t("suno.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},l=this.credential?.token;if(!l){console.error("no token specified");return}k.info(this.$t("suno.message.startingUploadAudio")),q.upload(t,{token:l}).then(n=>{console.debug("get upload music success",n.data);const u=n.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:u,action:"upload_extend"}),k.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(n=>{k.error(n?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),We={class:"relative"},Xe={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function He(e,t,l,n,u,r){const c=a("info-icon"),h=a("font-awesome-icon"),_=a("el-button"),f=a("el-upload");return i(),d("div",We,[s("div",Xe,[s("div",Ke,[s("span",Ye,m(e.$t("suno.name.referenceAudios")),1),o(c,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=C=>e.fileList=C),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[o(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[o(h,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+m(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Ze=w(Ne,[["render",He],["__scopeId","data-v-6236152c"]]),Je="",Qe=y({name:"PromptInput",components:{ElInput:N,ElSwitch:ee,InfoIcon:F},data(){return{}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}},mounted(){this.prompt||(this.prompt=Je)}}),xe={class:"field"},et={class:"box"},tt={class:"title-info"},ot={class:"title font-bold"},st={class:"instrumental"},nt={class:"title inline-block"};function it(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-switch"),_=a("el-input");return i(),d("div",xe,[s("div",et,[s("div",tt,[s("h2",ot,m(e.$t("suno.name.prompt")),1),o(c,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),s("div",st,[o(h,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=f=>e.instrumental=f),class:"value mr-2"},null,8,["modelValue"]),s("h2",nt,m(e.$t("suno.name.instrumental")),1)])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=f=>e.prompt=f),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const at=w(Qe,[["render",it],["__scopeId","data-v-d7004a7c"]]),lt="",rt=y({name:"LyricInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){console.debug("set lyric",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config}},mounted(){this.lyric||(this.lyric=lt)}}),ct={class:"field"},ut={class:"box"},dt={class:"title font-bold"};function pt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",ct,[s("div",ut,[s("h2",dt,m(e.$t("suno.name.lyrics")),1),o(c,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(i(),v(h,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(i(),v(h,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const mt=w(rt,[["render",pt],["__scopeId","data-v-99dfded8"]]),ht=y({name:"StyleInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){console.debug("set style",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},config(){return this.$store.state.suno?.config}}}),_t={class:"field"},ft={class:"title-container"},$t={class:"titlefont-bold"};function gt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",_t,[s("div",ft,[s("h2",$t,m(e.$t("suno.name.style")),1),o(c,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const vt=w(ht,[["render",gt],["__scopeId","data-v-85bbfcaa"]]),yt=y({name:"TitleInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){console.debug("set title",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}}}),kt={class:"field"},wt={class:"title-container"},bt={class:"title font-bold"};function Ct(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",kt,[s("div",wt,[s("h2",bt,m(e.$t("suno.name.title")),1),o(c,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Vt=w(yt,[["render",Ct],["__scopeId","data-v-ce70fe34"]]);function G(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const l=e%60,n=l<10?`0${l}`:l,u=t<10?`0${t}`:t;return n+":"+u}const At=y({name:"ExtendFromInput",components:{ElImage:X,ElIcon:W,ElInputNumber:pe,VideoPlay:H,VideoPause:Y},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||(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:G,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})}}}),Pt={class:"field"},St={class:"box"},Tt={class:"title font-bold"},It={class:"input-wrapper"},Et={class:"task"},Ut={class:"left"},Lt={key:2,class:"duration"},jt={class:"info"},Gt={class:"title"},Dt={class:"style"};function Ft(e,t,l,n,u,r){const c=a("el-input-number"),h=a("el-image"),_=a("video-pause"),f=a("el-icon"),C=a("video-play"),V=J("loading");return i(),d("div",Pt,[s("div",St,[s("h2",Tt,m(e.$t("suno.name.extend")),1),s("div",It,[o(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=b=>e.value=b),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"])])]),s("div",Et,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[3]||(t[3]=b=>e.onClick(e.audio))},[K((i(),d("div",Ut,[o(h,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=b=>e.onPause(e.audio))},[o(f,null,{default:p(()=>[o(_)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=b=>e.onPlay(e.audio))},[o(f,null,{default:p(()=>[o(C)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Lt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[V,!e.audio?.audio_url]]),s("div",jt,[s("h2",Gt,m(e.audio?.title),1),s("p",Dt,m(e.audio?.style),1)])])):g("",!0)])])}const Rt=w(At,[["render",Ft],["__scopeId","data-v-bcce4821"]]),zt=y({name:"CoverFromInput",components:{ElImage:X,ElIcon:W,VideoPlay:H,VideoPause:Y},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||(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:G,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})}}}),Mt={class:"field"},Ot={class:"box"},qt={class:"title font-bold"},Bt={class:"task"},Nt={class:"left"},Wt={key:2,class:"duration"},Xt={class:"info"},Kt={class:"title"},Yt={class:"style"};function Ht(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=J("loading");return i(),d("div",Mt,[s("div",Ot,[s("h2",qt,m(e.$t("suno.name.cover")),1)]),s("div",Bt,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[2]||(t[2]=V=>e.onClick(e.audio))},[K((i(),d("div",Nt,[o(c,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=V=>e.onPause(e.audio))},[o(_,null,{default:p(()=>[o(h)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=V=>e.onPlay(e.audio))},[o(_,null,{default:p(()=>[o(f)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Wt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[C,!e.audio?.audio_url]]),s("div",Xt,[s("h2",Kt,m(e.audio?.title),1),s("p",Yt,m(e.audio?.style),1)])])):g("",!0)])])}const Zt=w(zt,[["render",Ht],["__scopeId","data-v-06640216"]]),Jt=y({name:"PresetPanel",components:{TypeSelector:Be,PromptInput:at,LyricInput:mt,StyleInput:vt,TitleInput:Vt,ExtendFromInput:Rt,CoverFromInput:Zt,UploadAudio:Ze,FontAwesomeIcon:B,ElButton:Z,Consumption:Se},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Ie(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Qt={class:"flex flex-col h-full"},xt={class:"flex-1 overflow-y-auto p-[15px]"},eo={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function to(e,t,l,n,u,r){const c=a("type-selector"),h=a("upload-audio"),_=a("prompt-input"),f=a("lyric-input"),C=a("style-input"),V=a("title-input"),b=a("extend-from-input"),A=a("cover-from-input"),R=a("consumption"),U=a("font-awesome-icon"),z=a("el-button");return i(),d("div",Qt,[s("div",xt,[o(c,{class:"mb-4"}),o(h,{class:"mb-4"}),e.config?.custom?g("",!0):(i(),v(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(i(),v(f,{key:1,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(C,{key:2,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(V,{key:3,class:"mb-4"})):g("",!0),e.config?.action==="extend"?(i(),v(b,{key:4,class:"mb-4"})):g("",!0),e.config?.action==="cover"?(i(),v(A,{key:5,class:"mb-4"})):g("",!0)]),s("div",eo,[o(R,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(i(),v(z,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(i(),v(z,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const oo=w(Jt,[["render",to],["__scopeId","data-v-8c98e5e5"]]),so="https://webhook.acedata.cloud/suno",no=y({name:"TaskPreview",components:{ElImage:X,ElIcon:W,ElTooltip:fe,FontAwesomeIcon:B,VideoPlay:H,VideoPause:Y,ElDropdown:_e,ElDropdownMenu:he,ElDropdownItem:me,Loading:oe},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===L.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(l=>({...l,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:G,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);const n=new URL(t).pathname,u=n.substring(n.lastIndexOf("/")+1);console.log("on preview",u),fetch(t).then(r=>r.blob()).then(r=>{se.saveAs(r,u)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),k.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const n={audio_id:e},u=this.credential?.token;if(!u){console.error("no token specified"),l(new Error("No token specified"));return}q.mp4(n,{token:u}).then(r=>{const c=r.data?.data?.video_url;c?t(c):l(new Error("Video URL not found in response"))}).catch(r=>{l(r)})})},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 onGenerateAudioUrl(e,t){const l={action:e,audio_id:t,callback_url:so},n=this.credential?.token;if(!n){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),q.audio(l,{token:n}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(u=>{k.error(u?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),io={class:"task"},ao=["onClick"],lo={class:"left"},ro=["onClick"],co=["onClick"],uo={key:2,class:"duration"},po={class:"info"},mo={class:"title"},ho={class:"style"},_o={class:"right"},fo={class:"el-dropdown-link"},$o={class:"flex items-center min-w-[120px]"},go={class:"el-dropdown-link"};function vo(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=a("font-awesome-icon"),V=a("el-tooltip"),b=a("Loading"),A=a("el-dropdown-item"),R=a("el-dropdown-menu"),U=a("el-dropdown"),z=J("loading");return i(),d("div",io,[(i(!0),d(j,null,O(e.audios,$=>(i(),d("div",{key:$.id,class:"audio",onClick:T(P=>e.onClick($),["stop"])},[K((i(),d("div",lo,[o(c,{src:$?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),$?.audio_url&&e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="playing"?(i(),d("div",{key:0,class:"overlay",onClick:T(P=>e.onPause($),["stop"])},[o(_,null,{default:p(()=>[o(h)]),_:1})],8,ro)):g("",!0),$?.audio_url&&(e.$store.state?.suno?.audio?.id!==$.id||e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="paused")?(i(),d("div",{key:1,class:"overlay",onClick:T(P=>e.onPlay($),["stop"])},[o(_,null,{default:p(()=>[o(f)]),_:1})],8,co)):g("",!0),$?.duration?(i(),d("div",uo,m(e.useFormatDuring($?.duration)),1)):g("",!0)])),[[z,!$?.audio_url]]),s("div",po,[s("h2",mo,m($?.title),1),s("p",ho,m($?.style),1)]),s("div",_o,[o(U,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[o(A,{disabled:e.isFetchingVideoUrl,onClick:P=>e.handleVideoDownload($)},{default:p(()=>[s("div",$o,[e.isFetchingVideoUrl?(i(),v(_,{key:0,class:"is-loading mr-2"},{default:p(()=>[o(b)]),_:1})):g("",!0),s("span",null,m(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onDownload(P,$?.audio_url),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",fo,[o(V,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(U,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onExtend(P,$),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):g("",!0),$.id?(i(),v(A,{key:1,onClick:T(P=>e.onGetStems($.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):g("",!0),o(A,{onClick:T(P=>e.onCover($),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),$?.id&&$?.action==="extend"?(i(),v(A,{key:2,onClick:T(P=>e.onConcatMusic($?.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",go,[o(V,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ao))),128))])}const yo=w(no,[["render",vo]]),ko={class:"player-slider"},wo=y({__name:"PlayerSlider",setup(e){const t=D(),l=E({get:()=>t.state.suno?.audio?.progress,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:c})}),n=E({get:()=>t.state.suno?.audio?.duration,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:c})}),u=()=>{},r=c=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:c});return(c,h)=>(i(),d("div",ko,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":h[0]||(h[0]=_=>l.value=_),"show-tooltip":!1,min:0,max:n.value,onChange:r,onInput:u},null,8,["modelValue","max"])]))}}),bo="/assets/disk-XFRmVAfp.png",Co={class:"flex player-song"},Vo=["src"],Ao={class:"ml-2 text-xs flex flex-col justify-between"},Po={class:"w-52 2xl:w-96 cursor-pointer truncate"},So={class:"flex"},To={class:"ml-2 text-dc"},Io=y({__name:"PlayerSong",setup(e){const t=D(),l=E({get:()=>t.state.suno.audio,set:n=>t.commit("suno/setAudio",n)});return ke(l,(n,u)=>{if(n?.audio_url!==u?.audio_url){console.log("audio changed",n),n.object&&(console.log("111",n.object),n.object.pause(),delete n.object);const r=new Audio(n.audio_url);n.state==="playing"?r.play():r.pause(),r.addEventListener("loadedmetadata",()=>{r.currentTime=0,r.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:r.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:r})}else if(n?.progress!==u?.progress&&Math.abs(n.progress-n.object.currentTime)>2){console.log("progress changed",n.progress);const r=t.state.suno.audio;r.object&&(r.object.currentTime=r.progress)}else n?.state!==u?.state&&(console.log("state changed",n.state),n.object&&(n.state==="playing"?n.object.play():n.object.pause()));n?.volume!==u?.volume&&(console.log("volume changed",n.volume),n.object&&(n.object.volume=n.volume/100))}),(n,u)=>(i(),d("div",Co,[s("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||S(bo)},null,8,Vo),s("div",Ao,[s("div",Po,[s("div",So,[s("span",null,m(l.value?.title||"Music"),1),s("span",To,"- "+m(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Eo={class:"flex justify-end items-center gap-x-2.5"},Uo={class:"text-xs"},Lo=y({__name:"PlayerAction",setup(e){const t=D(),l=E({get:()=>t.state.suno?.audio?.progress,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:u})}),n=E({get:()=>t.state.suno?.audio?.duration,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:u})});return(u,r)=>(i(),d("div",Eo,[s("span",Uo,m(S(G)(l.value))+" / "+m(S(G)(n.value)),1)]))}}),x=y({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,l)=>(i(),v(we(t.icon),{theme:t.theme,size:t.size,spin:t.spin,fill:t.fill,"stroke-linecap":t.strokeLinecap,"stroke-linejoin":t.strokeLinejoin,"stroke-width":t.strokeWidth},null,8,["theme","size","spin","fill","stroke-linecap","stroke-linejoin","stroke-width"]))}}),jo={class:"player-volume flex flex-col items-center pt-2"},Go={class:"text-sm mt-3"},Do=y({__name:"PlayerVolumeSlider",setup(e){const t=D(),l=E({get:()=>t.state.suno.audio?.volume,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:r})}),n=E({get:()=>t.state.suno.audio?.muted,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:r})}),u=r=>t.dispatch("suno/setVolume",r);return(r,c)=>(i(),d("div",jo,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":c[0]||(c[0]=h=>l.value=h),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:n.value,onInput:u},null,8,["modelValue","disabled"]),s("div",Go,m(l.value),1)]))}}),Fo={class:"flex items-center justify-center gap-x-3"},Ro=y({__name:"PlayerController",setup(e){const t=D(),l=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),n=E(()=>t.state.suno.audio);return(u,r)=>(i(),d("div",Fo,[o(x,{icon:n.value?.state==="playing"?S(ne):S(ie),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),o(S($e),{placement:"top",width:"50px",trigger:"click"},{reference:p(()=>[o(x,{icon:S(ae),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:p(()=>[o(Do)]),_:1})]))}}),zo={class:"flex flex-col items-stretch h-20"},Mo={class:"flex grow px-5 items-center"},Oo={class:"flex-1"},qo={class:"flex-1"},Bo={class:"flex-1"},No=y({__name:"Player",setup(e){return(t,l)=>(i(),d("div",zo,[o(wo),s("div",Mo,[s("div",Oo,[o(Io)]),s("div",qo,[o(Ro)]),s("div",Bo,[o(Lo)])])]))}}),Wo=y({name:"RecentPanel",components:{ElSkeletonItem:ve,ElSkeleton:ge,TaskPreview:yo,Player:No,NoTasks:Te,ScrollList:Pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Xo={key:0,class:"tasks"},Ko={class:"left w-[70px] p-[10px] flex items-center"},Yo={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Ho={key:2,class:"w-full flex-1 flex items-center justify-center"},Zo={class:"h-20"};function Jo(e,t,l,n,u,r){const c=a("el-skeleton-item"),h=a("el-skeleton"),_=a("task-preview"),f=a("scroll-list"),C=a("no-tasks"),V=a("player");return i(),d(j,null,[e.tasks?.items===void 0?(i(),d("div",Xo,[(i(),d(j,null,O(3,b=>s("div",{key:b,class:"flex"},[s("div",Ko,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",Yo,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(c,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(i(),v(f,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:p(()=>[(i(!0),d(j,null,O(e.tasks?.items,(b,A)=>(i(),v(_,{key:A,"model-value":b,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(i(),d("div",Ho,[o(C)])):g("",!0),K(s("div",Zo,[o(V)],512),[[be,!!e.$store?.state?.suno?.audio?.object]])],64)}const Qo=w(Wo,[["render",Jo]]),xo=y({name:"TaskPreview",components:{IconPicture:le,ElImage:X,ElAvatar:ye,ElIcon:W},computed:{audio(){return this.$store.state.suno?.audio}}}),es={key:0,class:"size-full overflow-hidden"},ts={class:"relative h-[300px]"},os={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},ss={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"},ns={class:"p-4"},is={class:"flex items-center font-bold mb-2"},as={class:"text-[var(--el-text-color-regular)] mb-2"},ls={class:"text-xs text-[var(--el-text-color-regular)]"},rs={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},cs={key:1,class:"w-full h-full"};function us(e,t,l,n,u,r){const c=a("icon-picture"),h=a("el-icon"),_=a("el-image"),f=a("el-avatar");return e.audio?.object?(i(),d("div",es,[s("div",ts,[o(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:p(()=>[s("div",os,[o(h,{class:"text-3xl"},{default:p(()=>[o(c)]),_:1})])]),_:1},8,["src"]),s("h2",ss,m(e.audio?.title),1)]),s("div",ns,[s("div",is,[o(f,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,m(e.audio?.title),1)]),s("p",as,m(e.audio?.style),1),s("p",ls,m(e.$dayjs.format(e.audio?.created_at)),1),s("div",rs,[s("p",null,m(e.audio?.lyric),1)])])])):(i(),d("div",cs))}const ds=w(xo,[["render",us]]),ps="https://webhook.acedata.cloud/suno",ms=y({name:"SunoIndex",components:{Layout:Re,ConfigPanel:oo,RecentPanel:Qo,PreviewPanel:ds},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===L.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===L.Request},needApply(){return this.$store.state.suno.status.getApplications===L.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 Ee({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(){Ve.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ae&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:l,createdAtMax:n}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",n),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:l,createdAtMax:n})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:ps},t=this.credential?.token;if(!t){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),q.audio(e,{token:t}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(l=>{k.error(l?.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?.()}}});function hs(e,t,l,n,u,r){const c=a("config-panel"),h=a("recent-panel"),_=a("preview-panel"),f=a("layout");return i(),v(f,null,{config:p(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:p(()=>[o(h,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:p(()=>[o(_)]),_:1})}const Ps=w(ms,[["render",hs],["__scopeId","data-v-d1296b1a"]]);export{Ps as default};
|
|
1
|
+
import{bG as q,bS as Y,bT as Z,l as oe,bU as se,bV as D,bW as ne,bX as ie,bY as ae,bZ as le}from"./vendor-BVnhgPs4.js";import{o as H,N as re,j as ee,J as ce,K as ue,q as de,r as k,p as N,P as pe,e as W,i as K,f as me,g as he,h as _e,n as fe,Q as te,U as $e,G as ge,T as ve,V as ye}from"./vendor-element-plus-BUOzLm6W.js";import{d as y,c as d,a as s,l as o,P as M,S as p,al as a,o as i,Z as m,F as j,ai as B,R as v,Y as I,W as g,U as X,as as J,a1 as T,b as U,z as S,w as ke,X as we,_ as be}from"./vendor-vue-Bb02XvLT.js";import{_ as w,bB as Q,bC as O,U as Ce,a5 as L,Z as Ve,a4 as Ae}from"./index-wwpmx6zW.js";import{I as F,S as Pe}from"./ScrollList-CZI70Mqs.js";import{C as Se,N as Te}from"./NoTasks-DjsZiiOP.js";import{a as Ie}from"./price-BhobpaMO.js";import{l as Ue}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const Ee=y({name:"LayoutSuno",components:{ElDrawer:re,ElButton:H,FontAwesomeIcon:q},data(){return{drawer:!1,preview:!1}},computed:{}}),Le={class:"main flex flex-row flex-1"},je={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},Ge={class:"result h-full flex flex-col flex-1 border-r border-[var(--el-border-color)]"},De={class:"preview h-full w-[300px] flex flex-col"};function Fe(e,t,l,n,u,r){const c=a("font-awesome-icon"),h=a("el-button"),_=a("el-drawer");return i(),d("div",Le,[s("div",je,[M(e.$slots,"config",{},void 0,!0)]),s("div",Ge,[M(e.$slots,"result",{},void 0,!0)]),s("div",De,[M(e.$slots,"preview",{},void 0,!0)]),o(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:p(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:p(()=>[M(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Re=w(Ee,[["render",Fe],["__scopeId","data-v-6cc632e5"]]),ze=y({name:"VersionSelector",components:{ElSelect:ue,ElOption:ce,ElSwitch:ee},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("suno.model.model1"),value:"chirp-v2-xxl-alpha"},{label:this.$t("suno.model.model2"),value:"chirp-v3-0"},{label:this.$t("suno.model.model3"),value:"chirp-v3-5"},{label:this.$t("suno.model.model4"),value:"chirp-v4"},{label:this.$t("suno.model.model45"),value:"chirp-v4-5"},{label:this.$t("suno.model.model45plus"),value:"chirp-v4-5-plus"},{label:this.$t("suno.model.model5"),value:"chirp-v5"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){console.debug("set model",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(console.debug("set default type",Q),this.model=Q)}}),Me={class:"field"},Be={class:"title font-bold"};function Oe(e,t,l,n,u,r){const c=a("el-switch"),h=a("el-option"),_=a("el-select");return i(),d("div",Me,[s("h2",Be,m(e.$t("suno.name.type")),1),o(c,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=f=>e.custom=f),class:"value"},null,8,["modelValue"]),o(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=f=>e.model=f),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:p(()=>[(i(!0),d(j,null,B(e.options,f=>(i(),v(h,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const qe=w(ze,[["render",Oe],["__scopeId","data-v-5ebe40d6"]]),Ne=y({name:"UploadAudio",components:{ElUpload:de,ElButton:H,InfoIcon:F,FontAwesomeIcon:q},emits:["change"],data(){return{fileList:[],uploadUrl:Ce()+"/api/v1/files/"}},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(){}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){k.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){k.error(this.$t("suno.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},l=this.credential?.token;if(!l){console.error("no token specified");return}k.info(this.$t("suno.message.startingUploadAudio")),O.upload(t,{token:l}).then(n=>{console.debug("get upload music success",n.data);const u=n.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:u,action:"upload_extend"}),k.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(n=>{k.error(n?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),We={class:"relative"},Ke={class:"flex justify-between"},Xe={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function Ze(e,t,l,n,u,r){const c=a("info-icon"),h=a("font-awesome-icon"),_=a("el-button"),f=a("el-upload");return i(),d("div",We,[s("div",Ke,[s("div",Xe,[s("span",Ye,m(e.$t("suno.name.referenceAudios")),1),o(c,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=C=>e.fileList=C),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[o(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[o(h,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+m(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const He=w(Ne,[["render",Ze],["__scopeId","data-v-6236152c"]]),Je="",Qe=y({name:"PromptInput",components:{ElInput:N,ElSwitch:ee,InfoIcon:F},data(){return{}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}},mounted(){this.prompt||(this.prompt=Je)}}),xe={class:"field"},et={class:"box"},tt={class:"title-info"},ot={class:"title font-bold"},st={class:"instrumental"},nt={class:"title inline-block"};function it(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-switch"),_=a("el-input");return i(),d("div",xe,[s("div",et,[s("div",tt,[s("h2",ot,m(e.$t("suno.name.prompt")),1),o(c,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),s("div",st,[o(h,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=f=>e.instrumental=f),class:"value mr-2"},null,8,["modelValue"]),s("h2",nt,m(e.$t("suno.name.instrumental")),1)])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=f=>e.prompt=f),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const at=w(Qe,[["render",it],["__scopeId","data-v-d7004a7c"]]),lt="",rt=y({name:"LyricInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){console.debug("set lyric",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config}},mounted(){this.lyric||(this.lyric=lt)}}),ct={class:"field"},ut={class:"box"},dt={class:"title font-bold"};function pt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",ct,[s("div",ut,[s("h2",dt,m(e.$t("suno.name.lyrics")),1),o(c,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(i(),v(h,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(i(),v(h,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const mt=w(rt,[["render",pt],["__scopeId","data-v-99dfded8"]]),ht=y({name:"StyleInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){console.debug("set style",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},config(){return this.$store.state.suno?.config}}}),_t={class:"field"},ft={class:"title-container"},$t={class:"titlefont-bold"};function gt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",_t,[s("div",ft,[s("h2",$t,m(e.$t("suno.name.style")),1),o(c,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const vt=w(ht,[["render",gt],["__scopeId","data-v-85bbfcaa"]]),yt=y({name:"TitleInput",components:{ElInput:N,InfoIcon:F},data(){return{}},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){console.debug("set title",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}}}),kt={class:"field"},wt={class:"title-container"},bt={class:"title font-bold"};function Ct(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",kt,[s("div",wt,[s("h2",bt,m(e.$t("suno.name.title")),1),o(c,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Vt=w(yt,[["render",Ct],["__scopeId","data-v-ce70fe34"]]);function G(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const l=e%60,n=l<10?`0${l}`:l,u=t<10?`0${t}`:t;return n+":"+u}const At=y({name:"ExtendFromInput",components:{ElImage:K,ElIcon:W,ElInputNumber:pe,VideoPlay:Z,VideoPause:Y},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||(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:G,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})}}}),Pt={class:"field"},St={class:"box"},Tt={class:"title font-bold"},It={class:"input-wrapper"},Ut={class:"task"},Et={class:"left"},Lt={key:2,class:"duration"},jt={class:"info"},Gt={class:"title"},Dt={class:"style"};function Ft(e,t,l,n,u,r){const c=a("el-input-number"),h=a("el-image"),_=a("video-pause"),f=a("el-icon"),C=a("video-play"),V=J("loading");return i(),d("div",Pt,[s("div",St,[s("h2",Tt,m(e.$t("suno.name.extend")),1),s("div",It,[o(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=b=>e.value=b),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"])])]),s("div",Ut,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[3]||(t[3]=b=>e.onClick(e.audio))},[X((i(),d("div",Et,[o(h,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=b=>e.onPause(e.audio))},[o(f,null,{default:p(()=>[o(_)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=b=>e.onPlay(e.audio))},[o(f,null,{default:p(()=>[o(C)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Lt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[V,!e.audio?.audio_url]]),s("div",jt,[s("h2",Gt,m(e.audio?.title),1),s("p",Dt,m(e.audio?.style),1)])])):g("",!0)])])}const Rt=w(At,[["render",Ft],["__scopeId","data-v-bcce4821"]]),zt=y({name:"CoverFromInput",components:{ElImage:K,ElIcon:W,VideoPlay:Z,VideoPause:Y},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||(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:G,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})}}}),Mt={class:"field"},Bt={class:"box"},Ot={class:"title font-bold"},qt={class:"task"},Nt={class:"left"},Wt={key:2,class:"duration"},Kt={class:"info"},Xt={class:"title"},Yt={class:"style"};function Zt(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=J("loading");return i(),d("div",Mt,[s("div",Bt,[s("h2",Ot,m(e.$t("suno.name.cover")),1)]),s("div",qt,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[2]||(t[2]=V=>e.onClick(e.audio))},[X((i(),d("div",Nt,[o(c,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=V=>e.onPause(e.audio))},[o(_,null,{default:p(()=>[o(h)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=V=>e.onPlay(e.audio))},[o(_,null,{default:p(()=>[o(f)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Wt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[C,!e.audio?.audio_url]]),s("div",Kt,[s("h2",Xt,m(e.audio?.title),1),s("p",Yt,m(e.audio?.style),1)])])):g("",!0)])])}const Ht=w(zt,[["render",Zt],["__scopeId","data-v-06640216"]]),Jt=y({name:"PresetPanel",components:{TypeSelector:qe,PromptInput:at,LyricInput:mt,StyleInput:vt,TitleInput:Vt,ExtendFromInput:Rt,CoverFromInput:Ht,UploadAudio:He,FontAwesomeIcon:q,ElButton:H,Consumption:Se},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Ie(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Qt={class:"flex flex-col h-full"},xt={class:"flex-1 overflow-y-auto p-[15px]"},eo={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function to(e,t,l,n,u,r){const c=a("type-selector"),h=a("upload-audio"),_=a("prompt-input"),f=a("lyric-input"),C=a("style-input"),V=a("title-input"),b=a("extend-from-input"),A=a("cover-from-input"),R=a("consumption"),E=a("font-awesome-icon"),z=a("el-button");return i(),d("div",Qt,[s("div",xt,[o(c,{class:"mb-4"}),o(h,{class:"mb-4"}),e.config?.custom?g("",!0):(i(),v(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(i(),v(f,{key:1,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(C,{key:2,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(V,{key:3,class:"mb-4"})):g("",!0),e.config?.action==="extend"?(i(),v(b,{key:4,class:"mb-4"})):g("",!0),e.config?.action==="cover"?(i(),v(A,{key:5,class:"mb-4"})):g("",!0)]),s("div",eo,[o(R,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(i(),v(z,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(E,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(i(),v(z,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(E,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const oo=w(Jt,[["render",to],["__scopeId","data-v-8c98e5e5"]]),so="https://webhook.acedata.cloud/suno",no=y({name:"TaskPreview",components:{ElImage:K,ElIcon:W,ElTooltip:fe,FontAwesomeIcon:q,VideoPlay:Z,VideoPause:Y,ElDropdown:_e,ElDropdownMenu:he,ElDropdownItem:me,Loading:oe},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===L.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(l=>({...l,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:G,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);const n=new URL(t).pathname,u=n.substring(n.lastIndexOf("/")+1);console.log("on preview",u),fetch(t).then(r=>r.blob()).then(r=>{se.saveAs(r,u)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),k.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const n={audio_id:e},u=this.credential?.token;if(!u){console.error("no token specified"),l(new Error("No token specified"));return}O.mp4(n,{token:u}).then(r=>{const c=r.data?.data?.video_url;c?t(c):l(new Error("Video URL not found in response"))}).catch(r=>{l(r)})})},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 onGenerateAudioUrl(e,t){const l={action:e,audio_id:t,callback_url:so},n=this.credential?.token;if(!n){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),O.audio(l,{token:n}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(u=>{k.error(u?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),io={class:"task"},ao=["onClick"],lo={class:"left"},ro=["onClick"],co=["onClick"],uo={key:2,class:"duration"},po={class:"info"},mo={class:"title"},ho={class:"style"},_o={class:"right"},fo={class:"el-dropdown-link"},$o={class:"flex items-center min-w-[120px]"},go={class:"el-dropdown-link"};function vo(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=a("font-awesome-icon"),V=a("el-tooltip"),b=a("Loading"),A=a("el-dropdown-item"),R=a("el-dropdown-menu"),E=a("el-dropdown"),z=J("loading");return i(),d("div",io,[(i(!0),d(j,null,B(e.audios,$=>(i(),d("div",{key:$.id,class:"audio",onClick:T(P=>e.onClick($),["stop"])},[X((i(),d("div",lo,[o(c,{src:$?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),$?.audio_url&&e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="playing"?(i(),d("div",{key:0,class:"overlay",onClick:T(P=>e.onPause($),["stop"])},[o(_,null,{default:p(()=>[o(h)]),_:1})],8,ro)):g("",!0),$?.audio_url&&(e.$store.state?.suno?.audio?.id!==$.id||e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="paused")?(i(),d("div",{key:1,class:"overlay",onClick:T(P=>e.onPlay($),["stop"])},[o(_,null,{default:p(()=>[o(f)]),_:1})],8,co)):g("",!0),$?.duration?(i(),d("div",uo,m(e.useFormatDuring($?.duration)),1)):g("",!0)])),[[z,!$?.audio_url]]),s("div",po,[s("h2",mo,m($?.title),1),s("p",ho,m($?.style),1)]),s("div",_o,[o(E,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[o(A,{disabled:e.isFetchingVideoUrl,onClick:P=>e.handleVideoDownload($)},{default:p(()=>[s("div",$o,[e.isFetchingVideoUrl?(i(),v(_,{key:0,class:"is-loading mr-2"},{default:p(()=>[o(b)]),_:1})):g("",!0),s("span",null,m(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onDownload(P,$?.audio_url),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",fo,[o(V,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(E,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onExtend(P,$),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):g("",!0),$.id?(i(),v(A,{key:1,onClick:T(P=>e.onGetStems($.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):g("",!0),o(A,{onClick:T(P=>e.onCover($),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),$?.id&&$?.action==="extend"?(i(),v(A,{key:2,onClick:T(P=>e.onConcatMusic($?.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",go,[o(V,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ao))),128))])}const yo=w(no,[["render",vo]]),ko={class:"player-slider"},wo=y({__name:"PlayerSlider",setup(e){const t=D(),l=U({get:()=>t.state.suno?.audio?.progress,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:c})}),n=U({get:()=>t.state.suno?.audio?.duration,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:c})}),u=()=>{},r=c=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:c});return(c,h)=>(i(),d("div",ko,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":h[0]||(h[0]=_=>l.value=_),"show-tooltip":!1,min:0,max:n.value,onChange:r,onInput:u},null,8,["modelValue","max"])]))}}),bo="/assets/disk-XFRmVAfp.png",Co={class:"flex player-song"},Vo=["src"],Ao={class:"ml-2 text-xs flex flex-col justify-between"},Po={class:"w-52 2xl:w-96 cursor-pointer truncate"},So={class:"flex"},To={class:"ml-2 text-dc"},Io=y({__name:"PlayerSong",setup(e){const t=D(),l=U({get:()=>t.state.suno.audio,set:n=>t.commit("suno/setAudio",n)});return ke(l,(n,u)=>{if(n?.audio_url!==u?.audio_url){console.log("audio changed",n),n.object&&(console.log("111",n.object),n.object.pause(),delete n.object);const r=new Audio(n.audio_url);n.state==="playing"?r.play():r.pause(),r.addEventListener("loadedmetadata",()=>{r.currentTime=0,r.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:r.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:r})}else if(n?.progress!==u?.progress&&Math.abs(n.progress-n.object.currentTime)>2){console.log("progress changed",n.progress);const r=t.state.suno.audio;r.object&&(r.object.currentTime=r.progress)}else n?.state!==u?.state&&(console.log("state changed",n.state),n.object&&(n.state==="playing"?n.object.play():n.object.pause()));n?.volume!==u?.volume&&(console.log("volume changed",n.volume),n.object&&(n.object.volume=n.volume/100))}),(n,u)=>(i(),d("div",Co,[s("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||S(bo)},null,8,Vo),s("div",Ao,[s("div",Po,[s("div",So,[s("span",null,m(l.value?.title||"Music"),1),s("span",To,"- "+m(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Uo={class:"flex justify-end items-center gap-x-2.5"},Eo={class:"text-xs"},Lo=y({__name:"PlayerAction",setup(e){const t=D(),l=U({get:()=>t.state.suno?.audio?.progress,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:u})}),n=U({get:()=>t.state.suno?.audio?.duration,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:u})});return(u,r)=>(i(),d("div",Uo,[s("span",Eo,m(S(G)(l.value))+" / "+m(S(G)(n.value)),1)]))}}),x=y({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,l)=>(i(),v(we(t.icon),{theme:t.theme,size:t.size,spin:t.spin,fill:t.fill,"stroke-linecap":t.strokeLinecap,"stroke-linejoin":t.strokeLinejoin,"stroke-width":t.strokeWidth},null,8,["theme","size","spin","fill","stroke-linecap","stroke-linejoin","stroke-width"]))}}),jo={class:"player-volume flex flex-col items-center pt-2"},Go={class:"text-sm mt-3"},Do=y({__name:"PlayerVolumeSlider",setup(e){const t=D(),l=U({get:()=>t.state.suno.audio?.volume,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:r})}),n=U({get:()=>t.state.suno.audio?.muted,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:r})}),u=r=>t.dispatch("suno/setVolume",r);return(r,c)=>(i(),d("div",jo,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":c[0]||(c[0]=h=>l.value=h),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:n.value,onInput:u},null,8,["modelValue","disabled"]),s("div",Go,m(l.value),1)]))}}),Fo={class:"flex items-center justify-center gap-x-3"},Ro=y({__name:"PlayerController",setup(e){const t=D(),l=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),n=U(()=>t.state.suno.audio);return(u,r)=>(i(),d("div",Fo,[o(x,{icon:n.value?.state==="playing"?S(ne):S(ie),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),o(S($e),{placement:"top",width:"50px",trigger:"click"},{reference:p(()=>[o(x,{icon:S(ae),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:p(()=>[o(Do)]),_:1})]))}}),zo={class:"flex flex-col items-stretch h-20"},Mo={class:"flex grow px-5 items-center"},Bo={class:"flex-1"},Oo={class:"flex-1"},qo={class:"flex-1"},No=y({__name:"Player",setup(e){return(t,l)=>(i(),d("div",zo,[o(wo),s("div",Mo,[s("div",Bo,[o(Io)]),s("div",Oo,[o(Ro)]),s("div",qo,[o(Lo)])])]))}}),Wo=y({name:"RecentPanel",components:{ElSkeletonItem:ve,ElSkeleton:ge,TaskPreview:yo,Player:No,NoTasks:Te,ScrollList:Pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ko={key:0,class:"tasks"},Xo={class:"left w-[70px] p-[10px] flex items-center"},Yo={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Zo={key:2,class:"w-full flex-1 flex items-center justify-center"},Ho={class:"h-20"};function Jo(e,t,l,n,u,r){const c=a("el-skeleton-item"),h=a("el-skeleton"),_=a("task-preview"),f=a("scroll-list"),C=a("no-tasks"),V=a("player");return i(),d(j,null,[e.tasks?.items===void 0?(i(),d("div",Ko,[(i(),d(j,null,B(3,b=>s("div",{key:b,class:"flex"},[s("div",Xo,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",Yo,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(c,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(i(),v(f,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:p(()=>[(i(!0),d(j,null,B(e.tasks?.items,(b,A)=>(i(),v(_,{key:A,"model-value":b,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(i(),d("div",Zo,[o(C)])):g("",!0),X(s("div",Ho,[o(V)],512),[[be,!!e.$store?.state?.suno?.audio?.object]])],64)}const Qo=w(Wo,[["render",Jo]]),xo=y({name:"TaskPreview",components:{IconPicture:le,ElImage:K,ElAvatar:ye,ElIcon:W},computed:{audio(){return this.$store.state.suno?.audio}}}),es={key:0,class:"size-full overflow-hidden"},ts={class:"relative h-[300px]"},os={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},ss={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"},ns={class:"p-4"},is={class:"flex items-center font-bold mb-2"},as={class:"text-[var(--el-text-color-regular)] mb-2"},ls={class:"text-xs text-[var(--el-text-color-regular)]"},rs={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},cs={key:1,class:"w-full h-full"};function us(e,t,l,n,u,r){const c=a("icon-picture"),h=a("el-icon"),_=a("el-image"),f=a("el-avatar");return e.audio?.object?(i(),d("div",es,[s("div",ts,[o(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:p(()=>[s("div",os,[o(h,{class:"text-3xl"},{default:p(()=>[o(c)]),_:1})])]),_:1},8,["src"]),s("h2",ss,m(e.audio?.title),1)]),s("div",ns,[s("div",is,[o(f,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,m(e.audio?.title),1)]),s("p",as,m(e.audio?.style),1),s("p",ls,m(e.$dayjs.format(e.audio?.created_at)),1),s("div",rs,[s("p",null,m(e.audio?.lyric),1)])])])):(i(),d("div",cs))}const ds=w(xo,[["render",us]]),ps="https://webhook.acedata.cloud/suno",ms=y({name:"SunoIndex",components:{Layout:Re,ConfigPanel:oo,RecentPanel:Qo,PreviewPanel:ds},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===L.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===L.Request},needApply(){return this.$store.state.suno.status.getApplications===L.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 Ue({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(){Ve.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ae&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:l,createdAtMax:n}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",n),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:l,createdAtMax:n})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:ps},t=this.credential?.token;if(!t){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),O.audio(e,{token:t}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(l=>{k.error(l?.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?.()}}});function hs(e,t,l,n,u,r){const c=a("config-panel"),h=a("recent-panel"),_=a("preview-panel"),f=a("layout");return i(),v(f,null,{config:p(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:p(()=>[o(h,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:p(()=>[o(_)]),_:1})}const Ps=w(ms,[["render",hs],["__scopeId","data-v-d1296b1a"]]);export{Ps as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bG as U}from"./vendor-BVnhgPs4.js";import{o as L,N,j,q as R,r as V,p as q,n as H,B as W,i as K}from"./vendor-element-plus-BUOzLm6W.js";import{d as b,c as m,a as n,l as o,P as C,S as c,al as s,o as a,Z as i,Y as g,R as v,W as _,V as T,a1 as M,F as B,ai as X}from"./vendor-vue-Bb02XvLT.js";import{_ as w,aU as Y,aV as Z,aW as J,S as A,aX as Q,a6 as x,a3 as z}from"./index-Dn72Szn0.js";import{I as S,S as ee}from"./ScrollList-BkRXLc_a.js";import{I as D}from"./ImagePreview-BnQhS1sy.js";import{F as te}from"./FilePreview-Bz-RkJBC.js";import{V as F}from"./VideoPlayer-Ci_7fcAo.js";import{C as oe,N as se}from"./NoTasks-3Z1b05wG.js";import{a as ne}from"./price-7kPhVK1M.js";import{C as ae}from"./CopyToClipboard-CBliPgeP.js";import{B as le}from"./BotPlaceholder-Drm6xiuT.js";import{l as ie}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const re=b({name:"LayoutLuma",components:{ElDrawer:N,ElButton:L,FontAwesomeIcon:U},data(){return{drawer:!1}}}),ce={class:"main flex flex-row flex-1"},ue={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},de={class:"result h-full p-[15px] flex-1 flex flex-col"};function me(e,t,p,h,k,y){const r=s("font-awesome-icon"),d=s("el-button"),u=s("el-drawer");return a(),m("div",ce,[n("div",ue,[C(e.$slots,"config",{},void 0,!0)]),n("div",de,[C(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=$=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(u,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"350px",class:"drawer"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=w(re,[["render",me],["__scopeId","data-v-11a53e0c"]]),fe=b({name:"EnhancementSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug("set enhancement",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=Y)}}),_e={class:"relative"},he={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ge={class:"text-sm font-bold"},ve={class:"flex justify-end items-center"};function be(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",_e,[n("div",he,[n("div",$e,[n("span",ge,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),n("div",ve,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const we=w(fe,[["render",be]]),ke=b({name:"CustomSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=Z)}}),ye={class:"relative"},Ve={class:"flex justify-between"},Ee={class:"flex justify-start items-center"},Se={class:"text-sm font-bold"},Ue={class:"flex justify-end items-center"};function Le(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",ye,[n("div",Ve,[n("div",Ee,[n("span",Se,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),n("div",Ue,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const Ie=w(ke,[["render",Le]]),Te=b({name:"LoopSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug("set loop",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=J)}}),Ce={class:"relative"},je={class:"flex justify-between"},Re={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"},Pe={class:"flex justify-end items-center"};function Ge(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ce,[n("div",je,[n("div",Re,[n("span",Ae,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),n("div",Pe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const Me=w(Te,[["render",Ge]]),Be=b({name:"EndImage",components:{ElUpload:R,ElButton:L,ImagePreview:D,InfoIcon:S,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.error(this.$t("luma.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ze={class:"relative"},De={class:"flex justify-between"},Fe={class:"flex justify-start items-center"},Oe={class:"text-sm font-bold"};function Ne(e,t,p,h,k,y){const r=s("info-icon"),d=s("image-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",ze,[n("div",De,[n("div",Fe,[n("span",Oe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.url&&l.percentage!==void 0?(a(),v(d,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const qe=w(Be,[["render",Ne],["__scopeId","data-v-7ab78c3e"]]),He=b({name:"StartImage",components:{ElUpload:R,ElButton:L,ImagePreview:D,InfoIcon:S,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.error(this.$t("luma.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),We={class:"relative"},Ke={class:"flex justify-between"},Xe={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function Ze(e,t,p,h,k,y){const r=s("info-icon"),d=s("image-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",We,[n("div",Ke,[n("div",Xe,[n("span",Ye,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.percentage!=null?(a(),v(d,{key:0,url:l.url||l.response.file_url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Je=w(He,[["render",Ze],["__scopeId","data-v-425a8cec"]]),Qe=b({name:"UploadVideo",components:{ElUpload:R,ElButton:L,InfoIcon:S,FilePreview:te,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||(this.value=void 0)},methods:{onExceed(){V.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){V.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",p=e.size/1024/1024<10;return t?p?!0:(V.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(V.error(this.$t("luma.message.uploadVideoTypeFailed")),!1)},onSetVideoUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e,action:"extend"})},async onSuccess(){this.onSetVideoUrl()}}}),xe={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,p,h,k,y){const r=s("info-icon"),d=s("file-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",xe,[n("div",et,[n("div",tt,[n("span",ot,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),accept:".mp4",name:"file",class:"value","show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.percentage!=null?(a(),v(d,{key:0,url:l.url||l.response?.file_url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const nt=w(Qe,[["render",st],["__scopeId","data-v-74e51526"]]),at="",lt=b({name:"PromptInput",components:{ElInput:q,InfoIcon:S},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=at)}}),it={class:"field"},rt={class:"box"},ct={class:"title font-bold"};function ut(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-input");return a(),m("div",it,[n("div",rt,[n("h2",ct,i(e.$t("luma.name.prompt")),1),o(r,{content:e.$t("luma.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("luma.placeholder.prompt"),maxlength:2e3,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const dt=w(lt,[["render",ut],["__scopeId","data-v-e8284075"]]),mt=b({name:"ExtendFromInput",components:{VideoPlayer:F},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),pt={class:"relative"},ft={class:"flex mb-2"},_t={class:"text-sm font-bold"};function ht(e,t,p,h,k,y){const r=s("video-player");return a(),m("div",pt,[n("div",ft,[n("span",_t,i(e.$t("luma.name.extend")),1)]),n("div",null,[e.config?.video_url?(a(),v(r,{key:0,src:e.config?.video_url},null,8,["src"])):_("",!0)])])}const $t=w(mt,[["render",ht]]),gt=b({name:"ConfigPanel",components:{LoopSelector:Me,StartImageInput:Je,EndImageInput:qe,EnhancementSelector:we,ElButton:L,FontAwesomeIcon:U,PromptInput:dt,ExtendFromInput:$t,CustomSelector:Ie,UploadVideo:nt,Consumption:oe},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),vt={class:"flex flex-col h-full"},bt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function kt(e,t,p,h,k,y){const r=s("extend-from-input"),d=s("prompt-input"),u=s("custom-selector"),$=s("upload-video"),f=s("start-image-input"),l=s("end-image-input"),E=s("enhancement-selector"),I=s("loop-selector"),O=s("consumption"),P=s("font-awesome-icon"),G=s("el-button");return a(),m("div",vt,[n("div",bt,[e.config?.video_id||e.config?.video_url?(a(),v(r,{key:0,class:"mb-4"})):_("",!0),o(d,{class:"mb-4"}),e.config?.video_id?_("",!0):(a(),v(u,{key:1,class:"mb-4"})),e.config?.custom?(a(),v($,{key:2,class:"mb-4"})):_("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),v(f,{key:3,class:"mb-4"})):_("",!0),o(l,{class:"mb-4"}),o(E,{class:"mb-4"}),o(I,{class:"mb-4"})]),n("div",wt,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),v(G,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(P,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),v(G,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(P,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const yt=w(gt,[["render",kt]]),Vt=b({name:"TaskPreview",components:{ElImage:K,CopyToClipboard:ae,FontAwesomeIcon:U,ElAlert:W,VideoPlayer:F,ElTooltip:H,ElButton:L},props:{modelValue:{type:Object,required:!0}},emits:["extend"],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug("set config",t),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:"extend",thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit("extend")},onDownload(e){window.open(e,"_blank")}}}),Et={class:"preview"},St={class:"left"},Ut={class:"main"},Lt={class:"bot"},It={class:"datetime"},Tt={class:"info"},Ct={key:0,class:"prompt mt-2"},jt={key:0},Rt={key:1},At={key:0,class:T({content:!0,failed:!0})},Pt={key:0,class:"mb-4"},Gt={key:1,class:T({operations:!0,"mt-2":!0,"mb-4":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:T({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ot={key:2,class:T({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function qt(e,t,p,h,k,y){const r=s("el-image"),d=s("video-player"),u=s("el-button"),$=s("el-tooltip"),f=s("font-awesome-icon"),l=s("copy-to-clipboard"),E=s("el-alert");return a(),m("div",Et,[n("div",St,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),n("div",Ut,[n("div",Lt,[g(i(e.$t("luma.name.lumaBot"))+" ",1),n("span",It,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),n("div",Tt,[e.modelValue?.request?.prompt?(a(),m("p",Ct,[g(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?_("",!0):(a(),m("span",jt," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Rt," - ("+i(e.$t("luma.status.processing"))+") ",1)):_("",!0)])):_("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",At,[e.modelValue.response.video_url?(a(),m("div",Pt,[o(d,{src:e.modelValue.response.video_url},null,8,["src"])])):_("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Gt,[o($,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(u,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=M(I=>e.onExtend(I,e.modelValue?.response),["stop"]))},{default:c(()=>[g(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),o($,{class:"box-item",effect:"dark",content:e.$t("luma.message.downloadVideo"),placement:"top-start"},{default:c(()=>[o(u,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=M(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[g(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"])])):_("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[n("p",Mt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):_("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",Bt,[o(E,{closable:!1,class:"failure"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[n("p",zt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])]),n("p",Dt,[o(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+i(e.$t("luma.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),o(l,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),n("p",Ft,[o(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+i(e.$t("luma.name.traceId"))+": "+i(e.modelValue?.trace_id)+" ",1),o(l,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):_("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Ot,[o(E,{closable:!1,class:"info"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[n("p",Nt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):_("",!0)])])}const Ht=w(Vt,[["render",qt],["__scopeId","data-v-1b4a59bc"]]),Wt=b({name:"RecentPanel",components:{BotPlaceholder:le,TaskPreview:Ht,NoTasks:se,ScrollList:ee},props:{loading:{type:Boolean,default:!1}},emits:["reach-top","extend"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Kt={key:0},Xt={key:2,class:"w-full h-full flex items-center justify-center"};function Yt(e,t,p,h,k,y){const r=s("bot-placeholder"),d=s("task-preview"),u=s("scroll-list"),$=s("no-tasks");return a(),m(B,null,[e.tasks?.items===void 0?(a(),m("div",Kt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),v(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=f=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(B,null,X(e.tasks?.items,f=>(a(),v(d,{key:f.id,"model-value":f,onExtend:t[0]||(t[0]=l=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):_("",!0),e.tasks?.items?.length===0?(a(),m("div",Xt,[o($)])):_("",!0)],64)}const Zt=w(Wt,[["render",Yt]]),Jt="https://webhook.acedata.cloud/luma",Qt=b({name:"LumaIndex",components:{ConfigPanel:yt,Layout:pe,RecentPanel:Zt},inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===z.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ie({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("luma/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("luma/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){console.debug("scrolling down"),await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:p,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:p,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Jt},t=this.credential?.token;if(!t){console.error("no token specified");return}V.info(this.$t("luma.message.startingTask")),Q.generate(e,{token:t}).then(()=>{V.success(this.$t("luma.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===x?V.error(this.$t("luma.message.usedUp")):V.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function xt(e,t,p,h,k,y){const r=s("config-panel"),d=s("recent-panel"),u=s("layout");return a(),v(u,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=$=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const go=w(Qt,[["render",xt]]);export{go as default};
|
|
1
|
+
import{bG as U}from"./vendor-BVnhgPs4.js";import{o as L,N,j,q as R,r as V,p as q,n as H,B as W,i as Y}from"./vendor-element-plus-BUOzLm6W.js";import{d as b,c as m,a as n,l as o,P as C,S as c,al as s,o as a,Z as i,Y as g,R as v,W as _,V as T,a1 as M,F as B,ai as Z}from"./vendor-vue-Bb02XvLT.js";import{_ as w,aW as K,aX as X,aY as J,U as A,aZ as Q,a8 as x,a5 as z}from"./index-wwpmx6zW.js";import{I as S,S as ee}from"./ScrollList-CZI70Mqs.js";import{I as D}from"./ImagePreview-CGACVsa5.js";import{F as te}from"./FilePreview-BBdjPKEP.js";import{V as F}from"./VideoPlayer-B9VH6gxB.js";import{C as oe,N as se}from"./NoTasks-DjsZiiOP.js";import{a as ne}from"./price-BhobpaMO.js";import{C as ae}from"./CopyToClipboard-BqFSadU9.js";import{B as le}from"./BotPlaceholder-BA4i65l4.js";import{l as ie}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const re=b({name:"LayoutLuma",components:{ElDrawer:N,ElButton:L,FontAwesomeIcon:U},data(){return{drawer:!1}}}),ce={class:"main flex flex-row flex-1"},ue={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},de={class:"result h-full p-[15px] flex-1 flex flex-col"};function me(e,t,p,h,k,y){const r=s("font-awesome-icon"),d=s("el-button"),u=s("el-drawer");return a(),m("div",ce,[n("div",ue,[C(e.$slots,"config",{},void 0,!0)]),n("div",de,[C(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=$=>e.drawer=!0)},{default:c(()=>[o(r,{icon:"fa-solid fa-magic"})]),_:1}),o(u,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"350px",class:"drawer"},{default:c(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=w(re,[["render",me],["__scopeId","data-v-11a53e0c"]]),fe=b({name:"EnhancementSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug("set enhancement",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=K)}}),_e={class:"relative"},he={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ge={class:"text-sm font-bold"},ve={class:"flex justify-end items-center"};function be(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",_e,[n("div",he,[n("div",$e,[n("span",ge,i(e.$t("luma.name.enhancement")),1),o(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),n("div",ve,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const we=w(fe,[["render",be]]),ke=b({name:"CustomSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=X)}}),ye={class:"relative"},Ve={class:"flex justify-between"},Ee={class:"flex justify-start items-center"},Se={class:"text-sm font-bold"},Ue={class:"flex justify-end items-center"};function Le(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",ye,[n("div",Ve,[n("div",Ee,[n("span",Se,i(e.$t("luma.name.custom")),1),o(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),n("div",Ue,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const Ie=w(ke,[["render",Le]]),Te=b({name:"LoopSelector",components:{ElSwitch:j,InfoIcon:S},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug("set loop",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=J)}}),Ce={class:"relative"},je={class:"flex justify-between"},Re={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"},Pe={class:"flex justify-end items-center"};function Ge(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ce,[n("div",je,[n("div",Re,[n("span",Ae,i(e.$t("luma.name.loop")),1),o(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),n("div",Pe,[o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=u=>e.value=u),class:"value"},null,8,["modelValue"])])])])}const Me=w(Te,[["render",Ge]]),Be=b({name:"EndImage",components:{ElUpload:R,ElButton:L,ImagePreview:D,InfoIcon:S,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.error(this.$t("luma.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ze={class:"relative"},De={class:"flex justify-between"},Fe={class:"flex justify-start items-center"},Oe={class:"text-sm font-bold"};function Ne(e,t,p,h,k,y){const r=s("info-icon"),d=s("image-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",ze,[n("div",De,[n("div",Fe,[n("span",Oe,i(e.$t("luma.name.endImageUrl")),1),o(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.url&&l.percentage!==void 0?(a(),v(d,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const qe=w(Be,[["render",Ne],["__scopeId","data-v-7ab78c3e"]]),He=b({name:"StartImage",components:{ElUpload:R,ElButton:L,ImagePreview:D,InfoIcon:S,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.error(this.$t("luma.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),We={class:"relative"},Ye={class:"flex justify-between"},Ze={class:"flex justify-start items-center"},Ke={class:"text-sm font-bold"};function Xe(e,t,p,h,k,y){const r=s("info-icon"),d=s("image-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",We,[n("div",Ye,[n("div",Ze,[n("span",Ke,i(e.$t("luma.name.startImageUrl")),1),o(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.percentage!=null?(a(),v(d,{key:0,url:l.url||l.response.file_url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Je=w(He,[["render",Xe],["__scopeId","data-v-425a8cec"]]),Qe=b({name:"UploadVideo",components:{ElUpload:R,ElButton:L,InfoIcon:S,FilePreview:te,FontAwesomeIcon:U},data(){return{fileList:[],uploadUrl:A()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||(this.value=void 0)},methods:{onExceed(){V.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){V.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const t=e.type==="video/mp4",p=e.size/1024/1024<10;return t?p?!0:(V.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(V.error(this.$t("luma.message.uploadVideoTypeFailed")),!1)},onSetVideoUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e,action:"extend"})},async onSuccess(){this.onSetVideoUrl()}}}),xe={class:"relative"},et={class:"flex justify-between"},tt={class:"flex justify-start items-center"},ot={class:"text-sm font-bold"};function st(e,t,p,h,k,y){const r=s("info-icon"),d=s("file-preview"),u=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return a(),m("div",xe,[n("div",et,[n("div",tt,[n("span",ot,i(e.$t("luma.name.videoUrl")),1),o(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=l=>e.fileList=l),accept:".mp4",name:"file",class:"value","show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:c(({file:l})=>[l.percentage!=null?(a(),v(d,{key:0,url:l.url||l.response?.file_url,name:l.name,percentage:l.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):_("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(u,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const nt=w(Qe,[["render",st],["__scopeId","data-v-74e51526"]]),at="",lt=b({name:"PromptInput",components:{ElInput:q,InfoIcon:S},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=at)}}),it={class:"field"},rt={class:"box"},ct={class:"title font-bold"};function ut(e,t,p,h,k,y){const r=s("info-icon"),d=s("el-input");return a(),m("div",it,[n("div",rt,[n("h2",ct,i(e.$t("luma.name.prompt")),1),o(r,{content:e.$t("luma.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=u=>e.prompt=u),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("luma.placeholder.prompt"),maxlength:2e3,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const dt=w(lt,[["render",ut],["__scopeId","data-v-e8284075"]]),mt=b({name:"ExtendFromInput",components:{VideoPlayer:F},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),pt={class:"relative"},ft={class:"flex mb-2"},_t={class:"text-sm font-bold"};function ht(e,t,p,h,k,y){const r=s("video-player");return a(),m("div",pt,[n("div",ft,[n("span",_t,i(e.$t("luma.name.extend")),1)]),n("div",null,[e.config?.video_url?(a(),v(r,{key:0,src:e.config?.video_url},null,8,["src"])):_("",!0)])])}const $t=w(mt,[["render",ht]]),gt=b({name:"ConfigPanel",components:{LoopSelector:Me,StartImageInput:Je,EndImageInput:qe,EnhancementSelector:we,ElButton:L,FontAwesomeIcon:U,PromptInput:dt,ExtendFromInput:$t,CustomSelector:Ie,UploadVideo:nt,Consumption:oe},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),vt={class:"flex flex-col h-full"},bt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function kt(e,t,p,h,k,y){const r=s("extend-from-input"),d=s("prompt-input"),u=s("custom-selector"),$=s("upload-video"),f=s("start-image-input"),l=s("end-image-input"),E=s("enhancement-selector"),I=s("loop-selector"),O=s("consumption"),P=s("font-awesome-icon"),G=s("el-button");return a(),m("div",vt,[n("div",bt,[e.config?.video_id||e.config?.video_url?(a(),v(r,{key:0,class:"mb-4"})):_("",!0),o(d,{class:"mb-4"}),e.config?.video_id?_("",!0):(a(),v(u,{key:1,class:"mb-4"})),e.config?.custom?(a(),v($,{key:2,class:"mb-4"})):_("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),v(f,{key:3,class:"mb-4"})):_("",!0),o(l,{class:"mb-4"}),o(E,{class:"mb-4"}),o(I,{class:"mb-4"})]),n("div",wt,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),v(G,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(P,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),v(G,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(P,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const yt=w(gt,[["render",kt]]),Vt=b({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:ae,FontAwesomeIcon:U,ElAlert:W,VideoPlayer:F,ElTooltip:H,ElButton:L},props:{modelValue:{type:Object,required:!0}},emits:["extend"],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug("set config",t),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:"extend",thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit("extend")},onDownload(e){window.open(e,"_blank")}}}),Et={class:"preview"},St={class:"left"},Ut={class:"main"},Lt={class:"bot"},It={class:"datetime"},Tt={class:"info"},Ct={key:0,class:"prompt mt-2"},jt={key:0},Rt={key:1},At={key:0,class:T({content:!0,failed:!0})},Pt={key:0,class:"mb-4"},Gt={key:1,class:T({operations:!0,"mt-2":!0,"mb-4":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:T({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ot={key:2,class:T({content:!0})},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function qt(e,t,p,h,k,y){const r=s("el-image"),d=s("video-player"),u=s("el-button"),$=s("el-tooltip"),f=s("font-awesome-icon"),l=s("copy-to-clipboard"),E=s("el-alert");return a(),m("div",Et,[n("div",St,[o(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),n("div",Ut,[n("div",Lt,[g(i(e.$t("luma.name.lumaBot"))+" ",1),n("span",It,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),n("div",Tt,[e.modelValue?.request?.prompt?(a(),m("p",Ct,[g(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?_("",!0):(a(),m("span",jt," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Rt," - ("+i(e.$t("luma.status.processing"))+") ",1)):_("",!0)])):_("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",At,[e.modelValue.response.video_url?(a(),m("div",Pt,[o(d,{src:e.modelValue.response.video_url},null,8,["src"])])):_("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Gt,[o($,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:c(()=>[o(u,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=M(I=>e.onExtend(I,e.modelValue?.response),["stop"]))},{default:c(()=>[g(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),o($,{class:"box-item",effect:"dark",content:e.$t("luma.message.downloadVideo"),placement:"top-start"},{default:c(()=>[o(u,{type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=M(I=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:c(()=>[g(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"])])):_("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:c(()=>[n("p",Mt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):_("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",Bt,[o(E,{closable:!1,class:"failure"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[n("p",zt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])]),n("p",Dt,[o(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+i(e.$t("luma.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),o(l,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),n("p",Ft,[o(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+i(e.$t("luma.name.traceId"))+": "+i(e.modelValue?.trace_id)+" ",1),o(l,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):_("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Ot,[o(E,{closable:!1,class:"info"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:c(()=>[n("p",Nt,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),o(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):_("",!0)])])}const Ht=w(Vt,[["render",qt],["__scopeId","data-v-1b4a59bc"]]),Wt=b({name:"RecentPanel",components:{BotPlaceholder:le,TaskPreview:Ht,NoTasks:se,ScrollList:ee},props:{loading:{type:Boolean,default:!1}},emits:["reach-top","extend"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Yt={key:0},Zt={key:2,class:"w-full h-full flex items-center justify-center"};function Kt(e,t,p,h,k,y){const r=s("bot-placeholder"),d=s("task-preview"),u=s("scroll-list"),$=s("no-tasks");return a(),m(B,null,[e.tasks?.items===void 0?(a(),m("div",Yt,[o(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),v(u,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:t[1]||(t[1]=f=>e.$emit("reach-top"))},{default:c(()=>[(a(!0),m(B,null,Z(e.tasks?.items,f=>(a(),v(d,{key:f.id,"model-value":f,onExtend:t[0]||(t[0]=l=>e.$emit("extend"))},null,8,["model-value"]))),128))]),_:1},8,["loading"])):_("",!0),e.tasks?.items?.length===0?(a(),m("div",Zt,[o($)])):_("",!0)],64)}const Xt=w(Wt,[["render",Kt]]),Jt="https://webhook.acedata.cloud/luma",Qt=b({name:"LumaIndex",components:{ConfigPanel:yt,Layout:pe,RecentPanel:Xt},inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===z.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===z.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ie({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("luma/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("luma/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){console.debug("scrolling down"),await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:p,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("luma/getTasks",{limit:t,createdAtMin:p,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Jt},t=this.credential?.token;if(!t){console.error("no token specified");return}V.info(this.$t("luma.message.startingTask")),Q.generate(e,{token:t}).then(()=>{V.success(this.$t("luma.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===x?V.error(this.$t("luma.message.usedUp")):V.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function xt(e,t,p,h,k,y){const r=s("config-panel"),d=s("recent-panel"),u=s("layout");return a(),v(u,null,{config:c(()=>[o(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||(t[0]=$=>e.$emit("extend"))},null,8,["loading","onReachTop"])]),_:1})}const go=w(Qt,[["render",xt]]);export{go as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bG as S}from"./vendor-BVnhgPs4.js";import{o as L,N as j,J as P,K as G,P as B,Q as D,q as F,r as y,p as M,B as O,i as N}from"./vendor-element-plus-BUOzLm6W.js";import{d as $,c as i,a as l,l as t,P as E,S as f,al as s,o as a,Z as r,F as V,ai as I,R as w,Y as h,W as k,V as U}from"./vendor-vue-Bb02XvLT.js";import{_ as v,bs as q,bt as z,bu as X,S as K,bv as W,a6 as H,a3 as A}from"./index-Dn72Szn0.js";import{I as C,S as J}from"./ScrollList-BkRXLc_a.js";import{I as Q}from"./ImagePreview-BnQhS1sy.js";import{C as Y,N as Z}from"./NoTasks-3Z1b05wG.js";import{a as ee}from"./price-7kPhVK1M.js";import{C as te}from"./CopyToClipboard-CBliPgeP.js";import{I as oe}from"./ImageWrapper-LkV6h7vR.js";import{B as se}from"./BotPlaceholder-Drm6xiuT.js";import{l as ne}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const le=$({name:"LayoutFlux",components:{ElDrawer:j,ElButton:L,FontAwesomeIcon:S},data(){return{drawer:!1}}}),ae={class:"main flex flex-row flex-1"},re={class:"config w-[300px] flex-none h-full overflow-y-auto border-r border-[var(--el-border-color)]"},ie={class:"result h-full p-[15px] flex-1 flex flex-col min-w-0 overflow-x-hidden"};function ce(e,o,m,d,b,x){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),i("div",ae,[l("div",re,[E(e.$slots,"config",{},void 0,!0)]),l("div",ie,[E(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=p=>e.drawer=!0)},{default:f(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:f(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",ce],["__scopeId","data-v-8a4bf519"]]),de=$({name:"ModelSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"flux-dev",label:"flux-dev"},{value:"flux-pro",label:"flux-pro"},{value:"flux-pro-1.1",label:"flux-pro-1.1"},{value:"flux-pro-1.1-ultra",label:"flux-pro-1.1-ultra"},{value:"flux-kontext-pro",label:"flux-kontext-pro"},{value:"flux-kontext-max",label:"flux-kontext-max"}]}},computed:{value:{get(){return this.$store.state.flux?.config?.model},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,model:e})}}},mounted(){this.value||(this.value=q)}}),pe={class:"field"},me={class:"title font-bold"};function fe(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",pe,[l("h2",me,r(e.$t("flux.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(de,[["render",fe],["__scopeId","data-v-8df4b8a7"]]),he=$({name:"CountSelector",components:{ElSlider:D,InfoIcon:C,ElInputNumber:B},computed:{value:{get(){return this.$store.state.flux?.config?.count},set(e){console.debug("set count",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,count:e})}}},mounted(){this.value||(this.value=z)}}),ge={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ve={class:"text-sm font-bold"},be={class:"flex justify-end items-center"},xe={class:"w-full"};function ke(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input-number"),n=s("el-slider");return a(),i("div",null,[l("div",ge,[l("div",$e,[l("span",ve,r(e.$t("flux.name.numbers")),1),t(c,{content:e.$t("flux.description.numbers")},null,8,["content"])]),l("div",be,[t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=p=>e.value=p),"controls-position":"right"},null,8,["modelValue"])])]),l("div",xe,[t(n,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=p=>e.value=p),min:1,max:4,step:1},null,8,["modelValue"])])])}const we=v(he,[["render",ke]]),ye=$({name:"ActionSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"generate",label:this.$t("flux.name.generate")},{value:"edits",label:this.$t("flux.name.edits")}]}},computed:{value:{get(){return this.$store.state.flux?.config?.action},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Ve={class:"field"},Te={class:"title font-bold"};function Se(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",Ve,[l("h2",Te,r(e.$t("flux.name.task")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=v(ye,[["render",Se],["__scopeId","data-v-81fd05e5"]]),Ee=$({name:"ImageUrlInput",components:{ElUpload:F,ElButton:L,InfoIcon:C,FontAwesomeIcon:S,ImagePreview:Q},emits:["change"],data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{urls:{handler(e){console.debug("URLs changed:",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,image_url:e[0]})}}},methods:{onExceed(){y.warning(this.$t("flux.message.uploadStartImageExceed"))},onError(){y.error(this.$t("flux.message.uploadStartImageError"))}}}),Le={class:"relative"},Ue={class:"flex justify-between"},Ce={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"};function Pe(e,o,m,d,b,x){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),p=s("el-button"),g=s("el-upload");return a(),i("div",Le,[l("div",Ue,[l("div",Ce,[l("span",Ae,r(e.$t("flux.name.imageUrl")),1),t(c,{content:e.$t("flux.description.imageUrl")},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=_=>e.fileList=_),name:"file",limit:5,class:"upload-wrapper",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{file:f(({file:_})=>[t(u,{url:_.url||_.response?.file_url,name:_.name,percentage:_.percentage,onRemove:T=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])]),default:f(()=>[t(p,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:f(()=>[t(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+r(e.$t("flux.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","headers"])])}const Ge=v(Ee,[["render",Pe],["__scopeId","data-v-04710032"]]),Re="",je=$({name:"PromptInput",components:{ElInput:M,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.flux?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Re)}}),Be={class:"field"},De={class:"box"},Fe={class:"title font-bold"};function Me(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input");return a(),i("div",Be,[l("div",De,[l("h2",Fe,r(e.$t("flux.name.prompt")),1),t(c,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Oe=v(je,[["render",Me],["__scopeId","data-v-4c101a17"]]),Ne=$({name:"PresetPanel",components:{ElButton:L,FontAwesomeIcon:S,PromptInput:Oe,ModelSelector:_e,CountSelector:we,Consumption:Y,ActionSelector:Ie,ImageUrlInput:Ge},emits:["generate"],computed:{config(){return this.$store.state.flux?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit("generate")}}}),qe={class:"flex flex-col h-full"},ze={class:"flex-1 overflow-y-auto p-[15px]"},Xe={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ke(e,o,m,d,b,x){const c=s("action-selector"),u=s("prompt-input"),n=s("image-url-input"),p=s("model-selector"),g=s("count-selector"),_=s("consumption"),T=s("font-awesome-icon"),R=s("el-button");return a(),i("div",qe,[l("div",ze,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),e.config?.action==="edits"?(a(),w(n,{key:0,class:"mb-4"})):k("",!0),t(p,{class:"mb-4"}),t(g,{class:"mb-4"})]),l("div",Xe,[t(_,{value:e.consumption,service:e.service},null,8,["value","service"]),t(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:f(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+r(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])}const We=v(Ne,[["render",Ke]]),He=$({name:"TaskPreview",components:{ElImage:N,CopyToClipboard:te,FontAwesomeIcon:S,ElAlert:O,ImageWrapper:oe},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.flux?.application},config(){return this.$store.state.flux?.config},images(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(m=>{let d=m;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Je={class:"preview"},Qe={class:"left"},Ye={class:"main"},Ze={class:"bot"},et={class:"datetime"},tt={class:"info"},ot={key:0,class:"prompt mt-2"},st={key:0},nt={key:0,class:U({content:!0,failed:!0})},lt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:1,class:U({content:!0})},ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:2,class:U({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function ft(e,o,m,d,b,x){const c=s("el-image"),u=s("image-wrapper"),n=s("font-awesome-icon"),p=s("copy-to-clipboard"),g=s("el-alert");return a(),i("div",Je,[l("div",Qe,[t(c,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),l("div",Ye,[l("div",Ze,[h(r(e.$t("flux.name.fluxBot"))+" ",1),l("span",et,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",tt,[e.modelValue?.request?.prompt?(a(),i("p",ot,[h(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?k("",!0):(a(),i("span",st," - ("+r(e.$t("flux.status.pending"))+") ",1))])):k("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",nt,[l("div",lt,[(a(!0),i(V,null,I(e.images,(_,T)=>(a(),w(u,{key:T,src:_?.image_url,"raw-src":_?.image_url,"model-value":_},null,8,["src","raw-src","model-value"]))),128))]),t(g,{closable:!1,class:"mt-2 success"},{default:f(()=>[l("p",at,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.model"))+": "+r(e.modelValue?.request?.model),1)]),l("p",rt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?.success===!1?(a(),i("div",it,[t(g,{closable:!1,class:"failure"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",ct,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",ut,[t(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+r(e.$t("flux.name.failureReason"))+": "+r(e.modelValue?.response?.error?.message)+" ",1),t(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",dt,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),t(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?k("",!0):(a(),i("div",pt,[t(g,{closable:!1,class:"info"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",mt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const _t=v(He,[["render",ft],["__scopeId","data-v-fd5838a5"]]),ht=$({name:"RecentPanel",components:{TaskPreview:_t,BotPlaceholder:se,NoTasks:Z,ScrollList:J},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),gt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function vt(e,o,m,d,b,x){const c=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),p=s("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",gt,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=g=>e.$emit("reach-top"))},{default:f(()=>[(a(!0),i(V,null,I(e.tasks?.items,g=>(a(),w(u,{key:g.id,"model-value":g},null,8,["model-value"]))),128))]),_:1},8,["loading"])):k("",!0),e.tasks?.items?.length===0?(a(),i("div",$t,[t(p)])):k("",!0)],64)}const bt=v(ht,[["render",vt]]),xt="https://webhook.acedata.cloud/flux",kt=$({name:"FluxIndex",components:{ConfigPanel:We,Layout:ue,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.flux?.status?.getApplications===A.Request},tasksLoading(){return this.$store.state.flux?.status?.getTasks===A.Request||this.fetchingTasks},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ne({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("flux/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("flux/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:m,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:xt},o=this.credential?.token;if(!o){console.error("no token specified");return}y.info(this.$t("flux.message.startingTask")),W.generate(e,{token:o}).then(()=>{y.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const d=m?.response?.data;d?.error?.code===H?y.error(this.$t("flux.message.usedUp")):y.error(this.$t("flux.message.startTaskFailed")+d?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,o,m,d,b,x){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:f(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:f(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ft=v(kt,[["render",wt]]);export{Ft as default};
|
|
1
|
+
import{bG as I}from"./vendor-BVnhgPs4.js";import{o as L,N as j,J as P,K as G,P as B,Q as D,q as F,r as y,p as M,B as O,i as N}from"./vendor-element-plus-BUOzLm6W.js";import{d as $,c as i,a as l,l as t,P as E,S as f,al as s,o as a,Z as r,F as V,ai as S,R as w,Y as h,W as k,V as U}from"./vendor-vue-Bb02XvLT.js";import{_ as v,bu as q,bv as z,bw as X,U as K,bx as W,a8 as H,a5 as A}from"./index-wwpmx6zW.js";import{I as C,S as J}from"./ScrollList-CZI70Mqs.js";import{I as Q}from"./ImagePreview-CGACVsa5.js";import{C as Y,N as Z}from"./NoTasks-DjsZiiOP.js";import{a as ee}from"./price-BhobpaMO.js";import{C as te}from"./CopyToClipboard-BqFSadU9.js";import{I as oe}from"./ImageWrapper-un-KLqfT.js";import{B as se}from"./BotPlaceholder-BA4i65l4.js";import{l as ne}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const le=$({name:"LayoutFlux",components:{ElDrawer:j,ElButton:L,FontAwesomeIcon:I},data(){return{drawer:!1}}}),ae={class:"main flex flex-row flex-1"},re={class:"config w-[300px] flex-none h-full overflow-y-auto border-r border-[var(--el-border-color)]"},ie={class:"result h-full p-[15px] flex-1 flex flex-col min-w-0 overflow-x-hidden"};function ce(e,o,m,d,b,x){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),i("div",ae,[l("div",re,[E(e.$slots,"config",{},void 0,!0)]),l("div",ie,[E(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=p=>e.drawer=!0)},{default:f(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:f(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",ce],["__scopeId","data-v-8a4bf519"]]),de=$({name:"ModelSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"flux-dev",label:"flux-dev"},{value:"flux-pro",label:"flux-pro"},{value:"flux-pro-1.1",label:"flux-pro-1.1"},{value:"flux-pro-1.1-ultra",label:"flux-pro-1.1-ultra"},{value:"flux-kontext-pro",label:"flux-kontext-pro"},{value:"flux-kontext-max",label:"flux-kontext-max"}]}},computed:{value:{get(){return this.$store.state.flux?.config?.model},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,model:e})}}},mounted(){this.value||(this.value=q)}}),pe={class:"field"},me={class:"title font-bold"};function fe(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",pe,[l("h2",me,r(e.$t("flux.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,S(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(de,[["render",fe],["__scopeId","data-v-8df4b8a7"]]),he=$({name:"CountSelector",components:{ElSlider:D,InfoIcon:C,ElInputNumber:B},computed:{value:{get(){return this.$store.state.flux?.config?.count},set(e){console.debug("set count",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,count:e})}}},mounted(){this.value||(this.value=z)}}),ge={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ve={class:"text-sm font-bold"},be={class:"flex justify-end items-center"},xe={class:"w-full"};function ke(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input-number"),n=s("el-slider");return a(),i("div",null,[l("div",ge,[l("div",$e,[l("span",ve,r(e.$t("flux.name.numbers")),1),t(c,{content:e.$t("flux.description.numbers")},null,8,["content"])]),l("div",be,[t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=p=>e.value=p),"controls-position":"right"},null,8,["modelValue"])])]),l("div",xe,[t(n,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=p=>e.value=p),min:1,max:4,step:1},null,8,["modelValue"])])])}const we=v(he,[["render",ke]]),ye=$({name:"ActionSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"generate",label:this.$t("flux.name.generate")},{value:"edits",label:this.$t("flux.name.edits")}]}},computed:{value:{get(){return this.$store.state.flux?.config?.action},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Ve={class:"field"},Te={class:"title font-bold"};function Ie(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",Ve,[l("h2",Te,r(e.$t("flux.name.task")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,S(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Se=v(ye,[["render",Ie],["__scopeId","data-v-81fd05e5"]]),Ee=$({name:"ImageUrlInput",components:{ElUpload:F,ElButton:L,InfoIcon:C,FontAwesomeIcon:I,ImagePreview:Q},emits:["change"],data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{urls:{handler(e){console.debug("URLs changed:",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,image_url:e[0]})}}},methods:{onExceed(){y.warning(this.$t("flux.message.uploadStartImageExceed"))},onError(){y.error(this.$t("flux.message.uploadStartImageError"))}}}),Le={class:"relative"},Ue={class:"flex justify-between"},Ce={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"};function Pe(e,o,m,d,b,x){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),p=s("el-button"),g=s("el-upload");return a(),i("div",Le,[l("div",Ue,[l("div",Ce,[l("span",Ae,r(e.$t("flux.name.imageUrl")),1),t(c,{content:e.$t("flux.description.imageUrl")},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=_=>e.fileList=_),name:"file",limit:5,class:"upload-wrapper",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{file:f(({file:_})=>[t(u,{url:_.url||_.response?.file_url,name:_.name,percentage:_.percentage,onRemove:T=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])]),default:f(()=>[t(p,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:f(()=>[t(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+r(e.$t("flux.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","headers"])])}const Ge=v(Ee,[["render",Pe],["__scopeId","data-v-04710032"]]),Re="",je=$({name:"PromptInput",components:{ElInput:M,InfoIcon:C},computed:{prompt:{get(){return this.$store.state.flux?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Re)}}),Be={class:"field"},De={class:"box"},Fe={class:"title font-bold"};function Me(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input");return a(),i("div",Be,[l("div",De,[l("h2",Fe,r(e.$t("flux.name.prompt")),1),t(c,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Oe=v(je,[["render",Me],["__scopeId","data-v-4c101a17"]]),Ne=$({name:"PresetPanel",components:{ElButton:L,FontAwesomeIcon:I,PromptInput:Oe,ModelSelector:_e,CountSelector:we,Consumption:Y,ActionSelector:Se,ImageUrlInput:Ge},emits:["generate"],computed:{config(){return this.$store.state.flux?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit("generate")}}}),qe={class:"flex flex-col h-full"},ze={class:"flex-1 overflow-y-auto p-[15px]"},Xe={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ke(e,o,m,d,b,x){const c=s("action-selector"),u=s("prompt-input"),n=s("image-url-input"),p=s("model-selector"),g=s("count-selector"),_=s("consumption"),T=s("font-awesome-icon"),R=s("el-button");return a(),i("div",qe,[l("div",ze,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),e.config?.action==="edits"?(a(),w(n,{key:0,class:"mb-4"})):k("",!0),t(p,{class:"mb-4"}),t(g,{class:"mb-4"})]),l("div",Xe,[t(_,{value:e.consumption,service:e.service},null,8,["value","service"]),t(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:f(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+r(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])}const We=v(Ne,[["render",Ke]]),He=$({name:"TaskPreview",components:{ElImage:N,CopyToClipboard:te,FontAwesomeIcon:I,ElAlert:O,ImageWrapper:oe},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.flux?.application},config(){return this.$store.state.flux?.config},images(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(m=>{let d=m;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Je={class:"preview"},Qe={class:"left"},Ye={class:"main"},Ze={class:"bot"},et={class:"datetime"},tt={class:"info"},ot={key:0,class:"prompt mt-2"},st={key:0},nt={key:0,class:U({content:!0,failed:!0})},lt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:1,class:U({content:!0})},ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:2,class:U({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function ft(e,o,m,d,b,x){const c=s("el-image"),u=s("image-wrapper"),n=s("font-awesome-icon"),p=s("copy-to-clipboard"),g=s("el-alert");return a(),i("div",Je,[l("div",Qe,[t(c,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),l("div",Ye,[l("div",Ze,[h(r(e.$t("flux.name.fluxBot"))+" ",1),l("span",et,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",tt,[e.modelValue?.request?.prompt?(a(),i("p",ot,[h(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?k("",!0):(a(),i("span",st," - ("+r(e.$t("flux.status.pending"))+") ",1))])):k("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",nt,[l("div",lt,[(a(!0),i(V,null,S(e.images,(_,T)=>(a(),w(u,{key:T,src:_?.image_url,"raw-src":_?.image_url,"model-value":_},null,8,["src","raw-src","model-value"]))),128))]),t(g,{closable:!1,class:"mt-2 success"},{default:f(()=>[l("p",at,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.model"))+": "+r(e.modelValue?.request?.model),1)]),l("p",rt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?.success===!1?(a(),i("div",it,[t(g,{closable:!1,class:"failure"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",ct,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",ut,[t(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+r(e.$t("flux.name.failureReason"))+": "+r(e.modelValue?.response?.error?.message)+" ",1),t(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",dt,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),t(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?k("",!0):(a(),i("div",pt,[t(g,{closable:!1,class:"info"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",mt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const _t=v(He,[["render",ft],["__scopeId","data-v-fd5838a5"]]),ht=$({name:"RecentPanel",components:{TaskPreview:_t,BotPlaceholder:se,NoTasks:Z,ScrollList:J},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),gt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function vt(e,o,m,d,b,x){const c=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),p=s("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",gt,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=g=>e.$emit("reach-top"))},{default:f(()=>[(a(!0),i(V,null,S(e.tasks?.items,g=>(a(),w(u,{key:g.id,"model-value":g},null,8,["model-value"]))),128))]),_:1},8,["loading"])):k("",!0),e.tasks?.items?.length===0?(a(),i("div",$t,[t(p)])):k("",!0)],64)}const bt=v(ht,[["render",vt]]),xt="https://webhook.acedata.cloud/flux",kt=$({name:"FluxIndex",components:{ConfigPanel:We,Layout:ue,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.flux?.status?.getApplications===A.Request},tasksLoading(){return this.$store.state.flux?.status?.getTasks===A.Request||this.fetchingTasks},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ne({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("flux/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("flux/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:m,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:xt},o=this.credential?.token;if(!o){console.error("no token specified");return}y.info(this.$t("flux.message.startingTask")),W.generate(e,{token:o}).then(()=>{y.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const d=m?.response?.data;d?.error?.code===H?y.error(this.$t("flux.message.usedUp")):y.error(this.$t("flux.message.startTaskFailed")+d?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,o,m,d,b,x){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:f(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:f(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ft=v(kt,[["render",wt]]);export{Ft as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bG as L}from"./vendor-BVnhgPs4.js";import{o as R,N as B,J as I,K as C,P as O,Q as F,q as N,r as x,p as z,n as X,B as Q,i as Y}from"./vendor-element-plus-BUOzLm6W.js";import{d as _,c as r,a as l,l as o,P as U,S as d,al as s,o as a,Z as c,F as V,ai as S,R as w,V as T,a2 as H,Y as k,W as y}from"./vendor-vue-Bb02XvLT.js";import{_ as h,bl as J,bm as K,bn as W,bo as Z,bp as ee,bq as te,S as se,br as oe,a6 as ne,a3 as D}from"./index-Dn72Szn0.js";import{I as A,S as ae}from"./ScrollList-BkRXLc_a.js";import{I as le}from"./ImagePreview-BnQhS1sy.js";import{C as ie,N as re}from"./NoTasks-3Z1b05wG.js";import{a as ce}from"./price-7kPhVK1M.js";import{C as pe}from"./CopyToClipboard-CBliPgeP.js";import{V as de}from"./VideoPlayer-Ci_7fcAo.js";import{B as ue}from"./BotPlaceholder-Drm6xiuT.js";import{l as me}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const ve=_({name:"LayoutPixverse",components:{ElDrawer:B,ElButton:R,FontAwesomeIcon:L},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},_e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},he={class:"result h-full p-[15px] flex-1 flex flex-col"};function $e(e,t,u,m,$,g){const i=s("font-awesome-icon"),p=s("el-button"),n=s("el-drawer");return a(),r("div",fe,[l("div",_e,[U(e.$slots,"config",{},void 0,!0)]),l("div",he,[U(e.$slots,"result",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:d(()=>[o(i,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"350px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ge=h(ve,[["render",$e],["__scopeId","data-v-0646853d"]]),be=_({name:"ModelSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"v3.5",label:"v3.5"},{value:"v4",label:"v4"},{value:"v4.5",label:"v4.5"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.model},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,model:e})}}},mounted(){this.value||(this.value=J)}}),ye={class:"field"},ke={class:"title font-bold"};function we(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",ye,[l("h2",ke,c(e.$t("pixverse.name.model")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=h(be,[["render",we],["__scopeId","data-v-e8f337ca"]]),Se=_({name:"QualitySelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"360p",label:"360p"},{value:"540p",label:"540p"},{value:"720p",label:"720p"},{value:"1080p",label:"1080p"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.quality},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,quality:e})}}},mounted(){this.value||(this.value=K)}}),xe={class:"field"},Ee={class:"title font-bold"};function Te(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",xe,[l("h2",Ee,c(e.$t("pixverse.name.quality")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=h(Se,[["render",Te],["__scopeId","data-v-64aeaae9"]]),Ce=_({name:"MotionSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"normal",label:this.$t("pixverse.name.motion1")},{value:"fast",label:this.$t("pixverse.name.motion2")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.motion},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,motion:e})}}},mounted(){this.value||(this.value=W)}}),Le={class:"field"},Re={class:"title font-bold"};function Pe(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",Le,[l("h2",Re,c(e.$t("pixverse.name.motion")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=h(Ce,[["render",Pe],["__scopeId","data-v-94237408"]]),Ae=_({name:"StyleSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"cyberpunk",label:this.$t("pixverse.name.style1")},{value:"anime",label:this.$t("pixverse.name.style2")},{value:"comic",label:this.$t("pixverse.name.style3")},{value:"clay",label:this.$t("pixverse.name.style4")},{value:"3d_animation",label:this.$t("pixverse.name.style5")},{value:"realistic",label:this.$t("pixverse.name.style6")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.style},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,style:e})}}},mounted(){this.value||(this.value=Z)}}),De={class:"field"},Ge={class:"title font-bold"};function je(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",De,[l("h2",Ge,c(e.$t("pixverse.name.style")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=h(Ae,[["render",je],["__scopeId","data-v-64e17b3c"]]),qe=_({name:"SeedSelector",components:{ElSlider:F,InfoIcon:A,ElInputNumber:O},computed:{value:{get(){return this.$store.state?.pixverse?.config?.seed},set(e){console.debug("set seed",e),this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,seed:e})}}},mounted(){this.value||(this.value=void 0)}}),Be={class:"flex justify-between"},Oe={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"},Ne={class:"flex justify-end items-center"},ze={class:"w-full"};function Xe(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input-number"),n=s("el-slider");return a(),r("div",null,[l("div",Be,[l("div",Oe,[l("span",Fe,c(e.$t("pixverse.name.seed")),1),o(i,{content:e.$t("pixverse.description.seed")},null,8,["content"])]),l("div",Ne,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),"controls-position":"right"},null,8,["modelValue"])])]),l("div",ze,[o(n,{modelValue:e.value,"onUpdate:modelValue":t[1]||(t[1]=f=>e.value=f),min:0,max:1e3,step:1},null,8,["modelValue"])])])}const Qe=h(qe,[["render",Xe]]),Ye=_({name:"DurationSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:5,label:"5s"},{value:8,label:"8s"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.duration},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,duration:e})}}},mounted(){this.value||(this.value=ee)}}),He={class:"field"},Je={class:"title font-bold"};function Ke(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",He,[l("h2",Je,c(e.$t("pixverse.name.duration")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const We=h(Ye,[["render",Ke],["__scopeId","data-v-065c77ef"]]),Ze=_({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.pixverse.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),et={class:"text-sm font-bold mb-2 block"},tt={class:"items"},st=["onClick"],ot={class:"name"};function nt(e,t,u,m,$,g){return a(),r("div",null,[l("span",et,c(e.$t("pixverse.name.aspectRatio")),1),l("div",tt,[(a(!0),r(V,null,S(e.options,(i,p)=>(a(),r("div",{key:p,class:T({active:e.active===p,item:!0}),onClick:n=>e.value=i.value},[l("div",{class:T(["preview",i.label])},[l("div",{class:"rect",style:H({width:i.width+"px",height:i.height+"px"})},null,4)],2),l("p",ot,c(i.label),1)],10,st))),128))])])}const at=h(Ze,[["render",nt],["__scopeId","data-v-32a7677f"]]),lt=_({name:"StartImage",components:{ElUpload:N,ElButton:R,InfoIcon:A,FontAwesomeIcon:L,ImagePreview:le},emits:["change"],data(){return{fileList:[],uploadUrl:se()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.pixverse?.config?.image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){x.warning(this.$t("pixverse.message.uploadReferencesExceed"))},onError(){x.error(this.$t("pixverse.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),it={class:"relative"},rt={class:"flex justify-between"},ct={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function dt(e,t,u,m,$,g){const i=s("info-icon"),p=s("image-preview"),n=s("font-awesome-icon"),f=s("el-button"),b=s("el-upload");return a(),r("div",it,[l("div",rt,[l("div",ct,[l("span",pt,c(e.$t("pixverse.name.startImage")),1),o(i,{content:e.$t("pixverse.description.uploadStartImage")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:v})=>[v.url&&v.percentage!==void 0?(a(),w(p,{key:0,url:v.url,name:v.name,percentage:v.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(v),1)},null,8,["url","name","percentage","onRemove"])):y("",!0)]),default:d(()=>[o(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),k(" "+c(e.$t("pixverse.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ut=h(lt,[["render",dt],["__scopeId","data-v-666104e4"]]),mt="",vt=_({name:"PromptInput",components:{ElInput:z,InfoIcon:A},computed:{prompt:{get(){return this.$store.state.pixverse?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=mt)}}),ft={class:"field"},_t={class:"box"},ht={class:"title font-bold"};function $t(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input");return a(),r("div",ft,[l("div",_t,[l("h2",ht,c(e.$t("pixverse.name.prompt")),1),o(i,{content:e.$t("pixverse.description.prompt"),class:"info"},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pixverse.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const gt=h(vt,[["render",$t],["__scopeId","data-v-b3dd608e"]]),bt=_({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:L,PromptInput:gt,ModelSelector:Ve,QualitySelector:Ie,MotionSelector:Ue,StyleSelector:Me,DurationSelector:We,StartImage:ut,SeedSelector:Qe,RatioSelector:at,Consumption:ie},emits:["generate"],computed:{config(){return this.$store.state.pixverse?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.pixverse?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Vt(e,t,u,m,$,g){const i=s("prompt-input"),p=s("model-selector"),n=s("style-selector"),f=s("ratio-selector"),b=s("motion-selector"),v=s("quality-selector"),E=s("start-image"),P=s("seed-selector"),G=s("duration-selector"),j=s("consumption"),M=s("font-awesome-icon"),q=s("el-button");return a(),r("div",yt,[l("div",kt,[o(i,{class:"mb-4"}),o(p,{class:"mb-4"}),o(n,{class:"mb-4"}),o(f,{class:"mb-4"}),o(b,{class:"mb-4"}),o(v,{class:"mb-4"}),o(E,{class:"mb-2"}),o(P,{class:"mb-4"}),o(G,{class:"mb-4"})]),l("div",wt,[o(j,{value:e.consumption,service:e.service},null,8,["value","service"]),o(q,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),k(" "+c(e.$t("pixverse.button.generate")),1)]),_:1},8,["onClick"])])])}const St=h(bt,[["render",Vt]]),xt=_({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:pe,FontAwesomeIcon:L,ElAlert:Q,VideoPlayer:de,ElTooltip:X,ElButton:R},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pixverse?.application},config(){return this.$store.state.pixverse?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Et={class:"preview"},Tt={class:"left"},It={class:"main"},Ct={class:"bot"},Lt={class:"datetime"},Rt={class:"info"},Pt={key:0,class:"prompt mt-2"},Ut={key:0},At={key:1},Dt={key:0,class:T({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},jt={key:1,class:T({operations:!0,"mt-2":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:T({content:!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function zt(e,t,u,m,$,g){const i=s("el-image"),p=s("video-player"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",Et,[l("div",Tt,[o(i,{src:"https://cdn.acedata.cloud/viy61r.jpg",class:"avatar"})]),l("div",It,[l("div",Ct,[k(c(e.$t("pixverse.name.pixverseBot"))+" ",1),l("span",Lt,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Rt,[e.modelValue?.request?.prompt?(a(),r("p",Pt,[k(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?y("",!0):(a(),r("span",Ut," - ("+c(e.$t("pixverse.status.pending"))+") ",1)),e.modelValue?.response?.data&&(e.modelValue?.response?.data[0]?.state==="processing"||e.modelValue?.response?.data[0]?.state==="pending")?(a(),r("span",At," - ("+c(e.$t("pixverse.status.processing"))+") ",1)):y("",!0)])):y("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Gt,[o(p,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):y("",!0),e.modelValue?.response.success?(a(),r("div",jt,[o(f,{class:"box-item",effect:"dark",content:e.$t("pixverse.message.downloadVideo"),placement:"top-start"},{default:d(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=P=>e.onDownload(P,e.modelValue?.response?.data[0]?.video_url))},{default:d(()=>[k(c(e.$t("pixverse.button.download")),1)]),_:1})):y("",!0)]),_:1},8,["content"])])):y("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[l("p",Mt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.model"))+": "+c(e.modelValue?.request?.model),1)]),l("p",qt,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):y("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Bt,[o(E,{closable:!1,class:"info"},{template:d(()=>[o(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failure")),1)]),default:d(()=>[l("p",Ot,[o(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),l("p",Ft,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):y("",!0)]),_:1})])):y("",!0)])])}const Xt=h(xt,[["render",zt],["__scopeId","data-v-3f3bff8a"]]),Qt=_({name:"RecentPanel",components:{TaskPreview:Xt,NoTasks:re,BotPlaceholder:ue,ScrollList:ae},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pixverse?.tasks,items:this.$store.state.pixverse?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Yt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,t,u,m,$,g){const i=s("bot-placeholder"),p=s("task-preview"),n=s("scroll-list"),f=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Yt,[o(i)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),r(V,null,S(e.tasks?.items,(b,v)=>(a(),w(p,{key:v,"model-value":b},null,8,["model-value"]))),128))]),_:1},8,["loading"])):y("",!0),e.tasks?.items?.length===0?(a(),r("div",Ht,[o(f)])):y("",!0)],64)}const Kt=h(Qt,[["render",Jt]]),Wt="https://webhook.acedata.cloud/pixverse",Zt=_({name:"PixverseIndex",components:{ConfigPanel:St,Layout:ge,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pixverse?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.pixverse?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.pixverse.credential},config(){return this.$store.state.pixverse.config},tasks(){return this.$store.state.pixverse.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.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("pixverse/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pixverse/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:u,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("pixverse/getTasks",{limit:t,createdAtMin:u,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Wt},t=this.credential?.token;if(!t){console.error("no token specified");return}x.info(this.$t("pixverse.message.startingTask")),oe.generate(e,{token:t}).then(()=>{x.success(this.$t("pixverse.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===ne?x.error(this.$t("pixverse.message.usedUp")):x.error(this.$t("pixverse.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function es(e,t,u,m,$,g){const i=s("config-panel"),p=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:d(()=>[o(i,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[o(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const hs=h(Zt,[["render",es]]);export{hs as default};
|
|
1
|
+
import{bG as L}from"./vendor-BVnhgPs4.js";import{o as R,N as B,J as I,K as C,P as O,Q as F,q as N,r as x,p as z,n as X,B as Q,i as Y}from"./vendor-element-plus-BUOzLm6W.js";import{d as _,c as r,a as l,l as o,P as U,S as d,al as s,o as a,Z as c,F as V,ai as S,R as w,V as T,a2 as H,Y as k,W as y}from"./vendor-vue-Bb02XvLT.js";import{_ as h,bn as J,bo as K,bp as W,bq as Z,br as ee,bs as te,U as se,bt as oe,a8 as ne,a5 as D}from"./index-wwpmx6zW.js";import{I as A,S as ae}from"./ScrollList-CZI70Mqs.js";import{I as le}from"./ImagePreview-CGACVsa5.js";import{C as ie,N as re}from"./NoTasks-DjsZiiOP.js";import{a as ce}from"./price-BhobpaMO.js";import{C as pe}from"./CopyToClipboard-BqFSadU9.js";import{V as de}from"./VideoPlayer-B9VH6gxB.js";import{B as ue}from"./BotPlaceholder-BA4i65l4.js";import{l as me}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-C40ROiFS.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const ve=_({name:"LayoutPixverse",components:{ElDrawer:B,ElButton:R,FontAwesomeIcon:L},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},_e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},he={class:"result h-full p-[15px] flex-1 flex flex-col"};function $e(e,t,u,m,$,g){const i=s("font-awesome-icon"),p=s("el-button"),n=s("el-drawer");return a(),r("div",fe,[l("div",_e,[U(e.$slots,"config",{},void 0,!0)]),l("div",he,[U(e.$slots,"result",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:d(()=>[o(i,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"350px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ge=h(ve,[["render",$e],["__scopeId","data-v-0646853d"]]),be=_({name:"ModelSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"v3.5",label:"v3.5"},{value:"v4",label:"v4"},{value:"v4.5",label:"v4.5"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.model},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,model:e})}}},mounted(){this.value||(this.value=J)}}),ye={class:"field"},ke={class:"title font-bold"};function we(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",ye,[l("h2",ke,c(e.$t("pixverse.name.model")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=h(be,[["render",we],["__scopeId","data-v-e8f337ca"]]),Se=_({name:"QualitySelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"360p",label:"360p"},{value:"540p",label:"540p"},{value:"720p",label:"720p"},{value:"1080p",label:"1080p"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.quality},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,quality:e})}}},mounted(){this.value||(this.value=K)}}),xe={class:"field"},Ee={class:"title font-bold"};function Te(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",xe,[l("h2",Ee,c(e.$t("pixverse.name.quality")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=h(Se,[["render",Te],["__scopeId","data-v-64aeaae9"]]),Ce=_({name:"MotionSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"normal",label:this.$t("pixverse.name.motion1")},{value:"fast",label:this.$t("pixverse.name.motion2")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.motion},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,motion:e})}}},mounted(){this.value||(this.value=W)}}),Le={class:"field"},Re={class:"title font-bold"};function Pe(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",Le,[l("h2",Re,c(e.$t("pixverse.name.motion")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=h(Ce,[["render",Pe],["__scopeId","data-v-94237408"]]),Ae=_({name:"StyleSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"cyberpunk",label:this.$t("pixverse.name.style1")},{value:"anime",label:this.$t("pixverse.name.style2")},{value:"comic",label:this.$t("pixverse.name.style3")},{value:"clay",label:this.$t("pixverse.name.style4")},{value:"3d_animation",label:this.$t("pixverse.name.style5")},{value:"realistic",label:this.$t("pixverse.name.style6")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.style},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,style:e})}}},mounted(){this.value||(this.value=Z)}}),De={class:"field"},Ge={class:"title font-bold"};function je(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",De,[l("h2",Ge,c(e.$t("pixverse.name.style")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=h(Ae,[["render",je],["__scopeId","data-v-64e17b3c"]]),qe=_({name:"SeedSelector",components:{ElSlider:F,InfoIcon:A,ElInputNumber:O},computed:{value:{get(){return this.$store.state?.pixverse?.config?.seed},set(e){console.debug("set seed",e),this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,seed:e})}}},mounted(){this.value||(this.value=void 0)}}),Be={class:"flex justify-between"},Oe={class:"flex justify-start items-center"},Fe={class:"text-sm font-bold"},Ne={class:"flex justify-end items-center"},ze={class:"w-full"};function Xe(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input-number"),n=s("el-slider");return a(),r("div",null,[l("div",Be,[l("div",Oe,[l("span",Fe,c(e.$t("pixverse.name.seed")),1),o(i,{content:e.$t("pixverse.description.seed")},null,8,["content"])]),l("div",Ne,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),"controls-position":"right"},null,8,["modelValue"])])]),l("div",ze,[o(n,{modelValue:e.value,"onUpdate:modelValue":t[1]||(t[1]=f=>e.value=f),min:0,max:1e3,step:1},null,8,["modelValue"])])])}const Qe=h(qe,[["render",Xe]]),Ye=_({name:"DurationSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:5,label:"5s"},{value:8,label:"8s"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.duration},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,duration:e})}}},mounted(){this.value||(this.value=ee)}}),He={class:"field"},Je={class:"title font-bold"};function Ke(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",He,[l("h2",Je,c(e.$t("pixverse.name.duration")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const We=h(Ye,[["render",Ke],["__scopeId","data-v-065c77ef"]]),Ze=_({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.pixverse.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),et={class:"text-sm font-bold mb-2 block"},tt={class:"items"},st=["onClick"],ot={class:"name"};function nt(e,t,u,m,$,g){return a(),r("div",null,[l("span",et,c(e.$t("pixverse.name.aspectRatio")),1),l("div",tt,[(a(!0),r(V,null,S(e.options,(i,p)=>(a(),r("div",{key:p,class:T({active:e.active===p,item:!0}),onClick:n=>e.value=i.value},[l("div",{class:T(["preview",i.label])},[l("div",{class:"rect",style:H({width:i.width+"px",height:i.height+"px"})},null,4)],2),l("p",ot,c(i.label),1)],10,st))),128))])])}const at=h(Ze,[["render",nt],["__scopeId","data-v-32a7677f"]]),lt=_({name:"StartImage",components:{ElUpload:N,ElButton:R,InfoIcon:A,FontAwesomeIcon:L,ImagePreview:le},emits:["change"],data(){return{fileList:[],uploadUrl:se()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.pixverse?.config?.image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){x.warning(this.$t("pixverse.message.uploadReferencesExceed"))},onError(){x.error(this.$t("pixverse.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),it={class:"relative"},rt={class:"flex justify-between"},ct={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function dt(e,t,u,m,$,g){const i=s("info-icon"),p=s("image-preview"),n=s("font-awesome-icon"),f=s("el-button"),b=s("el-upload");return a(),r("div",it,[l("div",rt,[l("div",ct,[l("span",pt,c(e.$t("pixverse.name.startImage")),1),o(i,{content:e.$t("pixverse.description.uploadStartImage")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:v})=>[v.url&&v.percentage!==void 0?(a(),w(p,{key:0,url:v.url,name:v.name,percentage:v.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(v),1)},null,8,["url","name","percentage","onRemove"])):y("",!0)]),default:d(()=>[o(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),k(" "+c(e.$t("pixverse.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ut=h(lt,[["render",dt],["__scopeId","data-v-666104e4"]]),mt="",vt=_({name:"PromptInput",components:{ElInput:z,InfoIcon:A},computed:{prompt:{get(){return this.$store.state.pixverse?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=mt)}}),ft={class:"field"},_t={class:"box"},ht={class:"title font-bold"};function $t(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input");return a(),r("div",ft,[l("div",_t,[l("h2",ht,c(e.$t("pixverse.name.prompt")),1),o(i,{content:e.$t("pixverse.description.prompt"),class:"info"},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pixverse.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const gt=h(vt,[["render",$t],["__scopeId","data-v-b3dd608e"]]),bt=_({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:L,PromptInput:gt,ModelSelector:Ve,QualitySelector:Ie,MotionSelector:Ue,StyleSelector:Me,DurationSelector:We,StartImage:ut,SeedSelector:Qe,RatioSelector:at,Consumption:ie},emits:["generate"],computed:{config(){return this.$store.state.pixverse?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.pixverse?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Vt(e,t,u,m,$,g){const i=s("prompt-input"),p=s("model-selector"),n=s("style-selector"),f=s("ratio-selector"),b=s("motion-selector"),v=s("quality-selector"),E=s("start-image"),P=s("seed-selector"),G=s("duration-selector"),j=s("consumption"),M=s("font-awesome-icon"),q=s("el-button");return a(),r("div",yt,[l("div",kt,[o(i,{class:"mb-4"}),o(p,{class:"mb-4"}),o(n,{class:"mb-4"}),o(f,{class:"mb-4"}),o(b,{class:"mb-4"}),o(v,{class:"mb-4"}),o(E,{class:"mb-2"}),o(P,{class:"mb-4"}),o(G,{class:"mb-4"})]),l("div",wt,[o(j,{value:e.consumption,service:e.service},null,8,["value","service"]),o(q,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),k(" "+c(e.$t("pixverse.button.generate")),1)]),_:1},8,["onClick"])])])}const St=h(bt,[["render",Vt]]),xt=_({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:pe,FontAwesomeIcon:L,ElAlert:Q,VideoPlayer:de,ElTooltip:X,ElButton:R},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pixverse?.application},config(){return this.$store.state.pixverse?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Et={class:"preview"},Tt={class:"left"},It={class:"main"},Ct={class:"bot"},Lt={class:"datetime"},Rt={class:"info"},Pt={key:0,class:"prompt mt-2"},Ut={key:0},At={key:1},Dt={key:0,class:T({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},jt={key:1,class:T({operations:!0,"mt-2":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:T({content:!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function zt(e,t,u,m,$,g){const i=s("el-image"),p=s("video-player"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",Et,[l("div",Tt,[o(i,{src:"https://cdn.acedata.cloud/viy61r.jpg",class:"avatar"})]),l("div",It,[l("div",Ct,[k(c(e.$t("pixverse.name.pixverseBot"))+" ",1),l("span",Lt,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Rt,[e.modelValue?.request?.prompt?(a(),r("p",Pt,[k(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?y("",!0):(a(),r("span",Ut," - ("+c(e.$t("pixverse.status.pending"))+") ",1)),e.modelValue?.response?.data&&(e.modelValue?.response?.data[0]?.state==="processing"||e.modelValue?.response?.data[0]?.state==="pending")?(a(),r("span",At," - ("+c(e.$t("pixverse.status.processing"))+") ",1)):y("",!0)])):y("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Gt,[o(p,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):y("",!0),e.modelValue?.response.success?(a(),r("div",jt,[o(f,{class:"box-item",effect:"dark",content:e.$t("pixverse.message.downloadVideo"),placement:"top-start"},{default:d(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=P=>e.onDownload(P,e.modelValue?.response?.data[0]?.video_url))},{default:d(()=>[k(c(e.$t("pixverse.button.download")),1)]),_:1})):y("",!0)]),_:1},8,["content"])])):y("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[l("p",Mt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.model"))+": "+c(e.modelValue?.request?.model),1)]),l("p",qt,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):y("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Bt,[o(E,{closable:!1,class:"info"},{template:d(()=>[o(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failure")),1)]),default:d(()=>[l("p",Ot,[o(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),l("p",Ft,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):y("",!0)]),_:1})])):y("",!0)])])}const Xt=h(xt,[["render",zt],["__scopeId","data-v-3f3bff8a"]]),Qt=_({name:"RecentPanel",components:{TaskPreview:Xt,NoTasks:re,BotPlaceholder:ue,ScrollList:ae},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pixverse?.tasks,items:this.$store.state.pixverse?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Yt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,t,u,m,$,g){const i=s("bot-placeholder"),p=s("task-preview"),n=s("scroll-list"),f=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Yt,[o(i)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),r(V,null,S(e.tasks?.items,(b,v)=>(a(),w(p,{key:v,"model-value":b},null,8,["model-value"]))),128))]),_:1},8,["loading"])):y("",!0),e.tasks?.items?.length===0?(a(),r("div",Ht,[o(f)])):y("",!0)],64)}const Kt=h(Qt,[["render",Jt]]),Wt="https://webhook.acedata.cloud/pixverse",Zt=_({name:"PixverseIndex",components:{ConfigPanel:St,Layout:ge,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pixverse?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.pixverse?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.pixverse.credential},config(){return this.$store.state.pixverse.config},tasks(){return this.$store.state.pixverse.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.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("pixverse/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pixverse/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:u,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("pixverse/getTasks",{limit:t,createdAtMin:u,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Wt},t=this.credential?.token;if(!t){console.error("no token specified");return}x.info(this.$t("pixverse.message.startingTask")),oe.generate(e,{token:t}).then(()=>{x.success(this.$t("pixverse.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===ne?x.error(this.$t("pixverse.message.usedUp")):x.error(this.$t("pixverse.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function es(e,t,u,m,$,g){const i=s("config-panel"),p=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:d(()=>[o(i,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[o(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const hs=h(Zt,[["render",es]]);export{hs as default};
|