@acedatacloud/nexior 3.37.0 → 3.39.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 +1 -0
- package/dist/assets/BotPlaceholder-B9Ww1aFe.js +1 -0
- package/dist/assets/Callback-DB6VsxSu.js +1 -0
- package/dist/assets/Console-m-2kLU5c.js +1 -0
- package/dist/assets/{Consumption-DTFyP44R.js → Consumption-CYxLWzfB.js} +1 -1
- package/dist/assets/{Conversation-BPr3j2Yr.js → Conversation-Cj0tmGpI.js} +2 -2
- package/dist/assets/CopyToClipboard-DZ-hkTy6.js +1 -0
- package/dist/assets/Detail-DI1bc4mQ.js +2 -0
- package/dist/assets/EditArray-CIa3ND0t.js +1 -0
- package/dist/assets/Extra-CTtAVTv3.js +1 -0
- package/dist/assets/FilePreview-DrY18bah.js +1 -0
- package/dist/assets/History-DtLSxQ9h.js +1 -0
- package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-C7eA9UI3.js → IconPark.vue_vue_type_script_setup_true_lang-CNnhez9x.js} +1 -1
- package/dist/assets/{ImagePreview-COK_lQAf.js → ImagePreview-DKQRiQ0j.js} +1 -1
- package/dist/assets/{ImageWrapper-tWRqlRkx.js → ImageWrapper-ojoZewc8.js} +1 -1
- package/dist/assets/Index-B-yZ-l8r.js +1 -0
- package/dist/assets/Index-B8ol-aOh.js +1 -0
- package/dist/assets/Index-B9jiRvGf.js +1 -0
- package/dist/assets/Index-BI3YZdz1.js +1 -0
- package/dist/assets/Index-BRYJ_LD2.js +1 -0
- package/dist/assets/Index-BlmmK8vQ.js +1 -0
- package/dist/assets/Index-BuMHRKS_.js +1 -0
- package/dist/assets/Index-BuOKUD_r.js +1 -0
- package/dist/assets/Index-C9wjakQQ.js +1 -0
- package/dist/assets/Index-CKXOS0UE.js +1 -0
- package/dist/assets/Index-CUBYRhSH.js +1 -0
- package/dist/assets/Index-CbOOJZ5M.js +1 -0
- package/dist/assets/Index-CjBReyy1.js +1 -0
- package/dist/assets/Index-CxJQZBRf.js +4 -0
- package/dist/assets/Index-DNrqFYl3.css +1 -0
- package/dist/assets/Index-DUMG3CE3.js +1 -0
- package/dist/assets/Index-Db6Kknc4.js +1 -0
- package/dist/assets/Index-DiWePb6Y.js +1 -0
- package/dist/assets/Index-J-nQBiBP.js +1 -0
- package/dist/assets/Index-Jc9FI1hb.js +1 -0
- package/dist/assets/Index-LLKF8NP-.js +1 -0
- package/dist/assets/Index-d1re_GiC.js +1 -0
- package/dist/assets/Index-diYQwpZD.js +1 -0
- package/dist/assets/Index-gFIpUggR.js +1 -0
- package/dist/assets/Index-pSJJf2uJ.js +1 -0
- package/dist/assets/Invitees-BLqsKup3.js +1 -0
- package/dist/assets/List-BjDUWhof.js +1 -0
- package/dist/assets/List-D2EmhqIO.js +1 -0
- package/dist/assets/List-D7APfSkZ.js +1 -0
- package/dist/assets/{Login-4OoulsoS.js → Login-MBGScPOp.js} +1 -1
- package/dist/assets/Main-DUTUxec7.js +1 -0
- package/dist/assets/Navigator-D-cANjUI.js +1 -0
- package/dist/assets/NoTasks-CIXbmsjQ.js +1 -0
- package/dist/assets/OAuthCallback-CULHo_Tu.js +1 -0
- package/dist/assets/{Pagination-DE9cWxMh.js → Pagination-B96SB_9q.js} +1 -1
- package/dist/assets/{ScrollList-_cUBLaZZ.js → ScrollList-DTgkVuLR.js} +1 -1
- package/dist/assets/Status-DRft8ONk.js +1 -0
- package/dist/assets/Subscribe-C1bDa70a.js +1 -0
- package/dist/assets/TransportWebHID-BFi4KZ_q.js +1 -0
- package/dist/assets/{VideoPlayer-CF6zk-Kd.js → VideoPlayer-ACwtTDeP.js} +1 -1
- package/dist/assets/add-DzAWbmaQ.js +15 -0
- package/dist/assets/all-wallets-C-Q-GSKX.js +6 -0
- package/dist/assets/app-store-D2pI6pcZ.js +17 -0
- package/dist/assets/apple-BY9KBMvH.js +18 -0
- package/dist/assets/arrow-bottom-Ce6e1La6.js +8 -0
- package/dist/assets/arrow-bottom-circle-DoimaE1k.js +11 -0
- package/dist/assets/arrow-left-CT-gb3_f.js +8 -0
- package/dist/assets/arrow-right-DtLPR-VN.js +8 -0
- package/dist/assets/arrow-top-B689Lohf.js +8 -0
- package/dist/assets/{avatar-BUeF6xoP.js → avatar-C2HlXd8q.js} +1 -1
- package/dist/assets/bank-14SxdBw4.js +14 -0
- package/dist/assets/basic-B_1o-xIe.js +2115 -0
- package/dist/assets/bignumber-Df3Cckea.js +1 -0
- package/dist/assets/browser-C4bslPo3.js +14 -0
- package/dist/assets/card-BKeqsjAl.js +14 -0
- package/dist/assets/checkmark-DmN75zYD.js +11 -0
- package/dist/assets/checkmark-bold-CfL5lZLG.js +8 -0
- package/dist/assets/chevron-bottom-CK86jgbh.js +8 -0
- package/dist/assets/chevron-left-CQcfFHH8.js +8 -0
- package/dist/assets/chevron-right-CLRHniop.js +8 -0
- package/dist/assets/chevron-top-DSfuzvr0.js +8 -0
- package/dist/assets/chrome-store-Cu1FjnkN.js +61 -0
- package/dist/assets/clock-DaWQHmHB.js +8 -0
- package/dist/assets/close-bMVl8sPK.js +8 -0
- package/dist/assets/coinPlaceholder-CKRLXBoy.js +8 -0
- package/dist/assets/compass-HPgLsDyV.js +8 -0
- package/dist/assets/copy-DV702Out.js +15 -0
- package/dist/assets/cursor-BizrN5yL.js +3 -0
- package/dist/assets/cursor-transparent-DtBQD998.js +12 -0
- package/dist/assets/desktop-BB0_yTru.js +9 -0
- package/dist/assets/disconnect-6nEf9wc2.js +8 -0
- package/dist/assets/discord-BRYeJyqs.js +17 -0
- package/dist/assets/distribution-BtBkwRRT.js +1 -0
- package/dist/assets/etherscan-CKl92LBc.js +6 -0
- package/dist/assets/events-D0CJzW9n.js +1 -0
- package/dist/assets/exclamation-triangle-CCd9Gfyj.js +4 -0
- package/dist/assets/extension-Dq2t_PPn.js +8 -0
- package/dist/assets/external-link-pr-SQ8YT.js +8 -0
- package/dist/assets/facebook-DdJv4ZKt.js +26 -0
- package/dist/assets/farcaster-G1nMRd3g.js +12 -0
- package/dist/assets/filters-Bt2GCvxa.js +8 -0
- package/dist/assets/github-DzEOIakb.js +18 -0
- package/dist/assets/google-_Sa__qj-.js +18 -0
- package/dist/assets/help-circle-KT2jCidJ.js +12 -0
- package/dist/assets/id-BDIDX24R.js +12 -0
- package/dist/assets/image-V63z36yv.js +4 -0
- package/dist/assets/index-9Z3s9vER.js +1 -0
- package/dist/assets/index-BZH4xSG9.js +3 -0
- package/dist/assets/{index-BpCZBwAt.js → index-BhDhLSKE.js} +3 -3
- package/dist/assets/{index-DbW-B2qb.js → index-CR2O5iwt.js} +48 -48
- package/dist/assets/index-CXc6VuzW.js +1 -0
- package/dist/assets/index-CcFtMru9.js +3 -0
- package/dist/assets/{index-D220ynN6.js → index-Chn-DN0T.js} +1 -1
- package/dist/assets/index-Cxt3EugS.js +1 -0
- package/dist/assets/{index-59WF-aDo.js → index-D0vO2565.js} +30 -30
- package/dist/assets/index-DKuuwhRE.js +955 -0
- package/dist/assets/index-DqpLng1I.js +1 -0
- package/dist/assets/index-tqcowstn.js +395 -0
- package/dist/assets/index.browser.esm-CWwRaw8s.js +13 -0
- package/dist/assets/index.es-Q4HJJnLN.js +1 -0
- package/dist/assets/info-CCrGNsvU.js +3 -0
- package/dist/assets/info-circle-B_uXnoCn.js +12 -0
- package/dist/assets/lightbulb-25RHD0P4.js +3 -0
- package/dist/assets/mail-DhOV-I_J.js +8 -0
- package/dist/assets/mobile-Dtwt2n3D.js +9 -0
- package/dist/assets/more-ColoEcBE.js +11 -0
- package/dist/assets/network-placeholder-DHAJJeIx.js +14 -0
- package/dist/assets/nftPlaceholder-DiJc2RhW.js +8 -0
- package/dist/assets/off-B4RFjHNh.js +8 -0
- package/dist/assets/order-DUr8hGM-.js +1 -0
- package/dist/assets/{pagination-DLJ2pbsx.js → pagination-BISGwxYx.js} +1 -1
- package/dist/assets/play-store-BK_xoWfl.js +32 -0
- package/dist/assets/plus-Dq-Dmc7x.js +13 -0
- package/dist/assets/price-BxyGBvpv.js +1 -0
- package/dist/assets/qr-code-BI7lfdrx.js +6 -0
- package/dist/assets/recycle-horizontal-C3G6nbhF.js +9 -0
- package/dist/assets/refresh-8YhrVSu_.js +8 -0
- package/dist/assets/reown-logo-C0DAxZe9.js +12 -0
- package/dist/assets/search-Cyw3suPr.js +8 -0
- package/dist/assets/secp256k1-Dtotceig.js +1 -0
- package/dist/assets/secp256k1-J740LWdw.js +1 -0
- package/dist/assets/send-CkH9x4NW.js +15 -0
- package/dist/assets/solana-wallets-DCHhejMj.js +2 -0
- package/dist/assets/solana-wallets-vue-BZgXY5It.js +21 -0
- package/dist/assets/solanaEmbed.esm-C-L32rVL.js +10 -0
- package/dist/assets/standard-D6thY6gA.js +1 -0
- package/dist/assets/string_decoder-D7ymg8hN.js +1 -0
- package/dist/assets/{suno-B2EXqZt4.js → suno-B1GiqT-T.js} +1 -1
- package/dist/assets/{suno-BC6a0SoY.js → suno-D3UODCz4.js} +1 -1
- package/dist/assets/swapHorizontal-BpJZZgCG.js +8 -0
- package/dist/assets/swapHorizontalBold-jf6RbZ3Z.js +8 -0
- package/dist/assets/swapHorizontalMedium-DiODKF-T.js +16 -0
- package/dist/assets/swapHorizontalRoundedBold-DnrrjXNQ.js +8 -0
- package/dist/assets/swapVertical-hbZOlsvI.js +8 -0
- package/dist/assets/telegram-DC670vUO.js +16 -0
- package/dist/assets/three-dots-tuhIyikw.js +5 -0
- package/dist/assets/twitch-BohURGxQ.js +18 -0
- package/dist/assets/twitterIcon-CBMkIrjS.js +6 -0
- package/dist/assets/types-Cvj5H4DH.js +1 -0
- package/dist/assets/{vendor-chart-CdHmgBC5.js → vendor-chart-BjhYT8mq.js} +1 -1
- package/dist/assets/{vendor-element-plus-ZfFlETcH.js → vendor-element-plus-CQnKmb2Y.js} +2 -2
- package/dist/assets/{vendor-vue-BhXato7y.js → vendor-vue-qgt_zvDa.js} +1 -1
- package/dist/assets/{vendor-vue-router-8bYQCSwj.js → vendor-vue-router-u1O--QAh.js} +1 -1
- package/dist/assets/verify-CEsMn4f3.js +8 -0
- package/dist/assets/verify-filled-CW3a2eJh.js +8 -0
- package/dist/assets/w3m-modal-DAALPFfK.js +644 -0
- package/dist/assets/wallet-DAiXY9mg.js +8 -0
- package/dist/assets/wallet-placeholder-BnUqVZup.js +14 -0
- package/dist/assets/walletconnect-CUjtNkFF.js +30 -0
- package/dist/assets/warning-circle-T7iAnm6a.js +12 -0
- package/dist/assets/web-CSDLhi1Z.js +1 -0
- package/dist/assets/web-dNqPnBRw.js +1 -0
- package/dist/assets/x-C5mUIwaL.js +12 -0
- package/dist/index.html +37 -13
- package/package.json +1 -1
- package/dist/assets/Auth-B0r-juFO.js +0 -1
- package/dist/assets/BotPlaceholder-DEITkzHi.js +0 -1
- package/dist/assets/Callback-CGwf8d8n.js +0 -1
- package/dist/assets/Console--9XSD6DQ.js +0 -1
- package/dist/assets/CopyToClipboard-COWZc6L9.js +0 -1
- package/dist/assets/Detail-CCbd4Bq9.js +0 -2
- package/dist/assets/EditArray-UipmkzQk.js +0 -1
- package/dist/assets/Extra-Cr_5oVqv.js +0 -1
- package/dist/assets/FilePreview-DrDarXxz.js +0 -1
- package/dist/assets/History-BjYNQalO.js +0 -1
- package/dist/assets/Index-59yOvdC5.js +0 -1
- package/dist/assets/Index-8yjJ2a3P.js +0 -1
- package/dist/assets/Index-BCWGcmTi.js +0 -1
- package/dist/assets/Index-BXkyiXCB.js +0 -1
- package/dist/assets/Index-BlBSGmUe.js +0 -1
- package/dist/assets/Index-C4phnzV_.js +0 -1
- package/dist/assets/Index-CHASyFDL.js +0 -1
- package/dist/assets/Index-CN1RLB9p.js +0 -1
- package/dist/assets/Index-CbjsMkx4.js +0 -1
- package/dist/assets/Index-CeV6UIvP.js +0 -1
- package/dist/assets/Index-CfiZClON.js +0 -1
- package/dist/assets/Index-Ci3uTuoz.js +0 -1
- package/dist/assets/Index-Cjxg8NOx.css +0 -1
- package/dist/assets/Index-DJNsKBey.js +0 -1
- package/dist/assets/Index-DPhCvY6Q.js +0 -1
- package/dist/assets/Index-DUR-RnA2.js +0 -1
- package/dist/assets/Index-DZVTbDSQ.js +0 -1
- package/dist/assets/Index-DcAVsgz9.js +0 -1
- package/dist/assets/Index-Di9hbLdf.js +0 -1
- package/dist/assets/Index-IByo75xV.js +0 -1
- package/dist/assets/Index-Usv3XwZq.js +0 -1
- package/dist/assets/Index-WI6f1axv.js +0 -4
- package/dist/assets/Index-XCNLSkUK.js +0 -1
- package/dist/assets/Index-kyl5nTZY.js +0 -1
- package/dist/assets/Index-qaJbU0TV.js +0 -1
- package/dist/assets/Invitees-BPtPfdut.js +0 -1
- package/dist/assets/List-CC8Z4z5R.js +0 -1
- package/dist/assets/List-DCYHG6Bs.js +0 -1
- package/dist/assets/List-LRyxDpuD.js +0 -1
- package/dist/assets/Main-BXasj2-z.js +0 -1
- package/dist/assets/Navigator-ChBqOOgE.js +0 -1
- package/dist/assets/NoTasks-C1c_E_pm.js +0 -1
- package/dist/assets/OAuthCallback-DoOW4czE.js +0 -1
- package/dist/assets/Status-Bj7S8VFR.js +0 -1
- package/dist/assets/Subscribe-hbnDVlYv.js +0 -1
- package/dist/assets/TransportWebHID-tGhjdJt8.js +0 -1
- package/dist/assets/bignumber-8Qi93LJc.js +0 -1
- package/dist/assets/distribution-PHMiVGOn.js +0 -1
- package/dist/assets/index-BohILe2p.js +0 -1
- package/dist/assets/index-BoskLER6.js +0 -1
- package/dist/assets/index-CPXKDHlp.js +0 -3
- package/dist/assets/index-DdsA_zOr.js +0 -3
- package/dist/assets/index.es-CS-OHrjD.js +0 -1
- package/dist/assets/order-BxvNPyOX.js +0 -1
- package/dist/assets/price-DRZuZOgJ.js +0 -1
- package/dist/assets/solana-wallets-Cstdq8pH.js +0 -2
- package/dist/assets/solanaEmbed.esm-BhORHQgM.js +0 -10
- package/dist/assets/string_decoder-TDqYXdue.js +0 -1
- package/dist/assets/vendor-web3-UIIclDfr.js +0 -4912
- package/dist/assets/web-BMZ6uYLn.js +0 -1
- package/dist/assets/web-BR46pVjm.js +0 -1
- /package/dist/assets/{vendor-web3-CY2j0e5U.css → styles-CY2j0e5U.css} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{C as I}from"./CopyToClipboard-COWZc6L9.js";import{aA as E,bi as T,bj as F,bk as N,_ as P}from"./index-59WF-aDo.js";import{d as B,a as $,s as O}from"./distribution-PHMiVGOn.js";import{g as q}from"./price-DRZuZOgJ.js";import{F as M}from"./index.es-CS-OHrjD.js";import{L as R,y as z,z as A,q as U,x as V,p as G,m as H,A as Q,B as j,X as J}from"./vendor-element-plus-ZfFlETcH.js";import{d as K,J as r,K as o,T as i,ai as l,G as e,R as s,C as p,Q as _,O as k,D as n}from"./vendor-vue-BhXato7y.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const W=K({name:"ConsoleDistributionList",components:{CopyToClipboard:I,FontAwesomeIcon:M,QrCode:E,ElProgress:J,ElRow:j,ElCol:Q,ElButton:H,ElDivider:G,ElCard:V,ElTooltip:U,ElTable:A,ElTableColumn:z,ElSkeleton:R},data(){return{invitees:[],inviteesCount:void 0,distributionLevels:[],distributionLink:void 0,distributionStatus:void 0,loading:!1}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||"1")},qrColor(){const t=document.documentElement.classList.contains("dark");return{dark:t?"#ffffff":"#000000",light:t?"#1e1e1e":"#ffffff"}},distributionLevelMap(){let t={};return this.distributionLevels.forEach(a=>{t[a.level]=a}),t}},watch:{page:{handler(){this.onFetchData()}}},async mounted(){this.onFetchData(),this.onGenerateDistributionLink()},methods:{getPriceString:q,goHistory(){this.$router.push({name:N})},goInvitees(){this.$router.push({name:F})},onPageChange(t){this.$router.push({name:this.$route.name?.toString(),query:{page:t}})},getPercentageForNextLevel(){const t=this.distributionLevelMap[this.distributionStatus?.level?.level]?.threshold,a=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor((this.distributionStatus?.price-t)/(a-t)*100)},getDeltaForNextLevel(){const t=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor(t-this.distributionStatus?.price)},async onFetchData(){this.loading=!0,await $.initialize(),Promise.all([this.onFetchDistributionStatus(),this.onFetchDistributionLevels(),this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onGenerateDistributionLink(){const a=`${window.location.origin}?inviter_id=${this.$store.getters.user.id}`;try{const v=(await O.create(a))?.data?.data?.url;this.distributionLink=(v||a).replace("surl.id","share.acedata.cloud")}catch{this.distributionLink=a}},async onFetchDistributionStatus(){const{data:t}=await $.getAll({user_id:this.$store.getters.user.id});t.items&&t.items.length>0&&(this.distributionStatus=t.items[0])},async onFetchDistributionLevels(){const{data:t}=await B.getAll({limit:20,user_id:this.$store.getters.user.id});this.distributionLevels=t.items},async onFetchInvitees(){const{data:t}=await T.getInvitees({});this.invitees=t.items,this.inviteesCount=t.count}}}),X={class:"title"},Y={key:1},Z={class:"icon-wrapper"},x={class:"text-left"},tt={class:"description"},et={class:"value"},it={key:1},st={class:"icon-wrapper"},ot={class:"text-left"},nt={class:"description"},lt={class:"value"},at={key:1},rt={class:"icon-wrapper"},dt={class:"text-left"},ct={class:"description"},ut={class:"value"},pt={key:1},ht={class:"icon-wrapper"},_t={class:"text-left"},mt={class:"description"},bt={class:"value"},vt={key:1},ft={class:"title"},gt={class:"clear-both overflow-hidden"},kt={class:"float-left description"},yt={class:"float-right description"},Lt={class:"description"},$t={class:"level"},wt={class:"level"},St={class:"level"},Ct={key:1},Dt={class:"title"},It={class:"link-wrapper text-center"},Et=["href"],Tt={class:"qr-wrapper ml-auto mr-auto"},Ft={class:"mt-0"},Nt={class:"description"},Pt={class:"more"};function Bt(t,a,v,Ot,qt,Mt){const d=l("el-col"),m=l("el-row"),c=l("el-skeleton"),b=l("font-awesome-icon"),f=l("el-button"),u=l("el-card"),y=l("el-tooltip"),w=l("el-progress"),L=l("el-divider"),g=l("el-table-column"),S=l("el-table"),C=l("copy-to-clipboard"),D=l("qr-code");return n(),r(m,{class:"panel"},{default:o(()=>[i(d,{span:24},{default:o(()=>[i(m,null,{default:o(()=>[i(d,{span:24},{default:o(()=>[e("h2",X,s(t.$t("common.title.distribution")),1)]),_:1})]),_:1}),i(m,{gutter:15},{default:o(()=>[i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",Y,[e("div",Z,[i(b,{icon:"fa-solid fa-wallet",class:"icon"})]),e("div",x,[e("p",tt,s(t.$t("distribution.title.price")),1),e("p",et,s(t.getPriceString({value:t.distributionStatus?.price})),1)]),i(f,{type:"primary",round:"",size:"small",class:"btn",onClick:t.goHistory},{default:o(()=>[_(s(t.$t("distribution.button.detail")),1)]),_:1},8,["onClick"])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",it,[e("div",st,[i(b,{icon:"fa-solid fa-coins",class:"icon"})]),e("div",ot,[e("p",nt,s(t.$t("distribution.title.reward")),1),e("p",lt,s(t.getPriceString({value:t.distributionStatus?.reward})),1)]),i(y,{effect:"dark",content:t.$t("distribution.message.developingWithDrawal"),placement:"top"},{default:o(()=>[i(f,{type:"primary",round:"",size:"small",class:"btn"},{default:o(()=>[_(s(t.$t("distribution.button.withdrawal")),1)]),_:1})]),_:1},8,["content"])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",at,[e("div",rt,[i(b,{icon:"fa-solid fa-percent",class:"icon"})]),e("div",dt,[e("p",ct,s(t.$t("distribution.title.percentage")),1),e("p",ut,s(t.distributionStatus?.level?.percentage)+"%",1)])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",pt,[e("div",ht,[i(b,{icon:"fa-regular fa-user",class:"icon"})]),e("div",_t,[e("p",mt,s(t.$t("distribution.title.inviteesCount")),1),e("p",bt,s(t.inviteesCount),1)]),i(f,{type:"primary",round:"",size:"small",class:"btn",onClick:t.goInvitees},{default:o(()=>[_(s(t.$t("distribution.button.detail")),1)]),_:1},8,["onClick"])]))]),_:1})]),_:1})]),_:1}),i(m,{gutter:15},{default:o(()=>[i(d,{md:12,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"level-info mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",vt,[e("h4",ft,s(t.$t("distribution.title.levelInfo")),1),e("div",gt,[e("div",kt,[e("p",null,s(t.$t("distribution.title.currentLevel"))+": L"+s(t.distributionStatus?.level?.level),1),e("p",null,s(t.$t("distribution.title.currentPercentage"))+": "+s(t.distributionLevelMap[t.distributionStatus?.level?.level]?.percentage)+"% ",1)]),e("div",yt,[e("p",null,s(t.$t("distribution.title.nextLevel"))+": L"+s(t.distributionStatus?.level?.level+1),1),e("p",null,s(t.$t("distribution.title.nextPercentage"))+": "+s(t.distributionLevelMap[t.distributionStatus?.level?.level+1]?.percentage)+"% ",1)])]),i(w,{"text-inside":!0,"stroke-width":20,percentage:t.getPercentageForNextLevel(),class:"mb-2"},null,8,["percentage"]),e("p",Lt,s(t.$t("distribution.message.deltaPriceForNextLevel"))+": $"+s(t.getDeltaForNextLevel()),1),i(L),t.distributionLevels?(n(),r(S,{key:0,data:t.distributionLevels,stripe:""},{default:o(()=>[i(g,{label:t.$t("distribution.field.level")},{default:o(h=>[e("span",$t,"L"+s(h.row?.level),1)]),_:1},8,["label"]),i(g,{label:t.$t("distribution.field.threshold")},{default:o(h=>[e("span",wt,"$"+s(h.row?.threshold),1)]),_:1},8,["label"]),i(g,{label:t.$t("distribution.field.percentage")},{default:o(h=>[e("span",St,s(h.row?.percentage)+"%",1)]),_:1},8,["label"])]),_:1},8,["data"])):k("",!0)]))]),_:1})]),_:1}),i(d,{md:12,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"distribution-info mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",Ct,[e("h4",Dt,s(t.$t("distribution.title.distributionLink")),1),i(L),e("div",It,[k("",!0),e("a",{href:t.distributionLink,class:"link"},s(t.distributionLink),9,Et),i(C,{content:t.distributionLink},null,8,["content"])]),e("div",Tt,[t.distributionLink?(n(),r(D,{key:0,value:t.distributionLink,size:180,margin:2,class:"block mb-2 ml-auto mr-auto",type:"image/png",color:t.qrColor},null,8,["value","color"])):k("",!0),e("p",Ft,s(t.$t("distribution.message.distributionQrDescription")),1)]),e("p",Nt,[_(s(t.$t("distribution.message.distributionLinkDescription"))+" ",1),e("span",Pt,[i(y,{effect:"dark",content:t.$t("distribution.message.distributionLinkDescription2"),placement:"top"},{default:o(()=>[_(s(t.$t("distribution.message.technicalDetail")),1)]),_:1},8,["content"])])])]))]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Wt=P(W,[["render",Bt],["__scopeId","data-v-1ca0740d"]]);export{Wt as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as G}from"./index.es-CS-OHrjD.js";import{m as R,W,t as H,u as x,w as A,O as N,P as B,q as Z,H as J,j as K}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as l,G as c,T as o,E as C,K as $,ai as n,D as a,R as s,Q as f,S as I,ag as T,J as E,O as v,M as q,X as Q}from"./vendor-vue-BhXato7y.js";import{_ as y,au as X,cx as Y,cy as ee,cz as te,cA as oe,cB as se,cC as U,cD as M,cE as O,cF as z,aN as ae,aJ as j}from"./index-59WF-aDo.js";import{I as P,S as ne}from"./ScrollList-_cUBLaZZ.js";import{I as F}from"./ImagePreview-COK_lQAf.js";import{C as le}from"./Consumption-DTFyP44R.js";import{a as ie}from"./price-DRZuZOgJ.js";import{C as re}from"./CopyToClipboard-COWZc6L9.js";import{I as ce}from"./ImageWrapper-tWRqlRkx.js";import{B as me}from"./BotPlaceholder-DEITkzHi.js";import{N as pe}from"./NoTasks-C1c_E_pm.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const ue=w({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:R,FontAwesomeIcon:G},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},ge={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 he(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-drawer");return a(),l("div",de,[c("div",ge,[C(e.$slots,"config",{},void 0,!0)]),c("div",fe,[C(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:$(()=>[o(u,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=y(ue,[["render",he],["__scopeId","data-v-bfe5cd4b"]]),$e="",ve=w({name:"PromptInput",components:{ElInput:H,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),be={class:"field"},ke={class:"box"},we={class:"title font-bold"};function ye(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-input");return a(),l("div",be,[c("div",ke,[c("h2",we,s(e.$t("openaiimage.name.prompt")),1),o(u,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ie=y(ve,[["render",ye],["__scopeId","data-v-92f61e4a"]]),Ee=w({name:"ImageUrlsInput",components:{ElUpload:x,ElButton:R,InfoIcon:P,ImagePreview:F,FontAwesomeIcon:G},data(){return{fileList:[],uploadUrl:X()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(p=>!p?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const p=this.fileList.find(h=>h?.response?.file_url===i||h?.url===i);p?t.push(p):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(h=>h===i||h?.url===i?.url||h?.response?.file_url===i?.response?.file_url)||t.push(i)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){A.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){A.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Ve={class:"field flex items-center justify-between"},Ae={class:"title font-bold text-[14px] mb-[10px]"},Te={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Le={class:"controls flex items-center"},Se={class:"file-list flex flex-wrap gap-[10px]"};function Ge(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-upload"),g=n("info-icon"),k=n("image-preview");return a(),l(I,null,[c("div",Ve,[c("h2",Ae,s(e.$t("openaiimage.name.imageUrls")),1),c("div",Te,[c("div",Le,[o(_,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[o(d,{size:"small",type:"primary",round:""},{default:$(()=>[o(u,{icon:"fa-solid fa-upload",class:"mr-1"}),f(" "+s(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(g,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Se,[(a(!0),l(I,null,T(e.fileList,(r,b)=>(a(),E(k,{key:r.uid||r?.response?.file_url||r.url||b,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:L=>e.onRemovePreview(b,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Re=y(Ee,[["render",Ge]]),qe=w({name:"OpenAIImageModelSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:ee,label:this.$t("openaiimage.model.gptImage1")},{value:te,label:this.$t("openaiimage.model.gptImage15")},{value:oe,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=Y)}}),Pe={class:"field"},Ce={class:"label"},Ue={class:"box"},Me={class:"title font-bold"};function Oe(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",Pe,[c("div",Ce,[c("div",Ue,[c("h2",Me,s(e.$t("openaiimage.name.model")),1),o(u,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=y(qe,[["render",Oe],["__scopeId","data-v-cec771bd"]]),je=w({name:"OpenAIImageSizeSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:U,label:U},{value:M,label:M},{value:O,label:O}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.size},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})}}},mounted(){this.value||(this.value=se)}}),De={class:"field"},Ne={class:"label"},Be={class:"box"},Fe={class:"title font-bold"};function We(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",De,[c("div",Ne,[c("div",Be,[c("h2",Fe,s(e.$t("openaiimage.name.size")),1),o(u,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=y(je,[["render",We],["__scopeId","data-v-11116785"]]),xe=w({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:G,PromptInput:Ie,Consumption:le,ImageUrlsInput:Re,ModelSelector:ze,ResolutionSelector:He},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return ie({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,t,m,i,p,h){const u=n("model-selector"),d=n("resolution-selector"),_=n("prompt-input"),g=n("image-urls-input"),k=n("consumption"),r=n("font-awesome-icon"),b=n("el-button");return a(),l("div",Ze,[c("div",Je,[o(u,{class:"mb-4"}),o(d,{class:"mb-4"}),o(_,{class:"mb-4"}),o(g,{class:"mb-4"})]),c("div",Ke,[o(k,{value:e.consumption,service:e.service},null,8,["value","service"]),o(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[o(r,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+s(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=y(xe,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:K,CopyToClipboard:re,FontAwesomeIcon:G,ElAlert:J,ImageWrapper:ce,ElButton:R,ElTooltip:Z,ImagePreview:F},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const m=t;if(m?.image_url||m?.url){e.push(m);return}m?.b64_json&&e.push({...m,url:`data:image/png;base64,${m.b64_json}`})}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},at={class:"datetime"},nt={class:"info"},lt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},it={key:1,class:"prompt mt-2"},rt={key:0},ct={key:0,class:q({content:!0,failed:!0})},mt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},pt={class:q({operations:!0,"mt-2":!0,"mb-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:q({content:!0})},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},It={key:2,class:q({content:!0})},Et={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Lt(e,t,m,i,p,h){const u=n("el-image"),d=n("image-preview"),_=n("image-wrapper"),g=n("el-button"),k=n("el-tooltip"),r=n("font-awesome-icon"),b=n("copy-to-clipboard"),L=n("el-alert");return a(),l("div",et,[c("div",tt,[o(u,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",ot,[c("div",st,[f(s(e.$t("openaiimage.name.openaiimageBot"))+" ",1),c("span",at,s(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(a(),l("div",lt,[(a(!0),l(I,null,T(e.modelValue?.request?.image_urls,(V,S)=>(a(),E(d,{key:S,url:V,name:`image-${S+1}`,closable:!1},null,8,["url","name"]))),128))])):v("",!0),e.modelValue?.request?.prompt?(a(),l("p",it,[f(s(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(a(),l("span",rt," - ("+s(e.$t("openaiimage.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",ct,[c("div",mt,[(a(!0),l(I,null,T(e.images,(V,S)=>(a(),E(_,{key:S,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),c("div",pt,[o(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[o(g,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Q(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[f(s(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(L,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),l("p",ut,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",dt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",gt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",ft,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",ht,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),l("div",_t,[o(L,{closable:!1,class:"failure"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",$t,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",bt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",kt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",wt,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failureReason"))+": "+s(e.modelValue?.response?.error?.message)+" ",1),o(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",yt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(a(),l("div",It,[o(L,{closable:!1,class:"info"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",Et,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",Vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",At,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",Tt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const St=y(Ye,[["render",Lt],["__scopeId","data-v-e650f85d"]]),Gt=w({name:"RecentPanel",components:{TaskPreview:St,BotPlaceholder:me,NoTasks:pe,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Rt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Pt(e,t,m,i,p,h){const u=n("bot-placeholder"),d=n("task-preview"),_=n("scroll-list"),g=n("no-tasks");return a(),l(I,null,[e.tasks?.items===void 0?(a(),l("div",Rt,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E(_,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),l(I,null,T(e.tasks?.items,k=>(a(),E(d,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(a(),l("div",qt,[o(g)])):v("",!0)],64)}const Ct=y(Gt,[["render",Pt]]),D="https://webhook.acedata.cloud/openaiimage",Ut=w({name:"OpenAIImageIndex",components:{ConfigPanel:Xe,Layout:_e,RecentPanel:Ct},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const m=this.tasks?.items?.[0];if(!m?.created_at)return;const p=this.$refs.recentPanel?.getScrollElement?.(),h=p?.scrollHeight||0,u=p?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:m.created_at}),await this.$nextTick(),p){const d=p.scrollHeight;p.scrollTop=d-h+u}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:m,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",i),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:m,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const m={...e,action:"generate",callback_url:D},i={action:"edit",model:e?.model,prompt:e?.prompt,image_urls:e?.image_urls||[],callback_url:D},p=this.credential?.token;if(!p){console.error("no token specified");return}A.info(this.$t("openaiimage.message.startingTask")),(t?z.edit(i,{token:p}):z.generate(m,{token:p})).then(u=>{console.debug("task accepted",u.data?.task_id),A.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(u=>{const d=u?.response?.data;d?.error?.code===ae?A.error(this.$t("openaiimage.message.usedUp")):A.error(this.$t("openaiimage.message.startTaskFailed")+(d?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Mt(e,t,m,i,p,h){const u=n("config-panel"),d=n("recent-panel"),_=n("layout");return a(),E(_,null,{config:$(()=>[o(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[o(d,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const eo=y(Ut,[["render",Mt]]);export{eo as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{E as T,a as D,b as E}from"./EditArray-UipmkzQk.js";import{h as U,_ as V}from"./index-59WF-aDo.js";import{M as F,k as A,N as _,x as q,A as B,j as L,B as N,p as j}from"./vendor-element-plus-ZfFlETcH.js";import{d as R,J as O,K as s,T as t,ai as n,G as l,R as o,Q as m,C as y,ag as Q,S as K,D as w,L as k,O as G,U as C}from"./vendor-vue-BhXato7y.js";import"./index.es-CS-OHrjD.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const J=R({name:"SiteIndex",components:{EditText:E,EditImage:D,EditArray:T,ElDivider:j,ElRow:N,ElImage:L,ElCol:B,ElCard:q,ElForm:_,ElSwitch:A,ElFormItem:F},data(){return{editing:{title:!1}}},computed:{site(){return this.$store.getters.site}},methods:{onSave(e){const a={...this.site,...e};U.update(this.site?.id,a).then(()=>{console.debug("getSite for id",this.site?.id),this.$store.dispatch("getSite")})}}}),M={class:"title"},W={class:"title"},z={class:"block w-full"},H={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},Y={class:"block w-full"},Z={class:"block tip"},x={class:"block w-full"},ee={class:"block tip"},te={class:"block w-full"},ie={class:"block tip"},se={class:"title"},le={class:"block w-full"},oe={class:"block tip"},ae={class:"block w-full"},de={class:"block tip"},ne={class:"title"},re={class:"block tip"},me={class:"block tip"},ue={class:"title"},pe={class:"w-full"},fe={class:"block tip w-full"},be={key:0},ve={class:"block w-full"},he={class:"block w-full"};function ce(e,a,$e,ge,we,ke){const f=n("el-col"),h=n("el-row"),u=n("el-divider"),d=n("el-form-item"),p=n("edit-text"),c=n("el-image"),$=n("edit-image"),I=n("edit-array"),b=n("el-form"),v=n("el-card"),g=n("el-switch");return w(),O(h,{class:"panel"},{default:s(()=>[t(f,{span:24},{default:s(()=>[t(h,null,{default:s(()=>[t(f,{span:24},{default:s(()=>[l("h2",M,o(e.$t("common.title.site")),1)]),_:1})]),_:1}),t(h,{gutter:15},{default:s(()=>[t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",W,o(e.$t("site.title.basicConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.origin")},{default:s(()=>[l("span",z,o(e.site.origin),1),l("span",H,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",P,[m(o(e.site.title)+" ",1),t(p,{"model-value":e.site.title,title:e.$t("site.title.editTitle"),placeholder:e.$t("site.placeholder.title"),onConfirm:a[0]||(a[0]=i=>e.onSave({title:i}))},null,8,["model-value","title","placeholder"])]),l("span",X,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",Y,[t(c,{src:e.site.logo,class:"logo"},null,8,["src"]),t($,{"model-value":e.site.logo,title:e.$t("site.title.editLogo"),tip:e.$t("site.message.editLogoTip"),onConfirm:a[1]||(a[1]=i=>e.onSave({logo:i}))},null,8,["model-value","title","tip"])]),l("span",Z,o(e.$t("site.message.logoTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.favicon")},{default:s(()=>[l("span",x,[t(c,{src:e.site.favicon,class:"favicon"},null,8,["src"]),t($,{"model-value":e.site.favicon,title:e.$t("site.title.editFavicon"),tip:e.$t("site.message.editFaviconTip"),onConfirm:a[2]||(a[2]=i=>e.onSave({favicon:i}))},null,8,["model-value","title","tip"])]),l("span",ee,o(e.$t("site.message.faviconTip")),1)]),_:1},8,["label"]),t(u,{"border-style":"dashed"}),t(d,{label:e.$t("site.field.admins")},{default:s(()=>[l("span",te,[m(o(e.site.admins?.join(", "))+" ",1),t(I,{"model-value":e.site?.admins||[],title:e.$t("site.title.editAdmins"),placeholder:e.$t("site.placeholder.admins"),tip:e.$t("site.message.adminsTip2"),min:1,"min-error-message":e.$t("site.message.atLeastOneAdmin"),onConfirm:a[3]||(a[3]=i=>e.onSave({admins:i}))},null,8,["model-value","title","placeholder","tip","min-error-message"])]),l("span",ie,o(e.$t("site.message.adminsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",se,o(e.$t("site.title.seoConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.description")},{default:s(()=>[l("span",le,[m(o(e.site.description)+" ",1),t(p,{"model-value":e.site.description,title:e.$t("site.title.editDescription"),placeholder:e.$t("site.placeholder.description"),onConfirm:a[4]||(a[4]=i=>e.onSave({description:i}))},null,8,["model-value","title","placeholder"])]),l("span",oe,o(e.$t("site.message.descriptionTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.keywords")},{default:s(()=>[l("span",ae,[m(o(e.site.keywords?.join(", "))+" ",1),t(I,{"model-value":e.site?.keywords||[],title:e.$t("site.title.editKeywords"),placeholder:e.$t("site.placeholder.keywords"),tip:e.$t("site.message.keywordsTip2"),onConfirm:a[5]||(a[5]=i=>e.onSave({keywords:i}))},null,8,["model-value","title","placeholder","tip"])]),l("span",de,o(e.$t("site.message.keywordsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1})]),_:1}),t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",ne,o(e.$t("site.title.distributionConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.distributionDefaultInviterId")},{default:s(()=>[m(o(e.site.distribution?.default_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.default_inviter_id,title:e.$t("site.title.editDistributionDefaultInviterId"),placeholder:e.$t("site.placeholder.editDistributionDefaultInviterId"),onConfirm:a[6]||(a[6]=i=>e.onSave({distribution:{...e.site.distribution,default_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",re,o(e.$t("site.message.distributionDefaultInviterIdTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.distributionForceInviterId")},{default:s(()=>[m(o(e.site.distribution?.force_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.force_inviter_id,title:e.$t("site.title.editDistributionForceInviterId"),placeholder:e.$t("site.placeholder.editDistributionForceInviterId"),onConfirm:a[7]||(a[7]=i=>e.onSave({distribution:{...e.site.distribution,force_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",me,o(e.$t("site.message.distributionForceInviterIdTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",ue,o(e.$t("site.title.featuresConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[(w(),y(K,null,Q(["chat","midjourney","qrart","nanobanana","openaiimage","seedream","seedance","suno","luma","pika","kling","flux","hailuo","headshots","wan","producer","serp","support"],(i,S)=>t(d,{key:S,label:e.$t("site.field.features"+i.charAt(0).toUpperCase()+i.slice(1))},{default:s(()=>[l("div",pe,[t(g,{"model-value":e.site.features[i]?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],enabled:r}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),l("span",fe,o(e.$t("site.message.features"+i.charAt(0).toUpperCase()+i.slice(1))),1),i==="support"?k((w(),y("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.wechat?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.qr")},{default:s(()=>[l("span",ve,[t(c,{src:e.site.features[i]?.wechat?.qr},null,8,["src"]),t($,{"model-value":e.site.features[i]?.wechat?.qr,title:e.$t("site.title.editQR"),tip:e.$t("site.message.editQRTip"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,qr:r}}}})},null,8,["model-value","title","tip","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.wechat?.enabled]]),t(d,{label:"Discord"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.discord?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.url")},{default:s(()=>[l("span",he,[m(o(e.site.features[i]?.discord?.url)+" ",1),t(p,{"model-value":e.site.features[i]?.discord?.url,title:e.$t("site.title.editUrl"),placeholder:e.$t("site.placeholder.editUrl"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,url:r}}}})},null,8,["model-value","title","placeholder","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.discord?.enabled]])],512)),[[C,e.site.features[i]?.enabled]]):G("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Fe=V(J,[["render",ce],["__scopeId","data-v-38430f7a"]]);export{Fe as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as L}from"./index.es-CS-OHrjD.js";import{m as I,W as X,t as H,O as R,P as U,k as P,u as M,w,q as J,H as K,j as Q}from"./vendor-element-plus-ZfFlETcH.js";import{d as b,C as i,G as r,T as s,E as D,K as p,ai as t,D as n,R as o,S as T,ag as A,J as y,O as v,Q as h,M as C,X as Y}from"./vendor-vue-BhXato7y.js";import{_ as E,cR as Z,cS as x,cT as ee,cU as G,cV as se,cW as te,cX as oe,cY as ne,au as j,cZ as ae,c_ as le,c$ as ie,d0 as re,a4 as ce,d1 as de,aN as me,aJ as O}from"./index-59WF-aDo.js";import{I as S,S as ue}from"./ScrollList-_cUBLaZZ.js";import{p as B}from"./pasteUploadMixin-BurWbGNQ.js";import{I as q}from"./ImagePreview-COK_lQAf.js";import{C as pe}from"./Consumption-DTFyP44R.js";import{a as fe}from"./price-DRZuZOgJ.js";import{C as _e}from"./CopyToClipboard-COWZc6L9.js";import{V as he}from"./VideoPlayer-CF6zk-Kd.js";import{I as ve}from"./ImageWrapper-tWRqlRkx.js";import{B as $e}from"./BotPlaceholder-DEITkzHi.js";import{N as ge}from"./NoTasks-C1c_E_pm.js";import{l as be}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const Ee=b({name:"LayoutSeedance",components:{ElDrawer:X,ElButton:I,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ye={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Se(e,a,u,f,g,$){const c=t("font-awesome-icon"),l=t("el-button"),m=t("el-drawer");return n(),i("div",ke,[r("div",we,[D(e.$slots,"config",{},void 0,!0)]),r("div",ye,[D(e.$slots,"result",{},void 0,!0)]),s(l,{circle:"",class:"menu",onClick:a[0]||(a[0]=d=>e.drawer=!0)},{default:p(()=>[s(c,{icon:"fa-solid fa-magic"})]),_:1}),s(m,{modelValue:e.drawer,"onUpdate:modelValue":a[1]||(a[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[D(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ve=E(Ee,[["render",Se],["__scopeId","data-v-02e4e4b3"]]),Te="",Le=b({name:"SeedancePromptInput",components:{ElInput:H,InfoIcon:S},computed:{prompt:{get(){return this.$store.state.seedance?.config?.prompt},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Te)}}),Ie={class:"field"},Ce={class:"box"},Ae={class:"title font-bold"};function Fe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-input");return n(),i("div",Ie,[r("div",Ce,[r("h2",Ae,o(e.$t("seedance.name.prompt")),1),s(c,{content:e.$t("seedance.description.prompt"),class:"info"},null,8,["content"])]),s(l,{modelValue:e.prompt,"onUpdate:modelValue":a[0]||(a[0]=m=>e.prompt=m),rows:4,type:"textarea",class:"prompt",placeholder:e.$t("seedance.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const De=E(Le,[["render",Fe],["__scopeId","data-v-865909f4"]]),Re=b({name:"SeedanceModelSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:x,label:this.$t("seedance.model.seedance10pro")},{value:ee,label:this.$t("seedance.model.seedance10proFast")},{value:G,label:this.$t("seedance.model.seedance15pro")},{value:se,label:this.$t("seedance.model.seedance10liteT2v")},{value:te,label:this.$t("seedance.model.seedance10liteI2v")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.model},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,model:e})}}},mounted(){this.value||(this.value=Z)}}),Ue={class:"field"},Ne={class:"label"},Oe={class:"box"},Pe={class:"title font-bold"};function Me(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Ue,[r("div",Ne,[r("div",Oe,[r("h2",Pe,o(e.$t("seedance.name.model")),1),s(c,{content:e.$t("seedance.description.model"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=E(Re,[["render",Me],["__scopeId","data-v-eaa1425a"]]),je=b({name:"SeedanceDurationSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:2,label:"2s"},{value:3,label:"3s"},{value:4,label:"4s"},{value:5,label:"5s"},{value:6,label:"6s"},{value:7,label:"7s"},{value:8,label:"8s"},{value:9,label:"9s"},{value:10,label:"10s"},{value:11,label:"11s"},{value:12,label:"12s"}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.duration},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,duration:e})}}},mounted(){this.value||(this.value=oe)}}),Be={class:"field"},qe={class:"label"},ze={class:"box"},We={class:"title font-bold"};function Xe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Be,[r("div",qe,[r("div",ze,[r("h2",We,o(e.$t("seedance.name.duration")),1),s(c,{content:e.$t("seedance.description.duration"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=E(je,[["render",Xe],["__scopeId","data-v-5c809a72"]]),Je=b({name:"SeedanceGenerateAudioSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{isSupported(){return this.$store.state.seedance?.config?.model===G},value:{get(){return this.$store.state.seedance?.config?.generate_audio??!1},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,generate_audio:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=ne)}}),Ke={key:0,class:"field"},Qe={class:"label"},Ye={class:"box"},Ze={class:"title font-bold"},xe={class:"value"};function es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return e.isSupported?(n(),i("div",Ke,[r("div",Qe,[r("div",Ye,[r("h2",Ze,o(e.$t("seedance.name.generateAudio")),1),s(c,{content:e.$t("seedance.description.generateAudio"),class:"info"},null,8,["content"])])]),r("div",xe,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])):v("",!0)}const ss=E(Je,[["render",es],["__scopeId","data-v-8d716dcc"]]),ts=b({name:"SeedanceFirstFrameImage",components:{ElUpload:M,ElButton:I,InfoIcon:S,FontAwesomeIcon:L,ImagePreview:q},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetFirstFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="first_frame");e&&u.push({url:e,role:"first_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetFirstFrameUrl()},async onRemove(){this.onSetFirstFrameUrl()}}}),os={class:"relative"},ns={class:"flex justify-between"},as={class:"flex justify-start items-center"},ls={class:"text-sm font-bold"};function is(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",os,[r("div",ns,[r("div",as,[r("span",ls,o(e.$t("seedance.name.firstFrame")),1),s(c,{content:e.$t("seedance.description.firstFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const rs=E(ts,[["render",is],["__scopeId","data-v-5294baf8"]]),cs=b({name:"SeedanceLastFrameImage",components:{ElUpload:M,ElButton:I,ImagePreview:q,InfoIcon:S,FontAwesomeIcon:L},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetLastFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="last_frame");e&&u.push({url:e,role:"last_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetLastFrameUrl()},async onRemove(){this.onSetLastFrameUrl()}}}),ds={class:"relative"},ms={class:"flex justify-between"},us={class:"flex justify-start items-center"},ps={class:"text-sm font-bold"};function fs(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",ds,[r("div",ms,[r("div",us,[r("span",ps,o(e.$t("seedance.name.lastFrame")),1),s(c,{content:e.$t("seedance.description.lastFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const _s=E(cs,[["render",fs],["__scopeId","data-v-f423739f"]]),hs=b({name:"SeedanceServiceTierSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:le,label:this.$t("seedance.serviceTier.default")},{value:ie,label:this.$t("seedance.serviceTier.flex")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.service_tier},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,service_tier:e})}}},mounted(){this.value||(this.value=ae)}}),vs={class:"field"},$s={class:"label"},gs={class:"box"},bs={class:"title font-bold"};function Es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",vs,[r("div",$s,[r("div",gs,[r("h2",bs,o(e.$t("seedance.name.serviceTier")),1),s(c,{content:e.$t("seedance.description.serviceTier"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ks=E(hs,[["render",Es],["__scopeId","data-v-a62125ec"]]),ws=b({name:"SeedanceReturnLastFrameSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{value:{get(){return this.$store.state.seedance?.config?.return_last_frame},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,return_last_frame:e})}}},mounted(){this.value===void 0&&(this.value=re)}}),ys={class:"field"},Ss={class:"label"},Vs={class:"box"},Ts={class:"title font-bold"},Ls={class:"value"};function Is(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return n(),i("div",ys,[r("div",Ss,[r("div",Vs,[r("h2",Ts,o(e.$t("seedance.name.returnLastFrame")),1),s(c,{content:e.$t("seedance.description.returnLastFrame"),class:"info"},null,8,["content"])])]),r("div",Ls,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])}const Cs=E(ws,[["render",Is],["__scopeId","data-v-cd179b1c"]]),As=b({name:"SeedanceConfigPanel",components:{ElButton:I,FontAwesomeIcon:L,PromptInput:De,ModelSelector:Ge,DurationSelector:He,GenerateAudioSwitch:ss,ServiceTierSelector:ks,ReturnLastFrameSwitch:Cs,FirstFrameImage:rs,LastFrameImage:_s,Consumption:pe},emits:["generate"],computed:{config(){return this.$store.state.seedance?.config},consumption(){return fe(this.config,this.service?.cost)},service(){return this.$store.state.seedance?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Fs={class:"flex flex-col h-full"},Ds={class:"flex-1 overflow-y-auto p-5"},Rs={class:"flex flex-col items-center justify-center px-5 pb-5"};function Us(e,a,u,f,g,$){const c=t("prompt-input"),l=t("model-selector"),m=t("duration-selector"),d=t("generate-audio-switch"),k=t("service-tier-selector"),_=t("return-last-frame-switch"),V=t("first-frame-image"),F=t("last-frame-image"),N=t("consumption"),z=t("font-awesome-icon"),W=t("el-button");return n(),i("div",Fs,[r("div",Ds,[s(c,{class:"mb-4"}),s(l,{class:"mb-4"}),s(m,{class:"mb-4"}),s(d,{class:"mb-4"}),s(k,{class:"mb-4"}),s(_,{class:"mb-4"}),s(V,{class:"mb-2"}),s(F,{class:"mb-2"})]),r("div",Rs,[s(N,{value:e.consumption,service:e.service},null,8,["value","service"]),s(W,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[s(z,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+o(e.$t("seedance.button.generate")),1)]),_:1},8,["onClick"])])])}const Ns=E(As,[["render",Us]]),Os=b({name:"SeedanceTaskPreview",components:{ElImage:Q,CopyToClipboard:_e,FontAwesomeIcon:L,ElAlert:K,VideoPlayer:he,ElTooltip:J,ElButton:I,ImageWrapper:ve},props:{modelValue:{type:Object,required:!0}},data(){return{seedanceLogo:ce}},computed:{video(){return this.modelValue?.response?.data}},methods:{onDownload(e){window.open(e,"_blank")}}}),Ps={class:"preview"},Ms={class:"left"},Gs={class:"main"},js={class:"bot"},Bs={class:"datetime"},qs={class:"info"},zs={key:0,class:"prompt mt-2"},Ws={key:0},Xs={key:1},Hs={key:0,class:C({content:!0})},Js={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ks={key:1,class:C({content:!0})},Qs={key:0,class:"mb-4"},Ys={key:1,class:"mb-4"},Zs={key:2,class:C({operations:!0,"mt-2":!0,"mb-2":!0})},xs={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},et={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},st={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},tt={key:0},ot={key:1},nt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:2,class:C({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ct={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mt={key:3,class:C({content:!0})},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function ft(e,a,u,f,g,$){const c=t("el-image"),l=t("font-awesome-icon"),m=t("copy-to-clipboard"),d=t("el-alert"),k=t("video-player"),_=t("image-wrapper"),V=t("el-button"),F=t("el-tooltip");return n(),i("div",Ps,[r("div",Ms,[s(c,{src:e.seedanceLogo,class:"avatar"},null,8,["src"])]),r("div",Gs,[r("div",js,[h(o(e.$t("seedance.name.seedanceBot"))+" ",1),r("span",Bs,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",qs,[e.modelValue?.request?.prompt?(n(),i("p",zs,[h(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?e.video?.status==="processing"||e.video?.status==="pending"?(n(),i("span",Xs," - ("+o(e.$t("seedance.status.processing"))+") ",1)):v("",!0):(n(),i("span",Ws," - ("+o(e.$t("seedance.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(n(),i("div",Ks,[e.video?.video_url?(n(),i("div",Qs,[s(k,{src:e.video?.video_url},null,8,["src"])])):v("",!0),e.video?.last_frame_url?(n(),i("div",Ys,[s(_,{src:e.video?.last_frame_url,"raw-src":e.video?.last_frame_url},null,8,["src","raw-src"])])):v("",!0),e.video?.video_url?(n(),i("div",Zs,[s(F,{class:"box-item",effect:"dark",content:e.$t("seedance.message.downloadVideo"),placement:"top-start"},{default:p(()=>[s(V,{type:"info",size:"small",class:"btn-action",onClick:a[0]||(a[0]=Y(N=>e.onDownload(e.video?.video_url),["stop"]))},{default:p(()=>[h(o(e.$t("seedance.button.download")),1)]),_:1})]),_:1},8,["content"])])):v("",!0),s(d,{closable:!1,class:"mt-2 success"},{default:p(()=>[e.modelValue?.request?.model?(n(),i("p",xs,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),h(" "+o(e.$t("seedance.name.model"))+": "+o(e.modelValue?.request?.model),1)])):v("",!0),e.video?.duration?(n(),i("p",et,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.name.duration"))+": "+o(e.video?.duration)+"s ",1)])):v("",!0),e.video?.resolution?(n(),i("p",st,[s(l,{icon:"fa-solid fa-expand",class:"mr-1"}),h(" "+o(e.$t("seedance.name.resolution"))+": "+o(e.video?.resolution)+" ",1),e.video?.ratio?(n(),i("span",tt," · "+o(e.video?.ratio),1)):v("",!0),e.video?.framespersecond?(n(),i("span",ot," · "+o(e.video?.framespersecond)+"fps",1)):v("",!0)])):v("",!0),e.modelValue?.request?.generate_audio?(n(),i("p",nt,[s(l,{icon:"fa-solid fa-volume-up",class:"mr-1"}),h(" "+o(e.$t("seedance.name.generateAudio"))+": "+o(e.$t("seedance.button.on")),1)])):v("",!0),r("p",at,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",lt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),i("div",it,[s(d,{closable:!1,class:"failure"},{template:p(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failure")),1)]),default:p(()=>[r("p",rt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.error?.message?(n(),i("p",ct,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(m,{content:e.modelValue?.response?.error?.message,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0),e.modelValue?.response?.trace_id?(n(),i("p",dt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",mt,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.status")),1)]),default:p(()=>[r("p",ut,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",pt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",Hs,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-regular fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.status.pending")),1)]),default:p(()=>[r("p",Js,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})]))])])}const _t=E(Os,[["render",ft],["__scopeId","data-v-43479338"]]),ht=b({name:"SeedanceRecentPanel",components:{TaskPreview:_t,BotPlaceholder:$e,NoTasks:ge,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],computed:{tasks(){return{...this.$store.state.seedance?.tasks,items:this.$store.state.seedance?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),vt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function gt(e,a,u,f,g,$){const c=t("bot-placeholder"),l=t("task-preview"),m=t("scroll-list"),d=t("no-tasks");return n(),i(T,null,[e.tasks?.items===void 0?(n(),i("div",vt,[s(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(m,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:a[0]||(a[0]=k=>e.$emit("reach-top"))},{default:p(()=>[(n(!0),i(T,null,A(e.tasks?.items,k=>(n(),y(l,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),i("div",$t,[s(d)])):v("",!0)],64)}const bt=E(ht,[["render",gt]]),Et="https://webhook.acedata.cloud/seedance",kt=b({name:"SeedanceIndex",components:{ConfigPanel:Ns,Layout:Ve,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.seedance?.status?.getApplications===O.Request},tasksLoading(){return this.$store.state.seedance?.status?.getTasks===O.Request||this.fetchingTasks},credential(){return this.$store.state.seedance?.credential},config(){return this.$store.state.seedance?.config},tasks(){return this.$store.state.seedance?.tasks}},watch:{initialized:{async handler(e){e&&(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 be({tasks: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(){await this.$store.dispatch("seedance/getService")},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;const{limit:a=5,createdAtMin:u,createdAtMax:f}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch("seedance/getTasks",{limit:a,createdAtMin:u,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config||{}};if(typeof e?.prompt=="string"&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),Array.isArray(e?.images)){e.images=e.images.filter(c=>!!c?.url);const g=e.images.some(c=>c?.role==="first_frame"),$=e.images.some(c=>c?.role==="last_frame");!g&&$&&(e.images=e.images.map(c=>c?.role==="last_frame"?{...c,role:"first_frame"}:c))}!(Array.isArray(e?.images)&&e.images.length>0)&&"images"in e&&delete e.images;const u={...e,callback_url:Et},f=this.credential?.token;if(!f){console.error("no token specified");return}w.info(this.$t("seedance.message.startingTask")),de.generate(u,{token:f}).then(()=>{w.success(this.$t("seedance.message.startTaskSuccess"))}).catch(g=>{const $=g?.response?.data;$?.error?.code===me?w.error(this.$t("seedance.message.usedUp")):w.error(this.$t("seedance.message.startTaskFailed")+($?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,a,u,f,g,$){const c=t("config-panel"),l=t("recent-panel"),m=t("layout");return n(),y(m,null,{config:p(()=>[s(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[s(l,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const zt=E(kt,[["render",wt]]);export{zt as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as R}from"./index.es-CS-OHrjD.js";import{m as S,W as O,O as C,P as G,u as M,w as V,t as j,q as B,H as N,j as F}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as i,G as r,T as t,E as U,K as d,ai as o,D as a,R as l,S as I,ag as E,J as $,Q as _,O as m,M as L,X as q}from"./vendor-vue-BhXato7y.js";import{_ as v,d2 as z,au as W,ao as H,d3 as J,aN as K,aJ as D}from"./index-59WF-aDo.js";import{p as Q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as X}from"./ScrollList-_cUBLaZZ.js";import{I as Y}from"./ImagePreview-COK_lQAf.js";import{C as Z}from"./Consumption-DTFyP44R.js";import{a as x}from"./price-DRZuZOgJ.js";import{C as ee}from"./CopyToClipboard-COWZc6L9.js";import{V as te}from"./VideoPlayer-CF6zk-Kd.js";import{B as oe}from"./BotPlaceholder-DEITkzHi.js";import{N as se}from"./NoTasks-C1c_E_pm.js";import{l as ne}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const ae=w({name:"LayoutWan",components:{ElDrawer:O,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),le={class:"main flex flex-row flex-1"},re={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ie={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ce(e,s,f,h,b,k){const u=o("font-awesome-icon"),p=o("el-button"),n=o("el-drawer");return a(),i("div",le,[r("div",re,[U(e.$slots,"config",{},void 0,!0)]),r("div",ie,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:s[0]||(s[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const de=v(ae,[["render",ce],["__scopeId","data-v-98681d9b"]]),ue=w({name:"ModelSelector",components:{ElSelect:G,ElOption:C},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=z)}}),pe={class:"field"},me={class:"title font-bold"},fe={class:"float-left"};function he(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",pe,[r("h2",me,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",fe,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(ue,[["render",he],["__scopeId","data-v-eb090beb"]]),ge="720p",$e=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ge)}}),we={class:"field"},ve={class:"title font-bold"},be={class:"float-left"};function ke(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",we,[r("h2",ve,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",be,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ye=v($e,[["render",ke],["__scopeId","data-v-3e39f44e"]]),Ve=5,Te=w({name:"DurationSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ve)}}),Ie={class:"field"},Se={class:"title font-bold"},Ee={class:"float-left"};function Le(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",Ie,[r("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",Ee,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=v(Te,[["render",Le],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:M,ElButton:S,InfoIcon:P,ImagePreview:Y},mixins:[Q],data(){return{fileList:[],uploadUrl:W()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ce={class:"relative"},Ge={class:"flex justify-between"},Ae={class:"flex justify-start items-center"},De={class:"text-sm font-bold"};function Pe(e,s,f,h,b,k){const u=o("info-icon"),p=o("image-preview"),n=o("el-button"),g=o("el-upload");return a(),i("div",Ce,[r("div",Ge,[r("div",Ae,[r("span",De,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=c=>e.fileList=c),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"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:d(({file:c})=>[c.url&&c.percentage!==void 0?(a(),$(p,{key:0,url:c.url,name:c.name,percentage:c.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(c),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(n,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[_(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Pe],["__scopeId","data-v-c9ebe1b1"]]),Me="",je=w({name:"PromptInput",components:{ElInput:j,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Me)}}),Be={class:"field"},Ne={class:"box"},Fe={class:"title font-bold"};function qe(e,s,f,h,b,k){const u=o("info-icon"),p=o("el-input");return a(),i("div",Be,[r("div",Ne,[r("h2",Fe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ze=v(je,[["render",qe],["__scopeId","data-v-45557a2d"]]),We=w({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:ze,ImageUrlInput:Oe,ModelSelector:_e,ResolutionSelector:ye,DurationSelector:Ue,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return x(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),He={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,s,f,h,b,k){const u=o("prompt-input"),p=o("model-selector"),n=o("resolution-selector"),g=o("duration-selector"),c=o("image-url-input"),y=o("consumption"),T=o("font-awesome-icon"),A=o("el-button");return a(),i("div",He,[r("div",Je,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(a(),$(n,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(a(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(a(),$(c,{key:2,class:"mb-2"})):m("",!0)]),r("div",Ke,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=v(We,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:F,CopyToClipboard:ee,FontAwesomeIcon:R,ElAlert:N,VideoPlayer:te,ElTooltip:B,ElButton:S},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:H}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),Ze={class:"preview"},xe={class:"left"},et={class:"main"},tt={class:"bot"},ot={class:"datetime"},st={class:"info"},nt={key:0,class:"prompt mt-2"},at={key:0},lt={key:1},rt={key:0,class:L({content:!0,failed:!0})},it={key:0,class:"mb-4"},ct={key:1,class:L({operations:!0,"mt-2":!0})},dt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:1,class:L({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:2,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function $t(e,s,f,h,b,k){const u=o("el-image"),p=o("video-player"),n=o("el-button"),g=o("el-tooltip"),c=o("font-awesome-icon"),y=o("copy-to-clipboard"),T=o("el-alert");return a(),i("div",Ze,[r("div",xe,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),r("div",et,[r("div",tt,[_(l(e.$t("wan.name.wanBot"))+" ",1),r("span",ot,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",st,[e.modelValue?.request?.prompt?(a(),i("p",nt,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(a(),i("span",at," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(a(),i("span",lt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",rt,[e.modelValue?.response?.video_url?(a(),i("div",it,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(a(),i("div",ct,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(n,{type:"info",size:"small",class:"mb-2",onClick:s[0]||(s[0]=q(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[_(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(a(),i("p",dt,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),r("p",ut,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(a(),i("div",pt,[t(T,{closable:!1,class:"failure"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",mt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),r("p",ft,[t(c,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),r("p",ht,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(a(),i("div",_t,[t(T,{closable:!1,class:"info"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",gt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const wt=v(Ye,[["render",$t],["__scopeId","data-v-5cbc37f1"]]),vt=w({name:"RecentPanel",components:{TaskPreview:wt,BotPlaceholder:oe,NoTasks:se,ScrollList:X},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),bt={key:0},kt={key:2,class:"w-full h-full flex items-center justify-center"};function yt(e,s,f,h,b,k){const u=o("bot-placeholder"),p=o("task-preview"),n=o("scroll-list"),g=o("no-tasks");return a(),i(I,null,[e.tasks?.items===void 0?(a(),i("div",bt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(n,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=c=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),i(I,null,E(e.tasks?.items,c=>(a(),$(p,{key:c.id,"model-value":c},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(a(),i("div",kt,[t(g)])):m("",!0)],64)}const Vt=v(vt,[["render",yt]]),Tt="https://webhook.acedata.cloud/wan",It=w({name:"WanIndex",components:{ConfigPanel:Xe,Layout:de,RecentPanel:Vt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.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 ne({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:f,createdAtMax:h}=e||{};console.debug("limit",s,"createdAtMin",f,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:s,createdAtMin:f,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Tt},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),J.generate(e,{token:s}).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===K?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function St(e,s,f,h,b,k){const u=o("config-panel"),p=o("recent-panel"),n=o("layout");return a(),$(n,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Jt=v(It,[["render",St]]);export{Jt as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as x}from"./index.es-CS-OHrjD.js";import{m as A,W as O,t as E,O as N,P,a6 as z,a7 as G,w}from"./vendor-element-plus-ZfFlETcH.js";import{d as h,C as o,G as r,T as d,E as V,K as k,ai as i,D as t,R as a,Q as U,O as c,S as b,ag as y,J as v,aB as L}from"./vendor-vue-BhXato7y.js";import{_,aJ as I,aN as B}from"./index-59WF-aDo.js";import{C as D}from"./Consumption-DTFyP44R.js";import{a as T}from"./price-DRZuZOgJ.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},J={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},M={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function W(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",J,[V(e.$slots,"config",{},void 0,!0)]),r("div",M,[V(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[V(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const H=_(K,[["render",W],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:E},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=_(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,m,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=_(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=_(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),_e={class:"field"},me={class:"title font-bold"};function fe(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",_e,[r("h2",me,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=_(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:D},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return T(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===I.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,m,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),U(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=_($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ce={class:"flex-1 min-w-0"},Ve={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ie={class:"text-xl font-bold mb-1.5"},Ee={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,m,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ce,[e.data.type?(t(),o("div",Ve,a(e.data.type),1)):c("",!0),r("h3",Ie,a(e.data.title),1),e.data.description?(t(),o("p",Ee,[U(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const Ne=_(xe,[["render",Oe]]),Pe=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),ze={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Ge={key:0,class:"flex items-center gap-2 mb-1.5"},Le=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},Je={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Me=["href"];function We(e,n,p,m,f,g){return t(),o("div",ze,[e.displayUrl?(t(),o("div",Ge,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Le),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",Je,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Me))),128))])):c("",!0)])}const He=_(Pe,[["render",We]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,m,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=_(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},_t={class:"flex-1 min-w-0"},mt={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,m,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",_t,[r("div",mt,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=_(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Vt={class:"text-xs text-gray-400 mt-1"},It={key:0},Et={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,m,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Ct,a(s.title),1),r("div",Vt,[s.source?(t(),o("span",It,a(s.source),1)):c("",!0),s.date?(t(),o("span",Et," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=_(wt,[["render",Ft]]),Nt=h({name:"PeopleAlsoAsk",components:{ElCollapse:G,ElCollapseItem:z},props:{data:{type:Array,required:!0}}}),Pt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},zt={class:"text-base font-bold mb-3"},Gt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Lt=["href"];function Bt(e,n,p,m,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Pt,[r("h3",zt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Gt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Lt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=_(Nt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Jt={class:"flex flex-wrap gap-2"},Mt=["onClick"];function Wt(e,n,p,m,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Jt,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),U(" "+a(l.query),1)],8,Mt))),128))])])}const Ht=_(Tt,[["render",Wt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:Ne,OrganicResult:He,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Ht},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===I.Request},noResults(){return this.$store.state.serp?.status?.search===I.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,C=>r("div",{key:C,class:"mb-6 animate-pulse"},n[0]||(n[0]=[L('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)]))),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=_(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:H,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===B?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,m,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const bs=_(is,[["render",cs]]);export{bs as default};
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{F as D}from"./index.es-CS-OHrjD.js";import{m as B,W as ve,a as Ue,k as Pe,O as ae,P as le,F as ie,G as Z,_ as ye,$ as be,E as re,u as Ee,w,t as N,q as de,a4 as ue,a5 as ce,Y as x,e as ee,j as W,Z as pe,a6 as Ie,a7 as Le,a8 as Re,M as Me,N as Fe,l as ke,I as we,R as De,X as ze,f as Ce,g as Ve,h as Se,r as Te,L as Ge,a0 as je,a9 as Be,aa as Oe}from"./vendor-element-plus-ZfFlETcH.js";import{d as T,C as u,G as s,T as o,E as se,K as i,ai as l,D as n,O as c,M as G,R as a,S as M,ag as j,J as k,Q as v,af as ne,L as H,aq as q,X as P,c as O,u as z,w as Ne,U as We}from"./vendor-vue-BhXato7y.js";import{_ as E,cj as He,ck as R,au as qe,aJ as Y,cl as te,aC as Ke,aI as Je}from"./index-59WF-aDo.js";import{I as F,S as Qe}from"./ScrollList-_cUBLaZZ.js";import{u as X,F as Ye,O as Xe,_ as me,P as Ze,a as xe,V as et}from"./IconPark.vue_vue_type_script_setup_true_lang-C7eA9UI3.js";import{C as tt}from"./Consumption-DTFyP44R.js";import{a as ot}from"./price-DRZuZOgJ.js";import{N as st}from"./NoTasks-C1c_E_pm.js";import{l as nt}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const it=T({name:"LayoutSuno",components:{ElDrawer:ve,ElButton:B,FontAwesomeIcon:D},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,[se(e.$slots,"config",{},void 0,!0)]),s("div",rt,[se(e.$slots,"result",{},void 0,!0)]),s("div",dt,[se(e.$slots,"preview",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=b=>e.drawer=!0)},{default:i(()=>[o($,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=b=>e.drawer=b),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:i(()=>[se(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ct=E(it,[["render",ut],["__scopeId","data-v-c6c85757"]]),pt=T({name:"TypeSelector",components:{ElSelect:le,ElOption:ae,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=He)}}),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"),b=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)},a(e.$t("suno.mode.simple")),3),s("button",{class:G(["mode-tab",{active:e.custom}]),onClick:t[1]||(t[1]=g=>e.custom=!0)},a(e.$t("suno.mode.custom")),3)]),s("div",ft,[s("div",ht,[s("span",gt,a(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:i(()=>[(n(!0),u(M,null,j(e.options,g=>(n(),k(p,{key:g.value,label:g.label,value:g.value,class:G({"model-option-divider":g.dividerAfter})},{default:i(()=>[s("div",$t,[s("div",_t,[s("span",vt,a(g.label),1),g.pro?(n(),k($,{key:0,size:"small",type:"warning",effect:"plain",class:"model-option-pro"},{default:i(()=>t[4]||(t[4]=[v("Pro",-1)])),_:1,__:[4]})):c("",!0)]),s("span",yt,a(g.desc),1)])]),_:2},1032,["label","value","class"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),u("div",bt,[s("span",kt,a(e.$t("suno.name.instrumental")),1),o(b,{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=T({name:"UploadAudio",components:{ElUpload:Ee,ElButton:B,ElDialog:re,ElTabs:be,ElTabPane:ye,InfoIcon:F,FontAwesomeIcon:D,ElRadioGroup:Z,ElRadioButton:ie},emits:["change"],data(){return{fileList:[],uploadUrl:qe()+"/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 R.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"},Lt={class:"py-4"},Rt={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"},Gt={key:0,class:"text-red-500 flex items-center justify-center gap-2"},jt={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"},Wt=["src"],Ht={class:"flex justify-center gap-3"};function qt(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),b=l("el-radio-button"),g=l("el-radio-group"),A=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,a(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:i(()=>[o(p,{icon:"fa-solid fa-plus",class:"icon mr-1"}),v(" "+a(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:i(()=>[o(b,{value:"upload_extend"},{default:i(()=>[v(a(e.$t("suno.button.extend")),1)]),_:1}),o(b,{value:"upload_cover"},{default:i(()=>[v(a(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:i(()=>[o(V,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||(t[3]=I=>e.activeTab=I),class:"add-audio-tabs"},{default:i(()=>[o(_,{name:"browse",label:e.$t("suno.tab.browse")},{default:i(()=>[s("div",Lt,[o(A,{"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:i(()=>[s("div",Rt,[o(p,{icon:"fa-solid fa-upload",class:"text-4xl text-gray-400 mb-3"}),s("div",Mt,a(e.$t("suno.description.dropAudioHere")),1),s("div",Ft,a(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:i(()=>[s("div",Dt,[s("div",zt,[e.recording?(n(),u("div",Gt,[t[5]||(t[5]=s("span",{class:"recording-dot"},null,-1)),s("span",jt,a(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,a(e.$t("suno.message.recordingReady"))+" ("+a(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,Wt)])):c("",!0),s("div",Ht,[!e.recording&&!e.recordedBlob?(n(),k(f,{key:0,type:"primary",round:"",onClick:e.startRecording},{default:i(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+a(e.$t("suno.button.startRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recording?(n(),k(f,{key:1,type:"danger",round:"",onClick:e.stopRecording},{default:i(()=>[o(p,{icon:"fa-solid fa-stop",class:"mr-1"}),v(" "+a(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:i(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+a(e.$t("suno.button.reRecord")),1)]),_:1},8,["onClick"]),o(f,{type:"primary",round:"",loading:e.uploadingRecord,onClick:e.uploadRecording},{default:i(()=>[o(p,{icon:"fa-solid fa-upload",class:"mr-1"}),v(" "+a(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",qt],["__scopeId","data-v-bfb6b53d"]]),Jt="",fe=[{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 he(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=T({name:"PromptInput",components:{ElInput:N,FontAwesomeIcon:D,InfoIcon:F},data(){return{shuffledTags:he(fe)}},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=he(fe)}}}),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,a(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]=b=>e.prompt=b),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"]),s("div",eo,[(n(!0),u(M,null,j(e.visibleTags,b=>(n(),u("button",{key:b.key,class:"inspo-tag",onClick:g=>e.onTagClick(b)},a(b.label),9,to))),128)),s("button",{class:"inspo-tag inspo-tag-refresh",onClick:t[1]||(t[1]=(...b)=>e.onRefreshTags&&e.onRefreshTags(...b))},[o(f,{icon:"fa-solid fa-arrows-rotate"})])])])}const so=E(Yt,[["render",oo],["__scopeId","data-v-378e4372"]]),no="",io=T({name:"LyricInput",components:{ElInput:N,ElButton:B,ElTooltip:de,ElDialog:re,FontAwesomeIcon:D,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
|
-
|
|
3
|
-
Original lyrics:
|
|
4
|
-
${this.lyric}`,r=(await R.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 R.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"),b=l("el-tooltip"),g=l("el-input"),A=l("el-dialog");return n(),u("div",ao,[s("div",lo,[s("div",ro,[s("span",uo,a(e.$t("suno.name.lyrics")),1),o($,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),s("div",co,[e.lyricHistory.length>0?(n(),k(b,{key:0,content:e.$t("suno.button.undo"),placement:"top"},{default:i(()=>[o(f,{size:"small",circle:"",onClick:e.onUndo},{default:i(()=>[o(p,{icon:"fa-solid fa-rotate-left"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),e.lyric?(n(),k(b,{key:1,content:e.$t("suno.button.clear_lyrics"),placement:"top"},{default:i(()=>[o(f,{size:"small",circle:"",onClick:e.onClear},{default:i(()=>[o(p,{icon:"fa-solid fa-eraser"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),o(b,{content:e.$t("suno.button.expand_lyrics"),placement:"top"},{default:i(()=>[o(f,{size:"small",circle:"",onClick:t[0]||(t[0]=_=>e.expanded=!0)},{default:i(()=>[o(p,{icon:"fa-solid fa-expand"})]),_:1})]),_:1},8,["content"]),e.config?.action!=="extend"?(n(),k(f,{key:2,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:i(()=>[e.generatingLyrics?c("",!0):(n(),k(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+a(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):c("",!0)])]),s("div",po,[e.config?.action!=="extend"?(n(),k(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(),k(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,a(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:ne(e.onEnhanceLyrics,["enter"])},{append:i(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:i(()=>[e.enhancingLyrics?c("",!0):(n(),k(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+a(e.$t("suno.button.enhance_lyrics")),1)]),_:1},8,["loading","onClick"])]),_:1},8,["modelValue","placeholder","onKeyup"])])):c("",!0),o(A,{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:i(()=>[s("div",go,[s("div",$o,[e.lyricHistory.length>0?(n(),k(f,{key:0,size:"small",onClick:e.onUndo},{default:i(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+a(e.$t("suno.button.undo")),1)]),_:1},8,["onClick"])):c("",!0),e.lyric?(n(),k(f,{key:1,size:"small",onClick:e.onClear},{default:i(()=>[o(p,{icon:"fa-solid fa-eraser",class:"mr-1"}),v(" "+a(e.$t("suno.button.clear_lyrics")),1)]),_:1},8,["onClick"])):c("",!0),e.config?.action!=="extend"?(n(),k(f,{key:2,size:"small",loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:i(()=>[e.generatingLyrics?c("",!0):(n(),k(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+a(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:i(()=>[v(a(e.$t("common.button.confirm")),1)]),_:1})])]),default:i(()=>[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:ne(e.onEnhanceLyrics,["enter"])},{append:i(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:i(()=>[e.enhancingLyrics?c("",!0):(n(),k(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+a(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"]]),ge=["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=T({name:"StyleInput",components:{ElInput:N,ElButton:B,FontAwesomeIcon:D,InfoIcon:F},data(){return{optimizing:!1,shuffledTags:$e(ge)}},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(ge)},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 R.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"),b=l("el-input");return n(),u("div",ko,[s("div",wo,[s("div",Co,[s("span",Vo,a(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:i(()=>[e.optimizing?c("",!0):(n(),k(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+a(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),s("div",So,[o(b,{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,a(e.style?.length||0)+"/1000",1)]),s("div",Ao,[(n(!0),u(M,null,j(e.visibleTags,g=>(n(),u("button",{key:g,class:"style-tag",onClick:A=>e.onTagClick(g)},a(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=T({name:"TitleInput",components:{ElInput:N,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})}}}}),Lo={class:"field"},Ro={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",Lo,[s("div",Ro,[s("span",Mo,a(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=T({name:"ExtendFromInput",components:{ElImage:W,ElIcon:ee,ElInputNumber:x,VideoPlay:ce,VideoPause:ue},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:X,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})}}}),Go={class:"field"},jo={class:"box"},Bo={class:"title font-bold"},Oo={class:"input-wrapper"},No={class:"task"},Wo={class:"left"},Ho={key:2,class:"duration"},qo={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"),b=l("el-icon"),g=l("video-play"),A=q("loading");return n(),u("div",Go,[s("div",jo,[s("h2",Bo,a(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))},[H((n(),u("div",Wo,[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(b,null,{default:i(()=>[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(b,null,{default:i(()=>[o(g)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",Ho,a(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[A,!e.audio?.audio_url]]),s("div",qo,[s("h2",Ko,a(e.audio?.title),1),s("p",Jo,a(e.audio?.style),1)])])):c("",!0)])])}const Yo=E(zo,[["render",Qo],["__scopeId","data-v-bcce4821"]]),Xo=T({name:"CoverFromInput",components:{ElImage:W,ElIcon:ee,VideoPlay:ce,VideoPause:ue},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:X,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"),b=l("video-play"),g=q("loading");return n(),u("div",Zo,[s("div",xo,[s("h2",es,a(e.$t("suno.name.cover")),1)]),s("div",ts,[e.audio?(n(),u("div",{key:0,class:"audio",onClick:t[2]||(t[2]=A=>e.onClick(e.audio))},[H((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]=A=>e.onPause(e.audio))},[o(f,null,{default:i(()=>[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]=A=>e.onPlay(e.audio))},[o(f,null,{default:i(()=>[o(b)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",ss,a(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[g,!e.audio?.audio_url]]),s("div",ns,[s("h2",is,a(e.audio?.title),1),s("p",as,a(e.audio?.style),1)])])):c("",!0)])])}const rs=E(Xo,[["render",ls],["__scopeId","data-v-06640216"]]),ds=T({name:"VocalGenderSelector",components:{ElRadioGroup:Z,ElRadioButton:ie,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,a(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]=b=>e.vocalGender=b)},{default:i(()=>[o(p,{value:""},{default:i(()=>[v(a(e.$t("suno.gender.auto")),1)]),_:1}),o(p,{value:"f"},{default:i(()=>[v(a(e.$t("suno.gender.female")),1)]),_:1}),o(p,{value:"m"},{default:i(()=>[v(a(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const fs=E(ds,[["render",ms]]),hs=T({name:"AdvancedParams",components:{ElCollapse:Le,ElCollapseItem:Ie,ElInput:N,ElSlider:pe,ElRadioGroup:Z,ElRadioButton:ie},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"},Ls={key:5,class:"mb-3"},Rs={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"},Gs={class:"text-xs font-bold"};function js(e,t,d,r,m,y){const $=l("el-input"),p=l("el-slider"),f=l("el-radio-button"),b=l("el-radio-group"),g=l("el-collapse-item"),A=l("el-collapse");return n(),k(A,{modelValue:e.activeNames,"onUpdate:modelValue":t[7]||(t[7]=_=>e.activeNames=_),class:"advanced-collapse"},{default:i(()=>[o(g,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:i(()=>[e.config?.custom?(n(),u("div",gs,[s("div",$s,[s("span",_s,a(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,a(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,a(e.$t("suno.name.weirdness")),1),s("span",Vs,a(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,a(e.$t("suno.name.styleInfluence")),1),s("span",Us,a(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,a(e.$t("suno.name.variationCategory")),1)]),o(b,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=_=>e.variationCategory=_)},{default:i(()=>[o(f,{value:""},{default:i(()=>[v(a(e.$t("suno.gender.auto")),1)]),_:1}),o(f,{value:"high"},{default:i(()=>[v(a(e.$t("suno.variation.high")),1)]),_:1}),o(f,{value:"low"},{default:i(()=>[v(a(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),e.config?.action==="cover"?(n(),u("div",Ls,[s("div",Rs,[s("span",Ms,a(e.$t("suno.name.audioWeight")),1),s("span",Fs,a(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",Gs,a(e.$t("suno.name.lyricsMode")),1)]),o(b,{modelValue:e.lyricsMode,"onUpdate:modelValue":t[6]||(t[6]=_=>e.lyricsMode=_)},{default:i(()=>[o(f,{value:"manual"},{default:i(()=>[v(a(e.$t("suno.lyricsMode.manual")),1)]),_:1}),o(f,{value:"auto"},{default:i(()=>[v(a(e.$t("suno.lyricsMode.auto")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Bs=E(hs,[["render",js],["__scopeId","data-v-505f8fc7"]]),Os=T({name:"ReplaceSectionInput",components:{ElInputNumber:x,ElImage:W,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"},Ws={class:"flex items-center mb-2"},Hs={class:"text-sm font-bold m-0"},qs={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"),b=q("loading");return n(),u("div",Ns,[s("div",Ws,[s("h2",Hs,a(e.$t("suno.name.replaceSection")),1),o($,{content:e.$t("suno.description.replaceSection")},null,8,["content"])]),e.audio?(n(),u("div",qs,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[H((n(),u("div",Ks,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[b,!e.audio?.audio_url]]),s("div",Js,[s("h2",Qs,a(e.audio?.title),1),s("p",Ys,a(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=T({name:"OverpaintingInput",components:{ElInputNumber:x,ElImage:W,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"),b=q("loading");return n(),u("div",tn,[s("div",on,[s("h2",sn,a(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))},[H((n(),u("div",an,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[b,!e.audio?.audio_url]]),s("div",ln,[s("h2",rn,a(e.audio?.title),1),s("p",dn,a(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=T({name:"UnderpaintingInput",components:{ElInputNumber:x,ElImage:W,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"),b=q("loading");return n(),u("div",fn,[s("div",hn,[s("h2",gn,a(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))},[H((n(),u("div",_n,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[b,!e.audio?.audio_url]]),s("div",vn,[s("h2",yn,a(e.audio?.title),1),s("p",bn,a(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=T({name:"SamplesInput",components:{ElInputNumber:x,ElImage:W,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"},Ln={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Rn={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"),b=q("loading");return n(),u("div",Sn,[s("div",Tn,[s("h2",An,a(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))},[H((n(),u("div",Pn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[b,!e.audio?.audio_url]]),s("div",En,[s("h2",In,a(e.audio?.title),1),s("p",Ln,a(e.audio?.style),1)])])])):c("",!0),s("div",Rn,[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=T({name:"VoiceCreateDialog",components:{ElDialog:re,ElForm:Fe,ElFormItem:Me,ElInput:N,ElButton:B,ElRadioGroup:Z,ElRadio:Re},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 R.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await R.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 zn(e,t,d,r,m,y){const $=l("el-input"),p=l("el-form-item"),f=l("el-radio"),b=l("el-radio-group"),g=l("el-form"),A=l("el-button"),_=l("el-dialog");return n(),k(_,{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:i(()=>[o(A,{onClick:e.onClose},{default:i(()=>[v(a(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),o(A,{type:"primary",loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:i(()=>[v(a(e.$t("suno.voice.create")),1)]),_:1},8,["loading","disabled","onClick"])]),default:i(()=>[o(g,{"label-position":"top",class:"voice-create-form"},{default:i(()=>[o(p,{label:e.$t("suno.voice.name")},{default:i(()=>[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:i(()=>[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:i(()=>[o(b,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||(t[2]=V=>e.sourceType=V),class:"w-full"},{default:i(()=>[o(f,{value:"song"},{default:i(()=>[v(a(e.$t("suno.voice.fromSong")),1)]),_:1}),o(f,{value:"upload"},{default:i(()=>[v(a(e.$t("suno.voice.fromUpload")),1)]),_:1})]),_:1},8,["modelValue"])]),_:1},8,["label"]),e.sourceType==="song"?(n(),k(p,{key:0,label:e.$t("suno.voice.audioId")},{default:i(()=>[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(),k(p,{key:1,label:e.$t("suno.voice.audioUrl")},{default:i(()=>[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 Gn=E(Dn,[["render",zn]]),jn=T({name:"VoiceManager",components:{ElButton:B,ElIcon:ee,ElTabs:be,ElTabPane:ye,ElTooltip:de,Loading:ke,FontAwesomeIcon:D,VoiceCreateDialog:Gn},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 we.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()}}}),Bn={class:"voice-manager"},On={class:"flex items-center justify-between mb-3"},Nn={class:"text-sm font-medium"},Wn={key:0,class:"text-center py-6"},Hn={key:1,class:"text-center py-6 text-gray-400 text-sm"},qn={key:2,class:"voice-list"},Kn=["onClick"],Jn={class:"flex-1 min-w-0"},Qn={class:"voice-name"},Yn={key:0,class:"voice-desc"};function Xn(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-tab-pane"),b=l("el-tabs"),g=l("loading"),A=l("el-icon"),_=l("el-tooltip"),V=l("voice-create-dialog");return n(),u("div",Bn,[s("div",On,[s("span",Nn,a(e.$t("suno.voice.title")),1),o(p,{type:"primary",size:"small",onClick:t[0]||(t[0]=C=>e.showCreateDialog=!0)},{default:i(()=>[o($,{icon:"fa-solid fa-plus",class:"mr-1"}),v(" "+a(e.$t("suno.voice.create")),1)]),_:1})]),o(b,{modelValue:e.activeTab,"onUpdate:modelValue":t[1]||(t[1]=C=>e.activeTab=C),class:"voice-tabs",size:"small"},{default:i(()=>[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",Wn,[o(A,{class:"is-loading"},{default:i(()=>[o(g)]),_:1})])):e.visiblePersonas.length===0?(n(),u("div",Hn,a(e.activeTab==="favorites"?e.$t("suno.voice.emptyFavorites"):e.$t("suno.voice.empty")),1)):(n(),u("div",qn,[(n(!0),u(M,null,j(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",Jn,[s("div",Qn,[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(" "+a(C.name||C.persona_id),1)]),C.description?(n(),u("div",Yn,a(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:i(()=>[o(p,{size:"small",text:"",class:G({"voice-fav-active":e.isFavorite(C.persona_id)}),onClick:I=>e.onToggleFavorite(C)},{default:i(()=>[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:i(()=>[o($,{icon:"fa-solid fa-trash"})]),_:2},1032,["loading","onClick"])])],10,Kn))),128))])),o(V,{modelValue:e.showCreateDialog,"onUpdate:modelValue":t[3]||(t[3]=C=>e.showCreateDialog=C),onCreated:e.onCreated},null,8,["modelValue","onCreated"])])}const Zn=E(jn,[["render",Xn],["__scopeId","data-v-8b8e36d9"]]),xn=T({name:"PersonaInput",components:{ElSelect:le,ElOption:ae,ElButton:B,ElDrawer:ve,FontAwesomeIcon:D,InfoIcon:F,VoiceManager:Zn},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||[]}}}),ei={class:"field"},ti={class:"flex items-center justify-between mb-2"},oi={class:"flex items-center"},si={class:"text-sm font-bold m-0"},ni={class:"flex items-center justify-between w-full"},ii={key:0,class:"text-xs text-gray-400 ml-2"};function ai(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),b=l("el-option"),g=l("el-select"),A=l("voice-manager"),_=l("el-drawer");return n(),u("div",ei,[s("div",ti,[s("div",oi,[s("h2",si,a(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:i(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+a(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:i(()=>[(n(!0),u(M,null,j(e.personas,V=>(n(),k(b,{key:V.persona_id||"",value:V.persona_id||"",label:V.name||V.persona_id||""},{default:i(()=>[s("div",ni,[s("span",null,a(V.name||V.persona_id),1),V.source_type?(n(),u("span",ii,a(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:i(()=>[o(A)]),_:1},8,["modelValue","title"])])}const li=E(xn,[["render",ai]]),ri=T({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,PersonaInput:li,FontAwesomeIcon:D,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"):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})}}}),di={class:"flex flex-col h-full"},ui={class:"flex-1 overflow-y-auto p-5"},ci={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},pi={class:"flex gap-2 w-full"};function mi(e,t,d,r,m,y){const $=l("type-selector"),p=l("upload-audio"),f=l("prompt-input"),b=l("lyric-input"),g=l("style-input"),A=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"),Q=l("samples-input"),h=l("advanced-params"),S=l("consumption"),oe=l("font-awesome-icon"),L=l("el-button");return n(),u("div",di,[s("div",ui,[o($,{class:"mb-4"}),o(p,{class:"mb-4"}),e.config?.custom?c("",!0):(n(),k(f,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),k(b,{key:1,class:"mb-4"})):c("",!0),e.config?.custom?(n(),k(g,{key:2,class:"mb-4"})):c("",!0),e.config?.custom?(n(),k(A,{key:3,class:"mb-4"})):c("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(n(),k(_,{key:4,class:"mb-4"})):c("",!0),e.config?.custom&&e.supportsPersona?(n(),k(V,{key:5,class:"mb-4"})):c("",!0),e.config?.action==="extend"?(n(),k(C,{key:6,class:"mb-4"})):c("",!0),e.config?.action==="cover"?(n(),k(I,{key:7,class:"mb-4"})):c("",!0),e.config?.action==="replace_section"?(n(),k(U,{key:8,class:"mb-4"})):c("",!0),e.config?.action==="overpainting"?(n(),k(K,{key:9,class:"mb-4"})):c("",!0),e.config?.action==="underpainting"?(n(),k(J,{key:10,class:"mb-4"})):c("",!0),e.config?.action==="samples"?(n(),k(Q,{key:11,class:"mb-4"})):c("",!0),o(h,{class:"mb-4"})]),s("div",ci,[o(S,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",pi,[o(L,{class:"flex-1",onClick:e.onClearAll},{default:i(()=>[o(oe,{icon:"fa-solid fa-broom",class:"mr-1"}),v(" "+a(e.$t("suno.button.clear_all")),1)]),_:1},8,["onClick"]),o(L,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:i(()=>[o(oe,{icon:"fa-solid fa-magic",class:"mr-2"}),v(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const fi=E(ri,[["render",mi],["__scopeId","data-v-16f0f019"]]),_e="https://webhook.acedata.cloud/suno",hi=T({name:"TaskPreview",components:{ElImage:W,ElIcon:ee,ElTooltip:de,FontAwesomeIcon:D,VideoPlay:ce,VideoPause:ue,ElDropdown:Se,ElDropdownMenu:Ve,ElDropdownItem:Ce,ElInput:N,ElProgress:ze,ElCheckbox:De,Loading:ke},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===Y.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:X,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}R.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})},async onExtractVocals(e){const t=this.credential?.token;t&&(w.info(this.$t("suno.message.extractingVocals")),R.vox({audio_id:e,callback_url:_e},{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")),R.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 R.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 R.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:_e},r=this.credential?.token;if(!r){console.error("no token specified");return}w.info(this.$t("suno.message.startingTask")),R.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 we.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})}}}),gi={class:"task"},$i=["onClick"],_i=["onClick"],vi={class:"left"},yi=["onClick"],bi=["onClick"],ki={key:2,class:"duration"},wi={class:"info"},Ci={key:1,class:"title-row"},Vi={class:"title"},Si={class:"style"},Ti={key:2,class:"progress-row"},Ai={class:"progress-text"},Ui={class:"right"},Pi={class:"el-dropdown-link"},Ei={class:"flex items-center min-w-[120px]"},Ii={class:"flex items-center min-w-[120px]"},Li={class:"flex items-center min-w-[120px]"},Ri={class:"el-dropdown-link"};function Mi(e,t,d,r,m,y){const $=l("el-checkbox"),p=l("el-image"),f=l("video-pause"),b=l("el-icon"),g=l("video-play"),A=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"),Q=q("loading");return n(),u("div",gi,[(n(!0),u(M,null,j(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,_i)):c("",!0),H((n(),u("div",vi,[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(b,null,{default:i(()=>[o(f)]),_:1})],8,yi)):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(b,null,{default:i(()=>[o(g)]),_:1})],8,bi)):c("",!0),h?.duration?(n(),u("div",ki,a(e.useFormatDuring(h?.duration)),1)):c("",!0)])),[[Q,!h?.audio_url]]),s("div",wi,[e.editingAudioId===h.id?(n(),u("div",{key:0,class:"title-edit",onClick:t[2]||(t[2]=P(()=>{},["stop"]))},[o(A,{ref_for:!0,ref:"titleInput",modelValue:e.editingTitle,"onUpdate:modelValue":t[1]||(t[1]=S=>e.editingTitle=S),size:"small",onKeyup:[ne(S=>e.onSaveTitleEdit(h),["enter"]),ne(e.onCancelTitleEdit,["escape"])],onBlur:S=>e.onSaveTitleEdit(h)},null,8,["modelValue","onKeyup","onBlur"])])):(n(),u("div",Ci,[s("h2",Vi,a(h?.title),1),h?.audio_url?(n(),k(_,{key:0,icon:"fa-solid fa-pen",class:"edit-icon",onClick:P(S=>e.onStartTitleEdit(h),["stop"])},null,8,["onClick"])):c("",!0)])),s("p",Si,a(h?.style),1),!h?.audio_url&&h?.progress!=null&&h?.progress<100?(n(),u("div",Ti,[o(V,{percentage:Math.round(h.progress),"stroke-width":4,"show-text":!1,status:"warning",class:"progress-bar"},null,8,["percentage"]),s("span",Ai,a(e.$t("suno.name.generating"))+" "+a(Math.round(h.progress))+"%",1)])):c("",!0)]),s("div",Ui,[o(J,null,{dropdown:i(()=>[o(K,null,{default:i(()=>[o(U,{disabled:e.isFetchingVideoUrl,onClick:S=>e.handleVideoDownload(h)},{default:i(()=>[s("div",Ei,[e.isFetchingVideoUrl?(n(),k(b,{key:0,class:"is-loading mr-2"},{default:i(()=>[o(I)]),_:1})):c("",!0),s("span",null,a(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),h?.audio_url?(n(),k(U,{key:0,onClick:P(S=>e.onDownload(S,h?.audio_url),["stop"])},{default:i(()=>[v(a(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):c("",!0),o(U,{disabled:e.isFetchingWav,onClick:S=>e.handleWavDownload(h)},{default:i(()=>[s("div",Ii,[e.isFetchingWav?(n(),k(b,{key:0,class:"is-loading mr-2"},{default:i(()=>[o(I)]),_:1})):c("",!0),s("span",null,a(e.$t("suno.button.download_wav")),1)])]),_:2},1032,["disabled","onClick"]),o(U,{disabled:e.isFetchingMidi,onClick:S=>e.handleMidiDownload(h)},{default:i(()=>[s("div",Li,[e.isFetchingMidi?(n(),k(b,{key:0,class:"is-loading mr-2"},{default:i(()=>[o(I)]),_:1})):c("",!0),s("span",null,a(e.$t("suno.button.download_midi")),1)])]),_:2},1032,["disabled","onClick"])]),_:2},1024)]),default:i(()=>[s("span",Pi,[o(C,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:i(()=>[h?.audio_url||h?.video_url?(n(),k(_,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(J,null,{dropdown:i(()=>[o(K,{class:"suno-action-menu"},{default:i(()=>[h?.audio_url?(n(),k(U,{key:0,onClick:P(S=>e.onExtend(S,h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-forward",class:"menu-icon"}),v(" "+a(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):c("",!0),o(U,{onClick:P(S=>e.onCover(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-music",class:"menu-icon"}),v(" "+a(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),h?.id?(n(),k(U,{key:1,onClick:P(S=>e.onMashup(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-shuffle",class:"menu-icon"}),v(" "+a(e.$t("suno.button.mashup")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id&&h?.action==="extend"?(n(),k(U,{key:2,onClick:P(S=>e.onConcatMusic(h?.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-link",class:"menu-icon"}),v(" "+a(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(),k(U,{key:3,onClick:P(S=>e.onReplaceSection(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-scissors",class:"menu-icon"}),v(" "+a(e.$t("suno.button.replace_section")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:4,onClick:P(S=>e.onOverpainting(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-microphone",class:"menu-icon"}),v(" "+a(e.$t("suno.button.overpainting")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:5,onClick:P(S=>e.onUnderpainting(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-guitar",class:"menu-icon"}),v(" "+a(e.$t("suno.button.underpainting")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:6,onClick:P(S=>e.onSamples(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-drum",class:"menu-icon"}),v(" "+a(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(),k(U,{key:7,onClick:P(S=>e.onGetStems(h.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-layer-group",class:"menu-icon"}),v(" "+a(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):c("",!0),h.id?(n(),k(U,{key:8,onClick:P(S=>e.onGetAllStems(h.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-bars-staggered",class:"menu-icon"}),v(" "+a(e.$t("suno.button.all_stems")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:9,onClick:P(S=>e.onRemaster(h.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-wand-magic-sparkles",class:"menu-icon"}),v(" "+a(e.$t("suno.button.remaster")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:10,onClick:P(S=>e.onExtractVocals(h.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-headphones",class:"menu-icon"}),v(" "+a(e.$t("suno.button.extract_vocals")),1)]),_:2},1032,["onClick"])):c("",!0),h?.id?(n(),k(U,{key:11,onClick:P(S=>e.onArtistConsistency(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-palette",class:"menu-icon"}),v(" "+a(e.$t("suno.button.artist_consistency")),1)]),_:2},1032,["onClick"])):c("",!0),t[5]||(t[5]=s("div",{class:"menu-divider"},null,-1)),h?.id?(n(),k(U,{key:12,onClick:P(S=>e.onGetTiming(h.id),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-clock",class:"menu-icon"}),v(" "+a(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(),k(U,{key:13,class:"delete-item",onClick:P(S=>e.onDelete(h),["stop"])},{default:i(()=>[o(_,{icon:"fa-solid fa-trash",class:"menu-icon delete-icon"}),v(" "+a(e.$t("suno.button.delete")),1)]),_:2},1032,["onClick"])):c("",!0)]),_:2,__:[3,4,5,6]},1024)]),default:i(()=>[s("span",Ri,[o(C,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:i(()=>[h?.audio_url||h?.video_url?(n(),k(_,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],10,$i))),128))])}const Fi=E(hi,[["render",Mi]]),Di={class:"player-slider"},zi=T({__name:"PlayerSlider",setup(e){const t=te(),d=O({get:()=>t.state.suno?.audio?.progress,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:$})}),r=O({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",Di,[o(z(pe),{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"])]))}}),Gi={class:"flex player-song"},ji=["src"],Bi={class:"ml-2 text-xs flex flex-col justify-between"},Oi={class:"w-52 2xl:w-96 cursor-pointer truncate"},Ni={class:"flex"},Wi={class:"ml-2 text-dc"},Hi=T({__name:"PlayerSong",setup(e){const t=te(),d=O({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",Gi,[s("img",{alt:"",class:"w-11 h-11 rounded",src:d.value?.image_url||z(Xe)},null,8,ji),s("div",Bi,[s("div",Oi,[s("div",Ni,[s("span",null,a(d.value?.title||"Music"),1),s("span",Wi,"- "+a(d.value?.style||"SmallRuralDog"),1)])])])]))}}),qi={class:"flex justify-end items-center gap-x-2.5"},Ki={class:"text-xs"},Ji=T({__name:"PlayerAction",setup(e){const t=te(),d=O({get:()=>t.state.suno?.audio?.progress,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:m})}),r=O({get:()=>t.state.suno?.audio?.duration,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:m})});return(m,y)=>(n(),u("div",qi,[s("span",Ki,a(z(X)(d.value))+" / "+a(z(X)(r.value)),1)]))}}),Qi={class:"player-volume flex flex-col items-center pt-2"},Yi={class:"text-sm mt-3"},Xi=T({__name:"PlayerVolumeSlider",setup(e){const t=te(),d=O({get:()=>t.state.suno.audio?.volume,set:y=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:y})}),r=O({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",Qi,[o(z(pe),{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",Yi,a(d.value),1)]))}}),Zi={class:"flex items-center justify-center gap-x-3"},xi=T({__name:"PlayerController",setup(e){const t=te(),d=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),r=O(()=>t.state.suno.audio);return(m,y)=>(n(),u("div",Zi,[o(me,{icon:r.value?.state==="playing"?z(Ze):z(xe),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:d},null,8,["icon"]),o(z(Te),{placement:"top",width:"50px",trigger:"click"},{reference:i(()=>[o(me,{icon:z(et),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:i(()=>[o(Xi)]),_:1})]))}}),ea={class:"flex flex-col items-stretch h-20"},ta={class:"flex grow px-5 items-center"},oa={class:"flex-1"},sa={class:"flex-1"},na={class:"flex-1"},ia=T({__name:"Player",setup(e){return(t,d)=>(n(),u("div",ea,[o(zi),s("div",ta,[s("div",oa,[o(Hi)]),s("div",sa,[o(xi)]),s("div",na,[o(Ji)])])]))}}),aa=T({name:"RecentPanel",components:{ElSkeletonItem:je,ElSkeleton:Ge,ElInput:N,ElButton:B,ElDropdown:Se,ElDropdownMenu:Ve,ElDropdownItem:Ce,ElPopover:Te,ElRadioGroup:Z,ElRadioButton:ie,ElSelect:le,ElOption:ae,FontAwesomeIcon:D,TaskPreview:Fi,Player:ia,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?.()}}}),la={key:0,class:"tasks"},ra={class:"left w-[70px] p-[10px] flex items-center"},da={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},ua={key:0,class:"task-toolbar"},ca={key:0,class:"filter-badge"},pa={class:"filter-popover"},ma={class:"filter-row"},fa={class:"filter-label"},ha={class:"filter-row"},ga={class:"filter-label"},$a={class:"filter-row"},_a={class:"filter-label"},va={key:0,class:"filter-row"},ya={class:"filter-label"},ba={class:"filter-actions"},ka={key:2,class:"w-full flex-1 flex items-center justify-center"},wa={class:"text-sm text-gray-400"},Ca={key:3,class:"w-full flex-1 flex flex-col items-center justify-center gap-2"},Va={class:"text-sm text-gray-400"},Sa={key:4,class:"w-full flex-1 flex items-center justify-center"},Ta={class:"h-20"};function Aa(e,t,d,r,m,y){const $=l("el-skeleton-item"),p=l("el-skeleton"),f=l("font-awesome-icon"),b=l("el-input"),g=l("el-button"),A=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"),Q=l("task-preview"),h=l("scroll-list"),S=l("no-tasks"),oe=l("player");return n(),u(M,null,[e.tasks?.items===void 0?(n(),u("div",la,[(n(),u(M,null,j(3,L=>s("div",{key:L,class:"flex"},[s("div",ra,[o(p,{animated:""},{template:i(()=>[o($,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",da,[o(p,{animated:""},{template:i(()=>[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",ua,[o(b,{modelValue:e.searchQuery,"onUpdate:modelValue":t[0]||(t[0]=L=>e.searchQuery=L),size:"small",placeholder:e.$t("suno.placeholder.searchSongs"),clearable:"",class:"task-search"},{prefix:i(()=>[o(f,{icon:"fa-solid fa-magnifying-glass",class:"text-xs"})]),_:1},8,["modelValue","placeholder"]),o(V,{trigger:"click",onCommand:e.onSortChange},{dropdown:i(()=>[o(_,null,{default:i(()=>[o(A,{command:"newest",class:G({"is-active":e.sortBy==="newest"})},{default:i(()=>[v(a(e.$t("suno.sort.newest")),1)]),_:1},8,["class"]),o(A,{command:"oldest",class:G({"is-active":e.sortBy==="oldest"})},{default:i(()=>[v(a(e.$t("suno.sort.oldest")),1)]),_:1},8,["class"])]),_:1})]),default:i(()=>[o(g,{size:"small",class:"sort-btn"},{default:i(()=>[o(f,{icon:"fa-solid fa-arrow-down-wide-short",class:"mr-1"}),v(" "+a(e.sortLabel),1)]),_:1})]),_:1},8,["onCommand"]),o(J,{trigger:"click",placement:"bottom-end",width:260},{reference:i(()=>[o(g,{size:"small",class:G(["filter-btn",{"has-active-filter":e.activeFilterCount>0}])},{default:i(()=>[o(f,{icon:"fa-solid fa-filter",class:"mr-1"}),v(" "+a(e.$t("suno.filter.title"))+" ",1),e.activeFilterCount>0?(n(),u("span",ca,a(e.activeFilterCount),1)):c("",!0)]),_:1},8,["class"])]),default:i(()=>[s("div",pa,[s("div",ma,[s("div",fa,a(e.$t("suno.filter.type")),1),o(I,{modelValue:e.filterType,"onUpdate:modelValue":t[1]||(t[1]=L=>e.filterType=L),size:"small"},{default:i(()=>[o(C,{value:"all"},{default:i(()=>[v(a(e.$t("suno.filter.typeAll")),1)]),_:1}),o(C,{value:"vocal"},{default:i(()=>[v(a(e.$t("suno.filter.typeVocal")),1)]),_:1}),o(C,{value:"instrumental"},{default:i(()=>[v(a(e.$t("suno.filter.typeInstrumental")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",ha,[s("div",ga,a(e.$t("suno.filter.duration")),1),o(I,{modelValue:e.filterDuration,"onUpdate:modelValue":t[2]||(t[2]=L=>e.filterDuration=L),size:"small"},{default:i(()=>[o(C,{value:"all"},{default:i(()=>[v(a(e.$t("suno.filter.durationAll")),1)]),_:1}),o(C,{value:"short"},{default:i(()=>[v(a(e.$t("suno.filter.durationShort")),1)]),_:1}),o(C,{value:"medium"},{default:i(()=>[v(a(e.$t("suno.filter.durationMedium")),1)]),_:1}),o(C,{value:"long"},{default:i(()=>[v(a(e.$t("suno.filter.durationLong")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",$a,[s("div",_a,a(e.$t("suno.filter.video")),1),o(I,{modelValue:e.filterVideo,"onUpdate:modelValue":t[3]||(t[3]=L=>e.filterVideo=L),size:"small"},{default:i(()=>[o(C,{value:"all"},{default:i(()=>[v(a(e.$t("suno.filter.videoAll")),1)]),_:1}),o(C,{value:"with"},{default:i(()=>[v(a(e.$t("suno.filter.videoWith")),1)]),_:1}),o(C,{value:"without"},{default:i(()=>[v(a(e.$t("suno.filter.videoWithout")),1)]),_:1})]),_:1},8,["modelValue"])]),e.availableModels.length>0?(n(),u("div",va,[s("div",ya,a(e.$t("suno.filter.model")),1),o(K,{modelValue:e.filterModel,"onUpdate:modelValue":t[4]||(t[4]=L=>e.filterModel=L),size:"small",placeholder:e.$t("suno.filter.modelAll"),clearable:""},{default:i(()=>[o(U,{label:e.$t("suno.filter.modelAll"),value:"all"},null,8,["label"]),(n(!0),u(M,null,j(e.availableModels,L=>(n(),k(U,{key:L,label:L,value:L},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])):c("",!0),s("div",ba,[o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:i(()=>[v(a(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])])]),_:1})])):c("",!0),e.filteredTasks?.length>0?(n(),k(h,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[5]||(t[5]=L=>e.$emit("reach-top"))},{default:i(()=>[(n(!0),u(M,null,j(e.filteredTasks,(L,Ae)=>(n(),k(Q,{key:Ae,"model-value":L,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):e.searchQuery&&e.tasks?.items?.length>0?(n(),u("div",ka,[s("p",wa,a(e.$t("suno.message.noSearchResults")),1)])):e.activeFilterCount>0&&e.tasks?.items?.length>0?(n(),u("div",Ca,[s("p",Va,a(e.$t("suno.message.noFilterResults")),1),o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:i(()=>[v(a(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])):e.tasks?.items?.length===0?(n(),u("div",Sa,[o(S)])):c("",!0)],64)),H(s("div",Ta,[o(oe)],512),[[We,!!e.$store?.state?.suno?.audio?.object]])],64)}const Ua=E(aa,[["render",Aa],["__scopeId","data-v-4ab3f8f2"]]),Pa=T({name:"TaskPreview",components:{IconPicture:Oe,ElImage:W,ElAvatar:Be,ElIcon:ee},computed:{audio(){return this.$store.state.suno?.audio}}}),Ea={key:0,class:"size-full overflow-hidden"},Ia={class:"relative h-[300px]"},La={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Ra={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"},Ma={class:"p-4"},Fa={class:"flex items-center font-bold mb-2"},Da={class:"text-[var(--el-text-color-regular)] mb-2"},za={class:"text-xs text-[var(--el-text-color-regular)]"},Ga={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},ja={key:1,class:"w-full h-full"};function Ba(e,t,d,r,m,y){const $=l("icon-picture"),p=l("el-icon"),f=l("el-image"),b=l("el-avatar");return e.audio?.object?(n(),u("div",Ea,[s("div",Ia,[o(f,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:i(()=>[s("div",La,[o(p,{class:"text-3xl"},{default:i(()=>[o($)]),_:1})])]),_:1},8,["src"]),s("h2",Ra,a(e.audio?.title),1)]),s("div",Ma,[s("div",Fa,[o(b,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,a(e.audio?.title),1)]),s("p",Da,a(e.audio?.style),1),s("p",za,a(e.$dayjs.format(e.audio?.created_at)),1),s("div",Ga,[s("p",null,a(e.audio?.lyric),1)])])])):(n(),u("div",ja))}const Oa=E(Pa,[["render",Ba]]),Na="https://webhook.acedata.cloud/suno",Wa=T({name:"SunoIndex",components:{Layout:ct,ConfigPanel:fi,RecentPanel:Ua,PreviewPanel:Oa},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===Y.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===Y.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===Y.Request},needApply(){return this.$store.state.suno.status.getApplications===Y.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:Na},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("suno.message.startingTask")),R.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 Ha(e,t,d,r,m,y){const $=l("config-panel"),p=l("recent-panel"),f=l("preview-panel"),b=l("layout");return n(),k(b,null,{config:i(()=>[o($,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:i(()=>[o(p,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:i(()=>[o(f)]),_:1})}const al=E(Wa,[["render",Ha],["__scopeId","data-v-d1296b1a"]]);export{al as default};
|