@acedatacloud/nexior 3.34.0 → 3.34.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -6
- package/dist/assets/{Auth-BvEs7Q0k.js → Auth-BR7AQdFb.js} +1 -1
- package/dist/assets/{BotPlaceholder-B9PiWkYP.js → BotPlaceholder-CcWrwFmL.js} +1 -1
- package/dist/assets/{Callback-DKGpAmET.js → Callback-xXjmMOcU.js} +1 -1
- package/dist/assets/{Console-xOnM8DpL.js → Console-nj_hwu1u.js} +1 -1
- package/dist/assets/{Consumption-Cm2ejYcw.js → Consumption-DB4jsCIw.js} +1 -1
- package/dist/assets/Conversation-BhCBL3G3.css +1 -0
- package/dist/assets/Conversation-CiAYoNDT.js +23 -0
- package/dist/assets/{CopyToClipboard-GAgRsNeg.js → CopyToClipboard-DY-UF17o.js} +1 -1
- package/dist/assets/{Detail-DMagTbtC.js → Detail-Ja14bXDU.js} +2 -2
- package/dist/assets/{EditArray-CrHy6Iy7.js → EditArray-BFLjz-wW.js} +1 -1
- package/dist/assets/{Extra-k24GQBOd.css → Extra-C7QpOEzU.css} +1 -1
- package/dist/assets/Extra-Clq8boad.js +1 -0
- package/dist/assets/{FilePreview-BmW4SAVX.js → FilePreview-xVo0BsJp.js} +1 -1
- package/dist/assets/{History-B73xllIr.js → History-Do3SJVGQ.js} +1 -1
- package/dist/assets/{ImagePreview-A6UtflgQ.js → ImagePreview-eVaabJZn.js} +1 -1
- package/dist/assets/{ImageWrapper-CbJ9r_BN.js → ImageWrapper-BPES620_.js} +1 -1
- package/dist/assets/{Index-BW-_BYnl.css → Index-AE8zHRaI.css} +1 -1
- package/dist/assets/Index-B6QAUsOF.js +1 -0
- package/dist/assets/{Index-Bz6bW7YJ.css → Index-B6zzHZBJ.css} +1 -1
- package/dist/assets/{Index-MnuYBCdp.js → Index-BA5k_6bJ.js} +1 -1
- package/dist/assets/Index-BGwx8RuY.js +1 -0
- package/dist/assets/{Index-DPimbIIm.css → Index-BI75bQ5K.css} +1 -1
- package/dist/assets/Index-BU9oZ6JY.js +1 -0
- package/dist/assets/{Index-DVjZJUf3.css → Index-BWcq7tEj.css} +1 -1
- package/dist/assets/{Index-BWgyCRzd.js → Index-B_SMVoYZ.js} +1 -1
- package/dist/assets/{Index-DgKMWHlo.js → Index-Be0Zf-VK.js} +1 -1
- package/dist/assets/Index-BiCUVNeM.css +1 -0
- package/dist/assets/Index-BipMjUVy.js +1 -0
- package/dist/assets/Index-Bnsr9aoW.js +1 -0
- package/dist/assets/{Index-XbDGckcR.js → Index-BoI2jXTx.js} +1 -1
- package/dist/assets/{Index-DFl04-mQ.css → Index-BrSZra1u.css} +1 -1
- package/dist/assets/Index-BtuiXvN8.js +1 -0
- package/dist/assets/Index-Bv3aPtGw.js +1 -0
- package/dist/assets/{Index-C33PLD2u.css → Index-C0juYDGI.css} +1 -1
- package/dist/assets/{Index-BO47behT.js → Index-C7lBym9k.js} +1 -1
- package/dist/assets/{Index-DAaSduP5.css → Index-C9xKbtsc.css} +1 -1
- package/dist/assets/{Index-BIUOeyck.css → Index-CN1ddowY.css} +1 -1
- package/dist/assets/{Index-BCe23UNg.css → Index-CST3Vr3w.css} +1 -1
- package/dist/assets/{Index-RQ-d-Ybg.css → Index-CTnAfcwW.css} +1 -1
- package/dist/assets/Index-CgZ6CMgQ.css +1 -0
- package/dist/assets/Index-CwPif7U2.js +1 -0
- package/dist/assets/Index-D27OMdID.js +1 -0
- package/dist/assets/{Index-BBlk3V6J.css → Index-DGqf994l.css} +1 -1
- package/dist/assets/Index-DPCPO7cj.js +1 -0
- package/dist/assets/{Index-BdIxKD_Z.css → Index-DPVlQRDk.css} +1 -1
- package/dist/assets/{Index-CRpLasEm.js → Index-DS9xL4zc.js} +1 -1
- package/dist/assets/Index-DT-Iu1eV.js +1 -0
- package/dist/assets/Index-DWgoBNcF.js +1 -0
- package/dist/assets/{Index-DhttMrBW.js → Index-DpR3wEnE.js} +1 -1
- package/dist/assets/Index-Dq4ojYPG.js +1 -0
- package/dist/assets/Index-DqZLjJG6.js +1 -0
- package/dist/assets/Index-DyFEHsky.js +1 -0
- package/dist/assets/{Index-D4QYWsyj.css → Index-E0MNopju.css} +1 -1
- package/dist/assets/Index-JUELlnZe.css +1 -0
- package/dist/assets/{Index-KSQ5C-eY.css → Index-_JA55NiP.css} +1 -1
- package/dist/assets/Index-edVjS9Fq.js +1 -0
- package/dist/assets/{Index-Cet6Icjx.js → Index-mq2BOvvk.js} +1 -1
- package/dist/assets/Index-wsSUi0hI.css +1 -0
- package/dist/assets/{Index-Ct_ncjNQ.css → Index-x9mhTmun.css} +1 -1
- package/dist/assets/{Invitees-Dqat0sAc.js → Invitees-BFkwxUqa.js} +1 -1
- package/dist/assets/{List-k7Nal7bD.js → List-BGUJQ1_j.js} +1 -1
- package/dist/assets/{List-BNyKYGRn.js → List-Br3Pd6pi.js} +1 -1
- package/dist/assets/{List-D9f2PoNM.js → List-C-kCE03H.js} +1 -1
- package/dist/assets/Main-AkuYy9g7.css +1 -0
- package/dist/assets/{Main-DrjY6LqS.js → Main-BYUMd6qO.js} +1 -1
- package/dist/assets/{Navigator-2sFcVlDt.css → Navigator-Br1lpEYH.css} +1 -1
- package/dist/assets/Navigator-qudQv6Ew.js +1 -0
- package/dist/assets/{NoTasks-BkpMkp7w.js → NoTasks-Dk7Wt2AG.js} +1 -1
- package/dist/assets/OAuthCallback-8_rUp3M5.js +1 -0
- package/dist/assets/OAuthCallback-C9p1KhIU.css +1 -0
- package/dist/assets/{Pagination-B0AQa93-.js → Pagination-CfUAmnFo.js} +1 -1
- package/dist/assets/{ScrollList-CEdyl3y1.js → ScrollList-ZiMJkMBw.js} +1 -1
- package/dist/assets/{Status-Cpwj-Kjk.js → Status-KsOIucfx.js} +1 -1
- package/dist/assets/{Subscribe-BofzTKE_.js → Subscribe-De8de3Zo.js} +1 -1
- package/dist/assets/{TransportWebHID-DH-gA-7y.js → TransportWebHID-CdbyD8Nb.js} +1 -1
- package/dist/assets/{VideoPlayer-D3fPKGi8.js → VideoPlayer-DCxEj90A.js} +1 -1
- package/dist/assets/{avatar-Badm2eJ8.css → avatar-B3bcsy-o.css} +1 -1
- package/dist/assets/avatar-DhwSCd0o.js +1 -0
- package/dist/assets/{bignumber-C3CdKsRA.js → bignumber-qGuqSDbJ.js} +1 -1
- package/dist/assets/chat-80AFwtrY.js +1 -0
- package/dist/assets/chat-B0EMHVmg.js +1 -0
- package/dist/assets/chat-B1ri2YS-.js +1 -0
- package/dist/assets/chat-BEG2rE4I.js +1 -0
- package/dist/assets/chat-BXJ3jqVy.js +1 -0
- package/dist/assets/chat-BaWj6GkR.js +1 -0
- package/dist/assets/chat-Bf12ZxKk.js +1 -0
- package/dist/assets/chat-BidGEZdJ.js +1 -0
- package/dist/assets/chat-D3K6Y0Ze.js +1 -0
- package/dist/assets/chat-DXXgxmOm.js +1 -0
- package/dist/assets/chat-DXswCZ1D.js +1 -0
- package/dist/assets/chat-Dar25ncu.js +1 -0
- package/dist/assets/chat-DmuJNSxr.js +1 -0
- package/dist/assets/chat-DnUQVRpG.js +1 -0
- package/dist/assets/chat-kZ9fn-6R.js +1 -0
- package/dist/assets/chat-oy7Jsokj.js +1 -0
- package/dist/assets/chat-sJzMIYHr.js +1 -0
- package/dist/assets/chat-v2q-hWqX.js +1 -0
- package/dist/assets/common-5IW7PeCP.js +1 -0
- package/dist/assets/common-B8aG7Efa.js +1 -0
- package/dist/assets/common-BDh_3lNX.js +1 -0
- package/dist/assets/common-BEohz6cI.js +1 -0
- package/dist/assets/common-BFxVXE09.js +1 -0
- package/dist/assets/common-BTySlNze.js +1 -0
- package/dist/assets/common-BcnkXUqu.js +1 -0
- package/dist/assets/common-BgTIujtM.js +1 -0
- package/dist/assets/common-Bq5HdznI.js +1 -0
- package/dist/assets/{common-BJNxAXe8.js → common-Bty1Uj-r.js} +1 -1
- package/dist/assets/common-CLoNat-F.js +1 -0
- package/dist/assets/{common-BXAb_-Gq.js → common-CS9Ce9sH.js} +1 -1
- package/dist/assets/common-CuzSNb1o.js +1 -0
- package/dist/assets/common-DNZ7FSIr.js +1 -0
- package/dist/assets/common-DZgzSeWK.js +1 -0
- package/dist/assets/common-KnJh6qYN.js +1 -0
- package/dist/assets/common-qDu_zKFN.js +1 -0
- package/dist/assets/common-qTcriPbI.js +1 -0
- package/dist/assets/{distribution-e-6o6rdz.js → distribution-ClKMo0TJ.js} +1 -1
- package/dist/assets/{index-CE0qVX1R.js → index-0JZkSLcy.js} +1 -1
- package/dist/assets/{index-BphznM2U.js → index-BK4USX41.js} +1 -1
- package/dist/assets/{index-BrsKOucX.js → index-Bw6POElb.js} +1 -1
- package/dist/assets/{index-CAWi0GM8.css → index-BwUy-mpm.css} +1 -1
- package/dist/assets/{index-CyABBw6Y.js → index-D3HoJv4E.js} +1 -1
- package/dist/assets/{index-CMvUk9K5.js → index-DzuxpefT.js} +1 -1
- package/dist/assets/{index-D39FXg35.js → index-MSQW00oH.js} +1 -1
- package/dist/assets/index-muIEJvsu.js +614 -0
- package/dist/assets/{index-DhvpyDk4.js → index-ssOK1z8u.js} +1 -1
- package/dist/assets/{index.es-BBc1fFr1.js → index.es-Bqj83sQx.js} +1 -1
- package/dist/assets/kling-B6b0DmUc.js +1 -0
- package/dist/assets/kling-BE_aXo1J.js +1 -0
- package/dist/assets/kling-BMWIhQuA.js +1 -0
- package/dist/assets/kling-BaAWVbDH.js +1 -0
- package/dist/assets/kling-BuHKehNx.js +1 -0
- package/dist/assets/kling-C65LvmjS.js +1 -0
- package/dist/assets/kling-CWyudQ3n.js +1 -0
- package/dist/assets/kling-CaMEurxg.js +1 -0
- package/dist/assets/kling-Cj_wOXCf.js +1 -0
- package/dist/assets/kling-D0OSJXMQ.js +1 -0
- package/dist/assets/kling-D6pfPTeB.js +1 -0
- package/dist/assets/kling-DDhQlsis.js +1 -0
- package/dist/assets/kling-DHI7cuFc.js +1 -0
- package/dist/assets/kling-DRUdzQlN.js +1 -0
- package/dist/assets/kling-HuUm_n8B.js +1 -0
- package/dist/assets/kling-N_yDawUo.js +1 -0
- package/dist/assets/kling-aFiCfBR9.js +1 -0
- package/dist/assets/openaiimage-9Pv9ZOh9.js +1 -0
- package/dist/assets/openaiimage-BhqHReys.js +1 -0
- package/dist/assets/openaiimage-C2ikiCjF.js +1 -0
- package/dist/assets/openaiimage-CDNGeKnN.js +1 -0
- package/dist/assets/openaiimage-Ck83DPD4.js +1 -0
- package/dist/assets/openaiimage-Cr2b4bnz.js +1 -0
- package/dist/assets/openaiimage-D4ZQ9H2P.js +1 -0
- package/dist/assets/openaiimage-DVt5QnkZ.js +1 -0
- package/dist/assets/openaiimage-Dc0PpAMi.js +1 -0
- package/dist/assets/openaiimage-DqQiSZkl.js +1 -0
- package/dist/assets/openaiimage-DxVjGoRJ.js +1 -0
- package/dist/assets/openaiimage-EBXgRKqk.js +1 -0
- package/dist/assets/openaiimage-Gyhq5GfC.js +1 -0
- package/dist/assets/openaiimage-U__IyTyu.js +1 -0
- package/dist/assets/openaiimage-_4KlfJS9.js +1 -0
- package/dist/assets/openaiimage-aV1W966B.js +1 -0
- package/dist/assets/openaiimage-qrivkUi4.js +1 -0
- package/dist/assets/openaiimage-wWv12M5V.js +1 -0
- package/dist/assets/order-D4zdmHv8.js +1 -0
- package/dist/assets/pasteUploadMixin-BurWbGNQ.js +1 -0
- package/dist/assets/{price-uWkViTYj.js → price-Bva0CFLK.js} +1 -1
- package/dist/assets/site-B3keLIGN.js +1 -0
- package/dist/assets/site-BGwTb3tg.js +1 -0
- package/dist/assets/site-BMMKRHYh.js +1 -0
- package/dist/assets/site-BNS7HSkL.js +1 -0
- package/dist/assets/site-BTQuwc8k.js +1 -0
- package/dist/assets/site-Bf90NcZQ.js +1 -0
- package/dist/assets/site-Bkzgxs4F.js +1 -0
- package/dist/assets/site-BrHPCjO2.js +1 -0
- package/dist/assets/site-CA9uoj5i.js +1 -0
- package/dist/assets/site-CFgsatHq.js +1 -0
- package/dist/assets/site-Clxxx0VZ.js +1 -0
- package/dist/assets/site-CqC1Zlqo.js +1 -0
- package/dist/assets/site-D40YGJZV.js +1 -0
- package/dist/assets/site-D_8t7eNb.js +1 -0
- package/dist/assets/site-DkDsbOeT.js +1 -0
- package/dist/assets/site-DyZsn9NS.js +1 -0
- package/dist/assets/site-fw5D75Dx.js +1 -0
- package/dist/assets/site-qBXenR-u.js +1 -0
- package/dist/assets/{solana-wallets-B4qhAZvS.js → solana-wallets-nnfzRTGt.js} +2 -2
- package/dist/assets/{solanaEmbed.esm-CdBg48KL.js → solanaEmbed.esm-MqSs0vxC.js} +1 -1
- package/dist/assets/{string_decoder-CTh9Dc0K.js → string_decoder-BUnST7cI.js} +1 -1
- package/dist/assets/{vendor-element-plus-D_edKQou.js → vendor-element-plus-DN048TGi.js} +7 -7
- package/dist/assets/{vendor-web3-DjQkXVgW.js → vendor-web3-CIJ0oOq5.js} +4 -4
- package/dist/assets/{web-Cy5allfw.js → web-COanpFvz.js} +1 -1
- package/dist/assets/{web-BysK0smP.js → web-wXYMF4s3.js} +1 -1
- package/dist/index.html +4 -4
- package/package.json +2 -2
- package/dist/assets/Conversation-BZ7BGIYq.css +0 -1
- package/dist/assets/Conversation-DN18fER4.js +0 -23
- package/dist/assets/Extra-B4l6imdF.js +0 -1
- package/dist/assets/Index-B5VBxUhU.js +0 -1
- package/dist/assets/Index-BDaawPtT.css +0 -1
- package/dist/assets/Index-BJd3HbIa.js +0 -1
- package/dist/assets/Index-BTBNmOS3.js +0 -1
- package/dist/assets/Index-BcUqDqOp.css +0 -1
- package/dist/assets/Index-BguxD6dJ.js +0 -1
- package/dist/assets/Index-Bv6SFmLr.js +0 -1
- package/dist/assets/Index-C2LnA1x8.js +0 -1
- package/dist/assets/Index-C8LKEFN5.js +0 -1
- package/dist/assets/Index-CA7W0amY.css +0 -1
- package/dist/assets/Index-CSYtEWyE.js +0 -1
- package/dist/assets/Index-CgWdEqOu.js +0 -1
- package/dist/assets/Index-Cp1tLplM.js +0 -1
- package/dist/assets/Index-D05wqgk9.js +0 -1
- package/dist/assets/Index-D9pkv0sb.js +0 -1
- package/dist/assets/Index-DBwnH-pa.js +0 -1
- package/dist/assets/Index-DqDcXT9g.js +0 -1
- package/dist/assets/Index-h_usumlg.js +0 -1
- package/dist/assets/Main-DvbrFf7p.css +0 -1
- package/dist/assets/Navigator-Diyiaq_1.js +0 -1
- package/dist/assets/OAuthCallback-BWkdV6eG.css +0 -1
- package/dist/assets/OAuthCallback-Czg4ouIk.js +0 -1
- package/dist/assets/avatar-7CZrtbXj.js +0 -1
- package/dist/assets/chat-36Wd9kCM.js +0 -1
- package/dist/assets/chat-B39KXzrD.js +0 -1
- package/dist/assets/chat-B9GFfq6l.js +0 -1
- package/dist/assets/chat-BP0vp1hS.js +0 -1
- package/dist/assets/chat-BUuoch9a.js +0 -1
- package/dist/assets/chat-Bdxwx51q.js +0 -1
- package/dist/assets/chat-Bs3Bk2qR.js +0 -1
- package/dist/assets/chat-BtVPpVG8.js +0 -1
- package/dist/assets/chat-CYuAOXUc.js +0 -1
- package/dist/assets/chat-CaNGAB_U.js +0 -1
- package/dist/assets/chat-CaglwxV_.js +0 -1
- package/dist/assets/chat-CdFmMCUI.js +0 -1
- package/dist/assets/chat-DO3dMJYr.js +0 -1
- package/dist/assets/chat-Ddqk8Lnr.js +0 -1
- package/dist/assets/chat-DesutEQQ.js +0 -1
- package/dist/assets/chat-USPx71Wl.js +0 -1
- package/dist/assets/chat-gTHZCtxN.js +0 -1
- package/dist/assets/chat-uoqfg29X.js +0 -1
- package/dist/assets/common-3MfGVZdE.js +0 -1
- package/dist/assets/common-9W8gUcW9.js +0 -1
- package/dist/assets/common-BCjqZaHj.js +0 -1
- package/dist/assets/common-BMJtYvw9.js +0 -1
- package/dist/assets/common-BR5nfo_r.js +0 -1
- package/dist/assets/common-BksGkZkP.js +0 -1
- package/dist/assets/common-BotofnUU.js +0 -1
- package/dist/assets/common-C9ZuJQeF.js +0 -1
- package/dist/assets/common-CN-gnGBL.js +0 -1
- package/dist/assets/common-CT9dotYo.js +0 -1
- package/dist/assets/common-ChUs3jEt.js +0 -1
- package/dist/assets/common-DaGZP6Jh.js +0 -1
- package/dist/assets/common-DfLoTf-Q.js +0 -1
- package/dist/assets/common-NLzv6EKV.js +0 -1
- package/dist/assets/common-mkBqIsZ_.js +0 -1
- package/dist/assets/common-sWbklLkg.js +0 -1
- package/dist/assets/index-D3NEBeO5.js +0 -613
- package/dist/assets/kling-B07sbbVW.js +0 -1
- package/dist/assets/kling-B6rS1JgY.js +0 -1
- package/dist/assets/kling-B8jW8y5o.js +0 -1
- package/dist/assets/kling-BDHqGJwD.js +0 -1
- package/dist/assets/kling-BqxLrLWb.js +0 -1
- package/dist/assets/kling-BrSZS3Qu.js +0 -1
- package/dist/assets/kling-BtRgWSHy.js +0 -1
- package/dist/assets/kling-C3mYdPfU.js +0 -1
- package/dist/assets/kling-CCyNvH2U.js +0 -1
- package/dist/assets/kling-CUgtvq0o.js +0 -1
- package/dist/assets/kling-Cd524tuS.js +0 -1
- package/dist/assets/kling-DYHL8EzB.js +0 -1
- package/dist/assets/kling-DhB0gSwQ.js +0 -1
- package/dist/assets/kling-FOjKz7Bi.js +0 -1
- package/dist/assets/kling-PaK_AdvE.js +0 -1
- package/dist/assets/kling-XH0vGtRO.js +0 -1
- package/dist/assets/kling-buSi-PBK.js +0 -1
- package/dist/assets/order-ZqAxDAx1.js +0 -1
- package/dist/assets/site-6Qp0zGU_.js +0 -1
- package/dist/assets/site-B0L6h8jZ.js +0 -1
- package/dist/assets/site-B8H4rDw4.js +0 -1
- package/dist/assets/site-CMFzjRS5.js +0 -1
- package/dist/assets/site-CStmXlP9.js +0 -1
- package/dist/assets/site-Cgec_eAl.js +0 -1
- package/dist/assets/site-Cu8FD5El.js +0 -1
- package/dist/assets/site-CwAvUBLT.js +0 -1
- package/dist/assets/site-D5XZIjnc.js +0 -1
- package/dist/assets/site-DDeF5JE3.js +0 -1
- package/dist/assets/site-DQ3jSwJW.js +0 -1
- package/dist/assets/site-DUMf-vO2.js +0 -1
- package/dist/assets/site-DVOIWtUr.js +0 -1
- package/dist/assets/site-DWR6Iv3p.js +0 -1
- package/dist/assets/site-DzvtRwOx.js +0 -1
- package/dist/assets/site-iZCz8jo0.js +0 -1
- package/dist/assets/site-vMkeV379.js +0 -1
- package/dist/assets/site-z_pYrTYK.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as D}from"./index.es-BBc1fFr1.js";import{m as N,W as ue,k as ce,O as de,P as pe,F as Y,G as Z,u as me,w as b,t as z,a5 as x,a6 as ee,Z as W,e as Q,j as L,_ as te,a7 as fe,a8 as he,l as _e,f as ge,g as $e,h as ve,q as ye,r as ke,L as be,a1 as we,a9 as Ce,aa as Ve}from"./vendor-element-plus-D_edKQou.js";import{d as C,C as c,G as s,T as o,E as K,K as r,ai as i,D as n,O as d,R as a,S as M,ag as J,J as y,Q as w,L as F,aq as j,X as U,c as G,u as T,w as Se,U as Ae}from"./vendor-vue-BhXato7y.js";import{_ as A,ch as Ue,ci as I,as as Ee,aH as R,cj as q,aA as Pe,aG as Ie}from"./index-D3NEBeO5.js";import{I as P,S as Te}from"./ScrollList-CEdyl3y1.js";import{u as O,F as Ge,O as Le,_ as se,P as Fe,a as je,V as De}from"./IconPark.vue_vue_type_script_setup_true_lang-C7eA9UI3.js";import{C as ze}from"./Consumption-Cm2ejYcw.js";import{a as Re}from"./price-uWkViTYj.js";import{N as Me}from"./NoTasks-BkpMkp7w.js";import{l as Oe}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-DjQkXVgW.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const Ne=C({name:"LayoutSuno",components:{ElDrawer:ue,ElButton:N,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),We={class:"main flex flex-row flex-1"},qe={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Be={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},He={class:"preview h-full w-[300px] flex flex-col"};function Ke(e,t,u,l,$,h){const p=i("font-awesome-icon"),_=i("el-button"),m=i("el-drawer");return n(),c("div",We,[s("div",qe,[K(e.$slots,"config",{},void 0,!0)]),s("div",Be,[K(e.$slots,"result",{},void 0,!0)]),s("div",He,[K(e.$slots,"preview",{},void 0,!0)]),o(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:r(()=>[o(p,{icon:"fa-solid fa-magic"})]),_:1}),o(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:r(()=>[K(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Je=A(Ne,[["render",Ke],["__scopeId","data-v-c6c85757"]]),Qe=C({name:"TypeSelector",components:{ElSelect:pe,ElOption:de,ElSwitch:ce},data(){return{options:[{label:"Suno v5.5",value:"chirp-v5-5",info:"8 min"},{label:"Suno v5",value:"chirp-v5",info:"8 min"},{label:"Suno v4.5+",value:"chirp-v4-5-plus",info:"8 min"},{label:"Suno v4.5",value:"chirp-v4-5",info:"4 min"},{label:"Suno v4",value:"chirp-v4",info:"2.5 min"},{label:"Suno v3.5",value:"chirp-v3-5",info:"2 min"},{label:"Suno v3",value:"chirp-v3-0",info:"2 min"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(this.model=Ue)}}),Xe={class:"flex items-center justify-between mb-3"},Ye={class:"text-sm font-bold"},Ze={class:"mb-3"},xe={class:"flex items-center mb-1"},et={class:"text-sm font-bold"},tt={class:"flex items-center justify-between w-full"},st={class:"text-xs text-[var(--el-text-color-placeholder)]"},ot={key:0,class:"flex items-center justify-between mb-3"},nt={class:"text-sm font-bold"};function it(e,t,u,l,$,h){const p=i("el-switch"),_=i("el-option"),m=i("el-select");return n(),c("div",null,[s("div",Xe,[s("span",Ye,a(e.$t("suno.name.type")),1),o(p,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=g=>e.custom=g)},null,8,["modelValue"])]),s("div",Ze,[s("div",xe,[s("span",et,a(e.$t("suno.name.model")),1)]),o(m,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=g=>e.model=g),class:"w-full",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:r(()=>[(n(!0),c(M,null,J(e.options,g=>(n(),y(_,{key:g.value,label:g.label,value:g.value},{default:r(()=>[s("div",tt,[s("span",null,a(g.label),1),s("span",st,a(g.info),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),c("div",ot,[s("span",nt,a(e.$t("suno.name.instrumental")),1),o(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[2]||(t[2]=g=>e.instrumental=g)},null,8,["modelValue"])])):d("",!0)])}const at=A(Qe,[["render",it]]),lt=C({name:"UploadAudio",components:{ElUpload:me,ElButton:N,InfoIcon:P,FontAwesomeIcon:D,ElRadioGroup:Z,ElRadioButton:Y},emits:["change"],data(){return{fileList:[],uploadUrl:Ee()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},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})}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){b.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){b.error(this.$t("suno.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},u=this.credential?.token;if(!u){console.error("no token specified");return}b.info(this.$t("suno.message.startingUploadAudio")),I.upload(t,{token:u}).then(l=>{console.debug("get upload music success",l.data);const $=l.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:$,action:"upload_extend"}),b.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(l=>{b.error(l?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),rt={class:"relative"},ut={class:"flex justify-between"},ct={class:"flex justify-start items-center"},dt={class:"text-sm font-bold"},pt={key:0,class:"mt-2"};function mt(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-upload"),v=i("el-radio-button"),E=i("el-radio-group");return n(),c("div",rt,[s("div",ut,[s("div",ct,[s("span",dt,a(e.$t("suno.name.referenceAudios")),1),o(p,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),o(g,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=k=>e.fileList=k),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:r(()=>[o(m,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:r(()=>[o(_,{icon:"fa-solid fa-upload",class:"icon mr-1"}),w(" "+a(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"]),e.hasUploadedAudio?(n(),c("div",pt,[o(E,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=k=>e.uploadAction=k),size:"small"},{default:r(()=>[o(v,{value:"upload_extend"},{default:r(()=>[w(a(e.$t("suno.button.extend")),1)]),_:1}),o(v,{value:"upload_cover"},{default:r(()=>[w(a(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):d("",!0)])}const ft=A(lt,[["render",mt],["__scopeId","data-v-b5153405"]]),ht="",_t=C({name:"PromptInput",components:{ElInput:z,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ht)}}),gt={class:"field"},$t={class:"flex items-center mb-1"},vt={class:"text-sm font-bold"};function yt(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",gt,[s("div",$t,[s("span",vt,a(e.$t("suno.name.songDescription")),1),o(p,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const kt=A(_t,[["render",yt]]),bt="",wt=C({name:"LyricInput",components:{ElInput:z,ElButton:N,FontAwesomeIcon:D,InfoIcon:P},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=bt)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,b.info(this.$t("suno.message.generatingLyrics"));try{const l=(await I.lyric({prompt:t},{token:e})).data?.data;l?.text&&(this.lyric=l.text,l?.title&&!this.config?.title&&this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:l.text,title:l.title}),b.success(this.$t("suno.message.generateLyricsSuccess")))}catch{b.error(this.$t("suno.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),Ct={class:"field"},Vt={class:"flex items-center justify-between mb-1"},St={class:"flex items-center"},At={class:"text-sm font-bold"};function Ut(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-input");return n(),c("div",Ct,[s("div",Vt,[s("div",St,[s("span",At,a(e.$t("suno.name.lyrics")),1),o(p,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(n(),y(m,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:r(()=>[e.generatingLyrics?d("",!0):(n(),y(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+a(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):d("",!0)]),e.config?.action!=="extend"?(n(),y(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=v=>e.lyric=v),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),y(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=v=>e.lyric=v),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const Et=A(wt,[["render",Ut],["__scopeId","data-v-210d2670"]]),Pt=C({name:"StyleInput",components:{ElInput:z,ElButton:N,FontAwesomeIcon:D,InfoIcon:P},data(){return{optimizing:!1}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential}},methods:{async onOptimizeStyle(){const e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,b.info(this.$t("suno.message.optimizingStyle"));try{const t=await I.style({prompt:this.style},{token:e}),u=t.data?.text||t.data?.data?.text;u&&(this.style=u,b.success(this.$t("suno.message.optimizeStyleSuccess")))}catch{b.error(this.$t("suno.message.optimizeStyleFailed"))}finally{this.optimizing=!1}}}}}),It={class:"field"},Tt={class:"flex items-center justify-between mb-1"},Gt={class:"flex items-center"},Lt={class:"text-sm font-bold"};function Ft(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-input");return n(),c("div",It,[s("div",Tt,[s("div",Gt,[s("span",Lt,a(e.$t("suno.name.style")),1),o(p,{content:e.$t("suno.description.style")},null,8,["content"])]),o(m,{size:"small",loading:e.optimizing,round:"",onClick:e.onOptimizeStyle},{default:r(()=>[e.optimizing?d("",!0):(n(),y(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+a(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),o(g,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=v=>e.style=v),rows:2,type:"textarea",placeholder:e.$t("suno.placeholder.style")},null,8,["modelValue","placeholder"])])}const jt=A(Pt,[["render",Ft]]),Dt=C({name:"TitleInput",components:{ElInput:z,InfoIcon:P},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}}}}),zt={class:"field"},Rt={class:"flex items-center mb-1"},Mt={class:"text-sm font-bold"};function Ot(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",zt,[s("div",Rt,[s("span",Mt,a(e.$t("suno.name.title")),1),o(p,{content:e.$t("suno.description.title")},null,8,["content"])]),o(_,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=m=>e.title=m),placeholder:e.$t("suno.placeholder.title")},null,8,["modelValue","placeholder"])])}const Nt=A(Dt,[["render",Ot]]),Wt=C({name:"ExtendFromInput",components:{ElImage:L,ElIcon:Q,ElInputNumber:W,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:O,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),qt={class:"field"},Bt={class:"box"},Ht={class:"title font-bold"},Kt={class:"input-wrapper"},Jt={class:"task"},Qt={class:"left"},Xt={key:2,class:"duration"},Yt={class:"info"},Zt={class:"title"},xt={class:"style"};function es(e,t,u,l,$,h){const p=i("el-input-number"),_=i("el-image"),m=i("video-pause"),g=i("el-icon"),v=i("video-play"),E=j("loading");return n(),c("div",qt,[s("div",Bt,[s("h2",Ht,a(e.$t("suno.name.extend")),1),s("div",Kt,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=k=>e.value=k),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",Jt,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=k=>e.onClick(e.audio))},[F((n(),c("div",Qt,[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(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPause(e.audio))},[o(g,null,{default:r(()=>[o(m)]),_:1})])):d("",!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(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=k=>e.onPlay(e.audio))},[o(g,null,{default:r(()=>[o(v)]),_:1})])):d("",!0),e.audio?.duration?(n(),c("div",Xt,a(e.useFormatDuring(e.audio?.duration)),1)):d("",!0)])),[[E,!e.audio?.audio_url]]),s("div",Yt,[s("h2",Zt,a(e.audio?.title),1),s("p",xt,a(e.audio?.style),1)])])):d("",!0)])])}const ts=A(Wt,[["render",es],["__scopeId","data-v-bcce4821"]]),ss=C({name:"CoverFromInput",components:{ElImage:L,ElIcon:Q,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:O,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})}}}),os={class:"field"},ns={class:"box"},is={class:"title font-bold"},as={class:"task"},ls={class:"left"},rs={key:2,class:"duration"},us={class:"info"},cs={class:"title"},ds={class:"style"};function ps(e,t,u,l,$,h){const p=i("el-image"),_=i("video-pause"),m=i("el-icon"),g=i("video-play"),v=j("loading");return n(),c("div",os,[s("div",ns,[s("h2",is,a(e.$t("suno.name.cover")),1)]),s("div",as,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=E=>e.onClick(e.audio))},[F((n(),c("div",ls,[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(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=E=>e.onPause(e.audio))},[o(m,null,{default:r(()=>[o(_)]),_:1})])):d("",!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(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=E=>e.onPlay(e.audio))},[o(m,null,{default:r(()=>[o(g)]),_:1})])):d("",!0),e.audio?.duration?(n(),c("div",rs,a(e.useFormatDuring(e.audio?.duration)),1)):d("",!0)])),[[v,!e.audio?.audio_url]]),s("div",us,[s("h2",cs,a(e.audio?.title),1),s("p",ds,a(e.audio?.style),1)])])):d("",!0)])])}const ms=A(ss,[["render",ps],["__scopeId","data-v-06640216"]]),fs=C({name:"VocalGenderSelector",components:{ElRadioGroup:Z,ElRadioButton:Y,InfoIcon:P},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})}}}}),hs={class:"mb-2"},_s={class:"flex items-center mb-1"},gs={class:"text-sm font-bold"};function $s(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-radio-button"),m=i("el-radio-group");return n(),c("div",hs,[s("div",_s,[s("span",gs,a(e.$t("suno.name.vocalGender")),1),o(p,{content:e.$t("suno.description.vocalGender")},null,8,["content"])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=g=>e.vocalGender=g)},{default:r(()=>[o(_,{value:""},{default:r(()=>[w(a(e.$t("suno.gender.auto")),1)]),_:1}),o(_,{value:"f"},{default:r(()=>[w(a(e.$t("suno.gender.female")),1)]),_:1}),o(_,{value:"m"},{default:r(()=>[w(a(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const vs=A(fs,[["render",$s]]),ys=C({name:"AdvancedParams",components:{ElCollapse:he,ElCollapseItem:fe,ElInput:z,ElSlider:te,ElRadioGroup:Z,ElRadioButton:Y},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})}}}}),ks={key:0,class:"mb-3"},bs={class:"flex items-center mb-1"},ws={class:"text-xs font-bold"},Cs={key:1,class:"mb-3"},Vs={class:"flex items-center mb-1"},Ss={class:"text-xs font-bold"},As={key:2,class:"mb-3"},Us={class:"flex items-center justify-between mb-1"},Es={class:"text-xs font-bold"},Ps={class:"text-xs text-[var(--el-text-color-secondary)]"},Is={key:3,class:"mb-3"},Ts={class:"flex items-center justify-between mb-1"},Gs={class:"text-xs font-bold"},Ls={class:"text-xs text-[var(--el-text-color-secondary)]"},Fs={key:4,class:"mb-3"},js={class:"flex items-center mb-1"},Ds={class:"text-xs font-bold"},zs={key:5,class:"mb-3"},Rs={class:"flex items-center justify-between mb-1"},Ms={class:"text-xs font-bold"},Os={class:"text-xs text-[var(--el-text-color-secondary)]"};function Ns(e,t,u,l,$,h){const p=i("el-input"),_=i("el-slider"),m=i("el-radio-button"),g=i("el-radio-group"),v=i("el-collapse-item"),E=i("el-collapse");return n(),y(E,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=k=>e.activeNames=k),class:"advanced-collapse"},{default:r(()=>[o(v,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:r(()=>[e.config?.custom?(n(),c("div",ks,[s("div",bs,[s("span",ws,a(e.$t("suno.name.styleNegative")),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=k=>e.styleNegative=k),placeholder:e.$t("suno.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):d("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",Cs,[s("div",Vs,[s("span",Ss,a(e.$t("suno.name.lyricPrompt")),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=k=>e.lyricPrompt=k),placeholder:e.$t("suno.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):d("",!0),e.config?.custom?(n(),c("div",As,[s("div",Us,[s("span",Es,a(e.$t("suno.name.weirdness")),1),s("span",Ps,a(e.weirdness??0),1)]),o(_,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=k=>e.weirdness=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0),e.config?.custom?(n(),c("div",Is,[s("div",Ts,[s("span",Gs,a(e.$t("suno.name.styleInfluence")),1),s("span",Ls,a(e.styleInfluence??50),1)]),o(_,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||(t[3]=k=>e.styleInfluence=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0),e.isV5OrAbove?(n(),c("div",Fs,[s("div",js,[s("span",Ds,a(e.$t("suno.name.variationCategory")),1)]),o(g,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=k=>e.variationCategory=k)},{default:r(()=>[o(m,{value:""},{default:r(()=>[w(a(e.$t("suno.gender.auto")),1)]),_:1}),o(m,{value:"high"},{default:r(()=>[w(a(e.$t("suno.variation.high")),1)]),_:1}),o(m,{value:"low"},{default:r(()=>[w(a(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):d("",!0),e.config?.action==="cover"?(n(),c("div",zs,[s("div",Rs,[s("span",Ms,a(e.$t("suno.name.audioWeight")),1),s("span",Os,a(e.audioWeight??50),1)]),o(_,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||(t[5]=k=>e.audioWeight=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Ws=A(ys,[["render",Ns],["__scopeId","data-v-a6d82e2a"]]),qs=C({name:"ReplaceSectionInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),Bs={class:"field"},Hs={class:"flex items-center mb-2"},Ks={class:"text-sm font-bold m-0"},Js={key:0,class:"task mb-2"},Qs={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Xs={class:"info flex-1 min-w-0"},Ys={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 eo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",Bs,[s("div",Hs,[s("h2",Ks,a(e.$t("suno.name.replaceSection")),1),o(p,{content:e.$t("suno.description.replaceSection")},null,8,["content"])]),e.audio?(n(),c("div",Js,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",Qs,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Xs,[s("h2",Ys,a(e.audio?.title),1),s("p",Zs,a(e.audio?.style),1)])])])):d("",!0),s("div",xs,[o(m,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.replaceSectionStart=v),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(m,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.replaceSectionEnd=v),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 to=A(qs,[["render",eo]]),so=C({name:"OverpaintingInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),oo={class:"field"},no={class:"flex items-center mb-2"},io={class:"text-sm font-bold m-0"},ao={key:0,class:"task mb-2"},lo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ro={class:"info flex-1 min-w-0"},uo={class:"text-sm font-bold m-0 truncate"},co={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},po={class:"flex gap-2"};function mo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",oo,[s("div",no,[s("h2",io,a(e.$t("suno.name.overpaintingRange")),1),o(p,{content:e.$t("suno.description.overpainting")},null,8,["content"])]),e.audio?(n(),c("div",ao,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",lo,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",ro,[s("h2",uo,a(e.audio?.title),1),s("p",co,a(e.audio?.style),1)])])])):d("",!0),s("div",po,[o(m,{modelValue:e.overpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.overpaintingStart=v),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(m,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.overpaintingEnd=v),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 fo=A(so,[["render",mo]]),ho=C({name:"UnderpaintingInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),_o={class:"field"},go={class:"flex items-center mb-2"},$o={class:"text-sm font-bold m-0"},vo={key:0,class:"task mb-2"},yo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ko={class:"info flex-1 min-w-0"},bo={class:"text-sm font-bold m-0 truncate"},wo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Co={class:"flex gap-2"};function Vo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",_o,[s("div",go,[s("h2",$o,a(e.$t("suno.name.underpaintingRange")),1),o(p,{content:e.$t("suno.description.underpainting")},null,8,["content"])]),e.audio?(n(),c("div",vo,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",yo,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",ko,[s("h2",bo,a(e.audio?.title),1),s("p",wo,a(e.audio?.style),1)])])])):d("",!0),s("div",Co,[o(m,{modelValue:e.underpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.underpaintingStart=v),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(m,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.underpaintingEnd=v),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 So=A(ho,[["render",Vo]]),Ao=C({name:"SamplesInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),Uo={class:"field"},Eo={class:"flex items-center mb-2"},Po={class:"text-sm font-bold m-0"},Io={key:0,class:"task mb-2"},To={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Go={class:"info flex-1 min-w-0"},Lo={class:"text-sm font-bold m-0 truncate"},Fo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},jo={class:"flex gap-2"};function Do(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",Uo,[s("div",Eo,[s("h2",Po,a(e.$t("suno.name.samplesRange")),1),o(p,{content:e.$t("suno.description.samples")},null,8,["content"])]),e.audio?(n(),c("div",Io,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",To,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Go,[s("h2",Lo,a(e.audio?.title),1),s("p",Fo,a(e.audio?.style),1)])])])):d("",!0),s("div",jo,[o(m,{modelValue:e.samplesStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.samplesStart=v),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(m,{modelValue:e.samplesEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.samplesEnd=v),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 zo=A(Ao,[["render",Do]]),Ro=C({name:"PersonaInput",components:{ElInput:z,InfoIcon:P},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})}}}}),Mo={class:"field"},Oo={class:"flex items-center mb-2"},No={class:"text-sm font-bold m-0"};function Wo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",Mo,[s("div",Oo,[s("h2",No,a(e.$t("suno.name.persona")),1),o(p,{content:e.$t("suno.description.persona")},null,8,["content"])]),o(_,{modelValue:e.personaId,"onUpdate:modelValue":t[0]||(t[0]=m=>e.personaId=m),size:"small",placeholder:e.$t("suno.placeholder.personaId")},null,8,["modelValue","placeholder"])])}const qo=A(Ro,[["render",Wo]]),Bo=C({name:"PresetPanel",components:{TypeSelector:at,PromptInput:kt,LyricInput:Et,StyleInput:jt,TitleInput:Nt,ExtendFromInput:ts,CoverFromInput:ms,UploadAudio:ft,VocalGenderSelector:vs,AdvancedParams:Ws,ReplaceSectionInput:to,OverpaintingInput:fo,UnderpaintingInput:So,SamplesInput:zo,PersonaInput:qo,FontAwesomeIcon:D,ElButton:N,Consumption:ze},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Re(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){const e=this.config?.model||"";return["chirp-v4-5-plus","chirp-v5","chirp-v5-5"].includes(e)},supportsPersona(){const e=this.config?.action;return!e||e==="generate"||e==="artist_consistency"||e==="artist_consistency_vox"},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("suno.button.extend"):e==="cover"?this.$t("suno.button.cover_music"):e==="remaster"?this.$t("suno.button.remaster"):e==="replace_section"?this.$t("suno.button.replace_section"):e==="mashup"?this.$t("suno.button.mashup"):e==="stems"?this.$t("suno.button.get_stems"):e==="concat"?this.$t("suno.button.concat_music"):e==="upload_cover"?this.$t("suno.button.upload_cover"):e==="artist_consistency"?this.$t("suno.button.artist_consistency"):e==="artist_consistency_vox"?this.$t("suno.button.artist_consistency_vox"):e==="overpainting"?this.$t("suno.button.overpainting"):e==="underpainting"?this.$t("suno.button.underpainting"):e==="samples"?this.$t("suno.button.samples"):this.$t("suno.button.generate")}},methods:{onGenerate(){this.$emit("generate")}}}),Ho={class:"flex flex-col h-full"},Ko={class:"flex-1 overflow-y-auto p-5"},Jo={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qo(e,t,u,l,$,h){const p=i("type-selector"),_=i("upload-audio"),m=i("prompt-input"),g=i("lyric-input"),v=i("style-input"),E=i("title-input"),k=i("vocal-gender-selector"),S=i("persona-input"),B=i("extend-from-input"),H=i("cover-from-input"),X=i("replace-section-input"),f=i("overpainting-input"),V=i("underpainting-input"),ne=i("samples-input"),ie=i("advanced-params"),ae=i("consumption"),le=i("font-awesome-icon"),re=i("el-button");return n(),c("div",Ho,[s("div",Ko,[o(p,{class:"mb-4"}),o(_,{class:"mb-4"}),e.config?.custom?d("",!0):(n(),y(m,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),y(g,{key:1,class:"mb-4"})):d("",!0),e.config?.custom?(n(),y(v,{key:2,class:"mb-4"})):d("",!0),e.config?.custom?(n(),y(E,{key:3,class:"mb-4"})):d("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(n(),y(k,{key:4,class:"mb-4"})):d("",!0),e.config?.custom&&e.supportsPersona?(n(),y(S,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(n(),y(B,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="cover"?(n(),y(H,{key:7,class:"mb-4"})):d("",!0),e.config?.action==="replace_section"?(n(),y(X,{key:8,class:"mb-4"})):d("",!0),e.config?.action==="overpainting"?(n(),y(f,{key:9,class:"mb-4"})):d("",!0),e.config?.action==="underpainting"?(n(),y(V,{key:10,class:"mb-4"})):d("",!0),e.config?.action==="samples"?(n(),y(ne,{key:11,class:"mb-4"})):d("",!0),o(ie,{class:"mb-4"})]),s("div",Jo,[o(ae,{value:e.consumption,service:e.service},null,8,["value","service"]),o(re,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:r(()=>[o(le,{icon:"fa-solid fa-magic",class:"mr-2"}),w(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const Xo=A(Bo,[["render",Qo],["__scopeId","data-v-a9d5cfc6"]]),oe="https://webhook.acedata.cloud/suno",Yo=C({name:"TaskPreview",components:{ElImage:L,ElIcon:Q,ElTooltip:ye,FontAwesomeIcon:D,VideoPlay:ee,VideoPause:x,ElDropdown:ve,ElDropdownMenu:$e,ElDropdownItem:ge,Loading:_e},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===R.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(u=>({...u,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:O,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 l=new URL(t).pathname,$=l.substring(l.lastIndexOf("/")+1);console.log("on preview",$),fetch(t).then(h=>h.blob()).then(h=>{Ge.saveAs(h,$)})},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),b.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,u)=>{const l={audio_id:e},$=this.credential?.token;if(!$){console.error("no token specified"),u(new Error("No token specified"));return}I.mp4(l,{token:$}).then(h=>{const p=h.data?.data?.video_url;p?t(p):u(new Error("Video URL not found in response"))}).catch(h=>{u(h)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onRemaster(e){await this.onGenerateAudioUrl("remaster",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"mashup",audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"overpainting",audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"underpainting",audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"samples",audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"artist_consistency",audio:e,audio_id:e.id})},async onExtractVocals(e){const t=this.credential?.token;t&&(b.info(this.$t("suno.message.extractingVocals")),I.vox({audio_id:e,callback_url:oe},{token:t}).then(()=>{b.success(this.$t("suno.message.extractVocalsSuccess"))}).catch(u=>{b.error(u?.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&&(b.info(this.$t("suno.message.fetchingTiming")),I.timing({audio_id:e},{token:t}).then(u=>{b.success(this.$t("suno.message.fetchTimingSuccess")),console.debug("timing data",u.data)}).catch(u=>{b.error(u?.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,b.info(this.$t("suno.message.fetchingWav"));const l=(await I.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;l?this.onDownload(null,l):b.error(this.$t("suno.message.fetchWavFailed"))}catch{b.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,b.info(this.$t("suno.message.fetchingMidi"));const l=(await I.midi({audio_id:e.id},{token:t})).data?.data?.midi_url;l?this.onDownload(null,l):b.error(this.$t("suno.message.fetchMidiFailed"))}catch{b.error(this.$t("suno.message.fetchMidiFailed"))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){const u={action:e,audio_id:t,callback_url:oe},l=this.credential?.token;if(!l){console.error("no token specified");return}b.info(this.$t("suno.message.startingTask")),I.audio(u,{token:l}).then(()=>{b.success(this.$t("suno.message.startTaskSuccess"))}).catch($=>{b.error($?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),Zo={class:"task"},xo=["onClick"],en={class:"left"},tn=["onClick"],sn=["onClick"],on={key:2,class:"duration"},nn={class:"info"},an={class:"title"},ln={class:"style"},rn={class:"right"},un={class:"el-dropdown-link"},cn={class:"flex items-center min-w-[120px]"},dn={class:"flex items-center min-w-[120px]"},pn={class:"flex items-center min-w-[120px]"},mn={class:"el-dropdown-link"};function fn(e,t,u,l,$,h){const p=i("el-image"),_=i("video-pause"),m=i("el-icon"),g=i("video-play"),v=i("font-awesome-icon"),E=i("el-tooltip"),k=i("Loading"),S=i("el-dropdown-item"),B=i("el-dropdown-menu"),H=i("el-dropdown"),X=j("loading");return n(),c("div",Zo,[(n(!0),c(M,null,J(e.audios,f=>(n(),c("div",{key:f.id,class:"audio",onClick:U(V=>e.onClick(f),["stop"])},[F((n(),c("div",en,[o(p,{src:f?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),f?.audio_url&&e.$store.state?.suno?.audio?.id===f.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:U(V=>e.onPause(f),["stop"])},[o(m,null,{default:r(()=>[o(_)]),_:1})],8,tn)):d("",!0),f?.audio_url&&(e.$store.state?.suno?.audio?.id!==f.id||e.$store.state?.suno?.audio?.id===f.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:U(V=>e.onPlay(f),["stop"])},[o(m,null,{default:r(()=>[o(g)]),_:1})],8,sn)):d("",!0),f?.duration?(n(),c("div",on,a(e.useFormatDuring(f?.duration)),1)):d("",!0)])),[[X,!f?.audio_url]]),s("div",nn,[s("h2",an,a(f?.title),1),s("p",ln,a(f?.style),1)]),s("div",rn,[o(H,null,{dropdown:r(()=>[o(B,null,{default:r(()=>[o(S,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload(f)},{default:r(()=>[s("div",cn,[e.isFetchingVideoUrl?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),f?.audio_url?(n(),y(S,{key:0,onClick:U(V=>e.onDownload(V,f?.audio_url),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):d("",!0),o(S,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload(f)},{default:r(()=>[s("div",dn,[e.isFetchingWav?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_wav")),1)])]),_:2},1032,["disabled","onClick"]),o(S,{disabled:e.isFetchingMidi,onClick:V=>e.handleMidiDownload(f)},{default:r(()=>[s("div",pn,[e.isFetchingMidi?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_midi")),1)])]),_:2},1032,["disabled","onClick"])]),_:2},1024)]),default:r(()=>[s("span",un,[o(E,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:r(()=>[f?.audio_url||f?.video_url?(n(),y(v,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):d("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(H,null,{dropdown:r(()=>[o(B,null,{default:r(()=>[f?.audio_url?(n(),y(S,{key:0,onClick:U(V=>e.onExtend(V,f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):d("",!0),f.id?(n(),y(S,{key:1,onClick:U(V=>e.onGetStems(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):d("",!0),f.id?(n(),y(S,{key:2,onClick:U(V=>e.onGetAllStems(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.all_stems")),1)]),_:2},1032,["onClick"])):d("",!0),o(S,{onClick:U(V=>e.onCover(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),f?.id?(n(),y(S,{key:3,onClick:U(V=>e.onRemaster(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.remaster")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:4,onClick:U(V=>e.onReplaceSection(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.replace_section")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:5,onClick:U(V=>e.onMashup(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.mashup")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id&&f?.action==="extend"?(n(),y(S,{key:6,onClick:U(V=>e.onConcatMusic(f?.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:7,onClick:U(V=>e.onOverpainting(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.overpainting")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:8,onClick:U(V=>e.onUnderpainting(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.underpainting")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:9,onClick:U(V=>e.onSamples(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.samples")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:10,onClick:U(V=>e.onArtistConsistency(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.artist_consistency")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:11,onClick:U(V=>e.onExtractVocals(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.extract_vocals")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:12,onClick:U(V=>e.onGetTiming(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.get_timing")),1)]),_:2},1032,["onClick"])):d("",!0)]),_:2},1024)]),default:r(()=>[s("span",mn,[o(E,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:r(()=>[f?.audio_url||f?.video_url?(n(),y(v,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):d("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,xo))),128))])}const hn=A(Yo,[["render",fn]]),_n={class:"player-slider"},gn=C({__name:"PlayerSlider",setup(e){const t=q(),u=G({get:()=>t.state.suno?.audio?.progress,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:p})}),l=G({get:()=>t.state.suno?.audio?.duration,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:p})}),$=()=>{},h=p=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:p});return(p,_)=>(n(),c("div",_n,[o(T(te),{modelValue:u.value,"onUpdate:modelValue":_[0]||(_[0]=m=>u.value=m),"show-tooltip":!1,min:0,max:l.value,onChange:h,onInput:$},null,8,["modelValue","max"])]))}}),$n={class:"flex player-song"},vn=["src"],yn={class:"ml-2 text-xs flex flex-col justify-between"},kn={class:"w-52 2xl:w-96 cursor-pointer truncate"},bn={class:"flex"},wn={class:"ml-2 text-dc"},Cn=C({__name:"PlayerSong",setup(e){const t=q(),u=G({get:()=>t.state.suno.audio,set:l=>t.commit("suno/setAudio",l)});return Se(u,(l,$)=>{if(l?.audio_url!==$?.audio_url){console.log("audio changed",l),l.object&&(console.log("111",l.object),l.object.pause(),delete l.object);const h=new Audio(l.audio_url);l.state==="playing"?h.play():h.pause(),h.addEventListener("loadedmetadata",()=>{h.currentTime=0,h.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:h.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:h})}else if(l?.progress!==$?.progress&&Math.abs(l.progress-l.object.currentTime)>2){console.log("progress changed",l.progress);const h=t.state.suno.audio;h.object&&(h.object.currentTime=h.progress)}else l?.state!==$?.state&&(console.log("state changed",l.state),l.object&&(l.state==="playing"?l.object.play():l.object.pause()));l?.volume!==$?.volume&&(console.log("volume changed",l.volume),l.object&&(l.object.volume=l.volume/100))}),(l,$)=>(n(),c("div",$n,[s("img",{alt:"",class:"w-11 h-11 rounded",src:u.value?.image_url||T(Le)},null,8,vn),s("div",yn,[s("div",kn,[s("div",bn,[s("span",null,a(u.value?.title||"Music"),1),s("span",wn,"- "+a(u.value?.style||"SmallRuralDog"),1)])])])]))}}),Vn={class:"flex justify-end items-center gap-x-2.5"},Sn={class:"text-xs"},An=C({__name:"PlayerAction",setup(e){const t=q(),u=G({get:()=>t.state.suno?.audio?.progress,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:$})}),l=G({get:()=>t.state.suno?.audio?.duration,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:$})});return($,h)=>(n(),c("div",Vn,[s("span",Sn,a(T(O)(u.value))+" / "+a(T(O)(l.value)),1)]))}}),Un={class:"player-volume flex flex-col items-center pt-2"},En={class:"text-sm mt-3"},Pn=C({__name:"PlayerVolumeSlider",setup(e){const t=q(),u=G({get:()=>t.state.suno.audio?.volume,set:h=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:h})}),l=G({get:()=>t.state.suno.audio?.muted,set:h=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:h})}),$=h=>t.dispatch("suno/setVolume",h);return(h,p)=>(n(),c("div",Un,[o(T(te),{modelValue:u.value,"onUpdate:modelValue":p[0]||(p[0]=_=>u.value=_),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:l.value,onInput:$},null,8,["modelValue","disabled"]),s("div",En,a(u.value),1)]))}}),In={class:"flex items-center justify-center gap-x-3"},Tn=C({__name:"PlayerController",setup(e){const t=q(),u=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),l=G(()=>t.state.suno.audio);return($,h)=>(n(),c("div",In,[o(se,{icon:l.value?.state==="playing"?T(Fe):T(je),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:u},null,8,["icon"]),o(T(ke),{placement:"top",width:"50px",trigger:"click"},{reference:r(()=>[o(se,{icon:T(De),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:r(()=>[o(Pn)]),_:1})]))}}),Gn={class:"flex flex-col items-stretch h-20"},Ln={class:"flex grow px-5 items-center"},Fn={class:"flex-1"},jn={class:"flex-1"},Dn={class:"flex-1"},zn=C({__name:"Player",setup(e){return(t,u)=>(n(),c("div",Gn,[o(gn),s("div",Ln,[s("div",Fn,[o(Cn)]),s("div",jn,[o(Tn)]),s("div",Dn,[o(An)])])]))}}),Rn=C({name:"RecentPanel",components:{ElSkeletonItem:we,ElSkeleton:be,TaskPreview:hn,Player:zn,NoTasks:Me,ScrollList:Te},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mn={key:0,class:"tasks"},On={class:"left w-[70px] p-[10px] flex items-center"},Nn={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Wn={key:2,class:"w-full flex-1 flex items-center justify-center"},qn={class:"h-20"};function Bn(e,t,u,l,$,h){const p=i("el-skeleton-item"),_=i("el-skeleton"),m=i("task-preview"),g=i("scroll-list"),v=i("no-tasks"),E=i("player");return n(),c(M,null,[e.tasks?.items===void 0?(n(),c("div",Mn,[(n(),c(M,null,J(3,k=>s("div",{key:k,class:"flex"},[s("div",On,[o(_,{animated:""},{template:r(()=>[o(p,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",Nn,[o(_,{animated:""},{template:r(()=>[o(p,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(p,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(g,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:r(()=>[(n(!0),c(M,null,J(e.tasks?.items,(k,S)=>(n(),y(m,{key:S,"model-value":k,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(n(),c("div",Wn,[o(v)])):d("",!0),F(s("div",qn,[o(E)],512),[[Ae,!!e.$store?.state?.suno?.audio?.object]])],64)}const Hn=A(Rn,[["render",Bn]]),Kn=C({name:"TaskPreview",components:{IconPicture:Ve,ElImage:L,ElAvatar:Ce,ElIcon:Q},computed:{audio(){return this.$store.state.suno?.audio}}}),Jn={key:0,class:"size-full overflow-hidden"},Qn={class:"relative h-[300px]"},Xn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Yn={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"},Zn={class:"p-4"},xn={class:"flex items-center font-bold mb-2"},ei={class:"text-[var(--el-text-color-regular)] mb-2"},ti={class:"text-xs text-[var(--el-text-color-regular)]"},si={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},oi={key:1,class:"w-full h-full"};function ni(e,t,u,l,$,h){const p=i("icon-picture"),_=i("el-icon"),m=i("el-image"),g=i("el-avatar");return e.audio?.object?(n(),c("div",Jn,[s("div",Qn,[o(m,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:r(()=>[s("div",Xn,[o(_,{class:"text-3xl"},{default:r(()=>[o(p)]),_:1})])]),_:1},8,["src"]),s("h2",Yn,a(e.audio?.title),1)]),s("div",Zn,[s("div",xn,[o(g,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,a(e.audio?.title),1)]),s("p",ei,a(e.audio?.style),1),s("p",ti,a(e.$dayjs.format(e.audio?.created_at)),1),s("div",si,[s("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",oi))}const ii=A(Kn,[["render",ni]]),ai="https://webhook.acedata.cloud/suno",li=C({name:"SunoIndex",components:{Layout:Je,ConfigPanel:Xo,RecentPanel:Hn,PreviewPanel:ii},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===R.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===R.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===R.Request},needApply(){return this.$store.state.suno.status.getApplications===R.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await Oe({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(){Pe.create({application:this.application}).then(({data:e})=>{this.application=e,b.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ie&&b.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:u,createdAtMax:l}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",l),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:u,createdAtMax:l})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:ai},t=this.credential?.token;if(!t){console.error("no token specified");return}b.info(this.$t("suno.message.startingTask")),I.audio(e,{token:t}).then(()=>{b.success(this.$t("suno.message.startTaskSuccess"))}).catch(u=>{b.error(u?.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 ri(e,t,u,l,$,h){const p=i("config-panel"),_=i("recent-panel"),m=i("preview-panel"),g=i("layout");return n(),y(g,null,{config:r(()=>[o(p,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:r(()=>[o(_,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:r(()=>[o(m)]),_:1})}const wi=A(li,[["render",ri],["__scopeId","data-v-d1296b1a"]]);export{wi as default};
|
|
1
|
+
import{F as D}from"./index.es-Bqj83sQx.js";import{m as N,Y as ue,k as ce,O as de,P as pe,F as X,G as Z,u as me,w as b,t as z,a6 as x,a7 as ee,_ as W,e as Y,j as L,$ as te,a8 as fe,a9 as he,l as _e,f as ge,g as $e,h as ve,q as ye,r as ke,L as be,a2 as we,aa as Ce,ab as Ve}from"./vendor-element-plus-DN048TGi.js";import{d as C,C as c,G as s,T as o,E as H,K as r,ai as i,D as n,O as d,R as a,S as M,ag as J,J as y,Q as w,L as F,aq as j,X as U,c as G,u as T,w as Se,U as Ae}from"./vendor-vue-BhXato7y.js";import{_ as A,cj as Ue,ck as I,au as Ee,aJ as R,cl as q,aC as Pe,aI as Ie}from"./index-muIEJvsu.js";import{I as P,S as Te}from"./ScrollList-ZiMJkMBw.js";import{u as O,F as Ge,O as Le,_ as se,P as Fe,a as je,V as De}from"./IconPark.vue_vue_type_script_setup_true_lang-C7eA9UI3.js";import{C as ze}from"./Consumption-DB4jsCIw.js";import{a as Re}from"./price-Bva0CFLK.js";import{N as Me}from"./NoTasks-Dk7Wt2AG.js";import{l as Oe}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CIJ0oOq5.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const Ne=C({name:"LayoutSuno",components:{ElDrawer:ue,ElButton:N,FontAwesomeIcon:D},data(){return{drawer:!1,preview:!1}},computed:{}}),We={class:"main flex flex-row flex-1"},qe={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},Be={class:"result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"},Ke={class:"preview h-full w-[300px] flex flex-col"};function He(e,t,u,l,$,h){const p=i("font-awesome-icon"),_=i("el-button"),m=i("el-drawer");return n(),c("div",We,[s("div",qe,[H(e.$slots,"config",{},void 0,!0)]),s("div",Be,[H(e.$slots,"result",{},void 0,!0)]),s("div",Ke,[H(e.$slots,"preview",{},void 0,!0)]),o(_,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:r(()=>[o(p,{icon:"fa-solid fa-magic"})]),_:1}),o(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:r(()=>[H(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Je=A(Ne,[["render",He],["__scopeId","data-v-c6c85757"]]),Ye=C({name:"TypeSelector",components:{ElSelect:pe,ElOption:de,ElSwitch:ce},data(){return{options:[{label:"Suno v5.5",value:"chirp-v5-5",info:"8 min"},{label:"Suno v5",value:"chirp-v5",info:"8 min"},{label:"Suno v4.5+",value:"chirp-v4-5-plus",info:"8 min"},{label:"Suno v4.5",value:"chirp-v4-5",info:"4 min"},{label:"Suno v4",value:"chirp-v4",info:"2.5 min"},{label:"Suno v3.5",value:"chirp-v3-5",info:"2 min"},{label:"Suno v3",value:"chirp-v3-0",info:"2 min"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(this.model=Ue)}}),Qe={class:"flex items-center justify-between mb-3"},Xe={class:"text-sm font-bold"},Ze={class:"mb-3"},xe={class:"flex items-center mb-1"},et={class:"text-sm font-bold"},tt={class:"flex items-center justify-between w-full"},st={class:"text-xs text-[var(--el-text-color-placeholder)]"},ot={key:0,class:"flex items-center justify-between mb-3"},nt={class:"text-sm font-bold"};function it(e,t,u,l,$,h){const p=i("el-switch"),_=i("el-option"),m=i("el-select");return n(),c("div",null,[s("div",Qe,[s("span",Xe,a(e.$t("suno.name.type")),1),o(p,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=g=>e.custom=g)},null,8,["modelValue"])]),s("div",Ze,[s("div",xe,[s("span",et,a(e.$t("suno.name.model")),1)]),o(m,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=g=>e.model=g),class:"w-full",size:"default",placeholder:e.$t("suno.placeholder.select")},{default:r(()=>[(n(!0),c(M,null,J(e.options,g=>(n(),y(_,{key:g.value,label:g.label,value:g.value},{default:r(()=>[s("div",tt,[s("span",null,a(g.label),1),s("span",st,a(g.info),1)])]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])]),e.custom?(n(),c("div",ot,[s("span",nt,a(e.$t("suno.name.instrumental")),1),o(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[2]||(t[2]=g=>e.instrumental=g)},null,8,["modelValue"])])):d("",!0)])}const at=A(Ye,[["render",it]]),lt=C({name:"UploadAudio",components:{ElUpload:me,ElButton:N,InfoIcon:P,FontAwesomeIcon:D,ElRadioGroup:Z,ElRadioButton:X},emits:["change"],data(){return{fileList:[],uploadUrl:Ee()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},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})}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){b.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){b.error(this.$t("suno.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},u=this.credential?.token;if(!u){console.error("no token specified");return}b.info(this.$t("suno.message.startingUploadAudio")),I.upload(t,{token:u}).then(l=>{console.debug("get upload music success",l.data);const $=l.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:$,action:"upload_extend"}),b.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(l=>{b.error(l?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),rt={class:"relative"},ut={class:"flex justify-between"},ct={class:"flex justify-start items-center"},dt={class:"text-sm font-bold"},pt={key:0,class:"mt-2"};function mt(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-upload"),v=i("el-radio-button"),E=i("el-radio-group");return n(),c("div",rt,[s("div",ut,[s("div",ct,[s("span",dt,a(e.$t("suno.name.referenceAudios")),1),o(p,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),o(g,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=k=>e.fileList=k),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:r(()=>[o(m,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:r(()=>[o(_,{icon:"fa-solid fa-upload",class:"icon mr-1"}),w(" "+a(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"]),e.hasUploadedAudio?(n(),c("div",pt,[o(E,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||(t[1]=k=>e.uploadAction=k),size:"small"},{default:r(()=>[o(v,{value:"upload_extend"},{default:r(()=>[w(a(e.$t("suno.button.extend")),1)]),_:1}),o(v,{value:"upload_cover"},{default:r(()=>[w(a(e.$t("suno.button.upload_cover")),1)]),_:1})]),_:1},8,["modelValue"])])):d("",!0)])}const ft=A(lt,[["render",mt],["__scopeId","data-v-b5153405"]]),ht="",_t=C({name:"PromptInput",components:{ElInput:z,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ht)}}),gt={class:"field"},$t={class:"flex items-center mb-1"},vt={class:"text-sm font-bold"};function yt(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",gt,[s("div",$t,[s("span",vt,a(e.$t("suno.name.songDescription")),1),o(p,{content:e.$t("suno.description.prompt")},null,8,["content"])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:4,type:"textarea",placeholder:e.$t("suno.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const kt=A(_t,[["render",yt]]),bt="",wt=C({name:"LyricInput",components:{ElInput:z,ElButton:N,FontAwesomeIcon:D,InfoIcon:P},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||(this.lyric=bt)},methods:{async onGenerateLyrics(){const e=this.credential?.token;if(!e)return;const t=this.config?.style||this.config?.title||"a beautiful song";this.generatingLyrics=!0,b.info(this.$t("suno.message.generatingLyrics"));try{const l=(await I.lyric({prompt:t},{token:e})).data?.data;l?.text&&(this.lyric=l.text,l?.title&&!this.config?.title&&this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:l.text,title:l.title}),b.success(this.$t("suno.message.generateLyricsSuccess")))}catch{b.error(this.$t("suno.message.generateLyricsFailed"))}finally{this.generatingLyrics=!1}}}}),Ct={class:"field"},Vt={class:"flex items-center justify-between mb-1"},St={class:"flex items-center"},At={class:"text-sm font-bold"};function Ut(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-input");return n(),c("div",Ct,[s("div",Vt,[s("div",St,[s("span",At,a(e.$t("suno.name.lyrics")),1),o(p,{content:e.$t("suno.description.lyrics")},null,8,["content"])]),e.config?.action!=="extend"?(n(),y(m,{key:0,size:"small",loading:e.generatingLyrics,round:"",onClick:e.onGenerateLyrics},{default:r(()=>[e.generatingLyrics?d("",!0):(n(),y(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+a(e.$t("suno.button.generate_lyrics")),1)]),_:1},8,["loading","onClick"])):d("",!0)]),e.config?.action!=="extend"?(n(),y(g,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=v=>e.lyric=v),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics")},null,8,["modelValue","placeholder"])):(n(),y(g,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=v=>e.lyric=v),rows:5,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics")},null,8,["modelValue","placeholder"]))])}const Et=A(wt,[["render",Ut],["__scopeId","data-v-210d2670"]]),Pt=C({name:"StyleInput",components:{ElInput:z,ElButton:N,FontAwesomeIcon:D,InfoIcon:P},data(){return{optimizing:!1}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential}},methods:{async onOptimizeStyle(){const e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,b.info(this.$t("suno.message.optimizingStyle"));try{const t=await I.style({prompt:this.style},{token:e}),u=t.data?.text||t.data?.data?.text;u&&(this.style=u,b.success(this.$t("suno.message.optimizeStyleSuccess")))}catch{b.error(this.$t("suno.message.optimizeStyleFailed"))}finally{this.optimizing=!1}}}}}),It={class:"field"},Tt={class:"flex items-center justify-between mb-1"},Gt={class:"flex items-center"},Lt={class:"text-sm font-bold"};function Ft(e,t,u,l,$,h){const p=i("info-icon"),_=i("font-awesome-icon"),m=i("el-button"),g=i("el-input");return n(),c("div",It,[s("div",Tt,[s("div",Gt,[s("span",Lt,a(e.$t("suno.name.style")),1),o(p,{content:e.$t("suno.description.style")},null,8,["content"])]),o(m,{size:"small",loading:e.optimizing,round:"",onClick:e.onOptimizeStyle},{default:r(()=>[e.optimizing?d("",!0):(n(),y(_,{key:0,icon:"fa-solid fa-wand-magic-sparkles",class:"mr-1"})),w(" "+a(e.$t("suno.button.optimize_style")),1)]),_:1},8,["loading","onClick"])]),o(g,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=v=>e.style=v),rows:2,type:"textarea",placeholder:e.$t("suno.placeholder.style")},null,8,["modelValue","placeholder"])])}const jt=A(Pt,[["render",Ft]]),Dt=C({name:"TitleInput",components:{ElInput:z,InfoIcon:P},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}}}}),zt={class:"field"},Rt={class:"flex items-center mb-1"},Mt={class:"text-sm font-bold"};function Ot(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",zt,[s("div",Rt,[s("span",Mt,a(e.$t("suno.name.title")),1),o(p,{content:e.$t("suno.description.title")},null,8,["content"])]),o(_,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=m=>e.title=m),placeholder:e.$t("suno.placeholder.title")},null,8,["modelValue","placeholder"])])}const Nt=A(Dt,[["render",Ot]]),Wt=C({name:"ExtendFromInput",components:{ElImage:L,ElIcon:Y,ElInputNumber:W,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:O,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),qt={class:"field"},Bt={class:"box"},Kt={class:"title font-bold"},Ht={class:"input-wrapper"},Jt={class:"task"},Yt={class:"left"},Qt={key:2,class:"duration"},Xt={class:"info"},Zt={class:"title"},xt={class:"style"};function es(e,t,u,l,$,h){const p=i("el-input-number"),_=i("el-image"),m=i("video-pause"),g=i("el-icon"),v=i("video-play"),E=j("loading");return n(),c("div",qt,[s("div",Bt,[s("h2",Kt,a(e.$t("suno.name.extend")),1),s("div",Ht,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=k=>e.value=k),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",Jt,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[3]||(t[3]=k=>e.onClick(e.audio))},[F((n(),c("div",Yt,[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(),c("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPause(e.audio))},[o(g,null,{default:r(()=>[o(m)]),_:1})])):d("",!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(),c("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=k=>e.onPlay(e.audio))},[o(g,null,{default:r(()=>[o(v)]),_:1})])):d("",!0),e.audio?.duration?(n(),c("div",Qt,a(e.useFormatDuring(e.audio?.duration)),1)):d("",!0)])),[[E,!e.audio?.audio_url]]),s("div",Xt,[s("h2",Zt,a(e.audio?.title),1),s("p",xt,a(e.audio?.style),1)])])):d("",!0)])])}const ts=A(Wt,[["render",es],["__scopeId","data-v-bcce4821"]]),ss=C({name:"CoverFromInput",components:{ElImage:L,ElIcon:Y,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:O,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})}}}),os={class:"field"},ns={class:"box"},is={class:"title font-bold"},as={class:"task"},ls={class:"left"},rs={key:2,class:"duration"},us={class:"info"},cs={class:"title"},ds={class:"style"};function ps(e,t,u,l,$,h){const p=i("el-image"),_=i("video-pause"),m=i("el-icon"),g=i("video-play"),v=j("loading");return n(),c("div",os,[s("div",ns,[s("h2",is,a(e.$t("suno.name.cover")),1)]),s("div",as,[e.audio?(n(),c("div",{key:0,class:"audio",onClick:t[2]||(t[2]=E=>e.onClick(e.audio))},[F((n(),c("div",ls,[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(),c("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=E=>e.onPause(e.audio))},[o(m,null,{default:r(()=>[o(_)]),_:1})])):d("",!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(),c("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=E=>e.onPlay(e.audio))},[o(m,null,{default:r(()=>[o(g)]),_:1})])):d("",!0),e.audio?.duration?(n(),c("div",rs,a(e.useFormatDuring(e.audio?.duration)),1)):d("",!0)])),[[v,!e.audio?.audio_url]]),s("div",us,[s("h2",cs,a(e.audio?.title),1),s("p",ds,a(e.audio?.style),1)])])):d("",!0)])])}const ms=A(ss,[["render",ps],["__scopeId","data-v-06640216"]]),fs=C({name:"VocalGenderSelector",components:{ElRadioGroup:Z,ElRadioButton:X,InfoIcon:P},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})}}}}),hs={class:"mb-2"},_s={class:"flex items-center mb-1"},gs={class:"text-sm font-bold"};function $s(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-radio-button"),m=i("el-radio-group");return n(),c("div",hs,[s("div",_s,[s("span",gs,a(e.$t("suno.name.vocalGender")),1),o(p,{content:e.$t("suno.description.vocalGender")},null,8,["content"])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||(t[0]=g=>e.vocalGender=g)},{default:r(()=>[o(_,{value:""},{default:r(()=>[w(a(e.$t("suno.gender.auto")),1)]),_:1}),o(_,{value:"f"},{default:r(()=>[w(a(e.$t("suno.gender.female")),1)]),_:1}),o(_,{value:"m"},{default:r(()=>[w(a(e.$t("suno.gender.male")),1)]),_:1})]),_:1},8,["modelValue"])])}const vs=A(fs,[["render",$s]]),ys=C({name:"AdvancedParams",components:{ElCollapse:he,ElCollapseItem:fe,ElInput:z,ElSlider:te,ElRadioGroup:Z,ElRadioButton:X},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){const e=this.config?.model||"";return["chirp-v5","chirp-v5-5"].includes(e)},styleNegative:{get(){return this.$store.state.suno?.config?.style_negative||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.suno?.config?.lyric_prompt||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.suno?.config?.weirdness??0},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,weirdness:e||void 0})}},styleInfluence:{get(){return this.$store.state.suno?.config?.style_influence??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style_influence:e})}},variationCategory:{get(){return this.$store.state.suno?.config?.variation_category||""},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,variation_category:e||void 0})}},audioWeight:{get(){return this.$store.state.suno?.config?.audio_weight??50},set(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_weight:e})}}}}),ks={key:0,class:"mb-3"},bs={class:"flex items-center mb-1"},ws={class:"text-xs font-bold"},Cs={key:1,class:"mb-3"},Vs={class:"flex items-center mb-1"},Ss={class:"text-xs font-bold"},As={key:2,class:"mb-3"},Us={class:"flex items-center justify-between mb-1"},Es={class:"text-xs font-bold"},Ps={class:"text-xs text-[var(--el-text-color-secondary)]"},Is={key:3,class:"mb-3"},Ts={class:"flex items-center justify-between mb-1"},Gs={class:"text-xs font-bold"},Ls={class:"text-xs text-[var(--el-text-color-secondary)]"},Fs={key:4,class:"mb-3"},js={class:"flex items-center mb-1"},Ds={class:"text-xs font-bold"},zs={key:5,class:"mb-3"},Rs={class:"flex items-center justify-between mb-1"},Ms={class:"text-xs font-bold"},Os={class:"text-xs text-[var(--el-text-color-secondary)]"};function Ns(e,t,u,l,$,h){const p=i("el-input"),_=i("el-slider"),m=i("el-radio-button"),g=i("el-radio-group"),v=i("el-collapse-item"),E=i("el-collapse");return n(),y(E,{modelValue:e.activeNames,"onUpdate:modelValue":t[6]||(t[6]=k=>e.activeNames=k),class:"advanced-collapse"},{default:r(()=>[o(v,{title:e.$t("suno.name.advancedParams"),name:"advanced"},{default:r(()=>[e.config?.custom?(n(),c("div",ks,[s("div",bs,[s("span",ws,a(e.$t("suno.name.styleNegative")),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":t[0]||(t[0]=k=>e.styleNegative=k),placeholder:e.$t("suno.placeholder.styleNegative")},null,8,["modelValue","placeholder"])])):d("",!0),e.config?.custom&&!e.config?.instrumental?(n(),c("div",Cs,[s("div",Vs,[s("span",Ss,a(e.$t("suno.name.lyricPrompt")),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":t[1]||(t[1]=k=>e.lyricPrompt=k),placeholder:e.$t("suno.placeholder.lyricPrompt")},null,8,["modelValue","placeholder"])])):d("",!0),e.config?.custom?(n(),c("div",As,[s("div",Us,[s("span",Es,a(e.$t("suno.name.weirdness")),1),s("span",Ps,a(e.weirdness??0),1)]),o(_,{modelValue:e.weirdness,"onUpdate:modelValue":t[2]||(t[2]=k=>e.weirdness=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0),e.config?.custom?(n(),c("div",Is,[s("div",Ts,[s("span",Gs,a(e.$t("suno.name.styleInfluence")),1),s("span",Ls,a(e.styleInfluence??50),1)]),o(_,{modelValue:e.styleInfluence,"onUpdate:modelValue":t[3]||(t[3]=k=>e.styleInfluence=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0),e.isV5OrAbove?(n(),c("div",Fs,[s("div",js,[s("span",Ds,a(e.$t("suno.name.variationCategory")),1)]),o(g,{modelValue:e.variationCategory,"onUpdate:modelValue":t[4]||(t[4]=k=>e.variationCategory=k)},{default:r(()=>[o(m,{value:""},{default:r(()=>[w(a(e.$t("suno.gender.auto")),1)]),_:1}),o(m,{value:"high"},{default:r(()=>[w(a(e.$t("suno.variation.high")),1)]),_:1}),o(m,{value:"low"},{default:r(()=>[w(a(e.$t("suno.variation.low")),1)]),_:1})]),_:1},8,["modelValue"])])):d("",!0),e.config?.action==="cover"?(n(),c("div",zs,[s("div",Rs,[s("span",Ms,a(e.$t("suno.name.audioWeight")),1),s("span",Os,a(e.audioWeight??50),1)]),o(_,{modelValue:e.audioWeight,"onUpdate:modelValue":t[5]||(t[5]=k=>e.audioWeight=k),min:0,max:100,step:1},null,8,["modelValue"])])):d("",!0)]),_:1},8,["title"])]),_:1},8,["modelValue"])}const Ws=A(ys,[["render",Ns],["__scopeId","data-v-a6d82e2a"]]),qs=C({name:"ReplaceSectionInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),Bs={class:"field"},Ks={class:"flex items-center mb-2"},Hs={class:"text-sm font-bold m-0"},Js={key:0,class:"task mb-2"},Ys={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Qs={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 eo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",Bs,[s("div",Ks,[s("h2",Hs,a(e.$t("suno.name.replaceSection")),1),o(p,{content:e.$t("suno.description.replaceSection")},null,8,["content"])]),e.audio?(n(),c("div",Js,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",Ys,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Qs,[s("h2",Xs,a(e.audio?.title),1),s("p",Zs,a(e.audio?.style),1)])])])):d("",!0),s("div",xs,[o(m,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.replaceSectionStart=v),class:"flex-1",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.replaceSectionStart")},null,8,["modelValue","max","placeholder"]),o(m,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.replaceSectionEnd=v),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 to=A(qs,[["render",eo]]),so=C({name:"OverpaintingInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),oo={class:"field"},no={class:"flex items-center mb-2"},io={class:"text-sm font-bold m-0"},ao={key:0,class:"task mb-2"},lo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ro={class:"info flex-1 min-w-0"},uo={class:"text-sm font-bold m-0 truncate"},co={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},po={class:"flex gap-2"};function mo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",oo,[s("div",no,[s("h2",io,a(e.$t("suno.name.overpaintingRange")),1),o(p,{content:e.$t("suno.description.overpainting")},null,8,["content"])]),e.audio?(n(),c("div",ao,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",lo,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",ro,[s("h2",uo,a(e.audio?.title),1),s("p",co,a(e.audio?.style),1)])])])):d("",!0),s("div",po,[o(m,{modelValue:e.overpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.overpaintingStart=v),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(m,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.overpaintingEnd=v),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 fo=A(so,[["render",mo]]),ho=C({name:"UnderpaintingInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),_o={class:"field"},go={class:"flex items-center mb-2"},$o={class:"text-sm font-bold m-0"},vo={key:0,class:"task mb-2"},yo={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},ko={class:"info flex-1 min-w-0"},bo={class:"text-sm font-bold m-0 truncate"},wo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},Co={class:"flex gap-2"};function Vo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",_o,[s("div",go,[s("h2",$o,a(e.$t("suno.name.underpaintingRange")),1),o(p,{content:e.$t("suno.description.underpainting")},null,8,["content"])]),e.audio?(n(),c("div",vo,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",yo,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",ko,[s("h2",bo,a(e.audio?.title),1),s("p",wo,a(e.audio?.style),1)])])])):d("",!0),s("div",Co,[o(m,{modelValue:e.underpaintingStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.underpaintingStart=v),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(m,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.underpaintingEnd=v),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 So=A(ho,[["render",Vo]]),Ao=C({name:"SamplesInput",components:{ElInputNumber:W,ElImage:L,InfoIcon:P},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"})}}}),Uo={class:"field"},Eo={class:"flex items-center mb-2"},Po={class:"text-sm font-bold m-0"},Io={key:0,class:"task mb-2"},To={class:"left relative w-[50px] h-[50px] mr-3 flex-shrink-0"},Go={class:"info flex-1 min-w-0"},Lo={class:"text-sm font-bold m-0 truncate"},Fo={class:"text-xs text-[var(--el-text-color-secondary)] m-0 truncate"},jo={class:"flex gap-2"};function Do(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-image"),m=i("el-input-number"),g=j("loading");return n(),c("div",Uo,[s("div",Eo,[s("h2",Po,a(e.$t("suno.name.samplesRange")),1),o(p,{content:e.$t("suno.description.samples")},null,8,["content"])]),e.audio?(n(),c("div",Io,[s("div",{class:"audio flex items-center",onClick:t[0]||(t[0]=v=>e.onClick(e.audio))},[F((n(),c("div",To,[o(_,{src:e.audio?.image_url,class:"w-full h-full rounded",fit:"cover"},null,8,["src"])])),[[g,!e.audio?.audio_url]]),s("div",Go,[s("h2",Lo,a(e.audio?.title),1),s("p",Fo,a(e.audio?.style),1)])])])):d("",!0),s("div",jo,[o(m,{modelValue:e.samplesStart,"onUpdate:modelValue":t[1]||(t[1]=v=>e.samplesStart=v),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(m,{modelValue:e.samplesEnd,"onUpdate:modelValue":t[2]||(t[2]=v=>e.samplesEnd=v),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 zo=A(Ao,[["render",Do]]),Ro=C({name:"PersonaInput",components:{ElInput:z,InfoIcon:P},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})}}}}),Mo={class:"field"},Oo={class:"flex items-center mb-2"},No={class:"text-sm font-bold m-0"};function Wo(e,t,u,l,$,h){const p=i("info-icon"),_=i("el-input");return n(),c("div",Mo,[s("div",Oo,[s("h2",No,a(e.$t("suno.name.persona")),1),o(p,{content:e.$t("suno.description.persona")},null,8,["content"])]),o(_,{modelValue:e.personaId,"onUpdate:modelValue":t[0]||(t[0]=m=>e.personaId=m),size:"small",placeholder:e.$t("suno.placeholder.personaId")},null,8,["modelValue","placeholder"])])}const qo=A(Ro,[["render",Wo]]),Bo=C({name:"PresetPanel",components:{TypeSelector:at,PromptInput:kt,LyricInput:Et,StyleInput:jt,TitleInput:Nt,ExtendFromInput:ts,CoverFromInput:ms,UploadAudio:ft,VocalGenderSelector:vs,AdvancedParams:Ws,ReplaceSectionInput:to,OverpaintingInput:fo,UnderpaintingInput:So,SamplesInput:zo,PersonaInput:qo,FontAwesomeIcon:D,ElButton:N,Consumption:ze},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Re(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){const e=this.config?.model||"";return["chirp-v4-5-plus","chirp-v5","chirp-v5-5"].includes(e)},supportsPersona(){const e=this.config?.action;return!e||e==="generate"||e==="artist_consistency"||e==="artist_consistency_vox"},generateButtonText(){const e=this.config?.action;return e==="extend"?this.$t("suno.button.extend"):e==="cover"?this.$t("suno.button.cover_music"):e==="remaster"?this.$t("suno.button.remaster"):e==="replace_section"?this.$t("suno.button.replace_section"):e==="mashup"?this.$t("suno.button.mashup"):e==="stems"?this.$t("suno.button.get_stems"):e==="concat"?this.$t("suno.button.concat_music"):e==="upload_cover"?this.$t("suno.button.upload_cover"):e==="artist_consistency"?this.$t("suno.button.artist_consistency"):e==="artist_consistency_vox"?this.$t("suno.button.artist_consistency_vox"):e==="overpainting"?this.$t("suno.button.overpainting"):e==="underpainting"?this.$t("suno.button.underpainting"):e==="samples"?this.$t("suno.button.samples"):this.$t("suno.button.generate")}},methods:{onGenerate(){this.$emit("generate")}}}),Ko={class:"flex flex-col h-full"},Ho={class:"flex-1 overflow-y-auto p-5"},Jo={class:"flex flex-col items-center justify-center px-5 pb-5"};function Yo(e,t,u,l,$,h){const p=i("type-selector"),_=i("upload-audio"),m=i("prompt-input"),g=i("lyric-input"),v=i("style-input"),E=i("title-input"),k=i("vocal-gender-selector"),S=i("persona-input"),B=i("extend-from-input"),K=i("cover-from-input"),Q=i("replace-section-input"),f=i("overpainting-input"),V=i("underpainting-input"),ne=i("samples-input"),ie=i("advanced-params"),ae=i("consumption"),le=i("font-awesome-icon"),re=i("el-button");return n(),c("div",Ko,[s("div",Ho,[o(p,{class:"mb-4"}),o(_,{class:"mb-4"}),e.config?.custom?d("",!0):(n(),y(m,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(n(),y(g,{key:1,class:"mb-4"})):d("",!0),e.config?.custom?(n(),y(v,{key:2,class:"mb-4"})):d("",!0),e.config?.custom?(n(),y(E,{key:3,class:"mb-4"})):d("",!0),e.config?.custom&&!e.config.instrumental&&e.supportsVocalGender?(n(),y(k,{key:4,class:"mb-4"})):d("",!0),e.config?.custom&&e.supportsPersona?(n(),y(S,{key:5,class:"mb-4"})):d("",!0),e.config?.action==="extend"?(n(),y(B,{key:6,class:"mb-4"})):d("",!0),e.config?.action==="cover"?(n(),y(K,{key:7,class:"mb-4"})):d("",!0),e.config?.action==="replace_section"?(n(),y(Q,{key:8,class:"mb-4"})):d("",!0),e.config?.action==="overpainting"?(n(),y(f,{key:9,class:"mb-4"})):d("",!0),e.config?.action==="underpainting"?(n(),y(V,{key:10,class:"mb-4"})):d("",!0),e.config?.action==="samples"?(n(),y(ne,{key:11,class:"mb-4"})):d("",!0),o(ie,{class:"mb-4"})]),s("div",Jo,[o(ae,{value:e.consumption,service:e.service},null,8,["value","service"]),o(re,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:r(()=>[o(le,{icon:"fa-solid fa-magic",class:"mr-2"}),w(" "+a(e.generateButtonText),1)]),_:1},8,["onClick"])])])}const Qo=A(Bo,[["render",Yo],["__scopeId","data-v-a9d5cfc6"]]),oe="https://webhook.acedata.cloud/suno",Xo=C({name:"TaskPreview",components:{ElImage:L,ElIcon:Y,ElTooltip:ye,FontAwesomeIcon:D,VideoPlay:ee,VideoPause:x,ElDropdown:ve,ElDropdownMenu:$e,ElDropdownItem:ge,Loading:_e},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===R.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(u=>({...u,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:O,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 l=new URL(t).pathname,$=l.substring(l.lastIndexOf("/")+1);console.log("on preview",$),fetch(t).then(h=>h.blob()).then(h=>{Ge.saveAs(h,$)})},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),b.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,u)=>{const l={audio_id:e},$=this.credential?.token;if(!$){console.error("no token specified"),u(new Error("No token specified"));return}I.mp4(l,{token:$}).then(h=>{const p=h.data?.data?.video_url;p?t(p):u(new Error("Video URL not found in response"))}).catch(h=>{u(h)})})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onRemaster(e){await this.onGenerateAudioUrl("remaster",e)},async onGetAllStems(e){await this.onGenerateAudioUrl("all_stems",e)},onReplaceSection(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"replace_section",audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"mashup",audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"overpainting",audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"underpainting",audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"samples",audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:"artist_consistency",audio:e,audio_id:e.id})},async onExtractVocals(e){const t=this.credential?.token;t&&(b.info(this.$t("suno.message.extractingVocals")),I.vox({audio_id:e,callback_url:oe},{token:t}).then(()=>{b.success(this.$t("suno.message.extractVocalsSuccess"))}).catch(u=>{b.error(u?.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&&(b.info(this.$t("suno.message.fetchingTiming")),I.timing({audio_id:e},{token:t}).then(u=>{b.success(this.$t("suno.message.fetchTimingSuccess")),console.debug("timing data",u.data)}).catch(u=>{b.error(u?.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,b.info(this.$t("suno.message.fetchingWav"));const l=(await I.wav({audio_id:e.id},{token:t})).data?.data?.audio_url;l?this.onDownload(null,l):b.error(this.$t("suno.message.fetchWavFailed"))}catch{b.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,b.info(this.$t("suno.message.fetchingMidi"));const l=(await I.midi({audio_id:e.id},{token:t})).data?.data?.midi_url;l?this.onDownload(null,l):b.error(this.$t("suno.message.fetchMidiFailed"))}catch{b.error(this.$t("suno.message.fetchMidiFailed"))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){const u={action:e,audio_id:t,callback_url:oe},l=this.credential?.token;if(!l){console.error("no token specified");return}b.info(this.$t("suno.message.startingTask")),I.audio(u,{token:l}).then(()=>{b.success(this.$t("suno.message.startTaskSuccess"))}).catch($=>{b.error($?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),Zo={class:"task"},xo=["onClick"],en={class:"left"},tn=["onClick"],sn=["onClick"],on={key:2,class:"duration"},nn={class:"info"},an={class:"title"},ln={class:"style"},rn={class:"right"},un={class:"el-dropdown-link"},cn={class:"flex items-center min-w-[120px]"},dn={class:"flex items-center min-w-[120px]"},pn={class:"flex items-center min-w-[120px]"},mn={class:"el-dropdown-link"};function fn(e,t,u,l,$,h){const p=i("el-image"),_=i("video-pause"),m=i("el-icon"),g=i("video-play"),v=i("font-awesome-icon"),E=i("el-tooltip"),k=i("Loading"),S=i("el-dropdown-item"),B=i("el-dropdown-menu"),K=i("el-dropdown"),Q=j("loading");return n(),c("div",Zo,[(n(!0),c(M,null,J(e.audios,f=>(n(),c("div",{key:f.id,class:"audio",onClick:U(V=>e.onClick(f),["stop"])},[F((n(),c("div",en,[o(p,{src:f?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),f?.audio_url&&e.$store.state?.suno?.audio?.id===f.id&&e.$store.state?.suno?.audio?.state==="playing"?(n(),c("div",{key:0,class:"overlay",onClick:U(V=>e.onPause(f),["stop"])},[o(m,null,{default:r(()=>[o(_)]),_:1})],8,tn)):d("",!0),f?.audio_url&&(e.$store.state?.suno?.audio?.id!==f.id||e.$store.state?.suno?.audio?.id===f.id&&e.$store.state?.suno?.audio?.state==="paused")?(n(),c("div",{key:1,class:"overlay",onClick:U(V=>e.onPlay(f),["stop"])},[o(m,null,{default:r(()=>[o(g)]),_:1})],8,sn)):d("",!0),f?.duration?(n(),c("div",on,a(e.useFormatDuring(f?.duration)),1)):d("",!0)])),[[Q,!f?.audio_url]]),s("div",nn,[s("h2",an,a(f?.title),1),s("p",ln,a(f?.style),1)]),s("div",rn,[o(K,null,{dropdown:r(()=>[o(B,null,{default:r(()=>[o(S,{disabled:e.isFetchingVideoUrl,onClick:V=>e.handleVideoDownload(f)},{default:r(()=>[s("div",cn,[e.isFetchingVideoUrl?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),f?.audio_url?(n(),y(S,{key:0,onClick:U(V=>e.onDownload(V,f?.audio_url),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):d("",!0),o(S,{disabled:e.isFetchingWav,onClick:V=>e.handleWavDownload(f)},{default:r(()=>[s("div",dn,[e.isFetchingWav?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_wav")),1)])]),_:2},1032,["disabled","onClick"]),o(S,{disabled:e.isFetchingMidi,onClick:V=>e.handleMidiDownload(f)},{default:r(()=>[s("div",pn,[e.isFetchingMidi?(n(),y(m,{key:0,class:"is-loading mr-2"},{default:r(()=>[o(k)]),_:1})):d("",!0),s("span",null,a(e.$t("suno.button.download_midi")),1)])]),_:2},1032,["disabled","onClick"])]),_:2},1024)]),default:r(()=>[s("span",un,[o(E,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:r(()=>[f?.audio_url||f?.video_url?(n(),y(v,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):d("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(K,null,{dropdown:r(()=>[o(B,null,{default:r(()=>[f?.audio_url?(n(),y(S,{key:0,onClick:U(V=>e.onExtend(V,f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):d("",!0),f.id?(n(),y(S,{key:1,onClick:U(V=>e.onGetStems(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):d("",!0),f.id?(n(),y(S,{key:2,onClick:U(V=>e.onGetAllStems(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.all_stems")),1)]),_:2},1032,["onClick"])):d("",!0),o(S,{onClick:U(V=>e.onCover(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),f?.id?(n(),y(S,{key:3,onClick:U(V=>e.onRemaster(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.remaster")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:4,onClick:U(V=>e.onReplaceSection(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.replace_section")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:5,onClick:U(V=>e.onMashup(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.mashup")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id&&f?.action==="extend"?(n(),y(S,{key:6,onClick:U(V=>e.onConcatMusic(f?.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:7,onClick:U(V=>e.onOverpainting(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.overpainting")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:8,onClick:U(V=>e.onUnderpainting(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.underpainting")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:9,onClick:U(V=>e.onSamples(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.samples")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:10,onClick:U(V=>e.onArtistConsistency(f),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.artist_consistency")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:11,onClick:U(V=>e.onExtractVocals(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.extract_vocals")),1)]),_:2},1032,["onClick"])):d("",!0),f?.id?(n(),y(S,{key:12,onClick:U(V=>e.onGetTiming(f.id),["stop"])},{default:r(()=>[w(a(e.$t("suno.button.get_timing")),1)]),_:2},1032,["onClick"])):d("",!0)]),_:2},1024)]),default:r(()=>[s("span",mn,[o(E,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:r(()=>[f?.audio_url||f?.video_url?(n(),y(v,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):d("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,xo))),128))])}const hn=A(Xo,[["render",fn]]),_n={class:"player-slider"},gn=C({__name:"PlayerSlider",setup(e){const t=q(),u=G({get:()=>t.state.suno?.audio?.progress,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:p})}),l=G({get:()=>t.state.suno?.audio?.duration,set:p=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:p})}),$=()=>{},h=p=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:p});return(p,_)=>(n(),c("div",_n,[o(T(te),{modelValue:u.value,"onUpdate:modelValue":_[0]||(_[0]=m=>u.value=m),"show-tooltip":!1,min:0,max:l.value,onChange:h,onInput:$},null,8,["modelValue","max"])]))}}),$n={class:"flex player-song"},vn=["src"],yn={class:"ml-2 text-xs flex flex-col justify-between"},kn={class:"w-52 2xl:w-96 cursor-pointer truncate"},bn={class:"flex"},wn={class:"ml-2 text-dc"},Cn=C({__name:"PlayerSong",setup(e){const t=q(),u=G({get:()=>t.state.suno.audio,set:l=>t.commit("suno/setAudio",l)});return Se(u,(l,$)=>{if(l?.audio_url!==$?.audio_url){console.log("audio changed",l),l.object&&(console.log("111",l.object),l.object.pause(),delete l.object);const h=new Audio(l.audio_url);l.state==="playing"?h.play():h.pause(),h.addEventListener("loadedmetadata",()=>{h.currentTime=0,h.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:h.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:h})}else if(l?.progress!==$?.progress&&Math.abs(l.progress-l.object.currentTime)>2){console.log("progress changed",l.progress);const h=t.state.suno.audio;h.object&&(h.object.currentTime=h.progress)}else l?.state!==$?.state&&(console.log("state changed",l.state),l.object&&(l.state==="playing"?l.object.play():l.object.pause()));l?.volume!==$?.volume&&(console.log("volume changed",l.volume),l.object&&(l.object.volume=l.volume/100))}),(l,$)=>(n(),c("div",$n,[s("img",{alt:"",class:"w-11 h-11 rounded",src:u.value?.image_url||T(Le)},null,8,vn),s("div",yn,[s("div",kn,[s("div",bn,[s("span",null,a(u.value?.title||"Music"),1),s("span",wn,"- "+a(u.value?.style||"SmallRuralDog"),1)])])])]))}}),Vn={class:"flex justify-end items-center gap-x-2.5"},Sn={class:"text-xs"},An=C({__name:"PlayerAction",setup(e){const t=q(),u=G({get:()=>t.state.suno?.audio?.progress,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:$})}),l=G({get:()=>t.state.suno?.audio?.duration,set:$=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:$})});return($,h)=>(n(),c("div",Vn,[s("span",Sn,a(T(O)(u.value))+" / "+a(T(O)(l.value)),1)]))}}),Un={class:"player-volume flex flex-col items-center pt-2"},En={class:"text-sm mt-3"},Pn=C({__name:"PlayerVolumeSlider",setup(e){const t=q(),u=G({get:()=>t.state.suno.audio?.volume,set:h=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:h})}),l=G({get:()=>t.state.suno.audio?.muted,set:h=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:h})}),$=h=>t.dispatch("suno/setVolume",h);return(h,p)=>(n(),c("div",Un,[o(T(te),{modelValue:u.value,"onUpdate:modelValue":p[0]||(p[0]=_=>u.value=_),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:l.value,onInput:$},null,8,["modelValue","disabled"]),s("div",En,a(u.value),1)]))}}),In={class:"flex items-center justify-center gap-x-3"},Tn=C({__name:"PlayerController",setup(e){const t=q(),u=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),l=G(()=>t.state.suno.audio);return($,h)=>(n(),c("div",In,[o(se,{icon:l.value?.state==="playing"?T(Fe):T(je),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:u},null,8,["icon"]),o(T(ke),{placement:"top",width:"50px",trigger:"click"},{reference:r(()=>[o(se,{icon:T(De),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:r(()=>[o(Pn)]),_:1})]))}}),Gn={class:"flex flex-col items-stretch h-20"},Ln={class:"flex grow px-5 items-center"},Fn={class:"flex-1"},jn={class:"flex-1"},Dn={class:"flex-1"},zn=C({__name:"Player",setup(e){return(t,u)=>(n(),c("div",Gn,[o(gn),s("div",Ln,[s("div",Fn,[o(Cn)]),s("div",jn,[o(Tn)]),s("div",Dn,[o(An)])])]))}}),Rn=C({name:"RecentPanel",components:{ElSkeletonItem:we,ElSkeleton:be,TaskPreview:hn,Player:zn,NoTasks:Me,ScrollList:Te},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mn={key:0,class:"tasks"},On={class:"left w-[70px] p-[10px] flex items-center"},Nn={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Wn={key:2,class:"w-full flex-1 flex items-center justify-center"},qn={class:"h-20"};function Bn(e,t,u,l,$,h){const p=i("el-skeleton-item"),_=i("el-skeleton"),m=i("task-preview"),g=i("scroll-list"),v=i("no-tasks"),E=i("player");return n(),c(M,null,[e.tasks?.items===void 0?(n(),c("div",Mn,[(n(),c(M,null,J(3,k=>s("div",{key:k,class:"flex"},[s("div",On,[o(_,{animated:""},{template:r(()=>[o(p,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",Nn,[o(_,{animated:""},{template:r(()=>[o(p,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(p,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(g,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:r(()=>[(n(!0),c(M,null,J(e.tasks?.items,(k,S)=>(n(),y(m,{key:S,"model-value":k,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):d("",!0),e.tasks?.items?.length===0?(n(),c("div",Wn,[o(v)])):d("",!0),F(s("div",qn,[o(E)],512),[[Ae,!!e.$store?.state?.suno?.audio?.object]])],64)}const Kn=A(Rn,[["render",Bn]]),Hn=C({name:"TaskPreview",components:{IconPicture:Ve,ElImage:L,ElAvatar:Ce,ElIcon:Y},computed:{audio(){return this.$store.state.suno?.audio}}}),Jn={key:0,class:"size-full overflow-hidden"},Yn={class:"relative h-[300px]"},Qn={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},Xn={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"},Zn={class:"p-4"},xn={class:"flex items-center font-bold mb-2"},ei={class:"text-[var(--el-text-color-regular)] mb-2"},ti={class:"text-xs text-[var(--el-text-color-regular)]"},si={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},oi={key:1,class:"w-full h-full"};function ni(e,t,u,l,$,h){const p=i("icon-picture"),_=i("el-icon"),m=i("el-image"),g=i("el-avatar");return e.audio?.object?(n(),c("div",Jn,[s("div",Yn,[o(m,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:r(()=>[s("div",Qn,[o(_,{class:"text-3xl"},{default:r(()=>[o(p)]),_:1})])]),_:1},8,["src"]),s("h2",Xn,a(e.audio?.title),1)]),s("div",Zn,[s("div",xn,[o(g,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,a(e.audio?.title),1)]),s("p",ei,a(e.audio?.style),1),s("p",ti,a(e.$dayjs.format(e.audio?.created_at)),1),s("div",si,[s("p",null,a(e.audio?.lyric),1)])])])):(n(),c("div",oi))}const ii=A(Hn,[["render",ni]]),ai="https://webhook.acedata.cloud/suno",li=C({name:"SunoIndex",components:{Layout:Je,ConfigPanel:Qo,RecentPanel:Kn,PreviewPanel:ii},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===R.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===R.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===R.Request},needApply(){return this.$store.state.suno.status.getApplications===R.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await Oe({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(){Pe.create({application:this.application}).then(({data:e})=>{this.application=e,b.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ie&&b.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:u,createdAtMax:l}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",l),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:u,createdAtMax:l})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:ai},t=this.credential?.token;if(!t){console.error("no token specified");return}b.info(this.$t("suno.message.startingTask")),I.audio(e,{token:t}).then(()=>{b.success(this.$t("suno.message.startTaskSuccess"))}).catch(u=>{b.error(u?.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 ri(e,t,u,l,$,h){const p=i("config-panel"),_=i("recent-panel"),m=i("preview-panel"),g=i("layout");return n(),y(g,null,{config:r(()=>[o(p,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:r(()=>[o(_,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:r(()=>[o(m)]),_:1})}const wi=A(li,[["render",ri],["__scopeId","data-v-d1296b1a"]]);export{wi as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{E as T,a as D,b as E}from"./EditArray-
|
|
1
|
+
import{E as T,a as D,b as E}from"./EditArray-BFLjz-wW.js";import{h as U,_ as V}from"./index-muIEJvsu.js";import{M as F,k as A,N as _,x as q,A as B,j as L,B as N,p as j}from"./vendor-element-plus-DN048TGi.js";import{d as R,J as O,K as s,T as t,ai as n,G as l,R as o,Q as m,C as y,ag as Q,S as K,D as w,L as k,O as G,U as C}from"./vendor-vue-BhXato7y.js";import"./index.es-Bqj83sQx.js";import"./vendor-web3-CIJ0oOq5.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const J=R({name:"SiteIndex",components:{EditText:E,EditImage:D,EditArray:T,ElDivider:j,ElRow:N,ElImage:L,ElCol:B,ElCard:q,ElForm:_,ElSwitch:A,ElFormItem:F},data(){return{editing:{title:!1}}},computed:{site(){return this.$store.getters.site}},methods:{onSave(e){const a={...this.site,...e};U.update(this.site?.id,a).then(()=>{console.debug("getSite for id",this.site?.id),this.$store.dispatch("getSite")})}}}),M={class:"title"},W={class:"title"},z={class:"block w-full"},H={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},Y={class:"block w-full"},Z={class:"block tip"},x={class:"block w-full"},ee={class:"block tip"},te={class:"block w-full"},ie={class:"block tip"},se={class:"title"},le={class:"block w-full"},oe={class:"block tip"},ae={class:"block w-full"},de={class:"block tip"},ne={class:"title"},re={class:"block tip"},me={class:"block tip"},ue={class:"title"},pe={class:"w-full"},fe={class:"block tip w-full"},be={key:0},ve={class:"block w-full"},he={class:"block w-full"};function ce(e,a,$e,ge,we,ke){const f=n("el-col"),h=n("el-row"),u=n("el-divider"),d=n("el-form-item"),p=n("edit-text"),c=n("el-image"),$=n("edit-image"),I=n("edit-array"),b=n("el-form"),v=n("el-card"),g=n("el-switch");return w(),O(h,{class:"panel"},{default:s(()=>[t(f,{span:24},{default:s(()=>[t(h,null,{default:s(()=>[t(f,{span:24},{default:s(()=>[l("h2",M,o(e.$t("common.title.site")),1)]),_:1})]),_:1}),t(h,{gutter:15},{default:s(()=>[t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",W,o(e.$t("site.title.basicConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.origin")},{default:s(()=>[l("span",z,o(e.site.origin),1),l("span",H,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",P,[m(o(e.site.title)+" ",1),t(p,{"model-value":e.site.title,title:e.$t("site.title.editTitle"),placeholder:e.$t("site.placeholder.title"),onConfirm:a[0]||(a[0]=i=>e.onSave({title:i}))},null,8,["model-value","title","placeholder"])]),l("span",X,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",Y,[t(c,{src:e.site.logo,class:"logo"},null,8,["src"]),t($,{"model-value":e.site.logo,title:e.$t("site.title.editLogo"),tip:e.$t("site.message.editLogoTip"),onConfirm:a[1]||(a[1]=i=>e.onSave({logo:i}))},null,8,["model-value","title","tip"])]),l("span",Z,o(e.$t("site.message.logoTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.favicon")},{default:s(()=>[l("span",x,[t(c,{src:e.site.favicon,class:"favicon"},null,8,["src"]),t($,{"model-value":e.site.favicon,title:e.$t("site.title.editFavicon"),tip:e.$t("site.message.editFaviconTip"),onConfirm:a[2]||(a[2]=i=>e.onSave({favicon:i}))},null,8,["model-value","title","tip"])]),l("span",ee,o(e.$t("site.message.faviconTip")),1)]),_:1},8,["label"]),t(u,{"border-style":"dashed"}),t(d,{label:e.$t("site.field.admins")},{default:s(()=>[l("span",te,[m(o(e.site.admins?.join(", "))+" ",1),t(I,{"model-value":e.site?.admins||[],title:e.$t("site.title.editAdmins"),placeholder:e.$t("site.placeholder.admins"),tip:e.$t("site.message.adminsTip2"),min:1,"min-error-message":e.$t("site.message.atLeastOneAdmin"),onConfirm:a[3]||(a[3]=i=>e.onSave({admins:i}))},null,8,["model-value","title","placeholder","tip","min-error-message"])]),l("span",ie,o(e.$t("site.message.adminsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",se,o(e.$t("site.title.seoConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.description")},{default:s(()=>[l("span",le,[m(o(e.site.description)+" ",1),t(p,{"model-value":e.site.description,title:e.$t("site.title.editDescription"),placeholder:e.$t("site.placeholder.description"),onConfirm:a[4]||(a[4]=i=>e.onSave({description:i}))},null,8,["model-value","title","placeholder"])]),l("span",oe,o(e.$t("site.message.descriptionTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.keywords")},{default:s(()=>[l("span",ae,[m(o(e.site.keywords?.join(", "))+" ",1),t(I,{"model-value":e.site?.keywords||[],title:e.$t("site.title.editKeywords"),placeholder:e.$t("site.placeholder.keywords"),tip:e.$t("site.message.keywordsTip2"),onConfirm:a[5]||(a[5]=i=>e.onSave({keywords:i}))},null,8,["model-value","title","placeholder","tip"])]),l("span",de,o(e.$t("site.message.keywordsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1})]),_:1}),t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",ne,o(e.$t("site.title.distributionConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.distributionDefaultInviterId")},{default:s(()=>[m(o(e.site.distribution?.default_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.default_inviter_id,title:e.$t("site.title.editDistributionDefaultInviterId"),placeholder:e.$t("site.placeholder.editDistributionDefaultInviterId"),onConfirm:a[6]||(a[6]=i=>e.onSave({distribution:{...e.site.distribution,default_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",re,o(e.$t("site.message.distributionDefaultInviterIdTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.distributionForceInviterId")},{default:s(()=>[m(o(e.site.distribution?.force_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.force_inviter_id,title:e.$t("site.title.editDistributionForceInviterId"),placeholder:e.$t("site.placeholder.editDistributionForceInviterId"),onConfirm:a[7]||(a[7]=i=>e.onSave({distribution:{...e.site.distribution,force_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",me,o(e.$t("site.message.distributionForceInviterIdTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",ue,o(e.$t("site.title.featuresConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[(w(),y(K,null,Q(["chat","midjourney","qrart","nanobanana","openaiimage","seedream","seedance","suno","luma","pika","kling","flux","hailuo","headshots","wan","producer","serp","support"],(i,S)=>t(d,{key:S,label:e.$t("site.field.features"+i.charAt(0).toUpperCase()+i.slice(1))},{default:s(()=>[l("div",pe,[t(g,{"model-value":e.site.features[i]?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],enabled:r}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),l("span",fe,o(e.$t("site.message.features"+i.charAt(0).toUpperCase()+i.slice(1))),1),i==="support"?k((w(),y("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.wechat?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.qr")},{default:s(()=>[l("span",ve,[t(c,{src:e.site.features[i]?.wechat?.qr},null,8,["src"]),t($,{"model-value":e.site.features[i]?.wechat?.qr,title:e.$t("site.title.editQR"),tip:e.$t("site.message.editQRTip"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,qr:r}}}})},null,8,["model-value","title","tip","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.wechat?.enabled]]),t(d,{label:"Discord"},{default:s(()=>[t(g,{"model-value":e.site.features[i]?.discord?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.url")},{default:s(()=>[l("span",he,[m(o(e.site.features[i]?.discord?.url)+" ",1),t(p,{"model-value":e.site.features[i]?.discord?.url,title:e.$t("site.title.editUrl"),placeholder:e.$t("site.placeholder.editUrl"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,url:r}}}})},null,8,["model-value","title","placeholder","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.discord?.enabled]])],512)),[[C,e.site.features[i]?.enabled]]):G("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Fe=V(J,[["render",ce],["__scopeId","data-v-38430f7a"]]);export{Fe as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.menu[data-v-0fce633f]{border-right:none}.menu .el-menu-item[data-v-0fce633f]{height:40px}.profile[data-v-eeab02e4]{display:flex;flex-direction:column}.info[data-v-eeab02e4]{width:100%;display:flex;flex-direction:column;align-items:center;padding:50px 0 20px;height:200px!important;overflow:hidden;position:relative}.info .background[data-v-eeab02e4]{width:100%;height:100%;position:absolute;top:0;left:0;z-index:-1;background-repeat:no-repeat;background-size:cover;background-position:center;filter:blur(20px) brightness(.6)}.info .avatar[data-v-eeab02e4]{width:56px;height:56px;border-radius:50%;box-shadow:0 0 0 3px #2771864d}.info h2[data-v-eeab02e4]{font-size:18px;font-weight:600;color:#fff}.links[data-v-eeab02e4]{width:100%;flex:1;padding:20px}.links .link[data-v-eeab02e4]{height:44px;display:block;width:100%;cursor:pointer;margin-bottom:4px;position:relative;color:var(--el-text-color-primary);line-height:44px;border-radius:12px;padding:0 12px;transition:background-color .15s ease}.links .link[data-v-eeab02e4]:hover{background-color:var(--el-fill-color-extra-light)}.links .link .suffix[data-v-eeab02e4]{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--el-text-color-placeholder)}.links .link .icon[data-v-eeab02e4]{width:16px;height:16px;display:inline-block;position:relative;margin-right:10px;transform:translateY(-2%)}.links .link .text[data-v-eeab02e4]{font-size:14px}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as T}from"./index.es-Bqj83sQx.js";import{m as L,Y as X,O as R,P as M,u as F,w as V,_ as Z,$ as x,k as ee,t as z,q as te,H as oe,j as se}from"./vendor-element-plus-DN048TGi.js";import{d as $,C as c,G as l,T as t,E as G,K as p,ai as s,D as n,R as i,S as E,ag as C,J as y,M as I,Y as ne,Q as h,O as v}from"./vendor-vue-BhXato7y.js";import{_ as k,bK as le,bL as ae,bM as N,bN as K,bO as ie,au as q,bP as re,bQ as ce,bR as de,aN as ue,aJ as O}from"./index-muIEJvsu.js";import{p as H}from"./pasteUploadMixin-BurWbGNQ.js";import{I as U,S as pe}from"./ScrollList-ZiMJkMBw.js";import{I as J}from"./ImagePreview-eVaabJZn.js";import{C as me}from"./Consumption-DB4jsCIw.js";import{a as ge}from"./price-Bva0CFLK.js";import{C as fe}from"./CopyToClipboard-DY-UF17o.js";import{V as _e}from"./VideoPlayer-DCxEj90A.js";import{B as he}from"./BotPlaceholder-CcWrwFmL.js";import{N as ve}from"./NoTasks-Dk7Wt2AG.js";import{l as $e}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CIJ0oOq5.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const ke=$({name:"LayoutKling",components:{ElDrawer:X,ElButton:L,FontAwesomeIcon:T},data(){return{drawer:!1}}}),be={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ye={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Ve(e,o,m,g,b,w){const r=s("font-awesome-icon"),d=s("el-button"),a=s("el-drawer");return n(),c("div",be,[l("div",we,[G(e.$slots,"config",{},void 0,!0)]),l("div",ye,[G(e.$slots,"result",{},void 0,!0)]),t(d,{circle:"",class:"menu",onClick:o[0]||(o[0]=_=>e.drawer=!0)},{default:p(()=>[t(r,{icon:"fa-solid fa-magic"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[G(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Se=k(ke,[["render",Ve],["__scopeId","data-v-56d28e4b"]]),Ee=$({name:"ModelSelector",components:{ElSelect:M,ElOption:R},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"kling-v3",label:"v3"},{value:"kling-v3-omni",label:"v3-Omni"},{value:"kling-v2-6",label:"v2.6"},{value:"kling-v2-5-turbo",label:"v2.5-Turbo"},{value:"kling-v2-1-master",label:"v2.1-Master"},{value:"kling-v2-master",label:"v2-Master"},{value:"kling-v1-6",label:"v1.6"},{value:"kling-v1",label:"v1"},{value:"kling-video-o1",label:"Video-o1"}]}},computed:{value:{get(){return this.$store.state.kling?.config?.model},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,model:e})}}},mounted(){this.value||(this.value=le)}}),Ie={class:"field"},Te={class:"title font-bold"};function Le(e,o,m,g,b,w){const r=s("el-option"),d=s("el-select");return n(),c("div",Ie,[l("h2",Te,i(e.$t("pika.name.model")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=a=>e.value=a),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:p(()=>[(n(!0),c(E,null,C(e.options,a=>(n(),y(r,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=k(Ee,[["render",Le],["__scopeId","data-v-a1b940c0"]]),Ue=$({name:"ModeSelector",components:{ElSelect:M,ElOption:R},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"std",label:this.$t("kling.name.modeStd")},{value:"pro",label:this.$t("kling.name.modePro")}]}},computed:{value:{get(){return this.$store.state.kling?.config?.mode},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,mode:e})}}},mounted(){this.value||(this.value=ae)}}),Ae={class:"field"},Ge={class:"title font-bold"};function Re(e,o,m,g,b,w){const r=s("el-option"),d=s("el-select");return n(),c("div",Ae,[l("h2",Ge,i(e.$t("kling.name.mode")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=a=>e.value=a),class:"value",placeholder:e.$t("kling.placeholder.select"),clearable:!0},{default:p(()=>[(n(!0),c(E,null,C(e.options,a=>(n(),y(r,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=k(Ue,[["render",Re],["__scopeId","data-v-daa57765"]]),j=[{value:5,label:"5秒"},{value:10,label:"10秒"}],B=[{value:3,label:"3秒"},{value:5,label:"5秒"},{value:8,label:"8秒"},{value:10,label:"10秒"},{value:12,label:"12秒"},{value:15,label:"15秒"}],Pe=$({name:"DurationSelector",components:{ElSelect:M,ElOption:R},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],computed:{selectedModel(){return this.$store.state.kling?.config?.model||""},isV3Model(){return K.includes(this.selectedModel)},options(){return this.isV3Model?B:j},value:{get(){return this.$store.state.kling?.config?.duration},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling.config,duration:e})}}},watch:{isV3Model(e){const o=this.value,m=(e?B:j).map(g=>g.value);o!==void 0&&!m.includes(o)&&(this.value=N)}},mounted(){this.value||(this.value=N)}}),De={class:"field"},Ne={class:"title font-bold"};function Oe(e,o,m,g,b,w){const r=s("el-option"),d=s("el-select");return n(),c("div",De,[l("h2",Ne,i(e.$t("kling.name.duration")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=a=>e.value=a),class:"value",placeholder:e.$t("kling.placeholder.select")},{default:p(()=>[(n(!0),c(E,null,C(e.options,a=>(n(),y(r,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const je=k(Pe,[["render",Oe],["__scopeId","data-v-c4727eac"]]),Be=$({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state?.kling?.config?.aspect_ratio},set(e){console.debug("set ratio",e),this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=ie)}}),Fe={class:"text-sm font-bold mb-2 block"},ze={class:"items"},Ke=["onClick"],qe={class:"name"};function He(e,o,m,g,b,w){return n(),c("div",null,[l("span",Fe,i(e.$t("kling.name.ratio")),1),l("div",ze,[(n(!0),c(E,null,C(e.options,(r,d)=>(n(),c("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:a=>e.value=r.value},[l("div",{class:I(["preview",r.label])},[l("div",{class:"rect",style:ne({width:r.width+"px",height:r.height+"px"})},null,4)],2),l("p",qe,i(r.label),1)],10,Ke))),128))])])}const Je=k(Be,[["render",He],["__scopeId","data-v-cdb14b2f"]]),Qe=$({name:"StartImage",components:{ElUpload:F,ElButton:L,InfoIcon:U,FontAwesomeIcon:T,ImagePreview:J},mixins:[H],emits:["change"],data(){return{fileList:[],uploadUrl:q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.kling?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("kling.message.uploadReferencesExceed"))},onError(){V.error(this.$t("kling.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ye={class:"relative"},We={class:"flex justify-between"},Xe={class:"flex justify-start items-center"},Ze={class:"text-sm font-bold"};function xe(e,o,m,g,b,w){const r=s("info-icon"),d=s("image-preview"),a=s("font-awesome-icon"),_=s("el-button"),f=s("el-upload");return n(),c("div",Ye,[l("div",We,[l("div",Xe,[l("span",Ze,i(e.$t("kling.name.startImage")),1),t(r,{content:e.$t("kling.description.uploadStartImage")},null,8,["content"])])]),t(f,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:u})=>[u.url&&u.percentage!==void 0?(n(),y(d,{key:0,url:u.url,name:u.name,percentage:u.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[t(a,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+i(e.$t("kling.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const et=k(Qe,[["render",xe],["__scopeId","data-v-852a31cd"]]),tt=$({name:"EndImage",components:{ElUpload:F,ElButton:L,ImagePreview:J,InfoIcon:U,FontAwesomeIcon:T},mixins:[H],data(){return{fileList:[],uploadUrl:q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.kling?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){V.warning(this.$t("kling.message.uploadReferencesExceed"))},onError(){V.error(this.$t("kling.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ot={class:"relative"},st={class:"flex justify-between"},nt={class:"flex justify-start items-center"},lt={class:"text-sm font-bold"};function at(e,o,m,g,b,w){const r=s("info-icon"),d=s("image-preview"),a=s("font-awesome-icon"),_=s("el-button"),f=s("el-upload");return n(),c("div",ot,[l("div",st,[l("div",nt,[l("span",lt,i(e.$t("kling.name.endImage")),1),t(r,{content:e.$t("kling.description.uploadEndImage")},null,8,["content"])])]),t(f,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=u=>e.fileList=u),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:5,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:p(({file:u})=>[u.url&&u.percentage!==void 0?(n(),y(d,{key:0,url:u.url,name:u.name,percentage:u.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(u),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[t(a,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+i(e.$t("kling.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const it=k(tt,[["render",at],["__scopeId","data-v-e23f5fb8"]]),rt=$({name:"CfgScaleSelector",components:{ElSlider:x,InfoIcon:U,ElInputNumber:Z},computed:{value:{get(){return this.$store.state?.kling?.config?.cfg_scale},set(e){console.debug("set cfg_scale",e),this.$store.commit("kling/setConfig",{...this.$store.state?.kling?.config,cfg_scale:e})}}},mounted(){this.value||(this.value=re)}}),ct={class:"flex justify-between"},dt={class:"flex justify-start items-center"},ut={class:"text-sm font-bold"},pt={class:"flex justify-end items-center"},mt={class:"w-full"};function gt(e,o,m,g,b,w){const r=s("info-icon"),d=s("el-input-number"),a=s("el-slider");return n(),c("div",null,[l("div",ct,[l("div",dt,[l("span",ut,i(e.$t("kling.name.cfgScale")),1),t(r,{content:e.$t("kling.description.cfgScale")},null,8,["content"])]),l("div",pt,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=_=>e.value=_),"controls-position":"right"},null,8,["modelValue"])])]),l("div",mt,[t(a,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=_=>e.value=_),min:0,max:1,step:.1},null,8,["modelValue"])])])}const ft=k(rt,[["render",gt]]),_t=$({name:"GenerateAudioSelector",components:{ElSwitch:ee},computed:{selectedModel(){return this.$store.state.kling?.config?.model||""},selectedMode(){return this.$store.state.kling?.config?.mode||""},visible(){return!!(K.includes(this.selectedModel)||this.selectedModel==="kling-v2-6"&&this.selectedMode==="pro")},value:{get(){return this.$store.state.kling?.config?.generate_audio??ce},set(e){this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,generate_audio:e})}}},watch:{visible(e){!e&&this.value&&(this.value=!1)}}}),ht={key:0,class:"relative"},vt={class:"flex justify-between items-center"},$t={class:"text-sm font-bold"};function kt(e,o,m,g,b,w){const r=s("el-switch");return e.visible?(n(),c("div",ht,[l("div",vt,[l("span",$t,i(e.$t("kling.name.generateAudio")),1),t(r,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=d=>e.value=d),class:"value"},null,8,["modelValue"])])])):v("",!0)}const bt=k(_t,[["render",kt]]),wt="",yt=$({name:"PromptInput",components:{ElInput:z,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.kling?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=wt)}}),Vt={class:"field"},St={class:"box"},Et={class:"title font-bold"};function It(e,o,m,g,b,w){const r=s("info-icon"),d=s("el-input");return n(),c("div",Vt,[l("div",St,[l("h2",Et,i(e.$t("kling.name.prompt")),1),t(r,{content:e.$t("kling.description.prompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("kling.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Tt=k(yt,[["render",It],["__scopeId","data-v-64ef5737"]]),Lt="",Ct=$({name:"NegativePromptInput",components:{ElInput:z,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.kling?.config?.negative_prompt},set(e){console.debug("set prompt",e),this.$store.commit("kling/setConfig",{...this.$store.state.kling?.config,negative_prompt:e})}}},mounted(){this.prompt||(this.prompt=Lt)}}),Ut={class:"field"},At={class:"box"},Gt={class:"title font-bold"};function Rt(e,o,m,g,b,w){const r=s("info-icon"),d=s("el-input");return n(),c("div",Ut,[l("div",At,[l("h2",Gt,i(e.$t("kling.name.negativePrompt")),1),t(r,{content:e.$t("kling.description.negativePrompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("kling.placeholder.negativePrompt")},null,8,["modelValue","placeholder"])])}const Mt=k(Ct,[["render",Rt],["__scopeId","data-v-de98cf01"]]),Pt=$({name:"ConfigPanel",components:{ElButton:L,Consumption:me,FontAwesomeIcon:T,PromptInput:Tt,NegativePromptInput:Mt,ModelSelector:Ce,ModeSelector:Me,DurationSelector:je,RatioSelector:Je,StartImage:et,CfgScaleSelector:ft,GenerateAudioSelector:bt,EndImage:it},emits:["generate"],computed:{config(){return this.$store.state.kling?.config},consumption(){return ge(this.config,this.service?.cost)},service(){return this.$store.state.kling?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Dt={class:"flex flex-col h-full"},Nt={class:"flex-1 overflow-y-auto p-5"},Ot={class:"flex flex-col items-center justify-center px-5 pb-5"};function jt(e,o,m,g,b,w){const r=s("prompt-input"),d=s("model-selector"),a=s("ratio-selector"),_=s("start-image"),f=s("end-image"),u=s("duration-selector"),S=s("mode-selector"),A=s("generate-audio-selector"),Q=s("cfg-scale-selector"),Y=s("negative-prompt-input"),W=s("consumption"),P=s("font-awesome-icon"),D=s("el-button");return n(),c("div",Dt,[l("div",Nt,[t(r,{class:"mb-4"}),t(d,{class:"mb-4"}),t(a,{class:"mb-4"}),t(_,{class:"mb-2"}),t(f,{class:"mb-2"}),t(u,{class:"mb-4"}),t(S,{class:"mb-4"}),t(A,{class:"mb-4"}),t(Q,{class:"mb-4"}),t(Y,{class:"mb-4"})]),l("div",Ot,[t(W,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(n(),y(D,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(P,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("kling.button.extend")),1)]),_:1},8,["onClick"])):(n(),y(D,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(P,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("kling.button.generate")),1)]),_:1},8,["onClick"]))])])}const Bt=k(Pt,[["render",jt]]),Ft=$({name:"TaskPreview",components:{ElImage:se,CopyToClipboard:fe,FontAwesomeIcon:T,ElAlert:oe,VideoPlayer:_e,ElTooltip:te,ElButton:L},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.kling?.application},config(){return this.$store.state.kling?.config}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),zt={class:"preview"},Kt={class:"left"},qt={class:"main"},Ht={class:"bot"},Jt={class:"datetime"},Qt={class:"info"},Yt={key:0,class:"prompt mt-2"},Wt={key:0},Xt={key:1},Zt={key:0,class:I({content:!0,failed:!0})},xt={key:0,class:"mb-4"},eo={key:1,class:I({operations:!0,"mt-2":!0})},to={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},oo={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},so={key:1,class:I({content:!0})},no={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lo={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ao={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},io={key:2,class:I({content:!0})},ro={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},co={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function uo(e,o,m,g,b,w){const r=s("el-image"),d=s("video-player"),a=s("el-button"),_=s("el-tooltip"),f=s("font-awesome-icon"),u=s("copy-to-clipboard"),S=s("el-alert");return n(),c("div",zt,[l("div",Kt,[t(r,{src:"https://cdn.acedata.cloud/qpbbbb.jpg",class:"avatar"})]),l("div",qt,[l("div",Ht,[h(i(e.$t("kling.name.klingBot"))+" ",1),l("span",Jt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Qt,[e.modelValue?.request?.prompt?(n(),c("p",Yt,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(n(),c("span",Wt," - ("+i(e.$t("kling.status.pending"))+") ",1)),e.modelValue?.response?.state==="submitted"||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="completed"?(n(),c("span",Xt," - ("+i(e.$t("kling.status.processing"))+") ",1)):v("",!0)])):v("",!0)]),e.modelValue?.response?.success===!0?(n(),c("div",Zt,[e.modelValue?.response.video_url?(n(),c("div",xt,[t(d,{src:e.modelValue?.response.video_url},null,8,["src"])])):v("",!0),e.modelValue?.response.success?(n(),c("div",eo,[t(_,{class:"box-item",effect:"dark",content:e.$t("kling.message.downloadVideo"),placement:"top-start"},{default:p(()=>[e.modelValue?.response.video_url?(n(),y(a,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=A=>e.onDownload(A,e.modelValue?.response.video_url))},{default:p(()=>[h(i(e.$t("kling.button.download")),1)]),_:1})):v("",!0)]),_:1},8,["content"])])):v("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:p(()=>[l("p",to,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.model"))+": "+i(e.modelValue?.request?.model),1)]),l("p",oo,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):v("",!0),e.modelValue?.response?.success===!1?(n(),c("div",so,[t(S,{closable:!1,class:"failure"},{template:p(()=>[t(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("kling.name.failure")),1)]),default:p(()=>[l("p",no,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])]),l("p",lo,[t(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("kling.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(u,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),c("p",ao,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):v("",!0)]),_:1})])):v("",!0),e.modelValue?.response?.success===void 0?(n(),c("div",io,[t(S,{closable:!1,class:"info"},{template:p(()=>[t(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("kling.name.failure")),1)]),default:p(()=>[l("p",ro,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("kling.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),c("p",co,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("kling.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):v("",!0)]),_:1})])):v("",!0)])])}const po=k(Ft,[["render",uo],["__scopeId","data-v-43231066"]]),mo=$({name:"RecentPanel",components:{TaskPreview:po,NoTasks:ve,BotPlaceholder:he,ScrollList:pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.kling?.tasks,items:this.$store.state.kling?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),go={key:0},fo={key:2,class:"w-full h-full flex items-center justify-center"};function _o(e,o,m,g,b,w){const r=s("bot-placeholder"),d=s("task-preview"),a=s("scroll-list"),_=s("no-tasks");return n(),c(E,null,[e.tasks?.items===void 0?(n(),c("div",go,[t(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(a,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:o[0]||(o[0]=f=>e.$emit("reach-top"))},{default:p(()=>[(n(!0),c(E,null,C(e.tasks?.items,f=>(n(),y(d,{key:f.id,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),c("div",fo,[t(_)])):v("",!0)],64)}const ho=k(mo,[["render",_o]]),vo="https://webhook.acedata.cloud/kling",$o=$({name:"KlingIndex",components:{ConfigPanel:Bt,Layout:Se,RecentPanel:ho},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.kling?.status?.getApplications===O.Request},tasksLoading(){return this.$store.state.kling?.status?.getTasks===O.Request||this.fetchingTasks},credential(){return this.$store.state.kling.credential},config(){return this.$store.state.kling.config},tasks(){return this.$store.state.kling.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await $e({tasks:this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("kling/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("kling/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:g}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",g),this.fetchingTasks=!0;try{await this.$store.dispatch("kling/getTasks",{limit:o,createdAtMin:m,createdAtMax:g})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:vo},o=this.credential?.token;if(!o){console.error("no token specified");return}V.info(this.$t("kling.message.startingTask")),de.generate(e,{token:o}).then(()=>{V.success(this.$t("kling.message.startTaskSuccess"))}).catch(m=>{m?.response?.data?.error?.code===ue?V.error(this.$t("kling.message.usedUp")):V.error(this.$t("kling.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ko(e,o,m,g,b,w){const r=s("config-panel"),d=s("recent-panel"),a=s("layout");return n(),y(a,null,{config:p(()=>[t(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[t(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const jo=k($o,[["render",ko]]);export{jo as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as L}from"./index.es-Bqj83sQx.js";import{m as R,Y as q,O,P as D,k as z,u as N,w as E,t as H,q as J,H as Y,j as K}from"./vendor-element-plus-DN048TGi.js";import{d as g,C as r,G as l,T as t,E as G,K as u,ai as s,D as n,R as a,S as A,ag as U,J as y,M as I,Y as Q,O as v,Q as h,L as S,U as T}from"./vendor-vue-BhXato7y.js";import{_ as $,bS as W,bT as X,bU as Z,bV as x,au as ee,bW as te,aN as oe,aJ as j}from"./index-muIEJvsu.js";import{I as P,S as se}from"./ScrollList-ZiMJkMBw.js";import{V as M}from"./VideoPlayer-DCxEj90A.js";import{p as ne}from"./pasteUploadMixin-BurWbGNQ.js";import{I as ae}from"./ImagePreview-eVaabJZn.js";import{C as le}from"./Consumption-DB4jsCIw.js";import{a as ie}from"./price-Bva0CFLK.js";import{C as re}from"./CopyToClipboard-DY-UF17o.js";import{B as ce}from"./BotPlaceholder-CcWrwFmL.js";import{N as de}from"./NoTasks-Dk7Wt2AG.js";import{l as ue}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CIJ0oOq5.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const pe=g({name:"LayoutVeo",components:{ElDrawer:q,ElButton:R,FontAwesomeIcon:L},data(){return{drawer:!1}}}),me={class:"main flex flex-row flex-1"},fe={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ve={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function _e(e,o,m,_,b,k){const c=s("font-awesome-icon"),d=s("el-button"),i=s("el-drawer");return n(),r("div",me,[l("div",fe,[G(e.$slots,"config",{},void 0,!0)]),l("div",ve,[G(e.$slots,"result",{},void 0,!0)]),t(d,{circle:"",class:"menu",onClick:o[0]||(o[0]=w=>e.drawer=!0)},{default:u(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(i,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[G(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const he=$(pe,[["render",_e],["__scopeId","data-v-816b984c"]]),ge=g({name:"ModelSelector",components:{ElSelect:D,ElOption:O},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"},{value:"veo31-fast",label:"veo31-fast"},{value:"veo31",label:"veo31"},{value:"veo31-fast-ingredients",label:"veo31-fast-ingredients"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=W)}}),$e={class:"field"},be={class:"title font-bold"};function ke(e,o,m,_,b,k){const c=s("el-option"),d=s("el-select");return n(),r("div",$e,[l("h2",be,a(e.$t("veo.name.model")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:u(()=>[(n(!0),r(A,null,U(e.options,i=>(n(),y(c,{key:i.value,label:i.label,value:i.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const we=$(ge,[["render",ke],["__scopeId","data-v-a59d89c9"]]),ye=g({name:"ActionSelector",components:{ElSelect:D,ElOption:O},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"get1080p",label:this.$t("veo.button.action3")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Ve={class:"field"},Se={class:"title font-bold"},Te={class:"float-left"};function Ee(e,o,m,_,b,k){const c=s("el-option"),d=s("el-select");return n(),r("div",Ve,[l("h2",Se,a(e.$t("veo.name.action")),1),t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:u(()=>[(n(!0),r(A,null,U(e.options,i=>(n(),y(c,{key:i.value,label:i.label,value:i.value},{default:u(()=>[l("span",Te,a(i.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=$(ye,[["render",Ee],["__scopeId","data-v-ba5abc8a"]]),Ce=g({name:"TranslationSelector",components:{ElSwitch:z,InfoIcon:P},computed:{value:{get(){return this.$store.state.veo?.config?.translation},set(e){console.debug("set translation",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,translation:e})}}},mounted(){this.value===void 0&&(this.value=Z)}}),Ae={class:"relative"},Le={class:"flex justify-between"},Re={class:"flex justify-start items-center"},Ue={class:"text-sm font-bold"},Ge={class:"flex justify-end items-center"};function Pe(e,o,m,_,b,k){const c=s("info-icon"),d=s("el-switch");return n(),r("div",Ae,[l("div",Le,[l("div",Re,[l("span",Ue,a(e.$t("veo.name.translation")),1),t(c,{content:e.$t("veo.description.translation")},null,8,["content"])]),l("div",Ge,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=i=>e.value=i),class:"value"},null,8,["modelValue"])])])])}const je=$(Ce,[["render",Pe]]),Oe=g({name:"AspectRatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.veo?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=x)}}),De={class:"text-sm font-bold mb-2 block"},Me={class:"items"},Be=["onClick"],Fe={class:"name"};function qe(e,o,m,_,b,k){return n(),r("div",null,[l("span",De,a(e.$t("veo.name.ratio")),1),l("div",Me,[(n(!0),r(A,null,U(e.options,(c,d)=>(n(),r("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:i=>e.value=c.value},[l("div",{class:I(["preview",c.label])},[l("div",{class:"rect",style:Q({width:c.width+"px",height:c.height+"px"})},null,4)],2),l("p",Fe,a(c.label),1)],10,Be))),128))])])}const ze=$(Oe,[["render",qe],["__scopeId","data-v-0f16be77"]]),Ne=g({name:"VideoFromInput",components:{VideoPlayer:M},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),He={class:"relative"},Je={class:"flex mb-2"},Ye={class:"text-sm font-bold"};function Ke(e,o,m,_,b,k){const c=s("video-player");return n(),r("div",He,[l("div",Je,[l("span",Ye,a(e.$t("veo.name.action3")),1)]),l("div",null,[e.config?.video_url?(n(),y(c,{key:0,src:e.config?.video_url},null,8,["src"])):v("",!0)])])}const Qe=$(Ne,[["render",Ke]]),We=g({name:"StartEndImage",components:{ElUpload:N,ElButton:R,InfoIcon:P,FontAwesomeIcon:L,ImagePreview:ae},mixins:[ne],emits:["change"],data(){return{fileList:[],uploadUrl:ee()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){E.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){E.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Xe={class:"relative"},Ze={class:"flex justify-between"},xe={class:"flex justify-start items-center"},et={class:"text-sm font-bold"};function tt(e,o,m,_,b,k){const c=s("info-icon"),d=s("image-preview"),i=s("font-awesome-icon"),w=s("el-button"),f=s("el-upload");return n(),r("div",Xe,[l("div",Ze,[l("div",xe,[l("span",et,a(e.$t("veo.name.startEndImage")),1),t(c,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),t(f,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=p=>e.fileList=p),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:p})=>[p.url&&p.percentage!==void 0?(n(),y(d,{key:0,url:p.url,name:p.name,percentage:p.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(p),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:u(()=>[t(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(i,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+a(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ot=$(We,[["render",tt],["__scopeId","data-v-b8ddb8fb"]]),st="",nt=g({name:"PromptInput",components:{ElInput:H,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=st)}}),at={class:"field"},lt={class:"box"},it={class:"title font-bold"};function rt(e,o,m,_,b,k){const c=s("info-icon"),d=s("el-input");return n(),r("div",at,[l("div",lt,[l("h2",it,a(e.$t("veo.name.prompt")),1),t(c,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=i=>e.prompt=i),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ct=$(nt,[["render",rt],["__scopeId","data-v-84c55ea0"]]),dt=g({name:"ConfigPanel",components:{ElButton:R,Consumption:le,FontAwesomeIcon:L,PromptInput:ct,ModelSelector:we,StartEndImage:ot,ActionSelector:Ie,VideoFromInput:Qe,TranslationSelector:je,AspectRatioSelector:ze},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return ie(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ut={class:"flex flex-col h-full"},pt={class:"flex-1 overflow-y-auto p-5"},mt={class:"flex flex-col items-center justify-center px-5 pb-5"};function ft(e,o,m,_,b,k){const c=s("video-from-input"),d=s("action-selector"),i=s("translation-selector"),w=s("aspect-ratio-selector"),f=s("prompt-input"),p=s("model-selector"),V=s("start-end-image"),C=s("consumption"),B=s("font-awesome-icon"),F=s("el-button");return n(),r("div",ut,[l("div",pt,[S(t(c,{class:"mb-4"},null,512),[[T,e.config?.action==="get1080p"]]),t(d,{class:"mb-4"}),S(t(i,{class:"mb-4"},null,512),[[T,e.config?.action!=="get1080p"]]),S(t(w,{class:"mb-4"},null,512),[[T,e.config?.action==="image2video"]]),S(t(f,{class:"mb-4"},null,512),[[T,e.config?.action!=="get1080p"]]),S(t(p,{class:"mb-4"},null,512),[[T,e.config?.action!=="get1080p"]]),S(t(V,{class:"mb-2"},null,512),[[T,e.config?.action==="image2video"]])]),l("div",mt,[t(C,{value:e.consumption,service:e.service},null,8,["value","service"]),t(F,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(B,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+a(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const vt=$(dt,[["render",ft]]),_t=g({name:"TaskPreview",components:{ElImage:K,CopyToClipboard:re,FontAwesomeIcon:L,ElAlert:Y,VideoPlayer:M,ElTooltip:J,ElButton:R},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onGet1080p(e,o){console.debug("set config",o),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,video_id:o?.data?.[0]?.id,video_url:o?.data[0]?.video_url,action:"get1080p"})},onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),ht={class:"preview"},gt={class:"left"},$t={class:"main"},bt={class:"bot"},kt={class:"datetime"},wt={class:"info"},yt={key:0,class:"prompt mt-2"},Vt={key:0},St={key:1},Tt={key:0,class:I({content:!0,failed:!0})},Et={key:0,class:"mb-4"},It={key:1,class:I({operations:!0,"mt-2":!0})},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Lt={key:1,class:I({content:!0})},Rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Pt={key:2,class:I({content:!0})},jt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Dt(e,o,m,_,b,k){const c=s("el-image"),d=s("video-player"),i=s("el-button"),w=s("el-tooltip"),f=s("font-awesome-icon"),p=s("copy-to-clipboard"),V=s("el-alert");return n(),r("div",ht,[l("div",gt,[t(c,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),l("div",$t,[l("div",bt,[h(a(e.$t("veo.name.veoBot"))+" ",1),l("span",kt,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",wt,[e.modelValue?.request?.prompt?(n(),r("p",yt,[h(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(n(),r("span",Vt," - ("+a(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(n(),r("span",St," - ("+a(e.$t("veo.status.processing"))+") ",1)):v("",!0)])):v("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(n(),r("div",Tt,[e.modelValue?.response?.data[0]?.video_url?(n(),r("div",Et,[t(d,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):v("",!0),e.modelValue?.response.success?(n(),r("div",It,[t(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),y(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=C=>e.onGet1080p(C,e.modelValue?.response))},{default:u(()=>[h(a(e.$t("veo.button.action3")),1)]),_:1})):v("",!0)]),_:1},8,["content"]),t(w,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),y(i,{key:0,type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=C=>e.onDownload(C,e.modelValue?.response?.data[0]?.video_url))},{default:u(()=>[h(a(e.$t("veo.button.download")),1)]),_:1})):v("",!0)]),_:1},8,["content"])])):v("",!0),t(V,{closable:!1,class:"mt-2 success"},{default:u(()=>[l("p",Ct,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("veo.name.model"))+": "+a(e.modelValue?.request?.model),1)]),l("p",At,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):v("",!0),e.modelValue?.response?.success===!1?(n(),r("div",Lt,[t(V,{closable:!1,class:"failure"},{template:u(()=>[t(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("veo.name.failure")),1)]),default:u(()=>[l("p",Rt,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id},null,8,["content"])]),l("p",Ut,[t(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+a(e.$t("veo.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),t(p,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),r("p",Gt,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("veo.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(p,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):v("",!0)]),_:1})])):v("",!0),e.modelValue?.response?.success===void 0?(n(),r("div",Pt,[t(V,{closable:!1,class:"info"},{template:u(()=>[t(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+a(e.$t("veo.name.failure")),1)]),default:u(()=>[l("p",jt,[t(f,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),r("p",Ot,[t(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+a(e.$t("veo.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),t(p,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):v("",!0)]),_:1})])):v("",!0)])])}const Mt=$(_t,[["render",Dt],["__scopeId","data-v-4c98c3a2"]]),Bt=g({name:"RecentPanel",components:{TaskPreview:Mt,NoTasks:de,BotPlaceholder:ce,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Ft={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function zt(e,o,m,_,b,k){const c=s("bot-placeholder"),d=s("task-preview"),i=s("scroll-list"),w=s("no-tasks");return n(),r(A,null,[e.tasks?.items===void 0?(n(),r("div",Ft,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(i,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=f=>e.$emit("reach-top"))},{default:u(()=>[(n(!0),r(A,null,U(e.tasks?.items,(f,p)=>(n(),y(d,{key:p,"model-value":f},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),r("div",qt,[t(w)])):v("",!0)],64)}const Nt=$(Bt,[["render",zt]]),Ht="https://webhook.acedata.cloud/veo",Jt=g({name:"VeoIndex",components:{ConfigPanel:vt,Layout:he,RecentPanel:Nt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===j.Request||this.fetchingTasks},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ue({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("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:_}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("veo/getTasks",{limit:o,createdAtMin:m,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ht},o=this.credential?.token;if(!o){console.error("no token specified");return}E.info(this.$t("veo.message.startingTask")),te.generate(e,{token:o}).then(()=>{E.success(this.$t("veo.message.startTaskSuccess"))}).catch(m=>{m?.response?.data?.error?.code===oe?E.error(this.$t("veo.message.usedUp")):E.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Yt(e,o,m,_,b,k){const c=s("config-panel"),d=s("recent-panel"),i=s("layout");return n(),y(i,null,{config:u(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const fo=$(Jt,[["render",Yt]]);export{fo as default};
|