@acedatacloud/nexior 3.146.0 → 3.147.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-BIyIYsxp.js → Auth-DByhpSBv.js} +1 -1
- package/dist/assets/{BotPlaceholder-DB5oDTGl.js → BotPlaceholder-Dm4otfD4.js} +1 -1
- package/dist/assets/{Callback-BNmGVr45.js → Callback-D2jOtpcz.js} +1 -1
- package/dist/assets/{Console-4m3mlinT.js → Console-CbN7Fw5e.js} +1 -1
- package/dist/assets/{Consumption-CYQjCvht.js → Consumption-ONDtMvc3.js} +1 -1
- package/dist/assets/{Conversation-Bp0Fbnh-.js → Conversation-ZGkH8kaj.js} +1 -1
- package/dist/assets/{CopyToClipboard-D2bQdRpq.js → CopyToClipboard-BMP80HB1.js} +1 -1
- package/dist/assets/{Detail-3xCJLQ0s.js → Detail-CkmUuK5U.js} +2 -2
- package/dist/assets/{EditArray-CNBPR9M6.js → EditArray-CRg3v6TS.js} +1 -1
- package/dist/assets/{Extra-CCl0U-7K.js → Extra-C-R3Cr3I.js} +1 -1
- package/dist/assets/{FilePreview-DLO7Wgrb.js → FilePreview-DbJ6JHmH.js} +1 -1
- package/dist/assets/{History-CRtVUKME.js → History-ByulO3La.js} +1 -1
- package/dist/assets/{IconPark.vue_vue_type_script_setup_true_lang-DU1Lsb_w.js → IconPark.vue_vue_type_script_setup_true_lang-SkbqcCaS.js} +1 -1
- package/dist/assets/{ImagePreview-D0Ix1-Y-.js → ImagePreview-B7TB9R4K.js} +1 -1
- package/dist/assets/{ImageWrapper-nkAn1pNo.js → ImageWrapper-Bn4Mo6DP.js} +1 -1
- package/dist/assets/{Index-1lJKVQ08.js → Index-9BH43EN7.js} +1 -1
- package/dist/assets/{Index-XRCT2t28.js → Index-BCWhTlYv.js} +1 -1
- package/dist/assets/{Index-DdLbDKMT.js → Index-BdFoIcyS.js} +1 -1
- package/dist/assets/{Index-B9-idh3a.js → Index-BfwDk9GL.js} +1 -1
- package/dist/assets/{Index-DkC095r1.js → Index-Bmw6dTds.js} +1 -1
- package/dist/assets/{Index-BesriifZ.js → Index-BubJiCZF.js} +1 -1
- package/dist/assets/{Index-BWE0u2Gh.js → Index-CAp9SWic.js} +1 -1
- package/dist/assets/{Index-DWS9093W.js → Index-CBuxDGu_.js} +1 -1
- package/dist/assets/{Index-Cb5Y9y7f.js → Index-CNmsO212.js} +1 -1
- package/dist/assets/{Index-BHpGf8bf.js → Index-CSVG5ioy.js} +1 -1
- package/dist/assets/{Index-Bz5Sj-ME.js → Index-CgUG0OR2.js} +1 -1
- package/dist/assets/{Index-BiaXClOc.js → Index-CphEK_1Z.js} +1 -1
- package/dist/assets/{Index-IjJZbjIG.js → Index-CuitZEJq.js} +1 -1
- package/dist/assets/{Index-DZ-G34oe.js → Index-D7Zx5hQ0.js} +1 -1
- package/dist/assets/{Index-GIVCu94j.js → Index-DBlUL-4E.js} +1 -1
- package/dist/assets/{Index-BHlrNui_.js → Index-DDYEkPHE.js} +1 -1
- package/dist/assets/{Index-DNJirFiF.js → Index-DEorf77h.js} +1 -1
- package/dist/assets/{Index-CiKVAFax.js → Index-DHC08hIK.js} +1 -1
- package/dist/assets/{Index-CCDLMwOO.js → Index-DOEbT3oo.js} +1 -1
- package/dist/assets/{Index-B3j7SxWt.js → Index-DWuB7uDf.js} +1 -1
- package/dist/assets/{Index-D5FEMy_B.js → Index-DbNXBrHk.js} +1 -1
- package/dist/assets/{Index-DO6m49Ll.js → Index-QvxN8d9d.js} +1 -1
- package/dist/assets/{Index-Kbj2Kjlf.js → Index-Y7iIrAHg.js} +1 -1
- package/dist/assets/{Index-CPz-1qE-.js → Index-fI1H8AIZ.js} +1 -1
- package/dist/assets/{Invitees-B27rWTTm.js → Invitees-DUiq-UKa.js} +1 -1
- package/dist/assets/{List-vyZhD9t1.js → List-97h9ANy1.js} +1 -1
- package/dist/assets/{List-B45Yza38.js → List-BGwpbHHY.js} +1 -1
- package/dist/assets/{List-KhLMYgCu.js → List-b3SVKMxh.js} +1 -1
- package/dist/assets/{Main-CHnxh637.js → Main-CFdZgMP6.js} +1 -1
- package/dist/assets/{Navigator-CZSGvKik.js → Navigator-MqkL-Njx.js} +1 -1
- package/dist/assets/{NoTasks-BbVvi52h.js → NoTasks-B-8kqwJZ.js} +1 -1
- package/dist/assets/{NotFound-DwqzlI4F.js → NotFound-qIQAj3Xr.js} +1 -1
- package/dist/assets/{OAuthCallback-DKv309g6.js → OAuthCallback-DiSKiClu.js} +1 -1
- package/dist/assets/{Pagination-CXja6t_Y.js → Pagination-hO4pJf46.js} +1 -1
- package/dist/assets/{Status-B-fEvPr-.js → Status-Bs8sajhE.js} +1 -1
- package/dist/assets/{Subscribe-BIX7ZO22.js → Subscribe-DEYMWacX.js} +1 -1
- package/dist/assets/{VideoPlayer-BZ4kO4gb.js → VideoPlayer-CiCUB_ln.js} +1 -1
- package/dist/assets/{_Uint8Array-xB6L_WPD.js → _Uint8Array-CsLFINqA.js} +1 -1
- package/dist/assets/{_baseClone-glhf4o0G.js → _baseClone-C8MQPABx.js} +1 -1
- package/dist/assets/{_baseIteratee-BcMdsGpl.js → _baseIteratee-VzLHbp72.js} +1 -1
- package/dist/assets/{_initCloneObject-BLwDPMHn.js → _initCloneObject-ULQkxMrA.js} +1 -1
- package/dist/assets/{add-DBtg4Vbu.js → add-CycoYlvg.js} +1 -1
- package/dist/assets/{all-wallets-671MXUqM.js → all-wallets-DKNKxTqe.js} +1 -1
- package/dist/assets/{app-store-BD4hW1Pw.js → app-store-HFT8Y6sl.js} +1 -1
- package/dist/assets/{apple-Dtcfv7Px.js → apple-CzuVqJrN.js} +1 -1
- package/dist/assets/{arrow-bottom-DRJq9HT6.js → arrow-bottom-CI7lYP9E.js} +1 -1
- package/dist/assets/{arrow-bottom-circle-1RhdKvka.js → arrow-bottom-circle-CfIjB7sJ.js} +1 -1
- package/dist/assets/{arrow-left-CynV7co9.js → arrow-left-B9yWFv0n.js} +1 -1
- package/dist/assets/{arrow-right-5JCP3Ur8.js → arrow-right-Cz7LkJfw.js} +1 -1
- package/dist/assets/{arrow-top-DaxJj-_b.js → arrow-top-GYavK7PC.js} +1 -1
- package/dist/assets/{avatar-dcMLKZHO.js → avatar-DOPk2_wU.js} +1 -1
- package/dist/assets/{bank-CRzXMPsT.js → bank-B8SHWjoc.js} +1 -1
- package/dist/assets/{basic-B6HF1S4p.js → basic-_TSu1mkT.js} +1 -1
- package/dist/assets/{browser-MrFe1wms.js → browser-By5vHEDa.js} +1 -1
- package/dist/assets/{byokCredential-C8wSo8z2.js → byokCredential-B7lL-HDa.js} +1 -1
- package/dist/assets/{card-D2K8v5N9.js → card-CVFkSZlj.js} +1 -1
- package/dist/assets/{castArray-cUkz0Pa0.js → castArray-7_h4ryCS.js} +1 -1
- package/dist/assets/chat-4LnT_jIL.js +1 -0
- package/dist/assets/chat-8ydQ3XlA.js +1 -0
- package/dist/assets/chat-B3xwzAoK.js +1 -0
- package/dist/assets/chat-B4dI7loU.js +1 -0
- package/dist/assets/{chat-RLfJ6omp.js → chat-BGw45rYV.js} +1 -1
- package/dist/assets/chat-BZMHf8EX.js +1 -0
- package/dist/assets/chat-BpMfUTzR.js +1 -0
- package/dist/assets/chat-C0pkaD9H.js +1 -0
- package/dist/assets/chat-C9N07pvI.js +1 -0
- package/dist/assets/chat-CtWU3uq_.js +1 -0
- package/dist/assets/chat-DbYw3iIV.js +1 -0
- package/dist/assets/chat-DjV8gy5o.js +1 -0
- package/dist/assets/{chat-CgTEtZN6.js → chat-Dlrj3mud.js} +1 -1
- package/dist/assets/chat-Mc3Jm6gx.js +1 -0
- package/dist/assets/chat-W9yrhtso.js +1 -0
- package/dist/assets/chat-_XM6NJTu.js +1 -0
- package/dist/assets/chat-rzGFjZVX.js +1 -0
- package/dist/assets/chat-xGwLhwua.js +1 -0
- package/dist/assets/{checkmark-_lLJ1NIU.js → checkmark-CjyJ0rdA.js} +1 -1
- package/dist/assets/{checkmark-bold-rv1RhwGQ.js → checkmark-bold-VDHZBxku.js} +1 -1
- package/dist/assets/{chevron-bottom-CWwPZWHA.js → chevron-bottom-D52N4S4H.js} +1 -1
- package/dist/assets/{chevron-left-DtmFVJ7A.js → chevron-left-DL7w2m0z.js} +1 -1
- package/dist/assets/{chevron-right-BvOq8-tC.js → chevron-right-EME0wZWM.js} +1 -1
- package/dist/assets/{chevron-top-3WkTxcK4.js → chevron-top-DVM2RlL-.js} +1 -1
- package/dist/assets/{chrome-store-DvQMxv-2.js → chrome-store--TB_R7b3.js} +1 -1
- package/dist/assets/{clock-AuDtMIL3.js → clock-8s2E-K3T.js} +1 -1
- package/dist/assets/{close-DXOzc5gc.js → close-CoJErbDb.js} +1 -1
- package/dist/assets/{coinPlaceholder-CHz4_PSm.js → coinPlaceholder-gRphcAh4.js} +1 -1
- package/dist/assets/common-BFQ9qIPu.js +1 -0
- package/dist/assets/common-BpCYPWVK.js +1 -0
- package/dist/assets/common-BtPvbys4.js +1 -0
- package/dist/assets/common-C2SlU5kY.js +1 -0
- package/dist/assets/common-CopT50R-.js +1 -0
- package/dist/assets/common-Crs5ZXua.js +1 -0
- package/dist/assets/common-D9UJlzrt.js +1 -0
- package/dist/assets/common-D9YRS0ZT.js +1 -0
- package/dist/assets/common-DATqdNZb.js +1 -0
- package/dist/assets/common-DEtnfxOi.js +1 -0
- package/dist/assets/common-Dbs_vOar.js +1 -0
- package/dist/assets/common-DeTI1Oiq.js +1 -0
- package/dist/assets/common-DsATdqrJ.js +1 -0
- package/dist/assets/common-DwXW5KKv.js +1 -0
- package/dist/assets/common-ECcK7K9i.js +1 -0
- package/dist/assets/common-OLWrwmxc.js +1 -0
- package/dist/assets/common-lA_invO3.js +1 -0
- package/dist/assets/{compass-M8zZjprl.js → compass-DT4Z_uD9.js} +1 -1
- package/dist/assets/{copy-B05AL2iQ.js → copy-gEhVoKEw.js} +1 -1
- package/dist/assets/{cursor-DCs1vaR3.js → cursor-DY1ZJdSh.js} +1 -1
- package/dist/assets/{cursor-transparent-BaFZGDuR.js → cursor-transparent-b6ikTaCK.js} +1 -1
- package/dist/assets/{debounce-Bi-gexp-.js → debounce-DB6zHvwJ.js} +1 -1
- package/dist/assets/{desktop-qKBPH-m1.js → desktop-D8Gx3dMY.js} +1 -1
- package/dist/assets/{disconnect-D3-OHDEy.js → disconnect-DXduzhN8.js} +1 -1
- package/dist/assets/{discord-37xwfDxQ.js → discord-B7j1nY1t.js} +1 -1
- package/dist/assets/{distribution-Cy8zKy5C.js → distribution-CVCBSTgy.js} +1 -1
- package/dist/assets/{dropdown-DqhxcQ29.js → dropdown-CRQGEEtN.js} +1 -1
- package/dist/assets/{etherscan-Bnjj4S-M.js → etherscan-BinUXDvC.js} +1 -1
- package/dist/assets/{exclamation-triangle-CfJnL6Ru.js → exclamation-triangle-C299zWiY.js} +1 -1
- package/dist/assets/{extension-CEvEr4ZM.js → extension-D5m-Xha1.js} +1 -1
- package/dist/assets/{external-link-QkiOLtsC.js → external-link-DhzBXAlX.js} +1 -1
- package/dist/assets/{facebook-DX6F1Ntb.js → facebook-BW911WyE.js} +1 -1
- package/dist/assets/{farcaster-B3L4R3zu.js → farcaster-B3aBO6zs.js} +1 -1
- package/dist/assets/{filters-Dpze2jKq.js → filters-C-d-rhr5.js} +1 -1
- package/dist/assets/{flux-DcdftbKN.js → flux-BZflNr3e.js} +1 -1
- package/dist/assets/{github-bQUbBJ4_.js → github-CX8gg8-l.js} +1 -1
- package/dist/assets/{google-BJcsQRrW.js → google-DR5zsQBJ.js} +1 -1
- package/dist/assets/{hailuo-B-RwAX5l.js → hailuo-DGvPSzCH.js} +1 -1
- package/dist/assets/{headshots-CwIu7Jag.js → headshots-7lRktnLr.js} +1 -1
- package/dist/assets/{help-circle-CxzFJJj9.js → help-circle-C0_tFiBr.js} +1 -1
- package/dist/assets/{id-DmgqiPfC.js → id-CYdMpxUZ.js} +1 -1
- package/dist/assets/{image-CChJWS6s.js → image-Bb8NjmCr.js} +1 -1
- package/dist/assets/{index-BFvw5Wso.js → index-7bp5wXd1.js} +1 -1
- package/dist/assets/{index-Bmjvaez9.js → index-B3utwuyb.js} +1 -1
- package/dist/assets/{index-C0sHxSyB.js → index-B9h47UCD.js} +5 -5
- package/dist/assets/{index-QEdjdPo0.js → index-BHFLCWId.js} +1 -1
- package/dist/assets/{index-BejjWTzD.js → index-BPTyzprg.js} +1 -1
- package/dist/assets/{index-V9TgTZlG.js → index-BSxsMqKC.js} +1 -1
- package/dist/assets/{index-C5OVpUH6.js → index-BU9840ub.js} +1 -1
- package/dist/assets/{index-QyX7F9WO.js → index-BUiuY-GV.js} +1 -1
- package/dist/assets/{index-B_tUuUlH.js → index-BlJJZ-FK.js} +1 -1
- package/dist/assets/{index-CogRivcT.js → index-BoLTZmvv.js} +1 -1
- package/dist/assets/{index-Bj9sVQHY.js → index-BpypPkOP.js} +1 -1
- package/dist/assets/{index-CzKRwsO-.js → index-BvxUjFFi.js} +4 -4
- package/dist/assets/{index-C3OSW6Cg.js → index-C0ELHTHi.js} +1 -1
- package/dist/assets/{index-I1NmBQEV.js → index-C1R47LXO.js} +1 -1
- package/dist/assets/{index-D3HhWsO8.js → index-C4KHAdmJ.js} +1 -1
- package/dist/assets/{index-DpXIIlUX.js → index-C7ZtLk9o.js} +1 -1
- package/dist/assets/{index-D-XcigSs.js → index-CCKMz_0n.js} +1 -1
- package/dist/assets/{index-BAxMGGtv.js → index-CDgJvd-m.js} +1 -1
- package/dist/assets/{index-C8Na8WYK.js → index-CIsuyU3r.js} +3 -3
- package/dist/assets/{index-C4kG0RjP.js → index-CK-FSy5r.js} +1 -1
- package/dist/assets/{index-DTxz2m0n.js → index-CTjltMHn.js} +1 -1
- package/dist/assets/{index-CxdujS24.js → index-CUvOYM9o.js} +1 -1
- package/dist/assets/{index-BDBb60t-.js → index-CVwy_Ed1.js} +1 -1
- package/dist/assets/{index-EYN-XOSf.js → index-CZVcGuAd.js} +1 -1
- package/dist/assets/{index-B-caQ-Wt.js → index-Ca5Nap0z.js} +1 -1
- package/dist/assets/{index-yhxo1ekT.js → index-Cfm5TcpA.js} +1 -1
- package/dist/assets/{index-CsbAGhC9.js → index-CiolqKNE.js} +1 -1
- package/dist/assets/{index-BOS3KGej.js → index-Ciud4PMj.js} +1 -1
- package/dist/assets/{index-DFuPJnBT.js → index-CmD2kc06.js} +1 -1
- package/dist/assets/{index-Ip3EnZNv.js → index-CnqGlxcN.js} +1 -1
- package/dist/assets/{index-CwkuO9ft.js → index-CrnpemQd.js} +1 -1
- package/dist/assets/{index-B2wGJXe_.js → index-D5UhdhU4.js} +1 -1
- package/dist/assets/{index-Df3ypl4y.js → index-D5nwfcmc.js} +1 -1
- package/dist/assets/{index-DbAdobii.js → index-D8ijceQe.js} +1 -1
- package/dist/assets/{index-BR-gl1F1.js → index-D9JVwsd7.js} +1 -1
- package/dist/assets/{index-dI1hhYha.js → index-DFefNVXg.js} +1 -1
- package/dist/assets/{index-BxhXEHyN.js → index-DHBU4f9C.js} +1 -1
- package/dist/assets/{index-BeikWVz_.js → index-DII_S4CL.js} +1 -1
- package/dist/assets/{index-SCqShjBr.js → index-DIjkphiQ.js} +2 -2
- package/dist/assets/{index-Rp0HAQst.js → index-DJSVg0Pj.js} +1 -1
- package/dist/assets/{index-DOouqP-k.js → index-DL7cWj7I.js} +1 -1
- package/dist/assets/{index-D6ukxw6h.js → index-DfBMHPId.js} +1 -1
- package/dist/assets/{index-FE8DaT7K.js → index-DfLSVuzK.js} +1 -1
- package/dist/assets/{index-C4prmEPM.js → index-DgtmgbDr.js} +1 -1
- package/dist/assets/{index-DHoriu_A.js → index-DkUT9Sk0.js} +1 -1
- package/dist/assets/{index-CvoYKmGC.js → index-DnP6prVq.js} +1 -1
- package/dist/assets/{index-BRlkRqvc.js → index-E6Fwwtd6.js} +1 -1
- package/dist/assets/{index-B3iFQBIN.js → index-GR0DOSaB.js} +1 -1
- package/dist/assets/{index-B6r1zyN0.js → index-HJTUt22_.js} +1 -1
- package/dist/assets/{index-CV7S40VM.js → index-LbgbCrhW.js} +1 -1
- package/dist/assets/{index-BPdbGHkd.js → index-PszTydnx.js} +1 -1
- package/dist/assets/{index-Bmkr-O7j.js → index-csLOFEV9.js} +1 -1
- package/dist/assets/{index-Dqenaaf_.js → index-eEBfkKER.js} +1 -1
- package/dist/assets/{index-cTO_Q4Fm.js → index-h56YlOsG.js} +1 -1
- package/dist/assets/{index-cDqJTkhW.js → index-mVZBNen2.js} +1 -1
- package/dist/assets/{index-DNiNc_AV.js → index-pNQe1IhV.js} +1 -1
- package/dist/assets/{index-Cz_aZ9pB.js → index-pyE0lAm7.js} +1 -1
- package/dist/assets/{index-CLLBlbdx.js → index-r0dpdwDZ.js} +1 -1
- package/dist/assets/{index-CIT5FZ2g.js → index-s7rUFjhE.js} +1 -1
- package/dist/assets/{index-DftnOCHJ.js → index-uN-DbEwj.js} +1 -1
- package/dist/assets/{index.browser.esm-D7gFg-7J.js → index.browser.esm-j3h3mdoY.js} +1 -1
- package/dist/assets/{index.es-D_RAO8k8.js → index.es-CrttZSrc.js} +1 -1
- package/dist/assets/{info-D8JO70S_.js → info-BNQm3kZY.js} +1 -1
- package/dist/assets/{info-circle-C0q9TSHa.js → info-circle-D_M1uRs2.js} +1 -1
- package/dist/assets/{isEqual-aGnZeYF-.js → isEqual-D6B5l3d6.js} +1 -1
- package/dist/assets/{isPlainObject-CU9B9iVa.js → isPlainObject-BP4X79bi.js} +1 -1
- package/dist/assets/{kling-CczsWWRC.js → kling-B9y84PDr.js} +1 -1
- package/dist/assets/{lightbulb-BQKonWIO.js → lightbulb-oOozJ-40.js} +1 -1
- package/dist/assets/{luma-v8-eJx94.js → luma-Buc2fB5B.js} +1 -1
- package/dist/assets/{mail-mTx-0ako.js → mail-B9BR0sdV.js} +1 -1
- package/dist/assets/{midjourney-Zc-jdqN2.js → midjourney-CBWkxxng.js} +1 -1
- package/dist/assets/{mobile-CE2-iYPK.js → mobile-DkVIJHQr.js} +1 -1
- package/dist/assets/{more-CvShTaui.js → more-DN4aupQF.js} +1 -1
- package/dist/assets/{nanobanana-C_pxFwnz.js → nanobanana-BvnsUJYM.js} +1 -1
- package/dist/assets/{network-placeholder-CyceNURY.js → network-placeholder-CoGuNcjw.js} +1 -1
- package/dist/assets/{nftPlaceholder-C-wf7Jpl.js → nftPlaceholder-BmKUHL67.js} +1 -1
- package/dist/assets/{off-DBDXrP1m.js → off-bjUsJjO7.js} +1 -1
- package/dist/assets/{openaiimage-CgFnZxuJ.js → openaiimage-Zo1oqdrS.js} +1 -1
- package/dist/assets/{order-Dh6PQFBl.js → order-ByF7qR3A.js} +1 -1
- package/dist/assets/{pagination-CdyGf0kN.js → pagination-BkDK8QUo.js} +1 -1
- package/dist/assets/{pika-C6hQKQ0q.js → pika-DorWZ64r.js} +1 -1
- package/dist/assets/{pixverse-C_bdPPdg.js → pixverse-BxY-VpQT.js} +1 -1
- package/dist/assets/{play-store-CZb0vQLI.js → play-store-D9ekBIIj.js} +1 -1
- package/dist/assets/{plus-DK02WbEI.js → plus-6l1AS-lF.js} +1 -1
- package/dist/assets/{price-CvHw6R6n.js → price-BkvvXqnE.js} +1 -1
- package/dist/assets/{producer-Cub23-wq.js → producer-C955Sdou.js} +1 -1
- package/dist/assets/{qr-code-D2AfEf_a.js → qr-code-qp2DGLj1.js} +1 -1
- package/dist/assets/{qrart-Baez6Cxj.js → qrart-CNwCeQhj.js} +1 -1
- package/dist/assets/{recycle-horizontal-CXWfKCIk.js → recycle-horizontal-jQTXGKDE.js} +1 -1
- package/dist/assets/{refresh-BOKVT2G7.js → refresh-Cyl4RzTI.js} +1 -1
- package/dist/assets/{reown-logo-BxyQA5OX.js → reown-logo-CjnY4zWc.js} +1 -1
- package/dist/assets/{search-Bz4owPyR.js → search-DWgk054o.js} +1 -1
- package/dist/assets/{secp256k1-Tm9INg4u.js → secp256k1-5R6VUJ6J.js} +1 -1
- package/dist/assets/{secp256k1-DOIf11Z6.js → secp256k1-T-ERFygZ.js} +1 -1
- package/dist/assets/{seedance-TbT_NHJs.js → seedance-CveHd42p.js} +1 -1
- package/dist/assets/seedream-AD20CtYK.js +1 -0
- package/dist/assets/seedream-BR3HFKhf.js +1 -0
- package/dist/assets/seedream-BRQIHD_C.js +1 -0
- package/dist/assets/seedream-BRcdx2jV.js +1 -0
- package/dist/assets/seedream-C6T0yxjI.js +1 -0
- package/dist/assets/{seedream-BzzgSWWU.js → seedream-C7I7TGb-.js} +1 -1
- package/dist/assets/{seedream-BL_4_spl.js → seedream-CBaTJXUS.js} +1 -1
- package/dist/assets/seedream-CDJFhvi2.js +1 -0
- package/dist/assets/seedream-CEHYaGL_.js +1 -0
- package/dist/assets/seedream-CT5Njl7A.js +1 -0
- package/dist/assets/seedream-Cbj8kz0a.js +1 -0
- package/dist/assets/seedream-Cmu9le4D.js +1 -0
- package/dist/assets/seedream-D-RlJcLt.js +1 -0
- package/dist/assets/seedream-DLZWrWW2.js +1 -0
- package/dist/assets/{seedream-BzT8POxF.js → seedream-Dl1dYu0l.js} +1 -1
- package/dist/assets/seedream-DpKWP1Z5.js +1 -0
- package/dist/assets/{seedream-CtXTcWrG.js → seedream-b3mCAJuV.js} +1 -1
- package/dist/assets/seedream-kjWy2ipl.js +1 -0
- package/dist/assets/{send-CYxToW02.js → send-BwuMOBN8.js} +1 -1
- package/dist/assets/{service-DQsgK4_y.js → service-2hdsb4WE.js} +1 -1
- package/dist/assets/{solana-wallets-B-SU94bJ.js → solana-wallets-D-UQhMiC.js} +2 -2
- package/dist/assets/{solana-wallets-vue-DB1Xssy_.js → solana-wallets-vue-DqmpYxn9.js} +1 -1
- package/dist/assets/{sora-B90zAuXZ.js → sora-B_bzj8AT.js} +1 -1
- package/dist/assets/subsite-BNzJC6FP.js +1 -0
- package/dist/assets/{subsite-DzbRY7xB.js → subsite-BXpdnRW5.js} +1 -1
- package/dist/assets/subsite-BfNIt8q4.js +1 -0
- package/dist/assets/subsite-BtjAmoNy.js +1 -0
- package/dist/assets/subsite-CP5IDSDo.js +1 -0
- package/dist/assets/subsite-CYTpRbHe.js +1 -0
- package/dist/assets/subsite-CdILBSzS.js +1 -0
- package/dist/assets/subsite-Cyi7yx2c.js +1 -0
- package/dist/assets/subsite-DDRdM37d.js +1 -0
- package/dist/assets/subsite-DOITqoFx.js +1 -0
- package/dist/assets/subsite-DcVO5OK5.js +1 -0
- package/dist/assets/subsite-DivHC7h_.js +1 -0
- package/dist/assets/subsite-Dj37dqJF.js +1 -0
- package/dist/assets/subsite-DyLH2RYC.js +1 -0
- package/dist/assets/subsite-J5JwjOH6.js +1 -0
- package/dist/assets/subsite-QfUqckZV.js +1 -0
- package/dist/assets/subsite-zKy2awbl.js +1 -0
- package/dist/assets/{suno-3s5cqbYS.js → suno-4MDC-V0m.js} +1 -1
- package/dist/assets/{swapHorizontal-CrlKKu4I.js → swapHorizontal-Du-FW0uJ.js} +1 -1
- package/dist/assets/{swapHorizontalBold-CuJ5LJ0c.js → swapHorizontalBold-BQps-rmY.js} +1 -1
- package/dist/assets/{swapHorizontalMedium-BVjFwz7z.js → swapHorizontalMedium-XLf-SHHr.js} +1 -1
- package/dist/assets/{swapHorizontalRoundedBold-CF2Y40P_.js → swapHorizontalRoundedBold-BPaLu_VW.js} +1 -1
- package/dist/assets/{swapVertical-CC1C55Kd.js → swapVertical-C22Dst41.js} +1 -1
- package/dist/assets/{telegram-Ceymyynj.js → telegram-3fLdEpPp.js} +1 -1
- package/dist/assets/{three-dots-ByY9nbg5.js → three-dots-CYOpEJIb.js} +1 -1
- package/dist/assets/{twitch-Hjac4yhf.js → twitch-CJSQj9ZE.js} +1 -1
- package/dist/assets/{twitterIcon-C_QKlJe1.js → twitterIcon-D-LFHVoB.js} +1 -1
- package/dist/assets/{typescript-wVAvEF7Z.js → typescript-B1EqkZTz.js} +1 -1
- package/dist/assets/{use-form-item-DrgRpU-E.js → use-form-item-CckYMD9d.js} +1 -1
- package/dist/assets/validator-ei3g__md.js +1 -0
- package/dist/assets/{veo-CJQt8lau.js → veo-wPLVRQDX.js} +1 -1
- package/dist/assets/{verify-BOjidnXH.js → verify-CQtqy2sV.js} +1 -1
- package/dist/assets/{verify-filled-Be9gfztn.js → verify-filled-CizCs-Yd.js} +1 -1
- package/dist/assets/{w3m-modal-6m2KIhky.js → w3m-modal-DCcaXs6S.js} +1 -1
- package/dist/assets/{wallet-CNFltzJd.js → wallet-Dc2Ejzef.js} +1 -1
- package/dist/assets/{wallet-placeholder-deGMUsVy.js → wallet-placeholder-DIpZqjhY.js} +1 -1
- package/dist/assets/{walletconnect-D6fUlQvK.js → walletconnect-C1BNPwO9.js} +1 -1
- package/dist/assets/{wan-BBytRfO2.js → wan-C96nuIaJ.js} +1 -1
- package/dist/assets/{warning-circle-R_Tqzx2x.js → warning-circle-BJSxMGUI.js} +1 -1
- package/dist/assets/{web-B155UhDp.js → web-_n3xdC57.js} +1 -1
- package/dist/assets/{web-CVC_sE74.js → web-upTDeY5R.js} +1 -1
- package/dist/assets/{x-DTxyC7uM.js → x-Dgqv9OXM.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/dist/assets/chat-6Cx6hIh9.js +0 -1
- package/dist/assets/chat-B2JPV-vT.js +0 -1
- package/dist/assets/chat-BFe3uXsb.js +0 -1
- package/dist/assets/chat-BZQx1sDG.js +0 -1
- package/dist/assets/chat-BZtFrosy.js +0 -1
- package/dist/assets/chat-BkDKYPKy.js +0 -1
- package/dist/assets/chat-CEFfFUFV.js +0 -1
- package/dist/assets/chat-CYkXcqBF.js +0 -1
- package/dist/assets/chat-Ci1CP25b.js +0 -1
- package/dist/assets/chat-DfxsQBYT.js +0 -1
- package/dist/assets/chat-DxQmToSr.js +0 -1
- package/dist/assets/chat-YaYtf75Q.js +0 -1
- package/dist/assets/chat-ZfET-cKH.js +0 -1
- package/dist/assets/chat-eAr7YV7v.js +0 -1
- package/dist/assets/chat-mdrSagEm.js +0 -1
- package/dist/assets/chat-p57MSD1l.js +0 -1
- package/dist/assets/common-B0Kxcgqg.js +0 -1
- package/dist/assets/common-BMb9Jlf8.js +0 -1
- package/dist/assets/common-BfG-XURa.js +0 -1
- package/dist/assets/common-Bs_a2Jbd.js +0 -1
- package/dist/assets/common-CF6jYv__.js +0 -1
- package/dist/assets/common-CIoTYKAr.js +0 -1
- package/dist/assets/common-CRRlk1dN.js +0 -1
- package/dist/assets/common-CkJK6Mwo.js +0 -1
- package/dist/assets/common-DAsJXn4y.js +0 -1
- package/dist/assets/common-DPc35HbC.js +0 -1
- package/dist/assets/common-DRUS1FfC.js +0 -1
- package/dist/assets/common-DSCl3qVU.js +0 -1
- package/dist/assets/common-DVTP8TU2.js +0 -1
- package/dist/assets/common-DljrIfwU.js +0 -1
- package/dist/assets/common-QAy2g6as.js +0 -1
- package/dist/assets/common-Yq4gkwTX.js +0 -1
- package/dist/assets/common-yQzVxZcm.js +0 -1
- package/dist/assets/seedream-6QUGex9B.js +0 -1
- package/dist/assets/seedream-B87zDvKQ.js +0 -1
- package/dist/assets/seedream-Bbm_l18W.js +0 -1
- package/dist/assets/seedream-BcEjFDXb.js +0 -1
- package/dist/assets/seedream-CSHOGglz.js +0 -1
- package/dist/assets/seedream-Cbl6-d7E.js +0 -1
- package/dist/assets/seedream-ClV2dCTz.js +0 -1
- package/dist/assets/seedream-DE2AmkCI.js +0 -1
- package/dist/assets/seedream-EztDyZQS.js +0 -1
- package/dist/assets/seedream-U0diq1Mh.js +0 -1
- package/dist/assets/seedream-Y4uU_oeX.js +0 -1
- package/dist/assets/seedream-Y7YTkllU.js +0 -1
- package/dist/assets/seedream-c4OZxSR9.js +0 -1
- package/dist/assets/seedream-geHpbKqH.js +0 -1
- package/dist/assets/subsite-9U_y4AmL.js +0 -1
- package/dist/assets/subsite-B-iJ3iS_.js +0 -1
- package/dist/assets/subsite-B4zj5zPR.js +0 -1
- package/dist/assets/subsite-B5q36S7k.js +0 -1
- package/dist/assets/subsite-C-BZE9Yx.js +0 -1
- package/dist/assets/subsite-C6MFZkAl.js +0 -1
- package/dist/assets/subsite-CF7_XpFL.js +0 -1
- package/dist/assets/subsite-CYwQne5H.js +0 -1
- package/dist/assets/subsite-C_JKZMft.js +0 -1
- package/dist/assets/subsite-ChvtCmnI.js +0 -1
- package/dist/assets/subsite-DIxduXml.js +0 -1
- package/dist/assets/subsite-DKHGWNEA.js +0 -1
- package/dist/assets/subsite-Dd8YohLv.js +0 -1
- package/dist/assets/subsite-PbWSTGkX.js +0 -1
- package/dist/assets/subsite-ddG8KGKu.js +0 -1
- package/dist/assets/subsite-rWQbBgnu.js +0 -1
- package/dist/assets/validator-COZQRMjG.js +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as z}from"./index.es-D_RAO8k8.js";import{E as B}from"./index-BR-gl1F1.js";import{E as ye}from"./index-Df3ypl4y.js";import{d as A,H as u,E as s,z as ne,C as o,y as a,D as l,q as n,Q as G,F as i,O as M,N as D,J as c,x as b,I as v,U as ie,G as O,K as W,M as P,u as j,c as H,w as Pe,L as Ee}from"./vendor-vue-NSDaktjZ.js";import{E,F as Ie,b8 as le,b7 as Le,ef as re,eg as de,S as x,H as be,aw as X,ce as ke,eh as ee,ei as Re,cd as Me,a7 as Fe}from"./index-CzKRwsO-.js";import{a as De}from"./errorCode-Cqj9Td_Z.js";import{s as R}from"./suno-3s5cqbYS.js";import{b as ze}from"./suno-DFuCGH70.js";import{E as je}from"./index-C4kG0RjP.js";import{E as ue,a as ce}from"./index-DOouqP-k.js";import{I as F,S as Ge,l as Be}from"./pagination-CdyGf0kN.js";import{E as te,a as J,b as Oe}from"./index-DTxz2m0n.js";import{E as we,a as Ce}from"./index-CIT5FZ2g.js";import{E as Ne}from"./index-QyX7F9WO.js";import{E as w}from"./index-DbAdobii.js";import{E as q}from"./index-cTO_Q4Fm.js";import{E as pe}from"./index-yhxo1ekT.js";import{u as Z,F as He,O as We,_ as fe,P as qe,a as Ke,V as Qe,E as Je}from"./IconPark.vue_vue_type_script_setup_true_lang-DU1Lsb_w.js";import{E as oe}from"./index-CwkuO9ft.js";import{E as N}from"./index-B6r1zyN0.js";import{E as me}from"./index-cDqJTkhW.js";import{E as Ye,a as Xe}from"./index-BPdbGHkd.js";import{E as Ze,a as xe}from"./index-BxhXEHyN.js";import{E as Ve}from"./index-CogRivcT.js";import{C as et}from"./Consumption-CYQjCvht.js";import{a as tt}from"./price-CvHw6R6n.js";import{E as ot}from"./index-BOS3KGej.js";import{E as st}from"./index-Ip3EnZNv.js";import{E as Se,b as Te,a as Ae}from"./index-dI1hhYha.js";import{E as Ue}from"./index-D-XcigSs.js";import{N as nt}from"./NoTasks-BbVvi52h.js";import{a as it,E as at}from"./index-CsbAGhC9.js";import"./use-form-item-DrgRpU-E.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-COZQRMjG.js";import"./index-D3HhWsO8.js";import"./index-BFvw5Wso.js";import"./typescript-wVAvEF7Z.js";import"./strings-beZM2Y-f.js";import"./isEqual-aGnZeYF-.js";import"./_Uint8Array-xB6L_WPD.js";import"./castArray-cUkz0Pa0.js";import"./debounce-Bi-gexp-.js";import"./_baseIteratee-BcMdsGpl.js";import"./index-DNiNc_AV.js";import"./_baseClone-glhf4o0G.js";import"./_initCloneObject-BLwDPMHn.js";import"./isPlainObject-CU9B9iVa.js";import"./index-FE8DaT7K.js";import"./index-Cu41y2Fl.js";import"./index-QEdjdPo0.js";import"./dropdown-DqhxcQ29.js";const lt=A({name:"LayoutSuno",components:{ElDrawer:ye,ElButton:B,FontAwesomeIcon:z},data(){return{drawer:!1,preview:!1}},computed:{}}),rt={class:"main flex flex-row flex-1"},dt={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ut={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},ct={class:"preview h-full w-[300px] flex flex-col"};function pt(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-drawer");return n(),u("div",rt,[s("div",dt,[ne(e.$slots,"config",{},void 0,!0)]),s("div",ut,[ne(e.$slots,"result",{},void 0,!0)]),s("div",ct,[ne(e.$slots,"preview",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[ne(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const mt=E(lt,[["render",pt],["__scopeId","data-v-c6c85757"]]),ft=A({name:"TypeSelector",components:{ElSelect:ce,ElOption:ue,ElSwitch:je,ElTag:Ie},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=ze)}}),ht={class:"mode-tabs mb-3"},gt={class:"mb-3"},$t={class:"flex items-center mb-1"},_t={class:"text-sm font-bold"},vt={class:"model-option"},yt={class:"model-option-left"},bt={class:"model-option-name"},kt={class:"model-option-desc"},wt={key:0,class:"flex items-center justify-between mb-3"},Ct={class:"text-sm font-bold"};function Vt(e,t,d,r,m,y){const $=l("el-tag"),p=l("el-option"),f=l("el-select"),k=l("el-switch");return n(),u("div",null,[s("div",ht,[s("button",{class:G(["mode-tab",{active:!e.custom}]),onClick:t[0]||(t[0]=g=>e.custom=!1)},i(e.$t("suno.mode.simple")),3),s("button",{class:G(["mode-tab",{active:e.custom}]),onClick:t[1]||(t[1]=g=>e.custom=!0)},i(e.$t("suno.mode.custom")),3)]),s("div",gt,[s("div",$t,[s("span",_t,i(e.$t("suno.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[2]||(t[2]=g=>e.model=g),class:"w-full model-select",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:a(()=>[(n(!0),u(M,null,D(e.options,g=>(n(),b(p,{key:g.value,label:g.label,value:g.value,class:G({"model-option-divider":g.dividerAfter})},{default:a(()=>[s("div",vt,[s("div",yt,[s("span",bt,i(g.label),1),g.pro?(n(),b($,{key:0,size:"small",type:"warning",effect:"plain",class:"model-option-pro"},{default:a(()=>[...t[4]||(t[4]=[v("Pro",-1)])]),_:1})):c("",!0)]),s("span",kt,i(g.desc),1)])]),_:2},1032,["label","value","class"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),u("div",wt,[s("span",Ct,i(e.$t("suno.name.instrumental")),1),o(k,{modelValue:e.instrumental,"onUpdate:modelValue":t[3]||(t[3]=g=>e.instrumental=g)},null,8,["modelValue"])])):c("",!0)])}const St=E(ft,[["render",Vt],["__scopeId","data-v-a6ada414"]]),Tt=A({name:"UploadAudio",components:{ElUpload:Ne,ElButton:B,ElDialog:le,ElTabs:Ce,ElTabPane:we,InfoIcon:F,FontAwesomeIcon:z,ElRadioGroup:J,ElRadioButton:te},emits:["change"],data(){return{fileList:[],uploadUrl:Le()+"/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)}}}),At={class:"relative"},Ut={class:"flex justify-between items-center mb-2"},Pt={class:"flex justify-start items-center"},Et={class:"text-sm font-bold"},It={key:0,class:"mb-2"},Lt=["src"],Rt={key:1,class:"mt-2"},Mt={class:"py-4"},Ft={class:"text-center py-6"},Dt={class:"text-sm"},zt={class:"text-xs text-gray-400 mt-1"},jt={class:"py-4 text-center"},Gt={class:"recorder-display mb-4"},Bt={key:0,class:"text-red-500 flex items-center justify-center gap-2"},Ot={class:"text-2xl font-mono"},Nt={key:1,class:"text-green-600"},Ht={key:2,class:"text-gray-400 text-2xl font-mono"},Wt={key:0,class:"mb-4"},qt=["src"],Kt={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"),k=l("el-radio-button"),g=l("el-radio-group"),T=l("el-upload"),_=l("el-tab-pane"),V=l("el-tabs"),C=l("el-dialog");return n(),u("div",At,[s("div",Ut,[s("div",Pt,[s("span",Et,i(e.$t("suno.name.referenceAudios")),1),o($,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])]),o(f,{round:"",type:"primary",size:"small",onClick:t[0]||(t[0]=I=>e.dialogVisible=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-plus",class:"icon mr-1"}),v(" "+i(e.$t("suno.button.addAudio")),1)]),_:1})]),e.audioPreviewUrl?(n(),u("div",It,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,Lt)])):c("",!0),e.hasUploadedAudio?(n(),u("div",Rt,[o(g,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=I=>e.uploadAction=I),size:"small"},{default:a(()=>[o(k,{value:"upload_extend"},{default:a(()=>[v(i(e.$t("suno.button.extend")),1)]),_:1}),o(k,{value:"upload_cover"},{default:a(()=>[v(i(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),o(C,{modelValue:e.dialogVisible,"onUpdate:modelValue":t[4]||(t[4]=I=>e.dialogVisible=I),title:e.$t("suno.name.addAudio"),width:"520px","close-on-click-modal":!1,"append-to-body":""},{default:a(()=>[o(V,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||(t[3]=I=>e.activeTab=I),class:"add-audio-tabs"},{default:a(()=>[o(_,{name:"browse",label:e.$t("suno.tab.browse")},{default:a(()=>[s("div",Mt,[o(T,{"file-list":e.fileList,"onUpdate:fileList":t[2]||(t[2]=I=>e.fileList=I),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:""},{default:a(()=>[s("div",Ft,[o(p,{icon:"fa-solid fa-upload",class:"text-4xl text-gray-400 mb-3"}),s("div",Dt,i(e.$t("suno.description.dropAudioHere")),1),s("div",zt,i(e.$t("suno.description.audioFormats")),1)])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])]),_:1},8,["label"]),o(_,{name:"record",label:e.$t("suno.tab.record")},{default:a(()=>[s("div",jt,[s("div",Gt,[e.recording?(n(),u("div",Bt,[t[5]||(t[5]=s("span",{class:"recording-dot"},null,-1)),s("span",Ot,i(e.formattedTime),1)])):e.recordedBlob?(n(),u("div",Nt,[o(p,{icon:"fa-solid fa-check-circle",class:"text-2xl mr-2"}),s("span",null,i(e.$t("suno.message.recordingReady"))+" ("+i(e.formattedTime)+")",1)])):(n(),u("div",Ht,"00:00"))]),e.recordedAudioUrl&&!e.recording?(n(),u("div",Wt,[s("audio",{src:e.recordedAudioUrl,controls:"",class:"w-full"},null,8,qt)])):c("",!0),s("div",Kt,[!e.recording&&!e.recordedBlob?(n(),b(f,{key:0,type:"primary",round:"",onClick:e.startRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.button.startRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recording?(n(),b(f,{key:1,type:"danger",round:"",onClick:e.stopRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-stop",class:"mr-1"}),v(" "+i(e.$t("suno.button.stopRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recordedBlob&&!e.recording?(n(),u(M,{key:2},[o(f,{round:"",onClick:e.resetRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.reRecord")),1)]),_:1},8,["onClick"]),o(f,{type:"primary",round:"",loading:e.uploadingRecord,onClick:e.uploadRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-upload",class:"mr-1"}),v(" "+i(e.$t("suno.button.useRecording")),1)]),_:1},8,["loading","onClick"])],64)):c("",!0)])])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),_:1},8,["modelValue","title"])])}const Jt=E(Tt,[["render",Qt],["__scopeId","data-v-bfb6b53d"]]),Yt="",he=[{key:"lofi",label:"🎧 Lo-fi Chill",prompt:"a relaxing lo-fi hip hop beat for studying"},{key:"pop-love",label:"💕 Pop Love Song",prompt:"a catchy pop love song with sweet melodies"},{key:"rock-anthem",label:"🎸 Rock Anthem",prompt:"an energetic rock anthem with electric guitars"},{key:"jazz-night",label:"🎷 Jazz Night",prompt:"a smooth late-night jazz piece with saxophone"},{key:"edm-drop",label:"⚡ EDM Drop",prompt:"an intense EDM track with a massive drop"},{key:"folk-story",label:"🪕 Folk Story",prompt:"a warm folk song telling a story about traveling"},{key:"rnb-groove",label:"🎤 R&B Groove",prompt:"a smooth R&B groove with soulful vocals"},{key:"classical",label:"🎻 Classical",prompt:"an elegant classical piece for orchestra"},{key:"hip-hop",label:"🎤 Hip Hop",prompt:"a hard-hitting hip hop beat with bass"},{key:"country",label:"🤠 Country",prompt:"an upbeat country song with acoustic guitar and banjo"},{key:"reggae",label:"🌴 Reggae",prompt:"a laid-back reggae tune with island vibes"},{key:"latin",label:"💃 Latin",prompt:"a vibrant Latin dance track with percussion"},{key:"ambient",label:"🌊 Ambient",prompt:"a dreamy ambient soundscape for relaxation"},{key:"metal",label:"🤘 Metal",prompt:"a powerful metal song with heavy riffs and double bass drums"},{key:"soul",label:"🎵 Soul",prompt:"a heartfelt soul ballad with gospel harmonies"},{key:"synthwave",label:"🌃 Synthwave",prompt:"a retro synthwave track with 80s vibes"},{key:"kpop",label:"🇰🇷 K-Pop",prompt:"a catchy K-pop dance track with hook"},{key:"lullaby",label:"🌙 Lullaby",prompt:"a gentle lullaby for bedtime with soft piano"},{key:"cinematic",label:"🎬 Cinematic",prompt:"an epic cinematic orchestral score for a movie trailer"},{key:"blues",label:"🎸 Blues",prompt:"a soulful blues song with electric guitar bends"},{key:"disco",label:"🕺 Disco",prompt:"a funky disco track with groovy bassline"},{key:"punk",label:"🔥 Punk Rock",prompt:"a fast punk rock song with raw energy"},{key:"gospel",label:"⛪ Gospel",prompt:"an uplifting gospel choir song with piano"},{key:"trap",label:"🔊 Trap",prompt:"a dark trap beat with 808s and hi-hats"},{key:"bossa",label:"☕ Bossa Nova",prompt:"a gentle bossa nova with nylon guitar"},{key:"indie",label:"🎶 Indie",prompt:"a dreamy indie track with ethereal vocals"},{key:"cpop",label:"🇨🇳 C-Pop",prompt:"a beautiful Chinese pop ballad with emotional vocals"},{key:"jpop",label:"🇯🇵 J-Pop",prompt:"a cheerful J-pop song with anime vibes"},{key:"afrobeat",label:"🥁 Afrobeat",prompt:"a groovy Afrobeat track with layered percussion"},{key:"game",label:"🎮 Game BGM",prompt:"an adventurous video game background music"}],Xt=8;function ge(e){const t=[...e];for(let d=t.length-1;d>0;d--){const r=Math.floor(Math.random()*(d+1));[t[d],t[r]]=[t[r],t[d]]}return t}const Zt=A({name:"PromptInput",components:{ElInput:q,FontAwesomeIcon:z,InfoIcon:F},data(){return{shuffledTags:ge(he)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,Xt)}},mounted(){this.prompt||(this.prompt=Yt)},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=ge(he)}}}),xt={class:"field"},eo={class:"flex items-center mb-1"},to={class:"text-sm font-bold"},oo={class:"inspo-tags"},so=["onClick"];function no(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",eo,[s("span",to,i(e.$t("suno.name.songDescription")),1),o($,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=k=>e.prompt=k),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"]),s("div",oo,[(n(!0),u(M,null,D(e.visibleTags,k=>(n(),u("button",{key:k.key,class:"inspo-tag",onClick:g=>e.onTagClick(k)},i(k.label),9,so))),128)),s("button",{class:"inspo-tag inspo-tag-refresh",onClick:t[1]||(t[1]=(...k)=>e.onRefreshTags&&e.onRefreshTags(...k))},[o(f,{icon:"fa-solid fa-arrows-rotate"})])])])}const io=E(Zt,[["render",no],["__scopeId","data-v-378e4372"]]),ao="",lo=A({name:"LyricInput",components:{ElInput:q,ElButton:B,ElTooltip:pe,ElDialog:le,FontAwesomeIcon:z,InfoIcon:F},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:"",lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=ao)},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){const e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=""},async onEnhanceLyrics(){const e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,w.info(this.$t("suno.message.enhancingLyrics"));try{const t=`${this.enhancePrompt}
|
|
1
|
+
import{F as z}from"./index.es-CrttZSrc.js";import{E as B}from"./index-D9JVwsd7.js";import{E as ye}from"./index-D5nwfcmc.js";import{d as A,H as u,E as s,z as ne,C as o,y as a,D as l,q as n,Q as G,F as i,O as M,N as D,J as c,x as b,I as v,U as ie,G as O,K as W,M as P,u as j,c as H,w as Pe,L as Ee}from"./vendor-vue-NSDaktjZ.js";import{E,F as Ie,b8 as le,b7 as Le,ef as re,eg as de,S as x,H as be,aw as X,ce as ke,eh as ee,ei as Re,cd as Me,a7 as Fe}from"./index-BvxUjFFi.js";import{a as De}from"./errorCode-Cqj9Td_Z.js";import{s as R}from"./suno-4MDC-V0m.js";import{b as ze}from"./suno-DFuCGH70.js";import{E as je}from"./index-CK-FSy5r.js";import{E as ue,a as ce}from"./index-DL7cWj7I.js";import{I as F,S as Ge,l as Be}from"./pagination-BkDK8QUo.js";import{E as te,a as J,b as Oe}from"./index-CTjltMHn.js";import{E as we,a as Ce}from"./index-s7rUFjhE.js";import{E as Ne}from"./index-BUiuY-GV.js";import{E as w}from"./index-D8ijceQe.js";import{E as q}from"./index-h56YlOsG.js";import{E as pe}from"./index-Cfm5TcpA.js";import{u as Z,F as He,O as We,_ as fe,P as qe,a as Ke,V as Qe,E as Je}from"./IconPark.vue_vue_type_script_setup_true_lang-SkbqcCaS.js";import{E as oe}from"./index-CrnpemQd.js";import{E as N}from"./index-HJTUt22_.js";import{E as me}from"./index-mVZBNen2.js";import{E as Ye,a as Xe}from"./index-PszTydnx.js";import{E as Ze,a as xe}from"./index-DHBU4f9C.js";import{E as Ve}from"./index-BoLTZmvv.js";import{C as et}from"./Consumption-ONDtMvc3.js";import{a as tt}from"./price-BkvvXqnE.js";import{E as ot}from"./index-Ciud4PMj.js";import{E as st}from"./index-CnqGlxcN.js";import{E as Se,b as Te,a as Ae}from"./index-DFefNVXg.js";import{E as Ue}from"./index-CCKMz_0n.js";import{N as nt}from"./NoTasks-B-8kqwJZ.js";import{a as it,E as at}from"./index-CiolqKNE.js";import"./use-form-item-CckYMD9d.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./validator-ei3g__md.js";import"./index-C4KHAdmJ.js";import"./index-7bp5wXd1.js";import"./typescript-B1EqkZTz.js";import"./strings-beZM2Y-f.js";import"./isEqual-D6B5l3d6.js";import"./_Uint8Array-CsLFINqA.js";import"./castArray-7_h4ryCS.js";import"./debounce-DB6zHvwJ.js";import"./_baseIteratee-VzLHbp72.js";import"./index-pNQe1IhV.js";import"./_baseClone-C8MQPABx.js";import"./_initCloneObject-ULQkxMrA.js";import"./isPlainObject-BP4X79bi.js";import"./index-DfLSVuzK.js";import"./index-Cu41y2Fl.js";import"./index-BHFLCWId.js";import"./dropdown-CRQGEEtN.js";const lt=A({name:"LayoutSuno",components:{ElDrawer:ye,ElButton:B,FontAwesomeIcon:z},data(){return{drawer:!1,preview:!1}},computed:{}}),rt={class:"main flex flex-row flex-1"},dt={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ut={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},ct={class:"preview h-full w-[300px] flex flex-col"};function pt(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-drawer");return n(),u("div",rt,[s("div",dt,[ne(e.$slots,"config",{},void 0,!0)]),s("div",ut,[ne(e.$slots,"result",{},void 0,!0)]),s("div",ct,[ne(e.$slots,"preview",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=k=>e.drawer=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-magic"})]),_:1}),o(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=k=>e.drawer=k),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:a(()=>[ne(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const mt=E(lt,[["render",pt],["__scopeId","data-v-c6c85757"]]),ft=A({name:"TypeSelector",components:{ElSelect:ce,ElOption:ue,ElSwitch:je,ElTag:Ie},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=ze)}}),ht={class:"mode-tabs mb-3"},gt={class:"mb-3"},$t={class:"flex items-center mb-1"},_t={class:"text-sm font-bold"},vt={class:"model-option"},yt={class:"model-option-left"},bt={class:"model-option-name"},kt={class:"model-option-desc"},wt={key:0,class:"flex items-center justify-between mb-3"},Ct={class:"text-sm font-bold"};function Vt(e,t,d,r,m,y){const $=l("el-tag"),p=l("el-option"),f=l("el-select"),k=l("el-switch");return n(),u("div",null,[s("div",ht,[s("button",{class:G(["mode-tab",{active:!e.custom}]),onClick:t[0]||(t[0]=g=>e.custom=!1)},i(e.$t("suno.mode.simple")),3),s("button",{class:G(["mode-tab",{active:e.custom}]),onClick:t[1]||(t[1]=g=>e.custom=!0)},i(e.$t("suno.mode.custom")),3)]),s("div",gt,[s("div",$t,[s("span",_t,i(e.$t("suno.name.model")),1)]),o(f,{modelValue:e.model,"onUpdate:modelValue":t[2]||(t[2]=g=>e.model=g),class:"w-full model-select",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:a(()=>[(n(!0),u(M,null,D(e.options,g=>(n(),b(p,{key:g.value,label:g.label,value:g.value,class:G({"model-option-divider":g.dividerAfter})},{default:a(()=>[s("div",vt,[s("div",yt,[s("span",bt,i(g.label),1),g.pro?(n(),b($,{key:0,size:"small",type:"warning",effect:"plain",class:"model-option-pro"},{default:a(()=>[...t[4]||(t[4]=[v("Pro",-1)])]),_:1})):c("",!0)]),s("span",kt,i(g.desc),1)])]),_:2},1032,["label","value","class"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),u("div",wt,[s("span",Ct,i(e.$t("suno.name.instrumental")),1),o(k,{modelValue:e.instrumental,"onUpdate:modelValue":t[3]||(t[3]=g=>e.instrumental=g)},null,8,["modelValue"])])):c("",!0)])}const St=E(ft,[["render",Vt],["__scopeId","data-v-a6ada414"]]),Tt=A({name:"UploadAudio",components:{ElUpload:Ne,ElButton:B,ElDialog:le,ElTabs:Ce,ElTabPane:we,InfoIcon:F,FontAwesomeIcon:z,ElRadioGroup:J,ElRadioButton:te},emits:["change"],data(){return{fileList:[],uploadUrl:Le()+"/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)}}}),At={class:"relative"},Ut={class:"flex justify-between items-center mb-2"},Pt={class:"flex justify-start items-center"},Et={class:"text-sm font-bold"},It={key:0,class:"mb-2"},Lt=["src"],Rt={key:1,class:"mt-2"},Mt={class:"py-4"},Ft={class:"text-center py-6"},Dt={class:"text-sm"},zt={class:"text-xs text-gray-400 mt-1"},jt={class:"py-4 text-center"},Gt={class:"recorder-display mb-4"},Bt={key:0,class:"text-red-500 flex items-center justify-center gap-2"},Ot={class:"text-2xl font-mono"},Nt={key:1,class:"text-green-600"},Ht={key:2,class:"text-gray-400 text-2xl font-mono"},Wt={key:0,class:"mb-4"},qt=["src"],Kt={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"),k=l("el-radio-button"),g=l("el-radio-group"),T=l("el-upload"),_=l("el-tab-pane"),V=l("el-tabs"),C=l("el-dialog");return n(),u("div",At,[s("div",Ut,[s("div",Pt,[s("span",Et,i(e.$t("suno.name.referenceAudios")),1),o($,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])]),o(f,{round:"",type:"primary",size:"small",onClick:t[0]||(t[0]=I=>e.dialogVisible=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-plus",class:"icon mr-1"}),v(" "+i(e.$t("suno.button.addAudio")),1)]),_:1})]),e.audioPreviewUrl?(n(),u("div",It,[s("audio",{src:e.audioPreviewUrl,controls:"",class:"w-full"},null,8,Lt)])):c("",!0),e.hasUploadedAudio?(n(),u("div",Rt,[o(g,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=I=>e.uploadAction=I),size:"small"},{default:a(()=>[o(k,{value:"upload_extend"},{default:a(()=>[v(i(e.$t("suno.button.extend")),1)]),_:1}),o(k,{value:"upload_cover"},{default:a(()=>[v(i(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),o(C,{modelValue:e.dialogVisible,"onUpdate:modelValue":t[4]||(t[4]=I=>e.dialogVisible=I),title:e.$t("suno.name.addAudio"),width:"520px","close-on-click-modal":!1,"append-to-body":""},{default:a(()=>[o(V,{modelValue:e.activeTab,"onUpdate:modelValue":t[3]||(t[3]=I=>e.activeTab=I),class:"add-audio-tabs"},{default:a(()=>[o(_,{name:"browse",label:e.$t("suno.tab.browse")},{default:a(()=>[s("div",Mt,[o(T,{"file-list":e.fileList,"onUpdate:fileList":t[2]||(t[2]=I=>e.fileList=I),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3,.wav,.m4a,audio/*","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:""},{default:a(()=>[s("div",Ft,[o(p,{icon:"fa-solid fa-upload",class:"text-4xl text-gray-400 mb-3"}),s("div",Dt,i(e.$t("suno.description.dropAudioHere")),1),s("div",zt,i(e.$t("suno.description.audioFormats")),1)])]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])]),_:1},8,["label"]),o(_,{name:"record",label:e.$t("suno.tab.record")},{default:a(()=>[s("div",jt,[s("div",Gt,[e.recording?(n(),u("div",Bt,[t[5]||(t[5]=s("span",{class:"recording-dot"},null,-1)),s("span",Ot,i(e.formattedTime),1)])):e.recordedBlob?(n(),u("div",Nt,[o(p,{icon:"fa-solid fa-check-circle",class:"text-2xl mr-2"}),s("span",null,i(e.$t("suno.message.recordingReady"))+" ("+i(e.formattedTime)+")",1)])):(n(),u("div",Ht,"00:00"))]),e.recordedAudioUrl&&!e.recording?(n(),u("div",Wt,[s("audio",{src:e.recordedAudioUrl,controls:"",class:"w-full"},null,8,qt)])):c("",!0),s("div",Kt,[!e.recording&&!e.recordedBlob?(n(),b(f,{key:0,type:"primary",round:"",onClick:e.startRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.button.startRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recording?(n(),b(f,{key:1,type:"danger",round:"",onClick:e.stopRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-stop",class:"mr-1"}),v(" "+i(e.$t("suno.button.stopRecord")),1)]),_:1},8,["onClick"])):c("",!0),e.recordedBlob&&!e.recording?(n(),u(M,{key:2},[o(f,{round:"",onClick:e.resetRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.reRecord")),1)]),_:1},8,["onClick"]),o(f,{type:"primary",round:"",loading:e.uploadingRecord,onClick:e.uploadRecording},{default:a(()=>[o(p,{icon:"fa-solid fa-upload",class:"mr-1"}),v(" "+i(e.$t("suno.button.useRecording")),1)]),_:1},8,["loading","onClick"])],64)):c("",!0)])])]),_:1},8,["label"])]),_:1},8,["modelValue"])]),_:1},8,["modelValue","title"])])}const Jt=E(Tt,[["render",Qt],["__scopeId","data-v-bfb6b53d"]]),Yt="",he=[{key:"lofi",label:"🎧 Lo-fi Chill",prompt:"a relaxing lo-fi hip hop beat for studying"},{key:"pop-love",label:"💕 Pop Love Song",prompt:"a catchy pop love song with sweet melodies"},{key:"rock-anthem",label:"🎸 Rock Anthem",prompt:"an energetic rock anthem with electric guitars"},{key:"jazz-night",label:"🎷 Jazz Night",prompt:"a smooth late-night jazz piece with saxophone"},{key:"edm-drop",label:"⚡ EDM Drop",prompt:"an intense EDM track with a massive drop"},{key:"folk-story",label:"🪕 Folk Story",prompt:"a warm folk song telling a story about traveling"},{key:"rnb-groove",label:"🎤 R&B Groove",prompt:"a smooth R&B groove with soulful vocals"},{key:"classical",label:"🎻 Classical",prompt:"an elegant classical piece for orchestra"},{key:"hip-hop",label:"🎤 Hip Hop",prompt:"a hard-hitting hip hop beat with bass"},{key:"country",label:"🤠 Country",prompt:"an upbeat country song with acoustic guitar and banjo"},{key:"reggae",label:"🌴 Reggae",prompt:"a laid-back reggae tune with island vibes"},{key:"latin",label:"💃 Latin",prompt:"a vibrant Latin dance track with percussion"},{key:"ambient",label:"🌊 Ambient",prompt:"a dreamy ambient soundscape for relaxation"},{key:"metal",label:"🤘 Metal",prompt:"a powerful metal song with heavy riffs and double bass drums"},{key:"soul",label:"🎵 Soul",prompt:"a heartfelt soul ballad with gospel harmonies"},{key:"synthwave",label:"🌃 Synthwave",prompt:"a retro synthwave track with 80s vibes"},{key:"kpop",label:"🇰🇷 K-Pop",prompt:"a catchy K-pop dance track with hook"},{key:"lullaby",label:"🌙 Lullaby",prompt:"a gentle lullaby for bedtime with soft piano"},{key:"cinematic",label:"🎬 Cinematic",prompt:"an epic cinematic orchestral score for a movie trailer"},{key:"blues",label:"🎸 Blues",prompt:"a soulful blues song with electric guitar bends"},{key:"disco",label:"🕺 Disco",prompt:"a funky disco track with groovy bassline"},{key:"punk",label:"🔥 Punk Rock",prompt:"a fast punk rock song with raw energy"},{key:"gospel",label:"⛪ Gospel",prompt:"an uplifting gospel choir song with piano"},{key:"trap",label:"🔊 Trap",prompt:"a dark trap beat with 808s and hi-hats"},{key:"bossa",label:"☕ Bossa Nova",prompt:"a gentle bossa nova with nylon guitar"},{key:"indie",label:"🎶 Indie",prompt:"a dreamy indie track with ethereal vocals"},{key:"cpop",label:"🇨🇳 C-Pop",prompt:"a beautiful Chinese pop ballad with emotional vocals"},{key:"jpop",label:"🇯🇵 J-Pop",prompt:"a cheerful J-pop song with anime vibes"},{key:"afrobeat",label:"🥁 Afrobeat",prompt:"a groovy Afrobeat track with layered percussion"},{key:"game",label:"🎮 Game BGM",prompt:"an adventurous video game background music"}],Xt=8;function ge(e){const t=[...e];for(let d=t.length-1;d>0;d--){const r=Math.floor(Math.random()*(d+1));[t[d],t[r]]=[t[r],t[d]]}return t}const Zt=A({name:"PromptInput",components:{ElInput:q,FontAwesomeIcon:z,InfoIcon:F},data(){return{shuffledTags:ge(he)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,Xt)}},mounted(){this.prompt||(this.prompt=Yt)},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=ge(he)}}}),xt={class:"field"},eo={class:"flex items-center mb-1"},to={class:"text-sm font-bold"},oo={class:"inspo-tags"},so=["onClick"];function no(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",eo,[s("span",to,i(e.$t("suno.name.songDescription")),1),o($,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=k=>e.prompt=k),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"]),s("div",oo,[(n(!0),u(M,null,D(e.visibleTags,k=>(n(),u("button",{key:k.key,class:"inspo-tag",onClick:g=>e.onTagClick(k)},i(k.label),9,so))),128)),s("button",{class:"inspo-tag inspo-tag-refresh",onClick:t[1]||(t[1]=(...k)=>e.onRefreshTags&&e.onRefreshTags(...k))},[o(f,{icon:"fa-solid fa-arrows-rotate"})])])])}const io=E(Zt,[["render",no],["__scopeId","data-v-378e4372"]]),ao="",lo=A({name:"LyricInput",components:{ElInput:q,ElButton:B,ElTooltip:pe,ElDialog:le,FontAwesomeIcon:z,InfoIcon:F},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:"",lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=ao)},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){const e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=""},async onEnhanceLyrics(){const e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,w.info(this.$t("suno.message.enhancingLyrics"));try{const t=`${this.enhancePrompt}
|
|
2
2
|
|
|
3
3
|
Original lyrics:
|
|
4
4
|
${this.lyric}`,r=(await 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}}}}),ro={class:"field"},uo={class:"flex items-center justify-between mb-1"},co={class:"flex items-center"},po={class:"text-sm font-bold"},mo={class:"flex items-center gap-1"},fo={class:"relative"},ho={class:"text-xs text-right text-[var(--el-text-color-secondary)] mt-1"},go={key:0,class:"enhance-bar"},$o={key:0,class:"enhance-bar mt-3"},_o={class:"flex items-center justify-between"},vo={class:"flex items-center gap-1"};function yo(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-tooltip"),g=l("el-input"),T=l("el-dialog");return n(),u("div",ro,[s("div",uo,[s("div",co,[s("span",po,i(e.$t("suno.name.lyrics")),1),o($,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),s("div",mo,[e.lyricHistory.length>0?(n(),b(k,{key:0,content:e.$t("suno.button.undo"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:e.onUndo},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),e.lyric?(n(),b(k,{key:1,content:e.$t("suno.button.clear_lyrics"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:e.onClear},{default:a(()=>[o(p,{icon:"fa-solid fa-eraser"})]),_:1},8,["onClick"])]),_:1},8,["content"])):c("",!0),o(k,{content:e.$t("suno.button.expand_lyrics"),placement:"top"},{default:a(()=>[o(f,{size:"small",circle:"",onClick:t[0]||(t[0]=_=>e.expanded=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-expand"})]),_:1})]),_:1},8,["content"]),e.config?.action!=="extend"?(n(),b(f,{key:2,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):c("",!0)])]),s("div",fo,[e.config?.action!=="extend"?(n(),b(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),b(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[2]||(t[2]=_=>e.lyric=_),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"])),s("div",ho,i(e.lyric?.length||0)+"/5000",1)]),e.lyric&&e.config?.action!=="extend"?(n(),u("div",go,[o(g,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[3]||(t[3]=_=>e.enhancePrompt=_),size:"small",placeholder:e.$t("suno.placeholder.enhanceLyrics"),class:"enhance-input",onKeyup:ie(e.onEnhanceLyrics,["enter"])},{append:a(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:a(()=>[e.enhancingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.enhance_lyrics")),1)]),_:1},8,["loading","onClick"])]),_:1},8,["modelValue","placeholder","onKeyup"])])):c("",!0),o(T,{modelValue:e.expanded,"onUpdate:modelValue":t[7]||(t[7]=_=>e.expanded=_),title:e.$t("suno.name.lyrics"),width:"720px",top:"5vh","close-on-click-modal":!1,class:"lyrics-expand-dialog"},{footer:a(()=>[s("div",_o,[s("div",vo,[e.lyricHistory.length>0?(n(),b(f,{key:0,size:"small",onClick:e.onUndo},{default:a(()=>[o(p,{icon:"fa-solid fa-rotate-left",class:"mr-1"}),v(" "+i(e.$t("suno.button.undo")),1)]),_:1},8,["onClick"])):c("",!0),e.lyric?(n(),b(f,{key:1,size:"small",onClick:e.onClear},{default:a(()=>[o(p,{icon:"fa-solid fa-eraser",class:"mr-1"}),v(" "+i(e.$t("suno.button.clear_lyrics")),1)]),_:1},8,["onClick"])):c("",!0),e.config?.action!=="extend"?(n(),b(f,{key:2,size:"small",loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:a(()=>[e.generatingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):c("",!0)]),o(f,{type:"primary",onClick:t[6]||(t[6]=_=>e.expanded=!1)},{default:a(()=>[v(i(e.$t("common.button.confirm")),1)]),_:1})])]),default:a(()=>[o(g,{modelValue:e.lyric,"onUpdate:modelValue":t[4]||(t[4]=_=>e.lyric=_),type:"textarea",rows:20,class:"lyrics-expanded",placeholder:e.$t("suno.placeholder.lyrics"),autofocus:""},null,8,["modelValue","placeholder"]),e.config?.action!=="extend"?(n(),u("div",$o,[o(g,{modelValue:e.enhancePrompt,"onUpdate:modelValue":t[5]||(t[5]=_=>e.enhancePrompt=_),size:"small",placeholder:e.$t("suno.placeholder.enhanceLyrics"),class:"enhance-input",onKeyup:ie(e.onEnhanceLyrics,["enter"])},{append:a(()=>[o(f,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:a(()=>[e.enhancingLyrics?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.enhance_lyrics")),1)]),_:1},8,["loading","onClick"])]),_:1},8,["modelValue","placeholder","onKeyup"])])):c("",!0)]),_:1},8,["modelValue","title"])])}const bo=E(lo,[["render",yo],["__scopeId","data-v-2b97a493"]]),$e=["Pop","Rock","Jazz","R&B","Hip Hop","Lo-fi","Electronic","Classical","Country","Blues","Folk","Reggae","Metal","Punk","Soul","Funk","Ambient","Indie","Latin","Acoustic","Dance","Disco","Gospel","K-Pop","J-Pop","C-Pop","Bossa Nova","Trap","Drill","House","Techno","Dubstep","Synthwave","Chill","Dreamy","Upbeat","Melancholic","Romantic","Epic","Cinematic","Orchestral","Piano","Guitar","Saxophone","Violin","Tribal","World Music","Afrobeat","Ska","Grunge"],ko=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 wo=A({name:"StyleInput",components:{ElInput:q,ElButton:B,FontAwesomeIcon:z,InfoIcon:F},data(){return{optimizing:!1,shuffledTags:_e($e)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,ko)}},methods:{onTagClick(e){const t=this.style||"";t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=_e($e)},async onOptimizeStyle(){const e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,w.info(this.$t("suno.message.optimizingStyle"));try{const t=await 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}}}}}),Co={class:"field"},Vo={class:"flex items-center justify-between mb-1"},So={class:"flex items-center"},To={class:"text-sm font-bold"},Ao={class:"relative"},Uo={class:"text-xs text-right text-[var(--el-text-color-secondary)] mt-1"},Po={class:"style-tags"},Eo=["onClick"];function Io(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-input");return n(),u("div",Co,[s("div",Vo,[s("div",So,[s("span",To,i(e.$t("suno.name.style")),1),o($,{content:e.$t("suno.description.style")},null,8,["content"])]),o(f,{size:"small",loading:e.optimizing,round:"",onClick:e.onOptimizeStyle},{default:a(()=>[e.optimizing?c("",!0):(n(),b(p,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),v(" "+i(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),s("div",Ao,[o(k,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=g=>e.style=g),rows:2,type:"textarea",placeholder:e.$t("suno.placeholder.style")},null,8,["modelValue","placeholder"]),s("div",Uo,i(e.style?.length||0)+"/1000",1)]),s("div",Po,[(n(!0),u(M,null,D(e.visibleTags,g=>(n(),u("button",{key:g,class:"style-tag",onClick:T=>e.onTagClick(g)},i(g),9,Eo))),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 Lo=E(wo,[["render",Io],["__scopeId","data-v-ddebb076"]]),Ro=A({name:"TitleInput",components:{ElInput:q,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})}}}}),Mo={class:"field"},Fo={class:"flex items-center mb-1"},Do={class:"text-sm font-bold"};function zo(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-input");return n(),u("div",Mo,[s("div",Fo,[s("span",Do,i(e.$t("suno.name.title")),1),o($,{content:e.$t("suno.description.title")},null,8,["content"])]),o(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=f=>e.title=f),placeholder:e.$t("suno.placeholder.title")},null,8,["modelValue","placeholder"])])}const jo=E(Ro,[["render",zo]]),Go=A({name:"ExtendFromInput",components:{ElImage:N,ElIcon:x,ElInputNumber:oe,VideoPlay:de,VideoPause:re},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Z,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Bo={class:"field"},Oo={class:"box"},No={class:"title font-bold"},Ho={class:"input-wrapper"},Wo={class:"task"},qo={class:"left"},Ko={key:2,class:"duration"},Qo={class:"info"},Jo={class:"title"},Yo={class:"style"};function Xo(e,t,d,r,m,y){const $=l("el-input-number"),p=l("el-image"),f=l("video-pause"),k=l("el-icon"),g=l("video-play"),T=W("loading");return n(),u("div",Bo,[s("div",Oo,[s("h2",No,i(e.$t("suno.name.extend")),1),s("div",Ho,[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",Wo,[e.audio?(n(),u("div",{key:0,class:"audio",onClick:t[3]||(t[3]=_=>e.onClick(e.audio))},[O((n(),u("div",qo,[o(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),u("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=_=>e.onPause(e.audio))},[o(k,null,{default:a(()=>[o(f)]),_:1})])):c("",!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),u("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=_=>e.onPlay(e.audio))},[o(k,null,{default:a(()=>[o(g)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",Ko,i(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[T,!e.audio?.audio_url]]),s("div",Qo,[s("h2",Jo,i(e.audio?.title),1),s("p",Yo,i(e.audio?.style),1)])])):c("",!0)])])}const Zo=E(Go,[["render",Xo],["__scopeId","data-v-bcce4821"]]),xo=A({name:"CoverFromInput",components:{ElImage:N,ElIcon:x,VideoPlay:de,VideoPause:re},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:Z,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),es={class:"field"},ts={class:"box"},os={class:"title font-bold"},ss={class:"task"},ns={class:"left"},is={key:2,class:"duration"},as={class:"info"},ls={class:"title"},rs={class:"style"};function ds(e,t,d,r,m,y){const $=l("el-image"),p=l("video-pause"),f=l("el-icon"),k=l("video-play"),g=W("loading");return n(),u("div",es,[s("div",ts,[s("h2",os,i(e.$t("suno.name.cover")),1)]),s("div",ss,[e.audio?(n(),u("div",{key:0,class:"audio",onClick:t[2]||(t[2]=T=>e.onClick(e.audio))},[O((n(),u("div",ns,[o($,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),u("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=T=>e.onPause(e.audio))},[o(f,null,{default:a(()=>[o(p)]),_:1})])):c("",!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),u("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=T=>e.onPlay(e.audio))},[o(f,null,{default:a(()=>[o(k)]),_:1})])):c("",!0),e.audio?.duration?(n(),u("div",is,i(e.useFormatDuring(e.audio?.duration)),1)):c("",!0)])),[[g,!e.audio?.audio_url]]),s("div",as,[s("h2",ls,i(e.audio?.title),1),s("p",rs,i(e.audio?.style),1)])])):c("",!0)])])}const us=E(xo,[["render",ds],["__scopeId","data-v-06640216"]]),cs=A({name:"VocalGenderSelector",components:{ElRadioGroup:J,ElRadioButton:te,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})}}}}),ps={class:"mb-2"},ms={class:"flex items-center mb-1"},fs={class:"text-sm font-bold"};function hs(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-radio-button"),f=l("el-radio-group");return n(),u("div",ps,[s("div",ms,[s("span",fs,i(e.$t("suno.name.vocalGender")),1),o($,{content:e.$t("suno.description.vocalGender")},null,8,["content"])]),o(f,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=k=>e.vocalGender=k)},{default:a(()=>[o(p,{value:""},{default:a(()=>[v(i(e.$t("suno.gender.auto")),1)]),_:1}),o(p,{value:"f"},{default:a(()=>[v(i(e.$t("suno.gender.female")),1)]),_:1}),o(p,{value:"m"},{default:a(()=>[v(i(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const gs=E(cs,[["render",hs]]),$s=A({name:"AdvancedParams",components:{ElCollapse:Xe,ElCollapseItem:Ye,ElInput:q,ElSlider:me,ElRadioGroup:J,ElRadioButton:te},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})}}}}),_s={key:0,class:"mb-3"},vs={class:"flex items-center mb-1"},ys={class:"text-xs font-bold"},bs={key:1,class:"mb-3"},ks={class:"flex items-center mb-1"},ws={class:"text-xs font-bold"},Cs={key:2,class:"mb-3"},Vs={class:"flex items-center justify-between mb-1"},Ss={class:"text-xs font-bold"},Ts={class:"text-xs text-[var(--el-text-color-secondary)]"},As={key:3,class:"mb-3"},Us={class:"flex items-center justify-between mb-1"},Ps={class:"text-xs font-bold"},Es={class:"text-xs text-[var(--el-text-color-secondary)]"},Is={key:4,class:"mb-3"},Ls={class:"flex items-center mb-1"},Rs={class:"text-xs font-bold"},Ms={key:5,class:"mb-3"},Fs={class:"flex items-center justify-between mb-1"},Ds={class:"text-xs font-bold"},zs={class:"text-xs text-[var(--el-text-color-secondary)]"},js={key:6,class:"mb-3"},Gs={class:"flex items-center mb-1"},Bs={class:"text-xs font-bold"};function Os(e,t,d,r,m,y){const $=l("el-input"),p=l("el-slider"),f=l("el-radio-button"),k=l("el-radio-group"),g=l("el-collapse-item"),T=l("el-collapse");return n(),b(T,{modelValue:e.activeNames,"onUpdate:modelValue":t[7]||(t[7]=_=>e.activeNames=_),class:"advanced-collapse"},{default:a(()=>[o(g,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:a(()=>[e.config?.custom?(n(),u("div",_s,[s("div",vs,[s("span",ys,i(e.$t("suno.name.styleNegative")),1)]),o($,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=_=>e.styleNegative=_),placeholder:e.$t("suno.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):c("",!0),e.config?.custom&&!e.config?.instrumental?(n(),u("div",bs,[s("div",ks,[s("span",ws,i(e.$t("suno.name.lyricPrompt")),1)]),o($,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyricPrompt=_),placeholder:e.$t("suno.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):c("",!0),e.config?.custom?(n(),u("div",Cs,[s("div",Vs,[s("span",Ss,i(e.$t("suno.name.weirdness")),1),s("span",Ts,i(e.weirdness??0),1)]),o(p,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=_=>e.weirdness=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.config?.custom?(n(),u("div",As,[s("div",Us,[s("span",Ps,i(e.$t("suno.name.styleInfluence")),1),s("span",Es,i(e.styleInfluence??50),1)]),o(p,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||(t[3]=_=>e.styleInfluence=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.isV5OrAbove?(n(),u("div",Is,[s("div",Ls,[s("span",Rs,i(e.$t("suno.name.variationCategory")),1)]),o(k,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=_=>e.variationCategory=_)},{default:a(()=>[o(f,{value:""},{default:a(()=>[v(i(e.$t("suno.gender.auto")),1)]),_:1}),o(f,{value:"high"},{default:a(()=>[v(i(e.$t("suno.variation.high")),1)]),_:1}),o(f,{value:"low"},{default:a(()=>[v(i(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0),e.config?.action==="cover"?(n(),u("div",Ms,[s("div",Fs,[s("span",Ds,i(e.$t("suno.name.audioWeight")),1),s("span",zs,i(e.audioWeight??50),1)]),o(p,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||(t[5]=_=>e.audioWeight=_),min:0,max:100,step:1},null,8,["modelValue"])])):c("",!0),e.config?.custom&&!e.config?.instrumental?(n(),u("div",js,[s("div",Gs,[s("span",Bs,i(e.$t("suno.name.lyricsMode")),1)]),o(k,{modelValue:e.lyricsMode,"onUpdate:modelValue":t[6]||(t[6]=_=>e.lyricsMode=_)},{default:a(()=>[o(f,{value:"manual"},{default:a(()=>[v(i(e.$t("suno.lyricsMode.manual")),1)]),_:1}),o(f,{value:"auto"},{default:a(()=>[v(i(e.$t("suno.lyricsMode.auto")),1)]),_:1})]),_:1},8,["modelValue"])])):c("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Ns=E($s,[["render",Os],["__scopeId","data-v-505f8fc7"]]),Hs=A({name:"ReplaceSectionInput",components:{ElInputNumber:oe,ElImage:N,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"})}}}),Ws={class:"field"},qs={class:"flex items-center mb-2"},Ks={class:"text-sm font-bold m-0"},Qs={key:0,class:"task mb-2"},Js={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Ys={class:"info flex-1 min-w-0"},Xs={class:"text-sm font-bold m-0 truncate"},Zs={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},xs={class:"flex gap-2"};function en(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=W("loading");return n(),u("div",Ws,[s("div",qs,[s("h2",Ks,i(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))},[O((n(),u("div",Js,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",Ys,[s("h2",Xs,i(e.audio?.title),1),s("p",Zs,i(e.audio?.style),1)])])])):c("",!0),s("div",xs,[o(f,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=g=>e.replaceSectionStart=g),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(f,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=g=>e.replaceSectionEnd=g),class:"flex-1",min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionEnd")},null,8,["modelValue","min","max","placeholder"])])])}const tn=E(Hs,[["render",en]]),on=A({name:"OverpaintingInput",components:{ElInputNumber:oe,ElImage:N,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"})}}}),sn={class:"field"},nn={class:"flex items-center mb-2"},an={class:"text-sm font-bold m-0"},ln={key:0,class:"task mb-2"},rn={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},dn={class:"info flex-1 min-w-0"},un={class:"text-sm font-bold m-0 truncate"},cn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},pn={class:"flex gap-2"};function mn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=W("loading");return n(),u("div",sn,[s("div",nn,[s("h2",an,i(e.$t("suno.name.overpaintingRange")),1),o($,{content:e.$t("suno.description.overpainting")},null,8,["content"])]),e.audio?(n(),u("div",ln,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[O((n(),u("div",rn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",dn,[s("h2",un,i(e.audio?.title),1),s("p",cn,i(e.audio?.style),1)])])])):c("",!0),s("div",pn,[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 fn=E(on,[["render",mn]]),hn=A({name:"UnderpaintingInput",components:{ElInputNumber:oe,ElImage:N,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"})}}}),gn={class:"field"},$n={class:"flex items-center mb-2"},_n={class:"text-sm font-bold m-0"},vn={key:0,class:"task mb-2"},yn={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},bn={class:"info flex-1 min-w-0"},kn={class:"text-sm font-bold m-0 truncate"},wn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Cn={class:"flex gap-2"};function Vn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=W("loading");return n(),u("div",gn,[s("div",$n,[s("h2",_n,i(e.$t("suno.name.underpaintingRange")),1),o($,{content:e.$t("suno.description.underpainting")},null,8,["content"])]),e.audio?(n(),u("div",vn,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[O((n(),u("div",yn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",bn,[s("h2",kn,i(e.audio?.title),1),s("p",wn,i(e.audio?.style),1)])])])):c("",!0),s("div",Cn,[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 Sn=E(hn,[["render",Vn]]),Tn=A({name:"SamplesInput",components:{ElInputNumber:oe,ElImage:N,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"})}}}),An={class:"field"},Un={class:"flex items-center mb-2"},Pn={class:"text-sm font-bold m-0"},En={key:0,class:"task mb-2"},In={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"},Mn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Fn={class:"flex gap-2"};function Dn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-input-number"),k=W("loading");return n(),u("div",An,[s("div",Un,[s("h2",Pn,i(e.$t("suno.name.samplesRange")),1),o($,{content:e.$t("suno.description.samples")},null,8,["content"])]),e.audio?(n(),u("div",En,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=g=>e.onClick(e.audio))},[O((n(),u("div",In,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[k,!e.audio?.audio_url]]),s("div",Ln,[s("h2",Rn,i(e.audio?.title),1),s("p",Mn,i(e.audio?.style),1)])])])):c("",!0),s("div",Fn,[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 zn=E(Tn,[["render",Dn]]),jn=[.5,.75,1,1.25,1.5,2],Gn=A({name:"AdjustSpeedInput",components:{ElRadioGroup:J,ElRadioButton:te,ElImage:N,InfoIcon:F},data(){return{options:jn}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){const e=this.$store.state.suno?.config?.speed;return typeof e=="number"?e:1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"})}}}),Bn={class:"field"},On={class:"flex items-center mb-2"},Nn={class:"text-sm font-bold m-0"},Hn={key:0,class:"task mb-2"},Wn={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},qn={class:"info flex-1 min-w-0"},Kn={class:"text-sm font-bold m-0 truncate"},Qn={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"};function Jn(e,t,d,r,m,y){const $=l("info-icon"),p=l("el-image"),f=l("el-radio-button"),k=l("el-radio-group"),g=W("loading");return n(),u("div",Bn,[s("div",On,[s("h2",Nn,i(e.$t("suno.name.adjustSpeed")),1),o($,{content:e.$t("suno.description.adjustSpeed")},null,8,["content"])]),e.audio?(n(),u("div",Hn,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=T=>e.onClick(e.audio))},[O((n(),u("div",Wn,[o(p,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",qn,[s("h2",Kn,i(e.audio?.title),1),s("p",Qn,i(e.audio?.style),1)])])])):c("",!0),o(k,{modelValue:e.speed,"onUpdate:modelValue":t[1]||(t[1]=T=>e.speed=T),size:"small",class:"speed-group"},{default:a(()=>[(n(!0),u(M,null,D(e.options,T=>(n(),b(f,{key:T,value:T},{default:a(()=>[v(i(T)+"x",1)]),_:2},1032,["value"]))),128))]),_:1},8,["modelValue"])])}const Yn=E(Gn,[["render",Jn],["__scopeId","data-v-ba834628"]]),Xn=A({name:"VoiceCreateDialog",components:{ElDialog:le,ElForm:xe,ElFormItem:Ze,ElInput:q,ElButton:B,ElRadioGroup:J,ElRadio:Oe},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"),k=l("el-radio-group"),g=l("el-form"),T=l("el-button"),_=l("el-dialog");return n(),b(_,{modelValue:e.visible,"onUpdate:modelValue":t[5]||(t[5]=V=>e.visible=V),title:e.$t("suno.voice.createTitle"),width:"480px","close-on-click-modal":!1,onClose:e.onClose},{footer:a(()=>[o(T,{onClick:e.onClose},{default:a(()=>[v(i(e.$t("common.button.cancel")),1)]),_:1},8,["onClick"]),o(T,{type:"primary",loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:a(()=>[v(i(e.$t("suno.voice.create")),1)]),_:1},8,["loading","disabled","onClick"])]),default:a(()=>[o(g,{"label-position":"top",class:"voice-create-form"},{default:a(()=>[o(p,{label:e.$t("suno.voice.name")},{default:a(()=>[o($,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||(t[0]=V=>e.form.name=V),placeholder:e.$t("suno.voice.namePlaceholder"),maxlength:"50"},null,8,["modelValue","placeholder"])]),_:1},8,["label"]),o(p,{label:e.$t("suno.voice.description")},{default:a(()=>[o($,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||(t[1]=V=>e.form.description=V),type:"textarea",rows:2,placeholder:e.$t("suno.voice.descriptionPlaceholder"),maxlength:"200"},null,8,["modelValue","placeholder"])]),_:1},8,["label"]),o(p,{label:e.$t("suno.voice.sourceType")},{default:a(()=>[o(k,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||(t[2]=V=>e.sourceType=V),class:"w-full"},{default:a(()=>[o(f,{value:"song"},{default:a(()=>[v(i(e.$t("suno.voice.fromSong")),1)]),_:1}),o(f,{value:"upload"},{default:a(()=>[v(i(e.$t("suno.voice.fromUpload")),1)]),_:1})]),_:1},8,["modelValue"])]),_:1},8,["label"]),e.sourceType==="song"?(n(),b(p,{key:0,label:e.$t("suno.voice.audioId")},{default:a(()=>[o($,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||(t[3]=V=>e.form.audio_id=V),placeholder:e.$t("suno.voice.audioIdPlaceholder")},null,8,["modelValue","placeholder"])]),_:1},8,["label"])):c("",!0),e.sourceType==="upload"?(n(),b(p,{key:1,label:e.$t("suno.voice.audioUrl")},{default:a(()=>[o($,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||(t[4]=V=>e.form.audio_url=V),placeholder:e.$t("suno.voice.audioUrlPlaceholder")},null,8,["modelValue","placeholder"])]),_:1},8,["label"])):c("",!0)]),_:1})]),_:1},8,["modelValue","title","onClose"])}const xn=E(Xn,[["render",Zn]]),ei=A({name:"VoiceManager",components:{ElButton:B,ElIcon:x,ElTabs:Ce,ElTabPane:we,ElTooltip:pe,Loading:be,FontAwesomeIcon:z,VoiceCreateDialog:xn},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:"all"}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab==="favorites"?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit("suno/togglePersonaFavorite",e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch("suno/getPersonas")}finally{this.loading=!1}}},selectPersona(e){const t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch("suno/setConfig",t)},async onDelete(e){try{await Ve.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()}}}),ti={class:"voice-manager"},oi={class:"flex items-center justify-between mb-3"},si={class:"text-sm font-medium"},ni={key:0,class:"text-center py-6"},ii={key:1,class:"text-center py-6 text-gray-400 text-sm"},ai={key:2,class:"voice-list"},li=["onClick"],ri={class:"flex-1 min-w-0"},di={class:"voice-name"},ui={key:0,class:"voice-desc"};function ci(e,t,d,r,m,y){const $=l("font-awesome-icon"),p=l("el-button"),f=l("el-tab-pane"),k=l("el-tabs"),g=l("loading"),T=l("el-icon"),_=l("el-tooltip"),V=l("voice-create-dialog");return n(),u("div",ti,[s("div",oi,[s("span",si,i(e.$t("suno.voice.title")),1),o(p,{type:"primary",size:"small",onClick:t[0]||(t[0]=C=>e.showCreateDialog=!0)},{default:a(()=>[o($,{icon:"fa-solid fa-plus",class:"mr-1"}),v(" "+i(e.$t("suno.voice.create")),1)]),_:1})]),o(k,{modelValue:e.activeTab,"onUpdate:modelValue":t[1]||(t[1]=C=>e.activeTab=C),class:"voice-tabs",size:"small"},{default:a(()=>[o(f,{name:"all",label:e.$t("suno.voice.tabAll")+" ("+(e.personas?.length||0)+")"},null,8,["label"]),o(f,{name:"favorites",label:e.$t("suno.voice.tabFavorites")+" ("+e.favoritePersonas.length+")"},null,8,["label"])]),_:1},8,["modelValue"]),e.loading?(n(),u("div",ni,[o(T,{class:"is-loading"},{default:a(()=>[o(g)]),_:1})])):e.visiblePersonas.length===0?(n(),u("div",ii,i(e.activeTab==="favorites"?e.$t("suno.voice.emptyFavorites"):e.$t("suno.voice.empty")),1)):(n(),u("div",ai,[(n(!0),u(M,null,D(e.visiblePersonas,C=>(n(),u("div",{key:C.persona_id,class:G(["voice-item",{active:e.selectedPersonaId===C.persona_id}]),onClick:I=>e.selectPersona(C)},[s("div",ri,[s("div",di,[o($,{icon:C.source_type==="voice"?"fa-solid fa-microphone":"fa-solid fa-music",class:"mr-1.5 text-xs opacity-60"},null,8,["icon"]),v(" "+i(C.name||C.persona_id),1)]),C.description?(n(),u("div",ui,i(C.description),1)):c("",!0)]),s("div",{class:"voice-actions",onClick:t[2]||(t[2]=P(()=>{},["stop"]))},[o(_,{content:e.isFavorite(C.persona_id)?e.$t("suno.voice.unfavorite"):e.$t("suno.voice.favorite"),placement:"top"},{default:a(()=>[o(p,{size:"small",text:"",class:G({"voice-fav-active":e.isFavorite(C.persona_id)}),onClick:I=>e.onToggleFavorite(C)},{default:a(()=>[o($,{icon:e.isFavorite(C.persona_id)?"fa-solid fa-star":"fa-regular fa-star"},null,8,["icon"])]),_:2},1032,["class","onClick"])]),_:2},1032,["content"]),o(p,{type:"danger",size:"small",text:"",loading:e.deletingId===C.persona_id,onClick:I=>e.onDelete(C)},{default:a(()=>[o($,{icon:"fa-solid fa-trash"})]),_:1},8,["loading","onClick"])])],10,li))),128))])),o(V,{modelValue:e.showCreateDialog,"onUpdate:modelValue":t[3]||(t[3]=C=>e.showCreateDialog=C),onCreated:e.onCreated},null,8,["modelValue","onCreated"])])}const pi=E(ei,[["render",ci],["__scopeId","data-v-8b8e36d9"]]),mi=A({name:"PersonaInput",components:{ElSelect:ce,ElOption:ue,ElButton:B,ElDrawer:ye,FontAwesomeIcon:z,InfoIcon:F,VoiceManager:pi},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||[]}}}),fi={class:"field"},hi={class:"flex items-center justify-between mb-2"},gi={class:"flex items-center"},$i={class:"text-sm font-bold m-0"},_i={class:"flex items-center justify-between w-full"},vi={key:0,class:"text-xs text-gray-400 ml-2"};function yi(e,t,d,r,m,y){const $=l("info-icon"),p=l("font-awesome-icon"),f=l("el-button"),k=l("el-option"),g=l("el-select"),T=l("voice-manager"),_=l("el-drawer");return n(),u("div",fi,[s("div",hi,[s("div",gi,[s("h2",$i,i(e.$t("suno.name.persona")),1),o($,{content:e.$t("suno.description.persona")},null,8,["content"])]),o(f,{type:"primary",size:"small",text:"",onClick:t[0]||(t[0]=V=>e.showManager=!0)},{default:a(()=>[o(p,{icon:"fa-solid fa-microphone",class:"mr-1"}),v(" "+i(e.$t("suno.voice.manage")),1)]),_:1})]),o(g,{modelValue:e.personaId,"onUpdate:modelValue":t[1]||(t[1]=V=>e.personaId=V),size:"small",placeholder:e.$t("suno.placeholder.personaId"),clearable:"",filterable:"",class:"w-full"},{default:a(()=>[(n(!0),u(M,null,D(e.personas,V=>(n(),b(k,{key:V.persona_id||"",value:V.persona_id||"",label:V.name||V.persona_id||""},{default:a(()=>[s("div",_i,[s("span",null,i(V.name||V.persona_id),1),V.source_type?(n(),u("span",vi,i(V.source_type),1)):c("",!0)])]),_:2},1032,["value","label"]))),128))]),_:1},8,["modelValue","placeholder"]),o(_,{modelValue:e.showManager,"onUpdate:modelValue":t[2]||(t[2]=V=>e.showManager=V),title:e.$t("suno.voice.title"),size:"380px",direction:"rtl"},{default:a(()=>[o(T)]),_:1},8,["modelValue","title"])])}const bi=E(mi,[["render",yi]]),ki=A({name:"PresetPanel",components:{TypeSelector:St,PromptInput:io,LyricInput:bo,StyleInput:Lo,TitleInput:jo,ExtendFromInput:Zo,CoverFromInput:us,UploadAudio:Jt,VocalGenderSelector:gs,AdvancedParams:Ns,ReplaceSectionInput:tn,OverpaintingInput:fn,UnderpaintingInput:Sn,SamplesInput:zn,AdjustSpeedInput:Yn,PersonaInput:bi,FontAwesomeIcon:z,ElButton:B,Consumption:et},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return tt(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){const e=this.config?.model||"";return["chirp-v4-5-plus","chirp-v5","chirp-v5-5"].includes(e)},supportsPersona(){const e=this.config?.action;return!e||e==="generate"||e==="artist_consistency"||e==="artist_consistency_vox"},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("suno.button.extend"):e==="cover"?this.$t("suno.button.cover_music"):e==="remaster"?this.$t("suno.button.remaster"):e==="replace_section"?this.$t("suno.button.replace_section"):e==="mashup"?this.$t("suno.button.mashup"):e==="stems"?this.$t("suno.button.get_stems"):e==="concat"?this.$t("suno.button.concat_music"):e==="upload_cover"?this.$t("suno.button.upload_cover"):e==="artist_consistency"?this.$t("suno.button.artist_consistency"):e==="artist_consistency_vox"?this.$t("suno.button.artist_consistency_vox"):e==="overpainting"?this.$t("suno.button.overpainting"):e==="underpainting"?this.$t("suno.button.underpainting"):e==="samples"?this.$t("suno.button.samples"):e==="adjust_speed"?this.$t("suno.button.adjust_speed"):this.$t("suno.button.generate")}},methods:{onGenerate(){this.$emit("generate")},onClearAll(){this.$store.commit("suno/setConfig",{custom:!1,sounds:!1,instrumental:!1,lyric:"",style:"",title:"",lyrics_mode:"manual",model:this.$store.state.suno?.config?.model})}}}),wi={class:"flex flex-col h-full"},Ci={class:"flex-1 overflow-y-auto p-5"},Vi={class:"flex flex-col items-center justify-center px-5 pb-5 gap-2"},Si={class:"flex gap-2 w-full"};function Ti(e,t,d,r,m,y){const $=l("type-selector"),p=l("upload-audio"),f=l("prompt-input"),k=l("lyric-input"),g=l("style-input"),T=l("title-input"),_=l("vocal-gender-selector"),V=l("persona-input"),C=l("extend-from-input"),I=l("cover-from-input"),U=l("replace-section-input"),K=l("overpainting-input"),Q=l("underpainting-input"),Y=l("samples-input"),h=l("adjust-speed-input"),S=l("advanced-params"),ae=l("consumption"),L=l("font-awesome-icon"),se=l("el-button");return n(),u("div",wi,[s("div",Ci,[o($,{class:"mb-4"}),o(p,{class:"mb-4"}),e.config?.custom?c("",!0):(n(),b(f,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),b(k,{key:1,class:"mb-4"})):c("",!0),e.config?.custom?(n(),b(g,{key:2,class:"mb-4"})):c("",!0),e.config?.custom?(n(),b(T,{key:3,class:"mb-4"})):c("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(n(),b(_,{key:4,class:"mb-4"})):c("",!0),e.config?.custom&&e.supportsPersona?(n(),b(V,{key:5,class:"mb-4"})):c("",!0),e.config?.action==="extend"?(n(),b(C,{key:6,class:"mb-4"})):c("",!0),e.config?.action==="cover"?(n(),b(I,{key:7,class:"mb-4"})):c("",!0),e.config?.action==="replace_section"?(n(),b(U,{key:8,class:"mb-4"})):c("",!0),e.config?.action==="overpainting"?(n(),b(K,{key:9,class:"mb-4"})):c("",!0),e.config?.action==="underpainting"?(n(),b(Q,{key:10,class:"mb-4"})):c("",!0),e.config?.action==="samples"?(n(),b(Y,{key:11,class:"mb-4"})):c("",!0),e.config?.action==="adjust_speed"?(n(),b(h,{key:12,class:"mb-4"})):c("",!0),o(S,{class:"mb-4"})]),s("div",Vi,[o(ae,{value:e.consumption,service:e.service},null,8,["value","service"]),s("div",Si,[o(se,{class:"flex-1",onClick:e.onClearAll},{default:a(()=>[o(L,{icon:"fa-solid fa-broom",class:"mr-1"}),v(" "+i(e.$t("suno.button.clear_all")),1)]),_:1},8,["onClick"]),o(se,{type:"primary",class:"flex-1",round:"",onClick:e.onGenerate},{default:a(()=>[o(L,{icon:"fa-solid fa-magic",class:"mr-2"}),v(" "+i(e.generateButtonText),1)]),_:1},8,["onClick"])])])])}const Ai=E(ki,[["render",Ti],["__scopeId","data-v-fa2936b9"]]),ve=ke("suno"),Ui=A({name:"TaskPreview",components:{ElImage:N,ElIcon:x,ElTooltip:pe,FontAwesomeIcon:z,VideoPlay:de,VideoPause:re,ElDropdown:Ae,ElDropdownMenu:Te,ElDropdownItem:Se,ElInput:q,ElProgress:st,ElCheckbox:ot,Loading:be},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:""}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(d=>({...d,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action==="mashup"},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:Z,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.log("on extend"),console.debug("set config",t),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation(),console.log("on download",t);const r=new URL(t).pathname,m=r.substring(r.lastIndexOf("/")+1);console.log("on preview",m),fetch(t).then(y=>y.blob()).then(y=>{He.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})},onAdjustSpeed(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"adjust_speed",audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){const t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){w.warning(this.$t("suno.message.reusePromptEmpty"));return}this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??"",lyric:t.lyric??"",lyric_prompt:t.lyric_prompt??"",lyrics_mode:t.lyrics_mode??"manual",title:t.title??"",style:t.style??"",style_negative:t.style_negative??"",vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),w.success(this.$t("suno.message.reusePromptSuccess"))},async onExtractVocals(e){const t=this.credential?.token;t&&(w.info(this.$t("suno.message.extractingVocals")),R.vox({audio_id:e,callback_url:ve},{token:t}).then(()=>{w.success(this.$t("suno.message.extractVocalsSuccess"))}).catch(d=>{w.error(d?.response?.data?.error?.message||this.$t("suno.message.extractVocalsFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){const t=this.credential?.token;t&&(w.info(this.$t("suno.message.fetchingTiming")),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:ve},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 Ve.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})}}}),Pi={class:"task"},Ei=["onClick"],Ii=["onClick"],Li={class:"left"},Ri=["onClick"],Mi=["onClick"],Fi={key:2,class:"duration"},Di={class:"info"},zi={key:1,class:"title-row"},ji={class:"title"},Gi={class:"style"},Bi={key:2,class:"progress-row"},Oi={class:"progress-text"},Ni={class:"right"},Hi={class:"el-dropdown-link"},Wi={class:"flex items-center min-w-[120px]"},qi={class:"flex items-center min-w-[120px]"},Ki={class:"flex items-center min-w-[120px]"},Qi={class:"el-dropdown-link"};function Ji(e,t,d,r,m,y){const $=l("el-checkbox"),p=l("el-image"),f=l("video-pause"),k=l("el-icon"),g=l("video-play"),T=l("el-input"),_=l("font-awesome-icon"),V=l("el-progress"),C=l("el-tooltip"),I=l("Loading"),U=l("el-dropdown-item"),K=l("el-dropdown-menu"),Q=l("el-dropdown"),Y=W("loading");return n(),u("div",Pi,[(n(!0),u(M,null,D(e.audios,h=>(n(),u("div",{key:h.id,class:G(["audio",{"mashup-selected":e.isMashupSelected(h)}]),onClick:P(S=>e.onClick(h),["stop"])},[e.isMashupMode&&h?.audio_url?(n(),u("div",{key:0,class:"mashup-check",onClick:P(S=>e.onToggleMashup(h),["stop"])},[o($,{"model-value":e.isMashupSelected(h),onClick:t[0]||(t[0]=P(()=>{},["stop"]))},null,8,["model-value"])],8,Ii)):c("",!0),O((n(),u("div",Li,[o(p,{src:h?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),h?.audio_url&&e.$store.state?.suno?.audio?.id===h.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),u("div",{key:0,class:"overlay",onClick:P(S=>e.onPause(h),["stop"])},[o(k,null,{default:a(()=>[o(f)]),_:1})],8,Ri)):c("",!0),h?.audio_url&&(e.$store.state?.suno?.audio?.id!==h.id||e.$store.state?.suno?.audio?.id===h.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),u("div",{key:1,class:"overlay",onClick:P(S=>e.onPlay(h),["stop"])},[o(k,null,{default:a(()=>[o(g)]),_:1})],8,Mi)):c("",!0),h?.duration?(n(),u("div",Fi,i(e.useFormatDuring(h?.duration)),1)):c("",!0)])),[[Y,!h?.audio_url]]),s("div",Di,[e.editingAudioId===h.id?(n(),u("div",{key:0,class:"title-edit",onClick:t[2]||(t[2]=P(()=>{},["stop"]))},[o(T,{ref_for:!0,ref:"titleInput",modelValue:e.editingTitle,"onUpdate:modelValue":t[1]||(t[1]=S=>e.editingTitle=S),size:"small",onKeyup:[ie(S=>e.onSaveTitleEdit(h),["enter"]),ie(e.onCancelTitleEdit,["escape"])],onBlur:S=>e.onSaveTitleEdit(h)},null,8,["modelValue","onKeyup","onBlur"])])):(n(),u("div",zi,[s("h2",ji,i(h?.title),1),h?.audio_url?(n(),b(_,{key:0,icon:"fa-solid fa-pen",class:"edit-icon",onClick:P(S=>e.onStartTitleEdit(h),["stop"])},null,8,["onClick"])):c("",!0)])),s("p",Gi,i(h?.style),1),!h?.audio_url&&h?.progress!=null&&h?.progress<100?(n(),u("div",Bi,[o(V,{percentage:Math.round(h.progress),"stroke-width":4,"show-text":!1,status:"warning",class:"progress-bar"},null,8,["percentage"]),s("span",Oi,i(e.$t("suno.name.generating"))+" "+i(Math.round(h.progress))+"%",1)])):c("",!0)]),s("div",Ni,[o(Q,null,{dropdown:a(()=>[o(K,null,{default:a(()=>[o(U,{disabled:e.isFetchingVideoUrl,onClick:S=>e.handleVideoDownload(h)},{default:a(()=>[s("div",Wi,[e.isFetchingVideoUrl?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_video")),1)])]),_:1},8,["disabled","onClick"]),h?.audio_url?(n(),b(U,{key:0,onClick:P(S=>e.onDownload(S,h?.audio_url),["stop"])},{default:a(()=>[v(i(e.$t("suno.button.download_audio")),1)]),_:1},8,["onClick"])):c("",!0),o(U,{disabled:e.isFetchingWav,onClick:S=>e.handleWavDownload(h)},{default:a(()=>[s("div",qi,[e.isFetchingWav?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_wav")),1)])]),_:1},8,["disabled","onClick"]),o(U,{disabled:e.isFetchingMidi,onClick:S=>e.handleMidiDownload(h)},{default:a(()=>[s("div",Ki,[e.isFetchingMidi?(n(),b(k,{key:0,class:"is-loading mr-2"},{default:a(()=>[o(I)]),_:1})):c("",!0),s("span",null,i(e.$t("suno.button.download_midi")),1)])]),_:1},8,["disabled","onClick"])]),_:2},1024)]),default:a(()=>[s("span",Hi,[o(C,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:a(()=>[h?.audio_url||h?.video_url?(n(),b(_,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(Q,null,{dropdown:a(()=>[o(K,{class:"suno-action-menu"},{default:a(()=>[h?.audio_url?(n(),b(U,{key:0,onClick:P(S=>e.onExtend(S,h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-forward",class:"menu-icon"}),v(" "+i(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"])):c("",!0),o(U,{onClick:P(S=>e.onCover(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-music",class:"menu-icon"}),v(" "+i(e.$t("suno.button.cover_music")),1)]),_:1},8,["onClick"]),h?.id?(n(),b(U,{key:1,onClick:P(S=>e.onMashup(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-shuffle",class:"menu-icon"}),v(" "+i(e.$t("suno.button.mashup")),1)]),_:1},8,["onClick"])):c("",!0),h?.id&&h?.action==="extend"?(n(),b(U,{key:2,onClick:P(S=>e.onConcatMusic(h?.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-link",class:"menu-icon"}),v(" "+i(e.$t("suno.button.concat_music")),1)]),_:1},8,["onClick"])):c("",!0),t[3]||(t[3]=s("div",{class:"menu-divider"},null,-1)),h?.id?(n(),b(U,{key:3,onClick:P(S=>e.onReplaceSection(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-scissors",class:"menu-icon"}),v(" "+i(e.$t("suno.button.replace_section")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:4,onClick:P(S=>e.onOverpainting(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-microphone",class:"menu-icon"}),v(" "+i(e.$t("suno.button.overpainting")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:5,onClick:P(S=>e.onUnderpainting(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-guitar",class:"menu-icon"}),v(" "+i(e.$t("suno.button.underpainting")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:6,onClick:P(S=>e.onSamples(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-drum",class:"menu-icon"}),v(" "+i(e.$t("suno.button.samples")),1)]),_:1},8,["onClick"])):c("",!0),t[4]||(t[4]=s("div",{class:"menu-divider"},null,-1)),h.id?(n(),b(U,{key:7,onClick:P(S=>e.onGetStems(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-layer-group",class:"menu-icon"}),v(" "+i(e.$t("suno.button.get_stems")),1)]),_:1},8,["onClick"])):c("",!0),h.id?(n(),b(U,{key:8,onClick:P(S=>e.onGetAllStems(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-bars-staggered",class:"menu-icon"}),v(" "+i(e.$t("suno.button.all_stems")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:9,onClick:P(S=>e.onRemaster(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-wand-magic-sparkles",class:"menu-icon"}),v(" "+i(e.$t("suno.button.remaster")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:10,onClick:P(S=>e.onExtractVocals(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-headphones",class:"menu-icon"}),v(" "+i(e.$t("suno.button.extract_vocals")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:11,onClick:P(S=>e.onArtistConsistency(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-palette",class:"menu-icon"}),v(" "+i(e.$t("suno.button.artist_consistency")),1)]),_:1},8,["onClick"])):c("",!0),h?.id?(n(),b(U,{key:12,onClick:P(S=>e.onAdjustSpeed(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-gauge-high",class:"menu-icon"}),v(" "+i(e.$t("suno.button.adjust_speed")),1)]),_:1},8,["onClick"])):c("",!0),t[5]||(t[5]=s("div",{class:"menu-divider"},null,-1)),o(U,{onClick:P(S=>e.onReusePrompt(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-rotate-left",class:"menu-icon"}),v(" "+i(e.$t("suno.button.reuse_prompt")),1)]),_:1},8,["onClick"]),h?.id?(n(),b(U,{key:13,onClick:P(S=>e.onGetTiming(h.id),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-clock",class:"menu-icon"}),v(" "+i(e.$t("suno.button.get_timing")),1)]),_:1},8,["onClick"])):c("",!0),t[6]||(t[6]=s("div",{class:"menu-divider"},null,-1)),h?.id?(n(),b(U,{key:14,class:"delete-item",onClick:P(S=>e.onDelete(h),["stop"])},{default:a(()=>[o(_,{icon:"fa-solid fa-trash",class:"menu-icon delete-icon"}),v(" "+i(e.$t("suno.button.delete")),1)]),_:1},8,["onClick"])):c("",!0)]),_:2},1024)]),default:a(()=>[s("span",Qi,[o(C,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:a(()=>[h?.audio_url||h?.video_url?(n(),b(_,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):c("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],10,Ei))),128))])}const Yi=E(Ui,[["render",Ji]]),Xi={class:"player-slider"},Zi=A({__name:"PlayerSlider",setup(e){const t=ee(),d=H({get:()=>t.state.suno?.audio?.progress,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:$})}),r=H({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",Xi,[o(j(me),{modelValue:d.value,"onUpdate:modelValue":p[0]||(p[0]=f=>d.value=f),"show-tooltip":!1,min:0,max:r.value,onChange:y,onInput:m},null,8,["modelValue","max"])]))}}),xi={class:"flex player-song"},ea=["src"],ta={class:"ml-2 text-xs flex flex-col justify-between"},oa={class:"w-52 2xl:w-96 cursor-pointer truncate"},sa={class:"flex"},na={class:"ml-2 text-dc"},ia=A({__name:"PlayerSong",setup(e){const t=ee(),d=H({get:()=>t.state.suno.audio,set:r=>t.commit("suno/setAudio",r)});return Pe(d,(r,m)=>{if(r?.audio_url!==m?.audio_url){console.log("audio changed",r),r.object&&(console.log("111",r.object),r.object.pause(),delete r.object);const y=new Audio(r.audio_url);r.state==="playing"?y.play():y.pause(),y.addEventListener("loadedmetadata",()=>{y.currentTime=0,y.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:y.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:y})}else if(r?.progress!==m?.progress&&Math.abs(r.progress-r.object.currentTime)>2){console.log("progress changed",r.progress);const y=t.state.suno.audio;y.object&&(y.object.currentTime=y.progress)}else r?.state!==m?.state&&(console.log("state changed",r.state),r.object&&(r.state==="playing"?r.object.play():r.object.pause()));r?.volume!==m?.volume&&(console.log("volume changed",r.volume),r.object&&(r.object.volume=r.volume/100))}),(r,m)=>(n(),u("div",xi,[s("img",{alt:"",class:"w-11 h-11 rounded",src:d.value?.image_url||j(We)},null,8,ea),s("div",ta,[s("div",oa,[s("div",sa,[s("span",null,i(d.value?.title||"Music"),1),s("span",na,"- "+i(d.value?.style||"SmallRuralDog"),1)])])])]))}}),aa={class:"flex justify-end items-center gap-x-2.5"},la={class:"text-xs"},ra=A({__name:"PlayerAction",setup(e){const t=ee(),d=H({get:()=>t.state.suno?.audio?.progress,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:m})}),r=H({get:()=>t.state.suno?.audio?.duration,set:m=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:m})});return(m,y)=>(n(),u("div",aa,[s("span",la,i(j(Z)(d.value))+" / "+i(j(Z)(r.value)),1)]))}}),da={class:"player-volume flex flex-col items-center pt-2"},ua={class:"text-sm mt-3"},ca=A({__name:"PlayerVolumeSlider",setup(e){const t=ee(),d=H({get:()=>t.state.suno.audio?.volume,set:y=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:y})}),r=H({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",da,[o(j(me),{modelValue:d.value,"onUpdate:modelValue":$[0]||($[0]=p=>d.value=p),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:r.value,onInput:m},null,8,["modelValue","disabled"]),s("div",ua,i(d.value),1)]))}}),pa={class:"flex items-center justify-center gap-x-3"},ma=A({__name:"PlayerController",setup(e){const t=ee(),d=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),r=H(()=>t.state.suno.audio);return(m,y)=>(n(),u("div",pa,[o(fe,{icon:r.value?.state==="playing"?j(qe):j(Ke),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:d},null,8,["icon"]),o(j(Ue),{placement:"top",width:"50px",trigger:"click"},{reference:a(()=>[o(fe,{icon:j(Qe),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:a(()=>[o(ca)]),_:1})]))}}),fa={class:"flex flex-col items-stretch h-20"},ha={class:"flex grow px-5 items-center"},ga={class:"flex-1"},$a={class:"flex-1"},_a={class:"flex-1"},va=A({__name:"Player",setup(e){return(t,d)=>(n(),u("div",fa,[o(Zi),s("div",ha,[s("div",ga,[o(ia)]),s("div",$a,[o(ma)]),s("div",_a,[o(ra)])])]))}}),ya=A({name:"RecentPanel",components:{ElSkeletonItem:at,ElSkeleton:it,ElInput:q,ElButton:B,ElDropdown:Ae,ElDropdownMenu:Te,ElDropdownItem:Se,ElPopover:Ue,ElRadioGroup:J,ElRadioButton:te,ElSelect:ce,ElOption:ue,FontAwesomeIcon:z,TaskPreview:Yi,Player:va,NoTasks:nt,ScrollList:Ge},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?.()}}}),ba={key:0,class:"tasks"},ka={class:"left w-[70px] p-[10px] flex items-center"},wa={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Ca={key:0,class:"task-toolbar"},Va={key:0,class:"filter-badge"},Sa={class:"filter-popover"},Ta={class:"filter-row"},Aa={class:"filter-label"},Ua={class:"filter-row"},Pa={class:"filter-label"},Ea={class:"filter-row"},Ia={class:"filter-label"},La={key:0,class:"filter-row"},Ra={class:"filter-label"},Ma={class:"filter-actions"},Fa={key:2,class:"w-full flex-1 flex items-center justify-center"},Da={class:"text-sm text-gray-400"},za={key:3,class:"w-full flex-1 flex flex-col items-center justify-center gap-2"},ja={class:"text-sm text-gray-400"},Ga={key:4,class:"w-full flex-1 flex items-center justify-center"},Ba={class:"h-20"};function Oa(e,t,d,r,m,y){const $=l("el-skeleton-item"),p=l("el-skeleton"),f=l("font-awesome-icon"),k=l("el-input"),g=l("el-button"),T=l("el-dropdown-item"),_=l("el-dropdown-menu"),V=l("el-dropdown"),C=l("el-radio-button"),I=l("el-radio-group"),U=l("el-option"),K=l("el-select"),Q=l("el-popover"),Y=l("task-preview"),h=l("scroll-list"),S=l("no-tasks"),ae=l("player");return n(),u(M,null,[e.tasks?.items===void 0?(n(),u("div",ba,[(n(),u(M,null,D(3,L=>s("div",{key:L,class:"flex"},[s("div",ka,[o(p,{animated:""},{template:a(()=>[o($,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",wa,[o(p,{animated:""},{template:a(()=>[o($,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o($,{variant:"text"})]),_:1})])])),64))])):(n(),u(M,{key:1},[e.tasks?.items?.length?(n(),u("div",Ca,[o(k,{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:a(()=>[o(f,{icon:"fa-solid fa-magnifying-glass",class:"text-xs"})]),_:1},8,["modelValue","placeholder"]),o(V,{trigger:"click",onCommand:e.onSortChange},{dropdown:a(()=>[o(_,null,{default:a(()=>[o(T,{command:"newest",class:G({"is-active":e.sortBy==="newest"})},{default:a(()=>[v(i(e.$t("suno.sort.newest")),1)]),_:1},8,["class"]),o(T,{command:"oldest",class:G({"is-active":e.sortBy==="oldest"})},{default:a(()=>[v(i(e.$t("suno.sort.oldest")),1)]),_:1},8,["class"])]),_:1})]),default:a(()=>[o(g,{size:"small",class:"sort-btn"},{default:a(()=>[o(f,{icon:"fa-solid fa-arrow-down-wide-short",class:"mr-1"}),v(" "+i(e.sortLabel),1)]),_:1})]),_:1},8,["onCommand"]),o(Q,{trigger:"click",placement:"bottom-end",width:260},{reference:a(()=>[o(g,{size:"small",class:G(["filter-btn",{"has-active-filter":e.activeFilterCount>0}])},{default:a(()=>[o(f,{icon:"fa-solid fa-filter",class:"mr-1"}),v(" "+i(e.$t("suno.filter.title"))+" ",1),e.activeFilterCount>0?(n(),u("span",Va,i(e.activeFilterCount),1)):c("",!0)]),_:1},8,["class"])]),default:a(()=>[s("div",Sa,[s("div",Ta,[s("div",Aa,i(e.$t("suno.filter.type")),1),o(I,{modelValue:e.filterType,"onUpdate:modelValue":t[1]||(t[1]=L=>e.filterType=L),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.typeAll")),1)]),_:1}),o(C,{value:"vocal"},{default:a(()=>[v(i(e.$t("suno.filter.typeVocal")),1)]),_:1}),o(C,{value:"instrumental"},{default:a(()=>[v(i(e.$t("suno.filter.typeInstrumental")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",Ua,[s("div",Pa,i(e.$t("suno.filter.duration")),1),o(I,{modelValue:e.filterDuration,"onUpdate:modelValue":t[2]||(t[2]=L=>e.filterDuration=L),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.durationAll")),1)]),_:1}),o(C,{value:"short"},{default:a(()=>[v(i(e.$t("suno.filter.durationShort")),1)]),_:1}),o(C,{value:"medium"},{default:a(()=>[v(i(e.$t("suno.filter.durationMedium")),1)]),_:1}),o(C,{value:"long"},{default:a(()=>[v(i(e.$t("suno.filter.durationLong")),1)]),_:1})]),_:1},8,["modelValue"])]),s("div",Ea,[s("div",Ia,i(e.$t("suno.filter.video")),1),o(I,{modelValue:e.filterVideo,"onUpdate:modelValue":t[3]||(t[3]=L=>e.filterVideo=L),size:"small"},{default:a(()=>[o(C,{value:"all"},{default:a(()=>[v(i(e.$t("suno.filter.videoAll")),1)]),_:1}),o(C,{value:"with"},{default:a(()=>[v(i(e.$t("suno.filter.videoWith")),1)]),_:1}),o(C,{value:"without"},{default:a(()=>[v(i(e.$t("suno.filter.videoWithout")),1)]),_:1})]),_:1},8,["modelValue"])]),e.availableModels.length>0?(n(),u("div",La,[s("div",Ra,i(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:a(()=>[o(U,{label:e.$t("suno.filter.modelAll"),value:"all"},null,8,["label"]),(n(!0),u(M,null,D(e.availableModels,L=>(n(),b(U,{key:L,label:L,value:L},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])):c("",!0),s("div",Ma,[o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:a(()=>[v(i(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])])]),_:1})])):c("",!0),e.filteredTasks?.length>0?(n(),b(h,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[5]||(t[5]=L=>e.$emit("reach-top"))},{default:a(()=>[(n(!0),u(M,null,D(e.filteredTasks,(L,se)=>(n(),b(Y,{key:se,"model-value":L,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):e.searchQuery&&e.tasks?.items?.length>0?(n(),u("div",Fa,[s("p",Da,i(e.$t("suno.message.noSearchResults")),1)])):e.activeFilterCount>0&&e.tasks?.items?.length>0?(n(),u("div",za,[s("p",ja,i(e.$t("suno.message.noFilterResults")),1),o(g,{size:"small",text:"",onClick:e.onResetFilters},{default:a(()=>[v(i(e.$t("suno.filter.reset")),1)]),_:1},8,["onClick"])])):e.tasks?.items?.length===0?(n(),u("div",Ga,[o(S)])):c("",!0)],64)),O(s("div",Ba,[o(ae)],512),[[Ee,!!e.$store?.state?.suno?.audio?.object]])],64)}const Na=E(ya,[["render",Oa],["__scopeId","data-v-4ab3f8f2"]]),Ha=A({name:"TaskPreview",components:{IconPicture:Re,ElImage:N,ElAvatar:Je,ElIcon:x},computed:{audio(){return this.$store.state.suno?.audio}}}),Wa={key:0,class:"size-full overflow-hidden"},qa={class:"relative h-[300px]"},Ka={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Qa={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"},Ja={class:"p-4"},Ya={class:"flex items-center font-bold mb-2"},Xa={class:"text-[var(--el-text-color-regular)] mb-2"},Za={class:"text-xs text-[var(--el-text-color-regular)]"},xa={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},el={key:1,class:"w-full h-full"};function tl(e,t,d,r,m,y){const $=l("icon-picture"),p=l("el-icon"),f=l("el-image"),k=l("el-avatar");return e.audio?.object?(n(),u("div",Wa,[s("div",qa,[o(f,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:a(()=>[s("div",Ka,[o(p,{class:"text-3xl"},{default:a(()=>[o($)]),_:1})])]),_:1},8,["src"]),s("h2",Qa,i(e.audio?.title),1)]),s("div",Ja,[s("div",Ya,[o(k,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,i(e.audio?.title),1)]),s("p",Xa,i(e.audio?.style),1),s("p",Za,i(e.$dayjs.format(e.audio?.created_at)),1),s("div",xa,[s("p",null,i(e.audio?.lyric),1)])])])):(n(),u("div",el))}const ol=E(Ha,[["render",tl]]),sl=ke("suno"),nl=A({name:"SunoIndex",components:{Layout:mt,ConfigPanel:Ai,RecentPanel:Na,PreviewPanel:ol},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await Be({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(){Fe.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===De&&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:sl},t=this.credential?.token;if(!t){console.error("no token specified");return}w.info(this.$t("suno.message.startingTask")),Me("suno",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 il(e,t,d,r,m,y){const $=l("config-panel"),p=l("recent-panel"),f=l("preview-panel"),k=l("layout");return n(),b(k,null,{config:a(()=>[o($,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:a(()=>[o(p,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:a(()=>[o(f)]),_:1})}const lr=E(nl,[["render",il],["__scopeId","data-v-933ac61a"]]);export{lr as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as x}from"./index.es-D_RAO8k8.js";import{E as A}from"./index-BR-gl1F1.js";import{E as O}from"./index-Df3ypl4y.js";import{d as h,H as o,E as r,z as C,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{E as m,aw as V}from"./index-CzKRwsO-.js";import{E as U}from"./index-cTO_Q4Fm.js";import{E as N,a as P}from"./index-DOouqP-k.js";import{C as L}from"./Consumption-CYQjCvht.js";import{a as G}from"./price-CvHw6R6n.js";import{E as B,a as D}from"./index-BPdbGHkd.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-DbAdobii.js";import"./use-form-item-DrgRpU-E.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-wVAvEF7Z.js";import"./index-D3HhWsO8.js";import"./index-FE8DaT7K.js";import"./index-yhxo1ekT.js";import"./index-BFvw5Wso.js";import"./strings-beZM2Y-f.js";import"./isEqual-aGnZeYF-.js";import"./_Uint8Array-xB6L_WPD.js";import"./castArray-cUkz0Pa0.js";import"./debounce-Bi-gexp-.js";import"./_baseIteratee-BcMdsGpl.js";import"./index-DNiNc_AV.js";import"./index-QEdjdPo0.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"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[C(e.$slots,"config",{},void 0,!0)]),r("div",J,[C(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(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},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,_,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=m(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,_,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=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},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,_,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=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},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")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,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=m(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:L},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return G(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.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,_,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"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($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"],Ee={class:"flex-1 min-w-0"},Ce={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={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,_,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",Ee,[e.data.type?(t(),o("div",Ce,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(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 ze=m(xe,[["render",Oe]]),Ne=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"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Le={key:0,class:"flex items-center gap-2 mb-1.5"},Ge=["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"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Le,[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,Ge),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",He,[(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,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),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,_,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=m(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"},mt={class:"flex-1 min-w-0"},_t={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,_,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",mt,[r("div",_t,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=m(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"},Et={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Ct={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={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,_,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",Et,a(s.title),1),r("div",Ct,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+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=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Lt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Gt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,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",Lt,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,Gt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["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"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,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",Ht,[(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"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.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,_,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,E=>r("div",{key:E,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<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,(E,F)=>(t(),v(u,{key:F,data:E,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=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,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===T?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,_,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 Ls=m(is,[["render",cs]]);export{Ls as default};
|
|
1
|
+
import{F as x}from"./index.es-CrttZSrc.js";import{E as A}from"./index-D9JVwsd7.js";import{E as O}from"./index-D5nwfcmc.js";import{d as h,H as o,E as r,z as C,C as d,y as k,D as i,q as t,F as a,I,J as c,O as b,N as y,x as v,P as z}from"./vendor-vue-NSDaktjZ.js";import{E as m,aw as V}from"./index-BvxUjFFi.js";import{E as U}from"./index-h56YlOsG.js";import{E as N,a as P}from"./index-DL7cWj7I.js";import{C as L}from"./Consumption-ONDtMvc3.js";import{a as G}from"./price-BkvvXqnE.js";import{E as B,a as D}from"./index-PszTydnx.js";import{b as T}from"./errorCode-Cqj9Td_Z.js";import{E as w}from"./index-D8ijceQe.js";import"./use-form-item-CckYMD9d.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./typescript-B1EqkZTz.js";import"./index-C4KHAdmJ.js";import"./index-DfLSVuzK.js";import"./index-Cfm5TcpA.js";import"./index-7bp5wXd1.js";import"./strings-beZM2Y-f.js";import"./isEqual-D6B5l3d6.js";import"./_Uint8Array-CsLFINqA.js";import"./castArray-7_h4ryCS.js";import"./debounce-DB6zHvwJ.js";import"./_baseIteratee-VzLHbp72.js";import"./index-pNQe1IhV.js";import"./index-BHFLCWId.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"},H={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},J={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function M(e,n,p,_,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",H,[C(e.$slots,"config",{},void 0,!0)]),r("div",J,[C(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(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const W=m(K,[["render",M],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:U},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,_,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=m(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,_,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=m(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:U},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,_,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=m(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:U},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")}}),me={class:"field"},_e={class:"title font-bold"};function fe(e,n,p,_,f,g){const s=i("el-input");return t(),o("div",me,[r("h2",_e,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=m(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:L},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return G(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===V.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,_,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"}),I(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=m($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"],Ee={class:"flex-1 min-w-0"},Ce={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ve={class:"text-xl font-bold mb-1.5"},Ie={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,_,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",Ee,[e.data.type?(t(),o("div",Ce,a(e.data.type),1)):c("",!0),r("h3",Ve,a(e.data.title),1),e.data.description?(t(),o("p",Ie,[I(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 ze=m(xe,[["render",Oe]]),Ne=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"}}}),Pe={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Le={key:0,class:"flex items-center gap-2 mb-1.5"},Ge=["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"},He={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Je=["href"];function Me(e,n,p,_,f,g){return t(),o("div",Pe,[e.displayUrl?(t(),o("div",Le,[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,Ge),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",He,[(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,Je))),128))])):c("",!0)])}const We=m(Ne,[["render",Me]]),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,_,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=m(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"},mt={class:"flex-1 min-w-0"},_t={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,_,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",mt,[r("div",_t,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=m(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"},Et={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Ct={class:"text-xs text-gray-400 mt-1"},Vt={key:0},It={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,_,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",Et,a(s.title),1),r("div",Ct,[s.source?(t(),o("span",Vt,a(s.source),1)):c("",!0),s.date?(t(),o("span",It," · "+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=m(wt,[["render",Ft]]),zt=h({name:"PeopleAlsoAsk",components:{ElCollapse:D,ElCollapseItem:B},props:{data:{type:Array,required:!0}}}),Nt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Pt={class:"text-base font-bold mb-3"},Lt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Gt=["href"];function Bt(e,n,p,_,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Nt,[r("h3",Pt,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",Lt,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,Gt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=m(zt,[["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"},Ht={class:"flex flex-wrap gap-2"},Jt=["onClick"];function Mt(e,n,p,_,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",Ht,[(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"}),I(" "+a(l.query),1)],8,Jt))),128))])])}const Wt=m(Tt,[["render",Mt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:ze,OrganicResult:We,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Wt},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===V.Request},noResults(){return this.$store.state.serp?.status?.search===V.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,_,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,E=>r("div",{key:E,class:"mb-6 animate-pulse"},[...n[0]||(n[0]=[z('<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,(E,F)=>(t(),v(u,{key:F,data:E,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=m(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:W,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===T?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,_,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 Ls=m(is,[["render",cs]]);export{Ls as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as C}from"./index.es-D_RAO8k8.js";import{E as T}from"./index-BR-gl1F1.js";import{E as M}from"./index-Df3ypl4y.js";import{d as w,H as r,E as c,z as L,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as U}from"./vendor-vue-NSDaktjZ.js";import{E as v,b7 as j,cd as B,aw as D,ce as F}from"./index-CzKRwsO-.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-DOouqP-k.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as W,l as H}from"./pagination-CdyGf0kN.js";import{I as J}from"./ImagePreview-D0Ix1-Y-.js";import{E as K}from"./index-QyX7F9WO.js";import{E as V}from"./index-DbAdobii.js";import{E as Q}from"./index-cTO_Q4Fm.js";import{C as X}from"./Consumption-CYQjCvht.js";import{a as Y}from"./price-CvHw6R6n.js";import{b as Z}from"./errorCode-Cqj9Td_Z.js";import{w as x}from"./wan-BBytRfO2.js";import{C as ee}from"./CopyToClipboard-D2bQdRpq.js";import{V as te}from"./VideoPlayer-BZ4kO4gb.js";import{E as oe}from"./index-yhxo1ekT.js";import{E as se}from"./index-Dqenaaf_.js";import{E as ne}from"./index-B6r1zyN0.js";import{B as ae}from"./BotPlaceholder-DB5oDTGl.js";import{N as le}from"./NoTasks-BbVvi52h.js";import"./use-form-item-DrgRpU-E.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-BFvw5Wso.js";import"./typescript-wVAvEF7Z.js";import"./index-D3HhWsO8.js";import"./strings-beZM2Y-f.js";import"./isEqual-aGnZeYF-.js";import"./_Uint8Array-xB6L_WPD.js";import"./castArray-cUkz0Pa0.js";import"./debounce-Bi-gexp-.js";import"./_baseIteratee-BcMdsGpl.js";import"./index-DNiNc_AV.js";import"./index-Ip3EnZNv.js";import"./_baseClone-glhf4o0G.js";import"./_initCloneObject-BLwDPMHn.js";import"./index-FE8DaT7K.js";import"./vue-plyr-BO2nlN4c.js";import"./index-CsbAGhC9.js";const re=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ie={class:"main flex flex-row flex-1"},ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},de={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ue(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",ie,[c("div",ce,[L(e.$slots,"config",{},void 0,!0)]),c("div",de,[L(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=v(re,[["render",ue],["__scopeId","data-v-98681d9b"]]),me=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},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=N)}}),fe={class:"field"},he={class:"title font-bold"},_e={class:"float-left"};function ge(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",fe,[c("h2",he,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",_e,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const $e=v(me,[["render",ge],["__scopeId","data-v-eb090beb"]]),we="720p",ve=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},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=we)}}),be={class:"field"},ke={class:"title font-bold"},ye={class:"float-left"};function Ve(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",be,[c("h2",ke,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ye,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=v(ve,[["render",Ve],["__scopeId","data-v-3e39f44e"]]),Ie=5,Te=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},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=Ie)}}),Se={class:"field"},Ue={class:"title font-bold"},Le={class:"float-left"};function Ce(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Se,[c("h2",Ue,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=v(Te,[["render",Ce],["__scopeId","data-v-5f35a2cf"]]),Ge=w({name:"ImageUrlInput",components:{ElUpload:K,ElButton:T,InfoIcon:P,ImagePreview:J},mixins:[z],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.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()}}}),Ae={class:"relative"},De={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},Me={class:"text-sm font-bold"};function Oe(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ae,[c("div",De,[c("div",Pe,[c("span",Me,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":n[0]||(n[0]=i=>e.fileList=i),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:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=v(Ge,[["render",Oe],["__scopeId","data-v-c9ebe1b1"]]),Be="",Fe=w({name:"PromptInput",components:{ElInput:Q,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=Be)}}),Ne={class:"field"},qe={class:"box"},ze={class:"title font-bold"};function We(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Ne,[c("div",qe,[c("h2",ze,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":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const He=v(Fe,[["render",We],["__scopeId","data-v-45557a2d"]]),Je=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:He,ImageUrlInput:je,ModelSelector:$e,ResolutionSelector:Ee,DurationSelector:Re,Consumption:X},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Y(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")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Ke,[c("div",Qe,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Xe,[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(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ze=v(Je,[["render",Ye]]),xe=w({name:"TaskPreview",components:{ElImage:ne,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:se,VideoPlayer:te,ElTooltip:oe,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},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")}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},nt={class:"datetime"},at={class:"info"},lt={key:0,class:"prompt mt-2"},rt={key:0},it={key:1},ct={key:0,class:U({content:!0,failed:!0})},dt={key:0,class:"mb-4"},ut={key:1,class:U({operations:!0,"mt-2":!0})},pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:U({content:!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},vt={key:2,class:U({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function kt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",et,[c("div",tt,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",ot,[c("div",st,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",nt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",at,[e.modelValue?.request?.prompt?(s(),r("p",lt,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",rt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",it," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",ct,[e.modelValue?.response?.video_url?(s(),r("div",dt,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",ut,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",pt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",mt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ft,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ht,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",_t,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",gt,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",$t,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",wt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+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?(s(),r("div",vt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",bt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const yt=v(xe,[["render",kt],["__scopeId","data-v-6d1d636e"]]),Vt=w({name:"RecentPanel",components:{TaskPreview:yt,BotPlaceholder:ae,NoTasks:le,ScrollList:W},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?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(g)])):m("",!0)],64)}const St=v(Vt,[["render",Tt]]),Ut=F("wan"),Lt=w({name:"WanIndex",components:{ConfigPanel:Ze,Layout:pe,RecentPanel:St},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,n){e?.items?.length>n?.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 H({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:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",x.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===Z?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 Ct(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,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 Vo=v(Lt,[["render",Ct]]);export{Vo as default};
|
|
1
|
+
import{F as C}from"./index.es-CrttZSrc.js";import{E as T}from"./index-D9JVwsd7.js";import{E as M}from"./index-D5nwfcmc.js";import{d as w,H as r,E as c,z as L,C as t,y as d,D as o,q as s,F as l,O as I,N as S,x as $,I as f,J as m,M as O,Q as U}from"./vendor-vue-NSDaktjZ.js";import{E as v,b7 as j,cd as B,aw as D,ce as F}from"./index-BvxUjFFi.js";import{a as N,b as q}from"./wan-DKq-jYOo.js";import{E as R,a as G}from"./index-DL7cWj7I.js";import{p as z}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as W,l as H}from"./pagination-BkDK8QUo.js";import{I as J}from"./ImagePreview-B7TB9R4K.js";import{E as K}from"./index-BUiuY-GV.js";import{E as V}from"./index-D8ijceQe.js";import{E as Q}from"./index-h56YlOsG.js";import{C as X}from"./Consumption-ONDtMvc3.js";import{a as Y}from"./price-BkvvXqnE.js";import{b as Z}from"./errorCode-Cqj9Td_Z.js";import{w as x}from"./wan-C96nuIaJ.js";import{C as ee}from"./CopyToClipboard-BMP80HB1.js";import{V as te}from"./VideoPlayer-CiCUB_ln.js";import{E as oe}from"./index-Cfm5TcpA.js";import{E as se}from"./index-eEBfkKER.js";import{E as ne}from"./index-HJTUt22_.js";import{B as ae}from"./BotPlaceholder-Dm4otfD4.js";import{N as le}from"./NoTasks-B-8kqwJZ.js";import"./use-form-item-CckYMD9d.js";import"./index-BuyEbX8F.js";import"./vendor-axios-B8_nURbH.js";import"./vendor-dayjs-v0j1UNZp.js";import"./vendor-vue-router-Kg6s1a65.js";import"./index-7bp5wXd1.js";import"./typescript-B1EqkZTz.js";import"./index-C4KHAdmJ.js";import"./strings-beZM2Y-f.js";import"./isEqual-D6B5l3d6.js";import"./_Uint8Array-CsLFINqA.js";import"./castArray-7_h4ryCS.js";import"./debounce-DB6zHvwJ.js";import"./_baseIteratee-VzLHbp72.js";import"./index-pNQe1IhV.js";import"./index-CnqGlxcN.js";import"./_baseClone-C8MQPABx.js";import"./_initCloneObject-ULQkxMrA.js";import"./index-DfLSVuzK.js";import"./vue-plyr-BO2nlN4c.js";import"./index-CiolqKNE.js";const re=w({name:"LayoutWan",components:{ElDrawer:M,ElButton:T,FontAwesomeIcon:C},data(){return{drawer:!1}}}),ie={class:"main flex flex-row flex-1"},ce={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},de={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ue(e,n,h,_,b,k){const u=o("font-awesome-icon"),p=o("el-button"),a=o("el-drawer");return s(),r("div",ie,[c("div",ce,[L(e.$slots,"config",{},void 0,!0)]),c("div",de,[L(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:n[0]||(n[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[L(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=v(re,[["render",ue],["__scopeId","data-v-98681d9b"]]),me=w({name:"ModelSelector",components:{ElSelect:G,ElOption:R},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=N)}}),fe={class:"field"},he={class:"title font-bold"},_e={class:"float-left"};function ge(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",fe,[c("h2",he,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",_e,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const $e=v(me,[["render",ge],["__scopeId","data-v-eb090beb"]]),we="720p",ve=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:R},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=we)}}),be={class:"field"},ke={class:"title font-bold"},ye={class:"float-left"};function Ve(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",be,[c("h2",ke,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",ye,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ee=v(ve,[["render",Ve],["__scopeId","data-v-3e39f44e"]]),Ie=5,Te=w({name:"DurationSelector",components:{ElSelect:G,ElOption:R},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=Ie)}}),Se={class:"field"},Ue={class:"title font-bold"},Le={class:"float-left"};function Ce(e,n,h,_,b,k){const u=o("el-option"),p=o("el-select");return s(),r("div",Se,[c("h2",Ue,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=a=>e.value=a),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(s(!0),r(I,null,S(e.options,a=>(s(),$(u,{key:a.value,label:a.label,value:a.value},{default:d(()=>[c("span",Le,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Re=v(Te,[["render",Ce],["__scopeId","data-v-5f35a2cf"]]),Ge=w({name:"ImageUrlInput",components:{ElUpload:K,ElButton:T,InfoIcon:P,ImagePreview:J},mixins:[z],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.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()}}}),Ae={class:"relative"},De={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},Me={class:"text-sm font-bold"};function Oe(e,n,h,_,b,k){const u=o("info-icon"),p=o("image-preview"),a=o("el-button"),g=o("el-upload");return s(),r("div",Ae,[c("div",De,[c("div",Pe,[c("span",Me,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":n[0]||(n[0]=i=>e.fileList=i),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:i})=>[i.url&&i.percentage!==void 0?(s(),$(p,{key:0,url:i.url,name:i.name,percentage:i.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(i),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(a,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[f(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const je=v(Ge,[["render",Oe],["__scopeId","data-v-c9ebe1b1"]]),Be="",Fe=w({name:"PromptInput",components:{ElInput:Q,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=Be)}}),Ne={class:"field"},qe={class:"box"},ze={class:"title font-bold"};function We(e,n,h,_,b,k){const u=o("info-icon"),p=o("el-input");return s(),r("div",Ne,[c("div",qe,[c("h2",ze,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":n[0]||(n[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const He=v(Fe,[["render",We],["__scopeId","data-v-45557a2d"]]),Je=w({name:"PresetPanel",components:{ElButton:T,FontAwesomeIcon:C,PromptInput:He,ImageUrlInput:je,ModelSelector:$e,ResolutionSelector:Ee,DurationSelector:Re,Consumption:X},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return Y(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")}}}),Ke={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-5"},Xe={class:"flex flex-col items-center justify-center px-5 pb-5"};function Ye(e,n,h,_,b,k){const u=o("prompt-input"),p=o("model-selector"),a=o("resolution-selector"),g=o("duration-selector"),i=o("image-url-input"),y=o("consumption"),E=o("font-awesome-icon"),A=o("el-button");return s(),r("div",Ke,[c("div",Qe,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(s(),$(a,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(s(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(s(),$(i,{key:2,class:"mb-2"})):m("",!0)]),c("div",Xe,[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(E,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Ze=v(Je,[["render",Ye]]),xe=w({name:"TaskPreview",components:{ElImage:ne,CopyToClipboard:ee,FontAwesomeIcon:C,ElAlert:se,VideoPlayer:te,ElTooltip:oe,ElButton:T},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:q}},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")}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},nt={class:"datetime"},at={class:"info"},lt={key:0,class:"prompt mt-2"},rt={key:0},it={key:1},ct={key:0,class:U({content:!0,failed:!0})},dt={key:0,class:"mb-4"},ut={key:1,class:U({operations:!0,"mt-2":!0})},pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ht={key:1,class:U({content:!0})},_t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},vt={key:2,class:U({content:!0})},bt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function kt(e,n,h,_,b,k){const u=o("el-image"),p=o("video-player"),a=o("el-button"),g=o("el-tooltip"),i=o("font-awesome-icon"),y=o("copy-to-clipboard"),E=o("el-alert");return s(),r("div",et,[c("div",tt,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),c("div",ot,[c("div",st,[f(l(e.$t("wan.name.wanBot"))+" ",1),c("span",nt,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",at,[e.modelValue?.request?.prompt?(s(),r("p",lt,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(s(),r("span",rt," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(s(),r("span",it," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(s(),r("div",ct,[e.modelValue?.response?.video_url?(s(),r("div",dt,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(s(),r("div",ut,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(a,{type:"info",size:"small",class:"mb-2",onClick:n[0]||(n[0]=O(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[f(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(s(),r("p",pt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),c("p",mt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",ft,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0)]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(s(),r("div",ht,[t(E,{closable:!1,class:"failure"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",_t,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),c("p",gt,[t(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.elapsed?(s(),r("p",$t,[t(i,{icon:"fa-solid fa-clock",class:"mr-1"}),f(" "+l(e.$t("wan.name.elapsed"))+": "+l(e.modelValue?.elapsed?.toFixed(2))+"s ",1)])):m("",!0),c("p",wt,[t(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+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?(s(),r("div",vt,[t(E,{closable:!1,class:"info"},{template:d(()=>[t(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[c("p",bt,[t(i,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const yt=v(xe,[["render",kt],["__scopeId","data-v-6d1d636e"]]),Vt=w({name:"RecentPanel",components:{TaskPreview:yt,BotPlaceholder:ae,NoTasks:le,ScrollList:W},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?.()}}}),Et={key:0},It={key:2,class:"w-full h-full flex items-center justify-center"};function Tt(e,n,h,_,b,k){const u=o("bot-placeholder"),p=o("task-preview"),a=o("scroll-list"),g=o("no-tasks");return s(),r(I,null,[e.tasks?.items===void 0?(s(),r("div",Et,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),$(a,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:n[0]||(n[0]=i=>e.$emit("reach-top"))},{default:d(()=>[(s(!0),r(I,null,S(e.tasks?.items,i=>(s(),$(p,{key:i.id,"model-value":i},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(s(),r("div",It,[t(g)])):m("",!0)],64)}const St=v(Vt,[["render",Tt]]),Ut=F("wan"),Lt=w({name:"WanIndex",components:{ConfigPanel:Ze,Layout:pe,RecentPanel:St},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,n){e?.items?.length>n?.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 H({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:n=5,createdAtMin:h,createdAtMax:_}=e||{};console.debug("limit",n,"createdAtMin",h,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:n,createdAtMin:h,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},n=this.credential?.token;if(!n){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),B("wan",x.generate(e,{token:n})).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(h=>{h?.response?.data?.error?.code===Z?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 Ct(e,n,h,_,b,k){const u=o("config-panel"),p=o("recent-panel"),a=o("layout");return s(),$(a,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 Vo=v(Lt,[["render",Ct]]);export{Vo as default};
|