@acedatacloud/nexior 3.30.4 → 3.31.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-kGCys-gn.js → Auth-FDpP6sdw.js} +1 -1
- package/dist/assets/BotPlaceholder-C_tpj9cL.js +1 -0
- package/dist/assets/{Callback-DWSKlIl4.js → Callback-CF8NsFTN.js} +1 -1
- package/dist/assets/Console-DsJn6ORf.css +1 -0
- package/dist/assets/{Console-_IS1qii3.js → Console-DyDrK8jD.js} +1 -1
- package/dist/assets/{Conversation-Dohp2ZWp.css → Conversation-BmozhRPZ.css} +1 -1
- package/dist/assets/{Conversation-DuQtYVf4.js → Conversation-CbIvRgjb.js} +2 -2
- package/dist/assets/{CopyToClipboard-CEtp94k8.js → CopyToClipboard-BGClcrVG.js} +1 -1
- package/dist/assets/Detail-Cc46R_61.js +2 -0
- package/dist/assets/{Detail-D68ZlN5z.css → Detail-bHGSLGGq.css} +1 -1
- package/dist/assets/{EditArray-cZSRSfyf.js → EditArray-DhB4A-4P.js} +1 -1
- package/dist/assets/{Extra-CbORdop1.js → Extra-OG6qZqkS.js} +1 -1
- package/dist/assets/{FilePreview-Cs6OrAfv.js → FilePreview-vHpQ_39Y.js} +1 -1
- package/dist/assets/{History-gexbX9Zv.js → History-DkRw43Cl.js} +1 -1
- package/dist/assets/{ImagePreview--cM1y0-F.js → ImagePreview-Dif2Q49Y.js} +1 -1
- package/dist/assets/{ImageWrapper-CQl1PxLF.js → ImageWrapper-BskBzKqs.js} +1 -1
- package/dist/assets/ImageWrapper-CCC9KDpV.css +1 -0
- package/dist/assets/{Index-C7BtYXwv.js → Index-7-MqNqOx.js} +1 -1
- package/dist/assets/{Index-BCpgwdRH.js → Index-AOp1iyZX.js} +1 -1
- package/dist/assets/Index-B13mfXWf.js +1 -0
- package/dist/assets/{Index-DxzQLCOp.css → Index-B5VME3qz.css} +1 -1
- package/dist/assets/Index-BDaawPtT.css +1 -0
- package/dist/assets/Index-BJeIJzAF.js +1 -0
- package/dist/assets/Index-BOSlmfKu.js +1 -0
- package/dist/assets/Index-BS8oOxbR.css +1 -0
- package/dist/assets/{Index-CuZIoeXJ.css → Index-BUzTQm1k.css} +1 -1
- package/dist/assets/Index-B_WaHvVq.js +1 -0
- package/dist/assets/Index-BcUqDqOp.css +1 -0
- package/dist/assets/Index-BhKFb4US.js +1 -0
- package/dist/assets/Index-BhtS87g8.js +1 -0
- package/dist/assets/Index-Bi5z34-z.js +1 -0
- package/dist/assets/{Index-DpA3efz6.css → Index-Bohx5BOg.css} +1 -1
- package/dist/assets/Index-BqrsebVL.css +1 -0
- package/dist/assets/Index-Bs6AJerX.js +1 -0
- package/dist/assets/Index-By3C66Xq.js +1 -0
- package/dist/assets/Index-CE9mr3hy.js +1 -0
- package/dist/assets/Index-CQ8oi7FR.css +1 -0
- package/dist/assets/Index-CQsHLtL9.js +1 -0
- package/dist/assets/{Index-DWp92Qyv.css → Index-CTvpJ6Ko.css} +1 -1
- package/dist/assets/Index-Ce2hzTUa.css +1 -0
- package/dist/assets/{Index-Br9x7GnA.css → Index-ChN0dWdx.css} +1 -1
- package/dist/assets/Index-Ct_ncjNQ.css +1 -0
- package/dist/assets/Index-CvNs7Qc8.js +1 -0
- package/dist/assets/{Index-aB38D9pu.js → Index-CvWL3dnP.js} +1 -1
- package/dist/assets/Index-D-RbCzhR.js +1 -0
- package/dist/assets/{Index-BJHZd94h.js → Index-DAl7VUx0.js} +1 -1
- package/dist/assets/{Index-D5sduOkc.js → Index-DI0a679Y.js} +1 -1
- package/dist/assets/{Index-DxhkmCSp.css → Index-DJoSN5Ve.css} +1 -1
- package/dist/assets/Index-DVoeUmg0.css +1 -0
- package/dist/assets/Index-Do0VKmX9.css +1 -0
- package/dist/assets/{Index-Ch-rWHP2.css → Index-M_bCFF5S.css} +1 -1
- package/dist/assets/{Index-CB8Rnaiw.css → Index-OEKXTaNJ.css} +1 -1
- package/dist/assets/{Index-feu64dNe.css → Index-Q9b6AHOk.css} +1 -1
- package/dist/assets/Index-clf6vq08.css +1 -0
- package/dist/assets/Index-fmHObafV.js +1 -0
- package/dist/assets/Index-m8G7Pz-J.js +1 -0
- package/dist/assets/{Invitees-CYP2iQv2.js → Invitees-BjwE0w-8.js} +1 -1
- package/dist/assets/{List-CAfyfgl5.js → List-8o9CvgyI.js} +1 -1
- package/dist/assets/{List-DSRVmKTe.js → List-BfHX6UFu.js} +1 -1
- package/dist/assets/{List-CdFnDuaR.js → List-DVknUaOz.js} +1 -1
- package/dist/assets/{Main-BIRiKmiG.js → Main-B9Wl0aM6.js} +1 -1
- package/dist/assets/Main-CiQBunQe.css +1 -0
- package/dist/assets/Navigator-CZkWVWzN.js +1 -0
- package/dist/assets/Navigator-CwNZQUMg.css +1 -0
- package/dist/assets/NoTasks-4TJvTcNH.js +1 -0
- package/dist/assets/{Pagination-Dw29mJpo.js → Pagination-DrZT-YqX.js} +1 -1
- package/dist/assets/{ScrollList-6wsUvcj6.js → ScrollList-BSHydg5K.js} +1 -1
- package/dist/assets/{Status-CLz-FCw7.js → Status-CU3tRVGG.js} +1 -1
- package/dist/assets/Status-nxFeE51N.css +1 -0
- package/dist/assets/{Subscribe-CV4VHuLD.js → Subscribe-DEpZJt9v.js} +1 -1
- package/dist/assets/{TransportWebHID-CzVKn3HZ.js → TransportWebHID-x82bKdqW.js} +1 -1
- package/dist/assets/{VideoPlayer-DMQFBZXN.js → VideoPlayer-DhXW0ZpT.js} +1 -1
- package/dist/assets/{avatar-CN1uA8Po.js → avatar-Bypfdb1U.js} +1 -1
- package/dist/assets/avatar-i-yziJxn.css +1 -0
- package/dist/assets/{bignumber-BLJFVpCv.js → bignumber-D2i_F2iN.js} +1 -1
- package/dist/assets/common-2iCqJUYS.js +1 -0
- package/dist/assets/{distribution-Bn30t-dJ.js → distribution-DQWow-W5.js} +1 -1
- package/dist/assets/{index-BtWLfZip.js → index-7qIS8l-a.js} +1 -1
- package/dist/assets/{index-qzP26Lh5.js → index-BJU-syOe.js} +1 -1
- package/dist/assets/{index-D5QRd2Da.js → index-BPpDhZjH.js} +1 -1
- package/dist/assets/{index-BC2cccGJ.css → index-Bkear63z.css} +1 -1
- package/dist/assets/{index-DxHsOOmw.js → index-BnkMqzhi.js} +1 -1
- package/dist/assets/{index-DE_Wy0Gu.js → index-DWmgW--A.js} +1 -1
- package/dist/assets/{index-CZva-t16.js → index-Dd5huPwi.js} +1 -1
- package/dist/assets/{index-CCYW3AUY.js → index-DgtHfSqf.js} +27 -27
- package/dist/assets/{index-DGZsu5Ph.js → index-nzc2MroZ.js} +1 -1
- package/dist/assets/{index.es-mIRAKQ1A.js → index.es-CQANB9vJ.js} +1 -1
- package/dist/assets/order-BBkqrzA1.js +1 -0
- package/dist/assets/order-BIslMDZP.js +1 -0
- package/dist/assets/{order-DrwwxsRb.js → order-iKdGqXyS.js} +1 -1
- package/dist/assets/{price-hx3Y1R4a.js → price-Cbls6Qoc.js} +1 -1
- package/dist/assets/{solana-wallets-Cb3-7F7O.js → solana-wallets-CkstrrV4.js} +2 -2
- package/dist/assets/{solanaEmbed.esm-DHLMHDSC.js → solanaEmbed.esm-B1Go1xNW.js} +1 -1
- package/dist/assets/{string_decoder-BDwfFX0y.js → string_decoder-ll7baEuM.js} +1 -1
- package/dist/assets/{vendor-web3-CZJ1DcWo.js → vendor-web3-BXoVw72d.js} +4 -4
- package/dist/assets/{web-CwxjKiW2.js → web-Bl4nr7zA.js} +1 -1
- package/dist/assets/{web-DEeVFGiX.js → web-DE8XF-r4.js} +1 -1
- package/dist/index.html +15 -11
- package/package.json +1 -1
- package/dist/assets/BotPlaceholder-DghltQML.js +0 -1
- package/dist/assets/Console-C-Pnay3G.css +0 -1
- package/dist/assets/Detail-t2hlFwRn.js +0 -2
- package/dist/assets/ImageWrapper-DEadO_7m.css +0 -1
- package/dist/assets/Index-Acpzatzh.js +0 -1
- package/dist/assets/Index-B0a5arSf.js +0 -1
- package/dist/assets/Index-BLbwI9y2.css +0 -1
- package/dist/assets/Index-BNmeEQ_3.js +0 -1
- package/dist/assets/Index-BOpc0vYw.css +0 -1
- package/dist/assets/Index-Bb5DDJPy.js +0 -1
- package/dist/assets/Index-BjRYYdFX.js +0 -1
- package/dist/assets/Index-BqOX37kc.css +0 -1
- package/dist/assets/Index-BrxMTx-Y.js +0 -1
- package/dist/assets/Index-C57ALtjZ.js +0 -1
- package/dist/assets/Index-C60cc38l.js +0 -1
- package/dist/assets/Index-CByCCg-O.css +0 -1
- package/dist/assets/Index-CQHCtrEM.css +0 -1
- package/dist/assets/Index-CfVhUM4U.js +0 -1
- package/dist/assets/Index-CujgCEXB.css +0 -1
- package/dist/assets/Index-D8nMB7dN.js +0 -1
- package/dist/assets/Index-DXRd2oDS.css +0 -1
- package/dist/assets/Index-DY0jBLbu.css +0 -1
- package/dist/assets/Index-DYZt7wpr.css +0 -1
- package/dist/assets/Index-DZ-DbWl-.js +0 -1
- package/dist/assets/Index-DdS211RO.css +0 -1
- package/dist/assets/Index-HQInAAfi.js +0 -1
- package/dist/assets/Index-lMyEH6f1.js +0 -1
- package/dist/assets/Index-u8wK3QUd.js +0 -1
- package/dist/assets/Index-zpannX8x.js +0 -1
- package/dist/assets/Main-CFT_d-Ox.css +0 -1
- package/dist/assets/Navigator-CjErsr21.js +0 -1
- package/dist/assets/Navigator-O-mZrlgA.css +0 -1
- package/dist/assets/NoTasks-CSLShB84.js +0 -1
- package/dist/assets/Status-CGJoVgMo.css +0 -1
- package/dist/assets/avatar-Cfr3XS98.css +0 -1
- package/dist/assets/common-81UClLTs.js +0 -1
- package/dist/assets/order-691hfcVo.js +0 -1
- package/dist/assets/order-sPPLdLb3.js +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as L}from"./index.es-mIRAKQ1A.js";import{l as D,S as te,N as V,O as T,V as j,k as se,s as M,j as F,D as ae,F as oe,t as le,u as R,G as ne}from"./vendor-element-plus-B4FTqxj4.js";import{d as _,C as c,G as d,T as l,E as U,K as m,ai as o,D as a,R as i,S as y,ag as S,J as h,M as A,Y as re,O as f,Q as q}from"./vendor-vue-1w_NBnjl.js";import{_ as $,ba as z,bb as ie,bc as Q,bd as P,be as ce,bf as de,bg as ue,bh as pe,bi as me,bj as he,bk as fe,bl as _e,bm as $e,bn as ve,aj as ge,bo as be,aB as qe,ar as ke,ax as ye,ay as I}from"./index-CCYW3AUY.js";import{I as O,S as we}from"./ScrollList-6wsUvcj6.js";import{I as Se}from"./ImagePreview--cM1y0-F.js";import{C as Ve,N as Te}from"./NoTasks-CSLShB84.js";import{a as Re}from"./price-hx3Y1R4a.js";import{A as Ee}from"./Status-CLz-FCw7.js";import{C as Ae}from"./CopyToClipboard-CEtp94k8.js";import{I as Ie}from"./ImageWrapper-CQl1PxLF.js";import{B as Le}from"./BotPlaceholder-DghltQML.js";import{l as Ce}from"./pagination-CihAE3FS.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const Ue=_({name:"LayoutQrart",components:{ElDrawer:te,ElButton:D,FontAwesomeIcon:L},data(){return{drawer:!1}}}),Pe={class:"main flex flex-row flex-1"},De={class:"config w-[300px] h-full overflow-y-scroll bg-[var(--app-sidebar-bg)]"},Me={class:"result h-full p-[15px] flex-1 flex flex-col"};function Ge(e,s,u,p,v,g){const n=o("font-awesome-icon"),r=o("el-button"),t=o("el-drawer");return a(),c("div",Pe,[d("div",De,[U(e.$slots,"config",{},void 0,!0)]),d("div",Me,[U(e.$slots,"result",{},void 0,!0)]),l(r,{circle:"",class:"menu",onClick:s[0]||(s[0]=b=>e.drawer=!0)},{default:m(()=>[l(n,{icon:"fa-solid fa-magic"})]),_:1}),l(t,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"350px"},{default:m(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ze=$(Ue,[["render",Ge],["__scopeId","data-v-1b88dd7a"]]),Qe=_({name:"VersionSelector",components:{ElSelect:T,ElOption:V},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("qrart.type.text"),value:"text"},{label:this.$t("qrart.type.link"),value:"link"},{label:this.$t("qrart.type.email"),value:"email"},{label:this.$t("qrart.type.phone"),value:"phone"},{label:this.$t("qrart.type.sms"),value:"sms"}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.type},set(e){console.debug("set type",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,type:e})}}},mounted(){this.value||(console.debug("set default type",z),this.value=z)}}),je={class:"field"},Fe={class:"text-sm font-bold title"};function Oe(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",je,[d("span",Fe,i(e.$t("qrart.name.type")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),class:"value",placeholder:e.$t("qrart.placeholder.select")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ne=$(Qe,[["render",Oe],["__scopeId","data-v-b4bd8f04"]]),Be=_({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:30,height:30},{value:"4:3",label:"4:3",width:32,height:24},{value:"3:4",label:"3:4",width:24,height:32},{value:"16:9",label:"16:9",width:32,height:18},{value:"9:16",label:"9:16",width:18,height:32}]}},computed:{active(){return this.options.findIndex(e=>e.value===String(this.value))||0},value:{get(){return this.$store.state.qrart?.config?.aspect_ratio},set(e){console.debug("set aspect ratio",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=ie)}}),We={class:"text-sm font-bold block mb-2"},He={class:"items"},Je=["onClick"],Ke={class:"name"};function Ye(e,s,u,p,v,g){return a(),c("div",null,[d("span",We,i(e.$t("qrart.name.aspectRatio")),1),d("div",He,[(a(!0),c(y,null,S(e.options,(n,r)=>(a(),c("div",{key:r,class:A({active:e.active===r,item:!0}),onClick:t=>e.value=n.value},[d("div",{class:A(["preview",n.label])},[d("div",{class:"rect",style:re({width:n.width+"px",height:n.height+"px"})},null,4)],2),d("p",Ke,i(n.label),1)],10,Je))),128))])])}const Xe=$(Be,[["render",Ye],["__scopeId","data-v-b7590ecc"]]),Ze=_({name:"QrwSelector",components:{ElSlider:j,InfoIcon:O},computed:{value:{get(){return this.$store.state.qrart?.config?.qrw||Q},set(e){console.debug("set qrw",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,qrw:e})}}},mounted(){this.value||(console.debug("set default qrw"),this.value=Q)}}),xe={class:"field"},et={class:"text-sm font-bold title mb-2"};function tt(e,s,u,p,v,g){const n=o("el-slider"),r=o("info-icon");return a(),c("div",xe,[d("span",et,i(e.$t("qrart.name.qrw")),1),l(n,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),min:1.5,max:3,step:.1,class:"value"},null,8,["modelValue"]),l(r,{content:e.$t("qrart.description.qrw"),class:"info"},null,8,["content"])])}const st=$(Ze,[["render",tt],["__scopeId","data-v-8410479c"]]),at=_({name:"StepsSelector",components:{ElSlider:j,InfoIcon:O},computed:{value:{get(){return this.$store.state.qrart?.config?.steps||P},set(e){console.debug("set steps",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,steps:e})}}},mounted(){this.value||(console.debug("set default steps",P),this.value=P)}}),ot={class:"field"},lt={class:"text-sm font-bold block mb-2"};function nt(e,s,u,p,v,g){const n=o("el-slider"),r=o("info-icon");return a(),c("div",ot,[d("span",lt,i(e.$t("qrart.name.steps")),1),l(n,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),min:10,max:20,step:1,class:"value"},null,8,["modelValue"]),l(r,{content:e.$t("qrart.description.steps"),class:"info"},null,8,["content"])])}const rt=$(at,[["render",nt],["__scopeId","data-v-0c88983e"]]),it=_({name:"AdvancedSelector",components:{ElSwitch:se},computed:{value:{get(){return this.$store.state.qrart?.config?.advanced},set(e){console.debug("set advanced",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,advanced:e})}}},mounted(){this.value===void 0&&(this.value=ce)}}),ct={class:"field"},dt={class:"title font-bold"};function ut(e,s,u,p,v,g){const n=o("el-switch");return a(),c("div",ct,[d("span",dt,i(e.$t("qrart.name.advanced")),1),l(n,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=r=>e.value=r),class:"value"},null,8,["modelValue"])])}const pt=$(it,[["render",ut],["__scopeId","data-v-f8ddf849"]]),mt=_({name:"MarkerShapeSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:"square",label:this.$t("qrart.markerShape.square")},{value:"circle",label:this.$t("qrart.markerShape.circle")},{value:"plus",label:this.$t("qrart.markerShape.plus")},{value:"box",label:this.$t("qrart.markerShape.box")},{value:"octagon",label:this.$t("qrart.markerShape.octagon")},{value:"tiny-plus",label:this.$t("qrart.markerShape.tinyPlus")},{value:"random",label:this.$t("qrart.markerShape.random")}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.marker_shape},set(e){console.debug("set marker_shape",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,marker_shape:e})}}},mounted(){this.value||(this.value=de)}}),ht={class:"field"},ft={class:"text-sm font-bold block mb-2"};function _t(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",ht,[d("span",ft,i(e.$t("qrart.name.markerShape")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.markerShape")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const $t=$(mt,[["render",_t],["__scopeId","data-v-de71e0b0"]]),vt=_({name:"SubMarkerSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:"square",label:this.$t("qrart.subMarker.square")},{value:"circle",label:this.$t("qrart.subMarker.circle")},{value:"plus",label:this.$t("qrart.subMarker.plus")},{value:"box",label:this.$t("qrart.subMarker.box")},{value:"random",label:this.$t("qrart.subMarker.random")}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.sub_marker},set(e){console.debug("set sub_marker",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,sub_marker:e})}}},mounted(){this.value||(this.value=ue)}}),gt={class:"field"},bt={class:"text-sm font-bold block mb-2"};function qt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",gt,[d("span",bt,i(e.$t("qrart.name.subMarker")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.subMarker")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const kt=$(vt,[["render",qt],["__scopeId","data-v-51a39efa"]]),yt=_({name:"RotateSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:0,label:0},{value:90,label:90},{value:180,label:180},{value:270,label:270}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.rotate},set(e){console.debug("set rotate",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,rotate:e})}}},mounted(){this.value||(this.value=pe)}}),wt={class:"field"},St={class:"text-sm font-bold block mb-2"};function Vt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",wt,[d("span",St,i(e.$t("qrart.name.rotate")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.rotate")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Tt=$(yt,[["render",Vt],["__scopeId","data-v-72e35835"]]),Rt=_({name:"EclSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:"L",label:"L"},{value:"M",label:"M"},{value:"Q",label:"Q"},{value:"H",label:"H"}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.ecl},set(e){console.debug("set ecl",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,ecl:e})}}},mounted(){this.value||(this.value=me)}}),Et={class:"field"},At={class:"text-sm font-bold block mb-2"};function It(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",Et,[d("span",At,i(e.$t("qrart.name.ecl")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.ecl")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Lt=$(Rt,[["render",It],["__scopeId","data-v-b3a5e331"]]),Ct=_({name:"MarkerShapeSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:"center",label:this.$t("qrart.position.center")},{value:"top",label:this.$t("qrart.position.top")},{value:"right",label:this.$t("qrart.position.right")},{value:"bottom",label:this.$t("qrart.position.bottom")},{value:"left",label:this.$t("qrart.position.left")},{value:"top-left",label:this.$t("qrart.position.topLeft")},{value:"top-right",label:this.$t("qrart.position.topRight")},{value:"bottom-left",label:this.$t("qrart.position.bottomLeft")},{value:"bottom-right",label:this.$t("qrart.position.bottomRight")}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.position},set(e){console.debug("set position",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,position:e})}}},mounted(){this.value||(this.value=he)}}),Ut={class:"field"},Pt={class:"title font-bold"};function Dt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",Ut,[d("span",Pt,i(e.$t("qrart.name.position")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.position")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Mt=$(Ct,[["render",Dt],["__scopeId","data-v-54186505"]]),Gt=_({name:"PaddingLevelSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:0,label:0},{value:5,label:5},{value:10,label:10},{value:10,label:10},{value:15,label:15},{value:20,label:20}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.padding_level},set(e){console.debug("set padding_level",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,padding_level:e})}}},mounted(){this.value||(this.value=fe)}}),zt={class:"field"},Qt={class:"text-sm font-bold block mb-2"};function jt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",zt,[d("span",Qt,i(e.$t("qrart.name.paddingLevel")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.paddingLevel")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ft=$(Gt,[["render",jt],["__scopeId","data-v-49d801fd"]]),Ot=_({name:"PaddingNoiseSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:0,label:0},{value:.25,label:.25},{value:.5,label:.5},{value:.75,label:.75},{value:1,label:1}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.padding_noise},set(e){console.debug("set padding_noise",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,padding_noise:e})}}},mounted(){this.value||(this.value=_e)}}),Nt={class:"field"},Bt={class:"text-sm font-bold block mb-2"};function Wt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",Nt,[d("span",Bt,i(e.$t("qrart.name.paddingNoise")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.paddingNoise")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ht=$(Ot,[["render",Wt],["__scopeId","data-v-a20833bb"]]),Jt=_({name:"PixelStyleSelector",components:{ElSelect:T,ElOption:V},data(){return{options:[{value:"square",label:this.$t("qrart.pixelStyle.square")},{value:"rounded",label:this.$t("qrart.pixelStyle.rounded")},{value:"dot",label:this.$t("qrart.pixelStyle.dot")},{value:"squircle",label:this.$t("qrart.pixelStyle.squircle")},{value:"row",label:this.$t("qrart.pixelStyle.row")},{value:"column",label:this.$t("qrart.pixelStyle.column")}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.pixel_style},set(e){console.debug("set pixel_style",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,pixel_style:e})}}},mounted(){this.value||(this.value=$e)}}),Kt={class:"field"},Yt={class:"text-sm font-bold block mb-2"};function Xt(e,s,u,p,v,g){const n=o("el-option"),r=o("el-select");return a(),c("div",Kt,[d("span",Yt,i(e.$t("qrart.name.pixelStyle")),1),l(r,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=t=>e.value=t),clearable:"",class:"value",placeholder:e.$t("qrart.placeholder.pixelStyle")},{default:m(()=>[(a(!0),c(y,null,S(e.options,t=>(a(),h(n,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Zt=$(Jt,[["render",Xt],["__scopeId","data-v-aca7f79f"]]),xt=_({name:"SeedInput",components:{ElInput:M},data(){return{}},computed:{value:{get(){return this.$store.state.qrart?.config?.seed},set(e){console.debug("set seed",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,seed:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)}}),es={class:"field"},ts={class:"text-sm font-bold block mb-2"};function ss(e,s,u,p,v,g){const n=o("el-input");return a(),c("div",es,[d("span",ts,i(e.$t("qrart.name.seed")),1),l(n,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=r=>e.value=r),class:"value",placeholder:e.$t("qrart.placeholder.seed")},null,8,["modelValue","placeholder"])])}const as=$(xt,[["render",ss],["__scopeId","data-v-d939305d"]]),os=_({name:"PresetSelector",components:{ElImage:F},data(){return{options:[{value:"sunset",label:this.$t("qrart.preset.sunset"),url:"https://cdn.acedata.cloud/rp1h1s.png"},{value:"floral",label:this.$t("qrart.preset.floral"),url:"https://cdn.acedata.cloud/upyikx.png"},{value:"snowflakes",label:this.$t("qrart.preset.snowflakes"),url:"https://cdn.acedata.cloud/j447da.png"},{value:"feathers",label:this.$t("qrart.preset.feathers"),url:"https://cdn.acedata.cloud/d2ctz9.png"},{value:"raindrops",label:this.$t("qrart.preset.raindrops"),url:"https://cdn.acedata.cloud/xv2t3s.png"},{value:"ultra-realism",label:this.$t("qrart.preset.ultraRealism"),url:"https://cdn.acedata.cloud/nlor4y.png"},{value:"epic-realms",label:this.$t("qrart.preset.epicRealms"),url:"https://cdn.acedata.cloud/wwzkvy.png"},{value:"intricate-studio",label:this.$t("qrart.preset.intricateStudio"),url:"https://cdn.acedata.cloud/4kzf5y.png"},{value:"symmetric-masterpiece",label:this.$t("qrart.preset.symmetricMasterpiece"),url:"https://cdn.acedata.cloud/ff4ii2.png"},{value:"luminous-highway",label:this.$t("qrart.preset.luminousHighway"),url:"https://cdn.acedata.cloud/cliodt.png"},{value:"celestial-journey",label:this.$t("qrart.preset.celestialJourney"),url:"https://cdn.acedata.cloud/ejellf.png"},{value:"neon-mech",label:this.$t("qrart.preset.neonMech"),url:"https://cdn.acedata.cloud/3z0y6z.png"},{value:"ethereal-low-poly",label:this.$t("qrart.preset.etherealLowPoly"),url:"https://cdn.acedata.cloud/36o0mm.png"},{value:"golden-vista",label:this.$t("qrart.preset.goldenVista"),url:"https://cdn.acedata.cloud/xa0267.png"},{value:"cinematic-expanse",label:this.$t("qrart.preset.cinematicExpanse"),url:"https://cdn.acedata.cloud/krl5qp.png"},{value:"cinematic-warm",label:this.$t("qrart.preset.cinematicWarm"),url:"https://cdn.acedata.cloud/e1aahg.png"},{value:"desolate-wilderness",label:this.$t("qrart.preset.desolateWilderness"),url:"https://cdn.acedata.cloud/9evqqu.png"},{value:"vibrant-palette",label:this.$t("qrart.preset.vibrantPalette"),url:"https://cdn.acedata.cloud/3fvsmz.png"},{value:"enigmatic-journey",label:this.$t("qrart.preset.enigmaticJourney"),url:"https://cdn.acedata.cloud/l6kku0.png"},{value:"timeless-cinematic",label:this.$t("qrart.preset.timelessCinematic"),url:"https://cdn.acedata.cloud/h5mzyn.png"},{value:"regal-galaxy",label:this.$t("qrart.preset.regalGalaxy"),url:"https://cdn.acedata.cloud/czkegd.png"},{value:"illustrious-canvas",label:this.$t("qrart.preset.illustriousCanvas"),url:"https://cdn.acedata.cloud/m8hwzh.png"},{value:"expressive-mural",label:this.$t("qrart.preset.expressiveMural"),url:"https://cdn.acedata.cloud/g4v1rb.png"},{value:"serene-haze",label:this.$t("qrart.preset.sereneHaze"),url:"https://cdn.acedata.cloud/3w3ixr.png"}]}},computed:{value:{get(){return this.$store.state.qrart?.config?.preset},set(e){console.debug("set qrw",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,preset:e})}}},mounted(){this.value||(this.value=ve)}}),ls={class:"field"},ns={class:"text-sm font-bold block mb-2"},rs={class:"pane"},is=["onClick"],cs={class:"name"};function ds(e,s,u,p,v,g){const n=o("el-image");return a(),c("div",ls,[d("span",ns,i(e.$t("qrart.name.preset")),1),d("div",rs,[(a(!0),c(y,null,S(e.options,(r,t)=>(a(),c("div",{key:t,class:A({item:!0,active:e.value===r.value}),onClick:b=>e.value===r.value?e.value=void 0:e.value=r.value},[l(n,{src:r.url,fit:"fill",class:"preview"},null,8,["src"]),d("span",cs,i(r.label),1)],10,is))),128))])])}const us=$(os,[["render",ds],["__scopeId","data-v-65c34adf"]]),ps="",ms=_({name:"ContentInput",components:{ElInput:M,ElUpload:le,ElRadioGroup:oe,ElButton:D,ElRadioButton:ae,ImagePreview:Se,FontAwesomeIcon:L},data(){return{inputWay:"input",fileList:[],uploadUrl:ge()+"/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.qrart?.config?.content},set(e){this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,content:e,content_image_url:void 0})}}},mounted(){this.value||(this.value=ps),this.onSetContentImageUrl()},methods:{onExceed(){R.warning(this.$t("qrart.message.uploadDocumentsExceed"))},onError(){R.error(this.$t("qrart.message.uploadDocumentsError"))},onSetContentImageUrl(){const e=this.urls?.[0];this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,content:void 0,content_image_url:e})},async onSuccess(){this.onSetContentImageUrl()}}}),hs={class:"field"},fs={class:"flex justify-between items-center mb-4"},_s={class:"text-sm font-bold title"},$s={class:"flex items-center"},vs={key:2,class:"description"};function gs(e,s,u,p,v,g){const n=o("el-radio-button"),r=o("el-radio-group"),t=o("el-input"),b=o("image-preview"),w=o("font-awesome-icon"),E=o("el-button"),C=o("el-upload");return a(),c("div",hs,[d("div",fs,[d("span",_s,i(e.$t("qrart.name.content")),1),d("div",$s,[l(r,{modelValue:e.inputWay,"onUpdate:modelValue":s[0]||(s[0]=k=>e.inputWay=k)},{default:m(()=>[l(n,{label:"input"},{default:m(()=>[q(i(e.$t("qrart.inputWay.input")),1)]),_:1}),l(n,{label:"upload"},{default:m(()=>[q(i(e.$t("qrart.inputWay.upload")),1)]),_:1})]),_:1},8,["modelValue"])])]),e.inputWay=="input"?(a(),h(t,{key:0,modelValue:e.value,"onUpdate:modelValue":s[1]||(s[1]=k=>e.value=k),class:"content",placeholder:e.$t("qrart.placeholder.content")},null,8,["modelValue","placeholder"])):f("",!0),e.inputWay=="upload"?(a(),h(C,{key:1,"file-list":e.fileList,"onUpdate:fileList":s[2]||(s[2]=k=>e.fileList=k),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"upload upload-wrapper",limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:k})=>[l(b,{url:k.url||k.response?.file_url,name:k.name,percentage:k.percentage,onRemove:G=>e.fileList.splice(e.fileList.indexOf(k),1)},null,8,["url","name","percentage","onRemove"])]),default:m(()=>[l(E,{size:"small",type:"primary",round:""},{default:m(()=>[l(w,{icon:"fa-solid fa-upload",class:"mr-1"}),q(" "+i(e.$t("qrart.button.uploadQr")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])):f("",!0),e.inputWay=="upload"?(a(),c("p",vs,i(e.$t("qrart.message.uploadQr")),1)):f("",!0)])}const bs=$(ms,[["render",gs],["__scopeId","data-v-b986940a"]]),qs="",ks=_({name:"PromptInput",components:{ElInput:M},data(){return{}},computed:{value:{get(){return this.$store.state.qrart?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("qrart/setConfig",{...this.$store.state.qrart?.config,prompt:e})}}},mounted(){this.value||(this.value=qs)}}),ys={class:"field"},ws={class:"text-sm font-bold block mb-2"};function Ss(e,s,u,p,v,g){const n=o("el-input");return a(),c("div",ys,[d("span",ws,i(e.$t("qrart.name.prompt")),1),l(n,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=r=>e.value=r),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("qrart.placeholder.prompt"),resize:"none"},null,8,["modelValue","placeholder"])])}const Vs=$(ks,[["render",Ss],["__scopeId","data-v-004a0f07"]]),Ts=_({name:"ConfigPanel",components:{ElButton:D,FontAwesomeIcon:L,Consumption:Ve,TypeSelector:Ne,PositionSelector:Mt,PixelStyleSelector:Zt,PaddingLevelSelector:Ft,SeedInput:as,AspectRatioSelector:Xe,QrwSelector:st,EclSelector:Lt,StepsSelector:rt,PaddingNoiseSelector:Ht,AdvancedSelector:pt,MarkerShapeSelector:$t,SubMarkerSelector:kt,RotateSelector:Tt,PresetSelector:us,ContentInput:bs,PromptInput:Vs},emits:["generate"],computed:{config(){return this.$store.state.qrart?.config},consumption(){return Re(this.config,this.service?.cost)},service(){return this.$store.state.qrart?.service}}}),Rs={class:"flex flex-col h-full"},Es={class:"flex-1 overflow-y-auto p-[15px]"},As={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Is(e,s,u,p,v,g){const n=o("type-selector"),r=o("content-input"),t=o("prompt-input"),b=o("aspect-ratio-selector"),w=o("qrw-selector"),E=o("preset-selector"),C=o("position-selector"),k=o("advanced-selector"),G=o("steps-selector"),N=o("seed-input"),B=o("pixel-style-selector"),W=o("marker-shape-selector"),H=o("sub-marker-selector"),J=o("rotate-selector"),K=o("ecl-selector"),Y=o("padding-level-selector"),X=o("padding-noise-selector"),Z=o("consumption"),x=o("font-awesome-icon"),ee=o("el-button");return a(),c("div",Rs,[d("div",Es,[l(n,{class:"mb-4"}),l(r,{class:"mb-4"}),l(t,{class:"mb-4"}),l(b,{class:"mb-4"}),l(w,{class:"mb-4"}),l(E,{class:"mb-4"}),l(C,{class:"mb-4"}),l(k,{class:"mb-4"}),e.config?.advanced?(a(),h(G,{key:0,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(N,{key:1,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(B,{key:2,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(W,{key:3,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(H,{key:4,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(J,{key:5,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(K,{key:6,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(Y,{key:7,class:"mb-4"})):f("",!0),e.config?.advanced?(a(),h(X,{key:8,class:"mb-4"})):f("",!0)]),d("div",As,[l(Z,{value:e.consumption,service:e.service},null,8,["value","service"]),l(ee,{type:"primary",class:"btn w-full",round:"",onClick:s[0]||(s[0]=da=>e.$emit("generate"))},{default:m(()=>[l(x,{icon:"fa-solid fa-magic",class:"mr-2"}),q(" "+i(e.$t("qrart.button.generate")),1)]),_:1})])])}const Ls=$(Ts,[["render",Is]]),Cs=_({name:"TaskPreview",components:{ElImage:F,CopyToClipboard:Ae,FontAwesomeIcon:L,ElAlert:ne,ImageWrapper:Ie},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.qrart?.application}},methods:{onOpenLink(e){window.open(e,"_blank")},onReload(e){const s=e.target,u=new URL(s.src),p=u.searchParams.get("retry");if(!p)u.searchParams.set("retry","1");else if(parseInt(p)<2)u.searchParams.set("retry",(parseInt(p)+1).toString());else return;s.src=u.toString()},onOpenUrl(e){window.open(e,"_blank")},onDownload(e){const s=document.createElement("a");s.href=e,s.download=e.split("/").pop(),s.click()}}}),Us={class:"preview w-full h-fit text-left flex flex-row mb-[15px]"},Ps={class:"left"},Ds={class:"main flex-1 w-[calc(100%-70px)] pt-[10px] pr-[10px] pb-0 pl-[10px]"},Ms={class:"bot text-[16px] font-bold text-[rgb(46,204,113)]"},Gs={class:"datetime text-[12px] font-normal text-[var(--el-text-color-secondary)] ml-[10px]"},zs={class:"info"},Qs={key:0,class:"prompt mt-2 text-[14px] font-bold text-[var(--el-text-color-regular)] mb-[10px]"},js={key:0},Fs={key:0,class:A({content:!0,failed:!0})},Os={class:"description"},Ns={class:"description"},Bs={key:0,class:"description"},Ws={key:1,class:"description"},Hs={key:2,class:"description"},Js={key:1,class:A({content:!0})},Ks={class:"description"},Ys={class:"description"},Xs={class:"description"},Zs={key:2,class:A({content:!0})},xs={class:"description"};function ea(e,s,u,p,v,g){const n=o("el-image"),r=o("image-wrapper"),t=o("font-awesome-icon"),b=o("copy-to-clipboard"),w=o("el-alert");return a(),c("div",Us,[d("div",Ps,[l(n,{src:"https://cdn.acedata.cloud/bcml67.png",class:"avatar bg-[var(--el-bg-color)] p-[2px] w-[50px] h-[50px] m-[10px] rounded-full"})]),d("div",Ds,[d("div",Ms,[q(i(e.$t("qrart.name.qrartBot"))+" ",1),d("span",Gs,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),d("div",zs,[e.modelValue?.request?.prompt?(a(),c("p",Qs,[q(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),c("span",js," - ("+i(e.$t("qrart.status.pending"))+") ",1))])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),c("div",Fs,[e.modelValue?.response?.image_url?(a(),h(r,{key:0,src:e.modelValue?.response?.image_url,"raw-src":e.modelValue?.response?.image_url},null,8,["src","raw-src"])):f("",!0),l(w,{closable:!1,class:"mt-2 success"},{default:m(()=>[d("p",Os,[l(t,{icon:"fa-solid fa-magic",class:"mr-1"}),q(" "+i(e.$t("qrart.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),l(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),d("p",Ns,[l(t,{icon:"fa-solid fa-diamond",class:"mr-1"}),q(" "+i(e.$t("qrart.name.type"))+": "+i(e.$t("qrart.type."+e.modelValue?.request?.type))+" ",1),l(b,{content:e.modelValue?.request?.type,class:"btn-copy"},null,8,["content"])]),e.modelValue?.request?.content?(a(),c("p",Bs,[l(t,{icon:"fa-regular fa-message",class:"mr-1"}),q(" "+i(e.$t("qrart.name.content"))+": "+i(e.modelValue?.request?.content)+" ",1),l(b,{content:e.modelValue?.request?.content,class:"btn-copy"},null,8,["content"])])):f("",!0),e.modelValue?.request?.content_image_url?(a(),c("p",Ws,[l(t,{icon:"fa-regular fa-message",class:"mr-1"}),q(" "+i(e.$t("qrart.name.contentImageUrl"))+": ",1),l(t,{icon:"fa-solid fa-up-right-from-square",class:"mr-1 cursor-pointer",onClick:s[0]||(s[0]=E=>e.onOpenLink(e.modelValue?.request?.content_image_url))})])):f("",!0),e.modelValue?.request?.seed||e.modelValue?.response?.seed?(a(),c("p",Hs,[l(t,{icon:"fa-solid fa-seedling",class:"mr-1"}),q(" "+i(e.$t("qrart.name.seed"))+": "+i(e.modelValue?.request?.seed||e.modelValue?.response?.seed)+" ",1),l(b,{content:(e.modelValue?.request?.seed||e.modelValue?.response?.seed).toString(),class:"btn-copy"},null,8,["content"])])):f("",!0)]),_:1})])):f("",!0),e.modelValue?.response?.success===!1?(a(),c("div",Js,[l(w,{closable:!1,class:"failure"},{template:m(()=>[l(t,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),q(" "+i(e.$t("qrart.name.failure")),1)]),default:m(()=>[d("p",Ks,[l(t,{icon:"fa-solid fa-magic",class:"mr-1"}),q(" "+i(e.$t("qrart.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),l(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),d("p",Ys,[l(t,{icon:"fa-solid fa-circle-info",class:"mr-1"}),q(" "+i(e.$t("qrart.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),l(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),d("p",Xs,[l(t,{icon:"fa-solid fa-hashtag",class:"mr-1"}),q(" "+i(e.$t("qrart.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),l(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):f("",!0),e.modelValue?.response?f("",!0):(a(),c("div",Zs,[l(w,{closable:!1,class:"info"},{template:m(()=>[l(t,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),q(" "+i(e.$t("qrart.name.failure")),1)]),default:m(()=>[d("p",xs,[l(t,{icon:"fa-solid fa-magic",class:"mr-1"}),q(" "+i(e.$t("qrart.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),l(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const ta=$(Cs,[["render",ea],["__scopeId","data-v-df8d8e35"]]),sa=_({name:"RecentPanel",components:{TaskPreview:ta,BotPlaceholder:Le,NoTasks:Te,ScrollList:we},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.qrart?.tasks,items:this.$store.state.qrart?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),aa={key:0},oa={key:2,class:"w-full h-full flex items-center justify-center"};function la(e,s,u,p,v,g){const n=o("bot-placeholder"),r=o("task-preview"),t=o("scroll-list"),b=o("no-tasks");return a(),c(y,null,[e.tasks?.items===void 0?(a(),c("div",aa,[l(n)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),h(t,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=w=>e.$emit("reach-top"))},{default:m(()=>[(a(!0),c(y,null,S(e.tasks?.items,(w,E)=>(a(),h(r,{key:E,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(a(),c("div",oa,[l(b)])):f("",!0)],64)}const na=$(sa,[["render",la]]),ra="https://webhook.acedata.cloud/qrart",ia=_({name:"QrartIndex",components:{ConfigPanel:Ls,Layout:ze,ApplicationStatus:Ee,RecentPanel:na},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.qrart?.status?.getApplications===I.Request},tasksLoading(){return this.$store.state.qrart?.status?.getTasks===I.Request||this.fetchingTasks},service(){return this.$store.state.qrart.service},credential(){return this.$store.state.qrart.credential},config(){return this.$store.state.qrart.config},initializing(){return this.$store.state.qrart.status.getApplications===I.Request},needApply(){return this.$store.state.qrart.status.getApplications===I.Success&&!this.application},application(){return this.$store.state.qrart.application},tasks(){return this.$store.state.qrart.tasks},applications(){return this.$store.state.qrart.applications}},watch:{tasks:{handler(e,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await Ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("qrart/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("qrart/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){ke.create({application:this.application}).then(({data:e})=>{this.application=e,R.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ye&&R.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:s=5,createdAtMin:u,createdAtMax:p}=e||{};console.debug("limit",s,"createdAtMin",u,"createdAtMax",p),this.fetchingTasks=!0;try{await this.$store.dispatch("qrart/getTasks",{limit:s,createdAtMin:u,createdAtMax:p})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={type:this.config?.type,content:this.config?.content,content_image_url:this.config?.content_image_url,prompt:this.config?.prompt,aspect_ratio:this.config?.aspect_ratio,callback_url:ra,qrw:this.config?.qrw,steps:this.config?.steps,preset:this.config?.preset,...this.config?.advanced?{position:this.config?.position,pixel_style:this.config?.pixel_style,marker_shape:this.config?.marker_shape,sub_marker:this.config?.sub_marker,rotate:this.config?.rotate,ecl:this.config?.ecl,seed:this.config?.seed,padding_level:this.config?.padding_level,padding_noise:this.config?.padding_noise}:{}},s=this.credential?.token;if(!s){console.error("no token specified");return}R.info(this.$t("qrart.message.startingTask")),be.generate(e,{token:s}).then(()=>{R.success(this.$t("qrart.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===qe?R.error(this.$t("qrart.message.usedUp")):R.error(this.$t("qrart.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ca(e,s,u,p,v,g){const n=o("config-panel"),r=o("application-status"),t=o("recent-panel"),b=o("layout");return a(),h(b,null,{config:m(()=>[l(n,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[l(r,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:"mb-4",onRefresh:e.onGetApplication,onSelect:s[0]||(s[0]=w=>e.$store.dispatch("qrart/setApplication",w))},null,8,["initializing","application","applications","service","need-apply","onRefresh"]),l(t,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ra=$(ia,[["render",ca],["__scopeId","data-v-b90a878d"]]);export{Ra as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as M}from"./index.es-mIRAKQ1A.js";import{l as O,S as re,k as ce,N as ue,O as de,t as pe,u as C,s as B,a1 as x,a2 as ee,U as ie,e as J,j as N,D as ae,F as le,V as te,a3 as me,a4 as fe,Z as he,f as _e,g as ge,h as $e,p as ve,q as ye,K as ke,Y as we,a5 as be,a6 as Ce}from"./vendor-element-plus-B4FTqxj4.js";import{d as S,C as g,G as n,T as s,E as K,K as m,ai as a,D as i,O as y,R as u,S as D,ag as Y,J as w,Q as L,L as q,aq as Q,X as F,c as I,u as T,w as Se,b as Ve,P as Le,U as Ae}from"./vendor-vue-1w_NBnjl.js";import{_ as A,c4 as je,c5 as P,aj as Fe,ay as R,c6 as H,ar as Ee,ax as Te}from"./index-CCYW3AUY.js";import{I as G,S as Ue}from"./ScrollList-6wsUvcj6.js";import{C as Pe,N as Ie}from"./NoTasks-CSLShB84.js";import{a as ze}from"./price-hx3Y1R4a.js";import{j as Z}from"./vendor-dayjs-CzbnksQQ.js";import{l as Ge}from"./pagination-CihAE3FS.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const Me=S({name:"LayoutSuno",components:{ElDrawer:re,ElButton:O,FontAwesomeIcon:M},data(){return{drawer:!1,preview:!1}},computed:{}}),Re={class:"main flex flex-row flex-1"},De={class:"config w-[300px] h-full overflow-y-scroll bg-[var(--app-sidebar-bg)]"},We={class:"result h-full flex flex-col flex-1"},Oe={class:"preview h-full w-[300px] flex flex-col"};function Be(e,t,l,o,c,p){const d=a("font-awesome-icon"),_=a("el-button"),$=a("el-drawer");return i(),g("div",Re,[n("div",De,[K(e.$slots,"config",{},void 0,!0)]),n("div",We,[K(e.$slots,"result",{},void 0,!0)]),n("div",Oe,[K(e.$slots,"preview",{},void 0,!0)]),s(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=r=>e.drawer=!0)},{default:m(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s($,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=r=>e.drawer=r),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:m(()=>[K(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ne=A(Me,[["render",Be],["__scopeId","data-v-087f869f"]]),qe=S({name:"TypeSelector",components:{ElSelect:de,ElOption:ue,ElSwitch:ce},data(){return{options:[{label:"Suno v5",value:"chirp-v5",info:"8 min"},{label:"Suno v4.5+",value:"chirp-v4-5-plus",info:"8 min"},{label:"Suno v4.5",value:"chirp-v4-5",info:"4 min"},{label:"Suno v4",value:"chirp-v4",info:"2.5 min"},{label:"Suno v3.5",value:"chirp-v3-5",info:"2 min"},{label:"Suno v3",value:"chirp-v3-0",info:"2 min"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(this.model=je)}}),He={class:"flex items-center justify-between mb-3"},Ke={class:"text-sm font-bold"},Ze={class:"mb-3"},Xe={class:"flex items-center mb-1"},Ye={class:"text-sm font-bold"},Je={class:"flex items-center justify-between w-full"},Qe={class:"text-xs text-[var(--el-text-color-placeholder)]"},xe={key:0,class:"flex items-center justify-between mb-3"},et={class:"text-sm font-bold"};function tt(e,t,l,o,c,p){const d=a("el-switch"),_=a("el-option"),$=a("el-select");return i(),g("div",null,[n("div",He,[n("span",Ke,u(e.$t("suno.name.type")),1),s(d,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=r=>e.custom=r),size:"small"},null,8,["modelValue"])]),n("div",Ze,[n("div",Xe,[n("span",Ye,u(e.$t("suno.name.model")),1)]),s($,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=r=>e.model=r),class:"w-full",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:m(()=>[(i(!0),g(D,null,Y(e.options,r=>(i(),w(_,{key:r.value,label:r.label,value:r.value},{default:m(()=>[n("div",Je,[n("span",null,u(r.label),1),n("span",Qe,u(r.info),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(i(),g("div",xe,[n("span",et,u(e.$t("suno.name.instrumental")),1),s(d,{modelValue:e.instrumental,"onUpdate:modelValue":t[2]||(t[2]=r=>e.instrumental=r),size:"small"},null,8,["modelValue"])])):y("",!0)])}const ot=A(qe,[["render",tt]]),st=S({name:"UploadAudio",components:{ElUpload:pe,ElButton:O,InfoIcon:G,FontAwesomeIcon:M},emits:["change"],data(){return{fileList:[],uploadUrl:Fe()+"/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(){C.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){C.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}C.info(this.$t("suno.message.startingUploadAudio")),P.upload(t,{token:l}).then(o=>{console.debug("get upload music success",o.data);const c=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:c,action:"upload_extend"}),C.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{C.error(o?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),nt={class:"relative"},it={class:"flex justify-between"},at={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function rt(e,t,l,o,c,p){const d=a("info-icon"),_=a("font-awesome-icon"),$=a("el-button"),r=a("el-upload");return i(),g("div",nt,[n("div",it,[n("div",at,[n("span",lt,u(e.$t("suno.name.referenceAudios")),1),s(d,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),s(r,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=h=>e.fileList=h),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:m(()=>[s($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:m(()=>[s(_,{icon:"fa-solid fa-upload",class:"icon mr-1"}),L(" "+u(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ct=A(st,[["render",rt],["__scopeId","data-v-6236152c"]]),ut="",dt=S({name:"PromptInput",components:{ElInput:B,InfoIcon:G},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ut)}}),pt={class:"field"},mt={class:"flex items-center mb-1"},ft={class:"text-sm font-bold"};function ht(e,t,l,o,c,p){const d=a("info-icon"),_=a("el-input");return i(),g("div",pt,[n("div",mt,[n("span",ft,u(e.$t("suno.name.songDescription")),1),s(d,{content:e.$t("suno.description.prompt")},null,8,["content"])]),s(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=$=>e.prompt=$),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const _t=A(dt,[["render",ht]]),gt="",$t=S({name:"LyricInput",components:{ElInput:B,ElButton:O,FontAwesomeIcon:M,InfoIcon:G},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=gt)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,C.info(this.$t("suno.message.generatingLyrics"));try{const o=(await P.lyric({prompt:t},{token:e})).data?.data;o?.text&&(this.lyric=o.text,o?.title&&!this.config?.title&&this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:o.text,title:o.title}),C.success(this.$t("suno.message.generateLyricsSuccess")))}catch{C.error(this.$t("suno.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),vt={class:"field"},yt={class:"flex items-center justify-between mb-1"},kt={class:"flex items-center"},wt={class:"text-sm font-bold"};function bt(e,t,l,o,c,p){const d=a("info-icon"),_=a("font-awesome-icon"),$=a("el-button"),r=a("el-input");return i(),g("div",vt,[n("div",yt,[n("div",kt,[n("span",wt,u(e.$t("suno.name.lyrics")),1),s(d,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(i(),w($,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:m(()=>[e.generatingLyrics?y("",!0):(i(),w(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),L(" "+u(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):y("",!0)]),e.config?.action!=="extend"?(i(),w(r,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=h=>e.lyric=h),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(i(),w(r,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=h=>e.lyric=h),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const Ct=A($t,[["render",bt],["__scopeId","data-v-210d2670"]]),St=S({name:"StyleInput",components:{ElInput:B,ElButton:O,FontAwesomeIcon:M,InfoIcon:G},data(){return{optimizing:!1}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential}},methods:{async onOptimizeStyle(){const e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,C.info(this.$t("suno.message.optimizingStyle"));try{const t=await P.style({prompt:this.style},{token:e}),l=t.data?.text||t.data?.data?.text;l&&(this.style=l,C.success(this.$t("suno.message.optimizeStyleSuccess")))}catch{C.error(this.$t("suno.message.optimizeStyleFailed"))}finally{this.optimizing=!1}}}}}),Vt={class:"field"},Lt={class:"flex items-center justify-between mb-1"},At={class:"flex items-center"},jt={class:"text-sm font-bold"};function Ft(e,t,l,o,c,p){const d=a("info-icon"),_=a("font-awesome-icon"),$=a("el-button"),r=a("el-input");return i(),g("div",Vt,[n("div",Lt,[n("div",At,[n("span",jt,u(e.$t("suno.name.style")),1),s(d,{content:e.$t("suno.description.style")},null,8,["content"])]),s($,{size:"small",loading:e.optimizing,round:"",onClick:e.onOptimizeStyle},{default:m(()=>[e.optimizing?y("",!0):(i(),w(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),L(" "+u(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),s(r,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=h=>e.style=h),rows:2,type:"textarea",placeholder:e.$t("suno.placeholder.style")},null,8,["modelValue","placeholder"])])}const Et=A(St,[["render",Ft]]),Tt=S({name:"TitleInput",components:{ElInput:B,InfoIcon:G},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}}}}),Ut={class:"field"},Pt={class:"flex items-center mb-1"},It={class:"text-sm font-bold"};function zt(e,t,l,o,c,p){const d=a("info-icon"),_=a("el-input");return i(),g("div",Ut,[n("div",Pt,[n("span",It,u(e.$t("suno.name.title")),1),s(d,{content:e.$t("suno.description.title")},null,8,["content"])]),s(_,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=$=>e.title=$),placeholder:e.$t("suno.placeholder.title")},null,8,["modelValue","placeholder"])])}const Gt=A(Tt,[["render",zt]]);function W(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const l=e%60,o=l<10?`0${l}`:l,c=t<10?`0${t}`:t;return o+":"+c}const Mt=S({name:"ExtendFromInput",components:{ElImage:N,ElIcon:J,ElInputNumber:ie,VideoPlay:ee,VideoPause:x},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:W,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})}}}),Rt={class:"field"},Dt={class:"box"},Wt={class:"title font-bold"},Ot={class:"input-wrapper"},Bt={class:"task"},Nt={class:"left"},qt={key:2,class:"duration"},Ht={class:"info"},Kt={class:"title"},Zt={class:"style"};function Xt(e,t,l,o,c,p){const d=a("el-input-number"),_=a("el-image"),$=a("video-pause"),r=a("el-icon"),h=a("video-play"),b=Q("loading");return i(),g("div",Rt,[n("div",Dt,[n("h2",Wt,u(e.$t("suno.name.extend")),1),n("div",Ot,[s(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),n("div",Bt,[e.audio?(i(),g("div",{key:0,class:"audio",onClick:t[3]||(t[3]=f=>e.onClick(e.audio))},[q((i(),g("div",Nt,[s(_,{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(),g("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=f=>e.onPause(e.audio))},[s(r,null,{default:m(()=>[s($)]),_:1})])):y("",!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(),g("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=f=>e.onPlay(e.audio))},[s(r,null,{default:m(()=>[s(h)]),_:1})])):y("",!0),e.audio?.duration?(i(),g("div",qt,u(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[b,!e.audio?.audio_url]]),n("div",Ht,[n("h2",Kt,u(e.audio?.title),1),n("p",Zt,u(e.audio?.style),1)])])):y("",!0)])])}const Yt=A(Mt,[["render",Xt],["__scopeId","data-v-bcce4821"]]),Jt=S({name:"CoverFromInput",components:{ElImage:N,ElIcon:J,VideoPlay:ee,VideoPause:x},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:W,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})}}}),Qt={class:"field"},xt={class:"box"},eo={class:"title font-bold"},to={class:"task"},oo={class:"left"},so={key:2,class:"duration"},no={class:"info"},io={class:"title"},ao={class:"style"};function lo(e,t,l,o,c,p){const d=a("el-image"),_=a("video-pause"),$=a("el-icon"),r=a("video-play"),h=Q("loading");return i(),g("div",Qt,[n("div",xt,[n("h2",eo,u(e.$t("suno.name.cover")),1)]),n("div",to,[e.audio?(i(),g("div",{key:0,class:"audio",onClick:t[2]||(t[2]=b=>e.onClick(e.audio))},[q((i(),g("div",oo,[s(d,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(i(),g("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=b=>e.onPause(e.audio))},[s($,null,{default:m(()=>[s(_)]),_:1})])):y("",!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(),g("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=b=>e.onPlay(e.audio))},[s($,null,{default:m(()=>[s(r)]),_:1})])):y("",!0),e.audio?.duration?(i(),g("div",so,u(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[h,!e.audio?.audio_url]]),n("div",no,[n("h2",io,u(e.audio?.title),1),n("p",ao,u(e.audio?.style),1)])])):y("",!0)])])}const ro=A(Jt,[["render",lo],["__scopeId","data-v-06640216"]]),co=S({name:"VocalGenderSelector",components:{ElRadioGroup:le,ElRadioButton:ae,InfoIcon:G},computed:{vocalGender:{get(){return this.$store.state.suno?.config?.vocal_gender||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,vocal_gender:e||void 0})}}}}),uo={class:"mb-2"},po={class:"flex items-center mb-1"},mo={class:"text-sm font-bold"};function fo(e,t,l,o,c,p){const d=a("info-icon"),_=a("el-radio-button"),$=a("el-radio-group");return i(),g("div",uo,[n("div",po,[n("span",mo,u(e.$t("suno.name.vocalGender")),1),s(d,{content:e.$t("suno.description.vocalGender")},null,8,["content"])]),s($,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=r=>e.vocalGender=r),size:"small"},{default:m(()=>[s(_,{value:""},{default:m(()=>[L(u(e.$t("suno.gender.auto")),1)]),_:1}),s(_,{value:"f"},{default:m(()=>[L(u(e.$t("suno.gender.female")),1)]),_:1}),s(_,{value:"m"},{default:m(()=>[L(u(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const ho=A(co,[["render",fo]]),_o=S({name:"AdvancedParams",components:{ElCollapse:fe,ElCollapseItem:me,ElInput:B,ElSlider:te,ElRadioGroup:le,ElRadioButton:ae},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){return(this.config?.model||"")==="chirp-v5"},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_weight:e})}}}}),go={key:0,class:"mb-3"},$o={class:"flex items-center mb-1"},vo={class:"text-xs font-bold"},yo={key:1,class:"mb-3"},ko={class:"flex items-center mb-1"},wo={class:"text-xs font-bold"},bo={key:2,class:"mb-3"},Co={class:"flex items-center justify-between mb-1"},So={class:"text-xs font-bold"},Vo={class:"text-xs text-[var(--el-text-color-secondary)]"},Lo={key:3,class:"mb-3"},Ao={class:"flex items-center justify-between mb-1"},jo={class:"text-xs font-bold"},Fo={class:"text-xs text-[var(--el-text-color-secondary)]"},Eo={key:4,class:"mb-3"},To={class:"flex items-center mb-1"},Uo={class:"text-xs font-bold"},Po={key:5,class:"mb-3"},Io={class:"flex items-center justify-between mb-1"},zo={class:"text-xs font-bold"},Go={class:"text-xs text-[var(--el-text-color-secondary)]"};function Mo(e,t,l,o,c,p){const d=a("el-input"),_=a("el-slider"),$=a("el-radio-button"),r=a("el-radio-group"),h=a("el-collapse-item"),b=a("el-collapse");return i(),w(b,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=f=>e.activeNames=f),class:"advanced-collapse"},{default:m(()=>[s(h,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:m(()=>[e.config?.custom?(i(),g("div",go,[n("div",$o,[n("span",vo,u(e.$t("suno.name.styleNegative")),1)]),s(d,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=f=>e.styleNegative=f),size:"small",placeholder:e.$t("suno.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):y("",!0),e.config?.custom&&!e.config?.instrumental?(i(),g("div",yo,[n("div",ko,[n("span",wo,u(e.$t("suno.name.lyricPrompt")),1)]),s(d,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=f=>e.lyricPrompt=f),size:"small",placeholder:e.$t("suno.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):y("",!0),e.config?.custom?(i(),g("div",bo,[n("div",Co,[n("span",So,u(e.$t("suno.name.weirdness")),1),n("span",Vo,u(e.weirdness??0),1)]),s(_,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=f=>e.weirdness=f),min:0,max:100,step:1,size:"small"},null,8,["modelValue"])])):y("",!0),e.config?.custom?(i(),g("div",Lo,[n("div",Ao,[n("span",jo,u(e.$t("suno.name.styleInfluence")),1),n("span",Fo,u(e.styleInfluence??50),1)]),s(_,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||(t[3]=f=>e.styleInfluence=f),min:0,max:100,step:1,size:"small"},null,8,["modelValue"])])):y("",!0),e.isV5OrAbove?(i(),g("div",Eo,[n("div",To,[n("span",Uo,u(e.$t("suno.name.variationCategory")),1)]),s(r,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=f=>e.variationCategory=f),size:"small"},{default:m(()=>[s($,{value:""},{default:m(()=>[L(u(e.$t("suno.gender.auto")),1)]),_:1}),s($,{value:"high"},{default:m(()=>[L(u(e.$t("suno.variation.high")),1)]),_:1}),s($,{value:"low"},{default:m(()=>[L(u(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):y("",!0),e.config?.action==="cover"?(i(),g("div",Po,[n("div",Io,[n("span",zo,u(e.$t("suno.name.audioWeight")),1),n("span",Go,u(e.audioWeight??50),1)]),s(_,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||(t[5]=f=>e.audioWeight=f),min:0,max:100,step:1,size:"small"},null,8,["modelValue"])])):y("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Ro=A(_o,[["render",Mo],["__scopeId","data-v-be135363"]]),Do=S({name:"ReplaceSectionInput",components:{ElInputNumber:ie,ElImage:N,InfoIcon:G},computed:{audio(){return this.$store.state.suno?.config?.audio},replaceSectionStart:{get(){return this.$store.state.suno?.config?.replace_section_start},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.suno?.config?.replace_section_end},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),Wo={class:"field"},Oo={class:"flex items-center mb-2"},Bo={class:"text-sm font-bold m-0"},No={key:0,class:"task mb-2"},qo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ho={class:"info flex-1 min-w-0"},Ko={class:"text-sm font-bold m-0 truncate"},Zo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xo={class:"flex gap-2"};function Yo(e,t,l,o,c,p){const d=a("info-icon"),_=a("el-image"),$=a("el-input-number"),r=Q("loading");return i(),g("div",Wo,[n("div",Oo,[n("h2",Bo,u(e.$t("suno.name.replaceSection")),1),s(d,{content:e.$t("suno.description.replaceSection")},null,8,["content"])]),e.audio?(i(),g("div",No,[n("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=h=>e.onClick(e.audio))},[q((i(),g("div",qo,[s(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[r,!e.audio?.audio_url]]),n("div",Ho,[n("h2",Ko,u(e.audio?.title),1),n("p",Zo,u(e.audio?.style),1)])])])):y("",!0),n("div",Xo,[s($,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=h=>e.replaceSectionStart=h),class:"flex-1",size:"small",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),s($,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=h=>e.replaceSectionEnd=h),class:"flex-1",size:"small",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const Jo=A(Do,[["render",Yo]]),Qo=S({name:"PresetPanel",components:{TypeSelector:ot,PromptInput:_t,LyricInput:Ct,StyleInput:Et,TitleInput:Gt,ExtendFromInput:Yt,CoverFromInput:ro,UploadAudio:ct,VocalGenderSelector:ho,AdvancedParams:Ro,ReplaceSectionInput:Jo,FontAwesomeIcon:M,ElButton:O,Consumption:Pe},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return ze(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){const e=this.config?.model||"";return["chirp-v4-5-plus","chirp-v5"].includes(e)},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("suno.button.extend"):e==="cover"?this.$t("suno.button.cover_music"):e==="remaster"?this.$t("suno.button.remaster"):e==="replace_section"?this.$t("suno.button.replace_section"):e==="mashup"?this.$t("suno.button.mashup"):e==="stems"?this.$t("suno.button.get_stems"):e==="concat"?this.$t("suno.button.concat_music"):this.$t("suno.button.generate")}},methods:{onGenerate(){this.$emit("generate")}}}),xo={class:"flex flex-col h-full"},es={class:"flex-1 overflow-y-auto p-[15px]"},ts={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function os(e,t,l,o,c,p){const d=a("type-selector"),_=a("upload-audio"),$=a("prompt-input"),r=a("lyric-input"),h=a("style-input"),b=a("title-input"),f=a("vocal-gender-selector"),k=a("extend-from-input"),U=a("cover-from-input"),E=a("replace-section-input"),j=a("advanced-params"),v=a("consumption"),V=a("font-awesome-icon"),z=a("el-button");return i(),g("div",xo,[n("div",es,[s(d,{class:"mb-4"}),s(_,{class:"mb-4"}),e.config?.custom?y("",!0):(i(),w($,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(i(),w(r,{key:1,class:"mb-4"})):y("",!0),e.config?.custom?(i(),w(h,{key:2,class:"mb-4"})):y("",!0),e.config?.custom?(i(),w(b,{key:3,class:"mb-4"})):y("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(i(),w(f,{key:4,class:"mb-4"})):y("",!0),e.config?.action==="extend"?(i(),w(k,{key:5,class:"mb-4"})):y("",!0),e.config?.action==="cover"?(i(),w(U,{key:6,class:"mb-4"})):y("",!0),e.config?.action==="replace_section"?(i(),w(E,{key:7,class:"mb-4"})):y("",!0),s(j,{class:"mb-4"})]),n("div",ts,[s(v,{value:e.consumption,service:e.service},null,8,["value","service"]),s(z,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[s(V,{icon:"fa-solid fa-magic",class:"mr-2"}),L(" "+u(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const ss=A(Qo,[["render",os],["__scopeId","data-v-8201f79d"]]);var X={exports:{}},ns=X.exports,se;function is(){return se||(se=1,function(e,t){(function(l,o){o()})(ns,function(){function l(r,h){return typeof h>"u"?h={autoBom:!1}:typeof h!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),h={autoBom:!h}),h.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(r.type)?new Blob(["\uFEFF",r],{type:r.type}):r}function o(r,h,b){var f=new XMLHttpRequest;f.open("GET",r),f.responseType="blob",f.onload=function(){$(f.response,h,b)},f.onerror=function(){console.error("could not download file")},f.send()}function c(r){var h=new XMLHttpRequest;h.open("HEAD",r,!1);try{h.send()}catch{}return 200<=h.status&&299>=h.status}function p(r){try{r.dispatchEvent(new MouseEvent("click"))}catch{var h=document.createEvent("MouseEvents");h.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),r.dispatchEvent(h)}}var d=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof Z=="object"&&Z.global===Z?Z:void 0,_=d.navigator&&/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),$=d.saveAs||(typeof window!="object"||window!==d?function(){}:"download"in HTMLAnchorElement.prototype&&!_?function(r,h,b){var f=d.URL||d.webkitURL,k=document.createElement("a");h=h||r.name||"download",k.download=h,k.rel="noopener",typeof r=="string"?(k.href=r,k.origin===location.origin?p(k):c(k.href)?o(r,h,b):p(k,k.target="_blank")):(k.href=f.createObjectURL(r),setTimeout(function(){f.revokeObjectURL(k.href)},4e4),setTimeout(function(){p(k)},0))}:"msSaveOrOpenBlob"in navigator?function(r,h,b){if(h=h||r.name||"download",typeof r!="string")navigator.msSaveOrOpenBlob(l(r,b),h);else if(c(r))o(r,h,b);else{var f=document.createElement("a");f.href=r,f.target="_blank",setTimeout(function(){p(f)})}}:function(r,h,b,f){if(f=f||open("","_blank"),f&&(f.document.title=f.document.body.innerText="downloading..."),typeof r=="string")return o(r,h,b);var k=r.type==="application/octet-stream",U=/constructor/i.test(d.HTMLElement)||d.safari,E=/CriOS\/[\d]+/.test(navigator.userAgent);if((E||k&&U||_)&&typeof FileReader<"u"){var j=new FileReader;j.onloadend=function(){var z=j.result;z=E?z:z.replace(/^data:[^;]*;/,"data:attachment/file;"),f?f.location.href=z:location=z,f=null},j.readAsDataURL(r)}else{var v=d.URL||d.webkitURL,V=v.createObjectURL(r);f?f.location=V:location.href=V,f=null,setTimeout(function(){v.revokeObjectURL(V)},4e4)}});d.saveAs=$.saveAs=$,e.exports=$})}(X)),X.exports}var as=is();const ls="https://webhook.acedata.cloud/suno",rs=S({name:"TaskPreview",components:{ElImage:N,ElIcon:J,ElTooltip:ve,FontAwesomeIcon:M,VideoPlay:ee,VideoPause:x,ElDropdown:$e,ElDropdownMenu:ge,ElDropdownItem:_e,Loading:he},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===R.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:W,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 o=new URL(t).pathname,c=o.substring(o.lastIndexOf("/")+1);console.log("on preview",c),fetch(t).then(p=>p.blob()).then(p=>{as.saveAs(p,c)})},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),C.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const o={audio_id:e},c=this.credential?.token;if(!c){console.error("no token specified"),l(new Error("No token specified"));return}P.mp4(o,{token:c}).then(p=>{const d=p.data?.data?.video_url;d?t(d):l(new Error("Video URL not found in response"))}).catch(p=>{l(p)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onRemaster(e){await this.onGenerateAudioUrl("remaster",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"mashup",audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,C.info(this.$t("suno.message.fetchingWav"));const o=(await P.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;o?this.onDownload(null,o):C.error(this.$t("suno.message.fetchWavFailed"))}catch{C.error(this.$t("suno.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;const t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,C.info(this.$t("suno.message.fetchingMidi"));const o=(await P.midi({audio_id:e.id},{token:t})).data?.data?.midi_url;o?this.onDownload(null,o):C.error(this.$t("suno.message.fetchMidiFailed"))}catch{C.error(this.$t("suno.message.fetchMidiFailed"))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){const l={action:e,audio_id:t,callback_url:ls},o=this.credential?.token;if(!o){console.error("no token specified");return}C.info(this.$t("suno.message.startingTask")),P.audio(l,{token:o}).then(()=>{C.success(this.$t("suno.message.startTaskSuccess"))}).catch(c=>{C.error(c?.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})}}}),cs={class:"task"},us=["onClick"],ds={class:"left"},ps=["onClick"],ms=["onClick"],fs={key:2,class:"duration"},hs={class:"info"},_s={class:"title"},gs={class:"style"},$s={class:"right"},vs={class:"el-dropdown-link"},ys={class:"flex items-center min-w-[120px]"},ks={class:"flex items-center min-w-[120px]"},ws={class:"flex items-center min-w-[120px]"},bs={class:"el-dropdown-link"};function Cs(e,t,l,o,c,p){const d=a("el-image"),_=a("video-pause"),$=a("el-icon"),r=a("video-play"),h=a("font-awesome-icon"),b=a("el-tooltip"),f=a("Loading"),k=a("el-dropdown-item"),U=a("el-dropdown-menu"),E=a("el-dropdown"),j=Q("loading");return i(),g("div",cs,[(i(!0),g(D,null,Y(e.audios,v=>(i(),g("div",{key:v.id,class:"audio",onClick:F(V=>e.onClick(v),["stop"])},[q((i(),g("div",ds,[s(d,{src:v?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),v?.audio_url&&e.$store.state?.suno?.audio?.id===v.id&&e.$store.state?.suno?.audio?.state==="playing"?(i(),g("div",{key:0,class:"overlay",onClick:F(V=>e.onPause(v),["stop"])},[s($,null,{default:m(()=>[s(_)]),_:1})],8,ps)):y("",!0),v?.audio_url&&(e.$store.state?.suno?.audio?.id!==v.id||e.$store.state?.suno?.audio?.id===v.id&&e.$store.state?.suno?.audio?.state==="paused")?(i(),g("div",{key:1,class:"overlay",onClick:F(V=>e.onPlay(v),["stop"])},[s($,null,{default:m(()=>[s(r)]),_:1})],8,ms)):y("",!0),v?.duration?(i(),g("div",fs,u(e.useFormatDuring(v?.duration)),1)):y("",!0)])),[[j,!v?.audio_url]]),n("div",hs,[n("h2",_s,u(v?.title),1),n("p",gs,u(v?.style),1)]),n("div",$s,[s(E,null,{dropdown:m(()=>[s(U,null,{default:m(()=>[s(k,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload(v)},{default:m(()=>[n("div",ys,[e.isFetchingVideoUrl?(i(),w($,{key:0,class:"is-loading mr-2"},{default:m(()=>[s(f)]),_:1})):y("",!0),n("span",null,u(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),v?.audio_url?(i(),w(k,{key:0,onClick:F(V=>e.onDownload(V,v?.audio_url),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):y("",!0),s(k,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload(v)},{default:m(()=>[n("div",ks,[e.isFetchingWav?(i(),w($,{key:0,class:"is-loading mr-2"},{default:m(()=>[s(f)]),_:1})):y("",!0),n("span",null,u(e.$t("suno.button.download_wav")),1)])]),_:2},1032,["disabled","onClick"]),s(k,{disabled:e.isFetchingMidi,onClick:V=>e.handleMidiDownload(v)},{default:m(()=>[n("div",ws,[e.isFetchingMidi?(i(),w($,{key:0,class:"is-loading mr-2"},{default:m(()=>[s(f)]),_:1})):y("",!0),n("span",null,u(e.$t("suno.button.download_midi")),1)])]),_:2},1032,["disabled","onClick"])]),_:2},1024)]),default:m(()=>[n("span",vs,[s(b,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:m(()=>[v?.audio_url||v?.video_url?(i(),w(h,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(E,null,{dropdown:m(()=>[s(U,null,{default:m(()=>[v?.audio_url?(i(),w(k,{key:0,onClick:F(V=>e.onExtend(V,v),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):y("",!0),v.id?(i(),w(k,{key:1,onClick:F(V=>e.onGetStems(v.id),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):y("",!0),v.id?(i(),w(k,{key:2,onClick:F(V=>e.onGetAllStems(v.id),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.all_stems")),1)]),_:2},1032,["onClick"])):y("",!0),s(k,{onClick:F(V=>e.onCover(v),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),v?.id?(i(),w(k,{key:3,onClick:F(V=>e.onRemaster(v.id),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.remaster")),1)]),_:2},1032,["onClick"])):y("",!0),v?.id?(i(),w(k,{key:4,onClick:F(V=>e.onReplaceSection(v),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.replace_section")),1)]),_:2},1032,["onClick"])):y("",!0),v?.id?(i(),w(k,{key:5,onClick:F(V=>e.onMashup(v),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.mashup")),1)]),_:2},1032,["onClick"])):y("",!0),v?.id&&v?.action==="extend"?(i(),w(k,{key:6,onClick:F(V=>e.onConcatMusic(v?.id),["stop"])},{default:m(()=>[L(u(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:m(()=>[n("span",bs,[s(b,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:m(()=>[v?.audio_url||v?.video_url?(i(),w(h,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,us))),128))])}const Ss=A(rs,[["render",Cs]]),Vs={class:"player-slider"},Ls=S({__name:"PlayerSlider",setup(e){const t=H(),l=I({get:()=>t.state.suno?.audio?.progress,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:d})}),o=I({get:()=>t.state.suno?.audio?.duration,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:d})}),c=()=>{},p=d=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:d});return(d,_)=>(i(),g("div",Vs,[s(T(te),{modelValue:l.value,"onUpdate:modelValue":_[0]||(_[0]=$=>l.value=$),"show-tooltip":!1,min:0,max:o.value,onChange:p,onInput:c},null,8,["modelValue","max"])]))}}),As="/assets/disk-XFRmVAfp.png",js={class:"flex player-song"},Fs=["src"],Es={class:"ml-2 text-xs flex flex-col justify-between"},Ts={class:"w-52 2xl:w-96 cursor-pointer truncate"},Us={class:"flex"},Ps={class:"ml-2 text-dc"},Is=S({__name:"PlayerSong",setup(e){const t=H(),l=I({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return Se(l,(o,c)=>{if(o?.audio_url!==c?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const p=new Audio(o.audio_url);o.state==="playing"?p.play():p.pause(),p.addEventListener("loadedmetadata",()=>{p.currentTime=0,p.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:p.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:p})}else if(o?.progress!==c?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const p=t.state.suno.audio;p.object&&(p.object.currentTime=p.progress)}else o?.state!==c?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==c?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,c)=>(i(),g("div",js,[n("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||T(As)},null,8,Fs),n("div",Es,[n("div",Ts,[n("div",Us,[n("span",null,u(l.value?.title||"Music"),1),n("span",Ps,"- "+u(l.value?.style||"SmallRuralDog"),1)])])])]))}}),zs={class:"flex justify-end items-center gap-x-2.5"},Gs={class:"text-xs"},Ms=S({__name:"PlayerAction",setup(e){const t=H(),l=I({get:()=>t.state.suno?.audio?.progress,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:c})}),o=I({get:()=>t.state.suno?.audio?.duration,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:c})});return(c,p)=>(i(),g("div",zs,[n("span",Gs,u(T(W)(l.value))+" / "+u(T(W)(o.value)),1)]))}});var Rs={size:"1em",strokeWidth:4,strokeLinecap:"round",strokeLinejoin:"round",rtl:!1,theme:"outline",colors:{outline:{fill:"#333",background:"transparent"},filled:{fill:"#333",background:"#FFF"},twoTone:{fill:"#333",twoTone:"#2F88FF"},multiColor:{outStrokeColor:"#333",outFillColor:"#2F88FF",innerStrokeColor:"#FFF",innerFillColor:"#43CCF8"}},prefix:"i"};function Ds(){return"icon-"+((1+Math.random())*4294967296|0).toString(16).substring(1)}function Ws(e,t,l){var o=typeof t.fill=="string"?[t.fill]:t.fill||[],c=[],p=t.theme||l.theme;switch(p){case"outline":c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push("none"),c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push("none");break;case"filled":c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push("#FFF"),c.push("#FFF");break;case"two-tone":c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push(typeof o[1]=="string"?o[1]:l.colors.twoTone.twoTone),c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push(typeof o[1]=="string"?o[1]:l.colors.twoTone.twoTone);break;case"multi-color":c.push(typeof o[0]=="string"?o[0]:"currentColor"),c.push(typeof o[1]=="string"?o[1]:l.colors.multiColor.outFillColor),c.push(typeof o[2]=="string"?o[2]:l.colors.multiColor.innerStrokeColor),c.push(typeof o[3]=="string"?o[3]:l.colors.multiColor.innerFillColor);break}return{size:t.size||l.size,strokeWidth:t.strokeWidth||l.strokeWidth,strokeLinecap:t.strokeLinecap||l.strokeLinecap,strokeLinejoin:t.strokeLinejoin||l.strokeLinejoin,colors:c,id:e}}var Os=Symbol("icon-context");function oe(e,t,l){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(p){var d=Ds(),_=Ve(Os,Rs);return function(){var $=p.size,r=p.strokeWidth,h=p.strokeLinecap,b=p.strokeLinejoin,f=p.theme,k=p.fill,U=p.spin,E=Ws(d,{size:$,strokeWidth:r,strokeLinecap:h,strokeLinejoin:b,theme:f,fill:k},_),j=[_.prefix+"-icon"];return j.push(_.prefix+"-icon-"+e),t&&_.rtl&&j.push(_.prefix+"-icon-rtl"),U&&j.push(_.prefix+"-icon-spin"),s("span",{class:j.join(" ")},[l(E)])}}};return o}const Bs=oe("pause-one",!1,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("path",{d:"M24 44C35.0457 44 44 35.0457 44 24C44 12.9543 35.0457 4 24 4C12.9543 4 4 12.9543 4 24C4 35.0457 12.9543 44 24 44Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M19 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M29 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),Ns=oe("play",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("path",{d:"M24 44C35.0457 44 44 35.0457 44 24C44 12.9543 35.0457 4 24 4C12.9543 4 4 12.9543 4 24C4 35.0457 12.9543 44 24 44Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M20 24V17.0718L26 20.5359L32 24L26 27.4641L20 30.9282V24Z",fill:e.colors[3],stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null)])}),qs=oe("volume-small",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("path",{d:"M24 6V42C17 42 11.7985 32.8391 11.7985 32.8391H6C4.89543 32.8391 4 31.9437 4 30.8391V17.0108C4 15.9062 4.89543 15.0108 6 15.0108H11.7985C11.7985 15.0108 17 6 24 6Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M32 15L32 15C32.6232 15.5565 33.1881 16.1797 33.6841 16.8588C35.1387 18.8504 36 21.3223 36 24C36 26.6545 35.1535 29.1067 33.7218 31.0893C33.2168 31.7885 32.6391 32.4293 32 33",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),ne=S({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,l)=>(i(),w(Le(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"]))}}),Hs={class:"player-volume flex flex-col items-center pt-2"},Ks={class:"text-sm mt-3"},Zs=S({__name:"PlayerVolumeSlider",setup(e){const t=H(),l=I({get:()=>t.state.suno.audio?.volume,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:p})}),o=I({get:()=>t.state.suno.audio?.muted,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:p})}),c=p=>t.dispatch("suno/setVolume",p);return(p,d)=>(i(),g("div",Hs,[s(T(te),{modelValue:l.value,"onUpdate:modelValue":d[0]||(d[0]=_=>l.value=_),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:c},null,8,["modelValue","disabled"]),n("div",Ks,u(l.value),1)]))}}),Xs={class:"flex items-center justify-center gap-x-3"},Ys=S({__name:"PlayerController",setup(e){const t=H(),l=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=I(()=>t.state.suno.audio);return(c,p)=>(i(),g("div",Xs,[s(ne,{icon:o.value?.state==="playing"?T(Bs):T(Ns),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),s(T(ye),{placement:"top",width:"50px",trigger:"click"},{reference:m(()=>[s(ne,{icon:T(qs),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:m(()=>[s(Zs)]),_:1})]))}}),Js={class:"flex flex-col items-stretch h-20"},Qs={class:"flex grow px-5 items-center"},xs={class:"flex-1"},en={class:"flex-1"},tn={class:"flex-1"},on=S({__name:"Player",setup(e){return(t,l)=>(i(),g("div",Js,[s(Ls),n("div",Qs,[n("div",xs,[s(Is)]),n("div",en,[s(Ys)]),n("div",tn,[s(Ms)])])]))}}),sn=S({name:"RecentPanel",components:{ElSkeletonItem:we,ElSkeleton:ke,TaskPreview:Ss,Player:on,NoTasks:Ie,ScrollList:Ue},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?.()}}}),nn={key:0,class:"tasks"},an={class:"left w-[70px] p-[10px] flex items-center"},ln={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},rn={key:2,class:"w-full flex-1 flex items-center justify-center"},cn={class:"h-20"};function un(e,t,l,o,c,p){const d=a("el-skeleton-item"),_=a("el-skeleton"),$=a("task-preview"),r=a("scroll-list"),h=a("no-tasks"),b=a("player");return i(),g(D,null,[e.tasks?.items===void 0?(i(),g("div",nn,[(i(),g(D,null,Y(3,f=>n("div",{key:f,class:"flex"},[n("div",an,[s(_,{animated:""},{template:m(()=>[s(d,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),n("div",ln,[s(_,{animated:""},{template:m(()=>[s(d,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),s(d,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(i(),w(r,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=f=>e.$emit("reach-top"))},{default:m(()=>[(i(!0),g(D,null,Y(e.tasks?.items,(f,k)=>(i(),w($,{key:k,"model-value":f,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):y("",!0),e.tasks?.items?.length===0?(i(),g("div",rn,[s(h)])):y("",!0),q(n("div",cn,[s(b)],512),[[Ae,!!e.$store?.state?.suno?.audio?.object]])],64)}const dn=A(sn,[["render",un]]),pn=S({name:"TaskPreview",components:{IconPicture:Ce,ElImage:N,ElAvatar:be,ElIcon:J},computed:{audio(){return this.$store.state.suno?.audio}}}),mn={key:0,class:"size-full overflow-hidden"},fn={class:"relative h-[300px]"},hn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},_n={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"},gn={class:"p-4"},$n={class:"flex items-center font-bold mb-2"},vn={class:"text-[var(--el-text-color-regular)] mb-2"},yn={class:"text-xs text-[var(--el-text-color-regular)]"},kn={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},wn={key:1,class:"w-full h-full"};function bn(e,t,l,o,c,p){const d=a("icon-picture"),_=a("el-icon"),$=a("el-image"),r=a("el-avatar");return e.audio?.object?(i(),g("div",mn,[n("div",fn,[s($,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:m(()=>[n("div",hn,[s(_,{class:"text-3xl"},{default:m(()=>[s(d)]),_:1})])]),_:1},8,["src"]),n("h2",_n,u(e.audio?.title),1)]),n("div",gn,[n("div",$n,[s(r,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),n("span",null,u(e.audio?.title),1)]),n("p",vn,u(e.audio?.style),1),n("p",yn,u(e.$dayjs.format(e.audio?.created_at)),1),n("div",kn,[n("p",null,u(e.audio?.lyric),1)])])])):(i(),g("div",wn))}const Cn=A(pn,[["render",bn]]),Sn="https://webhook.acedata.cloud/suno",Vn=S({name:"SunoIndex",components:{Layout:Ne,ConfigPanel:ss,RecentPanel:dn,PreviewPanel:Cn},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===R.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===R.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===R.Request},needApply(){return this.$store.state.suno.status.getApplications===R.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 Ge({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(){Ee.create({application:this.application}).then(({data:e})=>{this.application=e,C.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Te&&C.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:o}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",o),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:l,createdAtMax:o})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:Sn},t=this.credential?.token;if(!t){console.error("no token specified");return}C.info(this.$t("suno.message.startingTask")),P.audio(e,{token:t}).then(()=>{C.success(this.$t("suno.message.startTaskSuccess"))}).catch(l=>{C.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 Ln(e,t,l,o,c,p){const d=a("config-panel"),_=a("recent-panel"),$=a("preview-panel"),r=a("layout");return i(),w(r,null,{config:m(()=>[s(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:m(()=>[s(_,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:m(()=>[s($)]),_:1})}const Dn=A(Vn,[["render",Ln],["__scopeId","data-v-d1296b1a"]]);export{Dn as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as P}from"./index.es-mIRAKQ1A.js";import{l as L,S as O,k as B,N as G,O as M,F as j,D as q,t as N,u as V,s as z,p as F,G as K,j as H}from"./vendor-element-plus-B4FTqxj4.js";import{d as $,C as r,G as l,T as t,E as U,K as u,ai as o,D as a,R as i,S as E,ag as T,J as I,Q as h,O as g,M as R}from"./vendor-vue-1w_NBnjl.js";import{_ as k,bt as J,bu as Q,bv as W,aj as X,bw as Y,aB as Z,ar as x,ax as ee,ay as C}from"./index-CCYW3AUY.js";import{I as D,S as te}from"./ScrollList-6wsUvcj6.js";import{I as se}from"./ImagePreview--cM1y0-F.js";import{C as oe,N as ae}from"./NoTasks-CSLShB84.js";import{a as ne}from"./price-hx3Y1R4a.js";import{C as ie}from"./CopyToClipboard-CEtp94k8.js";import{s as le}from"./vue-plyr-QZFBikSk.js";import{B as re}from"./BotPlaceholder-DghltQML.js";import{l as ce}from"./pagination-CihAE3FS.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const pe=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:L,FontAwesomeIcon:P},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},ue={class:"config w-[300px] h-full overflow-y-scroll bg-[var(--app-sidebar-bg)]"},me={class:"result h-full p-[15px] flex-1 flex flex-col"};function fe(e,s,c,d,v,b){const p=o("font-awesome-icon"),m=o("el-button"),n=o("el-drawer");return a(),r("div",de,[l("div",ue,[U(e.$slots,"config",{},void 0,!0)]),l("div",me,[U(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:s[0]||(s[0]=y=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=y=>e.drawer=y),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=k(pe,[["render",fe],["__scopeId","data-v-d20bd7bd"]]),he=$({name:"IngredientsSelector",components:{ElSwitch:B,InfoIcon:D},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=J)}}),ge={class:"field"},$e={class:"title font-bold"};function ke(e,s,c,d,v,b){const p=o("el-switch"),m=o("info-icon");return a(),r("div",ge,[l("h2",$e,i(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(m,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const ve=k(he,[["render",ke],["__scopeId","data-v-17c0af5c"]]),be=$({name:"EffectSelector",components:{ElSelect:M,ElOption:G},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),ye={class:"field"},we={class:"title font-bold"},Ve={class:"float-left"};function Ie(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",ye,[l("h2",we,i(e.$t("pika.name.effect")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},{default:u(()=>[l("span",Ve,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Se=k(be,[["render",Ie],["__scopeId","data-v-d1c54475"]]),Ee=$({name:"IngredientsModelSelector",components:{ElRadioButton:q,ElRadioGroup:j},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=Q)}}),Te={class:"field"},Ce={class:"title font-bold"};function Pe(e,s,c,d,v,b){const p=o("el-radio-button"),m=o("el-radio-group");return a(),r("div",Te,[l("h2",Ce,i(e.$t("pika.name.ingredientsModel")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),size:"small",class:"quality"},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.value},{default:u(()=>[h(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Le=k(Ee,[["render",Pe],["__scopeId","data-v-b948551f"]]),Re=$({name:"ModelSelector",components:{ElSelect:M,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=W)}}),Ae={class:"field"},Ue={class:"title font-bold"};function De(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",Ae,[l("h2",Ue,i(e.$t("pika.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=k(Re,[["render",De],["__scopeId","data-v-7b2e870a"]]),Me=$({name:"ImageUrlInput",components:{ElUpload:N,ElButton:L,InfoIcon:D,ImagePreview:se,FontAwesomeIcon:P},data(){return{fileList:[],uploadUrl:X()+"/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.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Oe={class:"field"},Be={class:"title font-bold"},je={class:"upload-wrapper"};function qe(e,s,c,d,v,b){const p=o("image-preview"),m=o("font-awesome-icon"),n=o("el-button"),y=o("el-upload"),_=o("info-icon");return a(),r("div",Oe,[l("h2",Be,i(e.$t("pika.name.imageUrl")),1),l("div",je,[t(y,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[t(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:u(()=>[t(n,{size:"small",type:"primary",round:""},{default:u(()=>[t(m,{icon:"fa-solid fa-upload",class:"mr-1"}),h(" "+i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(_,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Ne=k(Me,[["render",qe],["__scopeId","data-v-18cda67a"]]),ze="",Fe=$({name:"PromptInput",components:{ElInput:z,InfoIcon:D},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ze)}}),Ke={class:"field"},He={class:"box"},Je={class:"title font-bold"};function Qe(e,s,c,d,v,b){const p=o("info-icon"),m=o("el-input");return a(),r("div",Ke,[l("div",He,[l("h2",Je,i(e.$t("pika.name.prompt")),1),t(p,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const We=k(Fe,[["render",Qe],["__scopeId","data-v-d7f7cedd"]]),Xe=$({name:"PresetPanel",components:{ImageUrlInput:Ne,ElButton:L,FontAwesomeIcon:P,Consumption:oe,PromptInput:We,IngredientsSelector:ve,IngredientsModelSelector:Le,ModelSelector:Ge,EffectSelector:Se},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ye={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 et(e,s,c,d,v,b){const p=o("prompt-input"),m=o("model-selector"),n=o("ingredients-selector"),y=o("effect-selector"),_=o("image-url-input"),f=o("ingredients-model-selector"),S=o("consumption"),w=o("font-awesome-icon"),A=o("el-button");return a(),r("div",Ye,[l("div",Ze,[t(p,{class:"mb-4"}),t(m,{class:"mb-4"}),t(n,{class:"mb-4"}),t(y,{class:"mb-4"}),e.config?.ingredients?(a(),I(_,{key:0,class:"mb-4"})):g("",!0),e.config?.ingredients?(a(),I(f,{key:1,class:"mb-4"})):g("",!0)]),l("div",xe,[t(S,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(w,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const tt=k(Xe,[["render",et]]),st=$({name:"VideoPlayer",components:{VuePlyr:le},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),ot=["data-poster"],at=["src"];function nt(e,s,c,d,v,b){const p=o("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:u(()=>[l("video",{controls:"",crossorigin:"",playsinline:"","data-poster":e.modelValue?.image_url},[l("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,at)],8,ot)]),_:1},8,["options"])])}const it=k(st,[["render",nt],["__scopeId","data-v-fc420430"]]),lt=$({name:"TaskPreview",components:{ElImage:H,CopyToClipboard:ie,FontAwesomeIcon:P,ElAlert:K,VideoPlayer:it,ElTooltip:F,ElButton:L},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const s=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(c=>{let d=c;s&&(d.action=s),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const s=e.target,c=new URL(s.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;s.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),rt={class:"left"},ct={class:"main"},pt={class:"bot"},dt={class:"datetime"},ut={class:"info"},mt={key:0,class:"prompt mt-2"},ft={key:0},_t={key:1},ht={key:0,class:R({content:!0,failed:!0})},gt={class:"image-wrapper"},$t={key:0,class:R({operations:!0,"mt-2":!0})},kt={key:0,class:"description"},vt={class:"description"},bt={key:1,class:R({content:!0})},yt={class:"description"},wt={class:"description"},Vt={class:"description"},It={key:2,class:R({content:!0})},St={class:"description"};function Et(e,s,c,d,v,b){const p=o("el-image"),m=o("VideoPlayer"),n=o("el-button"),y=o("el-tooltip"),_=o("font-awesome-icon"),f=o("copy-to-clipboard"),S=o("el-alert");return a(!0),r(E,null,T(e.videos,(w,A)=>(a(),r("div",{key:A,class:"preview"},[l("div",rt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",ct,[l("div",pt,[h(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",dt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",ut,[e.modelValue?.request?.prompt?(a(),r("p",mt,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),r("span",ft," - ("+i(e.$t("pika.status.pending"))+") ",1)),w?.state==="processing"||w?.state==="pending"?(a(),r("span",_t," - ("+i(e.$t("pika.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",ht,[l("div",gt,[t(m,{"model-value":w},null,8,["model-value"])]),w?(a(),r("div",$t,[t(y,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:u(()=>[w?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Mt=>e.onDownload(w?.video_url)},{default:u(()=>[h(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1032,["content"])])):g("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(a(),r("p",kt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.model"))+": "+i(e.modelValue?.request?.model),1)])):g("",!0),l("p",vt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(a(),r("div",bt,[t(S,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",yt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",wt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(f,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",Vt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(f,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),!e.modelValue?.response||w?.state==="processing"||w?.state==="pending"?(a(),r("div",It,[t(S,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",St,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])]))),128)}const Tt=k(lt,[["render",Et],["__scopeId","data-v-26b4e543"]]),Ct=$({name:"RecentPanel",components:{TaskPreview:Tt,BotPlaceholder:re,NoTasks:ae,ScrollList:te},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Pt={key:0},Lt={key:2,class:"w-full h-full flex items-center justify-center"};function Rt(e,s,c,d,v,b){const p=o("bot-placeholder"),m=o("task-preview"),n=o("scroll-list"),y=o("no-tasks");return a(),r(E,null,[e.tasks?.items===void 0?(a(),r("div",Pt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(E,null,T(e.tasks?.items,(_,f)=>(a(),I(m,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),r("div",Lt,[t(y)])):g("",!0)],64)}const At=k(Ct,[["render",Rt]]),Ut="https://webhook.acedata.cloud/pika",Dt=$({name:"PikaIndex",components:{ConfigPanel:tt,Layout:_e,RecentPanel:At},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===C.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===C.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===C.Request},needApply(){return this.$store.state.pika.status.getApplications===C.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){x.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ee&&V.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:s=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),Y.generate(e,{token:s}).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===Z?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Gt(e,s,c,d,v,b){const p=o("config-panel"),m=o("recent-panel"),n=o("layout");return a(),I(n,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const es=k(Dt,[["render",Gt],["__scopeId","data-v-456819d1"]]);export{es as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.menu[data-v-0fce633f]{border-right:none}.menu .el-menu-item[data-v-0fce633f]{height:40px}.profile[data-v-8eb3b1d9]{display:flex;flex-direction:column}.info[data-v-8eb3b1d9]{width:100%;display:flex;flex-direction:column;align-items:center;padding:50px 0 20px;height:200px!important;overflow:hidden;position:relative}.info .background[data-v-8eb3b1d9]{width:100%;height:100%;position:absolute;top:0;left:0;z-index:-1;background-repeat:no-repeat;background-size:cover;background-position:center;filter:blur(15px) brightness(.7)}.info .avatar[data-v-8eb3b1d9]{width:50px;height:50px;border-radius:50%}.info h2[data-v-8eb3b1d9]{font-size:18px}.links[data-v-8eb3b1d9]{width:100%;flex:1;padding:20px}.links .link[data-v-8eb3b1d9]{height:40px;display:block;width:100%;cursor:pointer;margin-bottom:5px;position:relative;color:var(--el-text-color-primary);line-height:40px}.links .link .suffix[data-v-8eb3b1d9]{width:3px;height:40px;position:absolute;right:-5px;margin-right:5px;border-radius:3px;display:inline-block}.links .link .icon[data-v-8eb3b1d9]{width:16px;height:16px;display:inline-block;position:relative;margin-right:10px;transform:translateY(-2%)}.links .link .text[data-v-8eb3b1d9]{font-size:14px}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.menu[data-v-a55e8715]{display:none}@media (max-width: 767px){.config[data-v-a55e8715]{display:none}.result[data-v-a55e8715]{width:100%}.menu[data-v-a55e8715]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.title[data-v-7ab78c3e]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-7ab78c3e]{position:absolute;top:5px;right:0}.title[data-v-425a8cec]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-425a8cec]{position:absolute;top:5px;right:0}.title[data-v-74e51526]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-74e51526]{position:absolute;top:5px;right:0}.field .box[data-v-281baab8]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-281baab8]{font-size:14px;margin-bottom:10px}.field .info[data-v-281baab8]{margin-left:auto}.preview[data-v-a30031b6]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-a30031b6]{width:70px}.preview .left .avatar[data-v-a30031b6]{background-color:#000;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-a30031b6]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-a30031b6]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-a30031b6]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-a30031b6]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content[data-v-a30031b6]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-a30031b6]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-a30031b6]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-a30031b6]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-a30031b6]{border-color:var(--el-color-info)}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as S}from"./index.es-mIRAKQ1A.js";import{l as L,S as R,N as G,O as P,U as D,V as B,t as F,u as y,s as M,G as O,j as N}from"./vendor-element-plus-B4FTqxj4.js";import{d as $,C as i,G as l,T as t,E,K as f,ai as s,D as a,R as r,S as V,ag as I,J as w,Q as h,O as x,M as U}from"./vendor-vue-1w_NBnjl.js";import{_ as v,bZ as q,b_ as z,b$ as X,aj as K,c0 as H,aB as J,ay as A}from"./index-CCYW3AUY.js";import{I as C,S as Q}from"./ScrollList-6wsUvcj6.js";import{I as W}from"./ImagePreview--cM1y0-F.js";import{C as Z,N as Y}from"./NoTasks-CSLShB84.js";import{a as ee}from"./price-hx3Y1R4a.js";import{C as te}from"./CopyToClipboard-CEtp94k8.js";import{I as oe}from"./ImageWrapper-CQl1PxLF.js";import{B as se}from"./BotPlaceholder-DghltQML.js";import{l as ne}from"./pagination-CihAE3FS.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const le=$({name:"LayoutFlux",components:{ElDrawer:R,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 bg-[var(--app-sidebar-bg)]"},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,k){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-a7abbecc"]]),de=$({name:"ModelSelector",components:{ElSelect:P,ElOption:G},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,k){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:B,InfoIcon:C,ElInputNumber:D},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"},ke={class:"w-full"};function xe(e,o,m,d,b,k){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",ke,[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",xe]]),ye=$({name:"ActionSelector",components:{ElSelect:P,ElOption:G},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,k){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:W},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 Ge(e,o,m,d,b,k){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 Pe=v(Ee,[["render",Ge],["__scopeId","data-v-04710032"]]),je="",Re=$({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=je)}}),De={class:"field"},Be={class:"box"},Fe={class:"title font-bold"};function Me(e,o,m,d,b,k){const c=s("info-icon"),u=s("el-input");return a(),i("div",De,[l("div",Be,[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")},null,8,["modelValue","placeholder"])])}const Oe=v(Re,[["render",Me],["__scopeId","data-v-96df0218"]]),Ne=$({name:"PresetPanel",components:{ElButton:L,FontAwesomeIcon:S,PromptInput:Oe,ModelSelector:_e,CountSelector:we,Consumption:Z,ActionSelector:Ie,ImageUrlInput:Pe},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,k){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"),j=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"})):x("",!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(j,{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 He=v(Ne,[["render",Ke]]),Je=$({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")}}}),Qe={class:"preview"},We={class:"left"},Ze={class:"main"},Ye={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,k){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",Qe,[l("div",We,[t(c,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),l("div",Ze,[l("div",Ye,[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?x("",!0):(a(),i("span",st," - ("+r(e.$t("flux.status.pending"))+") ",1))])):x("",!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})])):x("",!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})])):x("",!0),e.modelValue?.response?x("",!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(Je,[["render",ft],["__scopeId","data-v-779c5dda"]]),ht=$({name:"RecentPanel",components:{TaskPreview:_t,BotPlaceholder:se,NoTasks:Y,ScrollList:Q},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,k){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"])):x("",!0),e.tasks?.items?.length===0?(a(),i("div",$t,[t(p)])):x("",!0)],64)}const bt=v(ht,[["render",vt]]),kt="https://webhook.acedata.cloud/flux",xt=$({name:"FluxIndex",components:{ConfigPanel:He,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:kt},o=this.credential?.token;if(!o){console.error("no token specified");return}y.info(this.$t("flux.message.startingTask")),H.generate(e,{token:o}).then(()=>{y.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const d=m?.response?.data;d?.error?.code===J?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,k){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(xt,[["render",wt]]);export{Ft as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.menu[data-v-d49b3d25]{display:none}@media (max-width: 767px){.config[data-v-d49b3d25]{display:none}.result[data-v-d49b3d25]{width:100%}.menu[data-v-d49b3d25]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-a768fbd9]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-a768fbd9]{font-size:14px;margin:0;width:30%}.field .value[data-v-a768fbd9]{flex:1}.title[data-v-a906df80]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-a906df80]{position:absolute;top:5px;right:0}.field .box[data-v-c601bcba]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-c601bcba]{font-size:14px;margin-bottom:10px}.field .info[data-v-c601bcba]{margin-left:auto}.preview[data-v-d1382b69]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-d1382b69]{width:70px}.preview .left .avatar[data-v-d1382b69]{width:50px;height:50px;margin:10px;border-radius:50%;box-shadow:var(--app-shadow-xs)}.preview .main[data-v-d1382b69]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-d1382b69]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-d1382b69]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-d1382b69]{font-size:16px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content[data-v-d1382b69]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-d1382b69]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-d1382b69]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-d1382b69]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-d1382b69]{border-color:var(--el-color-info)}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as T}from"./index.es-mIRAKQ1A.js";import{l as q,S as x,s as H,t as K,u as E,N as B,O as G,p as J,G as Q,j as X}from"./vendor-element-plus-B4FTqxj4.js";import{d as k,C as l,G as c,T as a,E as C,K as $,ai as s,D as n,R as o,Q as u,S as A,ag as N,J as V,O as b,M as O,X as Y}from"./vendor-vue-1w_NBnjl.js";import{_ as y,aj as Z,c7 as ee,c8 as z,c9 as P,ca as te,cb as S,cc as M,cd as j,ce as D,cf as ae,aB as oe,ay as F}from"./index-CCYW3AUY.js";import{I as U,S as ne}from"./ScrollList-6wsUvcj6.js";import{I as W}from"./ImagePreview--cM1y0-F.js";import{C as se,N as le}from"./NoTasks-CSLShB84.js";import{a as re}from"./price-hx3Y1R4a.js";import{C as ie}from"./CopyToClipboard-CEtp94k8.js";import{I as ce}from"./ImageWrapper-CQl1PxLF.js";import{B as ue}from"./BotPlaceholder-DghltQML.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const de=k({name:"LayoutNanobanana",components:{ElDrawer:x,ElButton:q,FontAwesomeIcon:T},data(){return{drawer:!1}}}),me={class:"main flex flex-row flex-1"},pe={class:"config w-[300px] h-full overflow-y-scroll bg-[var(--app-sidebar-bg)]"},fe={class:"result h-full p-[15px] flex-1 flex flex-col"};function he(e,t,g,r,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-drawer");return n(),l("div",me,[c("div",pe,[C(e.$slots,"config",{},void 0,!0)]),c("div",fe,[C(e.$slots,"result",{},void 0,!0)]),a(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=p=>e.drawer=!0)},{default:$(()=>[a(h,{icon:"fa-solid fa-magic"})]),_:1}),a(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=y(de,[["render",he],["__scopeId","data-v-c6025e81"]]),ge="",be=k({name:"PromptInput",components:{ElInput:H,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ge)}}),$e={class:"field"},ve={class:"box"},ke={class:"title font-bold"};function ye(e,t,g,r,d,f){const h=s("info-icon"),_=s("el-input");return n(),l("div",$e,[c("div",ve,[c("h2",ke,o(e.$t("nanobanana.name.prompt")),1),a(h,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),a(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const we=y(be,[["render",ye],["__scopeId","data-v-2331e197"]]),Ae=k({name:"ImageUrlsInput",components:{ElUpload:K,ElButton:q,InfoIcon:U,ImagePreview:W,FontAwesomeIcon:T},data(){return{fileList:[],uploadUrl:Z()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const d=this.fileList.find(f=>f?.response?.file_url===r||f?.url===r);d?t.push(d):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(f=>f===r||f?.url===r?.url||f?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){E.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){E.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Ve={class:"field flex items-center justify-between"},Ne={class:"title font-bold text-[14px] mb-[10px]"},Re={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Ee={class:"controls flex items-center"},Ie={class:"file-list flex flex-wrap gap-[10px]"};function Le(e,t,g,r,d,f){const h=s("font-awesome-icon"),_=s("el-button"),m=s("el-upload"),p=s("info-icon"),w=s("image-preview");return n(),l(A,null,[c("div",Ve,[c("h2",Ne,o(e.$t("nanobanana.name.imageUrls")),1),c("div",Re,[c("div",Ee,[a(m,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[a(_,{size:"small",type:"primary",round:""},{default:$(()=>[a(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(p,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Ie,[(n(!0),l(A,null,N(e.fileList,(i,v)=>(n(),V(w,{key:i.uid||i?.response?.file_url||i.url||v,url:i.url||i?.response?.file_url,name:i.name,percentage:i.percentage,onRemove:R=>e.onRemovePreview(v,i)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Se=y(Ae,[["render",Le]]),Te=k({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),qe={class:"field"},Oe={class:"title font-bold"};function Ue(e,t,g,r,d,f){const h=s("el-option"),_=s("el-select");return n(),l("div",qe,[c("h2",Oe,o(e.$t("nanobanana.name.aspectRatio")),1),a(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,m=>(n(),V(h,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=y(Te,[["render",Ue],["__scopeId","data-v-67f08a08"]]),Pe=k({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:B,InfoIcon:U},data(){return{options:[{value:z,label:this.$t("nanobanana.model.nanoBanana")},{value:P,label:this.$t("nanobanana.model.nanoBananaPro")},{value:te,label:this.$t("nanobanana.model.nanoBanana2")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=ee)}}),Be={class:"field"},Ge={class:"label"},Me={class:"box"},je={class:"title font-bold"};function De(e,t,g,r,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",Be,[c("div",Ge,[c("div",Me,[c("h2",je,o(e.$t("nanobanana.name.model")),1),a(h,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Fe=y(Pe,[["render",De],["__scopeId","data-v-94304d73"]]),ze=k({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:B,InfoIcon:U},data(){return{cachedResolution:S,options:[{value:M,label:M},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model!==z}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),We={class:"field"},xe={class:"label"},He={class:"box"},Ke={class:"title font-bold"};function Je(e,t,g,r,d,f){const h=s("info-icon"),_=s("el-option"),m=s("el-select");return n(),l("div",We,[c("div",xe,[c("div",He,[c("h2",Ke,o(e.$t("nanobanana.name.resolution")),1),a(h,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:$(()=>[(n(!0),l(A,null,N(e.options,p=>(n(),V(_,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Qe=y(ze,[["render",Je],["__scopeId","data-v-fd5ab393"]]),Xe=k({name:"ConfigPanel",components:{ElButton:q,FontAwesomeIcon:T,PromptInput:we,Consumption:se,ImageUrlsInput:Se,AspectRatioSelector:Ce,ModelSelector:Fe,ResolutionSelector:Qe},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return re({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ye={class:"flex flex-col h-full"},Ze={class:"flex-1 overflow-y-auto p-[15px]"},et={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function tt(e,t,g,r,d,f){const h=s("model-selector"),_=s("resolution-selector"),m=s("prompt-input"),p=s("aspect-ratio-selector"),w=s("image-urls-input"),i=s("consumption"),v=s("font-awesome-icon"),R=s("el-button");return n(),l("div",Ye,[c("div",Ze,[a(h,{class:"mb-4"}),a(_,{class:"mb-4"}),a(m,{class:"mb-4"}),a(p,{class:"mb-4"}),a(w,{class:"mb-4"})]),c("div",et,[a(i,{value:e.consumption,service:e.service},null,8,["value","service"]),a(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[a(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const at=y(Xe,[["render",tt]]),ot=k({name:"TaskPreview",components:{ElImage:X,CopyToClipboard:ie,FontAwesomeIcon:T,ElAlert:Q,ImageWrapper:ce,ElButton:q,ElTooltip:J,ImagePreview:W},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),nt={class:"preview"},st={class:"left"},lt={class:"main"},rt={class:"bot"},it={class:"datetime"},ct={class:"info"},ut={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},dt={key:1,class:"prompt mt-2"},mt={key:0},pt={key:0,class:O({content:!0,failed:!0})},ft={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},ht={class:O({operations:!0,"mt-2":!0,"mb-2":!0})},_t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},yt={key:1,class:O({content:!0})},wt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Et={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:2,class:O({content:!0})},St={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Ct(e,t,g,r,d,f){const h=s("el-image"),_=s("image-preview"),m=s("image-wrapper"),p=s("el-button"),w=s("el-tooltip"),i=s("font-awesome-icon"),v=s("copy-to-clipboard"),R=s("el-alert");return n(),l("div",nt,[c("div",st,[a(h,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",lt,[c("div",rt,[u(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",it,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",ct,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",ut,[(n(!0),l(A,null,N(e.modelValue?.request?.image_urls,(I,L)=>(n(),V(_,{key:L,url:I,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):b("",!0),e.modelValue?.request?.prompt?(n(),l("p",dt,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?b("",!0):(n(),l("span",mt," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):b("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",pt,[c("div",ft,[(n(!0),l(A,null,N(e.images,(I,L)=>(n(),V(m,{key:L,src:I?.image_url,"raw-src":I?.image_url},null,8,["src","raw-src"]))),128))]),c("div",ht,[a(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[a(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Y(I=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),a(R,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(n(),l("p",_t,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):b("",!0),e.modelValue?.request?.resolution?(n(),l("p",gt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):b("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",bt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):b("",!0),e.modelValue?.request?.action?(n(),l("p",$t,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):b("",!0),c("p",vt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),l("p",kt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):b("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),l("div",yt,[a(R,{closable:!1,class:"failure"},{template:$(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",wt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):b("",!0),e.modelValue?.request?.resolution?(n(),l("p",At,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):b("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):b("",!0),e.modelValue?.request?.action?(n(),l("p",Nt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):b("",!0),c("p",Rt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Et,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),l("p",It,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):b("",!0)]),_:1})])):(n(),l("div",Lt,[a(R,{closable:!1,class:"info"},{template:$(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",St,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):b("",!0),e.modelValue?.request?.resolution?(n(),l("p",Tt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):b("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):b("",!0),e.modelValue?.request?.action?(n(),l("p",Ot,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):b("",!0),c("p",Ut,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Pt=y(ot,[["render",Ct],["__scopeId","data-v-3eb5facb"]]),Bt=k({name:"RecentPanel",components:{TaskPreview:Pt,BotPlaceholder:ue,NoTasks:le,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Gt={key:0},Mt={key:2,class:"w-full h-full flex items-center justify-center"};function jt(e,t,g,r,d,f){const h=s("bot-placeholder"),_=s("task-preview"),m=s("scroll-list"),p=s("no-tasks");return n(),l(A,null,[e.tasks?.items===void 0?(n(),l("div",Gt,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),V(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:$(()=>[(n(!0),l(A,null,N(e.tasks?.items,w=>(n(),V(_,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):b("",!0),e.tasks?.items?.length===0?(n(),l("div",Mt,[a(p)])):b("",!0)],64)}const Dt=y(Bt,[["render",jt]]),Ft="https://webhook.acedata.cloud/nanobanana",zt=k({name:"NanobananaIndex",components:{ConfigPanel:at,Layout:_e,RecentPanel:Dt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.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(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const g=this.tasks?.items?.[0];if(!g?.created_at)return;const d=this.$refs.recentPanel?.getScrollElement?.(),f=d?.scrollHeight||0,h=d?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:g.created_at}),await this.$nextTick(),d){const _=d.scrollHeight;d.scrollTop=_-f+h}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:g,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",g,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:g,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==P&&"resolution"in e&&delete e.resolution,e?.model===P&&!e?.resolution&&(e.resolution=S);const g={...e,action:t?"edit":"generate",callback_url:Ft},r=this.credential?.token;if(!r){console.error("no token specified");return}E.info(this.$t("nanobanana.message.startingTask")),ae.generate(g,{token:r}).then(()=>{E.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const f=d?.response?.data;f?.error?.code===oe?E.error(this.$t("nanobanana.message.usedUp")):E.error(this.$t("nanobanana.message.startTaskFailed")+(f?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Wt(e,t,g,r,d,f){const h=s("config-panel"),_=s("recent-panel"),m=s("layout");return n(),V(m,null,{config:$(()=>[a(h,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[a(_,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ra=y(zt,[["render",Wt]]);export{ra as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.header{z-index:999;width:100%;background:var(--el-bg-color)}.header .brand-col{display:flex;align-items:center;justify-content:flex-end;min-height:60px;padding-right:20px}.header .el-menu.menu{--el-menu-hover-bg-color: var(--el-bg-color);--el-menu-active-color: var(--el-color-primary);background:none;border:none;height:60px;min-width:300px;overflow-x:hidden}.header .el-menu.menu .el-menu-item{height:60px;color:inherit!important}.header .el-menu.menu .el-menu-item.is-active{color:inherit!important;border-bottom:none!important}.header .el-menu.menu .el-menu-item:hover{border-bottom:2px solid var(--el-color-primary)!important}.header .avatar{height:40px;border-radius:50%;cursor:pointer;margin-top:10px;margin-right:20px;margin-left:10px}.header .console{color:inherit!important;height:60px;line-height:60px;margin:0 10px;font-size:14px;display:inline-block;cursor:pointer}.header .locale{cursor:pointer;display:inline-block;margin-left:10px}@media only screen and (max-width: 768px){.header .brand-col{justify-content:center;padding-right:0}}.container[data-v-febbd828]{margin:auto;max-width:1200px;padding:30px 0 20px}.footer[data-v-febbd828]{background-color:var(--el-color-primary);color:#fff;padding:0}.footer .title[data-v-febbd828]{font-size:1.2rem;font-weight:400}.footer a[data-v-febbd828]{text-decoration:none;color:#fff}.footer .github-link[data-v-febbd828]{display:inline-flex;align-items:center;margin-left:4px;transition:opacity .3s}.footer .github-link[data-v-febbd828]:hover{opacity:.7}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.download-page[data-v-fb8b4d83]{position:relative;overflow:hidden;min-height:calc(100vh - 140px);background:linear-gradient(180deg,#f3f8ff,#e8f1ff 48%,#f8fbff)}.ambient[data-v-fb8b4d83]{position:absolute;border-radius:999px;filter:blur(60px);opacity:.55;pointer-events:none}.ambient--cyan[data-v-fb8b4d83]{top:72px;left:-120px;width:320px;height:320px;background:#4cc9f040}.ambient--gold[data-v-fb8b4d83]{top:220px;right:-80px;width:260px;height:260px;background:#f59e0b2e}.container[data-v-fb8b4d83]{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:72px 24px 96px}.hero-shell[data-v-fb8b4d83]{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:28px;align-items:stretch;margin-bottom:28px}.hero-copy[data-v-fb8b4d83]{padding:48px;border-radius:36px;background:linear-gradient(135deg,#07111ffa,#0c2743f5 56%,#105c99eb);color:#f8fbff;box-shadow:0 30px 80px #07172b3d}.hero-copy .eyebrow[data-v-fb8b4d83]{margin-bottom:12px;font-size:14px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#8fdbfff0}.hero-copy h1[data-v-fb8b4d83]{margin:0 0 16px;max-width:560px;font-size:56px;line-height:1.1;color:#f8fbff}.hero-copy .subtitle[data-v-fb8b4d83]{max-width:560px;margin:0;font-size:18px;line-height:1.7;color:#e6eff8d1}.hero-tags[data-v-fb8b4d83]{display:flex;flex-wrap:wrap;gap:12px;margin:28px 0 24px}.tag[data-v-fb8b4d83]{display:inline-flex;align-items:center;padding:10px 16px;border-radius:999px;background:#ffffff1a;border:1px solid rgba(255,255,255,.12);color:#f8fbff;font-size:13px;font-weight:600}.tag--soft[data-v-fb8b4d83]{color:#e6eff8d1}.hero-actions[data-v-fb8b4d83]{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}.secondary-action[data-v-fb8b4d83]{border-color:#0ea5e92e;background:#ffffffb8;color:#123454}.metrics[data-v-fb8b4d83]{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.metric[data-v-fb8b4d83]{display:flex;flex-direction:column;gap:8px;padding:18px 20px;border-radius:22px;background:#ffffff14;border:1px solid rgba(17,24,39,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.metric strong[data-v-fb8b4d83]{font-size:20px;font-weight:700;color:#fff}.metric span[data-v-fb8b4d83]{font-size:13px;line-height:1.6;color:#e6eff8b8}.hero-panels[data-v-fb8b4d83]{display:grid;gap:20px}.panel[data-v-fb8b4d83]{position:relative;padding:28px;border-radius:32px;background:#ffffffd6;border:1px solid rgba(148,163,184,.18);box-shadow:0 24px 60px #0f172a14;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.panel--android[data-v-fb8b4d83]:before,.panel--ios[data-v-fb8b4d83]:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none}.panel--android[data-v-fb8b4d83]:before{background:linear-gradient(145deg,rgba(14,165,233,.12),transparent 42%)}.panel--ios[data-v-fb8b4d83]:before{background:linear-gradient(145deg,rgba(15,23,42,.06),transparent 48%)}.panel h2[data-v-fb8b4d83]{position:relative;z-index:1;margin:0 0 10px;font-size:32px;line-height:1.15;color:#0f172a}.panel__head[data-v-fb8b4d83]{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.panel__text[data-v-fb8b4d83]{position:relative;z-index:1;margin:0 0 20px;font-size:15px;line-height:1.75;color:#475569}.platform-badge[data-v-fb8b4d83],.status[data-v-fb8b4d83]{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700}.platform-badge[data-v-fb8b4d83]{background:#3b82f61f;color:#2563eb}.platform-badge--ios[data-v-fb8b4d83]{background:#0f172a14;color:#334155}.status--live[data-v-fb8b4d83]{background:#10b98124;color:#047857}.status--pending[data-v-fb8b4d83]{max-width:220px;background:#f59e0b24;color:#b45309;text-align:right;justify-content:flex-end}.qr-frame[data-v-fb8b4d83]{position:relative;z-index:1;display:inline-flex;padding:18px;border-radius:28px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:inset 0 0 0 1px #94a3b833}.qr[data-v-fb8b4d83]{display:block}.device-ghost[data-v-fb8b4d83]{position:relative;z-index:1;display:flex;justify-content:center;margin:10px 0 18px}.device-ghost__screen[data-v-fb8b4d83]{width:180px;height:220px;border-radius:34px;padding:24px;background:linear-gradient(180deg,#0f172a,#22314b);box-shadow:0 20px 40px #0f172a38;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#f8fafc}.device-ghost__screen span[data-v-fb8b4d83]{font-size:28px;font-weight:700;letter-spacing:.04em}.device-ghost__screen small[data-v-fb8b4d83]{margin-top:10px;font-size:13px;color:#e2e8f0b8}.panel__footer[data-v-fb8b4d83]{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:22px}.panel__footer--stacked[data-v-fb8b4d83]{align-items:flex-start;flex-direction:column}.button-group[data-v-fb8b4d83]{display:flex;flex-wrap:wrap;gap:12px}.panel__meta[data-v-fb8b4d83]{font-size:13px;line-height:1.7;color:#64748b}.advantage-grid[data-v-fb8b4d83]{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-bottom:24px}.advantage-card[data-v-fb8b4d83]{padding:26px;border-radius:28px;background:#ffffffbd;border:1px solid rgba(148,163,184,.16);box-shadow:0 18px 44px #0f172a0f}.advantage-card__eyebrow[data-v-fb8b4d83]{margin:0 0 14px;font-size:12px;font-weight:700;letter-spacing:.12em;color:#0ea5e9}.advantage-card h3[data-v-fb8b4d83]{margin:0 0 12px;font-size:24px;line-height:1.2;color:#0f172a}.advantage-card p[data-v-fb8b4d83]{margin:0;font-size:15px;line-height:1.75;color:#475569}.note[data-v-fb8b4d83]{padding:22px 24px;border-radius:24px;background:#091526e6;color:#e2e8f0d1;text-align:center;font-size:14px;line-height:1.7}@media (max-width: 767px){.container[data-v-fb8b4d83]{padding:44px 16px 72px}.hero-shell[data-v-fb8b4d83]{grid-template-columns:1fr}.hero-copy[data-v-fb8b4d83]{padding:32px 24px}.hero-copy h1[data-v-fb8b4d83]{font-size:42px}.metrics[data-v-fb8b4d83],.advantage-grid[data-v-fb8b4d83]{grid-template-columns:1fr}.panel[data-v-fb8b4d83]{padding:24px}.panel__head[data-v-fb8b4d83],.panel__footer[data-v-fb8b4d83]{flex-direction:column;align-items:flex-start}.status--pending[data-v-fb8b4d83]{max-width:none;text-align:left;justify-content:flex-start}}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.menu[data-v-d20bd7bd]{display:none}@media (max-width: 767px){.config[data-v-d20bd7bd]{display:none}.result[data-v-d20bd7bd]{width:100%}.menu[data-v-d20bd7bd]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-17c0af5c]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-17c0af5c]{font-size:14px;margin:0;width:30%}.field .value[data-v-17c0af5c]{flex:1;margin-left:60px}.field[data-v-d1c54475]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-d1c54475]{font-size:14px;margin:0;width:30%}.field .value[data-v-d1c54475]{flex:1}.field[data-v-b948551f]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-b948551f]{font-size:14px;margin:0;width:30%}.field .value[data-v-b948551f]{flex:1}.quality .el-radio-button--small .el-radio-button__inner{padding:8px 11px}.field[data-v-7b2e870a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-7b2e870a]{font-size:14px;margin:0;width:30%}.field .value[data-v-7b2e870a]{width:80px}.field[data-v-18cda67a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-18cda67a]{font-size:14px;margin:0;width:30%}.field .value[data-v-18cda67a]{flex:1;margin-left:60px}.field .upload-wrapper[data-v-18cda67a]{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.field .info[data-v-18cda67a]{margin-left:auto}.field .box[data-v-d7f7cedd]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-d7f7cedd]{font-size:14px;margin-bottom:10px}.field .info[data-v-d7f7cedd]{margin-left:auto}.video[data-v-fc420430]{max-width:100%;height:450px}.preview[data-v-26b4e543]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-26b4e543]{width:70px}.preview .left .avatar[data-v-26b4e543]{background-color:#222;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-26b4e543]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-26b4e543]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-26b4e543]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-26b4e543]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content[data-v-26b4e543]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-26b4e543]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-26b4e543]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-26b4e543]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-26b4e543]{border-color:var(--el-color-info)}.preview .main .image-wrapper[data-v-26b4e543]{position:relative;width:-moz-fit-content;width:fit-content;min-height:50px;min-width:100px}.preview .main .image-wrapper .image[data-v-26b4e543]{max-height:400px;max-width:500px;display:block;width:-moz-fit-content;width:fit-content}.preview .main .image-wrapper .btn-raw[data-v-26b4e543]{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1000;display:none}.preview .main .image-wrapper .play-icon[data-v-26b4e543]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;color:#fff;z-index:500;pointer-events:none}.preview .main .image-wrapper:hover .image[data-v-26b4e543]{filter:brightness(.6)}.preview .main .image-wrapper:hover .btn-raw[data-v-26b4e543]{display:block}.preview .main .image-wrapper:hover .play-icon[data-v-26b4e543]{display:none}.preview .main .operations[data-v-26b4e543]{display:flex;justify-content:left;flex-direction:row;width:100%;align-items:baseline;flex-wrap:wrap;overflow:hidden;text-align:center;color:var(--el-text-color-regular);font-size:14px;overflow-y:scroll}.preview .main .operations.full[data-v-26b4e543]{height:70px}.preview .main .operations .btn-action[data-v-26b4e543],.status[data-v-456819d1]{margin-bottom:10px}.panel.detail[data-v-456819d1]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-456819d1]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-456819d1]{position:relative}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as A}from"./index.es-mIRAKQ1A.js";import{l as C,S as N,s as W,t as H,u as V,N as j,O,p as K,G as Z,j as J}from"./vendor-element-plus-B4FTqxj4.js";import{d as k,C as i,G as c,T as s,E as D,K as _,ai as n,D as a,R as o,Q as u,S as w,ag as I,J as E,O as v,M as R,X as Q}from"./vendor-vue-1w_NBnjl.js";import{_ as y,aj as X,cg as Y,ch as x,ci as ee,cj as se,ck as te,cl as oe,cm as U,cn as G,co as q,cp as B,cq as ae,aB as ne,ay as P}from"./index-CCYW3AUY.js";import{I as M,S as le}from"./ScrollList-6wsUvcj6.js";import{I as F}from"./ImagePreview--cM1y0-F.js";import{C as re,N as ie}from"./NoTasks-CSLShB84.js";import{a as ce}from"./price-hx3Y1R4a.js";import{C as de}from"./CopyToClipboard-CEtp94k8.js";import{I as me}from"./ImageWrapper-CQl1PxLF.js";import{B as ue}from"./BotPlaceholder-DghltQML.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CZJ1DcWo.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-Dj5bcX0v.js";const pe=k({name:"LayoutSeedream",components:{ElDrawer:N,ElButton:C,FontAwesomeIcon:A},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},he={class:"config w-[300px] h-full overflow-y-scroll bg-[var(--app-sidebar-bg)]"},_e={class:"result h-full p-[15px] flex-1 flex flex-col"};function ge(e,t,g,r,m,p){const f=n("font-awesome-icon"),h=n("el-button"),l=n("el-drawer");return a(),i("div",fe,[c("div",he,[D(e.$slots,"config",{},void 0,!0)]),c("div",_e,[D(e.$slots,"result",{},void 0,!0)]),s(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=d=>e.drawer=!0)},{default:_(()=>[s(f,{icon:"fa-solid fa-magic"})]),_:1}),s(l,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[D(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const $e=y(pe,[["render",ge],["__scopeId","data-v-b4ad94f1"]]),ve="",be=k({name:"SeedreamPromptInput",components:{ElInput:W,InfoIcon:M},computed:{prompt:{get(){return this.$store.state.seedream?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ve)}}),ke={class:"field"},ye={class:"box"},we={class:"title font-bold"};function Ee(e,t,g,r,m,p){const f=n("info-icon"),h=n("el-input");return a(),i("div",ke,[c("div",ye,[c("h2",we,o(e.$t("seedream.name.prompt")),1),s(f,{content:e.$t("seedream.description.prompt"),class:"info"},null,8,["content"])]),s(h,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=l=>e.prompt=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("seedream.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Se=y(be,[["render",Ee],["__scopeId","data-v-5559520a"]]),Ve=k({name:"SeedreamImageInput",components:{ElUpload:H,ElButton:C,InfoIcon:M,ImagePreview:F,FontAwesomeIcon:A},data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.seedream?.config?.image}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(m=>!m?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const m=this.fileList.find(p=>p?.response?.file_url===r||p?.url===r);m?t.push(m):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(p=>p===r||p?.url===r?.url||p?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImages()},onExceed(){V.warning(this.$t("seedream.message.uploadImageExceed"))},onError(){V.error(this.$t("seedream.message.uploadImageError"))},onSetImages(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,image:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImages()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImages()}}}),Ie={class:"field"},Le={class:"label"},Re={class:"box"},Te={class:"title font-bold"},Ae={class:"value"},Ce={class:"file-list mt-2 flex flex-wrap gap-[10px]"};function Me(e,t,g,r,m,p){const f=n("info-icon"),h=n("font-awesome-icon"),l=n("el-button"),d=n("el-upload"),b=n("image-preview");return a(),i(w,null,[c("div",Ie,[c("div",Le,[c("div",Re,[c("h2",Te,o(e.$t("seedream.name.imageUrls")),1),s(f,{content:e.$t("seedream.description.imageUrls"),class:"info"},null,8,["content"])])]),c("div",Ae,[s(d,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=$=>e.fileList=$),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",limit:14,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:_(()=>[s(l,{size:"small",type:"primary",round:""},{default:_(()=>[s(h,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("seedream.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"])])]),c("div",Ce,[(a(!0),i(w,null,I(e.fileList,($,S)=>(a(),E(b,{key:$.uid||$?.response?.file_url||$.url||S,url:$.url||$?.response?.file_url,name:$.name,percentage:$.percentage,onRemove:z=>e.onRemovePreview(S,$)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const De=y(Ve,[["render",Me],["__scopeId","data-v-29737ed9"]]),ze=k({name:"SeedreamModelSelector",components:{ElSelect:O,ElOption:j,InfoIcon:M},data(){return{options:[{value:x,label:this.$t("seedream.model.seedream45")},{value:ee,label:this.$t("seedream.model.seedream40")},{value:se,label:this.$t("seedream.model.seedream30t2i")},{value:te,label:this.$t("seedream.model.seededit30i2i")}]}},computed:{value:{get(){return this.$store.state.seedream?.config?.model},set(e){this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,model:e})}}},mounted(){this.value||(this.value=Y)}}),Ue={class:"field"},Ge={class:"label"},qe={class:"box"},Pe={class:"title font-bold"};function je(e,t,g,r,m,p){const f=n("info-icon"),h=n("el-option"),l=n("el-select");return a(),i("div",Ue,[c("div",Ge,[c("div",qe,[c("h2",Pe,o(e.$t("seedream.name.model")),1),s(f,{content:e.$t("seedream.description.model"),class:"info"},null,8,["content"])])]),s(l,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedream.placeholder.select")},{default:_(()=>[(a(!0),i(w,null,I(e.options,d=>(a(),E(h,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Oe=y(ze,[["render",je],["__scopeId","data-v-3c3ca27d"]]),Be=k({name:"SeedreamSizeSelector",components:{ElSelect:O,ElOption:j,InfoIcon:M},data(){return{options:[{value:U,label:U},{value:G,label:G},{value:q,label:q}]}},computed:{value:{get(){return this.$store.state.seedream?.config?.size},set(e){this.$store.commit("seedream/setConfig",{...this.$store.state.seedream?.config,size:e})}}},mounted(){this.value||(this.value=oe)}}),Fe={class:"field"},Ne={class:"label"},We={class:"box"},He={class:"title font-bold"};function Ke(e,t,g,r,m,p){const f=n("info-icon"),h=n("el-option"),l=n("el-select");return a(),i("div",Fe,[c("div",Ne,[c("div",We,[c("h2",He,o(e.$t("seedream.name.size")),1),s(f,{content:e.$t("seedream.description.size"),class:"info"},null,8,["content"])])]),s(l,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedream.placeholder.select"),filterable:"","allow-create":"","default-first-option":""},{default:_(()=>[(a(!0),i(w,null,I(e.options,d=>(a(),E(h,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ze=y(Be,[["render",Ke],["__scopeId","data-v-54a9a469"]]),Je=k({name:"SeedreamConfigPanel",components:{ElButton:C,FontAwesomeIcon:A,PromptInput:Se,Consumption:re,ImageInput:De,ModelSelector:Oe,SizeSelector:Ze},emits:["generate"],computed:{config(){return this.$store.state.seedream?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image)&&e.image.length>0;return ce({...e,action:t?"edit":"generate",model:B(e?.model),count:1},this.service?.cost)},service(){return this.$store.state.seedream?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Qe={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-[15px]"},Ye={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function xe(e,t,g,r,m,p){const f=n("model-selector"),h=n("size-selector"),l=n("prompt-input"),d=n("image-input"),b=n("consumption"),$=n("font-awesome-icon"),S=n("el-button");return a(),i("div",Qe,[c("div",Xe,[s(f,{class:"mb-4"}),s(h,{class:"mb-4"}),s(l,{class:"mb-4"}),s(d,{class:"mb-4"})]),c("div",Ye,[s(b,{value:e.consumption,service:e.service},null,8,["value","service"]),s(S,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[s($,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("seedream.button.generate")),1)]),_:1},8,["onClick"])])])}const es=y(Je,[["render",xe]]),ss=k({name:"SeedreamTaskPreview",components:{ElImage:J,CopyToClipboard:de,FontAwesomeIcon:A,ElAlert:Z,ImageWrapper:me,ElButton:C,ElTooltip:K,ImagePreview:F},props:{modelValue:{type:Object,required:!0}},computed:{isEdit(){return Array.isArray(this.modelValue?.request?.image)&&(this.modelValue?.request?.image?.length||0)>0},images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{shortModel(e){return B(e)||e},onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.seedream?.config||{}};t.image=[e],this.$store.commit("seedream/setConfig",t)}}}),ts={class:"preview"},os={class:"left"},as={class:"main"},ns={class:"bot"},ls={class:"datetime"},rs={class:"info"},is={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},cs={key:1,class:"prompt mt-2"},ds={key:0},ms={key:0,class:R({content:!0})},us={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ps={key:1,class:R({content:!0,failed:!0})},fs={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},hs={class:R({operations:!0,"mt-2":!0,"mb-2":!0})},_s={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gs={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$s={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bs={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ks={key:2,class:R({content:!0})},ys={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ws={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Es={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ss={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vs={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Is={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ls={key:3,class:R({content:!0})},Rs={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ts={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function As(e,t,g,r,m,p){const f=n("el-image"),h=n("image-preview"),l=n("font-awesome-icon"),d=n("copy-to-clipboard"),b=n("el-alert"),$=n("image-wrapper"),S=n("el-button"),z=n("el-tooltip");return a(),i("div",ts,[c("div",os,[s(f,{src:"https://cdn.acedata.cloud/9egrbn.png",class:"avatar"})]),c("div",as,[c("div",ns,[u(o(e.$t("seedream.name.seedreamBot"))+" ",1),c("span",ls,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",rs,[Array.isArray(e.modelValue?.request?.image)&&e.modelValue?.request?.image.length>0?(a(),i("div",is,[(a(!0),i(w,null,I(e.modelValue?.request?.image,(L,T)=>(a(),E(h,{key:T,url:L,name:`image-${T+1}`,closable:!1},null,8,["url","name"]))),128))])):v("",!0),e.modelValue?.request?.prompt?(a(),i("p",cs,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(a(),i("span",ds," - ("+o(e.$t("seedream.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(a(),i("div",ps,[c("div",fs,[(a(!0),i(w,null,I(e.images,(L,T)=>(a(),E($,{key:T,src:L?.image_url,"raw-src":L?.image_url},null,8,["src","raw-src"]))),128))]),c("div",hs,[s(z,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[s(S,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Q(L=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:_(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),s(b,{closable:!1,class:"mt-2 success"},{default:_(()=>[e.modelValue?.request?.model?(a(),i("p",_s,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("seedream.name.model"))+": "+o(e.shortModel(e.modelValue?.request?.model)),1)])):v("",!0),e.modelValue?.request?.size?(a(),i("p",gs,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("seedream.name.size"))+": "+o(e.modelValue?.request?.size),1)])):v("",!0),c("p",$s,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("seedream.name.task"))+": "+o(e.isEdit?e.$t("seedream.name.edits"):e.$t("seedream.name.generate")),1)]),c("p",vs,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("seedream.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(d,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),i("p",bs,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("seedream.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(d,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),i("div",ks,[s(b,{closable:!1,class:"failure"},{template:_(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("seedream.name.failure")),1)]),default:_(()=>[e.modelValue?.request?.model?(a(),i("p",ys,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("seedream.name.model"))+": "+o(e.shortModel(e.modelValue?.request?.model)),1)])):v("",!0),e.modelValue?.request?.size?(a(),i("p",ws,[s(l,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("seedream.name.size"))+": "+o(e.modelValue?.request?.size),1)])):v("",!0),c("p",Es,[s(l,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("seedream.name.task"))+": "+o(e.isEdit?e.$t("seedream.name.edits"):e.$t("seedream.name.generate")),1)]),c("p",Ss,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("seedream.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(d,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.error?.message?(a(),i("p",Vs,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("seedream.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(d,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])])):v("",!0),e.modelValue?.response?.trace_id?(a(),i("p",Is,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("seedream.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(d,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(a(),i("div",Ls,[s(b,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("seedream.name.status")),1)]),default:_(()=>[c("p",Rs,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("seedream.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(d,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),i("p",Ts,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("seedream.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(d,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(a(),i("div",ms,[s(b,{closable:!1,class:"info"},{template:_(()=>[s(l,{icon:"fa-regular fa-clock",class:"mr-1"}),u(" "+o(e.$t("seedream.status.pending")),1)]),default:_(()=>[c("p",us,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("seedream.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(d,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})]))])])}const Cs=y(ss,[["render",As],["__scopeId","data-v-f34f00b9"]]),Ms=k({name:"SeedreamRecentPanel",components:{TaskPreview:Cs,BotPlaceholder:ue,NoTasks:ie,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],computed:{tasks(){return{...this.$store.state.seedream?.tasks,items:this.$store.state.seedream?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ds={key:0},zs={key:2,class:"w-full h-full flex items-center justify-center"};function Us(e,t,g,r,m,p){const f=n("bot-placeholder"),h=n("task-preview"),l=n("scroll-list"),d=n("no-tasks");return a(),i(w,null,[e.tasks?.items===void 0?(a(),i("div",Ds,[s(f)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E(l,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:_(()=>[(a(!0),i(w,null,I(e.tasks?.items,b=>(a(),E(h,{key:b.id,"model-value":b},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(a(),i("div",zs,[s(d)])):v("",!0)],64)}const Gs=y(Ms,[["render",Us]]),qs="https://webhook.acedata.cloud/seedream",Ps=k({name:"SeedreamIndex",components:{ConfigPanel:es,Layout:$e,RecentPanel:Gs},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.seedream?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.seedream?.status?.getTasks===P.Request},credential(){return this.$store.state.seedream?.credential},config(){return this.$store.state.seedream?.config},application(){return this.$store.state.seedream?.application},tasks(){return this.$store.state.seedream?.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(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const g=this.tasks?.items?.[0];if(!g?.created_at)return;const m=this.$refs.recentPanel?.getScrollElement?.(),p=m?.scrollHeight||0,f=m?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:g.created_at}),await this.$nextTick(),m){const h=m.scrollHeight;m.scrollTop=h-p+f}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("seedream/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("seedream/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:g,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",g,"createdAtMax",r),await this.$store.dispatch("seedream/getTasks",{limit:t,createdAtMin:g,createdAtMax:r})},async onGenerate(){const e={...this.config||{}};!(Array.isArray(e?.image)&&e.image.length>0)&&"image"in e&&delete e.image,e?.size||delete e.size;const g={...e,callback_url:qs},r=this.credential?.token;if(!r){console.error("no token specified");return}V.info(this.$t("seedream.message.startingTask")),ae.generate(g,{token:r}).then(()=>{V.success(this.$t("seedream.message.startTaskSuccess"))}).catch(m=>{const p=m?.response?.data;p?.error?.code===ne?V.error(this.$t("seedream.message.usedUp")):V.error(this.$t("seedream.message.startTaskFailed")+(p?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function js(e,t,g,r,m,p){const f=n("config-panel"),h=n("recent-panel"),l=n("layout");return a(),E(l,null,{config:_(()=>[s(f,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[s(h,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const tt=y(Ps,[["render",js]]);export{tt as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
.menu[data-v-a7abbecc]{display:none}@media (max-width: 767px){.config[data-v-a7abbecc]{display:none}.result[data-v-a7abbecc]{width:100%}.menu[data-v-a7abbecc]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-8df4b8a7]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-8df4b8a7]{font-size:14px;margin:0;width:30%}.field .value[data-v-8df4b8a7]{width:160px}.field[data-v-81fd05e5]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-81fd05e5]{font-size:14px;margin:0;width:30%}.field .value[data-v-81fd05e5]{width:160px}.title[data-v-04710032]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-04710032]{position:absolute;top:5px;right:0}.upload-wrapper{height:auto;display:flex}.upload-wrapper .el-upload-list{margin:0;width:100%}.field .box[data-v-96df0218]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-96df0218]{font-size:14px;margin-bottom:10px}.field .info[data-v-96df0218]{margin-left:auto}.field .prompt[data-v-96df0218]{resize:none}.preview[data-v-779c5dda]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:10px}.preview .left[data-v-779c5dda]{width:70px}.preview .left .avatar[data-v-779c5dda]{width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-779c5dda]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-779c5dda]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-779c5dda]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-779c5dda]{font-size:16px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:15px}.preview .main .content[data-v-779c5dda]{word-break:break-word;overflow-wrap:anywhere}.preview .main .content .el-alert[data-v-779c5dda]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-779c5dda]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-779c5dda]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-779c5dda]{border-color:var(--el-color-info)}
|