@acedatacloud/nexior 3.19.5 → 3.20.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{Auth-BApRpHaD.js → Auth-DOHlOCpp.js} +1 -1
- package/dist/assets/{BotPlaceholder-C25LBTud.js → BotPlaceholder-6rksUZSI.js} +1 -1
- package/dist/assets/{Callback-BOomIDw_.js → Callback-D-v3hKrJ.js} +1 -1
- package/dist/assets/{Console-DDA6Us14.js → Console-CrfUOjRg.js} +1 -1
- package/dist/assets/{Conversation-BKStx3ph.js → Conversation-XjUVydTy.js} +2 -2
- package/dist/assets/{CopyToClipboard-O565qcMZ.js → CopyToClipboard-CuCD6yxS.js} +1 -1
- package/dist/assets/{Detail-BjYzPojU.js → Detail-CxUCYXrK.js} +1 -1
- package/dist/assets/{EditArray-wsYvsHgH.js → EditArray-DaAQ3MHX.js} +1 -1
- package/dist/assets/{Extra-Dn6HEhFL.js → Extra-CLOABQjS.js} +1 -1
- package/dist/assets/{FilePreview-BUXdYV1J.js → FilePreview-CMrAVI3v.js} +1 -1
- package/dist/assets/{History-BiFpOenA.js → History-9Wg3k27E.js} +1 -1
- package/dist/assets/{ImagePreview-p5_RqQz1.js → ImagePreview-BvPOSpDB.js} +1 -1
- package/dist/assets/{ImageWrapper-DgBKf-7i.js → ImageWrapper-BChXhEi0.js} +1 -1
- package/dist/assets/{Index-C4dUprj9.js → Index--bZdH1SJ.js} +1 -1
- package/dist/assets/Index-7uD3N-hm.js +1 -0
- package/dist/assets/{Index-DK8QOrp8.js → Index-8uOMoloz.js} +1 -1
- package/dist/assets/{Index-FtFL22Yu.js → Index-B4I-9GbD.js} +1 -1
- package/dist/assets/Index-B6HCk_-Z.js +1 -0
- package/dist/assets/{Index-Dw50fc02.js → Index-BwBHSzg_.js} +1 -1
- package/dist/assets/{Index-CMeLFd2i.js → Index-CHOFYqOJ.js} +1 -1
- package/dist/assets/{Index-Cx1bLmYc.js → Index-CNCj6VmF.js} +1 -1
- package/dist/assets/{Index-Und3gfGe.css → Index-Cj_OO_Dg.css} +1 -1
- package/dist/assets/{Index-C7FY8vWp.js → Index-DB7xg-db.js} +1 -1
- package/dist/assets/{Index-C7G4D4rU.js → Index-DEJ1F06G.js} +1 -1
- package/dist/assets/{Index--soNap8R.js → Index-DFfkrcKD.js} +1 -1
- package/dist/assets/{Index-D2EM-P6W.js → Index-DOZ1CpUV.js} +1 -1
- package/dist/assets/{Index-BTQIV-VG.js → Index-DXy4uUZ0.js} +1 -1
- package/dist/assets/{Index-BnNXwTpm.js → Index-DgcbnuJl.js} +1 -1
- package/dist/assets/{Index-Bk-71Dyx.js → Index-DpXxZAQT.js} +1 -1
- package/dist/assets/{Index-D3rYK-kQ.js → Index-DwVMjgEx.js} +1 -1
- package/dist/assets/Index-m5GlW6Tw.css +1 -0
- package/dist/assets/{InfoIcon-BflahWxT.js → InfoIcon-DhMpzlKc.js} +1 -1
- package/dist/assets/{Invitees-DDtdfdsf.js → Invitees-CbKt6RsF.js} +1 -1
- package/dist/assets/{List-C-cWj9Zm.js → List-D0u8ApAR.js} +1 -1
- package/dist/assets/{List-CllgcXw8.js → List-DPJxF9Uq.js} +1 -1
- package/dist/assets/{List--93vWmGM.js → List-Dzt1AZ5s.js} +1 -1
- package/dist/assets/{Login-D_K33c4c.js → Login-BiY_rvx8.js} +1 -1
- package/dist/assets/{Main-BMxlqG_i.js → Main-DzlsxIsf.js} +1 -1
- package/dist/assets/Navigator-DHP0Z5BQ.js +1 -0
- package/dist/assets/{Navigator-C3rJMxVO.css → Navigator-De_Hn2Tg.css} +1 -1
- package/dist/assets/{NoTasks-qn9MLJ-D.js → NoTasks-DmNkmZBC.js} +1 -1
- package/dist/assets/{Pagination-5sorAM0p.js → Pagination-CTJgfb9h.js} +1 -1
- package/dist/assets/{Status-B9WJzAMr.js → Status-BdMCij8k.js} +1 -1
- package/dist/assets/{Subscribe-CiBBgmJC.js → Subscribe-RBtMq5Tr.js} +1 -1
- package/dist/assets/{VideoPlayer-BuSo2dmw.js → VideoPlayer-D-xD0k0W.js} +1 -1
- package/dist/assets/{_baseClone-wpyOdoMw.js → _baseClone-CyEUgRjr.js} +1 -1
- package/dist/assets/_baseIteratee-LzESfPbZ.js +1 -0
- package/dist/assets/{_initCloneObject-D45zvZL4.js → _initCloneObject-DL2KWEpg.js} +1 -1
- package/dist/assets/{castArray-CD7UiqMH.js → castArray-BeCWKAC7.js} +1 -1
- package/dist/assets/{common-B-Kes038.js → common-B-Qxjf7a.js} +1 -1
- package/dist/assets/common-BOuvwX_b.js +1 -0
- package/dist/assets/common-BRjwL6pa.js +1 -0
- package/dist/assets/common-BVnCkBQz.js +1 -0
- package/dist/assets/common-BW4-7pr5.js +1 -0
- package/dist/assets/common-BYSAKW_E.js +1 -0
- package/dist/assets/common-BcVKm2id.js +1 -0
- package/dist/assets/common-CAhDeo7r.js +1 -0
- package/dist/assets/common-CDZVeYh0.js +1 -0
- package/dist/assets/common-CGJk5NFZ.js +1 -0
- package/dist/assets/common-CMHolxbL.js +1 -0
- package/dist/assets/common-Co44qVkD.js +1 -0
- package/dist/assets/common-Ctz14A_a.js +1 -0
- package/dist/assets/common-Cv4BeUYg.js +1 -0
- package/dist/assets/common-DWd2m1fH.js +1 -0
- package/dist/assets/{common-BnJo0QQf.js → common-DZLnkE8j.js} +1 -1
- package/dist/assets/common-DbbO-j2h.js +1 -0
- package/dist/assets/common-wugNzywt.js +1 -0
- package/dist/assets/debounce-kw1MDyXj.js +1 -0
- package/dist/assets/{distribution-DLQIXuAr.js → distribution-D-fO2s3O.js} +1 -1
- package/dist/assets/{dropdown-BRkQyul0.js → dropdown-C8jclX96.js} +1 -1
- package/dist/assets/{index-qsQaHqnG.js → index-1UJz5zRY.js} +1 -1
- package/dist/assets/{index-DejNZUW1.js → index-B0EB6NMl.js} +1 -1
- package/dist/assets/{index-CrIlM19Z.js → index-BC4WNM6T.js} +1 -1
- package/dist/assets/{index-BPEPCjAr.js → index-BDYxvVsV.js} +1 -1
- package/dist/assets/index-BKJPB7EB.js +1 -0
- package/dist/assets/{index-DnwCzjob.js → index-BNbrEyG8.js} +1 -1
- package/dist/assets/{index-BIdUwTxm.js → index-BQcaFqGZ.js} +1 -1
- package/dist/assets/index-BZbKTMK3.js +638 -0
- package/dist/assets/{index-b-O-kW2M.js → index-BxILNqsr.js} +1 -1
- package/dist/assets/{index-DEXuGCWk.js → index-C1h2SbZU.js} +1 -1
- package/dist/assets/{index-B4WsAi2n.js → index-CGS5ltjA.js} +1 -1
- package/dist/assets/{index-a0SM6Kgh.js → index-CNEDsR9Z.js} +1 -1
- package/dist/assets/{index-Cg6SscQL.js → index-CSXTF63q.js} +1 -1
- package/dist/assets/index-CZi_rDaW.js +1 -0
- package/dist/assets/index-CbPHeT3X.js +1 -0
- package/dist/assets/index-CgzNR6Br.js +1 -0
- package/dist/assets/{index-Du2C0qPs.js → index-CjhBlm5C.js} +1 -1
- package/dist/assets/{index-B5BZx-QW.js → index-Cu3La3dR.js} +1 -1
- package/dist/assets/index-D0cZ5BM8.js +1 -0
- package/dist/assets/{index-YvY81tTD.js → index-DSYfQpVb.js} +1 -1
- package/dist/assets/{index-DGn6WALK.js → index-N5_Xerc6.js} +1 -1
- package/dist/assets/index-Rl2p1NyF.js +1 -0
- package/dist/assets/{index-Bc66ZYjN.js → index-Tp13-pBQ.js} +1 -1
- package/dist/assets/index-bAhdShMo.js +1 -0
- package/dist/assets/{index-Bomkjuj5.js → index-hbRYKLdf.js} +2 -2
- package/dist/assets/index-hrpdMjUu.js +1 -0
- package/dist/assets/{index-DgNW2Ufv.js → index-jqOaitfg.js} +1 -1
- package/dist/assets/{index-B5je-JKn.js → index-oeBw24Ll.js} +2 -2
- package/dist/assets/{index-BGYIpMvx.js → index-yxRIEND6.js} +1 -1
- package/dist/assets/{index.es-D1pJr9hZ.js → index.es-B92faSi8.js} +1 -1
- package/dist/assets/{isEqual-B7zzcc8k.js → isEqual-DIgYivsv.js} +1 -1
- package/dist/assets/{isPlainObject-CiHedlzL.js → isPlainObject-DCVZiiY1.js} +1 -1
- package/dist/assets/{order-C-uzneCO.js → order-C2E-v9oK.js} +1 -1
- package/dist/assets/{price-BYVPw8Af.js → price-B8COZ-j4.js} +1 -1
- package/dist/assets/site-AMu-furx.js +1 -0
- package/dist/assets/site-B-S3bmIw.js +1 -0
- package/dist/assets/site-B5Cf-IAc.js +1 -0
- package/dist/assets/site-BAvle2_O.js +1 -0
- package/dist/assets/site-B_Ggyidz.js +1 -0
- package/dist/assets/site-Bt1bg9lM.js +1 -0
- package/dist/assets/site-C2z7Acri.js +1 -0
- package/dist/assets/site-C3DwWYe_.js +1 -0
- package/dist/assets/site-CfaiNsJJ.js +1 -0
- package/dist/assets/site-CgZJc3OO.js +1 -0
- package/dist/assets/site-DShO1dvg.js +1 -0
- package/dist/assets/site-Dp6QqWBj.js +1 -0
- package/dist/assets/site-DuhFEiWH.js +1 -0
- package/dist/assets/site-Jn4RON08.js +1 -0
- package/dist/assets/site-OiCS76HU.js +1 -0
- package/dist/assets/site-hdQfWIGT.js +1 -0
- package/dist/assets/site-kMOtpEid.js +1 -0
- package/dist/assets/site-lU9w5lDF.js +1 -0
- package/dist/assets/sora-BUK9FWzQ.js +1 -0
- package/dist/assets/sora-BYPH869l.js +1 -0
- package/dist/assets/sora-BizlIhBX.js +1 -0
- package/dist/assets/sora-BuJK8yHa.js +1 -0
- package/dist/assets/sora-C0mxa8Yl.js +1 -0
- package/dist/assets/sora-C0vUW0Q5.js +1 -0
- package/dist/assets/sora-C2FEi91g.js +1 -0
- package/dist/assets/sora-C7V5I_Pb.js +1 -0
- package/dist/assets/sora-C_FveR_7.js +1 -0
- package/dist/assets/sora-Cg7-ROqn.js +1 -0
- package/dist/assets/sora-Cit485eG.js +1 -0
- package/dist/assets/sora-CxWfpWIC.js +1 -0
- package/dist/assets/sora-DHmIEYHj.js +1 -0
- package/dist/assets/sora-DKDd9iHJ.js +1 -0
- package/dist/assets/sora-DZ6FBDO0.js +1 -0
- package/dist/assets/sora-DzK7LcnH.js +1 -0
- package/dist/assets/sora-O01RKgmW.js +1 -0
- package/dist/assets/sora-uQuccjMW.js +1 -0
- package/dist/assets/{strings-BmOP-I9J.js → strings-BQbdUIFn.js} +1 -1
- package/dist/assets/{typescript-CdgndEnB.js → typescript-CkR2OWnN.js} +1 -1
- package/dist/assets/use-form-item-9EKLSUpL.js +1 -0
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/Index-Ceh1Bj6j.js +0 -1
- package/dist/assets/Navigator-8gUjUKur.js +0 -1
- package/dist/assets/_baseIteratee-C4j1VLPq.js +0 -1
- package/dist/assets/common-B1CT0nx5.js +0 -1
- package/dist/assets/common-BiLnunSy.js +0 -1
- package/dist/assets/common-BqKhcEHM.js +0 -1
- package/dist/assets/common-CFu8wLKe.js +0 -1
- package/dist/assets/common-CM60LE2n.js +0 -1
- package/dist/assets/common-Cj_pecZS.js +0 -1
- package/dist/assets/common-Cmwe9HAn.js +0 -1
- package/dist/assets/common-CwicZZxg.js +0 -1
- package/dist/assets/common-D6A0AAnZ.js +0 -1
- package/dist/assets/common-D7RN05bO.js +0 -1
- package/dist/assets/common-DUW7yqJg.js +0 -1
- package/dist/assets/common-D_yfqJEE.js +0 -1
- package/dist/assets/common-DlqYECrk.js +0 -1
- package/dist/assets/common-DtjJT7B4.js +0 -1
- package/dist/assets/common-DxZG3_lc.js +0 -1
- package/dist/assets/common-rSu-vhZH.js +0 -1
- package/dist/assets/debounce-C_L6yTYD.js +0 -1
- package/dist/assets/index-6j6xERKd.js +0 -1
- package/dist/assets/index-BFgUesf6.js +0 -1
- package/dist/assets/index-Bn4hPGE1.js +0 -1
- package/dist/assets/index-BwlZ8hes.js +0 -1
- package/dist/assets/index-CCNe6ApW.js +0 -1
- package/dist/assets/index-CeLCECpN.js +0 -1
- package/dist/assets/index-DAvd6Xob.js +0 -1
- package/dist/assets/index-DWIIosE4.js +0 -638
- package/dist/assets/index-GcOzATQL.js +0 -1
- package/dist/assets/site-3pdyp_fh.js +0 -1
- package/dist/assets/site-A_Dn0Oo8.js +0 -1
- package/dist/assets/site-B2QEedu5.js +0 -1
- package/dist/assets/site-B6m8fncP.js +0 -1
- package/dist/assets/site-BTxYdZIx.js +0 -1
- package/dist/assets/site-BkmA_5RC.js +0 -1
- package/dist/assets/site-BseGdLjV.js +0 -1
- package/dist/assets/site-CSQVmOqj.js +0 -1
- package/dist/assets/site-CUmst9Yr.js +0 -1
- package/dist/assets/site-CdlQcwdy.js +0 -1
- package/dist/assets/site-D6zZL71f.js +0 -1
- package/dist/assets/site-DPRfn39_.js +0 -1
- package/dist/assets/site-DZDweJfv.js +0 -1
- package/dist/assets/site-DsuCJXb7.js +0 -1
- package/dist/assets/site-TtOC2WZY.js +0 -1
- package/dist/assets/site-mKlVSmQy.js +0 -1
- package/dist/assets/site-vPI7uegD.js +0 -1
- package/dist/assets/site-vTTA-m4z.js +0 -1
- package/dist/assets/use-form-item-B1Hr2fTx.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as I}from"./index.es-B92faSi8.js";import{E as S}from"./index-CgzNR6Br.js";import{E as P}from"./index-C1h2SbZU.js";import{d as $,h as g,b as i,t as l,k as t,r as U,j as f,l as s,o as a,eX as R,x as r,F as V,v as T,i as y,eY as D,eZ as F,c9 as B,D as h,y as x,n as C,e_ as O,du as M,dq as q}from"./index-BZbKTMK3.js";import{E as L,a as G}from"./index-BNbrEyG8.js";import{I as A}from"./InfoIcon-DhMpzlKc.js";import{E as N,a as z}from"./index-jqOaitfg.js";import{I as X}from"./ImagePreview-BvPOSpDB.js";import{E as H}from"./index-yxRIEND6.js";import{E as k}from"./index-hrpdMjUu.js";import{E as K}from"./index-DSYfQpVb.js";import{C as W,N as Y}from"./NoTasks-DmNkmZBC.js";import{a as Z}from"./price-B8COZ-j4.js";import{C as J}from"./CopyToClipboard-CuCD6yxS.js";import{I as Q}from"./ImageWrapper-BChXhEi0.js";import{E as ee}from"./index-D0cZ5BM8.js";import{E as te}from"./index-Cu3La3dR.js";import{B as oe}from"./BotPlaceholder-6rksUZSI.js";import"./use-form-item-9EKLSUpL.js";import"./index-r5W6hzzQ.js";import"./index-BDYxvVsV.js";import"./index-CZi_rDaW.js";import"./typescript-CkR2OWnN.js";import"./index-BKJPB7EB.js";import"./strings-BQbdUIFn.js";import"./castArray-BeCWKAC7.js";import"./isEqual-DIgYivsv.js";import"./_initCloneObject-DL2KWEpg.js";import"./debounce-kw1MDyXj.js";import"./_baseIteratee-LzESfPbZ.js";import"./index-Tp13-pBQ.js";import"./index-oeBw24Ll.js";import"./_baseClone-CyEUgRjr.js";import"./index-CjhBlm5C.js";import"./index-Rl2p1NyF.js";const se=$({name:"LayoutFlux",components:{ElDrawer:P,ElButton:S,FontAwesomeIcon:I},data(){return{drawer:!1}}}),ne={class:"main flex flex-row flex-1"},le={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},ae={class:"result h-full p-[15px] flex-1 flex flex-col"};function re(e,o,m,p,v,b){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),i("div",ne,[l("div",le,[U(e.$slots,"config",{},void 0,!0)]),l("div",ae,[U(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=d=>e.drawer=!0)},{default:f(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:f(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ie=g(se,[["render",re],["__scopeId","data-v-468dfa4e"]]),ce=$({name:"ModelSelector",components:{ElSelect:G,ElOption:L},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=R)}}),ue={class:"field"},de={class:"title font-bold"};function pe(e,o,m,p,v,b){const c=s("el-option"),u=s("el-select");return a(),i("div",ue,[l("h2",de,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,T(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const me=g(ce,[["render",pe],["__scopeId","data-v-8df4b8a7"]]),fe=$({name:"CountSelector",components:{ElSlider:z,InfoIcon:A,ElInputNumber:N},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=D)}}),_e={class:"flex justify-between"},he={class:"flex justify-start items-center"},$e={class:"text-sm font-bold"},ge={class:"flex justify-end items-center"},ve={class:"w-full"};function be(e,o,m,p,v,b){const c=s("info-icon"),u=s("el-input-number"),n=s("el-slider");return a(),i("div",null,[l("div",_e,[l("div",he,[l("span",$e,r(e.$t("flux.name.numbers")),1),t(c,{content:e.$t("flux.description.numbers")},null,8,["content"])]),l("div",ge,[t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=d=>e.value=d),"controls-position":"right"},null,8,["modelValue"])])]),l("div",ve,[t(n,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=d=>e.value=d),min:1,max:4,step:1},null,8,["modelValue"])])])}const xe=g(fe,[["render",be]]),we=$({name:"ActionSelector",components:{ElSelect:G,ElOption:L},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=F)}}),ke={class:"field"},ye={class:"title font-bold"};function Ve(e,o,m,p,v,b){const c=s("el-option"),u=s("el-select");return a(),i("div",ke,[l("h2",ye,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,T(e.options,n=>(a(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=g(we,[["render",Ve],["__scopeId","data-v-81fd05e5"]]),Ie=$({name:"ImageUrlInput",components:{ElUpload:H,ElButton:S,InfoIcon:A,FontAwesomeIcon:I,ImagePreview:X},emits:["change"],data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},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(){k.warning(this.$t("flux.message.uploadStartImageExceed"))},onError(){k.error(this.$t("flux.message.uploadStartImageError"))}}}),Te={class:"relative"},Ue={class:"flex justify-between"},Se={class:"flex justify-start items-center"},Ce={class:"text-sm font-bold"};function Ae(e,o,m,p,v,b){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),d=s("el-button"),w=s("el-upload");return a(),i("div",Te,[l("div",Ue,[l("div",Se,[l("span",Ce,r(e.$t("flux.name.imageUrl")),1),t(c,{content:e.$t("flux.description.imageUrl")},null,8,["content"])])]),t(w,{"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:E=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])]),default:f(()=>[t(d,{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 Le=g(Ie,[["render",Ae],["__scopeId","data-v-04710032"]]),Ge="",je=$({name:"PromptInput",components:{ElInput:K,InfoIcon:A},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=Ge)}}),Pe={class:"field"},Re={class:"box"},De={class:"title font-bold"};function Fe(e,o,m,p,v,b){const c=s("info-icon"),u=s("el-input");return a(),i("div",Pe,[l("div",Re,[l("h2",De,r(e.$t("flux.name.prompt")),1),t(c,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Be=g(je,[["render",Fe],["__scopeId","data-v-4c101a17"]]),Oe=$({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:I,PromptInput:Be,ModelSelector:me,CountSelector:xe,Consumption:W,ActionSelector:Ee,ImageUrlInput:Le},emits:["generate"],computed:{config(){return this.$store.state.flux?.config},consumption(){return Z(this.config,this.service?.metadata?.price)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Me={class:"flex flex-col h-full"},qe={class:"flex-1 overflow-y-auto p-[15px]"},Ne={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ze(e,o,m,p,v,b){const c=s("action-selector"),u=s("prompt-input"),n=s("image-url-input"),d=s("model-selector"),w=s("count-selector"),_=s("consumption"),E=s("font-awesome-icon"),j=s("el-button");return a(),i("div",Me,[l("div",qe,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),e.config?.action==="edits"?(a(),y(n,{key:0,class:"mb-4"})):x("",!0),t(d,{class:"mb-4"}),t(w,{class:"mb-4"})]),l("div",Ne,[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(E,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+r(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=g(Oe,[["render",ze]]),He=$({name:"TaskPreview",components:{ElImage:te,CopyToClipboard:J,FontAwesomeIcon:I,ElAlert:ee,ImageWrapper:Q},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 p=m;o&&(p.action=o),e.push(p)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Ke={class:"preview"},We={class:"left"},Ye={class:"main"},Ze={class:"bot"},Je={class:"datetime"},Qe={class:"info"},et={key:0,class:"prompt mt-2"},tt={key:0},ot={key:0,class:C({content:!0,failed:!0})},st={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},at={key:1,class:C({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},it={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ct={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ut={key:2,class:C({content:!0})},dt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function pt(e,o,m,p,v,b){const c=s("el-image"),u=s("image-wrapper"),n=s("font-awesome-icon"),d=s("copy-to-clipboard"),w=s("el-alert");return a(),i("div",Ke,[l("div",We,[t(c,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),l("div",Ye,[l("div",Ze,[h(r(e.$t("flux.name.fluxBot"))+" ",1),l("span",Je,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Qe,[e.modelValue?.request?.prompt?(a(),i("p",et,[h(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?x("",!0):(a(),i("span",tt," - ("+r(e.$t("flux.status.pending"))+") ",1))])):x("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",ot,[l("div",st,[(a(!0),i(V,null,T(e.images,(_,E)=>(a(),y(u,{key:E,src:_?.image_url,"raw-src":_?.image_url,"model-value":_},null,8,["src","raw-src","model-value"]))),128))]),t(w,{closable:!1,class:"mt-2 success"},{default:f(()=>[l("p",nt,[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",lt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(d,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):x("",!0),e.modelValue?.response?.success===!1?(a(),i("div",at,[t(w,{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",rt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(d,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",it,[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(d,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",ct,[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(d,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):x("",!0),e.modelValue?.response?x("",!0):(a(),i("div",ut,[t(w,{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",dt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(d,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const mt=g(He,[["render",pt],["__scopeId","data-v-fd5838a5"]]),ft=$({name:"RecentPanel",components:{TaskPreview:mt,BotPlaceholder:oe,NoTasks:Y},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),_t={key:0},ht={key:1,class:"tasks h-full w-full overflow-y-auto"},$t={key:2,class:"w-full h-full flex items-center justify-center"};function gt(e,o,m,p,v,b){const c=s("bot-placeholder"),u=s("task-preview"),n=s("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",_t,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),i("div",ht,[(a(!0),i(V,null,T(e.tasks?.items,d=>(a(),y(u,{key:d.id,"model-value":d},null,8,["model-value"]))),128))])):x("",!0),e.tasks?.items?.length===0?(a(),i("div",$t,[t(n)])):x("",!0)],64)}const vt=g(ft,[["render",gt]]),bt="https://webhook.acedata.cloud/flux",xt=$({name:"FluxIndex",components:{ConfigPanel:Xe,Layout:ie,RecentPanel:vt},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.flux?.status?.getApplications===q.Request},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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:p}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",p),await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:m,createdAtMax:p})},async onGenerate(){const e={...this.config,callback_url:bt},o=this.credential?.token;if(!o){console.error("no token specified");return}k.info(this.$t("flux.message.startingTask")),O.generate(e,{token:o}).then(()=>{k.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const p=m?.response?.data;p?.error?.code===M?k.error(this.$t("flux.message.usedUp")):k.error(this.$t("flux.message.startTaskFailed")+p?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function wt(e,o,m,p,v,b){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),y(n,null,{config:f(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:f(()=>[t(u,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const no=g(xt,[["render",wt]]);export{no as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as x}from"./index.es-D1pJr9hZ.js";import{E as K}from"./index-GcOzATQL.js";import{E as de}from"./index-DEXuGCWk.js";import{ak as pe,aq as me,bJ as fe,al as ae,ca as he,_ as _e,d as b,a as $e,am as ve,c as F,bi as ge,bo as ke,ax as le,b as h,o as l,i as w,r as U,f as oe,e as V,j as $,b9 as re,E as R,n as ye,g as we,h as E,t as r,k as s,l as c,eS as se,x as v,F as z,v as N,eT as H,c7 as be,D as I,eU as Y,eV as Q,y,J as X,cO as ee,eW as B,bS as Ce,dn as W,ai as P,eX as G,ao as Se,K as Ae,eY as Le,df as Ee,dm as Ve}from"./index-DWIIosE4.js";import{E as ce}from"./index-Bn4hPGE1.js";import{E as je,a as Fe}from"./index-DnwCzjob.js";import{I as M}from"./InfoIcon-BflahWxT.js";import{E as Te}from"./index-BGYIpMvx.js";import{E as L}from"./index-BFgUesf6.js";import{E as Z}from"./index-YvY81tTD.js";import{E as Pe,a as ue}from"./index-DgNW2Ufv.js";import{E as J}from"./index-B5BZx-QW.js";import{C as Ie,N as Ue}from"./NoTasks-qn9MLJ-D.js";import{a as ze}from"./price-BYVPw8Af.js";import{E as De,a as Re,b as Ge}from"./index-Cg6SscQL.js";import{E as Me}from"./index-BPEPCjAr.js";import{E as Oe}from"./index-DejNZUW1.js";import{E as Be,a as We}from"./index-DAvd6Xob.js";import"./use-form-item-B1Hr2fTx.js";import"./index-r5W6hzzQ.js";import"./index-6j6xERKd.js";import"./index-CCNe6ApW.js";import"./typescript-CdgndEnB.js";import"./strings-BmOP-I9J.js";import"./castArray-CD7UiqMH.js";import"./isEqual-B7zzcc8k.js";import"./_initCloneObject-D45zvZL4.js";import"./debounce-C_L6yTYD.js";import"./_baseIteratee-C4j1VLPq.js";import"./index-Bc66ZYjN.js";import"./index-B5je-JKn.js";import"./_baseClone-wpyOdoMw.js";import"./index-Du2C0qPs.js";import"./dropdown-BRkQyul0.js";const qe=pe({size:{type:[Number,String],values:he,default:"",validator:e=>ae(e)},shape:{type:String,values:["circle","square"],default:"circle"},icon:{type:fe},src:{type:String,default:""},alt:String,srcSet:String,fit:{type:me(String),default:"cover"}}),Ne={error:e=>e instanceof Event},He=b({name:"ElAvatar"}),xe=b({...He,props:qe,emits:Ne,setup(e,{emit:t}){const i=e,o=$e("avatar"),a=ve(!1),u=F(()=>{const{size:n,icon:m,shape:k}=i,f=[o.b()];return ge(n)&&f.push(o.m(n)),m&&f.push(o.m("icon")),k&&f.push(o.m(k)),f}),d=F(()=>{const{size:n}=i;return ae(n)?o.cssVarBlock({size:ke(n)||""}):void 0}),p=F(()=>({objectFit:i.fit}));le(()=>i.src,()=>a.value=!1);function _(n){a.value=!0,t("error",n)}return(n,m)=>(l(),h("span",{class:ye(V(u)),style:oe(V(d))},[(n.src||n.srcSet)&&!a.value?(l(),h("img",{key:0,src:n.src,alt:n.alt,srcset:n.srcSet,style:oe(V(p)),onError:_},null,44,["src","alt","srcset"])):n.icon?(l(),w(V(R),{key:1},{default:$(()=>[(l(),w(re(n.icon)))]),_:1})):U(n.$slots,"default",{key:2})],6))}});var Ke=_e(xe,[["__file","avatar.vue"]]);const Xe=we(Ke),Ze=b({name:"LayoutSuno",components:{ElDrawer:de,ElButton:K,FontAwesomeIcon:x},data(){return{drawer:!1,preview:!1}},computed:{}}),Je={class:"main flex flex-row flex-1"},Ye={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},Qe={class:"result h-full flex flex-col flex-1 border-r border-[var(--el-border-color)]"},et={class:"preview h-full w-[300px] flex flex-col"};function tt(e,t,i,o,a,u){const d=c("font-awesome-icon"),p=c("el-button"),_=c("el-drawer");return l(),h("div",Je,[r("div",Ye,[U(e.$slots,"config",{},void 0,!0)]),r("div",Qe,[U(e.$slots,"result",{},void 0,!0)]),r("div",et,[U(e.$slots,"preview",{},void 0,!0)]),s(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=n=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=n=>e.drawer=n),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ot=E(Ze,[["render",tt],["__scopeId","data-v-6cc632e5"]]),st=b({name:"VersionSelector",components:{ElSelect:Fe,ElOption:je,ElSwitch:ce},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("suno.model.model1"),value:"chirp-v2-xxl-alpha"},{label:this.$t("suno.model.model2"),value:"chirp-v3-0"},{label:this.$t("suno.model.model3"),value:"chirp-v3-5"},{label:this.$t("suno.model.model4"),value:"chirp-v4"},{label:this.$t("suno.model.model45"),value:"chirp-v4-5"},{label:this.$t("suno.model.model45plus"),value:"chirp-v4-5-plus"},{label:this.$t("suno.model.model5"),value:"chirp-v5"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){console.debug("set model",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(console.debug("set default type",se),this.model=se)}}),nt={class:"field"},it={class:"title font-bold"};function at(e,t,i,o,a,u){const d=c("el-switch"),p=c("el-option"),_=c("el-select");return l(),h("div",nt,[r("h2",it,v(e.$t("suno.name.type")),1),s(d,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=n=>e.custom=n),class:"value"},null,8,["modelValue"]),s(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=n=>e.model=n),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:$(()=>[(l(!0),h(z,null,N(e.options,n=>(l(),w(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const lt=E(st,[["render",at],["__scopeId","data-v-5ebe40d6"]]),rt=b({name:"UploadAudio",components:{ElUpload:Te,ElButton:K,InfoIcon:M,FontAwesomeIcon:x},emits:["change"],data(){return{fileList:[],uploadUrl:be()+"/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(){L.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){L.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},i=this.credential?.token;if(!i){console.error("no token specified");return}L.info(this.$t("suno.message.startingUploadAudio")),H.upload(t,{token:i}).then(o=>{console.debug("get upload music success",o.data);const a=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:a,action:"upload_extend"}),L.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{L.error(o?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),ct={class:"relative"},ut={class:"flex justify-between"},dt={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function mt(e,t,i,o,a,u){const d=c("info-icon"),p=c("font-awesome-icon"),_=c("el-button"),n=c("el-upload");return l(),h("div",ct,[r("div",ut,[r("div",dt,[r("span",pt,v(e.$t("suno.name.referenceAudios")),1),s(d,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),s(n,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),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:$(()=>[s(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:$(()=>[s(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+v(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ft=E(rt,[["render",mt],["__scopeId","data-v-6236152c"]]),ht="",_t=b({name:"PromptInput",components:{ElInput:Z,ElSwitch:ce,InfoIcon:M},data(){return{}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}},mounted(){this.prompt||(this.prompt=ht)}}),$t={class:"field"},vt={class:"box"},gt={class:"title-info"},kt={class:"title font-bold"},yt={class:"instrumental"},wt={class:"title inline-block"};function bt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-switch"),_=c("el-input");return l(),h("div",$t,[r("div",vt,[r("div",gt,[r("h2",kt,v(e.$t("suno.name.prompt")),1),s(d,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),r("div",yt,[s(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=n=>e.instrumental=n),class:"value mr-2"},null,8,["modelValue"]),r("h2",wt,v(e.$t("suno.name.instrumental")),1)])]),s(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ct=E(_t,[["render",bt],["__scopeId","data-v-d7004a7c"]]),St="",At=b({name:"LyricInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){console.debug("set lyric",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config}},mounted(){this.lyric||(this.lyric=St)}}),Lt={class:"field"},Et={class:"box"},Vt={class:"title font-bold"};function jt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Lt,[r("div",Et,[r("h2",Vt,v(e.$t("suno.name.lyrics")),1),s(d,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(l(),w(p,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(l(),w(p,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const Ft=E(At,[["render",jt],["__scopeId","data-v-99dfded8"]]),Tt=b({name:"StyleInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){console.debug("set style",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},config(){return this.$store.state.suno?.config}}}),Pt={class:"field"},It={class:"title-container"},Ut={class:"titlefont-bold"};function zt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Pt,[r("div",It,[r("h2",Ut,v(e.$t("suno.name.style")),1),s(d,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Dt=E(Tt,[["render",zt],["__scopeId","data-v-85bbfcaa"]]),Rt=b({name:"TitleInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){console.debug("set title",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}}}),Gt={class:"field"},Mt={class:"title-container"},Ot={class:"title font-bold"};function Bt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Gt,[r("div",Mt,[r("h2",Ot,v(e.$t("suno.name.title")),1),s(d,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Wt=E(Rt,[["render",Bt],["__scopeId","data-v-ce70fe34"]]);function D(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const i=e%60,o=i<10?`0${i}`:i,a=t<10?`0${t}`:t;return o+":"+a}const qt=b({name:"ExtendFromInput",components:{ElImage:J,ElIcon:R,ElInputNumber:Pe,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:D,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})}}}),Nt={class:"field"},Ht={class:"box"},xt={class:"title font-bold"},Kt={class:"input-wrapper"},Xt={class:"task"},Zt={class:"left"},Jt={key:2,class:"duration"},Yt={class:"info"},Qt={class:"title"},eo={class:"style"};function to(e,t,i,o,a,u){const d=c("el-input-number"),p=c("el-image"),_=c("video-pause"),n=c("el-icon"),m=c("video-play"),k=ee("loading");return l(),h("div",Nt,[r("div",Ht,[r("h2",xt,v(e.$t("suno.name.extend")),1),r("div",Kt,[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"])])]),r("div",Xt,[e.audio?(l(),h("div",{key:0,class:"audio",onClick:t[3]||(t[3]=f=>e.onClick(e.audio))},[X((l(),h("div",Zt,[s(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(l(),h("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=f=>e.onPause(e.audio))},[s(n,null,{default:$(()=>[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")?(l(),h("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=f=>e.onPlay(e.audio))},[s(n,null,{default:$(()=>[s(m)]),_:1})])):y("",!0),e.audio?.duration?(l(),h("div",Jt,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[k,!e.audio?.audio_url]]),r("div",Yt,[r("h2",Qt,v(e.audio?.title),1),r("p",eo,v(e.audio?.style),1)])])):y("",!0)])])}const oo=E(qt,[["render",to],["__scopeId","data-v-bcce4821"]]),so=b({name:"CoverFromInput",components:{ElImage:J,ElIcon:R,VideoPlay:Q,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:D,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})}}}),no={class:"field"},io={class:"box"},ao={class:"title font-bold"},lo={class:"task"},ro={class:"left"},co={key:2,class:"duration"},uo={class:"info"},po={class:"title"},mo={class:"style"};function fo(e,t,i,o,a,u){const d=c("el-image"),p=c("video-pause"),_=c("el-icon"),n=c("video-play"),m=ee("loading");return l(),h("div",no,[r("div",io,[r("h2",ao,v(e.$t("suno.name.cover")),1)]),r("div",lo,[e.audio?(l(),h("div",{key:0,class:"audio",onClick:t[2]||(t[2]=k=>e.onClick(e.audio))},[X((l(),h("div",ro,[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"?(l(),h("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=k=>e.onPause(e.audio))},[s(_,null,{default:$(()=>[s(p)]),_: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")?(l(),h("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPlay(e.audio))},[s(_,null,{default:$(()=>[s(n)]),_:1})])):y("",!0),e.audio?.duration?(l(),h("div",co,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[m,!e.audio?.audio_url]]),r("div",uo,[r("h2",po,v(e.audio?.title),1),r("p",mo,v(e.audio?.style),1)])])):y("",!0)])])}const ho=E(so,[["render",fo],["__scopeId","data-v-06640216"]]),_o=b({name:"PresetPanel",components:{TypeSelector:lt,PromptInput:Ct,LyricInput:Ft,StyleInput:Dt,TitleInput:Wt,ExtendFromInput:oo,CoverFromInput:ho,UploadAudio:ft,FontAwesomeIcon:x,ElButton:K,Consumption:Ie},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return ze(this.config,this.service?.metadata?.price)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),$o={class:"flex flex-col h-full"},vo={class:"flex-1 overflow-y-auto p-[15px]"},go={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ko(e,t,i,o,a,u){const d=c("type-selector"),p=c("upload-audio"),_=c("prompt-input"),n=c("lyric-input"),m=c("style-input"),k=c("title-input"),f=c("extend-from-input"),C=c("cover-from-input"),j=c("consumption"),T=c("font-awesome-icon"),A=c("el-button");return l(),h("div",$o,[r("div",vo,[s(d,{class:"mb-4"}),s(p,{class:"mb-4"}),e.config?.custom?y("",!0):(l(),w(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(l(),w(n,{key:1,class:"mb-4"})):y("",!0),e.config?.custom?(l(),w(m,{key:2,class:"mb-4"})):y("",!0),e.config?.custom?(l(),w(k,{key:3,class:"mb-4"})):y("",!0),e.config?.action==="extend"?(l(),w(f,{key:4,class:"mb-4"})):y("",!0),e.config?.action==="cover"?(l(),w(C,{key:5,class:"mb-4"})):y("",!0)]),r("div",go,[s(j,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(l(),w(A,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+v(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(l(),w(A,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+v(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const yo=E(_o,[["render",ko],["__scopeId","data-v-b9fab929"]]);var q={exports:{}},wo=q.exports,ne;function bo(){return ne||(ne=1,function(e,t){(function(i,o){o()})(wo,function(){function i(n,m){return typeof m>"u"?m={autoBom:!1}:typeof m!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),m={autoBom:!m}),m.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(n.type)?new Blob(["\uFEFF",n],{type:n.type}):n}function o(n,m,k){var f=new XMLHttpRequest;f.open("GET",n),f.responseType="blob",f.onload=function(){_(f.response,m,k)},f.onerror=function(){console.error("could not download file")},f.send()}function a(n){var m=new XMLHttpRequest;m.open("HEAD",n,!1);try{m.send()}catch{}return 200<=m.status&&299>=m.status}function u(n){try{n.dispatchEvent(new MouseEvent("click"))}catch{var m=document.createEvent("MouseEvents");m.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),n.dispatchEvent(m)}}var d=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof B=="object"&&B.global===B?B:void 0,p=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&&!p?function(n,m,k){var f=d.URL||d.webkitURL,C=document.createElement("a");m=m||n.name||"download",C.download=m,C.rel="noopener",typeof n=="string"?(C.href=n,C.origin===location.origin?u(C):a(C.href)?o(n,m,k):u(C,C.target="_blank")):(C.href=f.createObjectURL(n),setTimeout(function(){f.revokeObjectURL(C.href)},4e4),setTimeout(function(){u(C)},0))}:"msSaveOrOpenBlob"in navigator?function(n,m,k){if(m=m||n.name||"download",typeof n!="string")navigator.msSaveOrOpenBlob(i(n,k),m);else if(a(n))o(n,m,k);else{var f=document.createElement("a");f.href=n,f.target="_blank",setTimeout(function(){u(f)})}}:function(n,m,k,f){if(f=f||open("","_blank"),f&&(f.document.title=f.document.body.innerText="downloading..."),typeof n=="string")return o(n,m,k);var C=n.type==="application/octet-stream",j=/constructor/i.test(d.HTMLElement)||d.safari,T=/CriOS\/[\d]+/.test(navigator.userAgent);if((T||C&&j||p)&&typeof FileReader<"u"){var A=new FileReader;A.onloadend=function(){var S=A.result;S=T?S:S.replace(/^data:[^;]*;/,"data:attachment/file;"),f?f.location.href=S:location=S,f=null},A.readAsDataURL(n)}else{var O=d.URL||d.webkitURL,g=O.createObjectURL(n);f?f.location=g:location.href=g,f=null,setTimeout(function(){O.revokeObjectURL(g)},4e4)}});d.saveAs=_.saveAs=_,e.exports=_})}(q)),q.exports}var Co=bo();const So="https://webhook.acedata.cloud/suno",Ao=b({name:"TaskPreview",components:{ElImage:J,ElIcon:R,ElTooltip:Me,ElButton:K,FontAwesomeIcon:x,VideoPlay:Q,VideoPause:Y,ElDropdown:Ge,ElDropdownMenu:Re,ElDropdownItem:De,Loading:Ce},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===W.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(i=>({...i,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:D,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,a=o.substring(o.lastIndexOf("/")+1);console.log("on preview",a),fetch(t).then(u=>u.blob()).then(u=>{Co.saveAs(u,a)})},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),L.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,i)=>{const o={audio_id:e},a=this.credential?.token;if(!a){console.error("no token specified"),i(new Error("No token specified"));return}H.mp4(o,{token:a}).then(u=>{const d=u.data?.data?.video_url;d?t(d):i(new Error("Video URL not found in response"))}).catch(u=>{i(u)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onGenerateAudioUrl(e,t){const i={action:e,audio_id:t,callback_url:So},o=this.credential?.token;if(!o){console.error("no token specified");return}L.info(this.$t("suno.message.startingTask")),H.audio(i,{token:o}).then(()=>{L.success(this.$t("suno.message.startTaskSuccess"))}).catch(a=>{L.error(a?.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})}}}),Lo={class:"task"},Eo=["onClick"],Vo={class:"left"},jo=["onClick"],Fo=["onClick"],To={key:2,class:"duration"},Po={class:"info"},Io={class:"title"},Uo={class:"style"},zo={class:"right"},Do={class:"el-dropdown-link"},Ro={class:"flex items-center min-w-[120px]"},Go={class:"el-dropdown-link"};function Mo(e,t,i,o,a,u){const d=c("el-image"),p=c("video-pause"),_=c("el-icon"),n=c("video-play"),m=c("el-button"),k=c("font-awesome-icon"),f=c("el-tooltip"),C=c("Loading"),j=c("el-dropdown-item"),T=c("el-dropdown-menu"),A=c("el-dropdown"),O=ee("loading");return l(),h("div",Lo,[(l(!0),h(z,null,N(e.audios,g=>(l(),h("div",{key:g.id,class:"audio",onClick:P(S=>e.onClick(g),["stop"])},[X((l(),h("div",Vo,[s(d,{src:g?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),g?.audio_url&&e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="playing"?(l(),h("div",{key:0,class:"overlay",onClick:P(S=>e.onPause(g),["stop"])},[s(_,null,{default:$(()=>[s(p)]),_:1})],8,jo)):y("",!0),g?.audio_url&&(e.$store.state?.suno?.audio?.id!==g.id||e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="paused")?(l(),h("div",{key:1,class:"overlay",onClick:P(S=>e.onPlay(g),["stop"])},[s(_,null,{default:$(()=>[s(n)]),_:1})],8,Fo)):y("",!0),g?.duration?(l(),h("div",To,v(e.useFormatDuring(g?.duration)),1)):y("",!0)])),[[O,!g?.audio_url]]),r("div",Po,[r("h2",Io,v(g?.title),1),r("p",Uo,v(g?.style),1)]),r("div",zo,[g?.audio_url?(l(),w(m,{key:0,size:"small",round:"",onClick:P(S=>e.onExtend(S,g),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):y("",!0),s(A,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[s(j,{disabled:e.isFetchingVideoUrl,onClick:S=>e.handleVideoDownload(g)},{default:$(()=>[r("div",Ro,[e.isFetchingVideoUrl?(l(),w(_,{key:0,class:"is-loading mr-2"},{default:$(()=>[s(C)]),_:1})):y("",!0),r("span",null,v(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),g?.audio_url?(l(),w(j,{key:0,onClick:P(S=>e.onDownload(S,g?.audio_url),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[r("span",Do,[s(f,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(l(),w(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(A,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g.id?(l(),w(j,{key:0,onClick:P(S=>e.onGetStems(g.id),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):y("",!0),s(j,{onClick:P(S=>e.onCover(g),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),g?.id&&g?.action==="extend"?(l(),w(j,{key:1,onClick:P(S=>e.onConcatMusic(g?.id),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[r("span",Go,[s(f,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(l(),w(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,Eo))),128))])}const Oo=E(Ao,[["render",Mo]]),Bo={class:"player-slider"},Wo=b({__name:"PlayerSlider",setup(e){const t=G(),i=F({get:()=>t.state.suno?.audio?.progress,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:d})}),o=F({get:()=>t.state.suno?.audio?.duration,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:d})}),a=()=>{},u=d=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:d});return(d,p)=>(l(),h("div",Bo,[s(V(ue),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=_=>i.value=_),"show-tooltip":!1,min:0,max:o.value,onChange:u,onInput:a},null,8,["modelValue","max"])]))}}),qo="/assets/disk-XFRmVAfp.png",No={class:"flex player-song"},Ho=["src"],xo={class:"ml-2 text-xs flex flex-col justify-between"},Ko={class:"w-52 2xl:w-96 cursor-pointer truncate"},Xo={class:"flex"},Zo={class:"ml-2 text-dc"},Jo=b({__name:"PlayerSong",setup(e){const t=G(),i=F({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return le(i,(o,a)=>{if(o?.audio_url!==a?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const u=new Audio(o.audio_url);o.state==="playing"?u.play():u.pause(),u.addEventListener("loadedmetadata",()=>{u.currentTime=0,u.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:u.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:u})}else if(o?.progress!==a?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const u=t.state.suno.audio;u.object&&(u.object.currentTime=u.progress)}else o?.state!==a?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==a?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,a)=>(l(),h("div",No,[r("img",{alt:"",class:"w-11 h-11 rounded",src:i.value?.image_url||V(qo)},null,8,Ho),r("div",xo,[r("div",Ko,[r("div",Xo,[r("span",null,v(i.value?.title||"Music"),1),r("span",Zo,"- "+v(i.value?.style||"SmallRuralDog"),1)])])])]))}}),Yo={class:"flex justify-end items-center gap-x-2.5"},Qo={class:"text-xs"},es=b({__name:"PlayerAction",setup(e){const t=G(),i=F({get:()=>t.state.suno?.audio?.progress,set:a=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:a})}),o=F({get:()=>t.state.suno?.audio?.duration,set:a=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:a})});return(a,u)=>(l(),h("div",Yo,[r("span",Qo,v(V(D)(i.value))+" / "+v(V(D)(o.value)),1)]))}});var ts={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 os(){return"icon-"+((1+Math.random())*4294967296|0).toString(16).substring(1)}function ss(e,t,i){var o=typeof t.fill=="string"?[t.fill]:t.fill||[],a=[],u=t.theme||i.theme;switch(u){case"outline":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("none"),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("none");break;case"filled":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("#FFF"),a.push("#FFF");break;case"two-tone":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone);break;case"multi-color":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.multiColor.outFillColor),a.push(typeof o[2]=="string"?o[2]:i.colors.multiColor.innerStrokeColor),a.push(typeof o[3]=="string"?o[3]:i.colors.multiColor.innerFillColor);break}return{size:t.size||i.size,strokeWidth:t.strokeWidth||i.strokeWidth,strokeLinecap:t.strokeLinecap||i.strokeLinecap,strokeLinejoin:t.strokeLinejoin||i.strokeLinejoin,colors:a,id:e}}var ns=Symbol("icon-context");function te(e,t,i){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(u){var d=os(),p=Se(ns,ts);return function(){var _=u.size,n=u.strokeWidth,m=u.strokeLinecap,k=u.strokeLinejoin,f=u.theme,C=u.fill,j=u.spin,T=ss(d,{size:_,strokeWidth:n,strokeLinecap:m,strokeLinejoin:k,theme:f,fill:C},p),A=[p.prefix+"-icon"];return A.push(p.prefix+"-icon-"+e),t&&p.rtl&&A.push(p.prefix+"-icon-rtl"),j&&A.push(p.prefix+"-icon-spin"),s("span",{class:A.join(" ")},[i(T)])}}};return o}const is=te("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)])}),as=te("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)])}),ls=te("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)])}),ie=b({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,i)=>(l(),w(re(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"]))}}),rs={class:"player-volume flex flex-col items-center pt-2"},cs={class:"text-sm mt-3"},us=b({__name:"PlayerVolumeSlider",setup(e){const t=G(),i=F({get:()=>t.state.suno.audio?.volume,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:u})}),o=F({get:()=>t.state.suno.audio?.muted,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:u})}),a=u=>t.dispatch("suno/setVolume",u);return(u,d)=>(l(),h("div",rs,[s(V(ue),{modelValue:i.value,"onUpdate:modelValue":d[0]||(d[0]=p=>i.value=p),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:a},null,8,["modelValue","disabled"]),r("div",cs,v(i.value),1)]))}}),ds={class:"flex items-center justify-center gap-x-3"},ps=b({__name:"PlayerController",setup(e){const t=G(),i=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=F(()=>t.state.suno.audio);return(a,u)=>(l(),h("div",ds,[s(ie,{icon:o.value?.state==="playing"?V(is):V(as),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:i},null,8,["icon"]),s(V(Oe),{placement:"top",width:"50px",trigger:"click"},{reference:$(()=>[s(ie,{icon:V(ls),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:$(()=>[s(us)]),_:1})]))}}),ms={class:"flex flex-col items-stretch h-20"},fs={class:"flex grow px-5 items-center"},hs={class:"flex-1"},_s={class:"flex-1"},$s={class:"flex-1"},vs=b({__name:"Player",setup(e){return(t,i)=>(l(),h("div",ms,[s(Wo),r("div",fs,[r("div",hs,[s(Jo)]),r("div",_s,[s(ps)]),r("div",$s,[s(es)])])]))}}),gs=b({name:"RecentPanel",components:{ElSkeletonItem:We,ElSkeleton:Be,TaskPreview:Oo,Player:vs,NoTasks:Ue},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),ks={key:0,class:"tasks"},ys={class:"left w-[70px] p-[10px] flex items-center"},ws={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},bs={key:2,class:"w-full flex-1 flex items-center justify-center"},Cs={class:"h-20"};function Ss(e,t,i,o,a,u){const d=c("el-skeleton-item"),p=c("el-skeleton"),_=c("task-preview"),n=c("no-tasks"),m=c("player");return l(),h(z,null,[e.tasks?.items===void 0?(l(),h("div",ks,[(l(),h(z,null,N(3,k=>r("div",{key:k,class:"flex"},[r("div",ys,[s(p,{animated:""},{template:$(()=>[s(d,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),r("div",ws,[s(p,{animated:""},{template:$(()=>[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?(l(),h("div",{key:1,class:"flex-1 w-full overflow-y-auto tasks p-2",onScroll:t[0]||(t[0]=(...k)=>e.onHandleScroll&&e.onHandleScroll(...k))},[(l(!0),h(z,null,N(e.tasks?.items,(k,f)=>(l(),w(_,{key:f,"model-value":k,class:"preview"},null,8,["model-value"]))),128))],32)):y("",!0),e.tasks?.items?.length===0?(l(),h("div",bs,[s(n)])):y("",!0),X(r("div",Cs,[s(m)],512),[[Ae,!!e.$store?.state?.suno?.audio?.object]])],64)}const As=E(gs,[["render",Ss]]),Ls=b({name:"TaskPreview",components:{IconPicture:Le,ElImage:J,ElAvatar:Xe,ElIcon:R},computed:{audio(){return this.$store.state.suno?.audio}}}),Es={key:0,class:"size-full overflow-hidden"},Vs={class:"relative h-[300px]"},js={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Fs={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"},Ts={class:"p-4"},Ps={class:"flex items-center font-bold mb-2"},Is={class:"text-[var(--el-text-color-regular)] mb-2"},Us={class:"text-xs text-[var(--el-text-color-regular)]"},zs={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Ds={key:1,class:"w-full h-full"};function Rs(e,t,i,o,a,u){const d=c("icon-picture"),p=c("el-icon"),_=c("el-image"),n=c("el-avatar");return e.audio?.object?(l(),h("div",Es,[r("div",Vs,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:$(()=>[r("div",js,[s(p,{class:"text-3xl"},{default:$(()=>[s(d)]),_:1})])]),_:1},8,["src"]),r("h2",Fs,v(e.audio?.title),1)]),r("div",Ts,[r("div",Ps,[s(n,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),r("span",null,v(e.audio?.title),1)]),r("p",Is,v(e.audio?.style),1),r("p",Us,v(e.$dayjs.format(e.audio?.created_at)),1),r("div",zs,[r("p",null,v(e.audio?.lyric),1)])])])):(l(),h("div",Ds))}const Gs=E(Ls,[["render",Rs]]),Ms="https://webhook.acedata.cloud/suno",Os=b({name:"SunoIndex",components:{Layout:ot,ConfigPanel:yo,RecentPanel:As,PreviewPanel:Gs},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===W.Request},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===W.Request},needApply(){return this.$store.state.suno.status.getApplications===W.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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,L.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ve&&L.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:i,createdAtMax:o}=e||{};console.debug("limit",t,"createdAtMin",i,"createdAtMax",o),await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:i,createdAtMax:o})},async onGenerateAudio(){const e={...this.config,callback_url:Ms},t=this.credential?.token;if(!t){console.error("no token specified");return}L.info(this.$t("suno.message.startingTask")),H.audio(e,{token:t}).then(()=>{L.success(this.$t("suno.message.startTaskSuccess"))}).catch(i=>{L.error(i?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Bs(e,t,i,o,a,u){const d=c("config-panel"),p=c("recent-panel"),_=c("preview-panel"),n=c("layout");return l(),w(n,null,{config:$(()=>[s(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:$(()=>[s(p,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),preview:$(()=>[s(_)]),_:1})}const Cn=E(Os,[["render",Bs],["__scopeId","data-v-f5721d95"]]);export{Cn as default};
|
|
1
|
+
import{F as K}from"./index.es-B92faSi8.js";import{E as Z}from"./index-CgzNR6Br.js";import{E as de}from"./index-C1h2SbZU.js";import{am as pe,as as me,bL as fe,an as ae,cc as he,_ as _e,d as b,a as $e,ao as ve,c as F,bk as ge,bq as ke,az as le,b as h,o as l,i as w,r as U,f as oe,e as V,j as $,bb as re,E as R,n as ye,g as we,h as E,t as r,k as s,l as c,f2 as se,x as v,F as z,v as N,f3 as H,c9 as be,D as I,f4 as Q,f5 as Y,y,J as x,cQ as ee,f6 as B,bU as Ce,dq as q,ak as P,f7 as G,aq as Se,K as Ae,f8 as Le,dh as Ee,dp as Ve}from"./index-BZbKTMK3.js";import{E as ce}from"./index-CbPHeT3X.js";import{E as je,a as Fe}from"./index-BNbrEyG8.js";import{I as M}from"./InfoIcon-DhMpzlKc.js";import{E as Te}from"./index-yxRIEND6.js";import{E as L}from"./index-hrpdMjUu.js";import{E as X}from"./index-DSYfQpVb.js";import{E as Pe,a as ue}from"./index-jqOaitfg.js";import{E as J}from"./index-Cu3La3dR.js";import{C as Ie,N as Ue}from"./NoTasks-DmNkmZBC.js";import{a as ze}from"./price-B8COZ-j4.js";import{E as De,a as Re,b as Ge}from"./index-CSXTF63q.js";import{E as Me}from"./index-BDYxvVsV.js";import{E as Oe}from"./index-B0EB6NMl.js";import{E as Be,a as qe}from"./index-Rl2p1NyF.js";import"./use-form-item-9EKLSUpL.js";import"./index-r5W6hzzQ.js";import"./index-CZi_rDaW.js";import"./index-BKJPB7EB.js";import"./typescript-CkR2OWnN.js";import"./strings-BQbdUIFn.js";import"./castArray-BeCWKAC7.js";import"./isEqual-DIgYivsv.js";import"./_initCloneObject-DL2KWEpg.js";import"./debounce-kw1MDyXj.js";import"./_baseIteratee-LzESfPbZ.js";import"./index-Tp13-pBQ.js";import"./index-oeBw24Ll.js";import"./_baseClone-CyEUgRjr.js";import"./index-CjhBlm5C.js";import"./dropdown-C8jclX96.js";const We=pe({size:{type:[Number,String],values:he,default:"",validator:e=>ae(e)},shape:{type:String,values:["circle","square"],default:"circle"},icon:{type:fe},src:{type:String,default:""},alt:String,srcSet:String,fit:{type:me(String),default:"cover"}}),Ne={error:e=>e instanceof Event},He=b({name:"ElAvatar"}),Ke=b({...He,props:We,emits:Ne,setup(e,{emit:t}){const i=e,o=$e("avatar"),a=ve(!1),u=F(()=>{const{size:n,icon:m,shape:k}=i,f=[o.b()];return ge(n)&&f.push(o.m(n)),m&&f.push(o.m("icon")),k&&f.push(o.m(k)),f}),d=F(()=>{const{size:n}=i;return ae(n)?o.cssVarBlock({size:ke(n)||""}):void 0}),p=F(()=>({objectFit:i.fit}));le(()=>i.src,()=>a.value=!1);function _(n){a.value=!0,t("error",n)}return(n,m)=>(l(),h("span",{class:ye(V(u)),style:oe(V(d))},[(n.src||n.srcSet)&&!a.value?(l(),h("img",{key:0,src:n.src,alt:n.alt,srcset:n.srcSet,style:oe(V(p)),onError:_},null,44,["src","alt","srcset"])):n.icon?(l(),w(V(R),{key:1},{default:$(()=>[(l(),w(re(n.icon)))]),_:1})):U(n.$slots,"default",{key:2})],6))}});var Ze=_e(Ke,[["__file","avatar.vue"]]);const xe=we(Ze),Xe=b({name:"LayoutSuno",components:{ElDrawer:de,ElButton:Z,FontAwesomeIcon:K},data(){return{drawer:!1,preview:!1}},computed:{}}),Je={class:"main flex flex-row flex-1"},Qe={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},Ye={class:"result h-full flex flex-col flex-1 border-r border-[var(--el-border-color)]"},et={class:"preview h-full w-[300px] flex flex-col"};function tt(e,t,i,o,a,u){const d=c("font-awesome-icon"),p=c("el-button"),_=c("el-drawer");return l(),h("div",Je,[r("div",Qe,[U(e.$slots,"config",{},void 0,!0)]),r("div",Ye,[U(e.$slots,"result",{},void 0,!0)]),r("div",et,[U(e.$slots,"preview",{},void 0,!0)]),s(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=n=>e.drawer=!0)},{default:$(()=>[s(d,{icon:"fa-solid fa-magic"})]),_:1}),s(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=n=>e.drawer=n),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ot=E(Xe,[["render",tt],["__scopeId","data-v-6cc632e5"]]),st=b({name:"VersionSelector",components:{ElSelect:Fe,ElOption:je,ElSwitch:ce},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("suno.model.model1"),value:"chirp-v2-xxl-alpha"},{label:this.$t("suno.model.model2"),value:"chirp-v3-0"},{label:this.$t("suno.model.model3"),value:"chirp-v3-5"},{label:this.$t("suno.model.model4"),value:"chirp-v4"},{label:this.$t("suno.model.model45"),value:"chirp-v4-5"},{label:this.$t("suno.model.model45plus"),value:"chirp-v4-5-plus"},{label:this.$t("suno.model.model5"),value:"chirp-v5"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){console.debug("set model",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(console.debug("set default type",se),this.model=se)}}),nt={class:"field"},it={class:"title font-bold"};function at(e,t,i,o,a,u){const d=c("el-switch"),p=c("el-option"),_=c("el-select");return l(),h("div",nt,[r("h2",it,v(e.$t("suno.name.type")),1),s(d,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=n=>e.custom=n),class:"value"},null,8,["modelValue"]),s(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=n=>e.model=n),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:$(()=>[(l(!0),h(z,null,N(e.options,n=>(l(),w(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const lt=E(st,[["render",at],["__scopeId","data-v-5ebe40d6"]]),rt=b({name:"UploadAudio",components:{ElUpload:Te,ElButton:Z,InfoIcon:M,FontAwesomeIcon:K},emits:["change"],data(){return{fileList:[],uploadUrl:be()+"/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(){L.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){L.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},i=this.credential?.token;if(!i){console.error("no token specified");return}L.info(this.$t("suno.message.startingUploadAudio")),H.upload(t,{token:i}).then(o=>{console.debug("get upload music success",o.data);const a=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:a,action:"upload_extend"}),L.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{L.error(o?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),ct={class:"relative"},ut={class:"flex justify-between"},dt={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function mt(e,t,i,o,a,u){const d=c("info-icon"),p=c("font-awesome-icon"),_=c("el-button"),n=c("el-upload");return l(),h("div",ct,[r("div",ut,[r("div",dt,[r("span",pt,v(e.$t("suno.name.referenceAudios")),1),s(d,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),s(n,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),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:$(()=>[s(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:$(()=>[s(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+v(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ft=E(rt,[["render",mt],["__scopeId","data-v-6236152c"]]),ht="",_t=b({name:"PromptInput",components:{ElInput:X,ElSwitch:ce,InfoIcon:M},data(){return{}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}},mounted(){this.prompt||(this.prompt=ht)}}),$t={class:"field"},vt={class:"box"},gt={class:"title-info"},kt={class:"title font-bold"},yt={class:"instrumental"},wt={class:"title inline-block"};function bt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-switch"),_=c("el-input");return l(),h("div",$t,[r("div",vt,[r("div",gt,[r("h2",kt,v(e.$t("suno.name.prompt")),1),s(d,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),r("div",yt,[s(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=n=>e.instrumental=n),class:"value mr-2"},null,8,["modelValue"]),r("h2",wt,v(e.$t("suno.name.instrumental")),1)])]),s(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ct=E(_t,[["render",bt],["__scopeId","data-v-d7004a7c"]]),St="",At=b({name:"LyricInput",components:{ElInput:X,InfoIcon:M},data(){return{}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){console.debug("set lyric",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config}},mounted(){this.lyric||(this.lyric=St)}}),Lt={class:"field"},Et={class:"box"},Vt={class:"title font-bold"};function jt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Lt,[r("div",Et,[r("h2",Vt,v(e.$t("suno.name.lyrics")),1),s(d,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(l(),w(p,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(l(),w(p,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const Ft=E(At,[["render",jt],["__scopeId","data-v-99dfded8"]]),Tt=b({name:"StyleInput",components:{ElInput:X,InfoIcon:M},data(){return{}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){console.debug("set style",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},config(){return this.$store.state.suno?.config}}}),Pt={class:"field"},It={class:"title-container"},Ut={class:"titlefont-bold"};function zt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Pt,[r("div",It,[r("h2",Ut,v(e.$t("suno.name.style")),1),s(d,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Dt=E(Tt,[["render",zt],["__scopeId","data-v-85bbfcaa"]]),Rt=b({name:"TitleInput",components:{ElInput:X,InfoIcon:M},data(){return{}},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){console.debug("set title",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}}}),Gt={class:"field"},Mt={class:"title-container"},Ot={class:"title font-bold"};function Bt(e,t,i,o,a,u){const d=c("info-icon"),p=c("el-input");return l(),h("div",Gt,[r("div",Mt,[r("h2",Ot,v(e.$t("suno.name.title")),1),s(d,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const qt=E(Rt,[["render",Bt],["__scopeId","data-v-ce70fe34"]]);function D(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const i=e%60,o=i<10?`0${i}`:i,a=t<10?`0${t}`:t;return o+":"+a}const Wt=b({name:"ExtendFromInput",components:{ElImage:J,ElIcon:R,ElInputNumber:Pe,VideoPlay:Y,VideoPause:Q},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:D,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})}}}),Nt={class:"field"},Ht={class:"box"},Kt={class:"title font-bold"},Zt={class:"input-wrapper"},xt={class:"task"},Xt={class:"left"},Jt={key:2,class:"duration"},Qt={class:"info"},Yt={class:"title"},eo={class:"style"};function to(e,t,i,o,a,u){const d=c("el-input-number"),p=c("el-image"),_=c("video-pause"),n=c("el-icon"),m=c("video-play"),k=ee("loading");return l(),h("div",Nt,[r("div",Ht,[r("h2",Kt,v(e.$t("suno.name.extend")),1),r("div",Zt,[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"])])]),r("div",xt,[e.audio?(l(),h("div",{key:0,class:"audio",onClick:t[3]||(t[3]=f=>e.onClick(e.audio))},[x((l(),h("div",Xt,[s(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(l(),h("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=f=>e.onPause(e.audio))},[s(n,null,{default:$(()=>[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")?(l(),h("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=f=>e.onPlay(e.audio))},[s(n,null,{default:$(()=>[s(m)]),_:1})])):y("",!0),e.audio?.duration?(l(),h("div",Jt,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[k,!e.audio?.audio_url]]),r("div",Qt,[r("h2",Yt,v(e.audio?.title),1),r("p",eo,v(e.audio?.style),1)])])):y("",!0)])])}const oo=E(Wt,[["render",to],["__scopeId","data-v-bcce4821"]]),so=b({name:"CoverFromInput",components:{ElImage:J,ElIcon:R,VideoPlay:Y,VideoPause:Q},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:D,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})}}}),no={class:"field"},io={class:"box"},ao={class:"title font-bold"},lo={class:"task"},ro={class:"left"},co={key:2,class:"duration"},uo={class:"info"},po={class:"title"},mo={class:"style"};function fo(e,t,i,o,a,u){const d=c("el-image"),p=c("video-pause"),_=c("el-icon"),n=c("video-play"),m=ee("loading");return l(),h("div",no,[r("div",io,[r("h2",ao,v(e.$t("suno.name.cover")),1)]),r("div",lo,[e.audio?(l(),h("div",{key:0,class:"audio",onClick:t[2]||(t[2]=k=>e.onClick(e.audio))},[x((l(),h("div",ro,[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"?(l(),h("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=k=>e.onPause(e.audio))},[s(_,null,{default:$(()=>[s(p)]),_: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")?(l(),h("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPlay(e.audio))},[s(_,null,{default:$(()=>[s(n)]),_:1})])):y("",!0),e.audio?.duration?(l(),h("div",co,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[m,!e.audio?.audio_url]]),r("div",uo,[r("h2",po,v(e.audio?.title),1),r("p",mo,v(e.audio?.style),1)])])):y("",!0)])])}const ho=E(so,[["render",fo],["__scopeId","data-v-06640216"]]),_o=b({name:"PresetPanel",components:{TypeSelector:lt,PromptInput:Ct,LyricInput:Ft,StyleInput:Dt,TitleInput:qt,ExtendFromInput:oo,CoverFromInput:ho,UploadAudio:ft,FontAwesomeIcon:K,ElButton:Z,Consumption:Ie},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return ze(this.config,this.service?.metadata?.price)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),$o={class:"flex flex-col h-full"},vo={class:"flex-1 overflow-y-auto p-[15px]"},go={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ko(e,t,i,o,a,u){const d=c("type-selector"),p=c("upload-audio"),_=c("prompt-input"),n=c("lyric-input"),m=c("style-input"),k=c("title-input"),f=c("extend-from-input"),C=c("cover-from-input"),j=c("consumption"),T=c("font-awesome-icon"),A=c("el-button");return l(),h("div",$o,[r("div",vo,[s(d,{class:"mb-4"}),s(p,{class:"mb-4"}),e.config?.custom?y("",!0):(l(),w(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(l(),w(n,{key:1,class:"mb-4"})):y("",!0),e.config?.custom?(l(),w(m,{key:2,class:"mb-4"})):y("",!0),e.config?.custom?(l(),w(k,{key:3,class:"mb-4"})):y("",!0),e.config?.action==="extend"?(l(),w(f,{key:4,class:"mb-4"})):y("",!0),e.config?.action==="cover"?(l(),w(C,{key:5,class:"mb-4"})):y("",!0)]),r("div",go,[s(j,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(l(),w(A,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+v(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(l(),w(A,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+v(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const yo=E(_o,[["render",ko],["__scopeId","data-v-b9fab929"]]);var W={exports:{}},wo=W.exports,ne;function bo(){return ne||(ne=1,function(e,t){(function(i,o){o()})(wo,function(){function i(n,m){return typeof m>"u"?m={autoBom:!1}:typeof m!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),m={autoBom:!m}),m.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(n.type)?new Blob(["\uFEFF",n],{type:n.type}):n}function o(n,m,k){var f=new XMLHttpRequest;f.open("GET",n),f.responseType="blob",f.onload=function(){_(f.response,m,k)},f.onerror=function(){console.error("could not download file")},f.send()}function a(n){var m=new XMLHttpRequest;m.open("HEAD",n,!1);try{m.send()}catch{}return 200<=m.status&&299>=m.status}function u(n){try{n.dispatchEvent(new MouseEvent("click"))}catch{var m=document.createEvent("MouseEvents");m.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),n.dispatchEvent(m)}}var d=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof B=="object"&&B.global===B?B:void 0,p=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&&!p?function(n,m,k){var f=d.URL||d.webkitURL,C=document.createElement("a");m=m||n.name||"download",C.download=m,C.rel="noopener",typeof n=="string"?(C.href=n,C.origin===location.origin?u(C):a(C.href)?o(n,m,k):u(C,C.target="_blank")):(C.href=f.createObjectURL(n),setTimeout(function(){f.revokeObjectURL(C.href)},4e4),setTimeout(function(){u(C)},0))}:"msSaveOrOpenBlob"in navigator?function(n,m,k){if(m=m||n.name||"download",typeof n!="string")navigator.msSaveOrOpenBlob(i(n,k),m);else if(a(n))o(n,m,k);else{var f=document.createElement("a");f.href=n,f.target="_blank",setTimeout(function(){u(f)})}}:function(n,m,k,f){if(f=f||open("","_blank"),f&&(f.document.title=f.document.body.innerText="downloading..."),typeof n=="string")return o(n,m,k);var C=n.type==="application/octet-stream",j=/constructor/i.test(d.HTMLElement)||d.safari,T=/CriOS\/[\d]+/.test(navigator.userAgent);if((T||C&&j||p)&&typeof FileReader<"u"){var A=new FileReader;A.onloadend=function(){var S=A.result;S=T?S:S.replace(/^data:[^;]*;/,"data:attachment/file;"),f?f.location.href=S:location=S,f=null},A.readAsDataURL(n)}else{var O=d.URL||d.webkitURL,g=O.createObjectURL(n);f?f.location=g:location.href=g,f=null,setTimeout(function(){O.revokeObjectURL(g)},4e4)}});d.saveAs=_.saveAs=_,e.exports=_})}(W)),W.exports}var Co=bo();const So="https://webhook.acedata.cloud/suno",Ao=b({name:"TaskPreview",components:{ElImage:J,ElIcon:R,ElTooltip:Me,ElButton:Z,FontAwesomeIcon:K,VideoPlay:Y,VideoPause:Q,ElDropdown:Ge,ElDropdownMenu:Re,ElDropdownItem:De,Loading:Ce},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===q.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(i=>({...i,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:D,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,a=o.substring(o.lastIndexOf("/")+1);console.log("on preview",a),fetch(t).then(u=>u.blob()).then(u=>{Co.saveAs(u,a)})},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),L.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,i)=>{const o={audio_id:e},a=this.credential?.token;if(!a){console.error("no token specified"),i(new Error("No token specified"));return}H.mp4(o,{token:a}).then(u=>{const d=u.data?.data?.video_url;d?t(d):i(new Error("Video URL not found in response"))}).catch(u=>{i(u)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onGenerateAudioUrl(e,t){const i={action:e,audio_id:t,callback_url:So},o=this.credential?.token;if(!o){console.error("no token specified");return}L.info(this.$t("suno.message.startingTask")),H.audio(i,{token:o}).then(()=>{L.success(this.$t("suno.message.startTaskSuccess"))}).catch(a=>{L.error(a?.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})}}}),Lo={class:"task"},Eo=["onClick"],Vo={class:"left"},jo=["onClick"],Fo=["onClick"],To={key:2,class:"duration"},Po={class:"info"},Io={class:"title"},Uo={class:"style"},zo={class:"right"},Do={class:"el-dropdown-link"},Ro={class:"flex items-center min-w-[120px]"},Go={class:"el-dropdown-link"};function Mo(e,t,i,o,a,u){const d=c("el-image"),p=c("video-pause"),_=c("el-icon"),n=c("video-play"),m=c("el-button"),k=c("font-awesome-icon"),f=c("el-tooltip"),C=c("Loading"),j=c("el-dropdown-item"),T=c("el-dropdown-menu"),A=c("el-dropdown"),O=ee("loading");return l(),h("div",Lo,[(l(!0),h(z,null,N(e.audios,g=>(l(),h("div",{key:g.id,class:"audio",onClick:P(S=>e.onClick(g),["stop"])},[x((l(),h("div",Vo,[s(d,{src:g?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),g?.audio_url&&e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="playing"?(l(),h("div",{key:0,class:"overlay",onClick:P(S=>e.onPause(g),["stop"])},[s(_,null,{default:$(()=>[s(p)]),_:1})],8,jo)):y("",!0),g?.audio_url&&(e.$store.state?.suno?.audio?.id!==g.id||e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="paused")?(l(),h("div",{key:1,class:"overlay",onClick:P(S=>e.onPlay(g),["stop"])},[s(_,null,{default:$(()=>[s(n)]),_:1})],8,Fo)):y("",!0),g?.duration?(l(),h("div",To,v(e.useFormatDuring(g?.duration)),1)):y("",!0)])),[[O,!g?.audio_url]]),r("div",Po,[r("h2",Io,v(g?.title),1),r("p",Uo,v(g?.style),1)]),r("div",zo,[g?.audio_url?(l(),w(m,{key:0,size:"small",round:"",onClick:P(S=>e.onExtend(S,g),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):y("",!0),s(A,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[s(j,{disabled:e.isFetchingVideoUrl,onClick:S=>e.handleVideoDownload(g)},{default:$(()=>[r("div",Ro,[e.isFetchingVideoUrl?(l(),w(_,{key:0,class:"is-loading mr-2"},{default:$(()=>[s(C)]),_:1})):y("",!0),r("span",null,v(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),g?.audio_url?(l(),w(j,{key:0,onClick:P(S=>e.onDownload(S,g?.audio_url),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[r("span",Do,[s(f,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(l(),w(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(A,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g.id?(l(),w(j,{key:0,onClick:P(S=>e.onGetStems(g.id),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):y("",!0),s(j,{onClick:P(S=>e.onCover(g),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),g?.id&&g?.action==="extend"?(l(),w(j,{key:1,onClick:P(S=>e.onConcatMusic(g?.id),["stop"])},{default:$(()=>[I(v(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[r("span",Go,[s(f,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(l(),w(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,Eo))),128))])}const Oo=E(Ao,[["render",Mo]]),Bo={class:"player-slider"},qo=b({__name:"PlayerSlider",setup(e){const t=G(),i=F({get:()=>t.state.suno?.audio?.progress,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:d})}),o=F({get:()=>t.state.suno?.audio?.duration,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:d})}),a=()=>{},u=d=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:d});return(d,p)=>(l(),h("div",Bo,[s(V(ue),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=_=>i.value=_),"show-tooltip":!1,min:0,max:o.value,onChange:u,onInput:a},null,8,["modelValue","max"])]))}}),Wo="/assets/disk-XFRmVAfp.png",No={class:"flex player-song"},Ho=["src"],Ko={class:"ml-2 text-xs flex flex-col justify-between"},Zo={class:"w-52 2xl:w-96 cursor-pointer truncate"},xo={class:"flex"},Xo={class:"ml-2 text-dc"},Jo=b({__name:"PlayerSong",setup(e){const t=G(),i=F({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return le(i,(o,a)=>{if(o?.audio_url!==a?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const u=new Audio(o.audio_url);o.state==="playing"?u.play():u.pause(),u.addEventListener("loadedmetadata",()=>{u.currentTime=0,u.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:u.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:u})}else if(o?.progress!==a?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const u=t.state.suno.audio;u.object&&(u.object.currentTime=u.progress)}else o?.state!==a?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==a?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,a)=>(l(),h("div",No,[r("img",{alt:"",class:"w-11 h-11 rounded",src:i.value?.image_url||V(Wo)},null,8,Ho),r("div",Ko,[r("div",Zo,[r("div",xo,[r("span",null,v(i.value?.title||"Music"),1),r("span",Xo,"- "+v(i.value?.style||"SmallRuralDog"),1)])])])]))}}),Qo={class:"flex justify-end items-center gap-x-2.5"},Yo={class:"text-xs"},es=b({__name:"PlayerAction",setup(e){const t=G(),i=F({get:()=>t.state.suno?.audio?.progress,set:a=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:a})}),o=F({get:()=>t.state.suno?.audio?.duration,set:a=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:a})});return(a,u)=>(l(),h("div",Qo,[r("span",Yo,v(V(D)(i.value))+" / "+v(V(D)(o.value)),1)]))}});var ts={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 os(){return"icon-"+((1+Math.random())*4294967296|0).toString(16).substring(1)}function ss(e,t,i){var o=typeof t.fill=="string"?[t.fill]:t.fill||[],a=[],u=t.theme||i.theme;switch(u){case"outline":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("none"),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("none");break;case"filled":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push("#FFF"),a.push("#FFF");break;case"two-tone":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone),a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone);break;case"multi-color":a.push(typeof o[0]=="string"?o[0]:"currentColor"),a.push(typeof o[1]=="string"?o[1]:i.colors.multiColor.outFillColor),a.push(typeof o[2]=="string"?o[2]:i.colors.multiColor.innerStrokeColor),a.push(typeof o[3]=="string"?o[3]:i.colors.multiColor.innerFillColor);break}return{size:t.size||i.size,strokeWidth:t.strokeWidth||i.strokeWidth,strokeLinecap:t.strokeLinecap||i.strokeLinecap,strokeLinejoin:t.strokeLinejoin||i.strokeLinejoin,colors:a,id:e}}var ns=Symbol("icon-context");function te(e,t,i){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(u){var d=os(),p=Se(ns,ts);return function(){var _=u.size,n=u.strokeWidth,m=u.strokeLinecap,k=u.strokeLinejoin,f=u.theme,C=u.fill,j=u.spin,T=ss(d,{size:_,strokeWidth:n,strokeLinecap:m,strokeLinejoin:k,theme:f,fill:C},p),A=[p.prefix+"-icon"];return A.push(p.prefix+"-icon-"+e),t&&p.rtl&&A.push(p.prefix+"-icon-rtl"),j&&A.push(p.prefix+"-icon-spin"),s("span",{class:A.join(" ")},[i(T)])}}};return o}const is=te("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)])}),as=te("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)])}),ls=te("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)])}),ie=b({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,i)=>(l(),w(re(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"]))}}),rs={class:"player-volume flex flex-col items-center pt-2"},cs={class:"text-sm mt-3"},us=b({__name:"PlayerVolumeSlider",setup(e){const t=G(),i=F({get:()=>t.state.suno.audio?.volume,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:u})}),o=F({get:()=>t.state.suno.audio?.muted,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:u})}),a=u=>t.dispatch("suno/setVolume",u);return(u,d)=>(l(),h("div",rs,[s(V(ue),{modelValue:i.value,"onUpdate:modelValue":d[0]||(d[0]=p=>i.value=p),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:a},null,8,["modelValue","disabled"]),r("div",cs,v(i.value),1)]))}}),ds={class:"flex items-center justify-center gap-x-3"},ps=b({__name:"PlayerController",setup(e){const t=G(),i=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=F(()=>t.state.suno.audio);return(a,u)=>(l(),h("div",ds,[s(ie,{icon:o.value?.state==="playing"?V(is):V(as),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:i},null,8,["icon"]),s(V(Oe),{placement:"top",width:"50px",trigger:"click"},{reference:$(()=>[s(ie,{icon:V(ls),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:$(()=>[s(us)]),_:1})]))}}),ms={class:"flex flex-col items-stretch h-20"},fs={class:"flex grow px-5 items-center"},hs={class:"flex-1"},_s={class:"flex-1"},$s={class:"flex-1"},vs=b({__name:"Player",setup(e){return(t,i)=>(l(),h("div",ms,[s(qo),r("div",fs,[r("div",hs,[s(Jo)]),r("div",_s,[s(ps)]),r("div",$s,[s(es)])])]))}}),gs=b({name:"RecentPanel",components:{ElSkeletonItem:qe,ElSkeleton:Be,TaskPreview:Oo,Player:vs,NoTasks:Ue},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),ks={key:0,class:"tasks"},ys={class:"left w-[70px] p-[10px] flex items-center"},ws={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},bs={key:2,class:"w-full flex-1 flex items-center justify-center"},Cs={class:"h-20"};function Ss(e,t,i,o,a,u){const d=c("el-skeleton-item"),p=c("el-skeleton"),_=c("task-preview"),n=c("no-tasks"),m=c("player");return l(),h(z,null,[e.tasks?.items===void 0?(l(),h("div",ks,[(l(),h(z,null,N(3,k=>r("div",{key:k,class:"flex"},[r("div",ys,[s(p,{animated:""},{template:$(()=>[s(d,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),r("div",ws,[s(p,{animated:""},{template:$(()=>[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?(l(),h("div",{key:1,class:"flex-1 w-full overflow-y-auto tasks p-2",onScroll:t[0]||(t[0]=(...k)=>e.onHandleScroll&&e.onHandleScroll(...k))},[(l(!0),h(z,null,N(e.tasks?.items,(k,f)=>(l(),w(_,{key:f,"model-value":k,class:"preview"},null,8,["model-value"]))),128))],32)):y("",!0),e.tasks?.items?.length===0?(l(),h("div",bs,[s(n)])):y("",!0),x(r("div",Cs,[s(m)],512),[[Ae,!!e.$store?.state?.suno?.audio?.object]])],64)}const As=E(gs,[["render",Ss]]),Ls=b({name:"TaskPreview",components:{IconPicture:Le,ElImage:J,ElAvatar:xe,ElIcon:R},computed:{audio(){return this.$store.state.suno?.audio}}}),Es={key:0,class:"size-full overflow-hidden"},Vs={class:"relative h-[300px]"},js={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Fs={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"},Ts={class:"p-4"},Ps={class:"flex items-center font-bold mb-2"},Is={class:"text-[var(--el-text-color-regular)] mb-2"},Us={class:"text-xs text-[var(--el-text-color-regular)]"},zs={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Ds={key:1,class:"w-full h-full"};function Rs(e,t,i,o,a,u){const d=c("icon-picture"),p=c("el-icon"),_=c("el-image"),n=c("el-avatar");return e.audio?.object?(l(),h("div",Es,[r("div",Vs,[s(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:$(()=>[r("div",js,[s(p,{class:"text-3xl"},{default:$(()=>[s(d)]),_:1})])]),_:1},8,["src"]),r("h2",Fs,v(e.audio?.title),1)]),r("div",Ts,[r("div",Ps,[s(n,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),r("span",null,v(e.audio?.title),1)]),r("p",Is,v(e.audio?.style),1),r("p",Us,v(e.$dayjs.format(e.audio?.created_at)),1),r("div",zs,[r("p",null,v(e.audio?.lyric),1)])])])):(l(),h("div",Ds))}const Gs=E(Ls,[["render",Rs]]),Ms="https://webhook.acedata.cloud/suno",Os=b({name:"SunoIndex",components:{Layout:ot,ConfigPanel:yo,RecentPanel:As,PreviewPanel:Gs},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===q.Request},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===q.Request},needApply(){return this.$store.state.suno.status.getApplications===q.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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,L.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ve&&L.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:i,createdAtMax:o}=e||{};console.debug("limit",t,"createdAtMin",i,"createdAtMax",o),await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:i,createdAtMax:o})},async onGenerateAudio(){const e={...this.config,callback_url:Ms},t=this.credential?.token;if(!t){console.error("no token specified");return}L.info(this.$t("suno.message.startingTask")),H.audio(e,{token:t}).then(()=>{L.success(this.$t("suno.message.startTaskSuccess"))}).catch(i=>{L.error(i?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Bs(e,t,i,o,a,u){const d=c("config-panel"),p=c("recent-panel"),_=c("preview-panel"),n=c("layout");return l(),w(n,null,{config:$(()=>[s(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:$(()=>[s(p,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),preview:$(()=>[s(_)]),_:1})}const Cn=E(Os,[["render",Bs],["__scopeId","data-v-f5721d95"]]);export{Cn as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{E,a as T,b as D}from"./EditArray-
|
|
1
|
+
import{E,a as T,b as D}from"./EditArray-DaAQ3MHX.js";import{d as F,H as U,h as V,i as q,j as s,k as t,l as n,t as l,x as o,D as m,b as I,v as A,F as _,o as w,J as k,y as j,K as C}from"./index-BZbKTMK3.js";import{E as B,a as L}from"./index-hbRYKLdf.js";import{E as N}from"./index-CbPHeT3X.js";import{E as R,a as K,b as O}from"./index-BQcaFqGZ.js";import{E as Q}from"./index-Cu3La3dR.js";import{E as H}from"./index-BxILNqsr.js";import"./index-CgzNR6Br.js";import"./use-form-item-9EKLSUpL.js";import"./index-r5W6hzzQ.js";import"./index-DSYfQpVb.js";import"./typescript-CkR2OWnN.js";import"./index-CZi_rDaW.js";import"./index-CjhBlm5C.js";import"./index.es-B92faSi8.js";import"./index-yxRIEND6.js";import"./index-oeBw24Ll.js";import"./_baseClone-CyEUgRjr.js";import"./_initCloneObject-DL2KWEpg.js";import"./isEqual-DIgYivsv.js";import"./index-hrpdMjUu.js";import"./castArray-BeCWKAC7.js";import"./debounce-kw1MDyXj.js";const J=F({name:"SiteIndex",components:{EditText:D,EditImage:T,EditArray:E,ElDivider:H,ElRow:O,ElImage:Q,ElCol:K,ElCard:R,ElForm:L,ElSwitch:N,ElFormItem:B},data(){return{editing:{title:!1}}},computed:{site(){return this.$store.getters.site}},methods:{onSave(e){const a={...this.site,...e};U.update(this.site?.id,a).then(()=>{console.debug("getSite for id",this.site?.id),this.$store.dispatch("getSite")})}}}),W={class:"title"},z={class:"title"},G={class:"block w-full"},M={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},Y={class:"block w-full"},Z={class:"block tip"},x={class:"block w-full"},ee={class:"block tip"},te={class:"block w-full"},ie={class:"block tip"},se={class:"title"},le={class:"block w-full"},oe={class:"block tip"},ae={class:"block w-full"},de={class:"block tip"},ne={class:"title"},re={class:"block tip"},me={class:"block tip"},pe={class:"title"},ue={class:"w-full"},fe={class:"block tip w-full"},be={key:0},ve={class:"block w-full"},he={class:"block w-full"};function ce(e,a,$e,ge,we,ke){const f=n("el-col"),h=n("el-row"),p=n("el-divider"),d=n("el-form-item"),u=n("edit-text"),c=n("el-image"),$=n("edit-image"),y=n("edit-array"),b=n("el-form"),v=n("el-card"),g=n("el-switch");return w(),q(h,{class:"panel"},{default:s(()=>[t(f,{span:24},{default:s(()=>[t(h,null,{default:s(()=>[t(f,{span:24},{default:s(()=>[l("h2",W,o(e.$t("common.title.site")),1)]),_:1})]),_:1}),t(h,{gutter:15},{default:s(()=>[t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",z,o(e.$t("site.title.basicConfig")),1),t(p),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.origin")},{default:s(()=>[l("span",G,o(e.site.origin),1),l("span",M,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",P,[m(o(e.site.title)+" ",1),t(u,{"model-value":e.site.title,title:e.$t("site.title.editTitle"),placeholder:e.$t("site.placeholder.title"),onConfirm:a[0]||(a[0]=i=>e.onSave({title:i}))},null,8,["model-value","title","placeholder"])]),l("span",X,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",Y,[t(c,{src:e.site.logo,class:"logo"},null,8,["src"]),t($,{"model-value":e.site.logo,title:e.$t("site.title.editLogo"),tip:e.$t("site.message.editLogoTip"),onConfirm:a[1]||(a[1]=i=>e.onSave({logo:i}))},null,8,["model-value","title","tip"])]),l("span",Z,o(e.$t("site.message.logoTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.favicon")},{default:s(()=>[l("span",x,[t(c,{src:e.site.favicon,class:"favicon"},null,8,["src"]),t($,{"model-value":e.site.favicon,title:e.$t("site.title.editFavicon"),tip:e.$t("site.message.editFaviconTip"),onConfirm:a[2]||(a[2]=i=>e.onSave({favicon:i}))},null,8,["model-value","title","tip"])]),l("span",ee,o(e.$t("site.message.faviconTip")),1)]),_:1},8,["label"]),t(p,{"border-style":"dashed"}),t(d,{label:e.$t("site.field.admins")},{default:s(()=>[l("span",te,[m(o(e.site.admins?.join(", "))+" ",1),t(y,{"model-value":e.site?.admins||[],title:e.$t("site.title.editAdmins"),placeholder:e.$t("site.placeholder.admins"),tip:e.$t("site.message.adminsTip2"),min:1,"min-error-message":e.$t("site.message.atLeastOneAdmin"),onConfirm:a[3]||(a[3]=i=>e.onSave({admins:i}))},null,8,["model-value","title","placeholder","tip","min-error-message"])]),l("span",ie,o(e.$t("site.message.adminsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",se,o(e.$t("site.title.seoConfig")),1),t(p),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.description")},{default:s(()=>[l("span",le,[m(o(e.site.description)+" ",1),t(u,{"model-value":e.site.description,title:e.$t("site.title.editDescription"),placeholder:e.$t("site.placeholder.description"),onConfirm:a[4]||(a[4]=i=>e.onSave({description:i}))},null,8,["model-value","title","placeholder"])]),l("span",oe,o(e.$t("site.message.descriptionTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.keywords")},{default:s(()=>[l("span",ae,[m(o(e.site.keywords?.join(", "))+" ",1),t(y,{"model-value":e.site?.keywords||[],title:e.$t("site.title.editKeywords"),placeholder:e.$t("site.placeholder.keywords"),tip:e.$t("site.message.keywordsTip2"),onConfirm:a[5]||(a[5]=i=>e.onSave({keywords:i}))},null,8,["model-value","title","placeholder","tip"])]),l("span",de,o(e.$t("site.message.keywordsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1})]),_:1}),t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",ne,o(e.$t("site.title.distributionConfig")),1),t(p),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.distributionDefaultInviterId")},{default:s(()=>[m(o(e.site.distribution?.default_inviter_id)+" ",1),t(u,{"model-value":e.site.distribution?.default_inviter_id,title:e.$t("site.title.editDistributionDefaultInviterId"),placeholder:e.$t("site.placeholder.editDistributionDefaultInviterId"),onConfirm:a[6]||(a[6]=i=>e.onSave({distribution:{...e.site.distribution,default_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",re,o(e.$t("site.message.distributionDefaultInviterIdTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.distributionForceInviterId")},{default:s(()=>[m(o(e.site.distribution?.force_inviter_id)+" ",1),t(u,{"model-value":e.site.distribution?.force_inviter_id,title:e.$t("site.title.editDistributionForceInviterId"),placeholder:e.$t("site.placeholder.editDistributionForceInviterId"),onConfirm:a[7]||(a[7]=i=>e.onSave({distribution:{...e.site.distribution,force_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",me,o(e.$t("site.message.distributionForceInviterIdTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",pe,o(e.$t("site.title.featuresConfig")),1),t(p),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[(w(),I(_,null,A(["chat","midjourney","qrart","suno","luma","pika","kling","flux","hailuo","headshots","support"],(i,S)=>t(d,{key:S,label:e.$t("site.field.features"+i.charAt(0).toUpperCase()+i.slice(1))},{default:s(()=>[l("div",ue,[t(g,{"model-value":e.site.features[i]?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],enabled:r}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),l("span",fe,o(e.$t("site.message.features"+i.charAt(0).toUpperCase()+i.slice(1))),1),i==="support"?k((w(),I("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.wechat?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.qr")},{default:s(()=>[l("span",ve,[t(c,{src:e.site.features[i]?.wechat?.qr},null,8,["src"]),t($,{"model-value":e.site.features[i]?.wechat?.qr,title:e.$t("site.title.editQR"),tip:e.$t("site.message.editQRTip"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,qr:r}}}})},null,8,["model-value","title","tip","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.wechat?.enabled]]),t(d,{label:"Discord"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.discord?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.url")},{default:s(()=>[l("span",he,[m(o(e.site.features[i]?.discord?.url)+" ",1),t(u,{"model-value":e.site.features[i]?.discord?.url,title:e.$t("site.title.editUrl"),placeholder:e.$t("site.placeholder.editUrl"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,url:r}}}})},null,8,["model-value","title","placeholder","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.discord?.enabled]])],512)),[[C,e.site.features[i]?.enabled]]):j("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const We=V(J,[["render",ce],["__scopeId","data-v-61e4ae55"]]);export{We as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as O}from"./index.es-B92faSi8.js";import{E as R}from"./index-CgzNR6Br.js";import{E as B}from"./index-C1h2SbZU.js";import{d as v,h as g,b as l,t as i,k as t,r as z,j as p,l as a,o as s,eG as P,eH as M,eI as C,eJ as E,eK as I,x as r,F as S,v as T,i as y,eL as q,eM as H,y as f,eN as J,n as L,f as K,c9 as W,D as $,eO as Z,J as Q,K as X,eP as Y,du as x,dq as ee}from"./index-BZbKTMK3.js";import{E as D,a as U}from"./index-BNbrEyG8.js";import{I as F}from"./InfoIcon-DhMpzlKc.js";import{I as te}from"./ImagePreview-BvPOSpDB.js";import{E as oe}from"./index-yxRIEND6.js";import{E as A}from"./index-hrpdMjUu.js";import{C as se,N as ae}from"./NoTasks-DmNkmZBC.js";import{E as ne}from"./index-DSYfQpVb.js";import{a as re}from"./price-B8COZ-j4.js";import{C as le}from"./CopyToClipboard-CuCD6yxS.js";import{V as ie}from"./VideoPlayer-D-xD0k0W.js";import{E as ce}from"./index-BDYxvVsV.js";import{E as de}from"./index-D0cZ5BM8.js";import{E as ue}from"./index-Cu3La3dR.js";import{B as pe}from"./BotPlaceholder-6rksUZSI.js";import"./use-form-item-9EKLSUpL.js";import"./index-r5W6hzzQ.js";import"./index-BKJPB7EB.js";import"./typescript-CkR2OWnN.js";import"./index-CZi_rDaW.js";import"./strings-BQbdUIFn.js";import"./castArray-BeCWKAC7.js";import"./isEqual-DIgYivsv.js";import"./_initCloneObject-DL2KWEpg.js";import"./debounce-kw1MDyXj.js";import"./_baseIteratee-LzESfPbZ.js";import"./index-Tp13-pBQ.js";import"./index-oeBw24Ll.js";import"./_baseClone-CyEUgRjr.js";import"./index-CjhBlm5C.js";import"./vue-plyr-QZFBikSk.js";import"./index-Rl2p1NyF.js";const me=v({name:"LayoutSora",components:{ElDrawer:B,ElButton:R,FontAwesomeIcon:O},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},_e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},he={class:"result h-full p-[15px] flex-1 flex flex-col"};function $e(e,o,d,_,b,k){const c=a("font-awesome-icon"),u=a("el-button"),n=a("el-drawer");return s(),l("div",fe,[i("div",_e,[z(e.$slots,"config",{},void 0,!0)]),i("div",he,[z(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:p(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[z(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ve=g(me,[["render",$e],["__scopeId","data-v-966c9b2c"]]),ge=v({name:"ModelSelector",components:{ElSelect:U,ElOption:D},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:M,label:"sora-2"},{value:C,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const d={...this.$store.state.sora?.config||{},model:e};e===M?(d.duration=E,d.size=I):e===C&&(d.duration=d.duration||E,d.size=d.size||I),this.$store.commit("sora/setConfig",d)}}},mounted(){this.value||(this.value=P)}}),be={class:"field"},ke={class:"title font-bold"};function we(e,o,d,_,b,k){const c=a("el-option"),u=a("el-select");return s(),l("div",be,[i("h2",ke,r(e.$t("sora.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:p(()=>[(s(!0),l(S,null,T(e.options,n=>(s(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ye=g(ge,[["render",we],["__scopeId","data-v-ea6f95d9"]]),Se=v({name:"ActionSelector",components:{ElSelect:U,ElOption:D},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=q)}}),Ve={class:"field"},Ee={class:"title font-bold"},Ie={class:"float-left"};function Ae(e,o,d,_,b,k){const c=a("el-option"),u=a("el-select");return s(),l("div",Ve,[i("h2",Ee,r(e.$t("sora.name.action")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:p(()=>[(s(!0),l(S,null,T(e.options,n=>(s(),y(c,{key:n.value,label:n.label,value:n.value},{default:p(()=>[i("span",Ie,r(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Le=g(Se,[["render",Ae],["__scopeId","data-v-7b82fa7f"]]),Te=v({name:"DurationSelector",components:{ElSelect:U,ElOption:D},data(){return{options:H.map(e=>({value:e,label:`${e}s`}))}},computed:{model(){return this.$store.state.sora?.config?.model||P},isLocked(){return this.model!==C},optionsForModel(){return this.isLocked?this.options.filter(e=>e.value===E):this.options},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const o=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...o,duration:e})}}},watch:{isLocked(e){e&&this.value!==E&&(this.value=E)}},mounted(){this.value||(this.value=E)}}),Ce={class:"field"},Oe={class:"control"},Re={class:"title font-bold"},De={key:0,class:"hint"};function Ue(e,o,d,_,b,k){const c=a("el-option"),u=a("el-select");return s(),l("div",Ce,[i("div",Oe,[i("h2",Re,r(e.$t("sora.name.duration")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),disabled:e.isLocked},{default:p(()=>[(s(!0),l(S,null,T(e.optionsForModel,n=>(s(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.isLocked?(s(),l("p",De,r(e.$t("sora.tip.proOnly")),1)):f("",!0)])}const Ge=g(Te,[["render",Ue],["__scopeId","data-v-8e3f9091"]]),ze=v({name:"OrientationSelector",data(){return{options:[{value:"portrait",label:"竖屏",width:13,height:25},{value:"landscape",label:"横屏",width:25,height:13}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=J)}}),Pe={class:"text-sm font-bold mb-2 block"},Me={class:"items"},Fe=["onClick"],je={class:"name"};function Ne(e,o,d,_,b,k){return s(),l("div",null,[i("span",Pe,r(e.$t("sora.name.orientation")),1),i("div",Me,[(s(!0),l(S,null,T(e.options,(c,u)=>(s(),l("div",{key:u,class:L({active:e.active===u,item:!0}),onClick:n=>e.value=c.value},[i("div",{class:L(["preview",c.value])},[i("div",{class:"rect",style:K({width:c.width+"px",height:c.height+"px"})},null,4)],2),i("p",je,r(c.label),1)],10,Fe))),128))])])}const Be=g(ze,[["render",Ne],["__scopeId","data-v-d6940af8"]]),qe=v({name:"StartEndImage",components:{ElUpload:oe,ElButton:R,InfoIcon:F,FontAwesomeIcon:O,ImagePreview:te},emits:["change"],data(){return{fileList:[],uploadUrl:W()+"/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?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){A.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){A.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),He={class:"relative"},Je={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},We={class:"text-sm font-bold"};function Ze(e,o,d,_,b,k){const c=a("info-icon"),u=a("image-preview"),n=a("font-awesome-icon"),w=a("el-button"),h=a("el-upload");return s(),l("div",He,[i("div",Je,[i("div",Ke,[i("span",We,r(e.$t("sora.name.startEndImage")),1),t(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),t(h,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=m=>e.fileList=m),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:m})=>[m.url&&m.percentage!==void 0?(s(),y(u,{key:0,url:m.url,name:m.name,percentage:m.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(m),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:p(()=>[t(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[t(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+r(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Qe=g(qe,[["render",Ze],["__scopeId","data-v-fd6e5c97"]]),Xe=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),Ye=v({name:"SizeSelector",components:{ElSelect:U,ElOption:D},data(){return{options:Z.map(e=>({value:e,label:Xe(e)}))}},computed:{model(){return this.$store.state.sora?.config?.model||P},isLocked(){return this.model!==C},optionsForModel(){return this.isLocked?this.options.filter(e=>e.value===I):this.options},value:{get(){return this.$store.state.sora?.config?.size},set(e){const o=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...o,size:e})}}},watch:{isLocked(e){e&&this.value!==I&&(this.value=I)}},mounted(){this.value||(this.value=I)}}),xe={class:"field"},et={class:"control"},tt={class:"title font-bold"},ot={key:0,class:"hint"};function st(e,o,d,_,b,k){const c=a("el-option"),u=a("el-select");return s(),l("div",xe,[i("div",et,[i("h2",tt,r(e.$t("sora.name.size")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("sora.placeholder.select"),disabled:e.isLocked},{default:p(()=>[(s(!0),l(S,null,T(e.optionsForModel,n=>(s(),y(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])]),e.isLocked?(s(),l("p",ot,r(e.$t("sora.tip.proOnly")),1)):f("",!0)])}const at=g(Ye,[["render",st],["__scopeId","data-v-c0582a64"]]),nt="",rt=v({name:"PromptInput",components:{ElInput:ne,InfoIcon:F},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=nt)}}),lt={class:"field"},it={class:"box"},ct={class:"title font-bold"};function dt(e,o,d,_,b,k){const c=a("info-icon"),u=a("el-input");return s(),l("div",lt,[i("div",it,[i("h2",ct,r(e.$t("sora.name.prompt")),1),t(c,{content:e.$t("sora.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("sora.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ut=g(rt,[["render",dt],["__scopeId","data-v-cf3a1497"]]),pt=v({name:"ConfigPanel",components:{ElButton:R,Consumption:se,FontAwesomeIcon:O,PromptInput:ut,ModelSelector:ye,StartEndImage:Qe,SizeSelector:at,ActionSelector:Le,OrientationSelector:Be,DurationSelector:Ge},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return re(this.config,this.service?.metadata?.price)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),mt={class:"flex flex-col h-full"},ft={class:"flex-1 overflow-y-auto p-[15px]"},_t={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ht(e,o,d,_,b,k){const c=a("model-selector"),u=a("action-selector"),n=a("duration-selector"),w=a("size-selector"),h=a("orientation-selector"),m=a("prompt-input"),V=a("start-end-image"),G=a("consumption"),j=a("font-awesome-icon"),N=a("el-button");return s(),l("div",mt,[i("div",ft,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),t(n,{class:"mb-4"}),t(w,{class:"mb-4"}),t(h,{class:"mb-4"}),t(m,{class:"mb-4"}),Q(t(V,{class:"mb-2"},null,512),[[X,e.config?.action==="image2video"]])]),i("div",_t,[t(G,{value:e.consumption,service:e.service},null,8,["value","service"]),t(N,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(j,{icon:"fa-solid fa-magic",class:"mr-2"}),$(" "+r(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const $t=g(pt,[["render",ht]]),vt=v({name:"TaskPreview",components:{ElImage:ue,CopyToClipboard:le,FontAwesomeIcon:O,ElAlert:de,VideoPlayer:ie,ElTooltip:ce,ElButton:R},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),gt={class:"preview"},bt={class:"left"},kt={class:"main"},wt={class:"bot"},yt={class:"datetime"},St={class:"info"},Vt={key:0,class:"prompt mt-2"},Et={key:0},It={key:1},At={key:0,class:L({content:!0,failed:!0})},Lt={key:0,class:"mb-4"},Tt={key:1,class:L({operations:!0,"mt-2":!0})},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Rt={key:1,class:L({content:!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},zt={key:2,class:L({content:!0})},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Ft(e,o,d,_,b,k){const c=a("el-image"),u=a("video-player"),n=a("el-button"),w=a("el-tooltip"),h=a("font-awesome-icon"),m=a("copy-to-clipboard"),V=a("el-alert");return s(),l("div",gt,[i("div",bt,[t(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),i("div",kt,[i("div",wt,[$(r(e.$t("sora.name.soraBot"))+" ",1),i("span",yt,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",St,[e.modelValue?.request?.prompt?(s(),l("p",Vt,[$(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(s(),l("span",Et," - ("+r(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(s(),l("span",It," - ("+r(e.$t("sora.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(s(),l("div",At,[e.modelValue?.response?.data[0]?.video_url?(s(),l("div",Lt,[t(u,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response.success?(s(),l("div",Tt,[t(w,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response?.data[0]?.video_url?(s(),y(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=G=>e.onDownload(G,e.modelValue?.response?.data[0]?.video_url))},{default:p(()=>[$(r(e.$t("sora.button.download")),1)]),_:1})):f("",!0)]),_:1},8,["content"])])):f("",!0),t(V,{closable:!1,class:"mt-2 success"},{default:p(()=>[i("p",Ct,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),$(" "+r(e.$t("sora.name.model"))+": "+r(e.modelValue?.request?.model),1)]),i("p",Ot,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+r(e.$t("sora.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(m,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0),e.modelValue?.response?.success===!1?(s(),l("div",Rt,[t(V,{closable:!1,class:"failure"},{template:p(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+r(e.$t("sora.name.failure")),1)]),default:p(()=>[i("p",Dt,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+r(e.$t("sora.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(m,{content:e.modelValue?.id},null,8,["content"])]),i("p",Ut,[t(h,{icon:"fa-solid fa-circle-info",class:"mr-1"}),$(" "+r(e.$t("sora.name.failureReason"))+": "+r(e.modelValue?.response?.error?.message)+" ",1),t(m,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(s(),l("p",Gt,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),$(" "+r(e.$t("sora.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),t(m,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):f("",!0)]),_:1})])):f("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",zt,[t(V,{closable:!1,class:"info"},{template:p(()=>[t(h,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+r(e.$t("sora.name.failure")),1)]),default:p(()=>[i("p",Pt,[t(h,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+r(e.$t("sora.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(m,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(s(),l("p",Mt,[t(h,{icon:"fa-solid fa-hashtag",class:"mr-1"}),$(" "+r(e.$t("sora.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),t(m,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):f("",!0)]),_:1})])):f("",!0)])])}const jt=g(vt,[["render",Ft],["__scopeId","data-v-183a4d07"]]),Nt=v({name:"RecentPanel",components:{TaskPreview:jt,NoTasks:ae,BotPlaceholder:pe},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),Bt={key:0},qt={key:1,class:"tasks h-full w-full overflow-y-auto"},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,o,d,_,b,k){const c=a("bot-placeholder"),u=a("task-preview"),n=a("no-tasks");return s(),l(S,null,[e.tasks?.items===void 0?(s(),l("div",Bt,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),l("div",qt,[(s(!0),l(S,null,T(e.tasks?.items,(w,h)=>(s(),y(u,{key:h,"model-value":w},null,8,["model-value"]))),128))])):f("",!0),e.tasks?.items?.length===0?(s(),l("div",Ht,[t(n)])):f("",!0)],64)}const Kt=g(Nt,[["render",Jt]]),Wt="https://webhook.acedata.cloud/sora",Zt=v({name:"SoraIndex",components:{ConfigPanel:$t,Layout:ve,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.sora?.status?.getApplications===ee.Request},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:d,createdAtMax:_}=e||{};console.debug("limit",o,"createdAtMin",d,"createdAtMax",_),await this.$store.dispatch("sora/getTasks",{limit:o,createdAtMin:d,createdAtMax:_})},async onGenerate(){const e={...this.config,callback_url:Wt},o=this.credential?.token;if(!o){console.error("no token specified");return}A.info(this.$t("sora.message.startingTask")),Y.generate(e,{token:o}).then(()=>{A.success(this.$t("sora.message.startTaskSuccess"))}).catch(d=>{d?.response?.data?.error?.code===x?A.error(this.$t("sora.message.usedUp")):A.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Qt(e,o,d,_,b,k){const c=a("config-panel"),u=a("recent-panel"),n=a("layout");return s(),y(n,null,{config:p(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[t(u,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Ro=g(Zt,[["render",Qt]]);export{Ro as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as S}from"./index.es-D1pJr9hZ.js";import{E as U}from"./index-GcOzATQL.js";import{E as O}from"./index-DEXuGCWk.js";import{d as k,h as y,b as i,t as l,k as o,r as G,j as _,l as n,o as a,e_ as D,x as c,F as V,v as I,i as w,c7 as F,D as g,e$ as q,y as $,n as L,ai as z,f0 as M,ds as W,dn as x}from"./index-DWIIosE4.js";import{E as j,a as N}from"./index-DnwCzjob.js";import{I as P}from"./InfoIcon-BflahWxT.js";import{E as H}from"./index-YvY81tTD.js";import{I as B}from"./ImagePreview-p5_RqQz1.js";import{E as K}from"./index-BGYIpMvx.js";import{E}from"./index-BFgUesf6.js";import{C as J,N as Q}from"./NoTasks-qn9MLJ-D.js";import{a as X}from"./price-BYVPw8Af.js";import{C as Y}from"./CopyToClipboard-O565qcMZ.js";import{I as Z}from"./ImageWrapper-DgBKf-7i.js";import{E as ee}from"./index-BPEPCjAr.js";import{E as te}from"./index-CeLCECpN.js";import{E as oe}from"./index-B5BZx-QW.js";import{B as ne}from"./BotPlaceholder-C25LBTud.js";import"./use-form-item-B1Hr2fTx.js";import"./index-r5W6hzzQ.js";import"./index-CCNe6ApW.js";import"./typescript-CdgndEnB.js";import"./index-6j6xERKd.js";import"./strings-BmOP-I9J.js";import"./castArray-CD7UiqMH.js";import"./isEqual-B7zzcc8k.js";import"./_initCloneObject-D45zvZL4.js";import"./debounce-C_L6yTYD.js";import"./_baseIteratee-C4j1VLPq.js";import"./index-Bc66ZYjN.js";import"./index-Du2C0qPs.js";import"./index-B5je-JKn.js";import"./_baseClone-wpyOdoMw.js";import"./index-DAvd6Xob.js";const ae=k({name:"LayoutNanobanana",components:{ElDrawer:O,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),se={class:"main flex flex-row flex-1"},re={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},le={class:"result h-full p-[15px] flex-1 flex flex-col"};function ie(e,t,f,s,u,h){const m=n("font-awesome-icon"),d=n("el-button"),r=n("el-drawer");return a(),i("div",se,[l("div",re,[G(e.$slots,"config",{},void 0,!0)]),l("div",le,[G(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=b=>e.drawer=!0)},{default:_(()=>[o(m,{icon:"fa-solid fa-magic"})]),_:1}),o(r,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[G(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ce=y(ae,[["render",ie],["__scopeId","data-v-3794959b"]]),pe=k({name:"ActionSelector",components:{ElSelect:N,ElOption:j},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"generate",label:this.$t("nanobanana.name.generate")},{value:"edit",label:this.$t("nanobanana.name.edits")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.action},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana.config,action:e})}}},mounted(){this.value||(this.value=D)}}),ue={class:"field"},me={class:"title font-bold"};function de(e,t,f,s,u,h){const m=n("el-option"),d=n("el-select");return a(),i("div",ue,[l("h2",me,c(e.$t("nanobanana.name.task")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:_(()=>[(a(!0),i(V,null,I(e.options,r=>(a(),w(m,{key:r.value,label:r.label,value:r.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const fe=y(pe,[["render",de],["__scopeId","data-v-53bf2549"]]),_e="",he=k({name:"PromptInput",components:{ElInput:H,InfoIcon:P},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=_e)}}),ge={class:"field"},be={class:"box"},$e={class:"title font-bold"};function ve(e,t,f,s,u,h){const m=n("info-icon"),d=n("el-input");return a(),i("div",ge,[l("div",be,[l("h2",$e,c(e.$t("nanobanana.name.prompt")),1),o(m,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=r=>e.prompt=r),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const we=y(he,[["render",ve],["__scopeId","data-v-38b040ab"]]),ke=k({name:"ImageUrlsInput",components:{ElUpload:K,ElButton:U,InfoIcon:P,ImagePreview:B,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:F()+"/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 s=(this.fileList||[]).filter(u=>!u?.response?.file_url);this.fileList=s.length?s:[];return}const t=[];e.forEach(s=>{const u=this.fileList.find(h=>h?.response?.file_url===s||h?.url===s);u?t.push(u):t.push({name:s.split("/").pop()||s,url:s,status:"success",percentage:100,response:{file_url:s}})}),(this.fileList||[]).filter(s=>!s?.response?.file_url).forEach(s=>{t.some(h=>h===s||h?.url===s?.url||h?.response?.file_url===s?.response?.file_url)||t.push(s)}),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()}}}),ye={class:"field flex items-center justify-between"},Ve={class:"title font-bold text-[14px] mb-[10px]"},Ee={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Ie={class:"controls flex items-center"},Ae={class:"file-list flex flex-wrap gap-[10px]"};function Te(e,t,f,s,u,h){const m=n("font-awesome-icon"),d=n("el-button"),r=n("el-upload"),b=n("info-icon"),A=n("image-preview");return a(),i(V,null,[l("div",ye,[l("h2",Ve,c(e.$t("nanobanana.name.imageUrls")),1),l("div",Ee,[l("div",Ie,[o(r,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=p=>e.fileList=p),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:_(()=>[o(d,{size:"small",type:"primary",round:""},{default:_(()=>[o(m,{icon:"fa-solid fa-upload",class:"mr-1"}),g(" "+c(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(b,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",Ae,[(a(!0),i(V,null,I(e.fileList,(p,v)=>(a(),w(A,{key:p.uid||p?.response?.file_url||p.url||v,url:p.url||p?.response?.file_url,name:p.name,percentage:p.percentage,onRemove:C=>e.onRemovePreview(v,p)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ce=y(ke,[["render",Te]]),Re=k({name:"AspectRatioSelector",components:{ElSelect:N,ElOption:j},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),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=q)}}),Se={class:"field"},Ue={class:"title font-bold"};function Le(e,t,f,s,u,h){const m=n("el-option"),d=n("el-select");return a(),i("div",Se,[l("h2",Ue,c(e.$t("nanobanana.name.aspectRatio")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:_(()=>[(a(!0),i(V,null,I(e.options,r=>(a(),w(m,{key:r,label:r,value:r},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=y(Re,[["render",Le],["__scopeId","data-v-e51b32d6"]]),je=k({name:"ConfigPanel",components:{ElButton:U,FontAwesomeIcon:S,PromptInput:we,Consumption:J,ActionSelector:fe,ImageUrlsInput:Ce,AspectRatioSelector:Ge},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){return X(this.config,this.service?.metadata?.price)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ne={class:"flex flex-col h-full"},Pe={class:"flex-1 overflow-y-auto p-[15px]"},Be={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Oe(e,t,f,s,u,h){const m=n("action-selector"),d=n("prompt-input"),r=n("aspect-ratio-selector"),b=n("image-urls-input"),A=n("consumption"),p=n("font-awesome-icon"),v=n("el-button");return a(),i("div",Ne,[l("div",Pe,[o(m,{class:"mb-4"}),o(d,{class:"mb-4"}),e.config?.action==="generate"?(a(),w(r,{key:0,class:"mb-4"})):$("",!0),e.config?.action==="edit"?(a(),w(b,{key:1,class:"mb-4"})):$("",!0)]),l("div",Be,[o(A,{value:e.consumption,service:e.service},null,8,["value","service"]),o(v,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[o(p,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+c(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const De=y(je,[["render",Oe]]),Fe=k({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Y,FontAwesomeIcon:S,ElAlert:te,ImageWrapper:Z,ElButton:U,ElTooltip:ee,ImagePreview:B},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){e&&(console.debug("Edit image:",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,action:"edit",image_urls:[e]}))}}}),qe={class:"preview"},ze={class:"left"},Me={class:"main"},We={class:"bot"},xe={class:"datetime"},He={class:"info"},Ke={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Je={key:1,class:"prompt mt-2"},Qe={key:0},Xe={key:0,class:L({content:!0,failed:!0})},Ye={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ze={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},tt={key:1,class:L({content:!0})},ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},at={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},st={key:2,class:L({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function lt(e,t,f,s,u,h){const m=n("el-image"),d=n("image-preview"),r=n("image-wrapper"),b=n("el-button"),A=n("el-tooltip"),p=n("font-awesome-icon"),v=n("copy-to-clipboard"),C=n("el-alert");return a(),i("div",qe,[l("div",ze,[o(m,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),l("div",Me,[l("div",We,[g(c(e.$t("nanobanana.name.nanobananaBot"))+" ",1),l("span",xe,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",He,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(a(),i("div",Ke,[(a(!0),i(V,null,I(e.modelValue?.request?.image_urls,(T,R)=>(a(),w(d,{key:R,url:T,name:`image-${R+1}`,closable:!1},null,8,["url","name"]))),128))])):$("",!0),e.modelValue?.request?.prompt?(a(),i("p",Je,[g(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(a(),i("span",Qe," - ("+c(e.$t("nanobanana.status.pending"))+") ",1))])):$("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",Xe,[l("div",Ye,[(a(!0),i(V,null,I(e.images,(T,R)=>(a(),w(r,{key:R,src:T?.image_url,"raw-src":T?.image_url},null,8,["src","raw-src"]))),128))]),l("div",Ze,[o(A,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[o(b,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=z(T=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:_(()=>[g(c(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[l("p",et,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),i("div",tt,[o(C,{closable:!1,class:"failure"},{template:_(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failure")),1)]),default:_(()=>[l("p",ot,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",nt,[o(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),i("p",at,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?$("",!0):(a(),i("div",st,[o(C,{closable:!1,class:"info"},{template:_(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failure")),1)]),default:_(()=>[l("p",rt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const it=y(Fe,[["render",lt],["__scopeId","data-v-4450fc95"]]),ct=k({name:"RecentPanel",components:{TaskPreview:it,BotPlaceholder:ne,NoTasks:Q},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{onHandleScroll(){this.$refs.panel.scrollTop===0&&this.$emit("reach-top")}}}),pt={key:0},ut={key:1,class:"tasks h-full w-full overflow-y-auto"},mt={key:2,class:"w-full h-full flex items-center justify-center"};function dt(e,t,f,s,u,h){const m=n("bot-placeholder"),d=n("task-preview"),r=n("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",pt,[o(m)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),i("div",ut,[(a(!0),i(V,null,I(e.tasks?.items,b=>(a(),w(d,{key:b.id,"model-value":b},null,8,["model-value"]))),128))])):$("",!0),e.tasks?.items?.length===0?(a(),i("div",mt,[o(r)])):$("",!0)],64)}const ft=y(ct,[["render",dt]]),_t="https://webhook.acedata.cloud/nanobanana",ht=k({name:"NanobananaIndex",components:{ConfigPanel:De,Layout:ce,RecentPanel:ft},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.nanobanana?.status?.getApplications===x.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:f,createdAtMax:s}=e||{};console.debug("limit",t,"createdAtMin",f,"createdAtMax",s),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:f,createdAtMax:s})},async onGenerate(){const e={...this.config||{}};e?.action==="generate"&&"image_urls"in e&&delete e.image_urls;const t={...e,callback_url:_t},f=this.credential?.token;if(!f){console.error("no token specified");return}E.info(this.$t("nanobanana.message.startingTask")),M.generate(t,{token:f}).then(()=>{E.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(s=>{const u=s?.response?.data;u?.error?.code===W?E.error(this.$t("nanobanana.message.usedUp")):E.error(this.$t("nanobanana.message.startTaskFailed")+(u?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function gt(e,t,f,s,u,h){const m=n("config-panel"),d=n("recent-panel"),r=n("layout");return a(),w(r,null,{config:_(()=>[o(m,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[o(d,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Yt=y(ht,[["render",gt]]);export{Yt as default};
|
|
1
|
+
import{F as S}from"./index.es-B92faSi8.js";import{E as U}from"./index-CgzNR6Br.js";import{E as O}from"./index-C1h2SbZU.js";import{d as k,h as y,b as i,t as l,k as o,r as G,j as _,l as n,o as a,fa as D,x as c,F as V,v as I,i as w,c9 as q,D as g,fb as F,y as $,n as L,ak as z,fc as M,du as W,dq as x}from"./index-BZbKTMK3.js";import{E as j,a as N}from"./index-BNbrEyG8.js";import{I as P}from"./InfoIcon-DhMpzlKc.js";import{E as H}from"./index-DSYfQpVb.js";import{I as B}from"./ImagePreview-BvPOSpDB.js";import{E as K}from"./index-yxRIEND6.js";import{E}from"./index-hrpdMjUu.js";import{C as J,N as Q}from"./NoTasks-DmNkmZBC.js";import{a as X}from"./price-B8COZ-j4.js";import{C as Y}from"./CopyToClipboard-CuCD6yxS.js";import{I as Z}from"./ImageWrapper-BChXhEi0.js";import{E as ee}from"./index-BDYxvVsV.js";import{E as te}from"./index-D0cZ5BM8.js";import{E as oe}from"./index-Cu3La3dR.js";import{B as ne}from"./BotPlaceholder-6rksUZSI.js";import"./use-form-item-9EKLSUpL.js";import"./index-r5W6hzzQ.js";import"./index-BKJPB7EB.js";import"./typescript-CkR2OWnN.js";import"./index-CZi_rDaW.js";import"./strings-BQbdUIFn.js";import"./castArray-BeCWKAC7.js";import"./isEqual-DIgYivsv.js";import"./_initCloneObject-DL2KWEpg.js";import"./debounce-kw1MDyXj.js";import"./_baseIteratee-LzESfPbZ.js";import"./index-Tp13-pBQ.js";import"./index-CjhBlm5C.js";import"./index-oeBw24Ll.js";import"./_baseClone-CyEUgRjr.js";import"./index-Rl2p1NyF.js";const ae=k({name:"LayoutNanobanana",components:{ElDrawer:O,ElButton:U,FontAwesomeIcon:S},data(){return{drawer:!1}}}),se={class:"main flex flex-row flex-1"},re={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},le={class:"result h-full p-[15px] flex-1 flex flex-col"};function ie(e,t,f,s,u,h){const m=n("font-awesome-icon"),d=n("el-button"),r=n("el-drawer");return a(),i("div",se,[l("div",re,[G(e.$slots,"config",{},void 0,!0)]),l("div",le,[G(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=b=>e.drawer=!0)},{default:_(()=>[o(m,{icon:"fa-solid fa-magic"})]),_:1}),o(r,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[G(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ce=y(ae,[["render",ie],["__scopeId","data-v-3794959b"]]),pe=k({name:"ActionSelector",components:{ElSelect:N,ElOption:j},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"generate",label:this.$t("nanobanana.name.generate")},{value:"edit",label:this.$t("nanobanana.name.edits")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.action},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana.config,action:e})}}},mounted(){this.value||(this.value=D)}}),ue={class:"field"},me={class:"title font-bold"};function de(e,t,f,s,u,h){const m=n("el-option"),d=n("el-select");return a(),i("div",ue,[l("h2",me,c(e.$t("nanobanana.name.task")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:_(()=>[(a(!0),i(V,null,I(e.options,r=>(a(),w(m,{key:r.value,label:r.label,value:r.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const fe=y(pe,[["render",de],["__scopeId","data-v-53bf2549"]]),_e="",he=k({name:"PromptInput",components:{ElInput:H,InfoIcon:P},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=_e)}}),ge={class:"field"},be={class:"box"},$e={class:"title font-bold"};function ve(e,t,f,s,u,h){const m=n("info-icon"),d=n("el-input");return a(),i("div",ge,[l("div",be,[l("h2",$e,c(e.$t("nanobanana.name.prompt")),1),o(m,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=r=>e.prompt=r),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const we=y(he,[["render",ve],["__scopeId","data-v-38b040ab"]]),ke=k({name:"ImageUrlsInput",components:{ElUpload:K,ElButton:U,InfoIcon:P,ImagePreview:B,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:q()+"/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 s=(this.fileList||[]).filter(u=>!u?.response?.file_url);this.fileList=s.length?s:[];return}const t=[];e.forEach(s=>{const u=this.fileList.find(h=>h?.response?.file_url===s||h?.url===s);u?t.push(u):t.push({name:s.split("/").pop()||s,url:s,status:"success",percentage:100,response:{file_url:s}})}),(this.fileList||[]).filter(s=>!s?.response?.file_url).forEach(s=>{t.some(h=>h===s||h?.url===s?.url||h?.response?.file_url===s?.response?.file_url)||t.push(s)}),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()}}}),ye={class:"field flex items-center justify-between"},Ve={class:"title font-bold text-[14px] mb-[10px]"},Ee={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Ie={class:"controls flex items-center"},Ae={class:"file-list flex flex-wrap gap-[10px]"};function Te(e,t,f,s,u,h){const m=n("font-awesome-icon"),d=n("el-button"),r=n("el-upload"),b=n("info-icon"),A=n("image-preview");return a(),i(V,null,[l("div",ye,[l("h2",Ve,c(e.$t("nanobanana.name.imageUrls")),1),l("div",Ee,[l("div",Ie,[o(r,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=p=>e.fileList=p),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:_(()=>[o(d,{size:"small",type:"primary",round:""},{default:_(()=>[o(m,{icon:"fa-solid fa-upload",class:"mr-1"}),g(" "+c(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(b,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),l("div",Ae,[(a(!0),i(V,null,I(e.fileList,(p,v)=>(a(),w(A,{key:p.uid||p?.response?.file_url||p.url||v,url:p.url||p?.response?.file_url,name:p.name,percentage:p.percentage,onRemove:C=>e.onRemovePreview(v,p)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Ce=y(ke,[["render",Te]]),Re=k({name:"AspectRatioSelector",components:{ElSelect:N,ElOption:j},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),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=F)}}),Se={class:"field"},Ue={class:"title font-bold"};function Le(e,t,f,s,u,h){const m=n("el-option"),d=n("el-select");return a(),i("div",Se,[l("h2",Ue,c(e.$t("nanobanana.name.aspectRatio")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:_(()=>[(a(!0),i(V,null,I(e.options,r=>(a(),w(m,{key:r,label:r,value:r},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=y(Re,[["render",Le],["__scopeId","data-v-e51b32d6"]]),je=k({name:"ConfigPanel",components:{ElButton:U,FontAwesomeIcon:S,PromptInput:we,Consumption:J,ActionSelector:fe,ImageUrlsInput:Ce,AspectRatioSelector:Ge},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){return X(this.config,this.service?.metadata?.price)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ne={class:"flex flex-col h-full"},Pe={class:"flex-1 overflow-y-auto p-[15px]"},Be={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Oe(e,t,f,s,u,h){const m=n("action-selector"),d=n("prompt-input"),r=n("aspect-ratio-selector"),b=n("image-urls-input"),A=n("consumption"),p=n("font-awesome-icon"),v=n("el-button");return a(),i("div",Ne,[l("div",Pe,[o(m,{class:"mb-4"}),o(d,{class:"mb-4"}),e.config?.action==="generate"?(a(),w(r,{key:0,class:"mb-4"})):$("",!0),e.config?.action==="edit"?(a(),w(b,{key:1,class:"mb-4"})):$("",!0)]),l("div",Be,[o(A,{value:e.consumption,service:e.service},null,8,["value","service"]),o(v,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[o(p,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+c(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const De=y(je,[["render",Oe]]),qe=k({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Y,FontAwesomeIcon:S,ElAlert:te,ImageWrapper:Z,ElButton:U,ElTooltip:ee,ImagePreview:B},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){e&&(console.debug("Edit image:",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,action:"edit",image_urls:[e]}))}}}),Fe={class:"preview"},ze={class:"left"},Me={class:"main"},We={class:"bot"},xe={class:"datetime"},He={class:"info"},Ke={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},Je={key:1,class:"prompt mt-2"},Qe={key:0},Xe={key:0,class:L({content:!0,failed:!0})},Ye={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Ze={class:L({operations:!0,"mt-2":!0,"mb-2":!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},tt={key:1,class:L({content:!0})},ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},at={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},st={key:2,class:L({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function lt(e,t,f,s,u,h){const m=n("el-image"),d=n("image-preview"),r=n("image-wrapper"),b=n("el-button"),A=n("el-tooltip"),p=n("font-awesome-icon"),v=n("copy-to-clipboard"),C=n("el-alert");return a(),i("div",Fe,[l("div",ze,[o(m,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),l("div",Me,[l("div",We,[g(c(e.$t("nanobanana.name.nanobananaBot"))+" ",1),l("span",xe,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",He,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(a(),i("div",Ke,[(a(!0),i(V,null,I(e.modelValue?.request?.image_urls,(T,R)=>(a(),w(d,{key:R,url:T,name:`image-${R+1}`,closable:!1},null,8,["url","name"]))),128))])):$("",!0),e.modelValue?.request?.prompt?(a(),i("p",Je,[g(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(a(),i("span",Qe," - ("+c(e.$t("nanobanana.status.pending"))+") ",1))])):$("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",Xe,[l("div",Ye,[(a(!0),i(V,null,I(e.images,(T,R)=>(a(),w(r,{key:R,src:T?.image_url,"raw-src":T?.image_url},null,8,["src","raw-src"]))),128))]),l("div",Ze,[o(A,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:_(()=>[o(b,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=z(T=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:_(()=>[g(c(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(C,{closable:!1,class:"mt-2 success"},{default:_(()=>[l("p",et,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),i("div",tt,[o(C,{closable:!1,class:"failure"},{template:_(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failure")),1)]),default:_(()=>[l("p",ot,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",nt,[o(p,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),i("p",at,[o(p,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?$("",!0):(a(),i("div",st,[o(C,{closable:!1,class:"info"},{template:_(()=>[o(p,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.failure")),1)]),default:_(()=>[l("p",rt,[o(p,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+c(e.$t("nanobanana.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const it=y(qe,[["render",lt],["__scopeId","data-v-4450fc95"]]),ct=k({name:"RecentPanel",components:{TaskPreview:it,BotPlaceholder:ne,NoTasks:Q},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{onHandleScroll(){this.$refs.panel.scrollTop===0&&this.$emit("reach-top")}}}),pt={key:0},ut={key:1,class:"tasks h-full w-full overflow-y-auto"},mt={key:2,class:"w-full h-full flex items-center justify-center"};function dt(e,t,f,s,u,h){const m=n("bot-placeholder"),d=n("task-preview"),r=n("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",pt,[o(m)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),i("div",ut,[(a(!0),i(V,null,I(e.tasks?.items,b=>(a(),w(d,{key:b.id,"model-value":b},null,8,["model-value"]))),128))])):$("",!0),e.tasks?.items?.length===0?(a(),i("div",mt,[o(r)])):$("",!0)],64)}const ft=y(ct,[["render",dt]]),_t="https://webhook.acedata.cloud/nanobanana",ht=k({name:"NanobananaIndex",components:{ConfigPanel:De,Layout:ce,RecentPanel:ft},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.nanobanana?.status?.getApplications===x.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:f,createdAtMax:s}=e||{};console.debug("limit",t,"createdAtMin",f,"createdAtMax",s),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:f,createdAtMax:s})},async onGenerate(){const e={...this.config||{}};e?.action==="generate"&&"image_urls"in e&&delete e.image_urls;const t={...e,callback_url:_t},f=this.credential?.token;if(!f){console.error("no token specified");return}E.info(this.$t("nanobanana.message.startingTask")),M.generate(t,{token:f}).then(()=>{E.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(s=>{const u=s?.response?.data;u?.error?.code===W?E.error(this.$t("nanobanana.message.usedUp")):E.error(this.$t("nanobanana.message.startTaskFailed")+(u?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function gt(e,t,f,s,u,h){const m=n("config-panel"),d=n("recent-panel"),r=n("layout");return a(),w(r,null,{config:_(()=>[o(m,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[o(d,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Yt=y(ht,[["render",gt]]);export{Yt as default};
|