@acedatacloud/nexior 3.39.0 → 3.40.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{Auth-DULrVYVC.js → Auth-BbfMVgRA.js} +1 -1
- package/dist/assets/{BotPlaceholder-B9Ww1aFe.js → BotPlaceholder-CdQRRE9L.js} +1 -1
- package/dist/assets/{Callback-DB6VsxSu.js → Callback-WKEAie0Z.js} +1 -1
- package/dist/assets/{Console-m-2kLU5c.js → Console-esmrpHj9.js} +1 -1
- package/dist/assets/{Consumption-CYxLWzfB.js → Consumption-BBl6mTTl.js} +1 -1
- package/dist/assets/{Conversation-Cj0tmGpI.js → Conversation-BfmzuyFd.js} +8 -8
- package/dist/assets/{Conversation-BMY_hUX2.css → Conversation-Xn9axh9Y.css} +1 -1
- package/dist/assets/{CopyToClipboard-DZ-hkTy6.js → CopyToClipboard-_MScsaoK.js} +1 -1
- package/dist/assets/{Detail-DI1bc4mQ.js → Detail-BItMwW4_.js} +2 -2
- package/dist/assets/{EditArray-CIa3ND0t.js → EditArray-MR-P9uH_.js} +1 -1
- package/dist/assets/{Extra-CTtAVTv3.js → Extra-g442FrUq.js} +1 -1
- package/dist/assets/{FilePreview-DrY18bah.js → FilePreview-BJtqKFUz.js} +1 -1
- package/dist/assets/{History-DtLSxQ9h.js → History-C6aUJHot.js} +1 -1
- package/dist/assets/{ImagePreview-DKQRiQ0j.js → ImagePreview-DYflUdpS.js} +1 -1
- package/dist/assets/{ImageWrapper-ojoZewc8.js → ImageWrapper-D1hV5cj0.js} +1 -1
- package/dist/assets/{Index-CKXOS0UE.js → Index--FDuI1U0.js} +1 -1
- package/dist/assets/{Index-B8ol-aOh.js → Index-B6haJzg0.js} +1 -1
- package/dist/assets/{Index-BuMHRKS_.js → Index-B8mSjmw9.js} +1 -1
- package/dist/assets/{Index-BlmmK8vQ.js → Index-B_W2hTi5.js} +1 -1
- package/dist/assets/{Index-d1re_GiC.js → Index-BsYUnuih.js} +1 -1
- package/dist/assets/{Index-diYQwpZD.js → Index-BtMn9GDs.js} +1 -1
- package/dist/assets/{Index-C9wjakQQ.js → Index-CBwC3ZlU.js} +1 -1
- package/dist/assets/{Index-BRYJ_LD2.js → Index-CHxYA8ZI.js} +1 -1
- package/dist/assets/{Index-LLKF8NP-.js → Index-CbiX8uxT.js} +1 -1
- package/dist/assets/{Index-CUBYRhSH.js → Index-CeZsIIHJ.js} +1 -1
- package/dist/assets/{Index-DiWePb6Y.js → Index-CgcjN5nq.js} +1 -1
- package/dist/assets/{Index-BI3YZdz1.js → Index-CiYDcK2a.js} +1 -1
- package/dist/assets/{Index-BuOKUD_r.js → Index-Cl5LTPY-.js} +1 -1
- package/dist/assets/{Index-J-nQBiBP.js → Index-Cma8jQim.js} +1 -1
- package/dist/assets/{Index-gFIpUggR.js → Index-D5E_i1dO.js} +1 -1
- package/dist/assets/{Index-B9jiRvGf.js → Index-D6XLoKdo.js} +1 -1
- package/dist/assets/{Index-Db6Kknc4.js → Index-DCsKZjrv.js} +1 -1
- package/dist/assets/{Index-B-yZ-l8r.js → Index-DM7EUVU5.js} +1 -1
- package/dist/assets/{Index-CjBReyy1.js → Index-DYKkltRZ.js} +1 -1
- package/dist/assets/{Index-CxJQZBRf.js → Index-GKRA6GJ2.js} +1 -1
- package/dist/assets/{Index-Jc9FI1hb.js → Index-S_y1HYlj.js} +1 -1
- package/dist/assets/{Index-pSJJf2uJ.js → Index-TbSsQzFY.js} +1 -1
- package/dist/assets/{Index-CbOOJZ5M.js → Index-V98MxuiO.js} +1 -1
- package/dist/assets/{Index-DUMG3CE3.js → Index-hRydZbT6.js} +1 -1
- package/dist/assets/{Invitees-BLqsKup3.js → Invitees-BA8Ybow6.js} +1 -1
- package/dist/assets/{List-D7APfSkZ.js → List-6NtI3nnu.js} +1 -1
- package/dist/assets/{List-D2EmhqIO.js → List-D4Kt236q.js} +1 -1
- package/dist/assets/{List-BjDUWhof.js → List-D7jTxj6b.js} +1 -1
- package/dist/assets/{Main-DUTUxec7.js → Main-CfNzPcOe.js} +1 -1
- package/dist/assets/{Navigator-D-cANjUI.js → Navigator-D7znSaFu.js} +1 -1
- package/dist/assets/{NoTasks-CIXbmsjQ.js → NoTasks-RLiH-azt.js} +1 -1
- package/dist/assets/{OAuthCallback-CULHo_Tu.js → OAuthCallback-B4lfCiMa.js} +1 -1
- package/dist/assets/{Pagination-B96SB_9q.js → Pagination-CdM5R0GT.js} +1 -1
- package/dist/assets/{ScrollList-DTgkVuLR.js → ScrollList-D_OIXYoa.js} +1 -1
- package/dist/assets/{Status-DRft8ONk.js → Status-BvYR0NL5.js} +1 -1
- package/dist/assets/{Subscribe-C1bDa70a.js → Subscribe-B4c03xf-.js} +1 -1
- package/dist/assets/{TransportWebHID-BFi4KZ_q.js → TransportWebHID-C_KGpN3h.js} +1 -1
- package/dist/assets/{VideoPlayer-ACwtTDeP.js → VideoPlayer-SMrh1I_l.js} +1 -1
- package/dist/assets/{add-DzAWbmaQ.js → add-D5hLFWg4.js} +1 -1
- package/dist/assets/{all-wallets-C-Q-GSKX.js → all-wallets-Dup-DE5U.js} +1 -1
- package/dist/assets/{app-store-D2pI6pcZ.js → app-store-DRrLPN6o.js} +1 -1
- package/dist/assets/{apple-BY9KBMvH.js → apple-BHzFl06X.js} +1 -1
- package/dist/assets/{arrow-bottom-Ce6e1La6.js → arrow-bottom-BFz_2PPj.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-DoimaE1k.js → arrow-bottom-circle-DhFWTDcT.js} +1 -1
- package/dist/assets/{arrow-left-CT-gb3_f.js → arrow-left-CVX7lNnj.js} +1 -1
- package/dist/assets/{arrow-right-DtLPR-VN.js → arrow-right-BmZbBRlx.js} +1 -1
- package/dist/assets/{arrow-top-B689Lohf.js → arrow-top-DtzN0bqn.js} +1 -1
- package/dist/assets/{avatar-C2HlXd8q.js → avatar-B3Sh4UHE.js} +1 -1
- package/dist/assets/{bank-14SxdBw4.js → bank-3119jnDz.js} +1 -1
- package/dist/assets/{basic-B_1o-xIe.js → basic-BMBd3oQg.js} +1 -1
- package/dist/assets/{bignumber-Df3Cckea.js → bignumber-BpAgiA64.js} +1 -1
- package/dist/assets/{browser-C4bslPo3.js → browser-DIJcG5QI.js} +1 -1
- package/dist/assets/{card-BKeqsjAl.js → card-BzdDC90i.js} +1 -1
- package/dist/assets/{checkmark-DmN75zYD.js → checkmark-CXxiLU_h.js} +1 -1
- package/dist/assets/{checkmark-bold-CfL5lZLG.js → checkmark-bold-7YCxivCd.js} +1 -1
- package/dist/assets/{chevron-bottom-CK86jgbh.js → chevron-bottom-I8OZrEQH.js} +1 -1
- package/dist/assets/{chevron-left-CQcfFHH8.js → chevron-left-DJur9zCQ.js} +1 -1
- package/dist/assets/{chevron-right-CLRHniop.js → chevron-right-C4G0BeYy.js} +1 -1
- package/dist/assets/{chevron-top-DSfuzvr0.js → chevron-top-BxdPj3Da.js} +1 -1
- package/dist/assets/{chrome-store-Cu1FjnkN.js → chrome-store-Bqfy0aGE.js} +1 -1
- package/dist/assets/{clock-DaWQHmHB.js → clock-DSnWSxJ4.js} +1 -1
- package/dist/assets/{close-bMVl8sPK.js → close-BNDBCrHm.js} +1 -1
- package/dist/assets/{coinPlaceholder-CKRLXBoy.js → coinPlaceholder-4BEq4_o-.js} +1 -1
- package/dist/assets/{compass-HPgLsDyV.js → compass-CDuOGmPJ.js} +1 -1
- package/dist/assets/{copy-DV702Out.js → copy-FOAfamKu.js} +1 -1
- package/dist/assets/{cursor-BizrN5yL.js → cursor-C91NKln1.js} +1 -1
- package/dist/assets/{cursor-transparent-DtBQD998.js → cursor-transparent-QLmz3aH0.js} +1 -1
- package/dist/assets/{desktop-BB0_yTru.js → desktop-C_cQSpKC.js} +1 -1
- package/dist/assets/{disconnect-6nEf9wc2.js → disconnect-JVL8XUiH.js} +1 -1
- package/dist/assets/{discord-BRYeJyqs.js → discord-CBMldl0b.js} +1 -1
- package/dist/assets/{distribution-BtBkwRRT.js → distribution-CuIW5q7S.js} +1 -1
- package/dist/assets/{etherscan-CKl92LBc.js → etherscan-BrKRHTHX.js} +1 -1
- package/dist/assets/{exclamation-triangle-CCd9Gfyj.js → exclamation-triangle-DB4Ewy06.js} +1 -1
- package/dist/assets/{extension-Dq2t_PPn.js → extension-CHZ70rUq.js} +1 -1
- package/dist/assets/{external-link-pr-SQ8YT.js → external-link-CYXS1X6_.js} +1 -1
- package/dist/assets/{facebook-DdJv4ZKt.js → facebook-DCFhpXlw.js} +1 -1
- package/dist/assets/{farcaster-G1nMRd3g.js → farcaster-MSNHkBnO.js} +1 -1
- package/dist/assets/{filters-Bt2GCvxa.js → filters-CV0PFaua.js} +1 -1
- package/dist/assets/{github-DzEOIakb.js → github-BNovLNp2.js} +1 -1
- package/dist/assets/{google-_Sa__qj-.js → google-C7QfBjAV.js} +1 -1
- package/dist/assets/{help-circle-KT2jCidJ.js → help-circle-newufXC0.js} +1 -1
- package/dist/assets/{id-BDIDX24R.js → id-Da-Z42NO.js} +1 -1
- package/dist/assets/{image-V63z36yv.js → image-DPvHTULW.js} +1 -1
- package/dist/assets/{index-DKuuwhRE.js → index-B5HiyjLZ.js} +7 -7
- package/dist/assets/{index-CR2O5iwt.js → index-B7tJkFtV.js} +1 -1
- package/dist/assets/{index-9Z3s9vER.js → index-BAMIeHYH.js} +1 -1
- package/dist/assets/{index-DqpLng1I.js → index-Be2UfxEe.js} +1 -1
- package/dist/assets/{index-D0vO2565.js → index-CjUw7pA3.js} +29 -29
- package/dist/assets/{index-BZH4xSG9.js → index-DHVT3avY.js} +1 -1
- package/dist/assets/{index-tqcowstn.js → index-Dzs44j5R.js} +3 -3
- package/dist/assets/{index-Chn-DN0T.js → index-MGKg_53O.js} +1 -1
- package/dist/assets/{index-CcFtMru9.js → index-MH9TytSE.js} +1 -1
- package/dist/assets/{index-BhDhLSKE.js → index-cjCwx4_h.js} +1 -1
- package/dist/assets/{index.browser.esm-CWwRaw8s.js → index.browser.esm-K35WXslC.js} +1 -1
- package/dist/assets/{index.es-Q4HJJnLN.js → index.es-p8_rCeM7.js} +1 -1
- package/dist/assets/{info-CCrGNsvU.js → info-DeDTWA02.js} +1 -1
- package/dist/assets/{info-circle-B_uXnoCn.js → info-circle-Cc2OVT_S.js} +1 -1
- package/dist/assets/{lightbulb-25RHD0P4.js → lightbulb-C-xqcrNR.js} +1 -1
- package/dist/assets/{mail-DhOV-I_J.js → mail-6hqreXpc.js} +1 -1
- package/dist/assets/{mobile-Dtwt2n3D.js → mobile-LjzAgBFN.js} +1 -1
- package/dist/assets/{more-ColoEcBE.js → more-DSGtFuF-.js} +1 -1
- package/dist/assets/{network-placeholder-DHAJJeIx.js → network-placeholder-BlmM5o66.js} +1 -1
- package/dist/assets/{nftPlaceholder-DiJc2RhW.js → nftPlaceholder-tKKnjlKv.js} +1 -1
- package/dist/assets/{off-B4RFjHNh.js → off-CFftYxwG.js} +1 -1
- package/dist/assets/{order-DUr8hGM-.js → order-B-WHKBBH.js} +1 -1
- package/dist/assets/{play-store-BK_xoWfl.js → play-store-CzhL6rt_.js} +1 -1
- package/dist/assets/{plus-Dq-Dmc7x.js → plus-9GFplFZz.js} +1 -1
- package/dist/assets/{price-BxyGBvpv.js → price-CbJb5IRW.js} +1 -1
- package/dist/assets/{qr-code-BI7lfdrx.js → qr-code-D59eqZQU.js} +1 -1
- package/dist/assets/{recycle-horizontal-C3G6nbhF.js → recycle-horizontal-C3eguG45.js} +1 -1
- package/dist/assets/{refresh-8YhrVSu_.js → refresh-ORde1OtV.js} +1 -1
- package/dist/assets/{reown-logo-C0DAxZe9.js → reown-logo-CGuZ3SXw.js} +1 -1
- package/dist/assets/{search-Cyw3suPr.js → search-CRGRq9Fm.js} +1 -1
- package/dist/assets/{secp256k1-Dtotceig.js → secp256k1-CB4NxLgY.js} +1 -1
- package/dist/assets/{secp256k1-J740LWdw.js → secp256k1-ElwdGYdi.js} +1 -1
- package/dist/assets/{send-CkH9x4NW.js → send-D5PFK3CS.js} +1 -1
- package/dist/assets/{solana-wallets-DCHhejMj.js → solana-wallets-qO89qAY4.js} +2 -2
- package/dist/assets/{solana-wallets-vue-BZgXY5It.js → solana-wallets-vue-BmOIBoLp.js} +1 -1
- package/dist/assets/{solanaEmbed.esm-C-L32rVL.js → solanaEmbed.esm-DNEKblFn.js} +1 -1
- package/dist/assets/{string_decoder-D7ymg8hN.js → string_decoder-BTnL9J_h.js} +1 -1
- package/dist/assets/{swapHorizontal-BpJZZgCG.js → swapHorizontal-Cu_g2w-M.js} +1 -1
- package/dist/assets/{swapHorizontalBold-jf6RbZ3Z.js → swapHorizontalBold-D_fueFv2.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-DiODKF-T.js → swapHorizontalMedium-BkyPR-8I.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-DnrrjXNQ.js → swapHorizontalRoundedBold-Dt5QETSS.js} +1 -1
- package/dist/assets/{swapVertical-hbZOlsvI.js → swapVertical-Bm4jBOMe.js} +1 -1
- package/dist/assets/{telegram-DC670vUO.js → telegram-Cx5sSyFM.js} +1 -1
- package/dist/assets/{three-dots-tuhIyikw.js → three-dots-CUgRPfll.js} +1 -1
- package/dist/assets/{twitch-BohURGxQ.js → twitch-C7y0mBjN.js} +1 -1
- package/dist/assets/{twitterIcon-CBMkIrjS.js → twitterIcon-B12jJpcP.js} +1 -1
- package/dist/assets/{verify-CEsMn4f3.js → verify-CpjiYs7d.js} +1 -1
- package/dist/assets/{verify-filled-CW3a2eJh.js → verify-filled-CFkQULQQ.js} +1 -1
- package/dist/assets/{w3m-modal-DAALPFfK.js → w3m-modal-ySMj_sSw.js} +1 -1
- package/dist/assets/{wallet-DAiXY9mg.js → wallet-BZ6shP18.js} +1 -1
- package/dist/assets/{wallet-placeholder-BnUqVZup.js → wallet-placeholder-19nzd6b0.js} +1 -1
- package/dist/assets/{walletconnect-CUjtNkFF.js → walletconnect-BhWFSdeo.js} +1 -1
- package/dist/assets/{warning-circle-T7iAnm6a.js → warning-circle-C_qlcDnA.js} +1 -1
- package/dist/assets/{web-dNqPnBRw.js → web-BQ6ReaNu.js} +1 -1
- package/dist/assets/{web-CSDLhi1Z.js → web-CdYjA9cB.js} +1 -1
- package/dist/assets/{x-C5mUIwaL.js → x-T2q97UP1.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as z}from"./index.es-Q4HJJnLN.js";import{d as B,U as ye,c as Ue,o as Pe,w as le,x as re,v as x,u as Q,X as be,Y as ke,B as de,O as Ee,p as w,N as W,n as ue,a1 as ce,a2 as pe,V as ee,z as te,t as O,W as me,$ as Ie,a0 as Re,a5 as Le,r as Me,s as Fe,l as we,R as Ce,C as De,i as ze,I as Ve,Z as Se,J as Te,G as Ae,k as je,j as Ge,a3 as Be,a4 as Oe}from"./vendor-element-plus-CQnKmb2Y.js";import{d as A,C as u,G as s,T as o,E as ne,K as a,ai as l,D as n,O as c,M as G,R as i,S as M,ag as D,J as b,Q as v,af as ie,L as N,aq as H,X as P,c as q,u as j,w as Ne,U as qe}from"./vendor-vue-qgt_zvDa.js";import{a as E,cB as We,cC as L,q as He,S as X,ck as oe,d as Ke,E as Je}from"./index-D0vO2565.js";import{I as F,S as Qe}from"./ScrollList-DTgkVuLR.js";import{u as Z,F as Ye,O as Xe,_ as fe,P as Ze,a as xe,V as et}from"./IconPark.vue_vue_type_script_setup_true_lang-CNnhez9x.js";import{C as tt}from"./Consumption-CYxLWzfB.js";import{a as ot}from"./price-BxyGBvpv.js";import{N as st}from"./NoTasks-CIXbmsjQ.js";import{l as nt}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const it=A({name:"LayoutSuno",components:{ElDrawer:ye,ElButton:B,FontAwesomeIcon:z},data(){return{drawer:!1,preview:!1}},computed:{}}),at={class:"main flex flex-row flex-1"},lt={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},rt={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},dt={class:"preview h-full w-[300px] flex flex-col"};function ut(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-drawer");return n(),u("div",at,[s("div",lt,[ne(e.$slots,"config",{},void 0,!0)]),s("div",rt,[ne(e.$slots,"result",{},void 0,!0)]),s("div",dt,[ne(e.$slots,"preview",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[ne(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ct=E(it,[["render",ut],["__scopeId","data-v-c6c85757"]]),pt=A({name:"TypeSelector",components:{ElSelect:re,ElOption:le,ElSwitch:Pe,ElTag:Ue},data(){return{options:[{label:"v5.5",value:"chirp-v5-5",desc:this.$t("suno.model.v55desc"),pro:!0},{label:"v5",value:"chirp-v5",desc:this.$t("suno.model.v5desc"),pro:!0},{label:"v4.5+",value:"chirp-v4-5-plus",desc:this.$t("suno.model.v45plusdesc"),pro:!0},{label:"v4.5",value:"chirp-v4-5",desc:this.$t("suno.model.v45desc"),pro:!0,dividerAfter:!0},{label:"v4",value:"chirp-v4",desc:this.$t("suno.model.v4desc")},{label:"v3.5",value:"chirp-v3-5",desc:this.$t("suno.model.v35desc")},{label:"v3",value:"chirp-v3-0",desc:this.$t("suno.model.v3desc")}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(this.model=We)}}),mt={class:"mode-tabs mb-3"},ft={class:"mb-3"},ht={class:"flex items-center mb-1"},gt={class:"text-sm font-bold"},$t={class:"model-option"},_t={class:"model-option-left"},vt={class:"model-option-name"},yt={class:"model-option-desc"},bt={key:0,class:"flex items-center justify-between mb-3"},kt={class:"text-sm font-bold"};function wt(e,t,d,r,m,y){const $=l("el-tag"),p=l("el-option"),f=l("el-select"),k=l("el-switch");return n(),u("div",null,[s("div",mt,[s("button",{class:G(["mode-tab",{active:!e.custom}]),onClick:t[0]||(t[0]=g=>e.custom=!1)},i(e.$t("suno.mode.simple")),3),s("button",{class:G(["mode-tab",{active:e.custom}]),onClick:t[1]||(t[1]=g=>e.custom=!0)},i(e.$t("suno.mode.custom")),3)]),s("div",ft,[s("div",ht,[s("span",gt,i(e.$t("suno.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[2]||(t[2]=g=>e.model=g),class:"w-full model-select",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:a(()=>[(n(!0),u(M,null,D(e.options,g=>(n(),b(p,{key:g.value,label:g.label,value:g.value,class:G({"model-option-divider":g.dividerAfter})},{default:a(()=>[s("div",$t,[s("div",_t,[s("span",vt,i(g.label),1),g.pro?(n(),b($,{key:0,size:"small",type:"warning",effect:"plain",class:"model-option-pro"},{default:a(()=>t[4]||(t[4]=[v("Pro",-1)])),_:1,__:[4]})):c("",!0)]),s("span",yt,i(g.desc),1)])]),_:2},1032,["label","value","class"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),u("div",bt,[s("span",kt,i(e.$t("suno.name.instrumental")),1),o(k,{modelValue:e.instrumental,"onUpdate:modelValue":t[3]||(t[3]=g=>e.instrumental=g)},null,8,["modelValue"])])):c("",!0)])}const Ct=E(pt,[["render",wt],["__scopeId","data-v-a6ada414"]]),Vt=A({name:"UploadAudio",components:{ElUpload:Ee,ElButton:B,ElDialog:de,ElTabs:ke,ElTabPane:be,InfoIcon:F,FontAwesomeIcon:z,ElRadioGroup:Q,ElRadioButton:x},emits:["change"],data(){return{fileList:[],uploadUrl:He()+"/api/v1/files/",dialogVisible:!1,activeTab:"browse",recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){const e=this.$store.state.suno?.config?.action;return e==="upload_extend"||e==="upload_cover"},uploadAction:{get(){return this.$store.state.suno?.config?.action||"upload_extend"},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,action:e})}},formattedTime(){const e=Math.floor(this.recordSeconds/60).toString().padStart(2,"0"),t=(this.recordSeconds%60).toString().padStart(2,"0");return`${e}:${t}`}},watch:{urls:{handler(e){this.$emit("change",e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){w.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){w.error(this.$t("suno.message.uploadReferencesError"))},async onBrowseSuccess(){const e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){const t={audio_url:e},d=this.credential?.token;if(!d){console.error("no token specified");return}w.info(this.$t("suno.message.startingUploadAudio"));try{const r=await L.upload(t,{token:d});console.debug("get upload music success",r.data);const m=r.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:m,action:"upload_extend"}),w.success(this.$t("suno.message.startUploadAudioSuccess"))}catch(r){w.error(r?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>"u"){w.error(this.$t("suno.message.recordingUnsupported"));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{const e=new Blob(this.recordedChunks,{type:"audio/webm"});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error("record error",e),w.error(this.$t("suno.message.recordingPermissionDenied"))}},stopRecording(){this.recordTimer&&(window.clearInterval(this.recordTimer),this.recordTimer=null),this.mediaRecorder&&this.mediaRecorder.state!=="inactive"&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{const e=new FormData,t=`recording-${Date.now()}.webm`;e.append("file",this.recordedBlob,t);const d=await fetch(this.uploadUrl,{method:"POST",headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!d.ok)throw new Error(`upload failed: ${d.status}`);const r=await d.json(),m=r?.file_url||r?.data?.file_url;if(!m)throw new Error("no file_url in response");this.audioPreviewUrl=m,await this.onGenerateAudioId(m),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),w.error(e?.message||this.$t("suno.message.uploadReferencesError"))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&(this.mediaStream.getTracks().forEach(e=>e.stop()),this.mediaStream=null)},cleanupRecording(){this.recordTimer&&(window.clearInterval(this.recordTimer),this.recordTimer=null),this.releaseStream(),this.recordedAudioUrl&&(URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=null)}}}),St={class:"relative"},Tt={class:"flex justify-between items-center mb-2"},At={class:"flex justify-start items-center"},Ut={class:"text-sm font-bold"},Pt={key:0,class:"mb-2"},Et=["src"],It={key:1,class:"mt-2"},Rt={class:"py-4"},Lt={class:"text-center py-6"},Mt={class:"text-sm"},Ft={class:"text-xs text-gray-400 mt-1"},Dt={class:"py-4 text-center"},zt={class:"recorder-display mb-4"},jt={key:0,class:"text-red-500 flex items-center justify-center gap-2"},Gt={class:"text-2xl font-mono"},Bt={key:1,class:"text-green-600"},Ot={key:2,class:"text-gray-400 text-2xl font-mono"},Nt={key:0,class:"mb-4"},qt=["src"],Wt={class:"flex justify-center gap-3"};function Ht(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-radio-button"),g=l("el-radio-group"),T=l("el-upload"),_=l("el-tab-pane"),V=l("el-tabs"),C=l("el-dialog");return n(),u("div",St,[s("div",Tt,[s("div",At,[s("span",Ut,i(e.$t("suno.name.referenceAudios")),1),o($,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])]),o(f,{round:"",type:"primary",size:"small",onClick:t[0]||(t[0]=I=>e.dialogVisible=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-plus",class:"icon mr-1"}),v(" "+i(e.$t("suno.button.addAudio")),1)]),_:1})]),e.audioPreviewUrl?(n(),u("div",Pt,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,Et)])):c("",!0),e.hasUploadedAudio?(n(),u("div",It,[o(g,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=I=>e.uploadAction=I),size:"small"},{default:a(()=>[o(k,{value:"upload_extend"},{default:a(()=>[v(i(e.$t("suno.button.extend")),1)]),_:1}),o(k,{value:"upload_cover"},{default:a(()=>[v(i(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),o(C,{modelValue:e.dialogVisible,"onUpdate:modelValue":t[4]||(t[4]=I=>e.dialogVisible=I),title:e.$t("suno.name.addAudio"),width:"520px","close-on-click-modal":!1,"append-to-body":""},{default:a(()=>[o(V,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||(t[3]=I=>e.activeTab=I),class:"add-audio-tabs"},{default:a(()=>[o(_,{name:"browse",label:e.$t("suno.tab.browse")},{default:a(()=>[s("div",Rt,[o(T,{"file-list":e.fileList,"onUpdate:fileList":t[2]||(t[2]=I=>e.fileList=I),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:""},{default:a(()=>[s("div",Lt,[o(p,{icon:"fa-solid fa-upload",class:"text-4xl text-gray-400 mb-3"}),s("div",Mt,i(e.$t("suno.description.dropAudioHere")),1),s("div",Ft,i(e.$t("suno.description.audioFormats")),1)])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])]),_:1},8,["label"]),o(_,{name:"record",label:e.$t("suno.tab.record")},{default:a(()=>[s("div",Dt,[s("div",zt,[e.recording?(n(),u("div",jt,[t[5]||(t[5]=s("span",{class:"recording-dot"},null,-1)),s("span",Gt,i(e.formattedTime),1)])):e.recordedBlob?(n(),u("div",Bt,[o(p,{icon:"fa-solid fa-check-circle",class:"text-2xl mr-2"}),s("span",null,i(e.$t("suno.message.recordingReady"))+" ("+i(e.formattedTime)+")",1)])):(n(),u("div",Ot,"00:00"))]),e.recordedAudioUrl&&!e.recording?(n(),u("div",Nt,[s("audio",{src:e.recordedAudioUrl,controls:"",class:"w-full"},null,8,qt)])):c("",!0),s("div",Wt,[!e.recording&&!e.recordedBlob?(n(),b(f,{key:0,type:"primary",round:"",onClick:e.startRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.button.startRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recording?(n(),b(f,{key:1,type:"danger",round:"",onClick:e.stopRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-stop",class:"mr-1"}),v(" "+i(e.$t("suno.button.stopRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recordedBlob&&!e.recording?(n(),u(M,{key:2},[o(f,{round:"",onClick:e.resetRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.reRecord")),1)]),_:1},8,["onClick"]),o(f,{type:"primary",round:"",loading:e.uploadingRecord,onClick:e.uploadRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-upload",class:"mr-1"}),v(" "+i(e.$t("suno.button.useRecording")),1)]),_:1},8,["loading","onClick"])],64)):c("",!0)])])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),_:1},8,["modelValue","title"])])}const Kt=E(Vt,[["render",Ht],["__scopeId","data-v-bfb6b53d"]]),Jt="",he=[{key:"lofi",label:"🎧 Lo-fi Chill",prompt:"a relaxing lo-fi hip hop beat for studying"},{key:"pop-love",label:"💕 Pop Love Song",prompt:"a catchy pop love song with sweet melodies"},{key:"rock-anthem",label:"🎸 Rock Anthem",prompt:"an energetic rock anthem with electric guitars"},{key:"jazz-night",label:"🎷 Jazz Night",prompt:"a smooth late-night jazz piece with saxophone"},{key:"edm-drop",label:"⚡ EDM Drop",prompt:"an intense EDM track with a massive drop"},{key:"folk-story",label:"🪕 Folk Story",prompt:"a warm folk song telling a story about traveling"},{key:"rnb-groove",label:"🎤 R&B Groove",prompt:"a smooth R&B groove with soulful vocals"},{key:"classical",label:"🎻 Classical",prompt:"an elegant classical piece for orchestra"},{key:"hip-hop",label:"🎤 Hip Hop",prompt:"a hard-hitting hip hop beat with bass"},{key:"country",label:"🤠 Country",prompt:"an upbeat country song with acoustic guitar and banjo"},{key:"reggae",label:"🌴 Reggae",prompt:"a laid-back reggae tune with island vibes"},{key:"latin",label:"💃 Latin",prompt:"a vibrant Latin dance track with percussion"},{key:"ambient",label:"🌊 Ambient",prompt:"a dreamy ambient soundscape for relaxation"},{key:"metal",label:"🤘 Metal",prompt:"a powerful metal song with heavy riffs and double bass drums"},{key:"soul",label:"🎵 Soul",prompt:"a heartfelt soul ballad with gospel harmonies"},{key:"synthwave",label:"🌃 Synthwave",prompt:"a retro synthwave track with 80s vibes"},{key:"kpop",label:"🇰🇷 K-Pop",prompt:"a catchy K-pop dance track with hook"},{key:"lullaby",label:"🌙 Lullaby",prompt:"a gentle lullaby for bedtime with soft piano"},{key:"cinematic",label:"🎬 Cinematic",prompt:"an epic cinematic orchestral score for a movie trailer"},{key:"blues",label:"🎸 Blues",prompt:"a soulful blues song with electric guitar bends"},{key:"disco",label:"🕺 Disco",prompt:"a funky disco track with groovy bassline"},{key:"punk",label:"🔥 Punk Rock",prompt:"a fast punk rock song with raw energy"},{key:"gospel",label:"⛪ Gospel",prompt:"an uplifting gospel choir song with piano"},{key:"trap",label:"🔊 Trap",prompt:"a dark trap beat with 808s and hi-hats"},{key:"bossa",label:"☕ Bossa Nova",prompt:"a gentle bossa nova with nylon guitar"},{key:"indie",label:"🎶 Indie",prompt:"a dreamy indie track with ethereal vocals"},{key:"cpop",label:"🇨🇳 C-Pop",prompt:"a beautiful Chinese pop ballad with emotional vocals"},{key:"jpop",label:"🇯🇵 J-Pop",prompt:"a cheerful J-pop song with anime vibes"},{key:"afrobeat",label:"🥁 Afrobeat",prompt:"a groovy Afrobeat track with layered percussion"},{key:"game",label:"🎮 Game BGM",prompt:"an adventurous video game background music"}],Qt=8;function ge(e){const t=[...e];for(let d=t.length-1;d>0;d--){const r=Math.floor(Math.random()*(d+1));[t[d],t[r]]=[t[r],t[d]]}return t}const Yt=A({name:"PromptInput",components:{ElInput:W,FontAwesomeIcon:z,InfoIcon:F},data(){return{shuffledTags:ge(he)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,Qt)}},mounted(){this.prompt||(this.prompt=Jt)},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=ge(he)}}}),Xt={class:"field"},Zt={class:"flex items-center mb-1"},xt={class:"text-sm font-bold"},eo={class:"inspo-tags"},to=["onClick"];function oo(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-input"),f=l("font-awesome-icon");return n(),u("div",Xt,[s("div",Zt,[s("span",xt,i(e.$t("suno.name.songDescription")),1),o($,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=k=>e.prompt=k),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"]),s("div",eo,[(n(!0),u(M,null,D(e.visibleTags,k=>(n(),u("button",{key:k.key,class:"inspo-tag",onClick:g=>e.onTagClick(k)},i(k.label),9,to))),128)),s("button",{class:"inspo-tag inspo-tag-refresh",onClick:t[1]||(t[1]=(...k)=>e.onRefreshTags&&e.onRefreshTags(...k))},[o(f,{icon:"fa-solid fa-arrows-rotate"})])])])}const so=E(Yt,[["render",oo],["__scopeId","data-v-378e4372"]]),no="",io=A({name:"LyricInput",components:{ElInput:W,ElButton:B,ElTooltip:ue,ElDialog:de,FontAwesomeIcon:z,InfoIcon:F},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:"",lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=no)},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){const e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=""},async onEnhanceLyrics(){const e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,w.info(this.$t("suno.message.enhancingLyrics"));try{const t=`${this.enhancePrompt}
|
|
1
|
+
import{F as z}from"./index.es-p8_rCeM7.js";import{d as B,U as ye,c as Ue,o as Pe,w as le,x as re,v as x,u as Q,X as be,Y as ke,B as de,O as Ee,p as w,N as W,n as ue,a1 as ce,a2 as pe,V as ee,z as te,t as O,W as me,$ as Ie,a0 as Re,a5 as Le,r as Me,s as Fe,l as we,R as Ce,C as De,i as ze,I as Ve,Z as Se,J as Te,G as Ae,k as je,j as Ge,a3 as Be,a4 as Oe}from"./vendor-element-plus-CQnKmb2Y.js";import{d as A,C as u,G as s,T as o,E as ne,K as a,ai as l,D as n,O as c,M as G,R as i,S as M,ag as D,J as b,Q as v,af as ie,L as N,aq as H,X as P,c as q,u as j,w as Ne,U as qe}from"./vendor-vue-qgt_zvDa.js";import{a as E,cB as We,cC as L,q as He,S as X,ck as oe,d as Ke,E as Je}from"./index-CjUw7pA3.js";import{I as F,S as Qe}from"./ScrollList-D_OIXYoa.js";import{u as Z,F as Ye,O as Xe,_ as fe,P as Ze,a as xe,V as et}from"./IconPark.vue_vue_type_script_setup_true_lang-CNnhez9x.js";import{C as tt}from"./Consumption-BBl6mTTl.js";import{a as ot}from"./price-CbJb5IRW.js";import{N as st}from"./NoTasks-RLiH-azt.js";import{l as nt}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const it=A({name:"LayoutSuno",components:{ElDrawer:ye,ElButton:B,FontAwesomeIcon:z},data(){return{drawer:!1,preview:!1}},computed:{}}),at={class:"main flex flex-row flex-1"},lt={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},rt={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},dt={class:"preview h-full w-[300px] flex flex-col"};function ut(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-drawer");return n(),u("div",at,[s("div",lt,[ne(e.$slots,"config",{},void 0,!0)]),s("div",rt,[ne(e.$slots,"result",{},void 0,!0)]),s("div",dt,[ne(e.$slots,"preview",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[ne(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ct=E(it,[["render",ut],["__scopeId","data-v-c6c85757"]]),pt=A({name:"TypeSelector",components:{ElSelect:re,ElOption:le,ElSwitch:Pe,ElTag:Ue},data(){return{options:[{label:"v5.5",value:"chirp-v5-5",desc:this.$t("suno.model.v55desc"),pro:!0},{label:"v5",value:"chirp-v5",desc:this.$t("suno.model.v5desc"),pro:!0},{label:"v4.5+",value:"chirp-v4-5-plus",desc:this.$t("suno.model.v45plusdesc"),pro:!0},{label:"v4.5",value:"chirp-v4-5",desc:this.$t("suno.model.v45desc"),pro:!0,dividerAfter:!0},{label:"v4",value:"chirp-v4",desc:this.$t("suno.model.v4desc")},{label:"v3.5",value:"chirp-v3-5",desc:this.$t("suno.model.v35desc")},{label:"v3",value:"chirp-v3-0",desc:this.$t("suno.model.v3desc")}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(this.model=We)}}),mt={class:"mode-tabs mb-3"},ft={class:"mb-3"},ht={class:"flex items-center mb-1"},gt={class:"text-sm font-bold"},$t={class:"model-option"},_t={class:"model-option-left"},vt={class:"model-option-name"},yt={class:"model-option-desc"},bt={key:0,class:"flex items-center justify-between mb-3"},kt={class:"text-sm font-bold"};function wt(e,t,d,r,m,y){const $=l("el-tag"),p=l("el-option"),f=l("el-select"),k=l("el-switch");return n(),u("div",null,[s("div",mt,[s("button",{class:G(["mode-tab",{active:!e.custom}]),onClick:t[0]||(t[0]=g=>e.custom=!1)},i(e.$t("suno.mode.simple")),3),s("button",{class:G(["mode-tab",{active:e.custom}]),onClick:t[1]||(t[1]=g=>e.custom=!0)},i(e.$t("suno.mode.custom")),3)]),s("div",ft,[s("div",ht,[s("span",gt,i(e.$t("suno.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[2]||(t[2]=g=>e.model=g),class:"w-full model-select",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:a(()=>[(n(!0),u(M,null,D(e.options,g=>(n(),b(p,{key:g.value,label:g.label,value:g.value,class:G({"model-option-divider":g.dividerAfter})},{default:a(()=>[s("div",$t,[s("div",_t,[s("span",vt,i(g.label),1),g.pro?(n(),b($,{key:0,size:"small",type:"warning",effect:"plain",class:"model-option-pro"},{default:a(()=>t[4]||(t[4]=[v("Pro",-1)])),_:1,__:[4]})):c("",!0)]),s("span",yt,i(g.desc),1)])]),_:2},1032,["label","value","class"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),u("div",bt,[s("span",kt,i(e.$t("suno.name.instrumental")),1),o(k,{modelValue:e.instrumental,"onUpdate:modelValue":t[3]||(t[3]=g=>e.instrumental=g)},null,8,["modelValue"])])):c("",!0)])}const Ct=E(pt,[["render",wt],["__scopeId","data-v-a6ada414"]]),Vt=A({name:"UploadAudio",components:{ElUpload:Ee,ElButton:B,ElDialog:de,ElTabs:ke,ElTabPane:be,InfoIcon:F,FontAwesomeIcon:z,ElRadioGroup:Q,ElRadioButton:x},emits:["change"],data(){return{fileList:[],uploadUrl:He()+"/api/v1/files/",dialogVisible:!1,activeTab:"browse",recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){const e=this.$store.state.suno?.config?.action;return e==="upload_extend"||e==="upload_cover"},uploadAction:{get(){return this.$store.state.suno?.config?.action||"upload_extend"},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,action:e})}},formattedTime(){const e=Math.floor(this.recordSeconds/60).toString().padStart(2,"0"),t=(this.recordSeconds%60).toString().padStart(2,"0");return`${e}:${t}`}},watch:{urls:{handler(e){this.$emit("change",e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){w.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){w.error(this.$t("suno.message.uploadReferencesError"))},async onBrowseSuccess(){const e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){const t={audio_url:e},d=this.credential?.token;if(!d){console.error("no token specified");return}w.info(this.$t("suno.message.startingUploadAudio"));try{const r=await L.upload(t,{token:d});console.debug("get upload music success",r.data);const m=r.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:m,action:"upload_extend"}),w.success(this.$t("suno.message.startUploadAudioSuccess"))}catch(r){w.error(r?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>"u"){w.error(this.$t("suno.message.recordingUnsupported"));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{const e=new Blob(this.recordedChunks,{type:"audio/webm"});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error("record error",e),w.error(this.$t("suno.message.recordingPermissionDenied"))}},stopRecording(){this.recordTimer&&(window.clearInterval(this.recordTimer),this.recordTimer=null),this.mediaRecorder&&this.mediaRecorder.state!=="inactive"&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{const e=new FormData,t=`recording-${Date.now()}.webm`;e.append("file",this.recordedBlob,t);const d=await fetch(this.uploadUrl,{method:"POST",headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!d.ok)throw new Error(`upload failed: ${d.status}`);const r=await d.json(),m=r?.file_url||r?.data?.file_url;if(!m)throw new Error("no file_url in response");this.audioPreviewUrl=m,await this.onGenerateAudioId(m),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),w.error(e?.message||this.$t("suno.message.uploadReferencesError"))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&(this.mediaStream.getTracks().forEach(e=>e.stop()),this.mediaStream=null)},cleanupRecording(){this.recordTimer&&(window.clearInterval(this.recordTimer),this.recordTimer=null),this.releaseStream(),this.recordedAudioUrl&&(URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=null)}}}),St={class:"relative"},Tt={class:"flex justify-between items-center mb-2"},At={class:"flex justify-start items-center"},Ut={class:"text-sm font-bold"},Pt={key:0,class:"mb-2"},Et=["src"],It={key:1,class:"mt-2"},Rt={class:"py-4"},Lt={class:"text-center py-6"},Mt={class:"text-sm"},Ft={class:"text-xs text-gray-400 mt-1"},Dt={class:"py-4 text-center"},zt={class:"recorder-display mb-4"},jt={key:0,class:"text-red-500 flex items-center justify-center gap-2"},Gt={class:"text-2xl font-mono"},Bt={key:1,class:"text-green-600"},Ot={key:2,class:"text-gray-400 text-2xl font-mono"},Nt={key:0,class:"mb-4"},qt=["src"],Wt={class:"flex justify-center gap-3"};function Ht(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-radio-button"),g=l("el-radio-group"),T=l("el-upload"),_=l("el-tab-pane"),V=l("el-tabs"),C=l("el-dialog");return n(),u("div",St,[s("div",Tt,[s("div",At,[s("span",Ut,i(e.$t("suno.name.referenceAudios")),1),o($,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])]),o(f,{round:"",type:"primary",size:"small",onClick:t[0]||(t[0]=I=>e.dialogVisible=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-plus",class:"icon mr-1"}),v(" "+i(e.$t("suno.button.addAudio")),1)]),_:1})]),e.audioPreviewUrl?(n(),u("div",Pt,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,Et)])):c("",!0),e.hasUploadedAudio?(n(),u("div",It,[o(g,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=I=>e.uploadAction=I),size:"small"},{default:a(()=>[o(k,{value:"upload_extend"},{default:a(()=>[v(i(e.$t("suno.button.extend")),1)]),_:1}),o(k,{value:"upload_cover"},{default:a(()=>[v(i(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),o(C,{modelValue:e.dialogVisible,"onUpdate:modelValue":t[4]||(t[4]=I=>e.dialogVisible=I),title:e.$t("suno.name.addAudio"),width:"520px","close-on-click-modal":!1,"append-to-body":""},{default:a(()=>[o(V,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||(t[3]=I=>e.activeTab=I),class:"add-audio-tabs"},{default:a(()=>[o(_,{name:"browse",label:e.$t("suno.tab.browse")},{default:a(()=>[s("div",Rt,[o(T,{"file-list":e.fileList,"onUpdate:fileList":t[2]||(t[2]=I=>e.fileList=I),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:""},{default:a(()=>[s("div",Lt,[o(p,{icon:"fa-solid fa-upload",class:"text-4xl text-gray-400 mb-3"}),s("div",Mt,i(e.$t("suno.description.dropAudioHere")),1),s("div",Ft,i(e.$t("suno.description.audioFormats")),1)])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])]),_:1},8,["label"]),o(_,{name:"record",label:e.$t("suno.tab.record")},{default:a(()=>[s("div",Dt,[s("div",zt,[e.recording?(n(),u("div",jt,[t[5]||(t[5]=s("span",{class:"recording-dot"},null,-1)),s("span",Gt,i(e.formattedTime),1)])):e.recordedBlob?(n(),u("div",Bt,[o(p,{icon:"fa-solid fa-check-circle",class:"text-2xl mr-2"}),s("span",null,i(e.$t("suno.message.recordingReady"))+" ("+i(e.formattedTime)+")",1)])):(n(),u("div",Ot,"00:00"))]),e.recordedAudioUrl&&!e.recording?(n(),u("div",Nt,[s("audio",{src:e.recordedAudioUrl,controls:"",class:"w-full"},null,8,qt)])):c("",!0),s("div",Wt,[!e.recording&&!e.recordedBlob?(n(),b(f,{key:0,type:"primary",round:"",onClick:e.startRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.button.startRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recording?(n(),b(f,{key:1,type:"danger",round:"",onClick:e.stopRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-stop",class:"mr-1"}),v(" "+i(e.$t("suno.button.stopRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recordedBlob&&!e.recording?(n(),u(M,{key:2},[o(f,{round:"",onClick:e.resetRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.reRecord")),1)]),_:1},8,["onClick"]),o(f,{type:"primary",round:"",loading:e.uploadingRecord,onClick:e.uploadRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-upload",class:"mr-1"}),v(" "+i(e.$t("suno.button.useRecording")),1)]),_:1},8,["loading","onClick"])],64)):c("",!0)])])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),_:1},8,["modelValue","title"])])}const Kt=E(Vt,[["render",Ht],["__scopeId","data-v-bfb6b53d"]]),Jt="",he=[{key:"lofi",label:"🎧 Lo-fi Chill",prompt:"a relaxing lo-fi hip hop beat for studying"},{key:"pop-love",label:"💕 Pop Love Song",prompt:"a catchy pop love song with sweet melodies"},{key:"rock-anthem",label:"🎸 Rock Anthem",prompt:"an energetic rock anthem with electric guitars"},{key:"jazz-night",label:"🎷 Jazz Night",prompt:"a smooth late-night jazz piece with saxophone"},{key:"edm-drop",label:"⚡ EDM Drop",prompt:"an intense EDM track with a massive drop"},{key:"folk-story",label:"🪕 Folk Story",prompt:"a warm folk song telling a story about traveling"},{key:"rnb-groove",label:"🎤 R&B Groove",prompt:"a smooth R&B groove with soulful vocals"},{key:"classical",label:"🎻 Classical",prompt:"an elegant classical piece for orchestra"},{key:"hip-hop",label:"🎤 Hip Hop",prompt:"a hard-hitting hip hop beat with bass"},{key:"country",label:"🤠 Country",prompt:"an upbeat country song with acoustic guitar and banjo"},{key:"reggae",label:"🌴 Reggae",prompt:"a laid-back reggae tune with island vibes"},{key:"latin",label:"💃 Latin",prompt:"a vibrant Latin dance track with percussion"},{key:"ambient",label:"🌊 Ambient",prompt:"a dreamy ambient soundscape for relaxation"},{key:"metal",label:"🤘 Metal",prompt:"a powerful metal song with heavy riffs and double bass drums"},{key:"soul",label:"🎵 Soul",prompt:"a heartfelt soul ballad with gospel harmonies"},{key:"synthwave",label:"🌃 Synthwave",prompt:"a retro synthwave track with 80s vibes"},{key:"kpop",label:"🇰🇷 K-Pop",prompt:"a catchy K-pop dance track with hook"},{key:"lullaby",label:"🌙 Lullaby",prompt:"a gentle lullaby for bedtime with soft piano"},{key:"cinematic",label:"🎬 Cinematic",prompt:"an epic cinematic orchestral score for a movie trailer"},{key:"blues",label:"🎸 Blues",prompt:"a soulful blues song with electric guitar bends"},{key:"disco",label:"🕺 Disco",prompt:"a funky disco track with groovy bassline"},{key:"punk",label:"🔥 Punk Rock",prompt:"a fast punk rock song with raw energy"},{key:"gospel",label:"⛪ Gospel",prompt:"an uplifting gospel choir song with piano"},{key:"trap",label:"🔊 Trap",prompt:"a dark trap beat with 808s and hi-hats"},{key:"bossa",label:"☕ Bossa Nova",prompt:"a gentle bossa nova with nylon guitar"},{key:"indie",label:"🎶 Indie",prompt:"a dreamy indie track with ethereal vocals"},{key:"cpop",label:"🇨🇳 C-Pop",prompt:"a beautiful Chinese pop ballad with emotional vocals"},{key:"jpop",label:"🇯🇵 J-Pop",prompt:"a cheerful J-pop song with anime vibes"},{key:"afrobeat",label:"🥁 Afrobeat",prompt:"a groovy Afrobeat track with layered percussion"},{key:"game",label:"🎮 Game BGM",prompt:"an adventurous video game background music"}],Qt=8;function ge(e){const t=[...e];for(let d=t.length-1;d>0;d--){const r=Math.floor(Math.random()*(d+1));[t[d],t[r]]=[t[r],t[d]]}return t}const Yt=A({name:"PromptInput",components:{ElInput:W,FontAwesomeIcon:z,InfoIcon:F},data(){return{shuffledTags:ge(he)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,Qt)}},mounted(){this.prompt||(this.prompt=Jt)},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=ge(he)}}}),Xt={class:"field"},Zt={class:"flex items-center mb-1"},xt={class:"text-sm font-bold"},eo={class:"inspo-tags"},to=["onClick"];function oo(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-input"),f=l("font-awesome-icon");return n(),u("div",Xt,[s("div",Zt,[s("span",xt,i(e.$t("suno.name.songDescription")),1),o($,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=k=>e.prompt=k),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"]),s("div",eo,[(n(!0),u(M,null,D(e.visibleTags,k=>(n(),u("button",{key:k.key,class:"inspo-tag",onClick:g=>e.onTagClick(k)},i(k.label),9,to))),128)),s("button",{class:"inspo-tag inspo-tag-refresh",onClick:t[1]||(t[1]=(...k)=>e.onRefreshTags&&e.onRefreshTags(...k))},[o(f,{icon:"fa-solid fa-arrows-rotate"})])])])}const so=E(Yt,[["render",oo],["__scopeId","data-v-378e4372"]]),no="",io=A({name:"LyricInput",components:{ElInput:W,ElButton:B,ElTooltip:ue,ElDialog:de,FontAwesomeIcon:z,InfoIcon:F},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:"",lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=no)},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){const e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=""},async onEnhanceLyrics(){const e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,w.info(this.$t("suno.message.enhancingLyrics"));try{const t=`${this.enhancePrompt}
|
|
2
2
|
|
|
3
3
|
Original lyrics:
|
|
4
4
|
${this.lyric}`,r=(await L.lyric({prompt:t},{token:e})).data?.data;r?.text&&(this.lyric=r.text,this.enhancePrompt="",w.success(this.$t("suno.message.enhanceLyricsSuccess")))}catch{w.error(this.$t("suno.message.enhanceLyricsFailed"))}finally{this.enhancingLyrics=!1}}},async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;this.pushHistory();const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,w.info(this.$t("suno.message.generatingLyrics"));try{const r=(await L.lyric({prompt:t},{token:e})).data?.data;r?.text&&(this.lyric=r.text,r?.title&&!this.config?.title&&this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:r.text,title:r.title}),w.success(this.$t("suno.message.generateLyricsSuccess")))}catch{w.error(this.$t("suno.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),ao={class:"field"},lo={class:"flex items-center justify-between mb-1"},ro={class:"flex items-center"},uo={class:"text-sm font-bold"},co={class:"flex items-center gap-1"},po={class:"relative"},mo={class:"text-xs text-right text-[var(--el-text-color-secondary)] mt-1"},fo={key:0,class:"enhance-bar"},ho={key:0,class:"enhance-bar mt-3"},go={class:"flex items-center justify-between"},$o={class:"flex items-center gap-1"};function _o(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-tooltip"),g=l("el-input"),T=l("el-dialog");return n(),u("div",ao,[s("div",lo,[s("div",ro,[s("span",uo,i(e.$t("suno.name.lyrics")),1),o($,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),s("div",co,[e.lyricHistory.length>0?(n(),b(k,{key:0,content:e.$t("suno.button.undo"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:e.onUndo},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),e.lyric?(n(),b(k,{key:1,content:e.$t("suno.button.clear_lyrics"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:e.onClear},{default:a(()=>[o(p,{icon:"fa-solid fa-eraser"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),o(k,{content:e.$t("suno.button.expand_lyrics"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:t[0]||(t[0]=_=>e.expanded=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-expand"})]),_:1})]),_:1},8,["content"]),e.config?.action!=="extend"?(n(),b(f,{key:2,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):c("",!0)])]),s("div",po,[e.config?.action!=="extend"?(n(),b(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),b(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[2]||(t[2]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"])),s("div",mo,i(e.lyric?.length||0)+"/5000",1)]),e.lyric&&e.config?.action!=="extend"?(n(),u("div",fo,[o(g,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[3]||(t[3]=_=>e.enhancePrompt=_),size:"small",placeholder:e.$t("suno.placeholder.enhanceLyrics"),class:"enhance-input",onKeyup:ie(e.onEnhanceLyrics,["enter"])},{append:a(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:a(()=>[e.enhancingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.enhance_lyrics")),1)]),_:1},8,["loading","onClick"])]),_:1},8,["modelValue","placeholder","onKeyup"])])):c("",!0),o(T,{modelValue:e.expanded,"onUpdate:modelValue":t[7]||(t[7]=_=>e.expanded=_),title:e.$t("suno.name.lyrics"),width:"720px",top:"5vh","close-on-click-modal":!1,class:"lyrics-expand-dialog"},{footer:a(()=>[s("div",go,[s("div",$o,[e.lyricHistory.length>0?(n(),b(f,{key:0,size:"small",onClick:e.onUndo},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.undo")),1)]),_:1},8,["onClick"])):c("",!0),e.lyric?(n(),b(f,{key:1,size:"small",onClick:e.onClear},{default:a(()=>[o(p,{icon:"fa-solid fa-eraser",class:"mr-1"}),v(" "+i(e.$t("suno.button.clear_lyrics")),1)]),_:1},8,["onClick"])):c("",!0),e.config?.action!=="extend"?(n(),b(f,{key:2,size:"small",loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):c("",!0)]),o(f,{type:"primary",onClick:t[6]||(t[6]=_=>e.expanded=!1)},{default:a(()=>[v(i(e.$t("common.button.confirm")),1)]),_:1})])]),default:a(()=>[o(g,{modelValue:e.lyric,"onUpdate:modelValue":t[4]||(t[4]=_=>e.lyric=_),type:"textarea",rows:20,class:"lyrics-expanded",placeholder:e.$t("suno.placeholder.lyrics"),autofocus:""},null,8,["modelValue","placeholder"]),e.config?.action!=="extend"?(n(),u("div",ho,[o(g,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[5]||(t[5]=_=>e.enhancePrompt=_),size:"small",placeholder:e.$t("suno.placeholder.enhanceLyrics"),class:"enhance-input",onKeyup:ie(e.onEnhanceLyrics,["enter"])},{append:a(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:a(()=>[e.enhancingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.enhance_lyrics")),1)]),_:1},8,["loading","onClick"])]),_:1},8,["modelValue","placeholder","onKeyup"])])):c("",!0)]),_:1},8,["modelValue","title"])])}const vo=E(io,[["render",_o],["__scopeId","data-v-2b97a493"]]),$e=["Pop","Rock","Jazz","R&B","Hip Hop","Lo-fi","Electronic","Classical","Country","Blues","Folk","Reggae","Metal","Punk","Soul","Funk","Ambient","Indie","Latin","Acoustic","Dance","Disco","Gospel","K-Pop","J-Pop","C-Pop","Bossa Nova","Trap","Drill","House","Techno","Dubstep","Synthwave","Chill","Dreamy","Upbeat","Melancholic","Romantic","Epic","Cinematic","Orchestral","Piano","Guitar","Saxophone","Violin","Tribal","World Music","Afrobeat","Ska","Grunge"],yo=12;function _e(e){const t=[...e];for(let d=t.length-1;d>0;d--){const r=Math.floor(Math.random()*(d+1));[t[d],t[r]]=[t[r],t[d]]}return t}const bo=A({name:"StyleInput",components:{ElInput:W,ElButton:B,FontAwesomeIcon:z,InfoIcon:F},data(){return{optimizing:!1,shuffledTags:_e($e)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,yo)}},methods:{onTagClick(e){const t=this.style||"";t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=_e($e)},async onOptimizeStyle(){const e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,w.info(this.$t("suno.message.optimizingStyle"));try{const t=await L.style({prompt:this.style},{token:e}),d=t.data?.text||t.data?.data?.text;d&&(this.style=d,w.success(this.$t("suno.message.optimizeStyleSuccess")))}catch{w.error(this.$t("suno.message.optimizeStyleFailed"))}finally{this.optimizing=!1}}}}}),ko={class:"field"},wo={class:"flex items-center justify-between mb-1"},Co={class:"flex items-center"},Vo={class:"text-sm font-bold"},So={class:"relative"},To={class:"text-xs text-right text-[var(--el-text-color-secondary)] mt-1"},Ao={class:"style-tags"},Uo=["onClick"];function Po(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-input");return n(),u("div",ko,[s("div",wo,[s("div",Co,[s("span",Vo,i(e.$t("suno.name.style")),1),o($,{content:e.$t("suno.description.style")},null,8,["content"])]),o(f,{size:"small",loading:e.optimizing,round:"",onClick:e.onOptimizeStyle},{default:a(()=>[e.optimizing?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),s("div",So,[o(k,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=g=>e.style=g),rows:2,type:"textarea",placeholder:e.$t("suno.placeholder.style")},null,8,["modelValue","placeholder"]),s("div",To,i(e.style?.length||0)+"/1000",1)]),s("div",Ao,[(n(!0),u(M,null,D(e.visibleTags,g=>(n(),u("button",{key:g,class:"style-tag",onClick:T=>e.onTagClick(g)},i(g),9,Uo))),128)),s("button",{class:"style-tag style-tag-refresh",onClick:t[1]||(t[1]=(...g)=>e.onRefreshTags&&e.onRefreshTags(...g))},[o(p,{icon:"fa-solid fa-arrows-rotate"})])])])}const Eo=E(bo,[["render",Po],["__scopeId","data-v-ddebb076"]]),Io=A({name:"TitleInput",components:{ElInput:W,InfoIcon:F},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}}}}),Ro={class:"field"},Lo={class:"flex items-center mb-1"},Mo={class:"text-sm font-bold"};function Fo(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-input");return n(),u("div",Ro,[s("div",Lo,[s("span",Mo,i(e.$t("suno.name.title")),1),o($,{content:e.$t("suno.description.title")},null,8,["content"])]),o(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=f=>e.title=f),placeholder:e.$t("suno.placeholder.title")},null,8,["modelValue","placeholder"])])}const Do=E(Io,[["render",Fo]]),zo=A({name:"ExtendFromInput",components:{ElImage:O,ElIcon:te,ElInputNumber:ee,VideoPlay:pe,VideoPause:ce},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:Z,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})}}}),jo={class:"field"},Go={class:"box"},Bo={class:"title font-bold"},Oo={class:"input-wrapper"},No={class:"task"},qo={class:"left"},Wo={key:2,class:"duration"},Ho={class:"info"},Ko={class:"title"},Jo={class:"style"};function Qo(e,t,d,r,m,y){const $=l("el-input-number"),p=l("el-image"),f=l("video-pause"),k=l("el-icon"),g=l("video-play"),T=H("loading");return n(),u("div",jo,[s("div",Go,[s("h2",Bo,i(e.$t("suno.name.extend")),1),s("div",Oo,[o($,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=_=>e.value=_),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),s("div",No,[e.audio?(n(),u("div",{key:0,class:"audio",onClick:t[3]||(t[3]=_=>e.onClick(e.audio))},[N((n(),u("div",qo,[o(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),u("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=_=>e.onPause(e.audio))},[o(k,null,{default:a(()=>[o(f)]),_:1})])):c("",!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")?(n(),u("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=_=>e.onPlay(e.audio))},[o(k,null,{default:a(()=>[o(g)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",Wo,i(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[T,!e.audio?.audio_url]]),s("div",Ho,[s("h2",Ko,i(e.audio?.title),1),s("p",Jo,i(e.audio?.style),1)])])):c("",!0)])])}const Yo=E(zo,[["render",Qo],["__scopeId","data-v-bcce4821"]]),Xo=A({name:"CoverFromInput",components:{ElImage:O,ElIcon:te,VideoPlay:pe,VideoPause:ce},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:Z,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})}}}),Zo={class:"field"},xo={class:"box"},es={class:"title font-bold"},ts={class:"task"},os={class:"left"},ss={key:2,class:"duration"},ns={class:"info"},is={class:"title"},as={class:"style"};function ls(e,t,d,r,m,y){const $=l("el-image"),p=l("video-pause"),f=l("el-icon"),k=l("video-play"),g=H("loading");return n(),u("div",Zo,[s("div",xo,[s("h2",es,i(e.$t("suno.name.cover")),1)]),s("div",ts,[e.audio?(n(),u("div",{key:0,class:"audio",onClick:t[2]||(t[2]=T=>e.onClick(e.audio))},[N((n(),u("div",os,[o($,{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"?(n(),u("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=T=>e.onPause(e.audio))},[o(f,null,{default:a(()=>[o(p)]),_:1})])):c("",!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")?(n(),u("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=T=>e.onPlay(e.audio))},[o(f,null,{default:a(()=>[o(k)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",ss,i(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[g,!e.audio?.audio_url]]),s("div",ns,[s("h2",is,i(e.audio?.title),1),s("p",as,i(e.audio?.style),1)])])):c("",!0)])])}const rs=E(Xo,[["render",ls],["__scopeId","data-v-06640216"]]),ds=A({name:"VocalGenderSelector",components:{ElRadioGroup:Q,ElRadioButton:x,InfoIcon:F},computed:{vocalGender:{get(){return this.$store.state.suno?.config?.vocal_gender||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,vocal_gender:e||void 0})}}}}),us={class:"mb-2"},cs={class:"flex items-center mb-1"},ps={class:"text-sm font-bold"};function ms(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-radio-button"),f=l("el-radio-group");return n(),u("div",us,[s("div",cs,[s("span",ps,i(e.$t("suno.name.vocalGender")),1),o($,{content:e.$t("suno.description.vocalGender")},null,8,["content"])]),o(f,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=k=>e.vocalGender=k)},{default:a(()=>[o(p,{value:""},{default:a(()=>[v(i(e.$t("suno.gender.auto")),1)]),_:1}),o(p,{value:"f"},{default:a(()=>[v(i(e.$t("suno.gender.female")),1)]),_:1}),o(p,{value:"m"},{default:a(()=>[v(i(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const fs=E(ds,[["render",ms]]),hs=A({name:"AdvancedParams",components:{ElCollapse:Re,ElCollapseItem:Ie,ElInput:W,ElSlider:me,ElRadioGroup:Q,ElRadioButton:x},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){const e=this.config?.model||"";return["chirp-v5","chirp-v5-5"].includes(e)},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_weight:e})}},lyricsMode:{get(){return this.$store.state.suno?.config?.lyrics_mode||"manual"},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyrics_mode:e})}}}}),gs={key:0,class:"mb-3"},$s={class:"flex items-center mb-1"},_s={class:"text-xs font-bold"},vs={key:1,class:"mb-3"},ys={class:"flex items-center mb-1"},bs={class:"text-xs font-bold"},ks={key:2,class:"mb-3"},ws={class:"flex items-center justify-between mb-1"},Cs={class:"text-xs font-bold"},Vs={class:"text-xs text-[var(--el-text-color-secondary)]"},Ss={key:3,class:"mb-3"},Ts={class:"flex items-center justify-between mb-1"},As={class:"text-xs font-bold"},Us={class:"text-xs text-[var(--el-text-color-secondary)]"},Ps={key:4,class:"mb-3"},Es={class:"flex items-center mb-1"},Is={class:"text-xs font-bold"},Rs={key:5,class:"mb-3"},Ls={class:"flex items-center justify-between mb-1"},Ms={class:"text-xs font-bold"},Fs={class:"text-xs text-[var(--el-text-color-secondary)]"},Ds={key:6,class:"mb-3"},zs={class:"flex items-center mb-1"},js={class:"text-xs font-bold"};function Gs(e,t,d,r,m,y){const $=l("el-input"),p=l("el-slider"),f=l("el-radio-button"),k=l("el-radio-group"),g=l("el-collapse-item"),T=l("el-collapse");return n(),b(T,{modelValue:e.activeNames,"onUpdate:modelValue":t[7]||(t[7]=_=>e.activeNames=_),class:"advanced-collapse"},{default:a(()=>[o(g,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:a(()=>[e.config?.custom?(n(),u("div",gs,[s("div",$s,[s("span",_s,i(e.$t("suno.name.styleNegative")),1)]),o($,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=_=>e.styleNegative=_),placeholder:e.$t("suno.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):c("",!0),e.config?.custom&&!e.config?.instrumental?(n(),u("div",vs,[s("div",ys,[s("span",bs,i(e.$t("suno.name.lyricPrompt")),1)]),o($,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyricPrompt=_),placeholder:e.$t("suno.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):c("",!0),e.config?.custom?(n(),u("div",ks,[s("div",ws,[s("span",Cs,i(e.$t("suno.name.weirdness")),1),s("span",Vs,i(e.weirdness??0),1)]),o(p,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=_=>e.weirdness=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.config?.custom?(n(),u("div",Ss,[s("div",Ts,[s("span",As,i(e.$t("suno.name.styleInfluence")),1),s("span",Us,i(e.styleInfluence??50),1)]),o(p,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||(t[3]=_=>e.styleInfluence=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.isV5OrAbove?(n(),u("div",Ps,[s("div",Es,[s("span",Is,i(e.$t("suno.name.variationCategory")),1)]),o(k,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=_=>e.variationCategory=_)},{default:a(()=>[o(f,{value:""},{default:a(()=>[v(i(e.$t("suno.gender.auto")),1)]),_:1}),o(f,{value:"high"},{default:a(()=>[v(i(e.$t("suno.variation.high")),1)]),_:1}),o(f,{value:"low"},{default:a(()=>[v(i(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),e.config?.action==="cover"?(n(),u("div",Rs,[s("div",Ls,[s("span",Ms,i(e.$t("suno.name.audioWeight")),1),s("span",Fs,i(e.audioWeight??50),1)]),o(p,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||(t[5]=_=>e.audioWeight=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.config?.custom&&!e.config?.instrumental?(n(),u("div",Ds,[s("div",zs,[s("span",js,i(e.$t("suno.name.lyricsMode")),1)]),o(k,{modelValue:e.lyricsMode,"onUpdate:modelValue":t[6]||(t[6]=_=>e.lyricsMode=_)},{default:a(()=>[o(f,{value:"manual"},{default:a(()=>[v(i(e.$t("suno.lyricsMode.manual")),1)]),_:1}),o(f,{value:"auto"},{default:a(()=>[v(i(e.$t("suno.lyricsMode.auto")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Bs=E(hs,[["render",Gs],["__scopeId","data-v-505f8fc7"]]),Os=A({name:"ReplaceSectionInput",components:{ElInputNumber:ee,ElImage:O,InfoIcon:F},computed:{audio(){return this.$store.state.suno?.config?.audio},replaceSectionStart:{get(){return this.$store.state.suno?.config?.replace_section_start},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.suno?.config?.replace_section_end},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),Ns={class:"field"},qs={class:"flex items-center mb-2"},Ws={class:"text-sm font-bold m-0"},Hs={key:0,class:"task mb-2"},Ks={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Js={class:"info flex-1 min-w-0"},Qs={class:"text-sm font-bold m-0 truncate"},Ys={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Xs={class:"flex gap-2"};function Zs(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=H("loading");return n(),u("div",Ns,[s("div",qs,[s("h2",Ws,i(e.$t("suno.name.replaceSection")),1),o($,{content:e.$t("suno.description.replaceSection")},null,8,["content"])]),e.audio?(n(),u("div",Hs,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[N((n(),u("div",Ks,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",Js,[s("h2",Qs,i(e.audio?.title),1),s("p",Ys,i(e.audio?.style),1)])])])):c("",!0),s("div",Xs,[o(f,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.replaceSectionStart=g),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.replaceSectionEnd=g),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const xs=E(Os,[["render",Zs]]),en=A({name:"OverpaintingInput",components:{ElInputNumber:ee,ElImage:O,InfoIcon:F},computed:{audio(){return this.$store.state.suno?.config?.audio},overpaintingStart:{get(){return this.$store.state.suno?.config?.overpainting_start},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,overpainting_start:e})}},overpaintingEnd:{get(){return this.$store.state.suno?.config?.overpainting_end},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,overpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),tn={class:"field"},on={class:"flex items-center mb-2"},sn={class:"text-sm font-bold m-0"},nn={key:0,class:"task mb-2"},an={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ln={class:"info flex-1 min-w-0"},rn={class:"text-sm font-bold m-0 truncate"},dn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},un={class:"flex gap-2"};function cn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=H("loading");return n(),u("div",tn,[s("div",on,[s("h2",sn,i(e.$t("suno.name.overpaintingRange")),1),o($,{content:e.$t("suno.description.overpainting")},null,8,["content"])]),e.audio?(n(),u("div",nn,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[N((n(),u("div",an,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",ln,[s("h2",rn,i(e.audio?.title),1),s("p",dn,i(e.audio?.style),1)])])])):c("",!0),s("div",un,[o(f,{modelValue:e.overpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.overpaintingStart=g),class:"flex-1",size:"small",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.overpaintingStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.overpaintingEnd=g),class:"flex-1",size:"small",min:e.overpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.overpaintingEnd")},null,8,["modelValue","min","max","placeholder"])])])}const pn=E(en,[["render",cn]]),mn=A({name:"UnderpaintingInput",components:{ElInputNumber:ee,ElImage:O,InfoIcon:F},computed:{audio(){return this.$store.state.suno?.config?.audio},underpaintingStart:{get(){return this.$store.state.suno?.config?.underpainting_start},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,underpainting_start:e})}},underpaintingEnd:{get(){return this.$store.state.suno?.config?.underpainting_end},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,underpainting_end:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),fn={class:"field"},hn={class:"flex items-center mb-2"},gn={class:"text-sm font-bold m-0"},$n={key:0,class:"task mb-2"},_n={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},vn={class:"info flex-1 min-w-0"},yn={class:"text-sm font-bold m-0 truncate"},bn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},kn={class:"flex gap-2"};function wn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=H("loading");return n(),u("div",fn,[s("div",hn,[s("h2",gn,i(e.$t("suno.name.underpaintingRange")),1),o($,{content:e.$t("suno.description.underpainting")},null,8,["content"])]),e.audio?(n(),u("div",$n,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[N((n(),u("div",_n,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",vn,[s("h2",yn,i(e.audio?.title),1),s("p",bn,i(e.audio?.style),1)])])])):c("",!0),s("div",kn,[o(f,{modelValue:e.underpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.underpaintingStart=g),class:"flex-1",size:"small",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.underpaintingStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.underpaintingEnd=g),class:"flex-1",size:"small",min:e.underpaintingStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.underpaintingEnd")},null,8,["modelValue","min","max","placeholder"])])])}const Cn=E(mn,[["render",wn]]),Vn=A({name:"SamplesInput",components:{ElInputNumber:ee,ElImage:O,InfoIcon:F},computed:{audio(){return this.$store.state.suno?.config?.audio},samplesStart:{get(){return this.$store.state.suno?.config?.samples_start},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,samples_start:e})}},samplesEnd:{get(){return this.$store.state.suno?.config?.samples_end},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,samples_end:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),Sn={class:"field"},Tn={class:"flex items-center mb-2"},An={class:"text-sm font-bold m-0"},Un={key:0,class:"task mb-2"},Pn={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},En={class:"info flex-1 min-w-0"},In={class:"text-sm font-bold m-0 truncate"},Rn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Ln={class:"flex gap-2"};function Mn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=H("loading");return n(),u("div",Sn,[s("div",Tn,[s("h2",An,i(e.$t("suno.name.samplesRange")),1),o($,{content:e.$t("suno.description.samples")},null,8,["content"])]),e.audio?(n(),u("div",Un,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[N((n(),u("div",Pn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",En,[s("h2",In,i(e.audio?.title),1),s("p",Rn,i(e.audio?.style),1)])])])):c("",!0),s("div",Ln,[o(f,{modelValue:e.samplesStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.samplesStart=g),class:"flex-1",size:"small",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.samplesStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.samplesEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.samplesEnd=g),class:"flex-1",size:"small",min:e.samplesStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.samplesEnd")},null,8,["modelValue","min","max","placeholder"])])])}const Fn=E(Vn,[["render",Mn]]),Dn=[.5,.75,1,1.25,1.5,2],zn=A({name:"AdjustSpeedInput",components:{ElRadioGroup:Q,ElRadioButton:x,ElImage:O,InfoIcon:F},data(){return{options:Dn}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){const e=this.$store.state.suno?.config?.speed;return typeof e=="number"?e:1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),jn={class:"field"},Gn={class:"flex items-center mb-2"},Bn={class:"text-sm font-bold m-0"},On={key:0,class:"task mb-2"},Nn={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},qn={class:"info flex-1 min-w-0"},Wn={class:"text-sm font-bold m-0 truncate"},Hn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"};function Kn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-radio-button"),k=l("el-radio-group"),g=H("loading");return n(),u("div",jn,[s("div",Gn,[s("h2",Bn,i(e.$t("suno.name.adjustSpeed")),1),o($,{content:e.$t("suno.description.adjustSpeed")},null,8,["content"])]),e.audio?(n(),u("div",On,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=T=>e.onClick(e.audio))},[N((n(),u("div",Nn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",qn,[s("h2",Wn,i(e.audio?.title),1),s("p",Hn,i(e.audio?.style),1)])])])):c("",!0),o(k,{modelValue:e.speed,"onUpdate:modelValue":t[1]||(t[1]=T=>e.speed=T),size:"small",class:"speed-group"},{default:a(()=>[(n(!0),u(M,null,D(e.options,T=>(n(),b(f,{key:T,value:T},{default:a(()=>[v(i(T)+"x",1)]),_:2},1032,["value"]))),128))]),_:1},8,["modelValue"])])}const Jn=E(zn,[["render",Kn],["__scopeId","data-v-ba834628"]]),Qn=A({name:"VoiceCreateDialog",components:{ElDialog:de,ElForm:Fe,ElFormItem:Me,ElInput:W,ElButton:B,ElRadioGroup:Q,ElRadio:Le},props:{modelValue:{type:Boolean,default:!1}},emits:["update:modelValue","created"],data(){return{sourceType:"song",form:{name:"",description:"",audio_id:"",audio_url:""},loading:!1}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},token(){return this.$store.state.suno?.credential?.token},canSubmit(){return!(!this.form.name||this.sourceType==="song"&&!this.form.audio_id||this.sourceType==="upload"&&!this.form.audio_url)}},methods:{onClose(){this.visible=!1,this.resetForm()},resetForm(){this.form={name:"",description:"",audio_id:"",audio_url:""},this.sourceType="song"},async onSubmit(){if(this.token){this.loading=!0;try{this.sourceType==="song"?await L.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await L.voices({audio_url:this.form.audio_url,name:this.form.name,description:this.form.description},{token:this.token}),w.success(this.$t("suno.voice.createSuccess")),this.$emit("created"),this.onClose()}catch{w.error(this.$t("suno.voice.createFailed"))}finally{this.loading=!1}}}}});function Yn(e,t,d,r,m,y){const $=l("el-input"),p=l("el-form-item"),f=l("el-radio"),k=l("el-radio-group"),g=l("el-form"),T=l("el-button"),_=l("el-dialog");return n(),b(_,{modelValue:e.visible,"onUpdate:modelValue":t[5]||(t[5]=V=>e.visible=V),title:e.$t("suno.voice.createTitle"),width:"480px","close-on-click-modal":!1,onClose:e.onClose},{footer:a(()=>[o(T,{onClick:e.onClose},{default:a(()=>[v(i(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),o(T,{type:"primary",loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:a(()=>[v(i(e.$t("suno.voice.create")),1)]),_:1},8,["loading","disabled","onClick"])]),default:a(()=>[o(g,{"label-position":"top",class:"voice-create-form"},{default:a(()=>[o(p,{label:e.$t("suno.voice.name")},{default:a(()=>[o($,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||(t[0]=V=>e.form.name=V),placeholder:e.$t("suno.voice.namePlaceholder"),maxlength:"50"},null,8,["modelValue","placeholder"])]),_:1},8,["label"]),o(p,{label:e.$t("suno.voice.description")},{default:a(()=>[o($,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||(t[1]=V=>e.form.description=V),type:"textarea",rows:2,placeholder:e.$t("suno.voice.descriptionPlaceholder"),maxlength:"200"},null,8,["modelValue","placeholder"])]),_:1},8,["label"]),o(p,{label:e.$t("suno.voice.sourceType")},{default:a(()=>[o(k,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||(t[2]=V=>e.sourceType=V),class:"w-full"},{default:a(()=>[o(f,{value:"song"},{default:a(()=>[v(i(e.$t("suno.voice.fromSong")),1)]),_:1}),o(f,{value:"upload"},{default:a(()=>[v(i(e.$t("suno.voice.fromUpload")),1)]),_:1})]),_:1},8,["modelValue"])]),_:1},8,["label"]),e.sourceType==="song"?(n(),b(p,{key:0,label:e.$t("suno.voice.audioId")},{default:a(()=>[o($,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||(t[3]=V=>e.form.audio_id=V),placeholder:e.$t("suno.voice.audioIdPlaceholder")},null,8,["modelValue","placeholder"])]),_:1},8,["label"])):c("",!0),e.sourceType==="upload"?(n(),b(p,{key:1,label:e.$t("suno.voice.audioUrl")},{default:a(()=>[o($,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||(t[4]=V=>e.form.audio_url=V),placeholder:e.$t("suno.voice.audioUrlPlaceholder")},null,8,["modelValue","placeholder"])]),_:1},8,["label"])):c("",!0)]),_:1})]),_:1},8,["modelValue","title","onClose"])}const Xn=E(Qn,[["render",Yn]]),Zn=A({name:"VoiceManager",components:{ElButton:B,ElIcon:te,ElTabs:ke,ElTabPane:be,ElTooltip:ue,Loading:we,FontAwesomeIcon:z,VoiceCreateDialog:Xn},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:"all"}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab==="favorites"?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit("suno/togglePersonaFavorite",e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch("suno/getPersonas")}finally{this.loading=!1}}},selectPersona(e){const t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch("suno/setConfig",t)},async onDelete(e){try{await Ce.confirm(this.$t("suno.voice.confirmDelete"),this.$t("suno.voice.delete"),{type:"warning",confirmButtonText:this.$t("common.button.confirm"),cancelButtonText:this.$t("common.button.cancel")})}catch{return}if(!e.persona_id)return;this.deletingId=e.persona_id;const t=await this.$store.dispatch("suno/deletePersona",e.persona_id);if(this.deletingId=null,t){if(w.success(this.$t("suno.voice.deleteSuccess")),this.selectedPersonaId===e.persona_id){const d={...this.$store.state.suno?.config,persona_id:void 0};this.$store.dispatch("suno/setConfig",d)}this.favoriteIds.includes(e.persona_id)&&this.$store.commit("suno/togglePersonaFavorite",e.persona_id)}else w.error(this.$t("suno.voice.deleteFailed"))},async onCreated(){await this.loadPersonas()}}}),xn={class:"voice-manager"},ei={class:"flex items-center justify-between mb-3"},ti={class:"text-sm font-medium"},oi={key:0,class:"text-center py-6"},si={key:1,class:"text-center py-6 text-gray-400 text-sm"},ni={key:2,class:"voice-list"},ii=["onClick"],ai={class:"flex-1 min-w-0"},li={class:"voice-name"},ri={key:0,class:"voice-desc"};function di(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-tab-pane"),k=l("el-tabs"),g=l("loading"),T=l("el-icon"),_=l("el-tooltip"),V=l("voice-create-dialog");return n(),u("div",xn,[s("div",ei,[s("span",ti,i(e.$t("suno.voice.title")),1),o(p,{type:"primary",size:"small",onClick:t[0]||(t[0]=C=>e.showCreateDialog=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-plus",class:"mr-1"}),v(" "+i(e.$t("suno.voice.create")),1)]),_:1})]),o(k,{modelValue:e.activeTab,"onUpdate:modelValue":t[1]||(t[1]=C=>e.activeTab=C),class:"voice-tabs",size:"small"},{default:a(()=>[o(f,{name:"all",label:e.$t("suno.voice.tabAll")+" ("+(e.personas?.length||0)+")"},null,8,["label"]),o(f,{name:"favorites",label:e.$t("suno.voice.tabFavorites")+" ("+e.favoritePersonas.length+")"},null,8,["label"])]),_:1},8,["modelValue"]),e.loading?(n(),u("div",oi,[o(T,{class:"is-loading"},{default:a(()=>[o(g)]),_:1})])):e.visiblePersonas.length===0?(n(),u("div",si,i(e.activeTab==="favorites"?e.$t("suno.voice.emptyFavorites"):e.$t("suno.voice.empty")),1)):(n(),u("div",ni,[(n(!0),u(M,null,D(e.visiblePersonas,C=>(n(),u("div",{key:C.persona_id,class:G(["voice-item",{active:e.selectedPersonaId===C.persona_id}]),onClick:I=>e.selectPersona(C)},[s("div",ai,[s("div",li,[o($,{icon:C.source_type==="voice"?"fa-solid fa-microphone":"fa-solid fa-music",class:"mr-1.5 text-xs opacity-60"},null,8,["icon"]),v(" "+i(C.name||C.persona_id),1)]),C.description?(n(),u("div",ri,i(C.description),1)):c("",!0)]),s("div",{class:"voice-actions",onClick:t[2]||(t[2]=P(()=>{},["stop"]))},[o(_,{content:e.isFavorite(C.persona_id)?e.$t("suno.voice.unfavorite"):e.$t("suno.voice.favorite"),placement:"top"},{default:a(()=>[o(p,{size:"small",text:"",class:G({"voice-fav-active":e.isFavorite(C.persona_id)}),onClick:I=>e.onToggleFavorite(C)},{default:a(()=>[o($,{icon:e.isFavorite(C.persona_id)?"fa-solid fa-star":"fa-regular fa-star"},null,8,["icon"])]),_:2},1032,["class","onClick"])]),_:2},1032,["content"]),o(p,{type:"danger",size:"small",text:"",loading:e.deletingId===C.persona_id,onClick:I=>e.onDelete(C)},{default:a(()=>[o($,{icon:"fa-solid fa-trash"})]),_:2},1032,["loading","onClick"])])],10,ii))),128))])),o(V,{modelValue:e.showCreateDialog,"onUpdate:modelValue":t[3]||(t[3]=C=>e.showCreateDialog=C),onCreated:e.onCreated},null,8,["modelValue","onCreated"])])}const ui=E(Zn,[["render",di],["__scopeId","data-v-8b8e36d9"]]),ci=A({name:"PersonaInput",components:{ElSelect:re,ElOption:le,ElButton:B,ElDrawer:ye,FontAwesomeIcon:z,InfoIcon:F,VoiceManager:ui},data(){return{showManager:!1}},computed:{personaId:{get(){return this.$store.state.suno?.config?.persona_id||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,persona_id:e||void 0})}},personas(){return this.$store.state.suno?.personas||[]}}}),pi={class:"field"},mi={class:"flex items-center justify-between mb-2"},fi={class:"flex items-center"},hi={class:"text-sm font-bold m-0"},gi={class:"flex items-center justify-between w-full"},$i={key:0,class:"text-xs text-gray-400 ml-2"};function _i(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-option"),g=l("el-select"),T=l("voice-manager"),_=l("el-drawer");return n(),u("div",pi,[s("div",mi,[s("div",fi,[s("h2",hi,i(e.$t("suno.name.persona")),1),o($,{content:e.$t("suno.description.persona")},null,8,["content"])]),o(f,{type:"primary",size:"small",text:"",onClick:t[0]||(t[0]=V=>e.showManager=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.voice.manage")),1)]),_:1})]),o(g,{modelValue:e.personaId,"onUpdate:modelValue":t[1]||(t[1]=V=>e.personaId=V),size:"small",placeholder:e.$t("suno.placeholder.personaId"),clearable:"",filterable:"",class:"w-full"},{default:a(()=>[(n(!0),u(M,null,D(e.personas,V=>(n(),b(k,{key:V.persona_id||"",value:V.persona_id||"",label:V.name||V.persona_id||""},{default:a(()=>[s("div",gi,[s("span",null,i(V.name||V.persona_id),1),V.source_type?(n(),u("span",$i,i(V.source_type),1)):c("",!0)])]),_:2},1032,["value","label"]))),128))]),_:1},8,["modelValue","placeholder"]),o(_,{modelValue:e.showManager,"onUpdate:modelValue":t[2]||(t[2]=V=>e.showManager=V),title:e.$t("suno.voice.title"),size:"380px",direction:"rtl"},{default:a(()=>[o(T)]),_:1},8,["modelValue","title"])])}const vi=E(ci,[["render",_i]]),yi=A({name:"PresetPanel",components:{TypeSelector:Ct,PromptInput:so,LyricInput:vo,StyleInput:Eo,TitleInput:Do,ExtendFromInput:Yo,CoverFromInput:rs,UploadAudio:Kt,VocalGenderSelector:fs,AdvancedParams:Bs,ReplaceSectionInput:xs,OverpaintingInput:pn,UnderpaintingInput:Cn,SamplesInput:Fn,AdjustSpeedInput:Jn,PersonaInput:vi,FontAwesomeIcon:z,ElButton:B,Consumption:tt},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return ot(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){const e=this.config?.model||"";return["chirp-v4-5-plus","chirp-v5","chirp-v5-5"].includes(e)},supportsPersona(){const e=this.config?.action;return!e||e==="generate"||e==="artist_consistency"||e==="artist_consistency_vox"},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("suno.button.extend"):e==="cover"?this.$t("suno.button.cover_music"):e==="remaster"?this.$t("suno.button.remaster"):e==="replace_section"?this.$t("suno.button.replace_section"):e==="mashup"?this.$t("suno.button.mashup"):e==="stems"?this.$t("suno.button.get_stems"):e==="concat"?this.$t("suno.button.concat_music"):e==="upload_cover"?this.$t("suno.button.upload_cover"):e==="artist_consistency"?this.$t("suno.button.artist_consistency"):e==="artist_consistency_vox"?this.$t("suno.button.artist_consistency_vox"):e==="overpainting"?this.$t("suno.button.overpainting"):e==="underpainting"?this.$t("suno.button.underpainting"):e==="samples"?this.$t("suno.button.samples"):e==="adjust_speed"?this.$t("suno.button.adjust_speed"):this.$t("suno.button.generate")}},methods:{onGenerate(){this.$emit("generate")},onClearAll(){this.$store.commit("suno/setConfig",{custom:!1,sounds:!1,instrumental:!1,lyric:"",style:"",title:"",lyrics_mode:"manual",model:this.$store.state.suno?.config?.model})}}}),bi={class:"flex flex-col h-full"},ki={class:"flex-1 overflow-y-auto p-5"},wi={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},Ci={class:"flex gap-2 w-full"};function Vi(e,t,d,r,m,y){const $=l("type-selector"),p=l("upload-audio"),f=l("prompt-input"),k=l("lyric-input"),g=l("style-input"),T=l("title-input"),_=l("vocal-gender-selector"),V=l("persona-input"),C=l("extend-from-input"),I=l("cover-from-input"),U=l("replace-section-input"),K=l("overpainting-input"),J=l("underpainting-input"),Y=l("samples-input"),h=l("adjust-speed-input"),S=l("advanced-params"),ae=l("consumption"),R=l("font-awesome-icon"),se=l("el-button");return n(),u("div",bi,[s("div",ki,[o($,{class:"mb-4"}),o(p,{class:"mb-4"}),e.config?.custom?c("",!0):(n(),b(f,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),b(k,{key:1,class:"mb-4"})):c("",!0),e.config?.custom?(n(),b(g,{key:2,class:"mb-4"})):c("",!0),e.config?.custom?(n(),b(T,{key:3,class:"mb-4"})):c("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(n(),b(_,{key:4,class:"mb-4"})):c("",!0),e.config?.custom&&e.supportsPersona?(n(),b(V,{key:5,class:"mb-4"})):c("",!0),e.config?.action==="extend"?(n(),b(C,{key:6,class:"mb-4"})):c("",!0),e.config?.action==="cover"?(n(),b(I,{key:7,class:"mb-4"})):c("",!0),e.config?.action==="replace_section"?(n(),b(U,{key:8,class:"mb-4"})):c("",!0),e.config?.action==="overpainting"?(n(),b(K,{key:9,class:"mb-4"})):c("",!0),e.config?.action==="underpainting"?(n(),b(J,{key:10,class:"mb-4"})):c("",!0),e.config?.action==="samples"?(n(),b(Y,{key:11,class:"mb-4"})):c("",!0),e.config?.action==="adjust_speed"?(n(),b(h,{key:12,class:"mb-4"})):c("",!0),o(S,{class:"mb-4"})]),s("div",wi,[o(ae,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",Ci,[o(se,{class:"flex-1",onClick:e.onClearAll},{default:a(()=>[o(R,{icon:"fa-solid fa-broom",class:"mr-1"}),v(" "+i(e.$t("suno.button.clear_all")),1)]),_:1},8,["onClick"]),o(se,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:a(()=>[o(R,{icon:"fa-solid fa-magic",class:"mr-2"}),v(" "+i(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const Si=E(yi,[["render",Vi],["__scopeId","data-v-fa2936b9"]]),ve="https://webhook.acedata.cloud/suno",Ti=A({name:"TaskPreview",components:{ElImage:O,ElIcon:te,ElTooltip:ue,FontAwesomeIcon:z,VideoPlay:pe,VideoPause:ce,ElDropdown:Te,ElDropdownMenu:Se,ElDropdownItem:Ve,ElInput:W,ElProgress:ze,ElCheckbox:De,Loading:we},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:""}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(d=>({...d,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action==="mashup"},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:Z,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 r=new URL(t).pathname,m=r.substring(r.lastIndexOf("/")+1);console.log("on preview",m),fetch(t).then(y=>y.blob()).then(y=>{Ye.saveAs(y,m)})},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),w.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,d)=>{const r={audio_id:e},m=this.credential?.token;if(!m){console.error("no token specified"),d(new Error("No token specified"));return}L.mp4(r,{token:m}).then(y=>{const $=y.data?.data?.video_url;$?t($):d(new Error("Video URL not found in response"))}).catch(y=>{d(y)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onRemaster(e){await this.onGenerateAudioUrl("remaster",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"mashup",audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"overpainting",audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"underpainting",audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"samples",audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"artist_consistency",audio:e,audio_id:e.id})},onAdjustSpeed(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"adjust_speed",audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){const t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){w.warning(this.$t("suno.message.reusePromptEmpty"));return}this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??"",lyric:t.lyric??"",lyric_prompt:t.lyric_prompt??"",lyrics_mode:t.lyrics_mode??"manual",title:t.title??"",style:t.style??"",style_negative:t.style_negative??"",vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),w.success(this.$t("suno.message.reusePromptSuccess"))},async onExtractVocals(e){const t=this.credential?.token;t&&(w.info(this.$t("suno.message.extractingVocals")),L.vox({audio_id:e,callback_url:ve},{token:t}).then(()=>{w.success(this.$t("suno.message.extractVocalsSuccess"))}).catch(d=>{w.error(d?.response?.data?.error?.message||this.$t("suno.message.extractVocalsFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){const t=this.credential?.token;t&&(w.info(this.$t("suno.message.fetchingTiming")),L.timing({audio_id:e},{token:t}).then(d=>{w.success(this.$t("suno.message.fetchTimingSuccess")),console.debug("timing data",d.data)}).catch(d=>{w.error(d?.response?.data?.error?.message||this.$t("suno.message.fetchTimingFailed"))}))},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;const t=this.credential?.token;if(t)try{this.isFetchingWav=!0,w.info(this.$t("suno.message.fetchingWav"));const r=(await L.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;r?this.onDownload(null,r):w.error(this.$t("suno.message.fetchWavFailed"))}catch{w.error(this.$t("suno.message.fetchWavFailed"))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;const t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,w.info(this.$t("suno.message.fetchingMidi"));const r=(await L.midi({audio_id:e.id},{token:t})).data?.data?.midi_url;r?this.onDownload(null,r):w.error(this.$t("suno.message.fetchMidiFailed"))}catch{w.error(this.$t("suno.message.fetchMidiFailed"))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){const d={action:e,audio_id:t,callback_url:ve},r=this.credential?.token;if(!r){console.error("no token specified");return}w.info(this.$t("suno.message.startingTask")),L.audio(d,{token:r}).then(()=>{w.success(this.$t("suno.message.startTaskSuccess"))}).catch(m=>{w.error(m?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},isMashupSelected(e){return!!e.id&&this.mashupAudioIds.includes(e.id)},onToggleMashup(e){if(!e.id)return;const t=[...this.mashupAudioIds],d=t.indexOf(e.id);d!==-1?t.splice(d,1):t.push(e.id),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,mashup_audio_ids:t})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},onStartTitleEdit(e){this.editingAudioId=e.id??null,this.editingTitle=e.title||"",this.$nextTick(()=>{this.$refs.titleInput?.focus?.()})},onSaveTitleEdit(e){if(this.editingAudioId!==e.id)return;const t=this.editingTitle.trim();if(t&&t!==e.title){const d=this.$store.state.suno?.tasks;if(d?.items)for(const r of d.items){const y=(r?.response?.data??[]).find($=>$.id===e.id);if(y){y.title=t;break}}}this.editingAudioId=null,this.editingTitle=""},onCancelTitleEdit(){this.editingAudioId=null,this.editingTitle=""},async onDelete(e){try{await Ce.confirm(this.$t("suno.message.confirmDelete"),{confirmButtonText:this.$t("suno.button.delete"),cancelButtonText:this.$t("common.button.cancel"),type:"warning"})}catch{return}const t=this.$store.state.suno?.tasks;if(t?.items)for(const d of t.items){const r=d?.response?.data??[],m=r.findIndex(y=>y.id===e.id);if(m!==-1){if(r.splice(m,1),r.length===0){const y=t.items.indexOf(d);y!==-1&&t.items.splice(y,1)}break}}this.$store.state?.suno?.audio?.id===e.id&&this.$store.dispatch("suno/setAudio",null),w.success(this.$t("suno.message.deleteSuccess"))},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),Ai={class:"task"},Ui=["onClick"],Pi=["onClick"],Ei={class:"left"},Ii=["onClick"],Ri=["onClick"],Li={key:2,class:"duration"},Mi={class:"info"},Fi={key:1,class:"title-row"},Di={class:"title"},zi={class:"style"},ji={key:2,class:"progress-row"},Gi={class:"progress-text"},Bi={class:"right"},Oi={class:"el-dropdown-link"},Ni={class:"flex items-center min-w-[120px]"},qi={class:"flex items-center min-w-[120px]"},Wi={class:"flex items-center min-w-[120px]"},Hi={class:"el-dropdown-link"};function Ki(e,t,d,r,m,y){const $=l("el-checkbox"),p=l("el-image"),f=l("video-pause"),k=l("el-icon"),g=l("video-play"),T=l("el-input"),_=l("font-awesome-icon"),V=l("el-progress"),C=l("el-tooltip"),I=l("Loading"),U=l("el-dropdown-item"),K=l("el-dropdown-menu"),J=l("el-dropdown"),Y=H("loading");return n(),u("div",Ai,[(n(!0),u(M,null,D(e.audios,h=>(n(),u("div",{key:h.id,class:G(["audio",{"mashup-selected":e.isMashupSelected(h)}]),onClick:P(S=>e.onClick(h),["stop"])},[e.isMashupMode&&h?.audio_url?(n(),u("div",{key:0,class:"mashup-check",onClick:P(S=>e.onToggleMashup(h),["stop"])},[o($,{"model-value":e.isMashupSelected(h),onClick:t[0]||(t[0]=P(()=>{},["stop"]))},null,8,["model-value"])],8,Pi)):c("",!0),N((n(),u("div",Ei,[o(p,{src:h?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),h?.audio_url&&e.$store.state?.suno?.audio?.id===h.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),u("div",{key:0,class:"overlay",onClick:P(S=>e.onPause(h),["stop"])},[o(k,null,{default:a(()=>[o(f)]),_:1})],8,Ii)):c("",!0),h?.audio_url&&(e.$store.state?.suno?.audio?.id!==h.id||e.$store.state?.suno?.audio?.id===h.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),u("div",{key:1,class:"overlay",onClick:P(S=>e.onPlay(h),["stop"])},[o(k,null,{default:a(()=>[o(g)]),_:1})],8,Ri)):c("",!0),h?.duration?(n(),u("div",Li,i(e.useFormatDuring(h?.duration)),1)):c("",!0)])),[[Y,!h?.audio_url]]),s("div",Mi,[e.editingAudioId===h.id?(n(),u("div",{key:0,class:"title-edit",onClick:t[2]||(t[2]=P(()=>{},["stop"]))},[o(T,{ref_for:!0,ref:"titleInput",modelValue:e.editingTitle,"onUpdate:modelValue":t[1]||(t[1]=S=>e.editingTitle=S),size:"small",onKeyup:[ie(S=>e.onSaveTitleEdit(h),["enter"]),ie(e.onCancelTitleEdit,["escape"])],onBlur:S=>e.onSaveTitleEdit(h)},null,8,["modelValue","onKeyup","onBlur"])])):(n(),u("div",Fi,[s("h2",Di,i(h?.title),1),h?.audio_url?(n(),b(_,{key:0,icon:"fa-solid fa-pen",class:"edit-icon",onClick:P(S=>e.onStartTitleEdit(h),["stop"])},null,8,["onClick"])):c("",!0)])),s("p",zi,i(h?.style),1),!h?.audio_url&&h?.progress!=null&&h?.progress<100?(n(),u("div",ji,[o(V,{percentage:Math.round(h.progress),"stroke-width":4,"show-text":!1,status:"warning",class:"progress-bar"},null,8,["percentage"]),s("span",Gi,i(e.$t("suno.name.generating"))+" "+i(Math.round(h.progress))+"%",1)])):c("",!0)]),s("div",Bi,[o(J,null,{dropdown:a(()=>[o(K,null,{default:a(()=>[o(U,{disabled:e.isFetchingVideoUrl,onClick:S=>e.handleVideoDownload(h)},{default:a(()=>[s("div",Ni,[e.isFetchingVideoUrl?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),h?.audio_url?(n(),b(U,{key:0,onClick:P(S=>e.onDownload(S,h?.audio_url),["stop"])},{default:a(()=>[v(i(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):c("",!0),o(U,{disabled:e.isFetchingWav,onClick:S=>e.handleWavDownload(h)},{default:a(()=>[s("div",qi,[e.isFetchingWav?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_wav")),1)])]),_:2},1032,["disabled","onClick"]),o(U,{disabled:e.isFetchingMidi,onClick:S=>e.handleMidiDownload(h)},{default:a(()=>[s("div",Wi,[e.isFetchingMidi?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_midi")),1)])]),_:2},1032,["disabled","onClick"])]),_:2},1024)]),default:a(()=>[s("span",Oi,[o(C,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:a(()=>[h?.audio_url||h?.video_url?(n(),b(_,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(J,null,{dropdown:a(()=>[o(K,{class:"suno-action-menu"},{default:a(()=>[h?.audio_url?(n(),b(U,{key:0,onClick:P(S=>e.onExtend(S,h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-forward",class:"menu-icon"}),v(" "+i(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):c("",!0),o(U,{onClick:P(S=>e.onCover(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-music",class:"menu-icon"}),v(" "+i(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),h?.id?(n(),b(U,{key:1,onClick:P(S=>e.onMashup(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-shuffle",class:"menu-icon"}),v(" "+i(e.$t("suno.button.mashup")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id&&h?.action==="extend"?(n(),b(U,{key:2,onClick:P(S=>e.onConcatMusic(h?.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-link",class:"menu-icon"}),v(" "+i(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):c("",!0),t[3]||(t[3]=s("div",{class:"menu-divider"},null,-1)),h?.id?(n(),b(U,{key:3,onClick:P(S=>e.onReplaceSection(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-scissors",class:"menu-icon"}),v(" "+i(e.$t("suno.button.replace_section")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:4,onClick:P(S=>e.onOverpainting(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-microphone",class:"menu-icon"}),v(" "+i(e.$t("suno.button.overpainting")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:5,onClick:P(S=>e.onUnderpainting(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-guitar",class:"menu-icon"}),v(" "+i(e.$t("suno.button.underpainting")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:6,onClick:P(S=>e.onSamples(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-drum",class:"menu-icon"}),v(" "+i(e.$t("suno.button.samples")),1)]),_:2},1032,["onClick"])):c("",!0),t[4]||(t[4]=s("div",{class:"menu-divider"},null,-1)),h.id?(n(),b(U,{key:7,onClick:P(S=>e.onGetStems(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-layer-group",class:"menu-icon"}),v(" "+i(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):c("",!0),h.id?(n(),b(U,{key:8,onClick:P(S=>e.onGetAllStems(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-bars-staggered",class:"menu-icon"}),v(" "+i(e.$t("suno.button.all_stems")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:9,onClick:P(S=>e.onRemaster(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-wand-magic-sparkles",class:"menu-icon"}),v(" "+i(e.$t("suno.button.remaster")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:10,onClick:P(S=>e.onExtractVocals(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-headphones",class:"menu-icon"}),v(" "+i(e.$t("suno.button.extract_vocals")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:11,onClick:P(S=>e.onArtistConsistency(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-palette",class:"menu-icon"}),v(" "+i(e.$t("suno.button.artist_consistency")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:12,onClick:P(S=>e.onAdjustSpeed(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-gauge-high",class:"menu-icon"}),v(" "+i(e.$t("suno.button.adjust_speed")),1)]),_:2},1032,["onClick"])):c("",!0),t[5]||(t[5]=s("div",{class:"menu-divider"},null,-1)),o(U,{onClick:P(S=>e.onReusePrompt(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-rotate-left",class:"menu-icon"}),v(" "+i(e.$t("suno.button.reuse_prompt")),1)]),_:2},1032,["onClick"]),h?.id?(n(),b(U,{key:13,onClick:P(S=>e.onGetTiming(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-clock",class:"menu-icon"}),v(" "+i(e.$t("suno.button.get_timing")),1)]),_:2},1032,["onClick"])):c("",!0),t[6]||(t[6]=s("div",{class:"menu-divider"},null,-1)),h?.id?(n(),b(U,{key:14,class:"delete-item",onClick:P(S=>e.onDelete(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-trash",class:"menu-icon delete-icon"}),v(" "+i(e.$t("suno.button.delete")),1)]),_:2},1032,["onClick"])):c("",!0)]),_:2,__:[3,4,5,6]},1024)]),default:a(()=>[s("span",Hi,[o(C,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:a(()=>[h?.audio_url||h?.video_url?(n(),b(_,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],10,Ui))),128))])}const Ji=E(Ti,[["render",Ki]]),Qi={class:"player-slider"},Yi=A({__name:"PlayerSlider",setup(e){const t=oe(),d=q({get:()=>t.state.suno?.audio?.progress,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:$})}),r=q({get:()=>t.state.suno?.audio?.duration,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:$})}),m=()=>{},y=$=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:$});return($,p)=>(n(),u("div",Qi,[o(j(me),{modelValue:d.value,"onUpdate:modelValue":p[0]||(p[0]=f=>d.value=f),"show-tooltip":!1,min:0,max:r.value,onChange:y,onInput:m},null,8,["modelValue","max"])]))}}),Xi={class:"flex player-song"},Zi=["src"],xi={class:"ml-2 text-xs flex flex-col justify-between"},ea={class:"w-52 2xl:w-96 cursor-pointer truncate"},ta={class:"flex"},oa={class:"ml-2 text-dc"},sa=A({__name:"PlayerSong",setup(e){const t=oe(),d=q({get:()=>t.state.suno.audio,set:r=>t.commit("suno/setAudio",r)});return Ne(d,(r,m)=>{if(r?.audio_url!==m?.audio_url){console.log("audio changed",r),r.object&&(console.log("111",r.object),r.object.pause(),delete r.object);const y=new Audio(r.audio_url);r.state==="playing"?y.play():y.pause(),y.addEventListener("loadedmetadata",()=>{y.currentTime=0,y.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:y.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:y})}else if(r?.progress!==m?.progress&&Math.abs(r.progress-r.object.currentTime)>2){console.log("progress changed",r.progress);const y=t.state.suno.audio;y.object&&(y.object.currentTime=y.progress)}else r?.state!==m?.state&&(console.log("state changed",r.state),r.object&&(r.state==="playing"?r.object.play():r.object.pause()));r?.volume!==m?.volume&&(console.log("volume changed",r.volume),r.object&&(r.object.volume=r.volume/100))}),(r,m)=>(n(),u("div",Xi,[s("img",{alt:"",class:"w-11 h-11 rounded",src:d.value?.image_url||j(Xe)},null,8,Zi),s("div",xi,[s("div",ea,[s("div",ta,[s("span",null,i(d.value?.title||"Music"),1),s("span",oa,"- "+i(d.value?.style||"SmallRuralDog"),1)])])])]))}}),na={class:"flex justify-end items-center gap-x-2.5"},ia={class:"text-xs"},aa=A({__name:"PlayerAction",setup(e){const t=oe(),d=q({get:()=>t.state.suno?.audio?.progress,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:m})}),r=q({get:()=>t.state.suno?.audio?.duration,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:m})});return(m,y)=>(n(),u("div",na,[s("span",ia,i(j(Z)(d.value))+" / "+i(j(Z)(r.value)),1)]))}}),la={class:"player-volume flex flex-col items-center pt-2"},ra={class:"text-sm mt-3"},da=A({__name:"PlayerVolumeSlider",setup(e){const t=oe(),d=q({get:()=>t.state.suno.audio?.volume,set:y=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:y})}),r=q({get:()=>t.state.suno.audio?.muted,set:y=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:y})}),m=y=>t.dispatch("suno/setVolume",y);return(y,$)=>(n(),u("div",la,[o(j(me),{modelValue:d.value,"onUpdate:modelValue":$[0]||($[0]=p=>d.value=p),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:r.value,onInput:m},null,8,["modelValue","disabled"]),s("div",ra,i(d.value),1)]))}}),ua={class:"flex items-center justify-center gap-x-3"},ca=A({__name:"PlayerController",setup(e){const t=oe(),d=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),r=q(()=>t.state.suno.audio);return(m,y)=>(n(),u("div",ua,[o(fe,{icon:r.value?.state==="playing"?j(Ze):j(xe),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:d},null,8,["icon"]),o(j(Ae),{placement:"top",width:"50px",trigger:"click"},{reference:a(()=>[o(fe,{icon:j(et),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:a(()=>[o(da)]),_:1})]))}}),pa={class:"flex flex-col items-stretch h-20"},ma={class:"flex grow px-5 items-center"},fa={class:"flex-1"},ha={class:"flex-1"},ga={class:"flex-1"},$a=A({__name:"Player",setup(e){return(t,d)=>(n(),u("div",pa,[o(Yi),s("div",ma,[s("div",fa,[o(sa)]),s("div",ha,[o(ca)]),s("div",ga,[o(aa)])])]))}}),_a=A({name:"RecentPanel",components:{ElSkeletonItem:Ge,ElSkeleton:je,ElInput:W,ElButton:B,ElDropdown:Te,ElDropdownMenu:Se,ElDropdownItem:Ve,ElPopover:Ae,ElRadioGroup:Q,ElRadioButton:x,ElSelect:re,ElOption:le,FontAwesomeIcon:z,TaskPreview:Ji,Player:$a,NoTasks:st,ScrollList:Qe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0,searchQuery:"",sortBy:"newest",filterType:"all",filterDuration:"all",filterVideo:"all",filterModel:"all"}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}},sortLabel(){return this.sortBy==="newest"?this.$t("suno.sort.newest"):this.$t("suno.sort.oldest")},activeFilterCount(){let e=0;return this.filterType!=="all"&&e++,this.filterDuration!=="all"&&e++,this.filterVideo!=="all"&&e++,this.filterModel&&this.filterModel!=="all"&&e++,e},availableModels(){const e=this.tasks?.items||[],t=new Set;for(const d of e){const r=d?.response?.data??[];for(const m of r)m.model&&t.add(m.model)}return Array.from(t).sort()},filteredTasks(){let e=this.tasks?.items||[];if(this.searchQuery){const t=this.searchQuery.toLowerCase();e=e.filter(d=>(d?.response?.data??[]).some(m=>m.title?.toLowerCase().includes(t)||m.style?.toLowerCase().includes(t)||m.prompt?.toLowerCase().includes(t)))}return this.activeFilterCount>0&&(e=e.filter(t=>{const d=t?.request??{},r=t?.response?.data??[];return this.filterType==="vocal"&&d.instrumental===!0||this.filterType==="instrumental"&&d.instrumental!==!0?!1:this.filterDuration!=="all"||this.filterVideo!=="all"||this.filterModel&&this.filterModel!=="all"?r.some(m=>!(this.filterDuration==="short"&&!(typeof m.duration=="number"&&m.duration<60)||this.filterDuration==="medium"&&!(typeof m.duration=="number"&&m.duration>=60&&m.duration<=180)||this.filterDuration==="long"&&!(typeof m.duration=="number"&&m.duration>180)||this.filterVideo==="with"&&!m.video_url||this.filterVideo==="without"&&m.video_url||this.filterModel&&this.filterModel!=="all"&&m.model!==this.filterModel)):!0})),this.sortBy==="oldest"&&(e=[...e].reverse()),e}},methods:{onSortChange(e){this.sortBy=e},onResetFilters(){this.filterType="all",this.filterDuration="all",this.filterVideo="all",this.filterModel="all"},getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),va={key:0,class:"tasks"},ya={class:"left w-[70px] p-[10px] flex items-center"},ba={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},ka={key:0,class:"task-toolbar"},wa={key:0,class:"filter-badge"},Ca={class:"filter-popover"},Va={class:"filter-row"},Sa={class:"filter-label"},Ta={class:"filter-row"},Aa={class:"filter-label"},Ua={class:"filter-row"},Pa={class:"filter-label"},Ea={key:0,class:"filter-row"},Ia={class:"filter-label"},Ra={class:"filter-actions"},La={key:2,class:"w-full flex-1 flex items-center justify-center"},Ma={class:"text-sm text-gray-400"},Fa={key:3,class:"w-full flex-1 flex flex-col items-center justify-center gap-2"},Da={class:"text-sm text-gray-400"},za={key:4,class:"w-full flex-1 flex items-center justify-center"},ja={class:"h-20"};function Ga(e,t,d,r,m,y){const $=l("el-skeleton-item"),p=l("el-skeleton"),f=l("font-awesome-icon"),k=l("el-input"),g=l("el-button"),T=l("el-dropdown-item"),_=l("el-dropdown-menu"),V=l("el-dropdown"),C=l("el-radio-button"),I=l("el-radio-group"),U=l("el-option"),K=l("el-select"),J=l("el-popover"),Y=l("task-preview"),h=l("scroll-list"),S=l("no-tasks"),ae=l("player");return n(),u(M,null,[e.tasks?.items===void 0?(n(),u("div",va,[(n(),u(M,null,D(3,R=>s("div",{key:R,class:"flex"},[s("div",ya,[o(p,{animated:""},{template:a(()=>[o($,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",ba,[o(p,{animated:""},{template:a(()=>[o($,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o($,{variant:"text"})]),_:1})])])),64))])):(n(),u(M,{key:1},[e.tasks?.items?.length?(n(),u("div",ka,[o(k,{modelValue:e.searchQuery,"onUpdate:modelValue":t[0]||(t[0]=R=>e.searchQuery=R),size:"small",placeholder:e.$t("suno.placeholder.searchSongs"),clearable:"",class:"task-search"},{prefix:a(()=>[o(f,{icon:"fa-solid fa-magnifying-glass",class:"text-xs"})]),_:1},8,["modelValue","placeholder"]),o(V,{trigger:"click",onCommand:e.onSortChange},{dropdown:a(()=>[o(_,null,{default:a(()=>[o(T,{command:"newest",class:G({"is-active":e.sortBy==="newest"})},{default:a(()=>[v(i(e.$t("suno.sort.newest")),1)]),_:1},8,["class"]),o(T,{command:"oldest",class:G({"is-active":e.sortBy==="oldest"})},{default:a(()=>[v(i(e.$t("suno.sort.oldest")),1)]),_:1},8,["class"])]),_:1})]),default:a(()=>[o(g,{size:"small",class:"sort-btn"},{default:a(()=>[o(f,{icon:"fa-solid fa-arrow-down-wide-short",class:"mr-1"}),v(" "+i(e.sortLabel),1)]),_:1})]),_:1},8,["onCommand"]),o(J,{trigger:"click",placement:"bottom-end",width:260},{reference:a(()=>[o(g,{size:"small",class:G(["filter-btn",{"has-active-filter":e.activeFilterCount>0}])},{default:a(()=>[o(f,{icon:"fa-solid fa-filter",class:"mr-1"}),v(" "+i(e.$t("suno.filter.title"))+" ",1),e.activeFilterCount>0?(n(),u("span",wa,i(e.activeFilterCount),1)):c("",!0)]),_:1},8,["class"])]),default:a(()=>[s("div",Ca,[s("div",Va,[s("div",Sa,i(e.$t("suno.filter.type")),1),o(I,{modelValue:e.filterType,"onUpdate:modelValue":t[1]||(t[1]=R=>e.filterType=R),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.typeAll")),1)]),_:1}),o(C,{value:"vocal"},{default:a(()=>[v(i(e.$t("suno.filter.typeVocal")),1)]),_:1}),o(C,{value:"instrumental"},{default:a(()=>[v(i(e.$t("suno.filter.typeInstrumental")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",Ta,[s("div",Aa,i(e.$t("suno.filter.duration")),1),o(I,{modelValue:e.filterDuration,"onUpdate:modelValue":t[2]||(t[2]=R=>e.filterDuration=R),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.durationAll")),1)]),_:1}),o(C,{value:"short"},{default:a(()=>[v(i(e.$t("suno.filter.durationShort")),1)]),_:1}),o(C,{value:"medium"},{default:a(()=>[v(i(e.$t("suno.filter.durationMedium")),1)]),_:1}),o(C,{value:"long"},{default:a(()=>[v(i(e.$t("suno.filter.durationLong")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",Ua,[s("div",Pa,i(e.$t("suno.filter.video")),1),o(I,{modelValue:e.filterVideo,"onUpdate:modelValue":t[3]||(t[3]=R=>e.filterVideo=R),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.videoAll")),1)]),_:1}),o(C,{value:"with"},{default:a(()=>[v(i(e.$t("suno.filter.videoWith")),1)]),_:1}),o(C,{value:"without"},{default:a(()=>[v(i(e.$t("suno.filter.videoWithout")),1)]),_:1})]),_:1},8,["modelValue"])]),e.availableModels.length>0?(n(),u("div",Ea,[s("div",Ia,i(e.$t("suno.filter.model")),1),o(K,{modelValue:e.filterModel,"onUpdate:modelValue":t[4]||(t[4]=R=>e.filterModel=R),size:"small",placeholder:e.$t("suno.filter.modelAll"),clearable:""},{default:a(()=>[o(U,{label:e.$t("suno.filter.modelAll"),value:"all"},null,8,["label"]),(n(!0),u(M,null,D(e.availableModels,R=>(n(),b(U,{key:R,label:R,value:R},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])):c("",!0),s("div",Ra,[o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:a(()=>[v(i(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])])]),_:1})])):c("",!0),e.filteredTasks?.length>0?(n(),b(h,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[5]||(t[5]=R=>e.$emit("reach-top"))},{default:a(()=>[(n(!0),u(M,null,D(e.filteredTasks,(R,se)=>(n(),b(Y,{key:se,"model-value":R,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):e.searchQuery&&e.tasks?.items?.length>0?(n(),u("div",La,[s("p",Ma,i(e.$t("suno.message.noSearchResults")),1)])):e.activeFilterCount>0&&e.tasks?.items?.length>0?(n(),u("div",Fa,[s("p",Da,i(e.$t("suno.message.noFilterResults")),1),o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:a(()=>[v(i(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])):e.tasks?.items?.length===0?(n(),u("div",za,[o(S)])):c("",!0)],64)),N(s("div",ja,[o(ae)],512),[[qe,!!e.$store?.state?.suno?.audio?.object]])],64)}const Ba=E(_a,[["render",Ga],["__scopeId","data-v-4ab3f8f2"]]),Oa=A({name:"TaskPreview",components:{IconPicture:Oe,ElImage:O,ElAvatar:Be,ElIcon:te},computed:{audio(){return this.$store.state.suno?.audio}}}),Na={key:0,class:"size-full overflow-hidden"},qa={class:"relative h-[300px]"},Wa={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Ha={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"},Ka={class:"p-4"},Ja={class:"flex items-center font-bold mb-2"},Qa={class:"text-[var(--el-text-color-regular)] mb-2"},Ya={class:"text-xs text-[var(--el-text-color-regular)]"},Xa={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Za={key:1,class:"w-full h-full"};function xa(e,t,d,r,m,y){const $=l("icon-picture"),p=l("el-icon"),f=l("el-image"),k=l("el-avatar");return e.audio?.object?(n(),u("div",Na,[s("div",qa,[o(f,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:a(()=>[s("div",Wa,[o(p,{class:"text-3xl"},{default:a(()=>[o($)]),_:1})])]),_:1},8,["src"]),s("h2",Ha,i(e.audio?.title),1)]),s("div",Ka,[s("div",Ja,[o(k,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,i(e.audio?.title),1)]),s("p",Qa,i(e.audio?.style),1),s("p",Ya,i(e.$dayjs.format(e.audio?.created_at)),1),s("div",Xa,[s("p",null,i(e.audio?.lyric),1)])])])):(n(),u("div",Za))}const el=E(Oa,[["render",xa]]),tl="https://webhook.acedata.cloud/suno",ol=A({name:"SunoIndex",components:{Layout:ct,ConfigPanel:Si,RecentPanel:Ba,PreviewPanel:el},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await nt({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("suno/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("suno/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){Ke.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Je&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:d,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",d,"createdAtMax",r),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:d,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:tl},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("suno.message.startingTask")),L.audio(e,{token:t}).then(()=>{w.success(this.$t("suno.message.startTaskSuccess"))}).catch(d=>{w.error(d?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function sl(e,t,d,r,m,y){const $=l("config-panel"),p=l("recent-panel"),f=l("preview-panel"),k=l("layout");return n(),b(k,null,{config:a(()=>[o($,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:a(()=>[o(p,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:a(()=>[o(f)]),_:1})}const $l=E(ol,[["render",sl],["__scopeId","data-v-d1296b1a"]]);export{$l as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as C}from"./index.es-Q4HJJnLN.js";import{d as A,U as G,O as U,p as w,u as D,v as M,t as P,X as O,Y as j,Q as z,j as B,k as q}from"./vendor-element-plus-CQnKmb2Y.js";import{d as v,C as l,G as r,T as s,E as R,K as d,ai as o,D as a,R as i,Q as _,S as T,ag as I,J as S,M as V,c as N,O as $}from"./vendor-vue-qgt_zvDa.js";import{a as b,q as F,ao as H,L as Q,d as J,E as K,S as E}from"./index-D0vO2565.js";import{p as X}from"./pasteUploadMixin-BurWbGNQ.js";import{I as Y,S as W}from"./ScrollList-DTgkVuLR.js";import{I as Z}from"./ImagePreview-DKQRiQ0j.js";import{A as x}from"./Status-DRft8ONk.js";import{C as ee}from"./CopyToClipboard-DZ-hkTy6.js";import{l as se}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const te=v({name:"LayoutHeadshots",components:{ElDrawer:G,ElButton:A,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ae={class:"main flex flex-row flex-1"},oe={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ne={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ie(e,t,m,h,k,y){const p=o("font-awesome-icon"),u=o("el-button"),n=o("el-drawer");return a(),l("div",ae,[r("div",oe,[R(e.$slots,"config",{},void 0,!0)]),r("div",ne,[R(e.$slots,"result",{},void 0,!0)]),s(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=c=>e.drawer=!0)},{default:d(()=>[s(p,{icon:"fa-solid fa-gear"})]),_:1}),s(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=c=>e.drawer=c),"with-header":!1,size:"340px",class:"drawer"},{default:d(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const le=b(te,[["render",ie],["__scopeId","data-v-202b355b"]]),re=v({name:"ImageUrlsInput",components:{ElUpload:U,ElButton:A,InfoIcon:Y,ImagePreview:Z,FontAwesomeIcon:C},mixins:[X],data(){return{fileList:[],uploadUrl:F()+"/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.headshots?.config?.image_urls},set(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrls()},methods:{onExceed(){w.warning(this.$t("headshots.message.uploadImageExceed"))},onError(){w.error(this.$t("headshots.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),ce={class:"field"},de={class:"title font-bold"},pe={class:"upload-wrapper"};function me(e,t,m,h,k,y){const p=o("image-preview"),u=o("font-awesome-icon"),n=o("el-button"),c=o("el-upload"),g=o("info-icon");return a(),l("div",ce,[r("h2",de,i(e.$t("headshots.name.endImageUrls")),1),r("div",pe,[s(c,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:2,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:f})=>[s(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:L=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:d(()=>[s(n,{size:"small",type:"primary",round:""},{default:d(()=>[s(u,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+i(e.$t("headshots.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),s(g,{content:e.$t("headshots.description.endImageUrls"),class:"info"},null,8,["content"])])}const he=b(re,[["render",me],["__scopeId","data-v-ca56051e"]]),ue="fast",ge=v({name:"ModeSelector",components:{ElRadioButton:M,ElRadioGroup:D},data(){return{options:[{label:this.$t("headshots.button.fast"),value:"fast"},{label:this.$t("headshots.button.relax"),value:"relax"}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug("set mode",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||(this.value=ue)}}),fe={class:"field"},_e={class:"title font-bold"};function $e(e,t,m,h,k,y){const p=o("el-radio-button"),u=o("el-radio-group");return a(),l("div",fe,[r("h2",_e,i(e.$t("headshots.name.mode")),1),s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"mode"},{default:d(()=>[(a(!0),l(T,null,I(e.options,n=>(a(),S(p,{key:n.value,label:n.value},{default:d(()=>[_(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const ve=b(ge,[["render",$e],["__scopeId","data-v-e7702494"]]),be=v({name:"StylizeSelector",components:{ElTabs:j,ElTabPane:O,ElImage:P},data(){return{tab:"styles",value:"",elements:{styles:{displayName:this.$t("headshots.styleCategory.styles"),items:[{image:"https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png",label:this.$t("headshots.styleTag.malePportrait"),value:"male_portrait"},{image:"https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png",label:this.$t("headshots.styleTag.malePportrait2"),value:"male_portrait2"},{image:"https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png",label:this.$t("headshots.styleTag.kindergarten"),value:"kindergarten"},{image:"https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp",label:this.$t("headshots.styleTag.logoTshirt"),value:"logo_tshirt"},{image:"https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg",label:this.$t("headshots.styleTag.wedding"),value:"wedding"},{image:"https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp",label:this.$t("headshots.styleTag.businessPphoto"),value:"business_photo"},{image:"https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg",label:this.$t("headshots.styleTag.bobSuit"),value:"bob_suit"},{image:"https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp",label:this.$t("headshots.styleTag.femalePortrait"),value:"female_portrait"}]}}}},watch:{value(e){console.debug("set template",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||(this.value=""),console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value="":this.value=e,console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})}}}),ke={class:"field"},ye=["onClick"],we={class:"name"};function Te(e,t,m,h,k,y){const p=o("el-image"),u=o("el-tab-pane"),n=o("el-tabs");return a(),l("div",ke,[s(n,{modelValue:e.tab,"onUpdate:modelValue":t[0]||(t[0]=c=>e.tab=c)},{default:d(()=>[(a(!0),l(T,null,I(e.elements,(c,g)=>(a(),S(u,{key:g,label:c.displayName,name:g,class:"pane"},{default:d(()=>[(a(!0),l(T,null,I(c.items,(f,L)=>(a(),l("div",{key:L,class:V({item:!0,active:e.value===f.value}),onClick:$s=>e.onToggle(f.value)},[s(p,{src:f.image,fit:"fill",class:"preview"},null,8,["src"]),r("span",we,i(f.label),1)],10,ye))),128))]),_:2},1032,["label","name"]))),128))]),_:1},8,["modelValue"])])}const Ie=b(be,[["render",Te],["__scopeId","data-v-be4bd25d"]]),Se=v({name:"PresetPanel",components:{ModeSelector:ve,ImageUrlsInput:he,ElButton:A,FontAwesomeIcon:C,ElementsSelector:Ie},emits:["generate"],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit("generate")}}}),Ve={class:"panel"},Ee={class:"config"},Ce={class:"actions"};function Re(e,t,m,h,k,y){const p=o("elements-selector"),u=o("mode-selector"),n=o("image-urls-input"),c=o("font-awesome-icon"),g=o("el-button");return a(),l("div",Ve,[r("div",Ee,[s(p,{class:"mb-4"}),s(u,{class:"mb-4"}),s(n,{class:"mb-4"}),r("div",Ce,[s(g,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(c,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("headshots.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ae=b(Se,[["render",Re],["__scopeId","data-v-848739f6"]]),Le=v({name:"ImageGallery",props:{modelValue:{type:Object,required:!0}},setup(e){return{images:N(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:h=>{window.open(h,"_blank")}}}}),Pe={class:"image-gallery"},Ge=["src"],Ue=["onClick"];function De(e,t,m,h,k,y){return a(),l("div",Pe,[(a(!0),l(T,null,I(e.images,(p,u)=>(a(),l("div",{key:u,class:"image-container"},[r("img",{src:p.image_url,alt:"Image"},null,8,Ge),p.image_url?(a(),l("button",{key:0,class:"view-button",onClick:n=>e.viewImage(p.image_url)},i(e.$t("headshots.button.viewImage")),9,Ue)):$("",!0)]))),128))])}const Me=b(Le,[["render",De],["__scopeId","data-v-42f0a7be"]]),Oe=v({name:"TaskPreview",components:{ElImage:P,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:z,ImageGallery:Me},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onReload(e){const t=e.target,m=new URL(t.src),h=m.searchParams.get("retry");if(!h)m.searchParams.set("retry","1");else if(parseInt(h)<2)m.searchParams.set("retry",(parseInt(h)+1).toString());else return;t.src=m.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),je={class:"preview"},ze={class:"left"},Be={class:"main"},qe={class:"bot"},Ne={class:"datetime"},Fe={class:"info"},He={key:0,class:"prompt mt-2"},Qe={key:0},Je={key:1},Ke={key:0,class:V({content:!0,failed:!0})},Xe={class:"image-wrapper"},Ye={class:"description"},We={key:1,class:V({content:!0})},Ze={class:"description"},xe={class:"description"},es={class:"description"},ss={key:2,class:V({content:!0})},ts={class:"description"},as={key:3,class:V({content:!0})},os={class:"description"};function ns(e,t,m,h,k,y){const p=o("el-image"),u=o("image-gallery"),n=o("font-awesome-icon"),c=o("copy-to-clipboard"),g=o("el-alert");return a(),l("div",je,[r("div",ze,[s(p,{src:"https://cdn.acedata.cloud/isxyfw.png",class:"avatar"})]),r("div",Be,[r("div",qe,[_(i(e.$t("headshots.name.headshotsBot"))+" ",1),r("span",Ne,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",Fe,[e.modelValue?.request?.template?(a(),l("p",He,[_(i(e.modelValue?.request?.template)+" ",1),e.modelValue?.response?$("",!0):(a(),l("span",Qe," - ("+i(e.$t("headshots.status.pending"))+") ",1)),e.modelValue?.response?.status==="unknown"?(a(),l("span",Je," - ("+i(e.$t("headshots.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",Ke,[r("div",Xe,[s(u,{"model-value":e.modelValue},null,8,["model-value"])]),s(g,{closable:!1,class:"mt-2 success"},{default:d(()=>[r("p",Ye,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),l("div",We,[s(g,{closable:!1,class:"failure"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",Ze,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),r("p",xe,[s(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),s(c,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),r("p",es,[s(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("headshots.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),s(c,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?$("",!0):(a(),l("div",ss,[s(g,{closable:!1,class:"info"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",ts,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])),e.modelValue?.response?.status==="unknown"?(a(),l("div",as,[s(g,{closable:!1,class:"info"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",os,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0)])])}const is=b(Oe,[["render",ns],["__scopeId","data-v-91e2f073"]]),ls=v({name:"RecentPanel",components:{TaskPreview:is,ElSkeleton:q,ElSkeletonItem:B,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),rs={key:0,class:"tasks"},cs={class:"left"},ds={class:"main"},ps={key:1,class:"tasks"},ms={key:2,class:"description"};function hs(e,t,m,h,k,y){const p=o("el-skeleton-item"),u=o("el-skeleton"),n=o("task-preview"),c=o("scroll-list");return a(),S(c,{ref:"scrollList",class:"panel recent",loading:e.loading,onReachTop:t[0]||(t[0]=g=>e.$emit("reach-top"))},{default:d(()=>[e.tasks?.items===void 0?(a(),l("div",rs,[(a(),l(T,null,I(3,g=>r("div",{key:g,class:"task placeholder"},[r("div",cs,[s(u,{animated:""},{template:d(()=>[s(p,{variant:"image",class:"avatar"})]),_:1})]),r("div",ds,[s(u,{animated:""},{template:d(()=>[s(p,{variant:"p",class:"title"}),s(p,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),l("div",ps,[(a(!0),l(T,null,I(e.tasks?.items,(g,f)=>(a(),S(n,{key:f,"model-value":g,class:"preview"},null,8,["model-value"]))),128))])):$("",!0),e.tasks?.items?.length===0?(a(),l("p",ms,i(e.$t("headshots.message.noTasks")),1)):$("",!0)]),_:1},8,["loading"])}const us=b(ls,[["render",hs],["__scopeId","data-v-ffd55c16"]]),gs="https://webhook.acedata.cloud/headshots",fs=v({name:"HeadshotsIndex",components:{ConfigPanel:Ae,Layout:le,ApplicationStatus:x,RecentPanel:us},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.headshots?.status?.getApplications===E.Request},tasksLoading(){return this.$store.state.headshots?.status?.getTasks===E.Request||this.fetchingTasks},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===E.Request},needApply(){return this.$store.state.headshots.status.getApplications===E.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await se({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("headshots/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("headshots/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){J.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===K&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:m,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("headshots/getTasks",{limit:t,createdAtMin:m,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGeneratePicture(){const e={...this.config,callback_url:gs},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("headshots.message.startingTask")),H.generate(e,{token:t}).then(()=>{w.success(this.$t("headshots.message.startTaskSuccess")),this.$store.commit("headshots/setConfig",{config:void 0})}).catch(m=>{m?.response?.data?.error?.code===Q?w.error(this.$t("headshots.message.usedUp")):w.error(this.$t("headshots.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function _s(e,t,m,h,k,y){const p=o("config-panel"),u=o("application-status"),n=o("recent-panel"),c=o("layout");return a(),S(c,null,{config:d(()=>[s(p,{onGenerate:e.onGeneratePicture},null,8,["onGenerate"])]),result:d(()=>[s(u,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:"mb-4",onRefresh:e.onGetApplication,onSelect:t[0]||(t[0]=g=>e.$store.dispatch("headshots/setApplication",g))},null,8,["initializing","application","applications","service","need-apply","onRefresh"]),s(n,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ls=b(fs,[["render",_s],["__scopeId","data-v-6cafffbd"]]);export{Ls as default};
|
|
1
|
+
import{F as C}from"./index.es-p8_rCeM7.js";import{d as A,U as G,O as U,p as w,u as D,v as M,t as P,X as O,Y as j,Q as z,j as B,k as q}from"./vendor-element-plus-CQnKmb2Y.js";import{d as v,C as l,G as r,T as s,E as R,K as d,ai as o,D as a,R as i,Q as _,S as T,ag as I,J as S,M as V,c as N,O as $}from"./vendor-vue-qgt_zvDa.js";import{a as b,q as F,ao as H,L as Q,d as J,E as K,S as E}from"./index-CjUw7pA3.js";import{p as X}from"./pasteUploadMixin-BurWbGNQ.js";import{I as Y,S as W}from"./ScrollList-D_OIXYoa.js";import{I as Z}from"./ImagePreview-DYflUdpS.js";import{A as x}from"./Status-BvYR0NL5.js";import{C as ee}from"./CopyToClipboard-_MScsaoK.js";import{l as se}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const te=v({name:"LayoutHeadshots",components:{ElDrawer:G,ElButton:A,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ae={class:"main flex flex-row flex-1"},oe={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ne={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ie(e,t,m,h,k,y){const p=o("font-awesome-icon"),u=o("el-button"),n=o("el-drawer");return a(),l("div",ae,[r("div",oe,[R(e.$slots,"config",{},void 0,!0)]),r("div",ne,[R(e.$slots,"result",{},void 0,!0)]),s(u,{circle:"",class:"menu",onClick:t[0]||(t[0]=c=>e.drawer=!0)},{default:d(()=>[s(p,{icon:"fa-solid fa-gear"})]),_:1}),s(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=c=>e.drawer=c),"with-header":!1,size:"340px",class:"drawer"},{default:d(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const le=b(te,[["render",ie],["__scopeId","data-v-202b355b"]]),re=v({name:"ImageUrlsInput",components:{ElUpload:U,ElButton:A,InfoIcon:Y,ImagePreview:Z,FontAwesomeIcon:C},mixins:[X],data(){return{fileList:[],uploadUrl:F()+"/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.headshots?.config?.image_urls},set(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrls()},methods:{onExceed(){w.warning(this.$t("headshots.message.uploadImageExceed"))},onError(){w.error(this.$t("headshots.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),ce={class:"field"},de={class:"title font-bold"},pe={class:"upload-wrapper"};function me(e,t,m,h,k,y){const p=o("image-preview"),u=o("font-awesome-icon"),n=o("el-button"),c=o("el-upload"),g=o("info-icon");return a(),l("div",ce,[r("h2",de,i(e.$t("headshots.name.endImageUrls")),1),r("div",pe,[s(c,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:2,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:f})=>[s(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:L=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:d(()=>[s(n,{size:"small",type:"primary",round:""},{default:d(()=>[s(u,{icon:"fa-solid fa-upload",class:"mr-1"}),_(" "+i(e.$t("headshots.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),s(g,{content:e.$t("headshots.description.endImageUrls"),class:"info"},null,8,["content"])])}const he=b(re,[["render",me],["__scopeId","data-v-ca56051e"]]),ue="fast",ge=v({name:"ModeSelector",components:{ElRadioButton:M,ElRadioGroup:D},data(){return{options:[{label:this.$t("headshots.button.fast"),value:"fast"},{label:this.$t("headshots.button.relax"),value:"relax"}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug("set mode",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||(this.value=ue)}}),fe={class:"field"},_e={class:"title font-bold"};function $e(e,t,m,h,k,y){const p=o("el-radio-button"),u=o("el-radio-group");return a(),l("div",fe,[r("h2",_e,i(e.$t("headshots.name.mode")),1),s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"mode"},{default:d(()=>[(a(!0),l(T,null,I(e.options,n=>(a(),S(p,{key:n.value,label:n.value},{default:d(()=>[_(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const ve=b(ge,[["render",$e],["__scopeId","data-v-e7702494"]]),be=v({name:"StylizeSelector",components:{ElTabs:j,ElTabPane:O,ElImage:P},data(){return{tab:"styles",value:"",elements:{styles:{displayName:this.$t("headshots.styleCategory.styles"),items:[{image:"https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png",label:this.$t("headshots.styleTag.malePportrait"),value:"male_portrait"},{image:"https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png",label:this.$t("headshots.styleTag.malePportrait2"),value:"male_portrait2"},{image:"https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png",label:this.$t("headshots.styleTag.kindergarten"),value:"kindergarten"},{image:"https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp",label:this.$t("headshots.styleTag.logoTshirt"),value:"logo_tshirt"},{image:"https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg",label:this.$t("headshots.styleTag.wedding"),value:"wedding"},{image:"https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp",label:this.$t("headshots.styleTag.businessPphoto"),value:"business_photo"},{image:"https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg",label:this.$t("headshots.styleTag.bobSuit"),value:"bob_suit"},{image:"https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp",label:this.$t("headshots.styleTag.femalePortrait"),value:"female_portrait"}]}}}},watch:{value(e){console.debug("set template",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||(this.value=""),console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value="":this.value=e,console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})}}}),ke={class:"field"},ye=["onClick"],we={class:"name"};function Te(e,t,m,h,k,y){const p=o("el-image"),u=o("el-tab-pane"),n=o("el-tabs");return a(),l("div",ke,[s(n,{modelValue:e.tab,"onUpdate:modelValue":t[0]||(t[0]=c=>e.tab=c)},{default:d(()=>[(a(!0),l(T,null,I(e.elements,(c,g)=>(a(),S(u,{key:g,label:c.displayName,name:g,class:"pane"},{default:d(()=>[(a(!0),l(T,null,I(c.items,(f,L)=>(a(),l("div",{key:L,class:V({item:!0,active:e.value===f.value}),onClick:$s=>e.onToggle(f.value)},[s(p,{src:f.image,fit:"fill",class:"preview"},null,8,["src"]),r("span",we,i(f.label),1)],10,ye))),128))]),_:2},1032,["label","name"]))),128))]),_:1},8,["modelValue"])])}const Ie=b(be,[["render",Te],["__scopeId","data-v-be4bd25d"]]),Se=v({name:"PresetPanel",components:{ModeSelector:ve,ImageUrlsInput:he,ElButton:A,FontAwesomeIcon:C,ElementsSelector:Ie},emits:["generate"],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit("generate")}}}),Ve={class:"panel"},Ee={class:"config"},Ce={class:"actions"};function Re(e,t,m,h,k,y){const p=o("elements-selector"),u=o("mode-selector"),n=o("image-urls-input"),c=o("font-awesome-icon"),g=o("el-button");return a(),l("div",Ve,[r("div",Ee,[s(p,{class:"mb-4"}),s(u,{class:"mb-4"}),s(n,{class:"mb-4"}),r("div",Ce,[s(g,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[s(c,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("headshots.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ae=b(Se,[["render",Re],["__scopeId","data-v-848739f6"]]),Le=v({name:"ImageGallery",props:{modelValue:{type:Object,required:!0}},setup(e){return{images:N(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:h=>{window.open(h,"_blank")}}}}),Pe={class:"image-gallery"},Ge=["src"],Ue=["onClick"];function De(e,t,m,h,k,y){return a(),l("div",Pe,[(a(!0),l(T,null,I(e.images,(p,u)=>(a(),l("div",{key:u,class:"image-container"},[r("img",{src:p.image_url,alt:"Image"},null,8,Ge),p.image_url?(a(),l("button",{key:0,class:"view-button",onClick:n=>e.viewImage(p.image_url)},i(e.$t("headshots.button.viewImage")),9,Ue)):$("",!0)]))),128))])}const Me=b(Le,[["render",De],["__scopeId","data-v-42f0a7be"]]),Oe=v({name:"TaskPreview",components:{ElImage:P,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:z,ImageGallery:Me},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onReload(e){const t=e.target,m=new URL(t.src),h=m.searchParams.get("retry");if(!h)m.searchParams.set("retry","1");else if(parseInt(h)<2)m.searchParams.set("retry",(parseInt(h)+1).toString());else return;t.src=m.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),je={class:"preview"},ze={class:"left"},Be={class:"main"},qe={class:"bot"},Ne={class:"datetime"},Fe={class:"info"},He={key:0,class:"prompt mt-2"},Qe={key:0},Je={key:1},Ke={key:0,class:V({content:!0,failed:!0})},Xe={class:"image-wrapper"},Ye={class:"description"},We={key:1,class:V({content:!0})},Ze={class:"description"},xe={class:"description"},es={class:"description"},ss={key:2,class:V({content:!0})},ts={class:"description"},as={key:3,class:V({content:!0})},os={class:"description"};function ns(e,t,m,h,k,y){const p=o("el-image"),u=o("image-gallery"),n=o("font-awesome-icon"),c=o("copy-to-clipboard"),g=o("el-alert");return a(),l("div",je,[r("div",ze,[s(p,{src:"https://cdn.acedata.cloud/isxyfw.png",class:"avatar"})]),r("div",Be,[r("div",qe,[_(i(e.$t("headshots.name.headshotsBot"))+" ",1),r("span",Ne,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",Fe,[e.modelValue?.request?.template?(a(),l("p",He,[_(i(e.modelValue?.request?.template)+" ",1),e.modelValue?.response?$("",!0):(a(),l("span",Qe," - ("+i(e.$t("headshots.status.pending"))+") ",1)),e.modelValue?.response?.status==="unknown"?(a(),l("span",Je," - ("+i(e.$t("headshots.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",Ke,[r("div",Xe,[s(u,{"model-value":e.modelValue},null,8,["model-value"])]),s(g,{closable:!1,class:"mt-2 success"},{default:d(()=>[r("p",Ye,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(a(),l("div",We,[s(g,{closable:!1,class:"failure"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",Ze,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),r("p",xe,[s(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),s(c,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),r("p",es,[s(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("headshots.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),s(c,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?$("",!0):(a(),l("div",ss,[s(g,{closable:!1,class:"info"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",ts,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])),e.modelValue?.response?.status==="unknown"?(a(),l("div",as,[s(g,{closable:!1,class:"info"},{template:d(()=>[s(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("headshots.name.failure")),1)]),default:d(()=>[r("p",os,[s(n,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("headshots.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),s(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):$("",!0)])])}const is=b(Oe,[["render",ns],["__scopeId","data-v-91e2f073"]]),ls=v({name:"RecentPanel",components:{TaskPreview:is,ElSkeleton:q,ElSkeletonItem:B,ScrollList:W},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),rs={key:0,class:"tasks"},cs={class:"left"},ds={class:"main"},ps={key:1,class:"tasks"},ms={key:2,class:"description"};function hs(e,t,m,h,k,y){const p=o("el-skeleton-item"),u=o("el-skeleton"),n=o("task-preview"),c=o("scroll-list");return a(),S(c,{ref:"scrollList",class:"panel recent",loading:e.loading,onReachTop:t[0]||(t[0]=g=>e.$emit("reach-top"))},{default:d(()=>[e.tasks?.items===void 0?(a(),l("div",rs,[(a(),l(T,null,I(3,g=>r("div",{key:g,class:"task placeholder"},[r("div",cs,[s(u,{animated:""},{template:d(()=>[s(p,{variant:"image",class:"avatar"})]),_:1})]),r("div",ds,[s(u,{animated:""},{template:d(()=>[s(p,{variant:"p",class:"title"}),s(p,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),l("div",ps,[(a(!0),l(T,null,I(e.tasks?.items,(g,f)=>(a(),S(n,{key:f,"model-value":g,class:"preview"},null,8,["model-value"]))),128))])):$("",!0),e.tasks?.items?.length===0?(a(),l("p",ms,i(e.$t("headshots.message.noTasks")),1)):$("",!0)]),_:1},8,["loading"])}const us=b(ls,[["render",hs],["__scopeId","data-v-ffd55c16"]]),gs="https://webhook.acedata.cloud/headshots",fs=v({name:"HeadshotsIndex",components:{ConfigPanel:Ae,Layout:le,ApplicationStatus:x,RecentPanel:us},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.headshots?.status?.getApplications===E.Request},tasksLoading(){return this.$store.state.headshots?.status?.getTasks===E.Request||this.fetchingTasks},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===E.Request},needApply(){return this.$store.state.headshots.status.getApplications===E.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await se({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("headshots/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("headshots/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){J.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===K&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:m,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("headshots/getTasks",{limit:t,createdAtMin:m,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGeneratePicture(){const e={...this.config,callback_url:gs},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("headshots.message.startingTask")),H.generate(e,{token:t}).then(()=>{w.success(this.$t("headshots.message.startTaskSuccess")),this.$store.commit("headshots/setConfig",{config:void 0})}).catch(m=>{m?.response?.data?.error?.code===Q?w.error(this.$t("headshots.message.usedUp")):w.error(this.$t("headshots.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function _s(e,t,m,h,k,y){const p=o("config-panel"),u=o("application-status"),n=o("recent-panel"),c=o("layout");return a(),S(c,null,{config:d(()=>[s(p,{onGenerate:e.onGeneratePicture},null,8,["onGenerate"])]),result:d(()=>[s(u,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:"mb-4",onRefresh:e.onGetApplication,onSelect:t[0]||(t[0]=g=>e.$store.dispatch("headshots/setApplication",g))},null,8,["initializing","application","applications","service","need-apply","onRefresh"]),s(n,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Ls=b(fs,[["render",_s],["__scopeId","data-v-6cafffbd"]]);export{Ls as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as P}from"./index.es-Q4HJJnLN.js";import{d as L,U as O,o as q,w as G,x as M,u as B,v as j,O as N,p as V,N as z,n as F,Q as K,t as Q}from"./vendor-element-plus-CQnKmb2Y.js";import{d as $,C as r,G as l,T as t,E as A,K as u,ai as o,D as a,R as i,S as E,ag as T,J as I,Q as h,O as g,M as R}from"./vendor-vue-qgt_zvDa.js";import{a as k,bO as H,bP as J,bQ as W,q as X,bR as Y,L as Z,d as x,E as ee,S as C}from"./index-D0vO2565.js";import{I as D,S as te}from"./ScrollList-DTgkVuLR.js";import{p as se}from"./pasteUploadMixin-BurWbGNQ.js";import{I as oe}from"./ImagePreview-DKQRiQ0j.js";import{C as ae}from"./Consumption-CYxLWzfB.js";import{a as ne}from"./price-BxyGBvpv.js";import{C as ie}from"./CopyToClipboard-DZ-hkTy6.js";import{s as le}from"./vue-plyr-QZFBikSk.js";import{B as re}from"./BotPlaceholder-B9Ww1aFe.js";import{N as ce}from"./NoTasks-CIXbmsjQ.js";import{l as pe}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const de=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:L,FontAwesomeIcon:P},data(){return{drawer:!1}}}),ue={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function _e(e,s,c,d,v,b){const p=o("font-awesome-icon"),m=o("el-button"),n=o("el-drawer");return a(),r("div",ue,[l("div",me,[A(e.$slots,"config",{},void 0,!0)]),l("div",fe,[A(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:s[0]||(s[0]=y=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=y=>e.drawer=y),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[A(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const he=k(de,[["render",_e],["__scopeId","data-v-11f71ab6"]]),ge=$({name:"IngredientsSelector",components:{ElSwitch:q,InfoIcon:D},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=H)}}),$e={class:"field"},ke={class:"title font-bold"};function ve(e,s,c,d,v,b){const p=o("el-switch"),m=o("info-icon");return a(),r("div",$e,[l("h2",ke,i(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(m,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const be=k(ge,[["render",ve],["__scopeId","data-v-17c0af5c"]]),ye=$({name:"EffectSelector",components:{ElSelect:M,ElOption:G},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),we={class:"field"},Ve={class:"title font-bold"},Ie={class:"float-left"};function Se(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",we,[l("h2",Ve,i(e.$t("pika.name.effect")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},{default:u(()=>[l("span",Ie,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=k(ye,[["render",Se],["__scopeId","data-v-d1c54475"]]),Te=$({name:"IngredientsModelSelector",components:{ElRadioButton:j,ElRadioGroup:B},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=J)}}),Ce={class:"field"},Pe={class:"title font-bold"};function Le(e,s,c,d,v,b){const p=o("el-radio-button"),m=o("el-radio-group");return a(),r("div",Ce,[l("h2",Pe,i(e.$t("pika.name.ingredientsModel")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"quality"},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.value},{default:u(()=>[h(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Re=k(Te,[["render",Le],["__scopeId","data-v-b72865fa"]]),Ue=$({name:"ModelSelector",components:{ElSelect:M,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=W)}}),Ae={class:"field"},De={class:"title font-bold"};function Ge(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",Ae,[l("h2",De,i(e.$t("pika.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=k(Ue,[["render",Ge],["__scopeId","data-v-7b2e870a"]]),Oe=$({name:"ImageUrlInput",components:{ElUpload:N,ElButton:L,InfoIcon:D,ImagePreview:oe,FontAwesomeIcon:P},mixins:[se],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),qe={class:"field"},Be={class:"title font-bold"},je={class:"upload-wrapper"};function Ne(e,s,c,d,v,b){const p=o("image-preview"),m=o("font-awesome-icon"),n=o("el-button"),y=o("el-upload"),_=o("info-icon");return a(),r("div",qe,[l("h2",Be,i(e.$t("pika.name.imageUrl")),1),l("div",je,[t(y,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[t(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:u(()=>[t(n,{size:"small",type:"primary",round:""},{default:u(()=>[t(m,{icon:"fa-solid fa-upload",class:"mr-1"}),h(" "+i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(_,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const ze=k(Oe,[["render",Ne],["__scopeId","data-v-a948772f"]]),Fe="",Ke=$({name:"PromptInput",components:{ElInput:z,InfoIcon:D},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Fe)}}),Qe={class:"field"},He={class:"box"},Je={class:"title font-bold"};function We(e,s,c,d,v,b){const p=o("info-icon"),m=o("el-input");return a(),r("div",Qe,[l("div",He,[l("h2",Je,i(e.$t("pika.name.prompt")),1),t(p,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Xe=k(Ke,[["render",We],["__scopeId","data-v-d7f7cedd"]]),Ye=$({name:"PresetPanel",components:{ImageUrlInput:ze,ElButton:L,FontAwesomeIcon:P,Consumption:ae,PromptInput:Xe,IngredientsSelector:be,IngredientsModelSelector:Re,ModelSelector:Me,EffectSelector:Ee},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},xe={class:"flex-1 overflow-y-auto p-5"},et={class:"flex flex-col items-center justify-center px-5 pb-5"};function tt(e,s,c,d,v,b){const p=o("prompt-input"),m=o("model-selector"),n=o("ingredients-selector"),y=o("effect-selector"),_=o("image-url-input"),f=o("ingredients-model-selector"),S=o("consumption"),w=o("font-awesome-icon"),U=o("el-button");return a(),r("div",Ze,[l("div",xe,[t(p,{class:"mb-4"}),t(m,{class:"mb-4"}),t(n,{class:"mb-4"}),t(y,{class:"mb-4"}),e.config?.ingredients?(a(),I(_,{key:0,class:"mb-4"})):g("",!0),e.config?.ingredients?(a(),I(f,{key:1,class:"mb-4"})):g("",!0)]),l("div",et,[t(S,{value:e.consumption,service:e.service},null,8,["value","service"]),t(U,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(w,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const st=k(Ye,[["render",tt]]),ot=$({name:"VideoPlayer",components:{VuePlyr:le},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),at=["data-poster"],nt=["src"];function it(e,s,c,d,v,b){const p=o("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:u(()=>[l("video",{controls:"",crossorigin:"",playsinline:"","data-poster":e.modelValue?.image_url},[l("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,nt)],8,at)]),_:1},8,["options"])])}const lt=k(ot,[["render",it],["__scopeId","data-v-fc420430"]]),rt=$({name:"TaskPreview",components:{ElImage:Q,CopyToClipboard:ie,FontAwesomeIcon:P,ElAlert:K,VideoPlayer:lt,ElTooltip:F,ElButton:L},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const s=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(c=>{let d=c;s&&(d.action=s),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const s=e.target,c=new URL(s.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;s.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),ct={class:"left"},pt={class:"main"},dt={class:"bot"},ut={class:"datetime"},mt={class:"info"},ft={key:0,class:"prompt mt-2"},_t={key:0},ht={key:1},gt={key:0,class:R({content:!0,failed:!0})},$t={class:"image-wrapper"},kt={key:0,class:R({operations:!0,"mt-2":!0})},vt={key:0,class:"description"},bt={class:"description"},yt={key:1,class:R({content:!0})},wt={class:"description"},Vt={class:"description"},It={class:"description"},St={key:2,class:R({content:!0})},Et={class:"description"};function Tt(e,s,c,d,v,b){const p=o("el-image"),m=o("VideoPlayer"),n=o("el-button"),y=o("el-tooltip"),_=o("font-awesome-icon"),f=o("copy-to-clipboard"),S=o("el-alert");return a(!0),r(E,null,T(e.videos,(w,U)=>(a(),r("div",{key:U,class:"preview"},[l("div",ct,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",pt,[l("div",dt,[h(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",ut,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",mt,[e.modelValue?.request?.prompt?(a(),r("p",ft,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),r("span",_t," - ("+i(e.$t("pika.status.pending"))+") ",1)),w?.state==="processing"||w?.state==="pending"?(a(),r("span",ht," - ("+i(e.$t("pika.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",gt,[l("div",$t,[t(m,{"model-value":w},null,8,["model-value"])]),w?(a(),r("div",kt,[t(y,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:u(()=>[w?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Ot=>e.onDownload(w?.video_url)},{default:u(()=>[h(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1032,["content"])])):g("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(a(),r("p",vt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.model"))+": "+i(e.modelValue?.request?.model),1)])):g("",!0),l("p",bt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(a(),r("div",yt,[t(S,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",wt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",Vt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(f,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",It,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(f,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),!e.modelValue?.response||w?.state==="processing"||w?.state==="pending"?(a(),r("div",St,[t(S,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",Et,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])]))),128)}const Ct=k(rt,[["render",Tt],["__scopeId","data-v-df7eb728"]]),Pt=$({name:"RecentPanel",components:{TaskPreview:Ct,BotPlaceholder:re,NoTasks:ce,ScrollList:te},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Lt={key:0},Rt={key:2,class:"w-full h-full flex items-center justify-center"};function Ut(e,s,c,d,v,b){const p=o("bot-placeholder"),m=o("task-preview"),n=o("scroll-list"),y=o("no-tasks");return a(),r(E,null,[e.tasks?.items===void 0?(a(),r("div",Lt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(E,null,T(e.tasks?.items,(_,f)=>(a(),I(m,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),r("div",Rt,[t(y)])):g("",!0)],64)}const At=k(Pt,[["render",Ut]]),Dt="https://webhook.acedata.cloud/pika",Gt=$({name:"PikaIndex",components:{ConfigPanel:st,Layout:he,RecentPanel:At},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===C.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===C.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===C.Request},needApply(){return this.$store.state.pika.status.getApplications===C.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await pe({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){x.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ee&&V.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Dt},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),Y.generate(e,{token:s}).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===Z?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Mt(e,s,c,d,v,b){const p=o("config-panel"),m=o("recent-panel"),n=o("layout");return a(),I(n,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ss=k(Gt,[["render",Mt],["__scopeId","data-v-456819d1"]]);export{ss as default};
|
|
1
|
+
import{F as P}from"./index.es-p8_rCeM7.js";import{d as L,U as O,o as q,w as G,x as M,u as B,v as j,O as N,p as V,N as z,n as F,Q as K,t as Q}from"./vendor-element-plus-CQnKmb2Y.js";import{d as $,C as r,G as l,T as t,E as A,K as u,ai as o,D as a,R as i,S as E,ag as T,J as I,Q as h,O as g,M as R}from"./vendor-vue-qgt_zvDa.js";import{a as k,bO as H,bP as J,bQ as W,q as X,bR as Y,L as Z,d as x,E as ee,S as C}from"./index-CjUw7pA3.js";import{I as D,S as te}from"./ScrollList-D_OIXYoa.js";import{p as se}from"./pasteUploadMixin-BurWbGNQ.js";import{I as oe}from"./ImagePreview-DYflUdpS.js";import{C as ae}from"./Consumption-BBl6mTTl.js";import{a as ne}from"./price-CbJb5IRW.js";import{C as ie}from"./CopyToClipboard-_MScsaoK.js";import{s as le}from"./vue-plyr-QZFBikSk.js";import{B as re}from"./BotPlaceholder-CdQRRE9L.js";import{N as ce}from"./NoTasks-RLiH-azt.js";import{l as pe}from"./pagination-BISGwxYx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-u1O--QAh.js";const de=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:L,FontAwesomeIcon:P},data(){return{drawer:!1}}}),ue={class:"main flex flex-row flex-1"},me={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function _e(e,s,c,d,v,b){const p=o("font-awesome-icon"),m=o("el-button"),n=o("el-drawer");return a(),r("div",ue,[l("div",me,[A(e.$slots,"config",{},void 0,!0)]),l("div",fe,[A(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:s[0]||(s[0]=y=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=y=>e.drawer=y),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[A(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const he=k(de,[["render",_e],["__scopeId","data-v-11f71ab6"]]),ge=$({name:"IngredientsSelector",components:{ElSwitch:q,InfoIcon:D},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=H)}}),$e={class:"field"},ke={class:"title font-bold"};function ve(e,s,c,d,v,b){const p=o("el-switch"),m=o("info-icon");return a(),r("div",$e,[l("h2",ke,i(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(m,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const be=k(ge,[["render",ve],["__scopeId","data-v-17c0af5c"]]),ye=$({name:"EffectSelector",components:{ElSelect:M,ElOption:G},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),we={class:"field"},Ve={class:"title font-bold"},Ie={class:"float-left"};function Se(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",we,[l("h2",Ve,i(e.$t("pika.name.effect")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},{default:u(()=>[l("span",Ie,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=k(ye,[["render",Se],["__scopeId","data-v-d1c54475"]]),Te=$({name:"IngredientsModelSelector",components:{ElRadioButton:j,ElRadioGroup:B},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=J)}}),Ce={class:"field"},Pe={class:"title font-bold"};function Le(e,s,c,d,v,b){const p=o("el-radio-button"),m=o("el-radio-group");return a(),r("div",Ce,[l("h2",Pe,i(e.$t("pika.name.ingredientsModel")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"quality"},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.value},{default:u(()=>[h(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Re=k(Te,[["render",Le],["__scopeId","data-v-b72865fa"]]),Ue=$({name:"ModelSelector",components:{ElSelect:M,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=W)}}),Ae={class:"field"},De={class:"title font-bold"};function Ge(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",Ae,[l("h2",De,i(e.$t("pika.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=k(Ue,[["render",Ge],["__scopeId","data-v-7b2e870a"]]),Oe=$({name:"ImageUrlInput",components:{ElUpload:N,ElButton:L,InfoIcon:D,ImagePreview:oe,FontAwesomeIcon:P},mixins:[se],data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),qe={class:"field"},Be={class:"title font-bold"},je={class:"upload-wrapper"};function Ne(e,s,c,d,v,b){const p=o("image-preview"),m=o("font-awesome-icon"),n=o("el-button"),y=o("el-upload"),_=o("info-icon");return a(),r("div",qe,[l("h2",Be,i(e.$t("pika.name.imageUrl")),1),l("div",je,[t(y,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[t(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:u(()=>[t(n,{size:"small",type:"primary",round:""},{default:u(()=>[t(m,{icon:"fa-solid fa-upload",class:"mr-1"}),h(" "+i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(_,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const ze=k(Oe,[["render",Ne],["__scopeId","data-v-a948772f"]]),Fe="",Ke=$({name:"PromptInput",components:{ElInput:z,InfoIcon:D},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Fe)}}),Qe={class:"field"},He={class:"box"},Je={class:"title font-bold"};function We(e,s,c,d,v,b){const p=o("info-icon"),m=o("el-input");return a(),r("div",Qe,[l("div",He,[l("h2",Je,i(e.$t("pika.name.prompt")),1),t(p,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pika.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Xe=k(Ke,[["render",We],["__scopeId","data-v-d7f7cedd"]]),Ye=$({name:"PresetPanel",components:{ImageUrlInput:ze,ElButton:L,FontAwesomeIcon:P,Consumption:ae,PromptInput:Xe,IngredientsSelector:be,IngredientsModelSelector:Re,ModelSelector:Me,EffectSelector:Ee},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},xe={class:"flex-1 overflow-y-auto p-5"},et={class:"flex flex-col items-center justify-center px-5 pb-5"};function tt(e,s,c,d,v,b){const p=o("prompt-input"),m=o("model-selector"),n=o("ingredients-selector"),y=o("effect-selector"),_=o("image-url-input"),f=o("ingredients-model-selector"),S=o("consumption"),w=o("font-awesome-icon"),U=o("el-button");return a(),r("div",Ze,[l("div",xe,[t(p,{class:"mb-4"}),t(m,{class:"mb-4"}),t(n,{class:"mb-4"}),t(y,{class:"mb-4"}),e.config?.ingredients?(a(),I(_,{key:0,class:"mb-4"})):g("",!0),e.config?.ingredients?(a(),I(f,{key:1,class:"mb-4"})):g("",!0)]),l("div",et,[t(S,{value:e.consumption,service:e.service},null,8,["value","service"]),t(U,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(w,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const st=k(Ye,[["render",tt]]),ot=$({name:"VideoPlayer",components:{VuePlyr:le},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),at=["data-poster"],nt=["src"];function it(e,s,c,d,v,b){const p=o("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:u(()=>[l("video",{controls:"",crossorigin:"",playsinline:"","data-poster":e.modelValue?.image_url},[l("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,nt)],8,at)]),_:1},8,["options"])])}const lt=k(ot,[["render",it],["__scopeId","data-v-fc420430"]]),rt=$({name:"TaskPreview",components:{ElImage:Q,CopyToClipboard:ie,FontAwesomeIcon:P,ElAlert:K,VideoPlayer:lt,ElTooltip:F,ElButton:L},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const s=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(c=>{let d=c;s&&(d.action=s),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const s=e.target,c=new URL(s.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;s.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),ct={class:"left"},pt={class:"main"},dt={class:"bot"},ut={class:"datetime"},mt={class:"info"},ft={key:0,class:"prompt mt-2"},_t={key:0},ht={key:1},gt={key:0,class:R({content:!0,failed:!0})},$t={class:"image-wrapper"},kt={key:0,class:R({operations:!0,"mt-2":!0})},vt={key:0,class:"description"},bt={class:"description"},yt={key:1,class:R({content:!0})},wt={class:"description"},Vt={class:"description"},It={class:"description"},St={key:2,class:R({content:!0})},Et={class:"description"};function Tt(e,s,c,d,v,b){const p=o("el-image"),m=o("VideoPlayer"),n=o("el-button"),y=o("el-tooltip"),_=o("font-awesome-icon"),f=o("copy-to-clipboard"),S=o("el-alert");return a(!0),r(E,null,T(e.videos,(w,U)=>(a(),r("div",{key:U,class:"preview"},[l("div",ct,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",pt,[l("div",dt,[h(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",ut,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",mt,[e.modelValue?.request?.prompt?(a(),r("p",ft,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),r("span",_t," - ("+i(e.$t("pika.status.pending"))+") ",1)),w?.state==="processing"||w?.state==="pending"?(a(),r("span",ht," - ("+i(e.$t("pika.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",gt,[l("div",$t,[t(m,{"model-value":w},null,8,["model-value"])]),w?(a(),r("div",kt,[t(y,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:u(()=>[w?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Ot=>e.onDownload(w?.video_url)},{default:u(()=>[h(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1032,["content"])])):g("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(a(),r("p",vt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.model"))+": "+i(e.modelValue?.request?.model),1)])):g("",!0),l("p",bt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(a(),r("div",yt,[t(S,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",wt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",Vt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(f,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",It,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(f,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),!e.modelValue?.response||w?.state==="processing"||w?.state==="pending"?(a(),r("div",St,[t(S,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",Et,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])]))),128)}const Ct=k(rt,[["render",Tt],["__scopeId","data-v-df7eb728"]]),Pt=$({name:"RecentPanel",components:{TaskPreview:Ct,BotPlaceholder:re,NoTasks:ce,ScrollList:te},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Lt={key:0},Rt={key:2,class:"w-full h-full flex items-center justify-center"};function Ut(e,s,c,d,v,b){const p=o("bot-placeholder"),m=o("task-preview"),n=o("scroll-list"),y=o("no-tasks");return a(),r(E,null,[e.tasks?.items===void 0?(a(),r("div",Lt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(E,null,T(e.tasks?.items,(_,f)=>(a(),I(m,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),r("div",Rt,[t(y)])):g("",!0)],64)}const At=k(Pt,[["render",Ut]]),Dt="https://webhook.acedata.cloud/pika",Gt=$({name:"PikaIndex",components:{ConfigPanel:st,Layout:he,RecentPanel:At},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===C.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===C.Request||this.fetchingTasks},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===C.Request},needApply(){return this.$store.state.pika.status.getApplications===C.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await pe({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){x.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===ee&&V.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Dt},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),Y.generate(e,{token:s}).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===Z?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Mt(e,s,c,d,v,b){const p=o("config-panel"),m=o("recent-panel"),n=o("layout");return a(),I(n,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const ss=k(Gt,[["render",Mt],["__scopeId","data-v-456819d1"]]);export{ss as default};
|