@acedatacloud/nexior 3.277.9 → 3.278.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/ApiCodeButton-C3W4LtUB.js +1 -0
- package/dist/assets/{AskUserQuestionCard-BO__kKe-.js → AskUserQuestionCard-j_jmA0-D.js} +2 -2
- package/dist/assets/Auth-DyQfWyhU.js +1 -0
- package/dist/assets/Bare-C7SSO2HH.js +1 -0
- package/dist/assets/BotPlaceholder-E0Ur6LDD.js +1 -0
- package/dist/assets/BottomFooter-Coy8gUiq.js +1 -0
- package/dist/assets/{Callback-Ds0Qhhfa.js → Callback-CHQhX-NO.js} +1 -1
- package/dist/assets/{Console-BvjrA-Id.js → Console-B1hCGk76.js} +1 -1
- package/dist/assets/Consumption-C3v4xGTO.js +1 -0
- package/dist/assets/Conversation-DIHoVLoF.js +3 -0
- package/dist/assets/CopyToClipboard-D1o-dyv3.js +1 -0
- package/dist/assets/{Detail-Cl54B-QS.js → Detail-DabGL3Du.js} +2 -2
- package/dist/assets/Extra-BnMUwI-A.js +1 -0
- package/dist/assets/{FilePreview-CEk-YWC4.js → FilePreview-BOcejUda.js} +1 -1
- package/dist/assets/Hailuo-CcLZYOcQ.js +1 -0
- package/dist/assets/History-YiNxOFaO.js +1 -0
- package/dist/assets/ImagePreview-B_BmQP_E.js +1 -0
- package/dist/assets/ImageWrapper-CqgtUTt-.js +1 -0
- package/dist/assets/Index-986_h1HR.js +1 -0
- package/dist/assets/Index-B9ijpbgE.js +1 -0
- package/dist/assets/Index-BBpMtv81.js +1 -0
- package/dist/assets/{Index-BsuuQ9Qp.js → Index-Bcup2f8Z.js} +1 -1
- package/dist/assets/Index-BqTTlCSO.js +1 -0
- package/dist/assets/Index-BrMouoyr.js +1 -0
- package/dist/assets/Index-BvznbM3d.js +1 -0
- package/dist/assets/Index-C2fUDB7K.js +1 -0
- package/dist/assets/Index-CEiKF6Kk.js +1 -0
- package/dist/assets/Index-CFGYwjjq.js +1 -0
- package/dist/assets/Index-CMV5f9-W.js +1 -0
- package/dist/assets/Index-CPGOW6pf.js +1 -0
- package/dist/assets/{Index-V_h8KuLe.js → Index-CQxivBoi.js} +1 -1
- package/dist/assets/Index-Ci3q4Cf_.js +1 -0
- package/dist/assets/Index-CnZM1TNE.js +1 -0
- package/dist/assets/Index-CwxRL1cp.js +1 -0
- package/dist/assets/Index-DDCtkGKq.js +1 -0
- package/dist/assets/Index-DKdty6BX.js +2 -0
- package/dist/assets/Index-DNsW7q_P.js +1 -0
- package/dist/assets/Index-DTx7keCo.js +1 -0
- package/dist/assets/Index-Dtt_uKlb.js +1 -0
- package/dist/assets/Index-Dz6e5mDD.js +1 -0
- package/dist/assets/Index-MK-8kZ9k.js +1 -0
- package/dist/assets/Index-b6E_eZVx.js +1 -0
- package/dist/assets/Index-wCq1UOIl.js +1 -0
- package/dist/assets/Index-xq9bdCfV.js +1 -0
- package/dist/assets/Invitees-DId6aoxP.js +1 -0
- package/dist/assets/List-CfSWYHJD.js +1 -0
- package/dist/assets/{List-BCTIkbqi.js → List-CnWG35Cv.js} +1 -1
- package/dist/assets/List-N9MHUGLT.js +1 -0
- package/dist/assets/{Login-D8lHpp8_.js → Login-ZkRB_fWm.js} +1 -1
- package/dist/assets/Main-DC6pe9Hl.css +1 -0
- package/dist/assets/Main-V4yM61gG.js +1 -0
- package/dist/assets/Model-Ca-nHvzH.js +1 -0
- package/dist/assets/Navigator-E58cuse1.js +4 -0
- package/dist/assets/NoTasks-Czm65vJ4.js +1 -0
- package/dist/assets/NotFound-BjA9ykZE.js +1 -0
- package/dist/assets/Pagination-DeCHT-PM.js +1 -0
- package/dist/assets/Pay-DSvvY9KB.js +1 -0
- package/dist/assets/{Player-C-7R8A5A.js → Player-C7Zoyb-g.js} +1 -1
- package/dist/assets/Seedance-Dsqi6eXq.js +1 -0
- package/dist/assets/Status-CJKkKwsI.js +1 -0
- package/dist/assets/{Subscribe-Cxb0qpvf.js → Subscribe-BdnJ-I5j.js} +1 -1
- package/dist/assets/TabSwitcher-DaGfiNGh.js +1 -0
- package/dist/assets/{Tts-C-6DTKCA.js → Tts-DjdS_pkj.js} +1 -1
- package/dist/assets/VideoPlayer-C5F3Jf17.js +1 -0
- package/dist/assets/{_Uint8Array-0UxlbjS_.js → _Uint8Array-3-KsyGhc.js} +1 -1
- package/dist/assets/{_baseClone-7uTPqT6Z.js → _baseClone-BG8qyJTx.js} +1 -1
- package/dist/assets/{_baseIteratee-Bt4PVrpe.js → _baseIteratee-jiBmvyYc.js} +1 -1
- package/dist/assets/{_initCloneObject-BJVAPsyT.js → _initCloneObject-ClDbGB1c.js} +1 -1
- package/dist/assets/alert-OvnfgMB-.js +1 -0
- package/dist/assets/avatar-CGS2cO-x.js +1 -0
- package/dist/assets/avatar-CTHa5OEM.js +1 -0
- package/dist/assets/{basic-qB2zBf_T.js → basic-BaLHvxkw.js} +1 -1
- package/dist/assets/button-DfsQodL-.js +1 -0
- package/dist/assets/card-DjyfNde2.js +1 -0
- package/dist/assets/castArray-BbtsObcD.js +1 -0
- package/dist/assets/{chat-DnQdfCwY.js → chat-DjIgeGDG.js} +1 -1
- package/dist/assets/checkbox-BAeQdLeW.js +1 -0
- package/dist/assets/{click-outside-DSZqOY28.js → click-outside-Bc_xOTXp.js} +1 -1
- package/dist/assets/{codingBridge-N0BY_pbA.js → codingBridge-CiyyRbRb.js} +1 -1
- package/dist/assets/{codingBridgeNotify-jR2fwnrs.js → codingBridgeNotify-CjCpVg4Q.js} +2 -2
- package/dist/assets/collapse-transition-C9jp2nDh.js +1 -0
- package/dist/assets/collapse-zZjSyR53.js +1 -0
- package/dist/assets/constants-CwLEZ_AF.js +3 -0
- package/dist/assets/container-BgEH5azS.js +1 -0
- package/dist/assets/{createTaskActions-H9Ak_ksZ.js → createTaskActions-CFfeCrRN.js} +1 -1
- package/dist/assets/date-picker-CpTCVLld.js +1 -0
- package/dist/assets/{debounce-BY7z7rFy.js → debounce-DDZaE3JE.js} +1 -1
- package/dist/assets/divider-LA__Fty9.js +1 -0
- package/dist/assets/drawer-Dpuj2uIl.js +1 -0
- package/dist/assets/dropdown-DhpaHW0b.js +1 -0
- package/dist/assets/empty-DA4nlQUv.js +1 -0
- package/dist/assets/{esm-BWKCQlE-.js → esm-B5K_w4bp.js} +1 -1
- package/dist/assets/esm-BwfXY7Jp.js +2 -0
- package/dist/assets/{esm-YSQHICP5.js → esm-C37xRURN.js} +3 -3
- package/dist/assets/esm-C882q9Kl.js +1 -0
- package/dist/assets/{esm-DrjL-zKA.js → esm-CMH1tVLr.js} +1 -1
- package/dist/assets/{esm-DtiDy7oQ.js → esm-CeezYReU.js} +2 -2
- package/dist/assets/{esm-C3UFPwEA.js → esm-Ck02AWWr.js} +1 -1
- package/dist/assets/{fish-Dtp6I8Fd.js → fish-D_IZAI95.js} +1 -1
- package/dist/assets/{flux-Dg2kTyMv.js → flux-BBB_MZCf.js} +1 -1
- package/dist/assets/{form-D0aSFxDK.js → form-DnBQT-zH.js} +2 -2
- package/dist/assets/{grokvideo-C6jRvGkV.js → grokvideo-Cd6Pej_-.js} +1 -1
- package/dist/assets/{hailuo-BBLTKTAc.js → hailuo-BW0HNO8M.js} +1 -1
- package/dist/assets/{headshots-Clf9mqgV.js → headshots-CEAWyKQo.js} +1 -1
- package/dist/assets/image-BLdTdN6v.js +1 -0
- package/dist/assets/index-CxBOJBZd.js +570 -0
- package/dist/assets/{index.browser.esm-D2oXUHNB.js → index.browser.esm-Dr5lQ_WG.js} +1 -1
- package/dist/assets/{index.es-DInZDd-8.js → index.es-Dw2lhymn.js} +2 -2
- package/dist/assets/input-number-DIoKTD0e.js +1 -0
- package/dist/assets/{install-ClulZuUd.js → install-CmiepWqE.js} +1 -1
- package/dist/assets/{isEqual-XQKSKR3y.js → isEqual-CE_hv887.js} +1 -1
- package/dist/assets/isPlainObject-Bo35bFi4.js +1 -0
- package/dist/assets/{kling-CIq0k3a9.js → kling-28InUIKx.js} +1 -1
- package/dist/assets/{luma-BTc_oEx8.js → luma-DvnCAypL.js} +1 -1
- package/dist/assets/{midjourney-CGSfGnTI.js → midjourney-BmPZMs3O.js} +1 -1
- package/dist/assets/{nanobanana-Co7IvZDU.js → nanobanana-ByMIuP8G.js} +1 -1
- package/dist/assets/{openaiimage-CiYgF1oS.js → openaiimage-BfkdmvD5.js} +1 -1
- package/dist/assets/{pagination-sho_4mvI.js → pagination-DC4Eh4yG.js} +3 -3
- package/dist/assets/{pika-DFeGWhry.js → pika-RDuFQTZH.js} +1 -1
- package/dist/assets/{pixverse-DPpyC5XF.js → pixverse-DfJ8R_7A.js} +1 -1
- package/dist/assets/popover-DCGISZxg.js +1 -0
- package/dist/assets/{producer-joKKn6M4.js → producer-DoTFIJf8.js} +1 -1
- package/dist/assets/progress-C3UHYIHi.js +6 -0
- package/dist/assets/{qrart-DmLZ7wWd.js → qrart-BXSZR12y.js} +1 -1
- package/dist/assets/radio-BmBXySlN.js +1 -0
- package/dist/assets/raf-NSjkkBtT.js +1 -0
- package/dist/assets/{repeat-click-bdfKzhUt.js → repeat-click-DbK3DhkT.js} +1 -1
- package/dist/assets/row-d76bUVm3.js +1 -0
- package/dist/assets/{runtime-Cvku-lF9.js → runtime-B1Eal4u3.js} +1 -1
- package/dist/assets/{scroll-Dk1pKbmY.js → scroll-ChHyik37.js} +1 -1
- package/dist/assets/scrollbar-DcyQ_b2c.js +1 -0
- package/dist/assets/{seedance-BPVDnit8.js → seedance-sRwpzrHn.js} +1 -1
- package/dist/assets/{seedream-1PZNci1g.js → seedream-DoGCfHzA.js} +1 -1
- package/dist/assets/select-B1uV_nnl.js +1 -0
- package/dist/assets/{serp-u19n44y7.js → serp-BivtyZn7.js} +1 -1
- package/dist/assets/skeleton-C4sltx62.js +1 -0
- package/dist/assets/slider-DqJsYqiE.js +1 -0
- package/dist/assets/solana-wallets-DV4PzTa7.js +2 -0
- package/dist/assets/solana-wallets-vue-Bfs5wP1l.js +16 -0
- package/dist/assets/{sora-DL1Eu3V_.js → sora-jRE0-dso.js} +1 -1
- package/dist/assets/strings-CaTtp-gD.js +1 -0
- package/dist/assets/{suno-D0R4gb6S.js → suno-CwNsysp6.js} +1 -1
- package/dist/assets/switch-BXfqi_p8.js +1 -0
- package/dist/assets/table-lRQt4LGt.js +1 -0
- package/dist/assets/tabs-D9l1-5D5.js +1 -0
- package/dist/assets/{taskDrawerMixin-Cr17Yxqk.js → taskDrawerMixin-DEgO_R5H.js} +1 -1
- package/dist/assets/teleport-CVHCI9MK.js +1 -0
- package/dist/assets/{tooltip-C3PYfh8V.js → tooltip-BLwTovWL.js} +1 -1
- package/dist/assets/upload-SS_pZz4k.js +1 -0
- package/dist/assets/{use-aria-B1wQLdcx.js → use-aria-ldhUoRRB.js} +1 -1
- package/dist/assets/use-deprecated-BzKQGDXN.js +1 -0
- package/dist/assets/use-dialog-CLGp3CMB.js +1 -0
- package/dist/assets/{vendor-chart-mdwpew_o.js → vendor-chart-BJCvKk8-.js} +1 -1
- package/dist/assets/{vendor-vue-router-ChMPprnO.js → vendor-vue-router-WDnlh53U.js} +1 -1
- package/dist/assets/{veo-CYfZPVE4.js → veo-CT03Jgwu.js} +1 -1
- package/dist/assets/vnode-BC_9e2sB.js +1 -0
- package/dist/assets/{wan-dwlkdz78.js → wan-CNWQl-J0.js} +1 -1
- package/dist/assets/{web-CqJ0KFOe.js → web-Bafgko4b.js} +1 -1
- package/dist/assets/{web-_Pa-5yYB.js → web-BuRFWZZM.js} +1 -1
- package/dist/assets/{web-CiJfTemP.js → web-Cuvolsnb.js} +1 -1
- package/dist/assets/{web-BCYCv9_i.js → web-D7nDzK4F.js} +1 -1
- package/dist/assets/{web-BNYAxux2.js → web-D_grrLKi.js} +1 -1
- package/dist/assets/{webextrator-CxXqfJm3.js → webextrator-UWXgV4-n.js} +1 -1
- package/dist/assets/wechat-CBB0_nqe.js +1 -0
- package/dist/index.html +13 -13
- package/package.json +6 -3
- package/dist/assets/ApiCodeButton-C6gLCf-Z.js +0 -1
- package/dist/assets/Auth-rjG5v1Zu.js +0 -1
- package/dist/assets/Bare-Bv4yJF2-.js +0 -1
- package/dist/assets/BotPlaceholder-C_RrL6-x.js +0 -1
- package/dist/assets/BottomFooter-DYHEXkR8.js +0 -1
- package/dist/assets/Consumption-sxyES3IM.js +0 -1
- package/dist/assets/Conversation-B1LkXj8C.js +0 -3
- package/dist/assets/CopyToClipboard-D8uYio89.js +0 -1
- package/dist/assets/Extra-Bph1prs-.js +0 -1
- package/dist/assets/Hailuo-Du-s8XoS.js +0 -1
- package/dist/assets/History-CehzioRT.js +0 -1
- package/dist/assets/ImagePreview-A5Uxs7St.js +0 -1
- package/dist/assets/ImageWrapper-q6dGYlku.js +0 -1
- package/dist/assets/Index--SVe2gf_.js +0 -1
- package/dist/assets/Index-B7ye1jps.js +0 -1
- package/dist/assets/Index-BFRB5Ecn.js +0 -1
- package/dist/assets/Index-BMZ7QDn4.js +0 -1
- package/dist/assets/Index-BVgjeXqY.js +0 -1
- package/dist/assets/Index-BWmJj-Ec.js +0 -1
- package/dist/assets/Index-BoY2-aI0.js +0 -1
- package/dist/assets/Index-C3FIbYj_.js +0 -1
- package/dist/assets/Index-CMp0mfWb.js +0 -1
- package/dist/assets/Index-CSvFys2c.js +0 -1
- package/dist/assets/Index-CmmpTMc1.js +0 -1
- package/dist/assets/Index-CuP83G9I.js +0 -1
- package/dist/assets/Index-CwCpcpVC.js +0 -1
- package/dist/assets/Index-DAwffrvQ.js +0 -1
- package/dist/assets/Index-DHWhU527.js +0 -1
- package/dist/assets/Index-DY12tQiR.js +0 -1
- package/dist/assets/Index-DlHycozQ.js +0 -1
- package/dist/assets/Index-DpOrn0vY.js +0 -1
- package/dist/assets/Index-DqOVMWDG.js +0 -1
- package/dist/assets/Index-Dqq9aZ6K.js +0 -2
- package/dist/assets/Index-Tsvr1KQ_.js +0 -1
- package/dist/assets/Index-cvsVkl66.js +0 -1
- package/dist/assets/Index-ocSH7ZvZ.js +0 -1
- package/dist/assets/Index-t0Cs_RZ8.js +0 -1
- package/dist/assets/Invitees-RCGTpw5d.js +0 -1
- package/dist/assets/List-BzAI-ui9.js +0 -1
- package/dist/assets/List-Cr7s548x.js +0 -1
- package/dist/assets/Main-BqfD4til.js +0 -1
- package/dist/assets/Main-y41dJXZG.css +0 -1
- package/dist/assets/Model-Bekj6zqJ.js +0 -1
- package/dist/assets/Navigator-dkWMjJ7c.js +0 -4
- package/dist/assets/NoTasks-Ze_beGGE.js +0 -1
- package/dist/assets/NotFound-DdFf8s7r.js +0 -1
- package/dist/assets/Pagination-uSqRcf5u.js +0 -1
- package/dist/assets/Pay-CJG9KOs8.js +0 -1
- package/dist/assets/Seedance-BThH9nJK.js +0 -1
- package/dist/assets/Status-BEBUGjir.js +0 -1
- package/dist/assets/TabSwitcher-fa4ctxOn.js +0 -1
- package/dist/assets/VideoPlayer-DDKrB3TS.js +0 -1
- package/dist/assets/alert-BJj7gY4q.js +0 -1
- package/dist/assets/avatar-B-r-EyXw.js +0 -1
- package/dist/assets/avatar-DJGt2zYX.js +0 -1
- package/dist/assets/button-DWzbdjZV.js +0 -1
- package/dist/assets/card-B1OoUKT4.js +0 -1
- package/dist/assets/castArray-BFcmUPBb.js +0 -1
- package/dist/assets/checkbox-hfJFSY6z.js +0 -1
- package/dist/assets/collapse-ldIH3UFR.js +0 -1
- package/dist/assets/collapse-transition-C7m30vMg.js +0 -1
- package/dist/assets/constants-BvG5EAGh.js +0 -3
- package/dist/assets/container-DUnSq7iO.js +0 -1
- package/dist/assets/date-picker-DU59CcgU.js +0 -1
- package/dist/assets/divider-Ba_Z3oBh.js +0 -1
- package/dist/assets/drawer-BvYPSxXh.js +0 -1
- package/dist/assets/dropdown-Dbdq5MEd.js +0 -1
- package/dist/assets/empty-D5eN5M0S.js +0 -1
- package/dist/assets/esm-BNNSASAI.js +0 -2
- package/dist/assets/esm-BWW4nO7I.js +0 -1
- package/dist/assets/image-BIhkq-3S.js +0 -1
- package/dist/assets/index-BbCaZ5EZ.js +0 -570
- package/dist/assets/input-number-B63gxX1G.js +0 -1
- package/dist/assets/isPlainObject-2p88HvQz.js +0 -1
- package/dist/assets/popover-CUhgirVQ.js +0 -1
- package/dist/assets/progress-Djs_fbqu.js +0 -6
- package/dist/assets/radio-IJQsW93X.js +0 -1
- package/dist/assets/raf-Bo8-dFzL.js +0 -1
- package/dist/assets/row-CaRpmAhk.js +0 -1
- package/dist/assets/scrollbar-BkgtdYMt.js +0 -1
- package/dist/assets/select-BxVmNFP6.js +0 -1
- package/dist/assets/skeleton-Cn4UY-T8.js +0 -1
- package/dist/assets/slider-CZsrZNiU.js +0 -1
- package/dist/assets/solana-wallets-Dvz6LEc2.js +0 -2
- package/dist/assets/solana-wallets-vue-nV27NBhX.js +0 -16
- package/dist/assets/strings-DaYxHDzK.js +0 -1
- package/dist/assets/switch-qy9A_eGr.js +0 -1
- package/dist/assets/table-fY8LUehs.js +0 -1
- package/dist/assets/tabs-DwY1eAPe.js +0 -1
- package/dist/assets/teleport-B3tPbGeJ.js +0 -1
- package/dist/assets/upload-B6XSKv2u.js +0 -1
- package/dist/assets/use-deprecated-CPfQu7wa.js +0 -1
- package/dist/assets/use-dialog-Daprv7SC.js +0 -1
- package/dist/assets/vnode-BMVwTmkF.js +0 -1
- package/dist/assets/wechat-iv-pzVEX.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Ut as c,Vt as l,Wt as u,Z as d,b as f,k as p,tt as m,ut as h}from"./vendor-chart-BJCvKk8-.js";import{t as g}from"./button-DfsQodL-.js";import{r as _,t as v}from"./select-B1uV_nnl.js";import{t as y}from"./upload-SS_pZz4k.js";import{t as b}from"./tooltip-BLwTovWL.js";import{t as x}from"./image-BLdTdN6v.js";import{t as S}from"./alert-OvnfgMB-.js";import{Ct as C,Et as w,Ot as T,St as E,Tt as D,_i as O,_t as k,bt as A,vt as j,wt as ee,xt as te,yt as M}from"./constants-CwLEZ_AF.js";import{At as N,E as P,Fn as F,Nt as I,Ot as L,Sr as R,Zt as z,jt as B,kr as V,kt as H,yr as U}from"./index-CxBOJBZd.js";import{t as W}from"./index.es-Dw2lhymn.js";import{t as G}from"./CopyToClipboard-D1o-dyv3.js";import{t as K}from"./ImagePreview-B_BmQP_E.js";import{t as q}from"./BotPlaceholder-E0Ur6LDD.js";import{i as J,n as Y,t as X}from"./pagination-DC4Eh4yG.js";import{n as Z,t as Q}from"./NoTasks-Czm65vJ4.js";import{t as ne}from"./Consumption-C3v4xGTO.js";import{t as re}from"./ApiCodeButton-C3W4LtUB.js";import{t as ie}from"./Seedance-Dsqi6eXq.js";import{t as ae}from"./VideoPlayer-C5F3Jf17.js";var oe=r({name:`GrokVideoPromptInput`,components:{PromptTextarea:Z},computed:{prompt:{get(){return this.$store.state.grokvideo?.config?.prompt},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function se(e,t,n,r,i,o){let s=m(`prompt-textarea`);return d(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`grokvideo.name.prompt`),info:e.$t(`grokvideo.description.prompt`),placeholder:e.$t(`grokvideo.placeholder.prompt`),"min-rows":5},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var ce=P(oe,[[`render`,se]]),le=r({name:`GrokVideoModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:E,label:this.$t(`grokvideo.model.default`)},{value:te,label:this.$t(`grokvideo.model.preview15`)}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.model},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,model:e})}}},mounted(){this.value||=k}}),ue={class:`field`},de={class:`label`},fe={class:`box`},pe={class:`title font-bold`};function me(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,ue,[n(`div`,de,[n(`div`,fe,[n(`h2`,pe,u(r.$t(`grokvideo.name.model`)),1),o(g,{content:r.$t(`grokvideo.description.model`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var he=P(le,[[`render`,me],[`__scopeId`,`data-v-291d93fb`]]),ge=r({name:`GrokVideoDurationSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:3,label:`3s`},{value:5,label:`5s`},{value:6,label:`6s`},{value:8,label:`8s`},{value:10,label:`10s`},{value:12,label:`12s`},{value:15,label:`15s`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.duration},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,duration:e})}}},mounted(){this.value||=8}}),_e={class:`field`},ve={class:`label`},ye={class:`box`},be={class:`title font-bold`};function xe(r,i,c,l,f,p){let g=m(`info-icon`),_=m(`el-option`),v=m(`el-select`);return d(),t(`div`,_e,[n(`div`,ve,[n(`div`,ye,[n(`h2`,be,u(r.$t(`grokvideo.name.duration`)),1),o(g,{content:r.$t(`grokvideo.description.duration`),class:`info`},null,8,[`content`])])]),o(v,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`grokvideo.placeholder.select`)},{default:h(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(_,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Se=P(ge,[[`render`,xe],[`__scopeId`,`data-v-8b8ef5e7`]]),Ce=r({name:`GrokVideoResolutionSelector`,components:{InfoIcon:J},data(){return{options:[{value:D,label:`480p`},{value:w,label:`720p`}]}},computed:{value:{get(){return this.$store.state.grokvideo?.config?.resolution},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,resolution:e})}}},mounted(){this.value||=M}}),we={class:`resolution`},Te={class:`header`},Ee={class:`title font-bold`},De={class:`items`},Oe=[`onClick`];function ke(r,i,a,c,f,p){let h=m(`info-icon`);return d(),t(`div`,we,[n(`div`,Te,[n(`h2`,Ee,u(r.$t(`grokvideo.name.resolution`)),1),o(h,{content:r.$t(`grokvideo.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,De,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},u(e.label),11,Oe))),128))])])}var Ae=P(Ce,[[`render`,ke],[`__scopeId`,`data-v-f1ebb899`]]),je=r({name:`GrokVideoRatioSelector`,components:{InfoIcon:J},computed:{options(){return[{value:C,label:`16:9`,w:32,h:18},{value:ee,label:`9:16`,w:18,h:32},{value:`1:1`,label:`1:1`,w:24,h:24},{value:`4:3`,label:`4:3`,w:28,h:21},{value:`3:4`,label:`3:4`,w:21,h:28},{value:`3:2`,label:`3:2`,w:30,h:20},{value:`2:3`,label:`2:3`,w:20,h:30}]},value:{get(){return this.$store.state.grokvideo?.config?.aspect_ratio},set(e){this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,aspect_ratio:e})}}},mounted(){this.value||=j}}),Me={class:`ratio`},Ne={class:`header`},Pe={class:`title font-bold`},Fe={class:`items`},Ie=[`onClick`],Le={class:`preview`},Re={class:`name`};function ze(r,i,a,f,p,h){let g=m(`info-icon`);return d(),t(`div`,Me,[n(`div`,Ne,[n(`h2`,Pe,u(r.$t(`grokvideo.name.ratio`)),1),o(g,{content:r.$t(`grokvideo.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Fe,[(d(!0),t(s,null,e(r.options,e=>(d(),t(`div`,{key:e.value,class:l([`item`,{active:r.value===e.value}]),onClick:t=>r.value=e.value},[n(`div`,Le,[n(`div`,{class:`rect`,style:c({width:e.w+`px`,height:e.h+`px`})},null,4)]),n(`div`,Re,u(e.label),1)],10,Ie))),128))])])}var Be=P(je,[[`render`,ze],[`__scopeId`,`data-v-70115284`]]),Ve=r({name:`GrokVideoImageInput`,components:{ElUpload:y,ElButton:g,InfoIcon:J,FontAwesomeIcon:W,ImagePreview:K},mixins:[B,H],data(){return{fileList:[],uploadUrl:R()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},required(){return T(this.$store.state.grokvideo?.config?.model)},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){V.warning(this.$t(`grokvideo.message.uploadExceed`))},onError(){V.error(this.$t(`grokvideo.message.uploadError`))},onSetImageUrl(){let e=this.urls?.[0];this.$store.commit(`grokvideo/setConfig`,{...this.$store.state.grokvideo?.config,image_url:e||void 0})},async onSuccess(){this.onSetImageUrl()},async onRemove(){this.onSetImageUrl()}}}),He={class:`relative`},Ue={class:`flex justify-between`},We={class:`flex justify-start items-center`},Ge={class:`text-sm font-bold`},Ke={key:0,class:`required-badge`};function qe(e,r,s,c,l,f){let g=m(`info-icon`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`el-button`),b=m(`el-upload`);return d(),t(`div`,He,[n(`div`,Ue,[n(`div`,We,[n(`span`,Ge,u(e.$t(`grokvideo.name.image`)),1),e.required?(d(),t(`span`,Ke,u(e.$t(`grokvideo.name.required`)),1)):p(``,!0),o(g,{content:e.$t(`grokvideo.description.image`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:1,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):p(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+u(e.$t(`grokvideo.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])}var Je=r({name:`GrokVideoConfigPanel`,components:{ElButton:g,FontAwesomeIcon:W,PromptInput:ce,ModelSelector:he,DurationSelector:Se,ResolutionSelector:Ae,RatioSelector:Be,ImageInput:P(Ve,[[`render`,qe],[`__scopeId`,`data-v-164e5a1d`]]),Consumption:ne},emits:[`generate`],computed:{config(){return this.$store.state.grokvideo?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.grokvideo?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),Ye={class:`flex flex-col h-full`},Xe={class:`flex-1 overflow-y-auto p-5`},Ze={class:`flex flex-col items-center justify-center px-5 pb-5`};function Qe(e,r,a,s,c,l){let f=m(`prompt-input`),p=m(`model-selector`),g=m(`ratio-selector`),_=m(`resolution-selector`),v=m(`duration-selector`),y=m(`image-input`),b=m(`consumption`),x=m(`font-awesome-icon`),S=m(`el-button`);return d(),t(`div`,Ye,[n(`div`,Xe,[o(f,{class:`mb-4`}),o(p,{class:`mb-4`}),o(g,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-2`})]),n(`div`,Ze,[o(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(S,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`grokvideo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var $e=P(Je,[[`render`,Qe]]),et=r({name:`GrokVideoTaskPreview`,components:{ElImage:x,CopyToClipboard:G,FontAwesomeIcon:W,ElAlert:S,VideoPlayer:ae,ElTooltip:b,ElButton:g,ImagePreview:K,ApiCodeButton:re},props:{modelValue:{type:Object,required:!0}},data(){return{grokVideoLogo:A}},computed:{video(){return this.modelValue?.response?.data?.[0]},inputImage(){return this.modelValue?.request?.image_url}},methods:{onDownload(e){window.open(e,`_blank`)}}}),tt={class:`preview`},nt={class:`left`},rt={class:`main`},it={class:`bot`},at={class:`datetime`},ot={class:`info`},st={key:0,class:`flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto`},ct={key:1,class:`prompt mt-2`},lt={key:0},ut={key:1},dt={key:0,class:l({content:!0})},ft={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},pt={key:1,class:l({content:!0})},mt={key:0,class:`mb-4`},ht={key:1,class:l({operations:!0,"mt-2":!0,"mb-2":!0})},gt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},_t={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vt={key:2,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},yt={key:0},bt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},xt={key:3,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={key:4,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ct={key:2,class:l({content:!0})},wt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Tt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},$={key:3,class:l({content:!0})},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Ot(e,r,a,s,c,l){let g=m(`el-image`),_=m(`image-preview`),v=m(`font-awesome-icon`),y=m(`copy-to-clipboard`),b=m(`el-alert`),x=m(`video-player`),S=m(`el-button`),C=m(`el-tooltip`),w=m(`api-code-button`);return d(),t(`div`,tt,[n(`div`,nt,[o(g,{src:e.grokVideoLogo,class:`avatar`},null,8,[`src`])]),n(`div`,rt,[n(`div`,it,[i(u(e.$t(`grokvideo.name.bot`))+` `,1),n(`span`,at,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ot,[e.inputImage?(d(),t(`div`,st,[o(_,{url:e.inputImage,name:`image`,closable:!1},null,8,[`url`])])):p(``,!0),e.modelValue?.request?.prompt?(d(),t(`p`,ct,[i(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.state===`processing`||e.video?.state===`pending`?(d(),t(`span`,ut,` - (`+u(e.$t(`grokvideo.status.processing`))+`) `,1)):p(``,!0):(d(),t(`span`,lt,` - (`+u(e.$t(`grokvideo.status.pending`))+`) `,1))])):p(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(d(),t(`div`,pt,[e.video?.video_url?(d(),t(`div`,mt,[o(x,{src:e.video?.video_url},null,8,[`src`])])):p(``,!0),e.video?.video_url?(d(),t(`div`,ht,[o(C,{class:`box-item`,effect:`dark`,content:e.$t(`grokvideo.message.downloadVideo`),placement:`top-start`},{default:h(()=>[o(S,{type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=f(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:h(()=>[i(u(e.$t(`grokvideo.button.download`)),1)]),_:1})]),_:1},8,[`content`]),o(w,{path:`/grok/videos`,body:e.modelValue?.request},null,8,[`body`])])):p(``,!0),o(b,{closable:!1,class:`mt-2 success`},{default:h(()=>[e.modelValue?.request?.model?(d(),t(`p`,gt,[o(v,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.model`))+`: `+u(e.modelValue?.request?.model),1)])):p(``,!0),e.video?.duration?(d(),t(`p`,_t,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.duration`))+`: `+u(e.video?.duration)+`s `,1)])):p(``,!0),e.modelValue?.request?.resolution?(d(),t(`p`,vt,[o(v,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.resolution`))+`: `+u(e.modelValue?.request?.resolution)+` `,1),e.modelValue?.request?.aspect_ratio?(d(),t(`span`,yt,` · `+u(e.modelValue?.request?.aspect_ratio),1)):p(``,!0)])):p(``,!0),n(`p`,bt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(d(),t(`p`,xt,[o(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,St,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(d(),t(`div`,Ct,[o(b,{closable:!1,class:`failure`},{template:h(()=>[o(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failure`)),1)]),default:h(()=>[n(`p`,wt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(d(),t(`p`,Tt,[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,Et,[o(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):p(``,!0)]),_:1})])):(d(),t(`div`,$,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.status`)),1)]),default:h(()=>[n(`p`,Dt,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})])):(d(),t(`div`,dt,[o(b,{closable:!1,class:`info`},{template:h(()=>[o(v,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.status.pending`)),1)]),default:h(()=>[n(`p`,ft,[o(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`grokvideo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var kt=r({name:`GrokVideoRecentPanel`,components:{TaskPreview:P(et,[[`render`,Ot],[`__scopeId`,`data-v-cb4cd43a`]]),BotPlaceholder:q,NoTasks:Q,ScrollList:Y},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],computed:{tasks(){return{...this.$store.state.grokvideo?.tasks,items:this.$store.state.grokvideo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),At={key:0},jt={key:2,class:`w-full h-full flex items-center justify-center`};function Mt(n,r,i,c,l,u){let f=m(`bot-placeholder`),g=m(`task-preview`),_=m(`scroll-list`),v=m(`no-tasks`);return d(),t(s,null,[n.tasks?.items===void 0?(d(),t(`div`,At,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(d(),a(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:h(()=>[(d(!0),t(s,null,e(n.tasks?.items,e=>(d(),a(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):p(``,!0),n.tasks?.items?.length===0?(d(),t(`div`,jt,[o(v)])):p(``,!0)],64)}var Nt=P(kt,[[`render`,Mt]]),Pt=O(`grok`),Ft=r({name:`GrokVideoIndex`,components:{ConfigPanel:$e,Layout:ie,RecentPanel:Nt},mixins:[N],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.grokvideo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.grokvideo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.grokvideo?.credential},config(){return this.$store.state.grokvideo?.config},tasks(){return this.$store.state.grokvideo?.tasks}},watch:{initialized:{async handler(e){e&&(await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await X({tasks:this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){await this.$store.dispatch(`grokvideo/getService`)},async onScrollDown(){await this.$nextTick();let e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch(`grokvideo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!L(this.uploadTracker,e=>this.$t(e),e=>V.warning(e)))return;let e={...this.config||{}};typeof e?.prompt==`string`&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),typeof e?.image_url==`string`&&!e.image_url.trim()&&delete e.image_url;let t=!!e?.image_url;if(T(e?.model)&&!t){V.warning(this.$t(`grokvideo.message.modelRequiresImage`));return}if(!t&&!e?.prompt){V.warning(this.$t(`grokvideo.message.promptOrImageRequired`));return}let n={...e,callback_url:Pt},r=this.credential?.token;if(!r){console.error(`no token specified`);return}V.info(this.$t(`grokvideo.message.startingTask`)),F(`grokvideo`,z.generate(n,{token:r})).then(()=>{V.success(this.$t(`grokvideo.message.startTaskSuccess`))}).catch(e=>{let t=e?.response?.data;t?.error?.code===`used_up`?V.error(this.$t(`grokvideo.message.usedUp`)):V.error(this.$t(`grokvideo.message.startTaskFailed`)+(t?.error?.message||``))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function It(e,t,n,r,i,s){let c=m(`config-panel`),l=m(`recent-panel`),u=m(`layout`);return d(),a(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Lt=P(Ft,[[`render`,It]]);export{Lt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Ut as c,Vt as l,Wt as u,Z as d,dt as f,et as p,k as m,tt as h,ut as g,v as _}from"./vendor-chart-BJCvKk8-.js";import{t as v}from"./button-DfsQodL-.js";import{r as y,t as b}from"./select-B1uV_nnl.js";import{t as x}from"./upload-SS_pZz4k.js";import{t as S}from"./tooltip-BLwTovWL.js";import{t as C}from"./image-BLdTdN6v.js";import{t as w}from"./alert-OvnfgMB-.js";import{t as T}from"./drawer-Dpuj2uIl.js";import{t as E}from"./switch-BXfqi_p8.js";import{_i as D,cr as O,dr as k,fr as A,gr as j,lr as M,mr as N,pr as ee,ur as P,vr as F}from"./constants-CwLEZ_AF.js";import{At as I,E as L,Fn as te,Ir as R,Nt as ne,Ot as z,Sr as B,fn as V,jt as H,kr as U,kt as W,yr as G}from"./index-CxBOJBZd.js";import{t as K}from"./index.es-Dw2lhymn.js";import{t as q}from"./CopyToClipboard-D1o-dyv3.js";import{t as J}from"./ImagePreview-B_BmQP_E.js";import{n as Y}from"./taskDrawerMixin-DEgO_R5H.js";import{t as X}from"./BotPlaceholder-E0Ur6LDD.js";import{i as Z,n as re,t as ie}from"./pagination-DC4Eh4yG.js";import{n as ae,t as oe}from"./NoTasks-Czm65vJ4.js";import{t as se}from"./Consumption-C3v4xGTO.js";import{t as ce}from"./ApiCodeButton-C3W4LtUB.js";import{t as Q}from"./VideoPlayer-C5F3Jf17.js";var le=r({name:`LayoutVeo`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:K},mixins:[Y]}),ue={class:`main flex flex-row flex-1`},de={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},fe={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function pe(e,r,i,a,s,c){let l=h(`font-awesome-icon`),u=h(`el-button`),m=h(`el-drawer`);return d(),t(`div`,ue,[n(`div`,de,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,fe,[p(e.$slots,`result`,{},void 0,!0)]),f(o(u,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:g(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[_,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`350px`},{default:g(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var me=L(le,[[`render`,pe],[`__scopeId`,`data-v-12b82bc3`]]),he=r({name:`ModelSelector`,components:{ElSelect:y,ElOption:b},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||=k}}),ge={class:`field`},_e={class:`title font-bold`};function ve(r,i,c,l,f,p){let m=h(`el-option`),_=h(`el-select`);return d(),t(`div`,ge,[n(`h2`,_e,u(r.$t(`veo.name.model`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`veo.placeholder.select`)},{default:g(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(m,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ye=L(he,[[`render`,ve],[`__scopeId`,`data-v-a59d89c9`]]),be=r({name:`ActionSelector`,components:{ElSelect:y,ElOption:b},data(){return{}},computed:{options(){return[{value:`text2video`,label:this.$t(`veo.button.action1`)},{value:`image2video`,label:this.$t(`veo.button.action2`)},{value:`ingredients2video`,label:this.$t(`veo.button.actionIngredients`)},{value:`upsample`,label:this.$t(`veo.button.actionUpsample`)},{value:`extend`,label:this.$t(`veo.button.actionExtend`)},{value:`reshoot`,label:this.$t(`veo.button.actionReshoot`)},{value:`object_insert`,label:this.$t(`veo.button.actionObjectInsert`)},{value:`object_remove`,label:this.$t(`veo.button.actionObjectRemove`)}]},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||=O}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(r,i,c,l,f,p){let m=h(`el-option`),_=h(`el-select`);return d(),t(`div`,xe,[n(`h2`,Se,u(r.$t(`veo.name.action`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`veo.placeholder.select`),clearable:``},{default:g(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(m,{key:e.value,label:e.label,value:e.value},{default:g(()=>[n(`span`,Ce,u(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=L(be,[[`render`,we],[`__scopeId`,`data-v-f4d8785c`]]),Ee=r({name:`TranslationSelector`,components:{ElSwitch:E,InfoIcon:Z},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=!1)}}),De={class:`relative`},Oe={class:`flex justify-between`},ke={class:`flex justify-start items-center`},Ae={class:`text-sm font-bold`},je={class:`flex justify-end items-center`};function Me(e,r,i,a,s,c){let l=h(`info-icon`),f=h(`el-switch`);return d(),t(`div`,De,[n(`div`,Oe,[n(`div`,ke,[n(`span`,Ae,u(e.$t(`veo.name.translation`)),1),o(l,{content:e.$t(`veo.description.translation`)},null,8,[`content`])]),n(`div`,je,[o(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var Ne=L(Ee,[[`render`,Me]]),Pe=r({name:`AspectRatioSelector`,data(){return{options:[{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||=M}}),Fe={class:`text-sm font-bold mb-2 block`},Ie={class:`items`},Le=[`onClick`],Re={class:`name`};function ze(r,i,a,o,f,p){return d(),t(`div`,null,[n(`span`,Fe,u(r.$t(`veo.name.ratio`)),1),n(`div`,Ie,[(d(!0),t(s,null,e(r.options,(e,i)=>(d(),t(`div`,{key:i,class:l({active:r.active===i,item:!0}),onClick:t=>r.value=e.value},[n(`div`,{class:l([`preview`,e.label])},[n(`div`,{class:`rect`,style:c({width:e.width+`px`,height:e.height+`px`})},null,4)],2),n(`p`,Re,u(e.label),1)],10,Le))),128))])])}var Be=L(Pe,[[`render`,ze],[`__scopeId`,`data-v-28c472c4`]]),Ve=r({name:`VideoFromInput`,components:{VideoPlayer:Q},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`},Ue={class:`flex mb-2`},We={class:`text-sm font-bold`};function Ge(e,r,i,o,s,c){let l=h(`video-player`);return d(),t(`div`,He,[n(`div`,Ue,[n(`span`,We,u(e.$t(`veo.name.action3`)),1)]),n(`div`,null,[e.config?.video_url?(d(),a(l,{key:0,src:e.config?.video_url},null,8,[`src`])):m(``,!0)])])}var Ke=L(Ve,[[`render`,Ge]]),qe=r({name:`VideoIdInput`,components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.video_id},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,video_id:e})}}}}),Je={class:`field`},Ye={class:`title font-bold`};function Xe(e,r,i,a,s,c){let l=h(`el-input`);return d(),t(`div`,Je,[n(`h2`,Ye,u(e.$t(`veo.name.videoId`)),1),o(l,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.videoId`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var Ze=L(qe,[[`render`,Xe],[`__scopeId`,`data-v-6eba4026`]]),Qe=r({name:`StartEndImage`,components:{ElUpload:x,ElButton:v,InfoIcon:Z,FontAwesomeIcon:K,ImagePreview:J},mixins:[H,W],emits:[`change`],data(){return{fileList:[],uploadUrl:B()+`/api/v1/files/`}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||=void 0,this.onSetStartEndImageUrl()},methods:{onExceed(){U.warning(this.$t(`veo.message.uploadReferencesExceed`))},onError(){U.error(this.$t(`veo.message.uploadReferencesError`))},onSetStartEndImageUrl(){let e=this.urls;this.$store.commit(`veo/setConfig`,{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),$e={class:`relative`},et={class:`flex justify-between`},tt={class:`flex justify-start items-center`},nt={class:`text-sm font-bold`};function rt(e,r,s,c,l,f){let p=h(`info-icon`),_=h(`image-preview`),v=h(`font-awesome-icon`),y=h(`el-button`),b=h(`el-upload`);return d(),t(`div`,$e,[n(`div`,et,[n(`div`,tt,[n(`span`,nt,u(e.$t(`veo.name.startEndImage`)),1),o(p,{content:e.$t(`veo.description.uploadStartEndImage`)},null,8,[`content`])])]),o(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":r[0]||=t=>e.fileList=t,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:g(({file:t})=>[t.url&&t.percentage!==void 0?(d(),a(_,{key:0,url:t.url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):m(``,!0)]),default:g(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:g(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+u(e.$t(`veo.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var it=L(Qe,[[`render`,rt],[`__scopeId`,`data-v-f9a79b4a`]]),at=r({name:`UpsampleActionSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return F.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.upsample_action},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,upsample_action:e})}}},mounted(){this.value||=ee}}),ot={class:`field`},st={class:`title font-bold`};function ct(r,i,c,l,f,p){let m=h(`el-option`),_=h(`el-select`);return d(),t(`div`,ot,[n(`h2`,st,u(r.$t(`veo.name.upsampleAction`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`veo.placeholder.select`)},{default:g(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(m,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var lt=L(at,[[`render`,ct],[`__scopeId`,`data-v-8b74a7ae`]]),ut=r({name:`ExtendModelSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return N.map(e=>({value:e,label:e}))},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||!N.includes(this.value))&&(this.value=P)}}),dt={class:`field`},ft={class:`title font-bold`};function pt(r,i,c,l,f,p){let m=h(`el-option`),_=h(`el-select`);return d(),t(`div`,dt,[n(`h2`,ft,u(r.$t(`veo.name.model`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`veo.placeholder.select`)},{default:g(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(m,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var mt=L(ut,[[`render`,pt],[`__scopeId`,`data-v-cc3f9355`]]),ht=r({name:`MotionTypeSelector`,components:{ElSelect:y,ElOption:b},computed:{options(){return j.map(e=>({value:e,label:e}))},value:{get(){return this.$store.state.veo?.config?.motion_type},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,motion_type:e})}}},mounted(){this.value||=A}}),gt={class:`field`},_t={class:`title font-bold`};function vt(r,i,c,l,f,p){let m=h(`el-option`),_=h(`el-select`);return d(),t(`div`,gt,[n(`h2`,_t,u(r.$t(`veo.name.motionType`)),1),o(_,{modelValue:r.value,"onUpdate:modelValue":i[0]||=e=>r.value=e,class:`value`,placeholder:r.$t(`veo.placeholder.select`),filterable:``},{default:g(()=>[(d(!0),t(s,null,e(r.options,e=>(d(),a(m,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var yt=L(ht,[[`render`,vt],[`__scopeId`,`data-v-3affff3c`]]),bt=r({name:`ImageMaskInput`,components:{ElInput:R},computed:{value:{get(){return this.$store.state.veo?.config?.image_mask},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo.config,image_mask:e})}}}}),xt={class:`field`},St={class:`title font-bold`};function Ct(e,r,i,a,s,c){let l=h(`el-input`);return d(),t(`div`,xt,[n(`h2`,St,u(e.$t(`veo.name.imageMask`)),1),o(l,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.imageMask`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var wt=L(bt,[[`render`,Ct],[`__scopeId`,`data-v-6cc27c68`]]),Tt=r({name:`PromptInput`,components:{PromptTextarea:ae},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Et(e,t,n,r,i,o){let s=h(`prompt-textarea`);return d(),a(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`veo.name.prompt`),info:e.$t(`veo.description.prompt`),placeholder:e.$t(`veo.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Dt=L(Tt,[[`render`,Et]]),Ot=[`upsample`,`extend`,`reshoot`,`object_insert`,`object_remove`,`get1080p`],kt=[`text2video`,`image2video`,`ingredients2video`],At=r({name:`ConfigPanel`,components:{ElButton:v,Consumption:se,FontAwesomeIcon:K,PromptInput:Dt,ModelSelector:ye,StartEndImage:it,ActionSelector:Te,VideoFromInput:Ke,VideoIdInput:Ze,UpsampleActionSelector:lt,ExtendModelSelector:mt,MotionTypeSelector:yt,ImageMaskInput:wt,TranslationSelector:Ne,AspectRatioSelector:Be},emits:[`generate`],computed:{config(){return this.$store.state.veo?.config},consumption(){return ne(this.config,this.service?.cost)},service(){return this.$store.state.veo?.service},isPostProcessing(){return Ot.includes(this.config?.action??``)},isGeneration(){return kt.includes(this.config?.action??``)}},methods:{onGenerate(){this.$emit(`generate`)}}}),jt={class:`flex flex-col h-full`},Mt={class:`flex-1 overflow-y-auto p-5`},Nt={class:`flex flex-col items-center justify-center px-5 pb-5`};function Pt(e,r,c,l,f,p){let _=h(`action-selector`),v=h(`video-from-input`),y=h(`video-id-input`),b=h(`upsample-action-selector`),x=h(`extend-model-selector`),S=h(`prompt-input`),C=h(`motion-type-selector`),w=h(`image-mask-input`),T=h(`translation-selector`),E=h(`aspect-ratio-selector`),D=h(`model-selector`),O=h(`start-end-image`),k=h(`consumption`),A=h(`font-awesome-icon`),j=h(`el-button`);return d(),t(`div`,jt,[n(`div`,Mt,[o(_,{class:`mb-4`}),e.isPostProcessing?(d(),t(s,{key:0},[e.config?.video_url?(d(),a(v,{key:0,class:`mb-4`})):m(``,!0),o(y,{class:`mb-4`})],64)):m(``,!0),e.config?.action===`upsample`?(d(),a(b,{key:1,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(d(),a(x,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(d(),a(S,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`reshoot`?(d(),a(C,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`object_insert`?(d(),a(S,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`object_insert`||e.config?.action===`object_remove`?(d(),a(w,{key:6,class:`mb-4`})):m(``,!0),e.config?.action===`object_remove`?(d(),a(S,{key:7,class:`mb-4`})):m(``,!0),e.isGeneration?(d(),t(s,{key:8},[o(T,{class:`mb-4`}),o(E,{class:`mb-4`}),o(S,{class:`mb-4`}),e.config?.action===`ingredients2video`?m(``,!0):(d(),a(D,{key:0,class:`mb-4`})),e.config?.action===`image2video`||e.config?.action===`ingredients2video`?(d(),a(O,{key:1,class:`mb-2`})):m(``,!0)],64)):m(``,!0)]),n(`div`,Nt,[o(k,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(j,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:g(()=>[o(A,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+u(e.$t(`veo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Ft=L(At,[[`render`,Pt]]),It=r({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:q,FontAwesomeIcon:K,ElAlert:w,VideoPlayer:Q,ElTooltip:S,ElButton:v,ApiCodeButton:ce},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onPickAction(e,t,n,r){console.debug(`seed config from preview`,{action:n,upsampleAction:r,response:t}),this.$store.commit(`veo/setConfig`,{...this.$store.state.veo?.config,action:n,video_id:t?.data?.[0]?.id,video_url:t?.data?.[0]?.video_url,...r?{upsample_action:r}:{}})},onDownload(e,t){e?.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenVideo(e){window.open(e,`_blank`)}}}),Lt={class:`preview`},Rt={class:`left`},zt={class:`main`},Bt={class:`bot`},Vt={class:`datetime`},Ht={class:`info`},Ut={key:0,class:`prompt mt-2`},Wt={key:0},Gt={key:1},Kt={key:0,class:l({content:!0,failed:!0})},qt={key:0,class:`mb-4`},Jt={key:1,class:l({operations:!0,"mt-2":!0})},Yt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Xt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Zt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Qt={key:1,class:l({content:!0})},$t={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},en={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},tn={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},nn={key:2,class:l({content:!0})},rn={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},an={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function on(e,r,s,c,l,f){let p=h(`el-image`),_=h(`video-player`),v=h(`el-button`),y=h(`el-tooltip`),b=h(`api-code-button`),x=h(`font-awesome-icon`),S=h(`copy-to-clipboard`),C=h(`el-alert`);return d(),t(`div`,Lt,[n(`div`,Rt,[o(p,{src:`https://cdn.acedata.cloud/8nxyy9.jpg`,class:`avatar`})]),n(`div`,zt,[n(`div`,Bt,[i(u(e.$t(`veo.name.veoBot`))+` `,1),n(`span`,Vt,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,Ht,[e.modelValue?.request?.prompt?(d(),t(`p`,Ut,[i(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?m(``,!0):(d(),t(`span`,Wt,` - (`+u(e.$t(`veo.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`running`?(d(),t(`span`,Gt,` - (`+u(e.$t(`veo.status.processing`))+`) `,1)):m(``,!0)])):m(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(d(),t(`div`,Kt,[e.modelValue?.response?.data[0]?.video_url?(d(),t(`div`,qt,[o(_,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):m(``,!0),e.modelValue?.response.success?(d(),t(`div`,Jt,[e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:r[0]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`1080p`)},{default:g(()=>[i(u(e.$t(`veo.button.actionUpsample1080p`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:1,type:`info`,size:`small`,class:`btn-action`,onClick:r[1]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`4k`)},{default:g(()=>[i(u(e.$t(`veo.button.actionUpsample4k`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:2,type:`info`,size:`small`,class:`btn-action`,onClick:r[2]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`gif`)},{default:g(()=>[i(u(e.$t(`veo.button.actionUpsampleGif`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:3,type:`info`,size:`small`,class:`btn-action`,onClick:r[3]||=t=>e.onPickAction(t,e.modelValue?.response,`extend`)},{default:g(()=>[i(u(e.$t(`veo.button.actionExtend`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:4,type:`info`,size:`small`,class:`btn-action`,onClick:r[4]||=t=>e.onPickAction(t,e.modelValue?.response,`reshoot`)},{default:g(()=>[i(u(e.$t(`veo.button.actionReshoot`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:5,type:`info`,size:`small`,class:`btn-action`,onClick:r[5]||=t=>e.onPickAction(t,e.modelValue?.response,`object_insert`)},{default:g(()=>[i(u(e.$t(`veo.button.actionObjectInsert`)),1)]),_:1})):m(``,!0),e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:6,type:`info`,size:`small`,class:`btn-action`,onClick:r[6]||=t=>e.onPickAction(t,e.modelValue?.response,`object_remove`)},{default:g(()=>[i(u(e.$t(`veo.button.actionObjectRemove`)),1)]),_:1})):m(``,!0),o(y,{class:`box-item`,effect:`dark`,content:e.$t(`veo.message.downloadVideo`),placement:`top-start`},{default:g(()=>[e.modelValue?.response?.data[0]?.video_url?(d(),a(v,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:r[7]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:g(()=>[i(u(e.$t(`veo.button.download`)),1)]),_:1})):m(``,!0)]),_:1},8,[`content`]),o(b,{path:`/veo/videos`,body:e.modelValue?.request},null,8,[`body`])])):m(``,!0),o(C,{closable:!1,class:`mt-2 success`},{default:g(()=>[n(`p`,Yt,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.model`))+`: `+u(e.modelValue?.request?.model),1)]),n(`p`,Xt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(d(),t(`p`,Zt,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0)]),_:1})])):m(``,!0),e.modelValue?.response?.success===!1?(d(),t(`div`,Qt,[o(C,{closable:!1,class:`failure`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.failure`)),1)]),default:g(()=>[n(`p`,$t,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),n(`p`,en,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(d(),t(`p`,$,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):m(``,!0),e.modelValue?.response?.trace_id?(d(),t(`p`,tn,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):m(``,!0)]),_:1})])):m(``,!0),e.modelValue?.response?.success===void 0?(d(),t(`div`,nn,[o(C,{closable:!1,class:`info`},{template:g(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.failure`)),1)]),default:g(()=>[n(`p`,rn,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(d(),t(`p`,an,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+u(e.$t(`veo.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):m(``,!0)]),_:1})])):m(``,!0)])])}var sn=r({name:`RecentPanel`,components:{TaskPreview:L(It,[[`render`,on],[`__scopeId`,`data-v-9698fe5f`]]),NoTasks:oe,BotPlaceholder:X,ScrollList:re},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?.()}}}),cn={key:0},ln={key:2,class:`w-full h-full flex items-center justify-center`};function un(n,r,i,c,l,u){let f=h(`bot-placeholder`),p=h(`task-preview`),_=h(`scroll-list`),v=h(`no-tasks`);return d(),t(s,null,[n.tasks?.items===void 0?(d(),t(`div`,cn,[o(f)])):n.tasks?.items?.length&&n.tasks?.items?.length>0?(d(),a(_,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:n.loading,onReachTop:r[0]||=e=>n.$emit(`reach-top`)},{default:g(()=>[(d(!0),t(s,null,e(n.tasks?.items,(e,t)=>(d(),a(p,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):m(``,!0),n.tasks?.items?.length===0?(d(),t(`div`,ln,[o(v)])):m(``,!0)],64)}var dn=L(sn,[[`render`,un]]),fn=D(`veo`),pn=r({name:`VeoIndex`,components:{ConfigPanel:Ft,Layout:me,RecentPanel:dn},mixins:[I],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.veo?.status?.getApplications===G.Request},tasksLoading(){return this.$store.state.veo?.status?.getTasks===G.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,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 ie({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();let 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);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`veo/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!z(this.uploadTracker,e=>this.$t(e),e=>U.warning(e)))return;let e={...this.config,callback_url:fn},t=this.credential?.token;if(!t){console.error(`no token specified`);return}if(e.action===`image2video`&&!(e.image_urls&&e.image_urls.length>0)){U.warning(this.$t(`veo.message.imageRequired`));return}(!e.image_urls||e.image_urls.length===0)&&delete e.image_urls,U.info(this.$t(`veo.message.startingTask`)),te(`veo`,V.generate(e,{token:t})).then(()=>{U.success(this.$t(`veo.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?U.error(this.$t(`veo.message.usedUp`)):U.error(this.$t(`veo.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function mn(e,t,n,r,i,s){let c=h(`config-panel`),l=h(`recent-panel`),u=h(`layout`);return d(),a(u,null,{config:g(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:g(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var hn=L(pn,[[`render`,mn]]);export{hn as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Vt as c,Wt as l,Z as u,b as d,dt as f,et as p,k as m,nt as h,tt as g,ut as _,v,y}from"./vendor-chart-BJCvKk8-.js";import{t as b}from"./button-DfsQodL-.js";import{F as x,X as S,Y as C,tt as w,z as T}from"./use-deprecated-BzKQGDXN.js";import{r as E,t as D}from"./select-B1uV_nnl.js";import{n as O,t as k}from"./tabs-D9l1-5D5.js";import{n as A,t as j}from"./form-DnBQT-zH.js";import{t as M}from"./upload-SS_pZz4k.js";import{t as N}from"./tooltip-BLwTovWL.js";import{t as P}from"./image-BLdTdN6v.js";import{t as F}from"./avatar-CTHa5OEM.js";import{t as I}from"./checkbox-BAeQdLeW.js";import{n as L,r as R,t as ee}from"./radio-BmBXySlN.js";import{n as te,t as ne}from"./collapse-zZjSyR53.js";import{t as z}from"./drawer-Dpuj2uIl.js";import{n as B,r as V,t as H}from"./dropdown-DhpaHW0b.js";import{t as U}from"./input-number-DIoKTD0e.js";import{t as re}from"./popover-DCGISZxg.js";import{t as ie}from"./progress-C3UHYIHi.js";import{n as ae,t as oe}from"./skeleton-C4sltx62.js";import{t as se}from"./slider-DqJsYqiE.js";import{t as ce}from"./switch-BXfqi_p8.js";import{Fn as le,_i as ue}from"./constants-CwLEZ_AF.js";import{An as de,At as fe,E as W,Fn as pe,Ir as G,Mr as K,Nt as me,Or as q,Ot as he,Sr as ge,kr as J,kt as _e,rn as Y,yr as X}from"./index-CxBOJBZd.js";import{t as Z}from"./index.es-Dw2lhymn.js";import{n as ve}from"./taskDrawerMixin-DEgO_R5H.js";import{i as Q,n as ye,r as be,t as xe}from"./pagination-DC4Eh4yG.js";import{n as Se,t as Ce}from"./NoTasks-Czm65vJ4.js";import{t as we}from"./Consumption-C3v4xGTO.js";import{n as Te,r as $,t as Ee}from"./Player-C7Zoyb-g.js";var De=r({name:`LayoutSuno`,components:{ElDrawer:z,ElButton:b,FontAwesomeIcon:Z},mixins:[ve],data(){return{preview:!1}},computed:{}}),Oe={class:`main flex flex-row flex-1`},ke={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Ae={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},je={class:`preview h-full w-[300px] flex flex-col`};function Me(e,r,i,a,s,c){let l=g(`font-awesome-icon`),d=g(`el-button`),m=g(`el-drawer`);return u(),t(`div`,Oe,[n(`div`,ke,[p(e.$slots,`config`,{},void 0,!0)]),n(`div`,Ae,[p(e.$slots,`result`,{},void 0,!0)]),n(`div`,je,[p(e.$slots,`preview`,{},void 0,!0)]),f(o(d,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:_(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[v,!e.tasksEmpty]]),o(m,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:_(()=>[p(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var Ne=W(De,[[`render`,Me],[`__scopeId`,`data-v-169b0449`]]),Pe=r({name:`TypeSelector`,components:{ElSelect:E,ElOption:D,ElSwitch:ce},data(){return{options:[{label:`v5.5`,value:`chirp-v5-5`,desc:this.$t(`suno.model.v55desc`)},{label:`v5`,value:`chirp-v5`,desc:this.$t(`suno.model.v5desc`)},{label:`v4.5+`,value:`chirp-v4-5-plus`,desc:this.$t(`suno.model.v45plusdesc`)},{label:`v4.5`,value:`chirp-v4-5`,desc:this.$t(`suno.model.v45desc`),dividerAfter:!0},{label:`v4`,value:`chirp-v4`,desc:this.$t(`suno.model.v4desc`)},{label:`v3.5`,value:`chirp-v3-5`,desc:this.$t(`suno.model.v35desc`)},{label:`v3`,value:`chirp-v3-0`,desc:this.$t(`suno.model.v3desc`)}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental||!1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,instrumental:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||=le}}),Fe={class:`mb-3`},Ie={class:`flex items-center mb-1`},Le={class:`text-sm font-bold`},Re={class:`model-option`},ze={class:`model-option-left`},Be={class:`model-option-name`},Ve={class:`model-option-desc`},He={key:0,class:`flex items-center justify-between mb-3`},Ue={class:`text-sm font-bold`};function We(r,i,d,f,p,h){let v=g(`el-option`),y=g(`el-select`),b=g(`el-switch`);return u(),t(`div`,null,[n(`div`,Fe,[n(`div`,Ie,[n(`span`,Le,l(r.$t(`suno.name.model`)),1)]),o(y,{modelValue:r.model,"onUpdate:modelValue":i[0]||=e=>r.model=e,class:`w-full model-select`,size:`default`,placeholder:r.$t(`suno.placeholder.select`)},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(v,{key:e.value,label:e.label,value:e.value,class:c({"model-option-divider":e.dividerAfter})},{default:_(()=>[n(`div`,Re,[n(`div`,ze,[n(`span`,Be,l(e.label),1)]),n(`span`,Ve,l(e.desc),1)])]),_:2},1032,[`label`,`value`,`class`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),r.custom?(u(),t(`div`,He,[n(`span`,Ue,l(r.$t(`suno.name.instrumental`)),1),o(b,{modelValue:r.instrumental,"onUpdate:modelValue":i[1]||=e=>r.instrumental=e},null,8,[`modelValue`])])):m(``,!0)])}var Ge=W(Pe,[[`render`,We],[`__scopeId`,`data-v-16e4d6fc`]]),Ke=r({name:`UploadAudio`,components:{ElUpload:M,ElButton:b,ElDialog:K,ElTabs:O,ElTabPane:k,InfoIcon:Q,FontAwesomeIcon:Z,ElRadioGroup:R,ElRadioButton:L},mixins:[_e],emits:[`change`],data(){return{fileList:[],uploadUrl:ge()+`/api/v1/files/`,dialogVisible:!1,activeTab:`browse`,recording:!1,recordedBlob:null,recordedAudioUrl:null,audioPreviewUrl:null,recordTimer:null,recordSeconds:0,mediaRecorder:null,mediaStream:null,recordedChunks:[],uploadingRecord:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}},hasUploadedAudio(){let e=this.$store.state.suno?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.suno?.config?.action||`upload_extend`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,action:e})}},formattedTime(){return`${Math.floor(this.recordSeconds/60).toString().padStart(2,`0`)}:${(this.recordSeconds%60).toString().padStart(2,`0`)}`}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},beforeUnmount(){this.cleanupRecording()},methods:{onExceed(){J.warning(this.$t(`suno.message.uploadReferencesExceed`))},onError(){J.error(this.$t(`suno.message.uploadReferencesError`))},async onBrowseSuccess(){let e=this.urls?.[0];e&&(this.audioPreviewUrl=e,await this.onGenerateAudioId(e),this.dialogVisible=!1)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingUploadAudio`));try{let e=await Y.upload(t,{token:n});console.debug(`get upload music success`,e.data);let r=e.data?.data.audio_id;this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_id:r,action:`upload_extend`}),J.success(this.$t(`suno.message.startUploadAudioSuccess`))}catch(e){J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startUploadAudioFailed`))}},async startRecording(){if(!navigator.mediaDevices?.getUserMedia||typeof MediaRecorder>`u`){J.error(this.$t(`suno.message.recordingUnsupported`));return}try{this.mediaStream=await navigator.mediaDevices.getUserMedia({audio:!0}),this.recordedChunks=[],this.mediaRecorder=new MediaRecorder(this.mediaStream),this.mediaRecorder.ondataavailable=e=>{e.data&&e.data.size>0&&this.recordedChunks.push(e.data)},this.mediaRecorder.onstop=()=>{let e=new Blob(this.recordedChunks,{type:`audio/webm`});this.recordedBlob=e,this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedAudioUrl=URL.createObjectURL(e),this.releaseStream()},this.mediaRecorder.start(),this.recording=!0,this.recordSeconds=0,this.recordTimer=window.setInterval(()=>{this.recordSeconds+=1,this.recordSeconds>=600&&this.stopRecording()},1e3)}catch(e){console.error(`record error`,e),J.error(this.$t(`suno.message.recordingPermissionDenied`))}},stopRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.mediaRecorder&&this.mediaRecorder.state!==`inactive`&&this.mediaRecorder.stop(),this.recording=!1},resetRecording(){this.recordedAudioUrl&&URL.revokeObjectURL(this.recordedAudioUrl),this.recordedBlob=null,this.recordedAudioUrl=null,this.recordSeconds=0},async uploadRecording(){if(this.recordedBlob){this.uploadingRecord=!0;try{let e=new FormData,t=`recording-${Date.now()}.webm`;e.append(`file`,this.recordedBlob,t);let n=await fetch(this.uploadUrl,{method:`POST`,headers:{Authorization:`Bearer ${this.$store.state.token.access}`},body:e});if(!n.ok)throw Error(`upload failed: ${n.status}`);let r=await n.json(),i=r?.file_url||r?.data?.file_url;if(!i)throw Error(`no file_url in response`);this.audioPreviewUrl=i,await this.onGenerateAudioId(i),this.dialogVisible=!1,this.resetRecording()}catch(e){console.error(e),J.error(e?.message||this.$t(`suno.message.uploadReferencesError`))}finally{this.uploadingRecord=!1}}},releaseStream(){this.mediaStream&&=(this.mediaStream.getTracks().forEach(e=>e.stop()),null)},cleanupRecording(){this.recordTimer&&=(window.clearInterval(this.recordTimer),null),this.releaseStream(),this.recordedAudioUrl&&=(URL.revokeObjectURL(this.recordedAudioUrl),null)}}}),qe={class:`relative`},Je={class:`flex justify-between items-center mb-2`},Ye={class:`flex justify-start items-center`},Xe={class:`text-sm font-bold`},Ze={key:0,class:`mb-2`},Qe=[`src`],$e={key:1,class:`mt-2`},et={class:`py-4`},tt={class:`text-center py-6`},nt={class:`text-sm`},rt={class:`text-xs text-gray-400 mt-1`},it={class:`py-4 text-center`},at={class:`recorder-display mb-4`},ot={key:0,class:`text-red-500 flex items-center justify-center gap-2`},st={class:`text-2xl font-mono`},ct={key:1,class:`text-green-600`},lt={key:2,class:`text-gray-400 text-2xl font-mono`},ut={key:0,class:`mb-4`},dt=[`src`],ft={class:`flex justify-center gap-3`};function pt(e,r,c,d,f,p){let h=g(`info-icon`),v=g(`font-awesome-icon`),y=g(`el-button`),b=g(`el-radio-button`),x=g(`el-radio-group`),S=g(`el-upload`),C=g(`el-tab-pane`),w=g(`el-tabs`),T=g(`el-dialog`);return u(),t(`div`,qe,[n(`div`,Je,[n(`div`,Ye,[n(`span`,Xe,l(e.$t(`suno.name.referenceAudios`)),1),o(h,{content:e.$t(`suno.description.uploadAudios`)},null,8,[`content`])]),o(y,{round:``,type:`primary`,size:`small`,onClick:r[0]||=t=>e.dialogVisible=!0},{default:_(()=>[o(v,{icon:`fa-solid fa-plus`,class:`icon mr-1`}),i(` `+l(e.$t(`suno.button.addAudio`)),1)]),_:1})]),e.audioPreviewUrl?(u(),t(`div`,Ze,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Qe)])):m(``,!0),e.hasUploadedAudio?(u(),t(`div`,$e,[o(x,{modelValue:e.uploadAction,"onUpdate:modelValue":r[1]||=t=>e.uploadAction=t,size:`small`},{default:_(()=>[o(b,{value:`upload_extend`},{default:_(()=>[i(l(e.$t(`suno.button.extend`)),1)]),_:1}),o(b,{value:`upload_cover`},{default:_(()=>[i(l(e.$t(`suno.button.upload_cover`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),o(T,{modelValue:e.dialogVisible,"onUpdate:modelValue":r[4]||=t=>e.dialogVisible=t,title:e.$t(`suno.name.addAudio`),width:`520px`,"close-on-click-modal":!1,"append-to-body":``},{default:_(()=>[o(w,{modelValue:e.activeTab,"onUpdate:modelValue":r[3]||=t=>e.activeTab=t,class:`add-audio-tabs`},{default:_(()=>[o(C,{name:`browse`,label:e.$t(`suno.tab.browse`)},{default:_(()=>[n(`div`,et,[o(S,{"file-list":e.fileList,"onUpdate:fileList":r[2]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onBrowseSuccess,headers:e.headers,drag:``},{default:_(()=>[n(`div`,tt,[o(v,{icon:`fa-solid fa-upload`,class:`text-4xl text-gray-400 mb-3`}),n(`div`,nt,l(e.$t(`suno.description.dropAudioHere`)),1),n(`div`,rt,l(e.$t(`suno.description.audioFormats`)),1)])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])]),_:1},8,[`label`]),o(C,{name:`record`,label:e.$t(`suno.tab.record`)},{default:_(()=>[n(`div`,it,[n(`div`,at,[e.recording?(u(),t(`div`,ot,[r[5]||=n(`span`,{class:`recording-dot`},null,-1),n(`span`,st,l(e.formattedTime),1)])):e.recordedBlob?(u(),t(`div`,ct,[o(v,{icon:`fa-solid fa-check-circle`,class:`text-2xl mr-2`}),n(`span`,null,l(e.$t(`suno.message.recordingReady`))+` (`+l(e.formattedTime)+`)`,1)])):(u(),t(`div`,lt,`00:00`))]),e.recordedAudioUrl&&!e.recording?(u(),t(`div`,ut,[n(`audio`,{src:e.recordedAudioUrl,controls:``,class:`w-full`},null,8,dt)])):m(``,!0),n(`div`,ft,[!e.recording&&!e.recordedBlob?(u(),a(y,{key:0,type:`primary`,round:``,onClick:e.startRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.startRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recording?(u(),a(y,{key:1,type:`danger`,round:``,onClick:e.stopRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-stop`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.stopRecord`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.recordedBlob&&!e.recording?(u(),t(s,{key:2},[o(y,{round:``,onClick:e.resetRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.reRecord`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,round:``,loading:e.uploadingRecord,onClick:e.uploadRecording},{default:_(()=>[o(v,{icon:`fa-solid fa-upload`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.useRecording`)),1)]),_:1},8,[`loading`,`onClick`])],64)):m(``,!0)])])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`])])}var mt=W(Ke,[[`render`,pt],[`__scopeId`,`data-v-5f17a1f4`]]),ht=[{key:`lofi`,label:`🎧 Lo-fi Chill`,prompt:`a relaxing lo-fi hip hop beat for studying`},{key:`pop-love`,label:`💕 Pop Love Song`,prompt:`a catchy pop love song with sweet melodies`},{key:`rock-anthem`,label:`🎸 Rock Anthem`,prompt:`an energetic rock anthem with electric guitars`},{key:`jazz-night`,label:`🎷 Jazz Night`,prompt:`a smooth late-night jazz piece with saxophone`},{key:`edm-drop`,label:`⚡ EDM Drop`,prompt:`an intense EDM track with a massive drop`},{key:`folk-story`,label:`🪕 Folk Story`,prompt:`a warm folk song telling a story about traveling`},{key:`rnb-groove`,label:`🎤 R&B Groove`,prompt:`a smooth R&B groove with soulful vocals`},{key:`classical`,label:`🎻 Classical`,prompt:`an elegant classical piece for orchestra`},{key:`hip-hop`,label:`🎤 Hip Hop`,prompt:`a hard-hitting hip hop beat with bass`},{key:`country`,label:`🤠 Country`,prompt:`an upbeat country song with acoustic guitar and banjo`},{key:`reggae`,label:`🌴 Reggae`,prompt:`a laid-back reggae tune with island vibes`},{key:`latin`,label:`💃 Latin`,prompt:`a vibrant Latin dance track with percussion`},{key:`ambient`,label:`🌊 Ambient`,prompt:`a dreamy ambient soundscape for relaxation`},{key:`metal`,label:`🤘 Metal`,prompt:`a powerful metal song with heavy riffs and double bass drums`},{key:`soul`,label:`🎵 Soul`,prompt:`a heartfelt soul ballad with gospel harmonies`},{key:`synthwave`,label:`🌃 Synthwave`,prompt:`a retro synthwave track with 80s vibes`},{key:`kpop`,label:`🇰🇷 K-Pop`,prompt:`a catchy K-pop dance track with hook`},{key:`lullaby`,label:`🌙 Lullaby`,prompt:`a gentle lullaby for bedtime with soft piano`},{key:`cinematic`,label:`🎬 Cinematic`,prompt:`an epic cinematic orchestral score for a movie trailer`},{key:`blues`,label:`🎸 Blues`,prompt:`a soulful blues song with electric guitar bends`},{key:`disco`,label:`🕺 Disco`,prompt:`a funky disco track with groovy bassline`},{key:`punk`,label:`🔥 Punk Rock`,prompt:`a fast punk rock song with raw energy`},{key:`gospel`,label:`⛪ Gospel`,prompt:`an uplifting gospel choir song with piano`},{key:`trap`,label:`🔊 Trap`,prompt:`a dark trap beat with 808s and hi-hats`},{key:`bossa`,label:`☕ Bossa Nova`,prompt:`a gentle bossa nova with nylon guitar`},{key:`indie`,label:`🎶 Indie`,prompt:`a dreamy indie track with ethereal vocals`},{key:`cpop`,label:`🇨🇳 C-Pop`,prompt:`a beautiful Chinese pop ballad with emotional vocals`},{key:`jpop`,label:`🇯🇵 J-Pop`,prompt:`a cheerful J-pop song with anime vibes`},{key:`afrobeat`,label:`🥁 Afrobeat`,prompt:`a groovy Afrobeat track with layered percussion`},{key:`game`,label:`🎮 Game BGM`,prompt:`an adventurous video game background music`}],gt=8;function _t(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var vt=r({name:`PromptInput`,components:{FontAwesomeIcon:Z,PromptTextarea:Se},data(){return{shuffledTags:_t(ht)}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,prompt:e})}},visibleTags(){return this.shuffledTags.slice(0,gt)}},mounted(){this.prompt||=``},methods:{onTagClick(e){this.prompt=e.prompt},onRefreshTags(){this.shuffledTags=_t(ht)}}}),yt={class:`inspo-tags`},bt=[`onClick`];function xt(r,i,c,d,f,p){let m=g(`font-awesome-icon`),h=g(`prompt-textarea`);return u(),a(h,{modelValue:r.prompt,"onUpdate:modelValue":i[1]||=e=>r.prompt=e,title:r.$t(`suno.name.songDescription`),info:r.$t(`suno.description.prompt`),placeholder:r.$t(`suno.placeholder.prompt`),"min-rows":5,"max-rows":14},{after:_(()=>[n(`div`,yt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e.key,class:`inspo-tag`,onClick:t=>r.onTagClick(e)},l(e.label),9,bt))),128)),n(`button`,{class:`inspo-tag inspo-tag-refresh`,onClick:i[0]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(m,{icon:`fa-solid fa-arrows-rotate`})])])]),_:1},8,[`modelValue`,`title`,`info`,`placeholder`])}var St=W(vt,[[`render`,xt],[`__scopeId`,`data-v-58ffcd38`]]),Ct=r({name:`LyricInput`,components:{ElInput:G,ElButton:b,ElTooltip:N,ElDialog:K,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{generatingLyrics:!1,enhancingLyrics:!1,enhancePrompt:``,lyricHistory:[],expanded:!1}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config},credential(){return this.$store.state.suno?.credential}},mounted(){this.lyric||=``},methods:{pushHistory(){this.lyric&&(this.lyricHistory.push(this.lyric),this.lyricHistory.length>20&&this.lyricHistory.shift())},onUndo(){let e=this.lyricHistory.pop();e!==void 0&&(this.lyric=e)},onClear(){this.pushHistory(),this.lyric=``},async onEnhanceLyrics(){let e=this.credential?.token;if(!(!e||!this.lyric||!this.enhancePrompt)){this.pushHistory(),this.enhancingLyrics=!0,J.info(this.$t(`suno.message.enhancingLyrics`));try{let t=`${this.enhancePrompt}\n\nOriginal lyrics:\n${this.lyric}`,n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,this.enhancePrompt=``,J.success(this.$t(`suno.message.enhanceLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.enhanceLyricsFailed`))}finally{this.enhancingLyrics=!1}}},async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t;try{t=((await q.prompt(this.$t(`suno.message.lyricsThemePromptMessage`),this.$t(`suno.message.lyricsThemePromptTitle`),{confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`),inputPlaceholder:this.$t(`suno.placeholder.lyricsTheme`),inputValue:this.config?.title||``,inputType:`textarea`,inputValidator:e=>typeof e==`string`&&e.trim().length>0||this.$t(`suno.message.lyricsThemeRequired`)})).value||``).trim()}catch{return}if(t){this.pushHistory(),this.generatingLyrics=!0,J.info(this.$t(`suno.message.generatingLyrics`));try{let n=(await Y.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyric:n.text,title:n.title}),J.success(this.$t(`suno.message.generateLyricsSuccess`)))}catch{J.error(this.$t(`suno.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}}),wt={class:`field`},Tt={class:`flex items-center justify-between mb-1`},Et={class:`flex items-center`},Dt={class:`text-sm font-bold`},Ot={class:`flex items-center gap-1`},kt={class:`relative`},At={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},jt={key:0,class:`enhance-bar`},Mt={key:0,class:`enhance-bar mt-3`},Nt={class:`flex items-center justify-between`},Pt={class:`flex items-center gap-1`};function Ft(e,r,s,c,d,f){let p=g(`info-icon`),h=g(`font-awesome-icon`),v=g(`el-button`),b=g(`el-tooltip`),x=g(`el-input`),S=g(`el-dialog`);return u(),t(`div`,wt,[n(`div`,Tt,[n(`div`,Et,[n(`span`,Dt,l(e.$t(`suno.name.lyrics`)),1),o(p,{content:e.$t(`suno.description.lyrics`)},null,8,[`content`])]),n(`div`,Ot,[e.lyricHistory.length>0?(u(),a(b,{key:0,content:e.$t(`suno.button.undo`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),e.lyric?(u(),a(b,{key:1,content:e.$t(`suno.button.clear_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`})]),_:1},8,[`onClick`])]),_:1},8,[`content`])):m(``,!0),o(b,{content:e.$t(`suno.button.expand_lyrics`),placement:`top`},{default:_(()=>[o(v,{size:`small`,circle:``,onClick:r[0]||=t=>e.expanded=!0},{default:_(()=>[o(h,{icon:`fa-solid fa-expand`})]),_:1})]),_:1},8,[`content`]),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))])]),n(`div`,kt,[e.config?.action===`extend`?(u(),a(x,{key:1,modelValue:e.lyric,"onUpdate:modelValue":r[2]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(u(),a(x,{key:0,modelValue:e.lyric,"onUpdate:modelValue":r[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`suno.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`])),n(`div`,At,l(e.lyric?.length||0)+`/5000`,1)]),e.lyric&&e.config?.action!==`extend`?(u(),t(`div`,jt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[3]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])])):m(``,!0),o(S,{modelValue:e.expanded,"onUpdate:modelValue":r[7]||=t=>e.expanded=t,title:e.$t(`suno.name.lyrics`),width:`720px`,top:`5vh`,"close-on-click-modal":!1,class:`lyrics-expand-dialog`},{footer:_(()=>[n(`div`,Nt,[n(`div`,Pt,[e.lyricHistory.length>0?(u(),a(v,{key:0,size:`small`,onClick:e.onUndo},{default:_(()=>[o(h,{icon:`fa-solid fa-rotate-left`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.undo`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.lyric?(u(),a(v,{key:1,size:`small`,onClick:e.onClear},{default:_(()=>[o(h,{icon:`fa-solid fa-eraser`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_lyrics`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.config?.action===`extend`?m(``,!0):(u(),a(v,{key:2,size:`small`,loading:e.generatingLyrics,onClick:e.onGenerateLyrics},{default:_(()=>[e.generatingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),o(v,{type:`primary`,onClick:r[6]||=t=>e.expanded=!1},{default:_(()=>[i(l(e.$t(`common.button.confirm`)),1)]),_:1})])]),default:_(()=>[o(x,{modelValue:e.lyric,"onUpdate:modelValue":r[4]||=t=>e.lyric=t,type:`textarea`,rows:20,class:`lyrics-expanded`,placeholder:e.$t(`suno.placeholder.lyrics`),autofocus:``},null,8,[`modelValue`,`placeholder`]),e.config?.action===`extend`?m(``,!0):(u(),t(`div`,Mt,[o(x,{modelValue:e.enhancePrompt,"onUpdate:modelValue":r[5]||=t=>e.enhancePrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.enhanceLyrics`),class:`enhance-input`,onKeyup:y(e.onEnhanceLyrics,[`enter`])},{append:_(()=>[o(v,{loading:e.enhancingLyrics,onClick:e.onEnhanceLyrics},{default:_(()=>[e.enhancingLyrics?m(``,!0):(u(),a(h,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(e.$t(`suno.button.enhance_lyrics`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1},8,[`modelValue`,`placeholder`,`onKeyup`])]))]),_:1},8,[`modelValue`,`title`])])}var It=W(Ct,[[`render`,Ft],[`__scopeId`,`data-v-d7d2ec74`]]),Lt=`Pop.Rock.Jazz.R&B.Hip Hop.Lo-fi.Electronic.Classical.Country.Blues.Folk.Reggae.Metal.Punk.Soul.Funk.Ambient.Indie.Latin.Acoustic.Dance.Disco.Gospel.K-Pop.J-Pop.C-Pop.Bossa Nova.Trap.Drill.House.Techno.Dubstep.Synthwave.Chill.Dreamy.Upbeat.Melancholic.Romantic.Epic.Cinematic.Orchestral.Piano.Guitar.Saxophone.Violin.Tribal.World Music.Afrobeat.Ska.Grunge`.split(`.`),Rt=12;function zt(e){let t=[...e];for(let e=t.length-1;e>0;e--){let n=Math.floor(Math.random()*(e+1));[t[e],t[n]]=[t[n],t[e]]}return t}var Bt=r({name:`StyleInput`,components:{ElInput:G,ElButton:b,FontAwesomeIcon:Z,InfoIcon:Q},data(){return{optimizing:!1,shuffledTags:zt(Lt)}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,style:e})}},credential(){return this.$store.state.suno?.credential},visibleTags(){return this.shuffledTags.slice(0,Rt)}},methods:{onTagClick(e){let t=this.style||``;t.toLowerCase().includes(e.toLowerCase())||(this.style=t?`${t}, ${e}`:e)},onRefreshTags(){this.shuffledTags=zt(Lt)},async onOptimizeStyle(){let e=this.credential?.token;if(!(!e||!this.style)){this.optimizing=!0,J.info(this.$t(`suno.message.optimizingStyle`));try{let t=await Y.style({prompt:this.style},{token:e}),n=t.data?.text||t.data?.data?.text;n&&(this.style=n,J.success(this.$t(`suno.message.optimizeStyleSuccess`)))}catch{J.error(this.$t(`suno.message.optimizeStyleFailed`))}finally{this.optimizing=!1}}}}}),Vt={class:`field`},Ht={class:`flex items-center justify-between mb-1`},Ut={class:`flex items-center`},Wt={class:`text-sm font-bold`},Gt={class:`relative`},Kt={class:`text-xs text-right text-[var(--el-text-color-secondary)] mt-1`},qt={class:`style-tags`},Jt=[`onClick`];function Yt(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-input`);return u(),t(`div`,Vt,[n(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,l(r.$t(`suno.name.style`)),1),o(v,{content:r.$t(`suno.description.style`)},null,8,[`content`])]),o(b,{size:`small`,loading:r.optimizing,round:``,onClick:r.onOptimizeStyle},{default:_(()=>[r.optimizing?m(``,!0):(u(),a(y,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),i(` `+l(r.$t(`suno.button.optimize_style`)),1)]),_:1},8,[`loading`,`onClick`])]),n(`div`,Gt,[o(x,{modelValue:r.style,"onUpdate:modelValue":c[0]||=e=>r.style=e,rows:2,type:`textarea`,placeholder:r.$t(`suno.placeholder.style`)},null,8,[`modelValue`,`placeholder`]),n(`div`,Kt,l(r.style?.length||0)+`/1000`,1)]),n(`div`,qt,[(u(!0),t(s,null,e(r.visibleTags,e=>(u(),t(`button`,{key:e,class:`style-tag`,onClick:t=>r.onTagClick(e)},l(e),9,Jt))),128)),n(`button`,{class:`style-tag style-tag-refresh`,onClick:c[1]||=(...e)=>r.onRefreshTags&&r.onRefreshTags(...e)},[o(y,{icon:`fa-solid fa-arrows-rotate`})])])])}var Xt=W(Bt,[[`render`,Yt],[`__scopeId`,`data-v-ddebb076`]]),Zt=r({name:`TitleInput`,components:{ElInput:G,InfoIcon:Q},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,title:e})}}}}),Qt={class:`field`},$t={class:`flex items-center mb-1`},en={class:`text-sm font-bold`};function tn(e,r,i,a,s,c){let d=g(`info-icon`),f=g(`el-input`);return u(),t(`div`,Qt,[n(`div`,$t,[n(`span`,en,l(e.$t(`suno.name.title`)),1),o(d,{content:e.$t(`suno.description.title`)},null,8,[`content`])]),o(f,{modelValue:e.title,"onUpdate:modelValue":r[0]||=t=>e.title=t,placeholder:e.$t(`suno.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var nn=W(Zt,[[`render`,tn]]),rn=r({name:`ExtendFromInput`,components:{ElImage:P,ElIcon:w,ElInputNumber:U,VideoPlay:S,VideoPause:C},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||=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:$,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})}}}),an={class:`field`},on={class:`box`},sn={class:`title font-bold`},cn={class:`input-wrapper`},ln={class:`task`},un={class:`left`},dn={key:2,class:`duration`},fn={class:`info`},pn={class:`title`},mn={class:`style`};function hn(e,r,i,a,s,c){let d=g(`el-input-number`),p=g(`el-image`),v=g(`video-pause`),y=g(`el-icon`),b=g(`video-play`),x=h(`loading`);return u(),t(`div`,an,[n(`div`,on,[n(`h2`,sn,l(e.$t(`suno.name.extend`)),1),n(`div`,cn,[o(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,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`])])]),n(`div`,ln,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[3]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,un,[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`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[1]||=t=>e.onPause(e.audio)},[o(y,null,{default:_(()=>[o(v)]),_:1})])):m(``,!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`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[2]||=t=>e.onPlay(e.audio)},[o(y,null,{default:_(()=>[o(b)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,dn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,fn,[n(`h2`,pn,l(e.audio?.title),1),n(`p`,mn,l(e.audio?.style),1)])])):m(``,!0)])])}var gn=W(rn,[[`render`,hn],[`__scopeId`,`data-v-bcce4821`]]),_n=r({name:`CoverFromInput`,components:{ElImage:P,ElIcon:w,VideoPlay:S,VideoPause:C},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||=void 0},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:$,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})}}}),vn={class:`field`},yn={class:`box`},bn={class:`title font-bold`},xn={class:`task`},Sn={class:`left`},Cn={key:2,class:`duration`},wn={class:`info`},Tn={class:`title`},En={class:`style`};function Dn(e,r,i,a,s,c){let d=g(`el-image`),p=g(`video-pause`),v=g(`el-icon`),y=g(`video-play`),b=h(`loading`);return u(),t(`div`,vn,[n(`div`,yn,[n(`h2`,bn,l(e.$t(`suno.name.cover`)),1)]),n(`div`,xn,[e.audio?(u(),t(`div`,{key:0,class:`audio`,onClick:r[2]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Sn,[o(d,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:r[0]||=t=>e.onPause(e.audio)},[o(v,null,{default:_(()=>[o(p)]),_:1})])):m(``,!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`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:r[1]||=t=>e.onPlay(e.audio)},[o(v,null,{default:_(()=>[o(y)]),_:1})])):m(``,!0),e.audio?.duration?(u(),t(`div`,Cn,l(e.useFormatDuring(e.audio?.duration)),1)):m(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,wn,[n(`h2`,Tn,l(e.audio?.title),1),n(`p`,En,l(e.audio?.style),1)])])):m(``,!0)])])}var On=W(_n,[[`render`,Dn],[`__scopeId`,`data-v-06640216`]]),kn=r({name:`VocalGenderSelector`,components:{ElRadioGroup:R,ElRadioButton:L,InfoIcon:Q},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})}}}}),An={class:`flex items-center mb-1`},jn={class:`text-sm font-bold`};function Mn(e,r,a,s,c,d){let f=g(`info-icon`),p=g(`el-radio-button`),m=g(`el-radio-group`);return u(),t(`div`,null,[n(`div`,An,[n(`span`,jn,l(e.$t(`suno.name.vocalGender`)),1),o(f,{content:e.$t(`suno.description.vocalGender`)},null,8,[`content`])]),o(m,{modelValue:e.vocalGender,"onUpdate:modelValue":r[0]||=t=>e.vocalGender=t,size:`small`},{default:_(()=>[o(p,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(p,{value:`f`},{default:_(()=>[i(l(e.$t(`suno.gender.female`)),1)]),_:1}),o(p,{value:`m`},{default:_(()=>[i(l(e.$t(`suno.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Nn=W(kn,[[`render`,Mn]]),Pn=r({name:`AdvancedParams`,components:{ElCollapse:ne,ElCollapseItem:te,ElInput:G,ElSlider:se,ElRadioGroup:R,ElRadioButton:L},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.suno?.config},isV5OrAbove(){let 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??.5},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??.5},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,audio_weight:e})}},lyricsMode:{get(){return this.$store.state.suno?.config?.lyrics_mode||`manual`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,lyrics_mode:e})}}},mounted(){let e=this.$store.state.suno?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.style_influence==`number`&&e.style_influence>1&&(t.style_influence=e.style_influence/100),typeof e.audio_weight==`number`&&e.audio_weight>1&&(t.audio_weight=e.audio_weight/100),Object.keys(t).length>0&&this.$store.commit(`suno/setConfig`,{...e,...t})}}),Fn={key:0,class:`mb-3`},In={class:`flex items-center mb-1`},Ln={class:`text-xs font-bold`},Rn={key:1,class:`mb-3`},zn={class:`flex items-center mb-1`},Bn={class:`text-xs font-bold`},Vn={key:2,class:`mb-3`},Hn={class:`flex items-center justify-between mb-1`},Un={class:`text-xs font-bold`},Wn={class:`text-xs text-[var(--el-text-color-secondary)]`},Gn={key:3,class:`mb-3`},Kn={class:`flex items-center justify-between mb-1`},qn={class:`text-xs font-bold`},Jn={class:`text-xs text-[var(--el-text-color-secondary)]`},Yn={key:4,class:`mb-3`},Xn={class:`flex items-center mb-1`},Zn={class:`text-xs font-bold`},Qn={key:5,class:`mb-3`},$n={class:`flex items-center justify-between mb-1`},er={class:`text-xs font-bold`},tr={class:`text-xs text-[var(--el-text-color-secondary)]`},nr={key:6,class:`mb-3`},rr={class:`flex items-center mb-1`},ir={class:`text-xs font-bold`};function ar(e,r,s,c,d,f){let p=g(`el-input`),h=g(`el-slider`),v=g(`el-radio-button`),y=g(`el-radio-group`),b=g(`el-collapse-item`),x=g(`el-collapse`);return u(),a(x,{modelValue:e.activeNames,"onUpdate:modelValue":r[7]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:_(()=>[o(b,{title:e.$t(`suno.name.advancedParams`),name:`advanced`},{default:_(()=>[e.config?.custom?(u(),t(`div`,Fn,[n(`div`,In,[n(`span`,Ln,l(e.$t(`suno.name.styleNegative`)),1)]),o(p,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`suno.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,Rn,[n(`div`,zn,[n(`span`,Bn,l(e.$t(`suno.name.lyricPrompt`)),1)]),o(p,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`suno.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Vn,[n(`div`,Hn,[n(`span`,Un,l(e.$t(`suno.name.weirdness`)),1),n(`span`,Wn,l(e.weirdness??0),1)]),o(h,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom?(u(),t(`div`,Gn,[n(`div`,Kn,[n(`span`,qn,l(e.$t(`suno.name.styleInfluence`)),1),n(`span`,Jn,l(e.styleInfluence??.5),1)]),o(h,{modelValue:e.styleInfluence,"onUpdate:modelValue":r[3]||=t=>e.styleInfluence=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.isV5OrAbove?(u(),t(`div`,Yn,[n(`div`,Xn,[n(`span`,Zn,l(e.$t(`suno.name.variationCategory`)),1)]),o(y,{modelValue:e.variationCategory,"onUpdate:modelValue":r[4]||=t=>e.variationCategory=t,size:`small`},{default:_(()=>[o(v,{value:``},{default:_(()=>[i(l(e.$t(`suno.gender.auto`)),1)]),_:1}),o(v,{value:`high`},{default:_(()=>[i(l(e.$t(`suno.variation.high`)),1)]),_:1}),o(v,{value:`low`},{default:_(()=>[i(l(e.$t(`suno.variation.low`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0),e.config?.action===`cover`?(u(),t(`div`,Qn,[n(`div`,$n,[n(`span`,er,l(e.$t(`suno.name.audioWeight`)),1),n(`span`,tr,l(e.audioWeight??.5),1)]),o(h,{modelValue:e.audioWeight,"onUpdate:modelValue":r[5]||=t=>e.audioWeight=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):m(``,!0),e.config?.custom&&!e.config?.instrumental?(u(),t(`div`,nr,[n(`div`,rr,[n(`span`,ir,l(e.$t(`suno.name.lyricsMode`)),1)]),o(y,{modelValue:e.lyricsMode,"onUpdate:modelValue":r[6]||=t=>e.lyricsMode=t,size:`small`},{default:_(()=>[o(v,{value:`manual`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.manual`)),1)]),_:1}),o(v,{value:`auto`},{default:_(()=>[i(l(e.$t(`suno.lyricsMode.auto`)),1)]),_:1})]),_:1},8,[`modelValue`])])):m(``,!0)]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var or=W(Pn,[[`render`,ar],[`__scopeId`,`data-v-363599d3`]]),sr=r({name:`ReplaceSectionInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},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`})}}}),cr={class:`field`},lr={class:`flex items-center mb-2`},ur={class:`text-sm font-bold m-0`},dr={key:0,class:`task mb-2`},fr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},pr={class:`info flex-1 min-w-0`},mr={class:`text-sm font-bold m-0 truncate`},hr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},gr={class:`flex gap-2`};function _r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,cr,[n(`div`,lr,[n(`h2`,ur,l(e.$t(`suno.name.replaceSection`)),1),o(d,{content:e.$t(`suno.description.replaceSection`)},null,8,[`content`])]),e.audio?(u(),t(`div`,dr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,fr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,pr,[n(`h2`,mr,l(e.audio?.title),1),n(`p`,hr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,gr,[o(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":r[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`suno.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),o(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":r[2]||=t=>e.replaceSectionEnd=t,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`])])])}var vr=W(sr,[[`render`,_r]]),yr=r({name:`OverpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},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`})}}}),br={class:`field`},xr={class:`flex items-center mb-2`},Sr={class:`text-sm font-bold m-0`},Cr={key:0,class:`task mb-2`},wr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Tr={class:`info flex-1 min-w-0`},Er={class:`text-sm font-bold m-0 truncate`},Dr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Or={class:`flex gap-2`};function kr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,br,[n(`div`,xr,[n(`h2`,Sr,l(e.$t(`suno.name.overpaintingRange`)),1),o(d,{content:e.$t(`suno.description.overpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Cr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,wr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Tr,[n(`h2`,Er,l(e.audio?.title),1),n(`p`,Dr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Or,[o(_,{modelValue:e.overpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.overpaintingStart=t,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(_,{modelValue:e.overpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.overpaintingEnd=t,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`])])])}var Ar=W(yr,[[`render`,kr]]),jr=r({name:`UnderpaintingInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},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`})}}}),Mr={class:`field`},Nr={class:`flex items-center mb-2`},Pr={class:`text-sm font-bold m-0`},Fr={key:0,class:`task mb-2`},Ir={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Lr={class:`info flex-1 min-w-0`},Rr={class:`text-sm font-bold m-0 truncate`},zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Br={class:`flex gap-2`};function Vr(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Mr,[n(`div`,Nr,[n(`h2`,Pr,l(e.$t(`suno.name.underpaintingRange`)),1),o(d,{content:e.$t(`suno.description.underpainting`)},null,8,[`content`])]),e.audio?(u(),t(`div`,Fr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Ir,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Lr,[n(`h2`,Rr,l(e.audio?.title),1),n(`p`,zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Br,[o(_,{modelValue:e.underpaintingStart,"onUpdate:modelValue":r[1]||=t=>e.underpaintingStart=t,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(_,{modelValue:e.underpaintingEnd,"onUpdate:modelValue":r[2]||=t=>e.underpaintingEnd=t,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`])])])}var Hr=W(jr,[[`render`,Vr]]),Ur=r({name:`SamplesInput`,components:{ElInputNumber:U,ElImage:P,InfoIcon:Q},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`})}}}),Wr={class:`field`},Gr={class:`flex items-center mb-2`},Kr={class:`text-sm font-bold m-0`},qr={key:0,class:`task mb-2`},Jr={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Yr={class:`info flex-1 min-w-0`},Xr={class:`text-sm font-bold m-0 truncate`},Zr={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},Qr={class:`flex gap-2`};function $r(e,r,i,a,s,c){let d=g(`info-icon`),p=g(`el-image`),_=g(`el-input-number`),v=h(`loading`);return u(),t(`div`,Wr,[n(`div`,Gr,[n(`h2`,Kr,l(e.$t(`suno.name.samplesRange`)),1),o(d,{content:e.$t(`suno.description.samples`)},null,8,[`content`])]),e.audio?(u(),t(`div`,qr,[n(`div`,{class:`audio flex items-center`,onClick:r[0]||=t=>e.onClick(e.audio)},[f((u(),t(`div`,Jr,[o(p,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Yr,[n(`h2`,Xr,l(e.audio?.title),1),n(`p`,Zr,l(e.audio?.style),1)])])])):m(``,!0),n(`div`,Qr,[o(_,{modelValue:e.samplesStart,"onUpdate:modelValue":r[1]||=t=>e.samplesStart=t,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(_,{modelValue:e.samplesEnd,"onUpdate:modelValue":r[2]||=t=>e.samplesEnd=t,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`])])])}var ei=W(Ur,[[`render`,$r]]),ti=[.5,.75,1,1.25,1.5,2],ni=r({name:`AdjustSpeedInput`,components:{ElRadioGroup:R,ElRadioButton:L,ElImage:P,InfoIcon:Q},data(){return{options:ti}},computed:{audio(){return this.$store.state.suno?.config?.audio},speed:{get(){let e=this.$store.state.suno?.config?.speed;return typeof e==`number`?e:1},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,speed:e})}}},methods:{onClick(e){this.$store.dispatch(`suno/setAudio`,{...this.$store.state.suno.audio,...e,state:`playing`})}}}),ri={class:`field`},ii={class:`flex items-center mb-2`},ai={class:`text-sm font-bold m-0`},oi={key:0,class:`task mb-2`},si={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},ci={class:`info flex-1 min-w-0`},li={class:`text-sm font-bold m-0 truncate`},ui={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`};function di(r,c,d,p,v,y){let b=g(`info-icon`),x=g(`el-image`),S=g(`el-radio-button`),C=g(`el-radio-group`),w=h(`loading`);return u(),t(`div`,ri,[n(`div`,ii,[n(`h2`,ai,l(r.$t(`suno.name.adjustSpeed`)),1),o(b,{content:r.$t(`suno.description.adjustSpeed`)},null,8,[`content`])]),r.audio?(u(),t(`div`,oi,[n(`div`,{class:`audio flex items-center`,onClick:c[0]||=e=>r.onClick(r.audio)},[f((u(),t(`div`,si,[o(x,{src:r.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[w,!r.audio?.audio_url]]),n(`div`,ci,[n(`h2`,li,l(r.audio?.title),1),n(`p`,ui,l(r.audio?.style),1)])])])):m(``,!0),o(C,{modelValue:r.speed,"onUpdate:modelValue":c[1]||=e=>r.speed=e,size:`small`,class:`speed-group`},{default:_(()=>[(u(!0),t(s,null,e(r.options,e=>(u(),a(S,{key:e,value:e},{default:_(()=>[i(l(e)+`x`,1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])])}var fi=W(ni,[[`render`,di],[`__scopeId`,`data-v-ba834628`]]),pi=r({name:`VoiceCreateDialog`,components:{ElDialog:K,ElForm:j,ElFormItem:A,ElInput:G,ElButton:b,ElRadioGroup:R,ElRadio:ee},props:{modelValue:{type:Boolean,default:!1}},emits:[`update:modelValue`,`created`],data(){return{sourceType:`song`,form:{name:``,description:``,audio_id:``,audio_url:``},loading:!1}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit(`update:modelValue`,e)}},token(){return this.$store.state.suno?.credential?.token},canSubmit(){return!(!this.form.name||this.sourceType===`song`&&!this.form.audio_id||this.sourceType===`upload`&&!this.form.audio_url)}},methods:{onClose(){this.visible=!1,this.resetForm()},resetForm(){this.form={name:``,description:``,audio_id:``,audio_url:``},this.sourceType=`song`},async onSubmit(){if(this.token){this.loading=!0;try{this.sourceType===`song`?await Y.persona({audio_id:this.form.audio_id,name:this.form.name,description:this.form.description},{token:this.token}):await Y.voices({audio_url:this.form.audio_url,name:this.form.name,description:this.form.description},{token:this.token}),J.success(this.$t(`suno.voice.createSuccess`)),this.$emit(`created`),this.onClose()}catch{J.error(this.$t(`suno.voice.createFailed`))}finally{this.loading=!1}}}}});function mi(e,t,n,r,s,c){let d=g(`el-input`),f=g(`el-form-item`),p=g(`el-radio`),h=g(`el-radio-group`),v=g(`el-form`),y=g(`el-button`),b=g(`el-dialog`);return u(),a(b,{modelValue:e.visible,"onUpdate:modelValue":t[5]||=t=>e.visible=t,title:e.$t(`suno.voice.createTitle`),width:`480px`,"close-on-click-modal":!1,onClose:e.onClose},{footer:_(()=>[o(y,{onClick:e.onClose},{default:_(()=>[i(l(e.$t(`common.button.cancel`)),1)]),_:1},8,[`onClick`]),o(y,{type:`primary`,loading:e.loading,disabled:!e.canSubmit,onClick:e.onSubmit},{default:_(()=>[i(l(e.$t(`suno.voice.create`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])]),default:_(()=>[o(v,{"label-position":`top`,class:`voice-create-form`},{default:_(()=>[o(f,{label:e.$t(`suno.voice.name`)},{default:_(()=>[o(d,{modelValue:e.form.name,"onUpdate:modelValue":t[0]||=t=>e.form.name=t,placeholder:e.$t(`suno.voice.namePlaceholder`),maxlength:`50`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.description`)},{default:_(()=>[o(d,{modelValue:e.form.description,"onUpdate:modelValue":t[1]||=t=>e.form.description=t,type:`textarea`,rows:2,placeholder:e.$t(`suno.voice.descriptionPlaceholder`),maxlength:`200`},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`]),o(f,{label:e.$t(`suno.voice.sourceType`)},{default:_(()=>[o(h,{modelValue:e.sourceType,"onUpdate:modelValue":t[2]||=t=>e.sourceType=t,class:`w-full`},{default:_(()=>[o(p,{value:`song`},{default:_(()=>[i(l(e.$t(`suno.voice.fromSong`)),1)]),_:1}),o(p,{value:`upload`},{default:_(()=>[i(l(e.$t(`suno.voice.fromUpload`)),1)]),_:1})]),_:1},8,[`modelValue`])]),_:1},8,[`label`]),e.sourceType===`song`?(u(),a(f,{key:0,label:e.$t(`suno.voice.audioId`)},{default:_(()=>[o(d,{modelValue:e.form.audio_id,"onUpdate:modelValue":t[3]||=t=>e.form.audio_id=t,placeholder:e.$t(`suno.voice.audioIdPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0),e.sourceType===`upload`?(u(),a(f,{key:1,label:e.$t(`suno.voice.audioUrl`)},{default:_(()=>[o(d,{modelValue:e.form.audio_url,"onUpdate:modelValue":t[4]||=t=>e.form.audio_url=t,placeholder:e.$t(`suno.voice.audioUrlPlaceholder`)},null,8,[`modelValue`,`placeholder`])]),_:1},8,[`label`])):m(``,!0)]),_:1})]),_:1},8,[`modelValue`,`title`,`onClose`])}var hi=r({name:`VoiceManager`,components:{ElButton:b,ElIcon:w,ElTabs:O,ElTabPane:k,ElTooltip:N,Loading:x,FontAwesomeIcon:Z,VoiceCreateDialog:W(pi,[[`render`,mi]])},data(){return{showCreateDialog:!1,loading:!1,deletingId:null,activeTab:`all`}},computed:{personas(){return this.$store.state.suno?.personas||[]},favoriteIds(){return this.$store.state.suno?.favoritePersonaIds||[]},favoritePersonas(){return this.personas.filter(e=>e.persona_id&&this.favoriteIds.includes(e.persona_id))},visiblePersonas(){return this.activeTab===`favorites`?this.favoritePersonas:this.personas},selectedPersonaId(){return this.$store.state.suno?.config?.persona_id}},watch:{"$store.state.suno.credential":{handler(){this.loadPersonas()},immediate:!0}},methods:{isFavorite(e){return!!e&&this.favoriteIds.includes(e)},onToggleFavorite(e){e.persona_id&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)},async loadPersonas(){if(this.$store.state.suno?.credential?.token){this.loading=!0;try{await this.$store.dispatch(`suno/getPersonas`)}finally{this.loading=!1}}},selectPersona(e){let t={...this.$store.state.suno?.config};t.persona_id===e.persona_id?t.persona_id=void 0:t.persona_id=e.persona_id,this.$store.dispatch(`suno/setConfig`,t)},async onDelete(e){try{await q.confirm(this.$t(`suno.voice.confirmDelete`),this.$t(`suno.voice.delete`),{type:`warning`,confirmButtonText:this.$t(`common.button.confirm`),cancelButtonText:this.$t(`common.button.cancel`)})}catch{return}if(!e.persona_id)return;this.deletingId=e.persona_id;let t=await this.$store.dispatch(`suno/deletePersona`,e.persona_id);if(this.deletingId=null,t){if(J.success(this.$t(`suno.voice.deleteSuccess`)),this.selectedPersonaId===e.persona_id){let e={...this.$store.state.suno?.config,persona_id:void 0};this.$store.dispatch(`suno/setConfig`,e)}this.favoriteIds.includes(e.persona_id)&&this.$store.commit(`suno/togglePersonaFavorite`,e.persona_id)}else J.error(this.$t(`suno.voice.deleteFailed`))},async onCreated(){await this.loadPersonas()}}}),gi={class:`voice-manager`},_i={class:`flex items-center justify-between mb-3`},vi={class:`text-sm font-medium`},yi={key:0,class:`text-center py-6`},bi={key:1,class:`text-center py-6 text-gray-400 text-sm`},xi={key:2,class:`voice-list`},Si=[`onClick`],Ci={class:`flex-1 min-w-0`},wi={class:`voice-name`},Ti={key:0,class:`voice-desc`};function Ei(r,a,f,p,h,v){let y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-tab-pane`),S=g(`el-tabs`),C=g(`loading`),w=g(`el-icon`),T=g(`el-tooltip`),E=g(`voice-create-dialog`);return u(),t(`div`,gi,[n(`div`,_i,[n(`span`,vi,l(r.$t(`suno.voice.title`)),1),o(b,{type:`primary`,size:`small`,onClick:a[0]||=e=>r.showCreateDialog=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-plus`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.create`)),1)]),_:1})]),o(S,{modelValue:r.activeTab,"onUpdate:modelValue":a[1]||=e=>r.activeTab=e,class:`voice-tabs`,size:`small`},{default:_(()=>[o(x,{name:`all`,label:r.$t(`suno.voice.tabAll`)+` (`+(r.personas?.length||0)+`)`},null,8,[`label`]),o(x,{name:`favorites`,label:r.$t(`suno.voice.tabFavorites`)+` (`+r.favoritePersonas.length+`)`},null,8,[`label`])]),_:1},8,[`modelValue`]),r.loading?(u(),t(`div`,yi,[o(w,{class:`is-loading`},{default:_(()=>[o(C)]),_:1})])):r.visiblePersonas.length===0?(u(),t(`div`,bi,l(r.activeTab===`favorites`?r.$t(`suno.voice.emptyFavorites`):r.$t(`suno.voice.empty`)),1)):(u(),t(`div`,xi,[(u(!0),t(s,null,e(r.visiblePersonas,e=>(u(),t(`div`,{key:e.persona_id,class:c([`voice-item`,{active:r.selectedPersonaId===e.persona_id}]),onClick:t=>r.selectPersona(e)},[n(`div`,Ci,[n(`div`,wi,[o(y,{icon:e.source_type===`voice`?`fa-solid fa-microphone`:`fa-solid fa-music`,class:`mr-1.5 text-xs opacity-60`},null,8,[`icon`]),i(` `+l(e.name||e.persona_id),1)]),e.description?(u(),t(`div`,Ti,l(e.description),1)):m(``,!0)]),n(`div`,{class:`voice-actions`,onClick:a[2]||=d(()=>{},[`stop`])},[o(T,{content:r.isFavorite(e.persona_id)?r.$t(`suno.voice.unfavorite`):r.$t(`suno.voice.favorite`),placement:`top`},{default:_(()=>[o(b,{size:`small`,text:``,class:c({"voice-fav-active":r.isFavorite(e.persona_id)}),onClick:t=>r.onToggleFavorite(e)},{default:_(()=>[o(y,{icon:r.isFavorite(e.persona_id)?`fa-solid fa-star`:`fa-regular fa-star`},null,8,[`icon`])]),_:2},1032,[`class`,`onClick`])]),_:2},1032,[`content`]),o(b,{type:`danger`,size:`small`,text:``,loading:r.deletingId===e.persona_id,onClick:t=>r.onDelete(e)},{default:_(()=>[o(y,{icon:`fa-solid fa-trash`})]),_:1},8,[`loading`,`onClick`])])],10,Si))),128))])),o(E,{modelValue:r.showCreateDialog,"onUpdate:modelValue":a[3]||=e=>r.showCreateDialog=e,onCreated:r.onCreated},null,8,[`modelValue`,`onCreated`])])}var Di=r({name:`PersonaInput`,components:{ElSelect:E,ElOption:D,ElButton:b,ElDrawer:z,FontAwesomeIcon:Z,InfoIcon:Q,VoiceManager:W(hi,[[`render`,Ei],[`__scopeId`,`data-v-8b8e36d9`]])},data(){return{showManager:!1}},computed:{personaId:{get(){return this.$store.state.suno?.config?.persona_id||``},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,persona_id:e||void 0})}},personas(){return this.$store.state.suno?.personas||[]}}}),Oi={class:`field`},ki={class:`flex items-center justify-between mb-2`},Ai={class:`flex items-center`},ji={class:`text-sm font-bold`},Mi={class:`flex items-center justify-between w-full`},Ni={key:0,class:`text-xs text-gray-400 ml-2`};function Pi(r,c,d,f,p,h){let v=g(`info-icon`),y=g(`font-awesome-icon`),b=g(`el-button`),x=g(`el-option`),S=g(`el-select`),C=g(`voice-manager`),w=g(`el-drawer`);return u(),t(`div`,Oi,[n(`div`,ki,[n(`div`,Ai,[n(`span`,ji,l(r.$t(`suno.name.persona`)),1),o(v,{content:r.$t(`suno.description.persona`)},null,8,[`content`])]),o(b,{size:`small`,round:``,onClick:c[0]||=e=>r.showManager=!0},{default:_(()=>[o(y,{icon:`fa-solid fa-microphone`,class:`mr-1`}),i(` `+l(r.$t(`suno.voice.manage`)),1)]),_:1})]),o(S,{modelValue:r.personaId,"onUpdate:modelValue":c[1]||=e=>r.personaId=e,placeholder:r.$t(`suno.placeholder.personaId`),clearable:``,filterable:``,class:`w-full`},{default:_(()=>[(u(!0),t(s,null,e(r.personas,e=>(u(),a(x,{key:e.persona_id||``,value:e.persona_id||``,label:e.name||e.persona_id||``},{default:_(()=>[n(`div`,Mi,[n(`span`,null,l(e.name||e.persona_id),1),e.source_type?(u(),t(`span`,Ni,l(e.source_type),1)):m(``,!0)])]),_:2},1032,[`value`,`label`]))),128))]),_:1},8,[`modelValue`,`placeholder`]),o(w,{modelValue:r.showManager,"onUpdate:modelValue":c[2]||=e=>r.showManager=e,title:r.$t(`suno.voice.title`),size:`380px`,direction:`rtl`},{default:_(()=>[o(C)]),_:1},8,[`modelValue`,`title`])])}var Fi=r({name:`PresetPanel`,components:{TypeSelector:Ge,PromptInput:St,LyricInput:It,StyleInput:Xt,TitleInput:nn,ExtendFromInput:gn,CoverFromInput:On,UploadAudio:mt,VocalGenderSelector:Nn,AdvancedParams:or,ReplaceSectionInput:vr,OverpaintingInput:Ar,UnderpaintingInput:Hr,SamplesInput:ei,AdjustSpeedInput:fi,PersonaInput:W(Di,[[`render`,Pi]]),FontAwesomeIcon:Z,ElButton:b,ElTabs:O,ElTabPane:k,Consumption:we},emits:[`generate`],computed:{config(){return this.$store.state.suno?.config},mode:{get(){return this.$store.state.suno?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,custom:e===`custom`})}},consumption(){return me(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service},supportsVocalGender(){let e=this.config?.model||``;return[`chirp-v4-5-plus`,`chirp-v5`,`chirp-v5-5`].includes(e)},supportsPersona(){let e=this.config?.action;return!e||e===`generate`||e===`artist_consistency`||e===`artist_consistency_vox`},generateButtonText(){let e=this.config?.action;return e===`extend`?this.$t(`suno.button.extend`):e===`cover`?this.$t(`suno.button.cover_music`):e===`remaster`?this.$t(`suno.button.remaster`):e===`replace_section`?this.$t(`suno.button.replace_section`):e===`mashup`?this.$t(`suno.button.mashup`):e===`stems`?this.$t(`suno.button.get_stems`):e===`concat`?this.$t(`suno.button.concat_music`):e===`upload_cover`?this.$t(`suno.button.upload_cover`):e===`artist_consistency`?this.$t(`suno.button.artist_consistency`):e===`artist_consistency_vox`?this.$t(`suno.button.artist_consistency_vox`):e===`overpainting`?this.$t(`suno.button.overpainting`):e===`underpainting`?this.$t(`suno.button.underpainting`):e===`samples`?this.$t(`suno.button.samples`):e===`adjust_speed`?this.$t(`suno.button.adjust_speed`):this.$t(`suno.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`suno/setConfig`,{custom:!1,sounds:!1,instrumental:!1,lyric:``,style:``,title:``,lyrics_mode:`manual`,model:this.$store.state.suno?.config?.model})}}}),Ii={class:`flex flex-col h-full`},Li={class:`flex-1 overflow-y-auto p-5`},Ri={class:`pt-2 px-1`},zi={class:`pt-2 px-1`},Bi={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Vi={class:`flex gap-2 w-full`};function Hi(e,r,s,c,d,f){let p=g(`type-selector`),h=g(`upload-audio`),v=g(`prompt-input`),y=g(`extend-from-input`),b=g(`cover-from-input`),x=g(`replace-section-input`),S=g(`overpainting-input`),C=g(`underpainting-input`),w=g(`samples-input`),T=g(`adjust-speed-input`),E=g(`advanced-params`),D=g(`el-tab-pane`),O=g(`lyric-input`),k=g(`style-input`),A=g(`title-input`),j=g(`vocal-gender-selector`),M=g(`persona-input`),N=g(`el-tabs`),P=g(`consumption`),F=g(`font-awesome-icon`),I=g(`el-button`);return u(),t(`div`,Ii,[n(`div`,Li,[o(N,{modelValue:e.mode,"onUpdate:modelValue":r[0]||=t=>e.mode=t,class:`suno-mode-tabs`,stretch:``},{default:_(()=>[o(D,{label:e.$t(`suno.mode.simple`),name:`simple`},{default:_(()=>[n(`div`,Ri,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),o(v,{class:`mb-4`}),e.config?.action===`extend`?(u(),a(y,{key:0,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:1,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:6,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`]),o(D,{label:e.$t(`suno.mode.custom`),name:`custom`},{default:_(()=>[n(`div`,zi,[o(p,{class:`mb-4`}),o(h,{class:`mb-4`}),e.config?.instrumental?m(``,!0):(u(),a(O,{key:0,class:`mb-4`})),o(k,{class:`mb-4`}),o(A,{class:`mb-4`}),!e.config?.instrumental&&e.supportsVocalGender?(u(),a(j,{key:1,class:`mb-4`})):m(``,!0),e.supportsPersona?(u(),a(M,{key:2,class:`mb-4`})):m(``,!0),e.config?.action===`extend`?(u(),a(y,{key:3,class:`mb-4`})):m(``,!0),e.config?.action===`cover`?(u(),a(b,{key:4,class:`mb-4`})):m(``,!0),e.config?.action===`replace_section`?(u(),a(x,{key:5,class:`mb-4`})):m(``,!0),e.config?.action===`overpainting`?(u(),a(S,{key:6,class:`mb-4`})):m(``,!0),e.config?.action===`underpainting`?(u(),a(C,{key:7,class:`mb-4`})):m(``,!0),e.config?.action===`samples`?(u(),a(w,{key:8,class:`mb-4`})):m(``,!0),e.config?.action===`adjust_speed`?(u(),a(T,{key:9,class:`mb-4`})):m(``,!0),o(E,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Bi,[o(P,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Vi,[o(I,{class:`flex-1`,onClick:e.onClearAll},{default:_(()=>[o(F,{icon:`fa-solid fa-broom`,class:`mr-1`}),i(` `+l(e.$t(`suno.button.clear_all`)),1)]),_:1},8,[`onClick`]),o(I,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:_(()=>[o(F,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Ui=W(Fi,[[`render`,Hi],[`__scopeId`,`data-v-c62324e6`]]),Wi=Te(),Gi=ue(`suno`),Ki=r({name:`TaskPreview`,components:{ElImage:P,ElIcon:w,ElTooltip:N,FontAwesomeIcon:Z,VideoPlay:S,VideoPause:C,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElInput:G,ElProgress:ie,ElCheckbox:I,Loading:x,ApiCodeDialog:be},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,isFetchingMidi:!1,editingAudioId:null,editingTitle:``,apiCodeVisible:!1,apiCodePath:`/suno/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===X.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){let e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(e=>({...e,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active},isMashupMode(){return this.$store.state.suno?.config?.action===`mashup`},mashupAudioIds(){return this.$store.state.suno?.config?.mashup_audio_ids||[]}},methods:{useFormatDuring:$,onViewCode(){let e=this.modelValue?.request||{},t={};Object.entries(e).forEach(([e,n])=>{e===`application_id`||e===`callback_url`||n!=null&&(typeof n==`string`&&n===``||Array.isArray(n)&&n.length===0||(t[e]=n))}),this.apiCodeBody=t,this.apiCodePath=`/suno/audios`,this.apiCodeVisible=!0},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);let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);console.log(`on preview`,r),fetch(t).then(e=>e.blob()).then(e=>{(0,Wi.saveAs)(e,r)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;let t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(e){console.error(`get videoUrl failed:`,e),J.error(this.$t(`suno.message.getVideoUrlFailed`))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,n)=>{let r={audio_id:e},i=this.credential?.token;if(!i){console.error(`no token specified`),n(Error(`No token specified`));return}Y.mp4(r,{token:i}).then(e=>{let r=e.data?.data?.video_url;r?t(r):n(Error(`Video URL not found in response`))}).catch(e=>{n(e)})})},onPreview(e,t){e?.stopPropagation(),console.log(`on preview`,t),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){console.log(`on cover`),console.debug(`set config`,e),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl(`concat`,e)},async onRemaster(e){await this.onGenerateAudioUrl(`remaster`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`replace_section`,audio:e,audio_id:e.id,replace_section_start:0,replace_section_end:Math.min(30,e.duration||30)})},onMashup(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`mashup`,audio:e,audio_id:e.id,mashup_audio_ids:[e.id]})},onOverpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`overpainting`,audio:e,audio_id:e.id,overpainting_start:0,overpainting_end:Math.min(30,e.duration||30)})},onUnderpainting(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`underpainting`,audio:e,audio_id:e.id,underpainting_start:0,underpainting_end:Math.min(30,e.duration||30)})},onSamples(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`samples`,audio:e,audio_id:e.id,samples_start:0,samples_end:Math.min(30,e.duration||30)})},onArtistConsistency(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`artist_consistency`,audio:e,audio_id:e.id})},onAdjustSpeed(e){this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:e.model,custom:!0,style:e.style,action:`adjust_speed`,audio:e,audio_id:e.id,speed:1})},onReusePrompt(e){let t=this.modelValue?.request??{};if(!(t.prompt||t.lyric||t.style||t.title||t.lyric_prompt||t.style_negative||t.persona_id)){J.warning(this.$t(`suno.message.reusePromptEmpty`));return}this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,model:t.model??e.model,custom:t.custom??!1,instrumental:t.instrumental??!1,prompt:t.prompt??``,lyric:t.lyric??``,lyric_prompt:t.lyric_prompt??``,lyrics_mode:t.lyrics_mode??`manual`,title:t.title??``,style:t.style??``,style_negative:t.style_negative??``,vocal_gender:t.vocal_gender,weirdness:t.weirdness,style_influence:t.style_influence,variation_category:t.variation_category,audio_weight:t.audio_weight,persona_id:t.persona_id,action:void 0,audio:void 0,audio_id:void 0,mashup_audio_ids:void 0,continue_at:void 0,speed:void 0,replace_section_start:void 0,replace_section_end:void 0,overpainting_start:void 0,overpainting_end:void 0,underpainting_start:void 0,underpainting_end:void 0,samples_start:void 0,samples_end:void 0}),J.success(this.$t(`suno.message.reusePromptSuccess`))},async onExtractVocals(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.extractingVocals`)),Y.vox({audio_id:e,callback_url:Gi},{token:t}).then(()=>{J.success(this.$t(`suno.message.extractVocalsSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.extractVocalsFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()}))},async onGetTiming(e){let t=this.credential?.token;t&&(J.info(this.$t(`suno.message.fetchingTiming`)),Y.timing({audio_id:e},{token:t}).then(e=>{J.success(this.$t(`suno.message.fetchTimingSuccess`)),console.debug(`timing data`,e.data)}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.fetchTimingFailed`))}))},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,J.info(this.$t(`suno.message.fetchingWav`));let n=(await Y.wav({audio_id:e.id},{token:t})).data?.data?.[0]?.file_url;n?this.onDownload(null,n):J.error(this.$t(`suno.message.fetchWavFailed`))}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async handleMidiDownload(e){if(!e?.id||this.isFetchingMidi)return;let t=this.credential?.token;if(t)try{this.isFetchingMidi=!0,J.info(this.$t(`suno.message.fetchingMidi`));let n=(await Y.midi({audio_id:e.id},{token:t})).data?.data;if(!n?.length){J.error(this.$t(`suno.message.fetchMidiFailed`));return}let r=(e.title||e.id||`suno`).replace(/[^\w.-]+/g,`_`)+`.json`;(0,Wi.saveAs)(new Blob([JSON.stringify(n,null,2)],{type:`application/json`}),r)}catch(e){let t=e?.response?.data?.error?.message;J.error(t||this.$t(`suno.message.fetchMidiFailed`))}finally{this.isFetchingMidi=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Gi},r=this.credential?.token;if(!r){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),Y.audio(n,{token:r}).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.response?.data?.error?.message||this.$t(`suno.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},isMashupSelected(e){return!!e.id&&this.mashupAudioIds.includes(e.id)},onToggleMashup(e){if(!e.id)return;let t=[...this.mashupAudioIds],n=t.indexOf(e.id);n===-1?t.push(e.id):t.splice(n,1),this.$store.commit(`suno/setConfig`,{...this.$store.state.suno?.config,mashup_audio_ids:t})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},onStartTitleEdit(e){this.editingAudioId=e.id??null,this.editingTitle=e.title||``,this.$nextTick(()=>{this.$refs.titleInput?.focus?.()})},onSaveTitleEdit(e){if(this.editingAudioId!==e.id)return;let t=this.editingTitle.trim();if(t&&t!==e.title){let n=this.$store.state.suno?.tasks;if(n?.items)for(let r of n.items){let n=(r?.response?.data??[]).find(t=>t.id===e.id);if(n){n.title=t;break}}}this.editingAudioId=null,this.editingTitle=``},onCancelTitleEdit(){this.editingAudioId=null,this.editingTitle=``},async onDelete(e){try{await q.confirm(this.$t(`suno.message.confirmDelete`),{confirmButtonText:this.$t(`suno.button.delete`),cancelButtonText:this.$t(`common.button.cancel`),type:`warning`})}catch{return}let t=this.$store.state.suno?.tasks;if(t?.items)for(let n of t.items){let r=n?.response?.data??[],i=r.findIndex(t=>t.id===e.id);if(i!==-1){if(r.splice(i,1),r.length===0){let e=t.items.indexOf(n);e!==-1&&t.items.splice(e,1)}break}}this.$store.state?.suno?.audio?.id===e.id&&this.$store.dispatch(`suno/setAudio`,null),J.success(this.$t(`suno.message.deleteSuccess`))},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`suno/getTasks`,{limit:30,offset:0})}}}),qi={class:`task`},Ji=[`onClick`],Yi=[`onClick`],Xi={class:`left`},Zi=[`onClick`],Qi=[`onClick`],$i={key:2,class:`duration`},ea={class:`info`},ta={key:1,class:`title-row`},na={class:`title`},ra={class:`style`},ia={key:2,class:`progress-row`},aa={class:`progress-text`},oa={class:`right`},sa={class:`el-dropdown-link`},ca={class:`flex items-center min-w-[120px]`},la={class:`flex items-center min-w-[120px]`},ua={class:`flex items-center min-w-[120px]`},da={class:`el-dropdown-link`};function fa(r,p,v,b,x,S){let C=g(`el-checkbox`),w=g(`el-image`),T=g(`video-pause`),E=g(`el-icon`),D=g(`video-play`),O=g(`el-input`),k=g(`font-awesome-icon`),A=g(`el-progress`),j=g(`el-tooltip`),M=g(`Loading`),N=g(`el-dropdown-item`),P=g(`el-dropdown-menu`),F=g(`el-dropdown`),I=g(`api-code-dialog`),L=h(`loading`);return u(),t(`div`,qi,[(u(!0),t(s,null,e(r.audios,e=>(u(),t(`div`,{key:e.id,class:c([`audio`,{"mashup-selected":r.isMashupSelected(e)}]),onClick:d(t=>r.onClick(e),[`stop`])},[r.isMashupMode&&e?.audio_url?(u(),t(`div`,{key:0,class:`mashup-check`,onClick:d(t=>r.onToggleMashup(e),[`stop`])},[o(C,{"model-value":r.isMashupSelected(e),onClick:p[0]||=d(()=>{},[`stop`])},null,8,[`model-value`])],8,Yi)):m(``,!0),f((u(),t(`div`,Xi,[o(w,{src:e?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),e?.audio_url&&r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`playing`?(u(),t(`div`,{key:0,class:`overlay`,onClick:d(t=>r.onPause(e),[`stop`])},[o(E,null,{default:_(()=>[o(T)]),_:1})],8,Zi)):m(``,!0),e?.audio_url&&(r.$store.state?.suno?.audio?.id!==e.id||r.$store.state?.suno?.audio?.id===e.id&&r.$store.state?.suno?.audio?.state===`paused`)?(u(),t(`div`,{key:1,class:`overlay`,onClick:d(t=>r.onPlay(e),[`stop`])},[o(E,null,{default:_(()=>[o(D)]),_:1})],8,Qi)):m(``,!0),e?.duration?(u(),t(`div`,$i,l(r.useFormatDuring(e?.duration)),1)):m(``,!0)])),[[L,!e?.audio_url]]),n(`div`,ea,[r.editingAudioId===e.id?(u(),t(`div`,{key:0,class:`title-edit`,onClick:p[2]||=d(()=>{},[`stop`])},[o(O,{ref_for:!0,ref:`titleInput`,modelValue:r.editingTitle,"onUpdate:modelValue":p[1]||=e=>r.editingTitle=e,size:`small`,onKeyup:[y(t=>r.onSaveTitleEdit(e),[`enter`]),y(r.onCancelTitleEdit,[`escape`])],onBlur:t=>r.onSaveTitleEdit(e)},null,8,[`modelValue`,`onKeyup`,`onBlur`])])):(u(),t(`div`,ta,[n(`h2`,na,l(e?.title),1),e?.audio_url?(u(),a(k,{key:0,icon:`fa-solid fa-pen`,class:`edit-icon`,onClick:d(t=>r.onStartTitleEdit(e),[`stop`])},null,8,[`onClick`])):m(``,!0)])),n(`p`,ra,l(e?.style),1),!e?.audio_url&&e?.progress!=null&&e?.progress<100?(u(),t(`div`,ia,[o(A,{percentage:Math.round(e.progress),"stroke-width":4,"show-text":!1,status:`warning`,class:`progress-bar`},null,8,[`percentage`]),n(`span`,aa,l(r.$t(`suno.name.generating`))+` `+l(Math.round(e.progress))+`%`,1)])):m(``,!0)]),n(`div`,oa,[o(F,null,{dropdown:_(()=>[o(P,null,{default:_(()=>[o(N,{disabled:r.isFetchingVideoUrl,onClick:t=>r.handleVideoDownload(e)},{default:_(()=>[n(`div`,ca,[r.isFetchingVideoUrl?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onDownload(t,e?.audio_url),[`stop`])},{default:_(()=>[i(l(r.$t(`suno.button.download_audio`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{disabled:r.isFetchingWav,onClick:t=>r.handleWavDownload(e)},{default:_(()=>[n(`div`,la,[r.isFetchingWav?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`]),o(N,{disabled:r.isFetchingMidi,onClick:t=>r.handleMidiDownload(e)},{default:_(()=>[n(`div`,ua,[r.isFetchingMidi?(u(),a(E,{key:0,class:`is-loading mr-2`},{default:_(()=>[o(M)]),_:1})):m(``,!0),n(`span`,null,l(r.$t(`suno.button.download_midi`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:_(()=>[n(`span`,sa,[o(j,{effect:`dark`,content:r.$t(`suno.button.download`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),o(F,null,{dropdown:_(()=>[o(P,{class:`suno-action-menu`},{default:_(()=>[e?.audio_url?(u(),a(N,{key:0,onClick:d(t=>r.onExtend(t,e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-forward`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extend`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(t=>r.onCover(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-music`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.cover_music`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:1,onClick:d(t=>r.onMashup(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-shuffle`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.mashup`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id&&e?.action===`extend`?(u(),a(N,{key:2,onClick:d(t=>r.onConcatMusic(e?.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-link`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.concat_music`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[4]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:3,onClick:d(t=>r.onReplaceSection(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-scissors`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.replace_section`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:4,onClick:d(t=>r.onOverpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-microphone`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.overpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:5,onClick:d(t=>r.onUnderpainting(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-guitar`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.underpainting`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:6,onClick:d(t=>r.onSamples(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-drum`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.samples`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[5]||=n(`div`,{class:`menu-divider`},null,-1),e.id?(u(),a(N,{key:7,onClick:d(t=>r.onGetStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-layer-group`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e.id?(u(),a(N,{key:8,onClick:d(t=>r.onGetAllStems(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-bars-staggered`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.all_stems`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:9,onClick:d(t=>r.onRemaster(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-wand-magic-sparkles`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.remaster`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:10,onClick:d(t=>r.onExtractVocals(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-headphones`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.extract_vocals`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:11,onClick:d(t=>r.onArtistConsistency(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-palette`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.artist_consistency`)),1)]),_:1},8,[`onClick`])):m(``,!0),e?.id?(u(),a(N,{key:12,onClick:d(t=>r.onAdjustSpeed(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-gauge-high`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.adjust_speed`)),1)]),_:1},8,[`onClick`])):m(``,!0),p[6]||=n(`div`,{class:`menu-divider`},null,-1),o(N,{onClick:d(t=>r.onReusePrompt(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-rotate-left`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.reuse_prompt`)),1)]),_:1},8,[`onClick`]),e?.id?(u(),a(N,{key:13,onClick:d(t=>r.onGetTiming(e.id),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-clock`,class:`menu-icon`}),i(` `+l(r.$t(`suno.button.get_timing`)),1)]),_:1},8,[`onClick`])):m(``,!0),o(N,{onClick:d(r.onViewCode,[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-code`,class:`menu-icon`}),i(` `+l(r.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`]),p[7]||=n(`div`,{class:`menu-divider`},null,-1),e?.id?(u(),a(N,{key:14,class:`delete-item`,onClick:d(t=>r.onDelete(e),[`stop`])},{default:_(()=>[o(k,{icon:`fa-solid fa-trash`,class:`menu-icon delete-icon`}),i(` `+l(r.$t(`suno.button.delete`)),1)]),_:1},8,[`onClick`])):m(``,!0)]),_:2},1024)]),default:_(()=>[n(`span`,da,[o(j,{effect:`dark`,content:r.$t(`suno.button.more`),placement:`top`},{default:_(()=>[e?.audio_url||e?.video_url?(u(),a(k,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):m(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],10,Ji))),128)),o(I,{visible:r.apiCodeVisible,"onUpdate:visible":p[3]||=e=>r.apiCodeVisible=e,method:`POST`,path:r.apiCodePath,body:r.apiCodeBody,token:r.$store.state.suno?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var pa=r({name:`RecentPanel`,components:{ElSkeletonItem:ae,ElSkeleton:oe,ElInput:G,ElButton:b,ElDropdown:H,ElDropdownMenu:V,ElDropdownItem:B,ElPopover:re,ElRadioGroup:R,ElRadioButton:L,ElSelect:E,ElOption:D,FontAwesomeIcon:Z,TaskPreview:W(Ki,[[`render`,fa]]),Player:Ee,NoTasks:Ce,ScrollList:ye},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0,searchQuery:``,sortBy:`newest`,filterType:`all`,filterDuration:`all`,filterVideo:`all`,filterModel:`all`}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}},sortLabel(){return this.sortBy===`newest`?this.$t(`suno.sort.newest`):this.$t(`suno.sort.oldest`)},activeFilterCount(){let e=0;return this.filterType!==`all`&&e++,this.filterDuration!==`all`&&e++,this.filterVideo!==`all`&&e++,this.filterModel&&this.filterModel!==`all`&&e++,e},availableModels(){let e=this.tasks?.items||[],t=new Set;for(let n of e){let e=n?.response?.data??[];for(let n of e)n.model&&t.add(n.model)}return Array.from(t).sort()},filteredTasks(){let e=this.tasks?.items||[];if(this.searchQuery){let t=this.searchQuery.toLowerCase();e=e.filter(e=>(e?.response?.data??[]).some(e=>e.title?.toLowerCase().includes(t)||e.style?.toLowerCase().includes(t)||e.prompt?.toLowerCase().includes(t)))}return this.activeFilterCount>0&&(e=e.filter(e=>{let t=e?.request??{},n=e?.response?.data??[];return this.filterType===`vocal`&&t.instrumental===!0||this.filterType===`instrumental`&&t.instrumental!==!0?!1:this.filterDuration!==`all`||this.filterVideo!==`all`||this.filterModel&&this.filterModel!==`all`?n.some(e=>!(this.filterDuration===`short`&&!(typeof e.duration==`number`&&e.duration<60)||this.filterDuration===`medium`&&!(typeof e.duration==`number`&&e.duration>=60&&e.duration<=180)||this.filterDuration===`long`&&!(typeof e.duration==`number`&&e.duration>180)||this.filterVideo===`with`&&!e.video_url||this.filterVideo===`without`&&e.video_url||this.filterModel&&this.filterModel!==`all`&&e.model!==this.filterModel)):!0})),this.sortBy===`oldest`&&(e=[...e].reverse()),e}},methods:{onSortChange(e){this.sortBy=e},onResetFilters(){this.filterType=`all`,this.filterDuration=`all`,this.filterVideo=`all`,this.filterModel=`all`},getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),ma={key:0,class:`tasks`},ha={class:`left w-[70px] p-[10px] flex items-center`},ga={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},_a={key:0,class:`task-toolbar`},va={key:0,class:`filter-badge`},ya={class:`filter-popover`},ba={class:`filter-row`},xa={class:`filter-label`},Sa={class:`filter-row`},Ca={class:`filter-label`},wa={class:`filter-row`},Ta={class:`filter-label`},Ea={key:0,class:`filter-row`},Da={class:`filter-label`},Oa={class:`filter-actions`},ka={key:2,class:`w-full flex-1 flex items-center justify-center`},Aa={class:`text-sm text-gray-400`},ja={key:3,class:`w-full flex-1 flex flex-col items-center justify-center gap-2`},Ma={class:`text-sm text-gray-400`},Na={key:4,class:`w-full flex-1 flex items-center justify-center`},Pa={class:`h-20`};function Fa(r,d,p,h,y,b){let x=g(`el-skeleton-item`),S=g(`el-skeleton`),C=g(`font-awesome-icon`),w=g(`el-input`),T=g(`el-button`),E=g(`el-dropdown-item`),D=g(`el-dropdown-menu`),O=g(`el-dropdown`),k=g(`el-radio-button`),A=g(`el-radio-group`),j=g(`el-option`),M=g(`el-select`),N=g(`el-popover`),P=g(`task-preview`),F=g(`scroll-list`),I=g(`no-tasks`),L=g(`player`);return u(),t(s,null,[r.tasks?.items===void 0?(u(),t(`div`,ma,[(u(),t(s,null,e(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,ha,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,ga,[o(S,{animated:``},{template:_(()=>[o(x,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),o(x,{variant:`text`})]),_:1})])])),64))])):(u(),t(s,{key:1},[r.tasks?.items?.length?(u(),t(`div`,_a,[o(w,{modelValue:r.searchQuery,"onUpdate:modelValue":d[0]||=e=>r.searchQuery=e,size:`small`,placeholder:r.$t(`suno.placeholder.searchSongs`),clearable:``,class:`task-search`},{prefix:_(()=>[o(C,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs`})]),_:1},8,[`modelValue`,`placeholder`]),o(O,{trigger:`click`,onCommand:r.onSortChange},{dropdown:_(()=>[o(D,null,{default:_(()=>[o(E,{command:`newest`,class:c({"is-active":r.sortBy===`newest`})},{default:_(()=>[i(l(r.$t(`suno.sort.newest`)),1)]),_:1},8,[`class`]),o(E,{command:`oldest`,class:c({"is-active":r.sortBy===`oldest`})},{default:_(()=>[i(l(r.$t(`suno.sort.oldest`)),1)]),_:1},8,[`class`])]),_:1})]),default:_(()=>[o(T,{size:`small`,class:`sort-btn`},{default:_(()=>[o(C,{icon:`fa-solid fa-arrow-down-wide-short`,class:`mr-1`}),i(` `+l(r.sortLabel),1)]),_:1})]),_:1},8,[`onCommand`]),o(N,{trigger:`click`,placement:`bottom-end`,width:260},{reference:_(()=>[o(T,{size:`small`,class:c([`filter-btn`,{"has-active-filter":r.activeFilterCount>0}])},{default:_(()=>[o(C,{icon:`fa-solid fa-filter`,class:`mr-1`}),i(` `+l(r.$t(`suno.filter.title`))+` `,1),r.activeFilterCount>0?(u(),t(`span`,va,l(r.activeFilterCount),1)):m(``,!0)]),_:1},8,[`class`])]),default:_(()=>[n(`div`,ya,[n(`div`,ba,[n(`div`,xa,l(r.$t(`suno.filter.type`)),1),o(A,{modelValue:r.filterType,"onUpdate:modelValue":d[1]||=e=>r.filterType=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.typeAll`)),1)]),_:1}),o(k,{value:`vocal`},{default:_(()=>[i(l(r.$t(`suno.filter.typeVocal`)),1)]),_:1}),o(k,{value:`instrumental`},{default:_(()=>[i(l(r.$t(`suno.filter.typeInstrumental`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,Sa,[n(`div`,Ca,l(r.$t(`suno.filter.duration`)),1),o(A,{modelValue:r.filterDuration,"onUpdate:modelValue":d[2]||=e=>r.filterDuration=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.durationAll`)),1)]),_:1}),o(k,{value:`short`},{default:_(()=>[i(l(r.$t(`suno.filter.durationShort`)),1)]),_:1}),o(k,{value:`medium`},{default:_(()=>[i(l(r.$t(`suno.filter.durationMedium`)),1)]),_:1}),o(k,{value:`long`},{default:_(()=>[i(l(r.$t(`suno.filter.durationLong`)),1)]),_:1})]),_:1},8,[`modelValue`])]),n(`div`,wa,[n(`div`,Ta,l(r.$t(`suno.filter.video`)),1),o(A,{modelValue:r.filterVideo,"onUpdate:modelValue":d[3]||=e=>r.filterVideo=e,size:`small`},{default:_(()=>[o(k,{value:`all`},{default:_(()=>[i(l(r.$t(`suno.filter.videoAll`)),1)]),_:1}),o(k,{value:`with`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWith`)),1)]),_:1}),o(k,{value:`without`},{default:_(()=>[i(l(r.$t(`suno.filter.videoWithout`)),1)]),_:1})]),_:1},8,[`modelValue`])]),r.availableModels.length>0?(u(),t(`div`,Ea,[n(`div`,Da,l(r.$t(`suno.filter.model`)),1),o(M,{modelValue:r.filterModel,"onUpdate:modelValue":d[4]||=e=>r.filterModel=e,size:`small`,placeholder:r.$t(`suno.filter.modelAll`),clearable:``},{default:_(()=>[o(j,{label:r.$t(`suno.filter.modelAll`),value:`all`},null,8,[`label`]),(u(!0),t(s,null,e(r.availableModels,e=>(u(),a(j,{key:e,label:e,value:e},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])):m(``,!0),n(`div`,Oa,[o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])])]),_:1})])):m(``,!0),r.filteredTasks?.length>0?(u(),a(F,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:r.loading,onReachTop:d[5]||=e=>r.$emit(`reach-top`)},{default:_(()=>[(u(!0),t(s,null,e(r.filteredTasks,(e,t)=>(u(),a(P,{key:t,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):r.searchQuery&&r.tasks?.items?.length>0?(u(),t(`div`,ka,[n(`p`,Aa,l(r.$t(`suno.message.noSearchResults`)),1)])):r.activeFilterCount>0&&r.tasks?.items?.length>0?(u(),t(`div`,ja,[n(`p`,Ma,l(r.$t(`suno.message.noFilterResults`)),1),o(T,{size:`small`,text:``,onClick:r.onResetFilters},{default:_(()=>[i(l(r.$t(`suno.filter.reset`)),1)]),_:1},8,[`onClick`])])):r.tasks?.items?.length===0?(u(),t(`div`,Na,[o(I)])):m(``,!0)],64)),f(n(`div`,Pa,[o(L,{namespace:`suno`})],512),[[v,!!r.$store?.state?.suno?.audio?.object]])],64)}var Ia=W(pa,[[`render`,Fa],[`__scopeId`,`data-v-6ce376c9`]]),La=r({name:`TaskPreview`,components:{IconPicture:T,ElImage:P,ElAvatar:F,ElIcon:w},computed:{audio(){return this.$store.state.suno?.audio}}}),Ra={key:0,class:`size-full overflow-hidden`},za={class:`relative h-[300px]`},Ba={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},Va={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`},Ha={class:`p-4`},Ua={class:`flex items-center font-bold mb-2`},Wa={class:`text-[var(--el-text-color-regular)] mb-2`},Ga={class:`text-xs text-[var(--el-text-color-regular)]`},Ka={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},qa={key:1,class:`w-full h-full`};function Ja(e,r,i,a,s,c){let d=g(`icon-picture`),f=g(`el-icon`),p=g(`el-image`),m=g(`el-avatar`);return e.audio?.object?(u(),t(`div`,Ra,[n(`div`,za,[o(p,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:_(()=>[n(`div`,Ba,[o(f,{class:`text-3xl`},{default:_(()=>[o(d)]),_:1})])]),_:1},8,[`src`]),n(`h2`,Va,l(e.audio?.title),1)]),n(`div`,Ha,[n(`div`,Ua,[o(m,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,l(e.audio?.title),1)]),n(`p`,Wa,l(e.audio?.style),1),n(`p`,Ga,l(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,Ka,[n(`p`,null,l(e.audio?.lyric),1)])])])):(u(),t(`div`,qa))}var Ya=W(La,[[`render`,Ja]]),Xa=ue(`suno`),Za=r({name:`SunoIndex`,components:{Layout:Ne,ConfigPanel:Ui,RecentPanel:Ia,PreviewPanel:Ya},mixins:[fe],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===X.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===X.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===X.Request},needApply(){return this.$store.state.suno.status.getApplications===X.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug(`new tasks detected`)},deep:!0},initialized:{async handler(e){e&&(console.debug(`layout initialized`),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await xe({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(){de.create({application:this.application}).then(({data:e})=>{this.application=e,J.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&J.error(this.$t(`application.message.alreadyApplied`))})},async onScrollDown(){await this.$nextTick();let 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);let{limit:t=5,createdAtMin:n,createdAtMax:r}=e||{};console.debug(`limit`,t,`createdAtMin`,n,`createdAtMax`,r),this.fetchingTasks=!0;try{await this.$store.dispatch(`suno/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!he(this.uploadTracker,e=>this.$t(e),e=>J.warning(e)))return;let e={...this.config,callback_url:Xa};if(!this.hasSunoInput(e)){J.error(this.$t(`suno.message.promptRequired`));return}this.hasText(e.prompt)&&(e.prompt=e.prompt.trim());let t=this.credential?.token;if(!t){console.error(`no token specified`);return}J.info(this.$t(`suno.message.startingTask`)),pe(`suno`,Y.audio(e,{token:t})).then(()=>{J.success(this.$t(`suno.message.startTaskSuccess`))}).catch(e=>{J.error(e?.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?.()},hasText(e){return typeof e==`string`&&e.trim().length>0},hasSunoInput(e){return[e.prompt,e.lyric,e.lyric_prompt,e.style,e.title].some(e=>this.hasText(e))||this.hasText(e.audio_id)||Array.isArray(e.mashup_audio_ids)&&e.mashup_audio_ids.length>0}}});function Qa(e,t,n,r,i,s){let c=g(`config-panel`),l=g(`recent-panel`),d=g(`preview-panel`),f=g(`layout`);return u(),a(f,null,{config:_(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:_(()=>[o(l,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:_(()=>[o(d)]),_:1})}var $a=W(Za,[[`render`,Qa],[`__scopeId`,`data-v-b9beee12`]]);export{$a as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,M as i,N as a,O as o,P as s,S as c,Wt as l,Z as u,et as d,k as f,tt as p,ut as m}from"./vendor-chart-BJCvKk8-.js";import{t as h}from"./button-DfsQodL-.js";import{r as g,t as _}from"./select-B1uV_nnl.js";import{n as v,t as y}from"./collapse-zZjSyR53.js";import{t as b}from"./drawer-Dpuj2uIl.js";import"./constants-CwLEZ_AF.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-CxBOJBZd.js";import{t as E}from"./index.es-Dw2lhymn.js";import{t as ee}from"./Consumption-C3v4xGTO.js";var te=r({name:`LayoutSerp`,components:{ElDrawer:b,ElButton:h,FontAwesomeIcon:E},data(){return{drawer:!1}}}),D={class:`main flex flex-row flex-1`},O={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},k={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function A(e,r,i,a,o,c){let l=p(`font-awesome-icon`),f=p(`el-button`),h=p(`el-drawer`);return u(),t(`div`,D,[n(`div`,O,[d(e.$slots,`config`,{},void 0,!0)]),n(`div`,k,[d(e.$slots,`result`,{},void 0,!0)]),s(f,{circle:``,class:`menu`,onClick:r[0]||=t=>e.drawer=!0},{default:m(()=>[s(l,{icon:`fa-solid fa-search`})]),_:1}),s(h,{modelValue:e.drawer,"onUpdate:modelValue":r[1]||=t=>e.drawer=t,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:m(()=>[d(e.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=r({name:`QueryInput`,components:{ElInput:S},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e})}}}}),N={class:`field`},P={class:`box`},F={class:`title font-bold`};function I(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,N,[n(`div`,P,[n(`h2`,F,l(e.$t(`serp.name.query`)),1)]),s(d,{modelValue:e.query,"onUpdate:modelValue":r[0]||=t=>e.query=t,rows:3,type:`textarea`,class:`prompt`,placeholder:e.$t(`serp.placeholder.query`)},null,8,[`modelValue`,`placeholder`])])}var L=x(M,[[`render`,I],[`__scopeId`,`data-v-3582b195`]]),R=r({name:`TypeSelector`,components:{ElSelect:g,ElOption:_},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||=`search`}}),z={class:`field`},B={class:`title font-bold`};function V(e,r,i,a,o,c){let d=p(`el-option`),f=p(`el-select`);return u(),t(`div`,z,[n(`h2`,B,l(e.$t(`serp.name.type`)),1),s(f,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`},{default:m(()=>[s(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),s(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),s(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),s(d,{value:`videos`,label:e.$t(`serp.type.videos`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var H=x(R,[[`render`,V],[`__scopeId`,`data-v-2913fb62`]]),U=r({name:`CountryInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||=`US`}}),W={class:`field`},G={class:`title font-bold`};function K(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,W,[n(`h2`,G,l(e.$t(`serp.name.country`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.country`)},null,8,[`modelValue`,`placeholder`])])}var q=x(U,[[`render`,K],[`__scopeId`,`data-v-f0672cc6`]]),J=r({name:`LanguageInput`,components:{ElInput:S},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||=`en`}}),Y={class:`field`},X={class:`title font-bold`};function Z(e,r,i,a,o,c){let d=p(`el-input`);return u(),t(`div`,Y,[n(`h2`,X,l(e.$t(`serp.name.language`)),1),s(d,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=r({name:`SearchPanel`,components:{ElButton:h,FontAwesomeIcon:E,QueryInput:L,TypeSelector:H,CountryInput:q,LanguageInput:x(J,[[`render`,Z],[`__scopeId`,`data-v-dc1c94b7`]]),Consumption:ee},emits:[`search`],computed:{config(){return this.$store.state.serp?.config},consumption(){return C(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===T.Request}},methods:{onSearch(){this.$emit(`search`)}}}),ne={class:`flex flex-col h-full`},re={class:`flex-1 overflow-y-auto p-5`},ie={class:`flex flex-col items-center justify-center px-5 pb-5`};function ae(e,r,i,o,c,d){let f=p(`query-input`),h=p(`type-selector`),g=p(`country-input`),_=p(`language-input`),v=p(`consumption`),y=p(`font-awesome-icon`),b=p(`el-button`);return u(),t(`div`,ne,[n(`div`,re,[s(f,{class:`mb-4`}),s(h,{class:`mb-4`}),s(g,{class:`mb-4`}),s(_,{class:`mb-4`})]),n(`div`,ie,[s(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),s(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:m(()=>[s(y,{icon:`fa-solid fa-search`,class:`mr-2`}),a(` `+l(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=r({name:`KnowledgeGraph`,props:{data:{type:Object,required:!0}}}),ce={class:`knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},le={class:`flex flex-row gap-4`},ue=[`src`,`alt`],de={class:`flex-1 min-w-0`},fe={key:0,class:`text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide`},pe={class:`text-xl font-bold mb-1.5`},me={key:1,class:`text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed`},he=[`href`],ge={key:2,class:`text-sm`},_e={class:`text-[var(--el-text-color-disabled)] flex-none font-medium`},ve={class:`text-[var(--el-text-color-regular)]`};function ye(r,i,o,s,d,p){return u(),t(`div`,ce,[n(`div`,le,[r.data.image_url?(u(),t(`img`,{key:0,src:r.data.image_url,alt:r.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):f(``,!0),n(`div`,de,[r.data.type?(u(),t(`div`,fe,l(r.data.type),1)):f(``,!0),n(`h3`,pe,l(r.data.title),1),r.data.description?(u(),t(`p`,me,[a(l(r.data.description)+` `,1),r.data.description_link?(u(),t(`a`,{key:0,href:r.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},l(r.data.description_source||`Source`),9,he)):f(``,!0)])):f(``,!0),r.data.attributes&&Object.keys(r.data.attributes).length?(u(),t(`div`,ge,[(u(!0),t(c,null,e(r.data.attributes,(e,r)=>(u(),t(`div`,{key:r,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,l(r)+`:`,1),n(`span`,ve,l(e),1)]))),128))])):f(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=r({name:`OrganicResult`,props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return``;try{return new URL(this.data.link).hostname}catch{return``}},pathname(){if(!this.data.link)return``;try{let e=new URL(this.data.link).pathname;return e===`/`?``:e}catch{return``}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?``:`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display=`none`}}}),Se={class:`organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]`},Ce={key:0,class:`flex items-center gap-2 mb-1.5`},we=[`src`,`alt`],Te={class:`text-xs text-[var(--el-text-color-secondary)] truncate`},Ee={class:`text-xs text-[var(--el-text-color-disabled)]`},De=[`href`],Oe={key:1,class:`text-xs text-[var(--el-text-color-disabled)] mt-1`},ke={key:2,class:`text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3`},Ae={key:3,class:`mt-3 flex flex-wrap gap-x-4 gap-y-1`},je=[`href`];function Me(r,i,a,o,s,d){return u(),t(`div`,Se,[r.displayUrl?(u(),t(`div`,Ce,[n(`img`,{src:r.faviconUrl,alt:r.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:i[0]||=(...e)=>r.onFaviconError&&r.onFaviconError(...e)},null,40,we),n(`span`,Te,l(r.hostname),1),n(`span`,Ee,l(r.pathname),1)])):f(``,!0),n(`a`,{href:r.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},l(r.data.title),9,De),r.data.date?(u(),t(`div`,Oe,l(r.data.date),1)):f(``,!0),r.data.snippet?(u(),t(`p`,ke,l(r.data.snippet),1)):f(``,!0),r.data.sitelinks?.length?(u(),t(`div`,Ae,[(u(!0),t(c,null,e(r.data.sitelinks,(e,n)=>(u(),t(`a`,{key:n,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors`},l(e.title),9,je))),128))])):f(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=r({name:`ImageResults`,props:{data:{type:Array,required:!0}}}),Fe={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},Ie={class:`text-base font-bold mb-3`},Le={class:`grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3`},Re=[`href`],ze=[`src`,`alt`],Be={class:`absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200`},Ve={class:`text-xs text-white line-clamp-2`};function He(r,i,a,o,s,d){return u(),t(`div`,Fe,[n(`h3`,Ie,l(r.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square`},[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover transition-transform duration-300 group-hover:scale-105`,loading:`lazy`},null,8,ze)):f(``,!0),n(`div`,Be,[n(`span`,Ve,l(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=r({name:`VideoResults`,props:{data:{type:Array,required:!0}}}),Ge={class:`text-base font-bold mb-3`},Ke={class:`space-y-4`},qe=[`href`],Je={class:`relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},Ye=[`src`,`alt`],Xe={key:1,class:`absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded`},Ze={class:`flex-1 min-w-0`},Qe={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},$e={class:`text-xs text-gray-400 mt-1`},et={key:0},tt={key:1},nt={key:2},rt={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`};function it(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,Ge,l(r.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(u(),t(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):f(``,!0),e.duration?(u(),t(`div`,Xe,l(e.duration),1)):f(``,!0)]),n(`div`,Ze,[n(`div`,Qe,l(e.title),1),n(`div`,$e,[e.source?(u(),t(`span`,et,l(e.source),1)):f(``,!0),e.channel?(u(),t(`span`,tt,` · `+l(e.channel),1)):f(``,!0),e.date?(u(),t(`span`,nt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,rt,l(e.snippet),1)):f(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=r({name:`NewsResults`,props:{data:{type:Array,required:!0}}}),st={class:`text-base font-bold mb-3`},ct={class:`space-y-4`},lt=[`href`],ut={class:`flex-1 min-w-0`},dt={class:`text-blue-600 group-hover:underline font-medium line-clamp-2`},ft={class:`text-xs text-gray-400 mt-1`},pt={key:0},mt={key:1},ht={key:0,class:`text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2`},gt={key:0,class:`flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800`},_t=[`src`,`alt`];function vt(r,i,a,o,s,d){return u(),t(`div`,null,[n(`h3`,st,l(r.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(u(!0),t(c,null,e(r.data,(e,r)=>(u(),t(`a`,{key:r,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,l(e.title),1),n(`div`,ft,[e.source?(u(),t(`span`,pt,l(e.source),1)):f(``,!0),e.date?(u(),t(`span`,mt,` · `+l(e.date),1)):f(``,!0)]),e.snippet?(u(),t(`p`,ht,l(e.snippet),1)):f(``,!0)]),e.image_url?(u(),t(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):f(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=r({name:`PeopleAlsoAsk`,components:{ElCollapse:y,ElCollapseItem:v},props:{data:{type:Array,required:!0}}}),xt={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},St={class:`text-base font-bold mb-3`},Ct={key:0,class:`text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed`},wt=[`href`];function Tt(r,i,a,d,h,g){let _=p(`el-collapse-item`),v=p(`el-collapse`);return u(),t(`div`,xt,[n(`h3`,St,l(r.$t(`serp.name.peopleAlsoAsk`)),1),s(v,null,{default:m(()=>[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),o(_,{key:n,title:e.question||e.title||``},{default:m(()=>[e.snippet?(u(),t(`p`,Ct,l(e.snippet),1)):f(``,!0),e.link?(u(),t(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},l(e.title||e.link),9,wt)):f(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=r({name:`RelatedSearches`,components:{FontAwesomeIcon:E},props:{data:{type:Array,required:!0}},emits:[`search`],methods:{onSearch(e){e&&this.$emit(`search`,e)}}}),Ot={class:`rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]`},kt={class:`text-base font-bold mb-3`},At={class:`flex flex-wrap gap-2`},jt=[`onClick`];function Mt(r,i,o,d,f,m){let h=p(`font-awesome-icon`);return u(),t(`div`,Ot,[n(`h3`,kt,l(r.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(u(!0),t(c,null,e(r.data,(e,n)=>(u(),t(`button`,{key:n,class:`inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none`,onClick:t=>r.onSearch(e.query)},[s(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),a(` `+l(e.query),1)],8,jt))),128))])])}var Nt=r({name:`ResultPanel`,components:{FontAwesomeIcon:E,KnowledgeGraph:be,OrganicResult:Ne,ImageResults:Ue,VideoResults:at,NewsResults:yt,PeopleAlsoAsk:Et,RelatedSearches:x(Dt,[[`render`,Mt]])},emits:[`related-search`],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===T.Request},noResults(){return this.$store.state.serp?.status?.search===T.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit(`related-search`,e)}}}),$={class:`h-full overflow-y-auto p-6`},Pt={key:0,class:`max-w-3xl mx-auto py-8`},Ft={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},It={class:`text-base`},Lt={key:2,class:`max-w-3xl mx-auto`},Rt={key:1,class:`mb-6`},zt={key:3,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Bt={class:`text-base`};function Vt(r,a,d,m,h,g){let _=p(`font-awesome-icon`),v=p(`knowledge-graph`),y=p(`organic-result`),b=p(`image-results`),x=p(`video-results`),S=p(`news-results`),C=p(`people-also-ask`),w=p(`related-searches`);return u(),t(`div`,$,[r.searching?(u(),t(`div`,Pt,[(u(),t(c,null,e(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...a[0]||=[i(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):r.noResults?(u(),t(`div`,Ft,[s(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,l(r.$t(`serp.message.noResults`)),1)])):r.results?(u(),t(`div`,Lt,[r.results.knowledge_graph?.title?(u(),o(v,{key:0,data:r.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.organic?.length?(u(),t(`div`,Rt,[(u(!0),t(c,null,e(r.results.organic,(e,t)=>(u(),o(y,{key:t,data:e,class:`mb-1`},null,8,[`data`]))),128))])):f(``,!0),r.results.images?.length?(u(),o(b,{key:2,data:r.results.images,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.videos?.length?(u(),o(x,{key:3,data:r.results.videos,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.news?.length?(u(),o(S,{key:4,data:r.results.news,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.people_also_ask?.length?(u(),o(C,{key:5,data:r.results.people_also_ask,class:`mb-6`},null,8,[`data`])):f(``,!0),r.results.related_searches?.length?(u(),o(w,{key:6,data:r.results.related_searches,class:`mb-6`,onSearch:r.onRelatedSearch},null,8,[`data`,`onSearch`])):f(``,!0)])):(u(),t(`div`,zt,[s(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,l(r.$t(`serp.description.query`)),1)]))])}var Ht=r({name:`SerpIndex`,components:{Layout:j,SearchPanel:oe,ResultPanel:x(Nt,[[`render`,Vt]])},inject:[`initialized`],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug(`start onGetService`),await this.$store.dispatch(`serp/getService`),console.debug(`end onGetService`)},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t(`serp.message.searching`));try{await this.$store.dispatch(`serp/search`),w.success(this.$t(`serp.message.searchSuccess`))}catch(e){(e?.response?.data)?.error?.code===`used_up`?w.error(this.$t(`serp.message.usedUp`)):w.error(this.$t(`serp.message.searchFailed`))}}},async onRelatedSearch(e){this.$store.commit(`serp/setConfig`,{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function Ut(e,t,n,r,i,a){let c=p(`search-panel`),l=p(`result-panel`),d=p(`layout`);return u(),o(d,null,{config:m(()=>[s(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:m(()=>[s(l,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{A as e,F as t,Z as n}from"./vendor-chart-BJCvKk8-.js";import{E as r}from"./index-CxBOJBZd.js";var i=t({name:`SettingsIndex`,mounted(){let e=this.$route.query.tab||``;window.dispatchEvent(new CustomEvent(`open-user-settings`,{detail:{tab:e}}))}}),a={class:`settings-page`};function o(t,r,i,o,s,c){return n(),e(`div`,a)}var s=r(i,[[`render`,o]]);export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{D as e,F as t,O as n,P as r,Wt as i,Z as a,dt as o,nt as s,tt as c,ut as l}from"./vendor-chart-BJCvKk8-.js";import{n as u,t as d}from"./table-lRQt4LGt.js";import{t as f}from"./card-DjyfNde2.js";import{n as p,t as m}from"./row-d76bUVm3.js";import{t as h}from"./Pagination-DeCHT-PM.js";import{E as g,kn as _}from"./index-CxBOJBZd.js";import{t as v}from"./CopyToClipboard-D1o-dyv3.js";var y=t({name:`ConsoleDistributionInvitees`,components:{Pagination:h,CopyToClipboard:v,ElRow:m,ElCol:p,ElTable:d,ElTableColumn:u,ElCard:f},data(){return{invitees:[],loading:!1,total:void 0,limit:10}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData()},methods:{onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{page:e}})},onFetchData(){this.loading=!0,Promise.all([this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onFetchInvitees(){let{data:e}=await _.getInvitees({limit:this.limit,offset:(this.page-1)*this.limit,ordering:`-created_at`});this.invitees=e.items,this.total=e.count}}}),b={class:`title`},x={class:`key`},S={class:`copy`},C={class:`description`},w={class:`description`},T={class:`description`},E={class:`created-at`},D={class:`pagination m-v-lg`};function O(t,u,d,f,p,m){let h=c(`el-col`),g=c(`el-row`),_=c(`copy-to-clipboard`),v=c(`el-table-column`),y=c(`el-table`),O=c(`el-card`),k=c(`pagination`),A=s(`loading`);return a(),n(g,{class:`panel`},{default:l(()=>[r(h,{span:24},{default:l(()=>[r(g,null,{default:l(()=>[r(h,{span:24},{default:l(()=>[e(`h2`,b,i(t.$t(`common.title.invitee`)),1)]),_:1})]),_:1}),r(g,null,{default:l(()=>[r(h,{span:24},{default:l(()=>[r(O,{shadow:`hover`},{default:l(()=>[o((a(),n(y,{data:t.invitees,stripe:``},{default:l(()=>[r(v,{prop:`id`,label:t.$t(`user.field.id`),"class-name":`text-center`,width:`350px`},{default:l(t=>[e(`span`,x,i(t.row.id),1),e(`span`,S,[r(_,{content:t.row.id},null,8,[`content`])])]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.username`),width:`300px`},{default:l(t=>[e(`span`,C,i(t.row?.username),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.email`),width:`300px`},{default:l(t=>[e(`span`,w,i(t.row?.email),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.nickname`),width:`200px`},{default:l(t=>[e(`span`,T,i(t.row.nickname),1)]),_:1},8,[`label`]),r(v,{label:t.$t(`user.field.dateJoined`)},{default:l(n=>[e(`span`,E,i(t.$dayjs.format(n.row.date_joined)),1)]),_:1},8,[`label`])]),_:1},8,[`data`])),[[A,t.loading]])]),_:1})]),_:1})]),_:1}),r(g,null,{default:l(()=>[r(h,{span:10,offset:14},{default:l(()=>[e(`div`,D,[r(k,{"current-page":t.page,"page-size":t.limit,total:t.total,onChange:t.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var k=g(y,[[`render`,O],[`__scopeId`,`data-v-4556864d`]]);export{k as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Wt as c,Z as l,dt as u,nt as d,tt as f,ut as p}from"./vendor-chart-BJCvKk8-.js";import{t as m}from"./button-DfsQodL-.js";import{r as h,t as g}from"./select-B1uV_nnl.js";import{n as _,t as v}from"./table-lRQt4LGt.js";import{t as y}from"./date-picker-CpTCVLld.js";import{t as b}from"./card-DjyfNde2.js";import{n as x,t as S}from"./row-d76bUVm3.js";import{t as C}from"./Pagination-DeCHT-PM.js";import{t as w}from"./skeleton-C4sltx62.js";import{Cn as T,E,Pr as D,Pt as O,dr as k}from"./index-CxBOJBZd.js";import{t as A}from"./index.es-Dw2lhymn.js";import{t as j}from"./CopyToClipboard-D1o-dyv3.js";var M={total_count:0,total_spent:0,state_counts:{}},N=r({name:`ConsoleOrderList`,components:{Pagination:C,CopyToClipboard:j,ElRow:S,ElCol:x,ElTable:v,ElTableColumn:_,ElButton:m,ElTag:D,ElCard:b,ElSelect:h,ElOption:g,ElDatePicker:y,ElSkeleton:w,FontAwesomeIcon:A},data(){return{OrderState:k,orders:[],loading:!1,total:void 0,limit:10,filterState:this.$route.query.state?.toString()||``,filterPayWay:this.$route.query.pay_way?.toString()||``,createdAtRange:(()=>{let e=this.$route.query.created_at_from?.toString(),t=this.$route.query.created_at_to?.toString();if(e&&t)return[new Date(e),new Date(t)]})(),summary:{...M},summaryLoading:!1,exporting:!1,shortcuts:[{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}]}},computed:{page(){return parseInt(this.$route.query.page?.toString()||`1`)},stateOptions(){return[{value:k.PENDING,label:this.$t(`order.state.pending`)},{value:k.FINISHED,label:this.$t(`order.state.finished`)},{value:k.PAID,label:this.$t(`order.state.paid`)},{value:k.EXPIRED,label:this.$t(`order.state.expired`)},{value:k.FAILED,label:this.$t(`order.state.failed`)},{value:k.REFUNDED,label:this.$t(`order.state.refunded`)}]},payWayOptions(){return[{value:`WechatPay`,label:this.$t(`order.title.wechatPay`)},{value:`Stripe`,label:this.$t(`order.title.stripe`)},{value:`AliPay`,label:this.$t(`order.title.aliPay`)},{value:`X402`,label:this.$t(`order.title.x402`)},{value:`PayPal`,label:this.$t(`order.title.paypal`)}]},filterQuery(){let e={user_id:this.$store.getters.user?.id};return this.filterState&&(e.state=this.filterState),this.filterPayWay&&(e.pay_way=this.filterPayWay),this.createdAtRange?.[0]&&(e.created_at_from=this.createdAtRange[0]),this.createdAtRange?.[1]&&(e.created_at_to=this.createdAtRange[1]),e}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onFetchData(),this.onFetchSummary()},methods:{getPriceString:O,stateTagType(e){return e===k.FINISHED||e===k.PAID?`success`:e===k.EXPIRED||e===k.FAILED?`danger`:e===k.REFUNDED?`warning`:`info`},stateLabel(e){return{[k.PENDING]:this.$t(`order.state.pending`),[k.PAID]:this.$t(`order.state.paid`),[k.FINISHED]:this.$t(`order.state.finished`),[k.EXPIRED]:this.$t(`order.state.expired`),[k.FAILED]:this.$t(`order.state.failed`),[k.REFUNDED]:this.$t(`order.state.refunded`)}[e]||e},isPendingAction(e){return e!==k.PAID&&e!==k.FINISHED&&e!==k.EXPIRED&&e!==k.FAILED&&e!==k.REFUNDED},goToDetail(e){this.$router.push({name:`console-order-detail`,params:{id:e}})},async onFilterChange(){await this.$router.push({name:this.$route.name?.toString(),query:{page:1,...this.filterState?{state:this.filterState}:{},...this.filterPayWay?{pay_way:this.filterPayWay}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0].toISOString()}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1].toISOString()}:{}}}),this.onFetchData(),this.onFetchSummary()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},onFetchData(){this.loading=!0,T.getAll({ordering:`-created_at`,limit:this.limit,offset:(this.page-1)*this.limit,...this.filterQuery}).then(({data:e})=>{this.orders=e.items,this.total=e.count}).catch(()=>{}).finally(()=>{this.loading=!1})},onFetchSummary(){this.summaryLoading=!0,T.getSummary(this.filterQuery).then(({data:e})=>{this.summary=e}).catch(()=>{this.summary={...M}}).finally(()=>{this.summaryLoading=!1})},onExport(){this.exporting=!0,T.exportCsv(this.filterQuery).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`orders.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})}}}),P={class:`title`},F={key:1,class:`card-content`},I={class:`icon-wrapper`},L={class:`description`},R={class:`value`},z={key:1,class:`card-content`},B={class:`icon-wrapper`},V={class:`description`},H={class:`value`},U={key:1,class:`card-content`},W={class:`icon-wrapper`},ee={class:`description`},G={class:`value`},K={key:1,class:`card-content`},q={class:`icon-wrapper`},J={class:`description`},Y={class:`value`},X={class:`filter-row mb-3`},Z={class:`key`},Q={class:`cursor-pointer`},$={class:`price`},te={class:`description`},ne={class:`text-gray-500`},re={class:`created-at`},ie={class:`flex items-center justify-center flex-wrap`},ae={class:`float-right`};function oe(r,m,h,g,_,v){let y=f(`el-col`),b=f(`el-row`),x=f(`el-skeleton`),S=f(`font-awesome-icon`),C=f(`el-card`),w=f(`el-option`),T=f(`el-select`),E=f(`el-date-picker`),D=f(`el-button`),O=f(`copy-to-clipboard`),k=f(`el-table-column`),A=f(`el-tag`),j=f(`el-table`),M=f(`pagination`),N=d(`loading`);return l(),a(b,{class:`panel`},{default:p(()=>[o(y,{span:24},{default:p(()=>[o(b,null,{default:p(()=>[o(y,{span:24},{default:p(()=>[n(`h2`,P,c(r.$t(`common.title.allOrders`)),1)]),_:1})]),_:1}),o(b,{gutter:16},{default:p(()=>[o(y,{md:6,sm:12,xs:24},{default:p(()=>[o(C,{shadow:`hover`,class:`item-mini mb-3`},{default:p(()=>[r.summaryLoading?(l(),a(x,{key:0})):(l(),t(`div`,F,[n(`div`,I,[o(S,{icon:`fa-solid fa-receipt`,class:`icon`})]),n(`p`,L,c(r.$t(`order.title.totalOrders`)),1),n(`p`,R,c(r.summary.total_count),1)]))]),_:1})]),_:1}),o(y,{md:6,sm:12,xs:24},{default:p(()=>[o(C,{shadow:`hover`,class:`item-mini mb-3`},{default:p(()=>[r.summaryLoading?(l(),a(x,{key:0})):(l(),t(`div`,z,[n(`div`,B,[o(S,{icon:`fa-solid fa-dollar-sign`,class:`icon`})]),n(`p`,V,c(r.$t(`order.title.totalSpent`)),1),n(`p`,H,c(r.getPriceString({value:r.summary.total_spent})),1)]))]),_:1})]),_:1}),o(y,{md:6,sm:12,xs:24},{default:p(()=>[o(C,{shadow:`hover`,class:`item-mini mb-3`},{default:p(()=>[r.summaryLoading?(l(),a(x,{key:0})):(l(),t(`div`,U,[n(`div`,W,[o(S,{icon:`fa-solid fa-check-circle`,class:`icon`})]),n(`p`,ee,c(r.$t(`order.title.finishedOrders`)),1),n(`p`,G,c(r.summary.state_counts?.Finished||0),1)]))]),_:1})]),_:1}),o(y,{md:6,sm:12,xs:24},{default:p(()=>[o(C,{shadow:`hover`,class:`item-mini mb-3`},{default:p(()=>[r.summaryLoading?(l(),a(x,{key:0})):(l(),t(`div`,K,[n(`div`,q,[o(S,{icon:`fa-solid fa-clock`,class:`icon`})]),n(`p`,J,c(r.$t(`order.title.pendingOrders`)),1),n(`p`,Y,c(r.summary.state_counts?.Pending||0),1)]))]),_:1})]),_:1})]),_:1}),n(`div`,X,[o(T,{modelValue:r.filterState,"onUpdate:modelValue":m[0]||=e=>r.filterState=e,clearable:``,placeholder:r.$t(`order.field.allStates`),class:`filter-select`,onChange:r.onFilterChange},{default:p(()=>[(l(!0),t(s,null,e(r.stateOptions,e=>(l(),a(w,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),o(T,{modelValue:r.filterPayWay,"onUpdate:modelValue":m[1]||=e=>r.filterPayWay=e,clearable:``,placeholder:r.$t(`order.field.allPayWays`),class:`filter-select`,onChange:r.onFilterChange},{default:p(()=>[(l(!0),t(s,null,e(r.payWayOptions,e=>(l(),a(w,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]),o(E,{modelValue:r.createdAtRange,"onUpdate:modelValue":m[2]||=e=>r.createdAtRange=e,type:`datetimerange`,shortcuts:r.shortcuts,"range-separator":r.$t(`usage.placeholder.to`),"start-placeholder":r.$t(`usage.placeholder.startDate`),"end-placeholder":r.$t(`usage.placeholder.endDate`),onChange:r.onFilterChange},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`]),o(D,{type:`primary`,plain:``,loading:r.exporting,onClick:r.onExport},{default:p(()=>[o(S,{icon:`fa-solid fa-file-export`,class:`mr-1`}),i(` `+c(r.$t(`order.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),o(b,null,{default:p(()=>[o(y,{span:24},{default:p(()=>[o(C,{shadow:`hover`},{default:p(()=>[u((l(),a(j,{data:r.orders,stripe:``,"empty-text":r.$t(`common.message.noData`),class:`min-h-[calc(100vh-450px)] mb-[20px]`},{default:p(()=>[o(k,{prop:`id`,label:r.$t(`order.field.id`),"class-name":`text-center`,width:`200px`},{default:p(e=>[n(`span`,Z,c(e.row.id),1),n(`span`,Q,[o(O,{content:e.row.id,class:`inline-block`},null,8,[`content`])])]),_:1},8,[`label`]),o(k,{label:r.$t(`order.field.price`),width:`110px`,align:`center`},{default:p(e=>[n(`span`,$,c(r.getPriceString({value:e.row?.price})),1)]),_:1},8,[`label`]),o(k,{label:r.$t(`order.field.description`),"min-width":`220px`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:p(e=>[n(`span`,te,c(e.row.description),1)]),_:1},8,[`label`]),o(k,{prop:`state`,label:r.$t(`order.field.state`),width:`130px`,align:`center`},{default:p(e=>[o(A,{type:r.stateTagType(e.row.state),class:`mx-1`,effect:`dark`,round:``,size:`small`},{default:p(()=>[i(c(r.stateLabel(e.row.state)),1)]),_:2},1032,[`type`])]),_:1},8,[`label`]),o(k,{label:r.$t(`order.field.payWay`),width:`120px`,align:`center`,"class-name":`hidden md:table-cell`,"label-class-name":`hidden md:table-cell`},{default:p(e=>[n(`span`,ne,c(e.row.pay_way||`-`),1)]),_:1},8,[`label`]),o(k,{label:r.$t(`order.field.createdAt`),width:`200px`,"class-name":`hidden sm:table-cell`,"label-class-name":`hidden sm:table-cell`},{default:p(e=>[n(`span`,re,c(r.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`]),o(k,{"min-width":`130px`,fixed:`right`},{default:p(e=>[n(`div`,ie,[r.isPendingAction(e.row.state)?(l(),a(D,{key:0,type:`primary`,size:`small`,onClick:t=>r.goToDetail(e.row.id)},{default:p(()=>[i(c(r.$t(`order.button.continuePay`)),1)]),_:1},8,[`onClick`])):(l(),a(D,{key:1,size:`small`,onClick:t=>r.goToDetail(e.row.id)},{default:p(()=>[i(c(r.$t(`order.button.checkDetail`)),1)]),_:1},8,[`onClick`]))])]),_:1})]),_:1},8,[`data`,`empty-text`])),[[N,r.loading]])]),_:1})]),_:1})]),_:1}),o(b,null,{default:p(()=>[o(y,{span:10,offset:14},{default:p(()=>[n(`div`,ae,[o(M,{"current-page":r.page,"page-size":r.limit,total:r.total,onChange:r.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var se=E(N,[[`render`,oe],[`__scopeId`,`data-v-350ab467`]]);export{se as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"./rolldown-runtime--c01j_DQ.js";import{D as e,E as t,M as n,N as r,O as i,P as a,Q as o,Ut as s,X as c,_ as l,a as u,c as d,et as f,i as ee,k as p,lt as m,n as h,o as g,r as _,s as v,t as y,tt as b,ut as x,x as S}from"./vendor-chart-mdwpew_o.js";import{t as C}from"./button-DWzbdjZV.js";import{r as w,t as T}from"./select-BxVmNFP6.js";import{n as E,t as D}from"./table-fY8LUehs.js";import{n as O,t as k}from"./tabs-DwY1eAPe.js";import{t as A}from"./date-picker-DU59CcgU.js";import{t as j}from"./card-B1OoUKT4.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as P,t as F}from"./row-CaRpmAhk.js";import{t as I}from"./Pagination-uSqRcf5u.js";import{n as L,t as R}from"./skeleton-Cn4UY-T8.js";import{An as z,E as B,En as V,Mr as H,Pr as U,Tn as W,_r as G,lr as K,ur as q,wn as J}from"./index-BbCaZ5EZ.js";import{t as Y}from"./index.es-DInZDd-8.js";import{t as X}from"./CopyToClipboard-D8uYio89.js";ee.register(_,u,h,v,d,g);var Z=a({name:`ConsoleUsageList`,components:{Pagination:I,ElTag:U,ElDatePicker:A,ElTable:D,ElSelect:w,ElOption:T,CopyToClipboard:X,ElRow:F,ElCol:P,ElTableColumn:E,ElCard:j,ElRadioButton:M,ElRadioGroup:N,ElSkeleton:R,ElSkeletonItem:L,ElDialog:H,ElTabs:O,ElTabPane:k,ElButton:C,FontAwesomeIcon:Y,BarChart:y},data(){return{applicationIds:this.$route.query.application_id?.toString()?this.$route.query.application_id?.toString().split(`,`):[],apiIds:this.$route.query.api_id?.toString()?this.$route.query.api_id?.toString().split(`,`):[],applications:[],apis:[],apisLoading:!1,credentialType:K,serviceType:q,apiUsages:[],proxyUsages:[],createdAtRange:(()=>{let e=this.$route.query.created_at_to?.toString(),t=this.$route.query.created_at_from?.toString();if(t&&e)return[new Date(t),new Date(e)];let n=new Date,r=new Date;return r.setDate(1),r.setHours(0,0,0,0),[r,n]})(),shortcuts:[{text:this.$t(`usage.shortcuts.thisMonth`),value:()=>{let e=new Date,t=new Date;return t.setDate(1),t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last1Day`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-1),[t,e]}},{text:this.$t(`usage.shortcuts.last3Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-3),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}],type:this.$route.query.type?.toString()||q.API,loading:!1,total:void 0,limit:15,totalUsed:0,barChartLabels:[],barChartSeries:[],aggLoading:!1,detailDialogVisible:!1,detailRow:null,detailActiveTab:`request`,detailLoading:!1,exporting:!1,statusCodeFilter:this.$route.query.status_code?.toString()||``,statusCodeOptions:[],statusCodeOptionsLoading:!1}},computed:{redirect(){return this.$route.query?.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},totalUsedString(){return`${(this.totalUsed||0).toFixed(2)}`},barChartData(){return{labels:this.barChartLabels,datasets:this.barChartSeries.map(e=>({label:e.label,data:e.data,backgroundColor:e.color}))}},barChartOptions(){return{responsive:!0,plugins:{legend:{position:`top`,onClick:(e,t,n)=>{let r=n?.chart;if(!r||t?.datasetIndex===void 0)return;let i=t.datasetIndex,a=r.data?.datasets||[];a.some((e,t)=>t!==i&&r.isDatasetVisible(t))?a.forEach((e,t)=>r.setDatasetVisibility(t,t===i)):a.forEach((e,t)=>r.setDatasetVisibility(t,!0)),r.update()}},title:{display:!0,text:this.$t(`usage.title.usageTrend`)}},scales:{x:{stacked:!0},y:{stacked:!0,beginAtZero:!0}}}}},watch:{page:{handler(){this.onFetchUsages()}},type:{handler(){this.applicationIds=[],this.apiIds=[],this.onApplicationsChange(this.applicationIds),this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()}}},mounted(){this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},methods:{async onFetchUsages(){this.type===q.API?this.onFetchApiUsages():this.type===q.Proxy&&this.onFetchProxyUsages()},async onApiChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onApisChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e&&e.length?e.join(`,`):``}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onTimeRangeChanged(){console.log(`onTimeRangeChanged`,this.createdAtRange),await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,created_at_from:this.createdAtRange?this.$dayjs.format(this.createdAtRange[0].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``,created_at_to:this.createdAtRange?this.$dayjs.format(this.createdAtRange[1].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``}}),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},async onApplicationChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e}}),this.onFetchUsages(),this.onFetchAggregate()},async onApplicationsChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e&&e.length?e.join(`,`):``}}),this.onFetchUsages(),this.onFetchAggregate()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},getRemainingAmount(e){if(e.remaining_amount===void 0||e.remaining_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.remaining_amount?.toFixed(6)} ${t}`},getUsedAmount(e){if(e.used_amount===void 0||e.used_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.used_amount?.toFixed(6)} ${t}`},getDeductedAmount(e){if(e?.deducted_amount===void 0||e?.deducted_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.deducted_amount?.toFixed(6)} ${t}`},getOriginalAmount(e){if(e?.original_amount===void 0||e?.original_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.original_amount?.toFixed(6)} ${t}`},onStatusCodeChange(e){let t={...this.$route.query},n=(e||``).trim();n?t.status_code=n:delete t.status_code,delete t.status_code_filter,this.$router.push({name:this.$route.name?.toString(),query:t}),this.onFetchUsages(),this.onFetchAggregate()},async onFetchStatusCodeOptions(){this.statusCodeOptionsLoading=!0;try{let{data:e}=await W.getStatusCodes({user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}});this.statusCodeOptions=(e?.items||[]).slice().sort((e,t)=>e-t)}catch{this.statusCodeOptions=[]}finally{this.statusCodeOptionsLoading=!1}},formatElapsed(e){return e==null||Number.isNaN(e)?`-`:e<1?`${Math.round(e*1e3)} ms`:`${e.toFixed(2)} s`},getSimpleMetadata(e){if(!e)return{};let t={};for(let[n,r]of Object.entries(e))n===`request`||n===`response`||typeof r==`object`&&r||(t[n]=r);return t},onShowDetail(e){this.detailRow={...e,metadata:void 0},this.detailActiveTab=`request`,this.detailDialogVisible=!0,this.detailLoading=!0,e.id&&W.get(e.id).then(e=>{this.detailRow=e.data}).finally(()=>{this.detailLoading=!1})},formatJson(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}},onFetchApplications(){z.getAll({limit:100,offset:0,user_id:this.$store.getters.user.id,ordering:`-created_at`,type:G.USAGE}).then(({data:e})=>{this.applications=e.items.filter(e=>e?.service?.type===this.type)}).catch(()=>{})},onFetchApis(){this.apisLoading=!0,J.getAll({limit:100,offset:0,ordering:`-created_at`}).then(({data:e})=>{this.apis=e.items}).catch(()=>{}).finally(()=>{this.apisLoading=!1})},onFetchApiUsages(){console.log(`onFetchApiUsages`,this.createdAtRange),this.loading=!0,W.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{this.apiUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onFetchProxyUsages(){this.loading=!0,V.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{}}).then(({data:e})=>{this.proxyUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onExport(){this.exporting=!0,W.exportCsv({user_id:this.$store.getters.user.id,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`usages.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})},async onFetchAggregate(){if(this.aggLoading=!0,this.type!==this.serviceType.API)return;let e={user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}};try{let{data:t}=await W.getAggregate(e);this.totalUsed=t.total||0;let n=Array.from(new Set((t.items||[]).map(e=>e.date))).sort(),r=Array.from(new Set((t.items||[]).map(e=>e.api_id))),i=e=>`hsl(${e*57%360}, 70%, 60%)`,a=r.map((e,r)=>{let a=t.apis?.[e]?.title||e,o={};return(t.items||[]).filter(t=>t.api_id===e).forEach(e=>{o[e.date]=e.amount||0}),{key:e,label:a,data:n.map(e=>o[e]||0),color:i(r)}});this.barChartLabels=n,this.barChartSeries=a}finally{this.aggLoading=!1}}}}),Q={class:`text-[26px] font-bold mb-5 text-[var(--el-text-color-primary)]`},$={class:`inline-block w-9`},te={class:`inline-block`},ne={key:1,class:`summary-card`},re={class:`icon-wrapper`},ie={class:`text-left`},ae={class:`description`},oe={class:`value`},se={class:`chart-wrapper`},ce={key:0},le={key:1},ue={class:`flex flex-wrap gap-2`},de={class:`key`},fe={key:0,class:`cursor-pointer`},pe={class:`created-at`},me={class:`created-at`},he={key:1,class:`detail-json`},ge={key:2,class:`text-gray-400`},_e={key:1,class:`detail-json`},ve={key:2,class:`text-gray-400`},ye={class:`float-right`};function be(a,u,d,ee,h,g){let _=f(`el-col`),v=f(`el-row`),y=f(`el-radio-button`),C=f(`el-radio-group`),w=f(`el-option`),T=f(`el-select`),E=f(`el-skeleton-item`),D=f(`el-skeleton`),O=f(`el-date-picker`),k=f(`font-awesome-icon`),A=f(`el-button`),j=f(`el-card`),M=f(`bar-chart`),N=f(`el-table-column`),P=f(`el-tag`),F=f(`copy-to-clipboard`),I=f(`el-table`),L=f(`el-tab-pane`),R=f(`el-tabs`),z=f(`el-dialog`),B=f(`pagination`),V=b(`loading`);return c(),e(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[t(`h2`,Q,s(a.$t(`common.title.allUsages`)),1)]),_:1})]),_:1}),r(v,null,{default:m(()=>[r(_,{md:4,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,null,s(a.$t(`application.field.type`)),1),r(C,{modelValue:a.type,"onUpdate:modelValue":u[0]||=e=>a.type=e},{default:m(()=>[r(y,{value:a.serviceType.API,label:a.$t(`application.field.api`)},null,8,[`value`,`label`]),r(y,{value:a.serviceType.Proxy,label:a.$t(`application.field.proxy`)},null,8,[`value`,`label`])]),_:1},8,[`modelValue`])]),_:1}),x(r(_,{md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,$,s(a.$t(`usage.field.application`)),1),r(T,{modelValue:a.applicationIds,"onUpdate:modelValue":u[1]||=e=>a.applicationIds=e,placeholder:a.$t(`usage.field.application`),clearable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApplicationsChange},{default:m(()=>[(c(!0),p(S,null,o(a.applications,t=>(c(),e(w,{key:t.id,label:t.service?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`])]),_:1},512),[[l,!1]]),a.type===a.serviceType.API?(c(),e(_,{key:0,md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[t(`span`,te,s(a.$t(`usage.field.api`)),1),a.apisLoading?(c(),e(D,{key:0,animated:``,class:`w-full`},{template:m(()=>[r(E,{variant:`rect`,style:{height:`32px`,"border-radius":`4px`}})]),_:1})):(c(),e(T,{key:1,modelValue:a.apiIds,"onUpdate:modelValue":u[2]||=e=>a.apiIds=e,placeholder:a.$t(`usage.field.api`),clearable:``,filterable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:a.onApisChange},{default:m(()=>[(c(!0),p(S,null,o(a.apis,t=>(c(),e(w,{key:t?.id,label:t?.title,value:t?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]))]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:1,md:8,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(O,{modelValue:a.createdAtRange,"onUpdate:modelValue":u[3]||=e=>a.createdAtRange=e,type:`datetimerange`,class:`w-full`,shortcuts:a.shortcuts,"range-separator":a.$t(`usage.placeholder.to`),"start-placeholder":a.$t(`usage.placeholder.startDate`),"end-placeholder":a.$t(`usage.placeholder.endDate`),onChange:a.onTimeRangeChanged},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:2,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:m(()=>[r(T,{modelValue:a.statusCodeFilter,"onUpdate:modelValue":u[4]||=e=>a.statusCodeFilter=e,placeholder:a.$t(`usage.option.statusCodeAll`),class:`w-full`,clearable:``,filterable:``,"allow-create":``,"default-first-option":``,loading:a.statusCodeOptionsLoading,onChange:a.onStatusCodeChange},{default:m(()=>[(c(!0),p(S,null,o(a.statusCodeOptions,t=>(c(),e(w,{key:t,label:String(t),value:String(t)},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`loading`,`onChange`])]),_:1})):i(``,!0),a.type===a.serviceType.API?(c(),e(_,{key:3,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center justify-end`},{default:m(()=>[r(A,{type:`primary`,plain:``,loading:a.exporting,class:`w-full whitespace-nowrap`,onClick:a.onExport},{default:m(()=>[r(k,{icon:`fa-solid fa-file-export`,class:`mr-1`}),n(` `+s(a.$t(`usage.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1})):i(``,!0)]),_:1}),r(v,null,{default:m(()=>[r(_,{span:24},{default:m(()=>[a.type===a.serviceType.API?(c(),e(v,{key:0,gutter:24,class:`mb-5`},{default:m(()=>[r(_,{md:6,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[a.aggLoading?(c(),e(D,{key:0})):(c(),p(`div`,ne,[t(`div`,re,[r(k,{icon:`fa-solid fa-cubes`,class:`icon`})]),t(`div`,ie,[t(`p`,ae,s(a.$t(`usage.title.totalUsed`)),1),t(`p`,oe,s(a.totalUsedString),1)])]))]),_:1})]),_:1}),r(_,{md:18,xs:24},{default:m(()=>[r(j,{shadow:`hover`,class:`h-full`},{default:m(()=>[t(`div`,se,[a.aggLoading?(c(),e(D,{key:0,class:`w-full`})):(c(),e(M,{key:1,data:a.barChartData,options:a.barChartOptions,class:`chart`},null,8,[`data`,`options`]))])]),_:1})]),_:1})]),_:1})):i(``,!0),r(j,{shadow:`hover`},{default:m(()=>[a.type===a.serviceType.API?x((c(),e(I,{key:0,data:a.apiUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.api?.title),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.statusCode`),width:`120px`},{default:m(e=>[t(`span`,null,s(e.row.status_code),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.elapsed`),width:`120px`},{default:m(e=>[t(`span`,null,s(a.formatElapsed(e.row.elapsed)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[a.getDeductedAmount(e.row)===a.getOriginalAmount(e.row)?(c(),p(`div`,ce,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)])):(c(),p(`div`,le,[u[7]||=t(`p`,null,null,-1),t(`p`,null,[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),t(`p`,null,[t(`del`,null,s(a.getOriginalAmount(e.row)),1)])]))]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`260px`,"class-name":`text-center`},{default:m(r=>[t(`div`,ue,[r.row.original_amount>r.row.deducted_amount&&r.row.original_amount>0?(c(),e(P,{key:0,type:`success`,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(((r.row.original_amount-r.row.deducted_amount)*100/r.row.original_amount).toFixed(0)+`% OFF`),1)]),_:2},1024)):i(``,!0),(c(!0),p(S,null,o(a.getSimpleMetadata(r.row.metadata),(t,r)=>(c(),e(P,{key:r,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))])]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.button.viewDetail`),width:`120px`,"class-name":`text-center`},{default:m(t=>[t.row.id?(c(),e(A,{key:0,type:`primary`,plain:``,size:`small`,class:`!px-2 !py-1 !text-xs !h-auto !min-h-0`,onClick:e=>a.onShowDetail(t.row)},{default:m(()=>[n(s(a.$t(`usage.button.viewDetail`)),1)]),_:1},8,[`onClick`])):i(``,!0)]),_:1},8,[`label`]),r(N,{prop:`trace_id`,label:a.$t(`application.field.traceId`),width:`200px`,"class-name":`text-center`},{default:m(e=>[t(`span`,de,s(e.row.trace_id),1),e.row.trace_id?(c(),p(`span`,fe,[r(F,{content:e.row.trace_id,class:`inline-block`},null,8,[`content`])])):i(``,!0)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,pe,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0),a.type===a.serviceType.Proxy?x((c(),e(I,{key:1,data:a.proxyUsages,stripe:``,"table-layout":`fixed`,"empty-text":a.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:m(()=>[r(N,{label:a.$t(`application.field.name`),width:`160px`},{default:m(e=>[t(`span`,null,s(e.row?.service?.title),1)]),_:1},8,[`label`]),r(N,{prop:`remaining_amount`,label:a.$t(`usage.field.remainingAmount`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1),t(`span`,null,s(a.getOriginalAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`deducted_amount`,label:a.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getDeductedAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:m(e=>[t(`span`,null,s(a.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),r(N,{prop:`metadata`,label:a.$t(`usage.field.metadata`),width:`200px`,"class-name":`text-center`},{default:m(t=>[(c(!0),p(S,null,o(t.row.metadata,(t,r)=>(c(),e(P,{key:r,class:`mb-2`},{default:m(()=>[n(s(r)+`: `+s(t),1)]),_:2},1024))),128))]),_:1},8,[`label`]),r(N,{label:a.$t(`usage.field.createdAt`),width:`200px`},{default:m(e=>[t(`span`,me,s(a.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,a.loading]]):i(``,!0)]),_:1})]),_:1})]),_:1}),r(z,{modelValue:a.detailDialogVisible,"onUpdate:modelValue":u[6]||=e=>a.detailDialogVisible=e,title:a.$t(`usage.dialog.detailTitle`),width:`70%`,top:`5vh`,"destroy-on-close":``},{default:m(()=>[r(R,{modelValue:a.detailActiveTab,"onUpdate:modelValue":u[5]||=e=>a.detailActiveTab=e},{default:m(()=>[r(L,{label:a.$t(`usage.dialog.request`),name:`request`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.request?(c(),p(`pre`,he,s(a.formatJson(a.detailRow.metadata.request)),1)):(c(),p(`p`,ge,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`]),r(L,{label:a.$t(`usage.dialog.response`),name:`response`},{default:m(()=>[a.detailLoading?(c(),e(D,{key:0,rows:6,animated:``})):a.detailRow?.metadata?.response?(c(),p(`pre`,_e,s(a.formatJson(a.detailRow.metadata.response)),1)):(c(),p(`p`,ve,s(a.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`]),r(v,null,{default:m(()=>[r(_,{span:10,offset:14},{default:m(()=>[t(`div`,ye,[r(B,{"current-page":a.page,"page-size":a.limit,total:a.total,onChange:a.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var xe=B(Z,[[`render`,be],[`__scopeId`,`data-v-38f1845c`]]);export{xe as default};
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{$ as e,A as t,D as n,F as r,N as i,O as a,P as o,S as s,Wt as c,Z as l,a as u,c as d,dt as f,i as ee,k as p,n as m,nt as h,o as g,r as _,s as v,t as y,tt as b,ut as x,v as S}from"./vendor-chart-BJCvKk8-.js";import{t as C}from"./button-DfsQodL-.js";import{r as w,t as T}from"./select-B1uV_nnl.js";import{n as E,t as D}from"./table-lRQt4LGt.js";import{n as O,t as k}from"./tabs-D9l1-5D5.js";import{t as A}from"./date-picker-CpTCVLld.js";import{t as j}from"./card-DjyfNde2.js";import{n as M,r as N}from"./radio-BmBXySlN.js";import{n as P,t as F}from"./row-d76bUVm3.js";import{t as I}from"./Pagination-DeCHT-PM.js";import{n as L,t as R}from"./skeleton-C4sltx62.js";import{An as z,E as B,En as V,Mr as H,Pr as U,Tn as W,_r as G,lr as K,ur as q,wn as J}from"./index-CxBOJBZd.js";import{t as Y}from"./index.es-Dw2lhymn.js";import{t as X}from"./CopyToClipboard-D1o-dyv3.js";ee.register(_,u,m,v,d,g);var Z=r({name:`ConsoleUsageList`,components:{Pagination:I,ElTag:U,ElDatePicker:A,ElTable:D,ElSelect:w,ElOption:T,CopyToClipboard:X,ElRow:F,ElCol:P,ElTableColumn:E,ElCard:j,ElRadioButton:M,ElRadioGroup:N,ElSkeleton:R,ElSkeletonItem:L,ElDialog:H,ElTabs:O,ElTabPane:k,ElButton:C,FontAwesomeIcon:Y,BarChart:y},data(){return{applicationIds:this.$route.query.application_id?.toString()?this.$route.query.application_id?.toString().split(`,`):[],apiIds:this.$route.query.api_id?.toString()?this.$route.query.api_id?.toString().split(`,`):[],applications:[],apis:[],apisLoading:!1,credentialType:K,serviceType:q,apiUsages:[],proxyUsages:[],createdAtRange:(()=>{let e=this.$route.query.created_at_to?.toString(),t=this.$route.query.created_at_from?.toString();if(t&&e)return[new Date(t),new Date(e)];let n=new Date,r=new Date;return r.setDate(1),r.setHours(0,0,0,0),[r,n]})(),shortcuts:[{text:this.$t(`usage.shortcuts.thisMonth`),value:()=>{let e=new Date,t=new Date;return t.setDate(1),t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.today`),value:()=>{let e=new Date,t=new Date;return t.setHours(0,0,0,0),[t,e]}},{text:this.$t(`usage.shortcuts.last1Day`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-1),[t,e]}},{text:this.$t(`usage.shortcuts.last3Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-3),[t,e]}},{text:this.$t(`usage.shortcuts.last7Days`),value:()=>{let e=new Date,t=new Date;return t.setDate(t.getDate()-7),[t,e]}},{text:this.$t(`usage.shortcuts.last1Month`),value:()=>{let e=new Date,t=new Date;return t.setMonth(t.getMonth()-1),[t,e]}}],type:this.$route.query.type?.toString()||q.API,loading:!1,total:void 0,limit:15,totalUsed:0,barChartLabels:[],barChartSeries:[],aggLoading:!1,detailDialogVisible:!1,detailRow:null,detailActiveTab:`request`,detailLoading:!1,exporting:!1,statusCodeFilter:this.$route.query.status_code?.toString()||``,statusCodeOptions:[],statusCodeOptionsLoading:!1}},computed:{redirect(){return this.$route.query?.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},totalUsedString(){return`${(this.totalUsed||0).toFixed(2)}`},barChartData(){return{labels:this.barChartLabels,datasets:this.barChartSeries.map(e=>({label:e.label,data:e.data,backgroundColor:e.color}))}},barChartOptions(){return{responsive:!0,plugins:{legend:{position:`top`,onClick:(e,t,n)=>{let r=n?.chart;if(!r||t?.datasetIndex===void 0)return;let i=t.datasetIndex,a=r.data?.datasets||[];a.some((e,t)=>t!==i&&r.isDatasetVisible(t))?a.forEach((e,t)=>r.setDatasetVisibility(t,t===i)):a.forEach((e,t)=>r.setDatasetVisibility(t,!0)),r.update()}},title:{display:!0,text:this.$t(`usage.title.usageTrend`)}},scales:{x:{stacked:!0},y:{stacked:!0,beginAtZero:!0}}}}},watch:{page:{handler(){this.onFetchUsages()}},type:{handler(){this.applicationIds=[],this.apiIds=[],this.onApplicationsChange(this.applicationIds),this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()}}},mounted(){this.onFetchApplications(),this.onFetchApis(),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},methods:{async onFetchUsages(){this.type===q.API?this.onFetchApiUsages():this.type===q.Proxy&&this.onFetchProxyUsages()},async onApiChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onApisChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,api_id:e&&e.length?e.join(`,`):``}}),this.onFetchApiUsages(),this.onFetchAggregate()},async onTimeRangeChanged(){console.log(`onTimeRangeChanged`,this.createdAtRange),await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,created_at_from:this.createdAtRange?this.$dayjs.format(this.createdAtRange[0].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``,created_at_to:this.createdAtRange?this.$dayjs.format(this.createdAtRange[1].toString(),`YYYY-MM-DDTHH:mm:ss.SSSSSSZ`):``}}),this.onFetchUsages(),this.onFetchAggregate(),this.onFetchStatusCodeOptions()},async onApplicationChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e}}),this.onFetchUsages(),this.onFetchAggregate()},async onApplicationsChange(e){await this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,application_id:e&&e.length?e.join(`,`):``}}),this.onFetchUsages(),this.onFetchAggregate()},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},getRemainingAmount(e){if(e.remaining_amount===void 0||e.remaining_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.remaining_amount?.toFixed(6)} ${t}`},getUsedAmount(e){if(e.used_amount===void 0||e.used_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.used_amount?.toFixed(6)} ${t}`},getDeductedAmount(e){if(e?.deducted_amount===void 0||e?.deducted_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.deducted_amount?.toFixed(6)} ${t}`},getOriginalAmount(e){if(e?.original_amount===void 0||e?.original_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.original_amount?.toFixed(6)} ${t}`},onStatusCodeChange(e){let t={...this.$route.query},n=(e||``).trim();n?t.status_code=n:delete t.status_code,delete t.status_code_filter,this.$router.push({name:this.$route.name?.toString(),query:t}),this.onFetchUsages(),this.onFetchAggregate()},async onFetchStatusCodeOptions(){this.statusCodeOptionsLoading=!0;try{let{data:e}=await W.getStatusCodes({user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}});this.statusCodeOptions=(e?.items||[]).slice().sort((e,t)=>e-t)}catch{this.statusCodeOptions=[]}finally{this.statusCodeOptionsLoading=!1}},formatElapsed(e){return e==null||Number.isNaN(e)?`-`:e<1?`${Math.round(e*1e3)} ms`:`${e.toFixed(2)} s`},getSimpleMetadata(e){if(!e)return{};let t={};for(let[n,r]of Object.entries(e))n===`request`||n===`response`||typeof r==`object`&&r||(t[n]=r);return t},onShowDetail(e){this.detailRow={...e,metadata:void 0},this.detailActiveTab=`request`,this.detailDialogVisible=!0,this.detailLoading=!0,e.id&&W.get(e.id).then(e=>{this.detailRow=e.data}).finally(()=>{this.detailLoading=!1})},formatJson(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}},onFetchApplications(){z.getAll({limit:100,offset:0,user_id:this.$store.getters.user.id,ordering:`-created_at`,type:G.USAGE}).then(({data:e})=>{this.applications=e.items.filter(e=>e?.service?.type===this.type)}).catch(()=>{})},onFetchApis(){this.apisLoading=!0,J.getAll({limit:100,offset:0,ordering:`-created_at`}).then(({data:e})=>{this.apis=e.items}).catch(()=>{}).finally(()=>{this.apisLoading=!1})},onFetchApiUsages(){console.log(`onFetchApiUsages`,this.createdAtRange),this.loading=!0,W.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{this.apiUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onFetchProxyUsages(){this.loading=!0,V.getAll({limit:this.limit,offset:(this.page-1)*this.limit,user_id:this.$store.getters.user.id,ordering:`-created_at`,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{}}).then(({data:e})=>{this.proxyUsages=e.items,this.loading=!1,this.total=e.count}).catch(()=>{this.loading=!1})},onExport(){this.exporting=!0,W.exportCsv({user_id:this.$store.getters.user.id,...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{},...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.statusCodeFilter?{status_code:this.statusCodeFilter}:{}}).then(({data:e})=>{let t=window.URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`usages.csv`,n.click(),window.URL.revokeObjectURL(t)}).catch(()=>{}).finally(()=>{this.exporting=!1})},async onFetchAggregate(){if(this.aggLoading=!0,this.type!==this.serviceType.API)return;let e={user_id:this.$store.getters.user.id,...this.applicationIds&&this.applicationIds.length?{application_id:this.applicationIds}:{},...this.apiIds&&this.apiIds.length?{api_id:this.apiIds}:{},...this.createdAtRange?.[0]?{created_at_from:this.createdAtRange[0]}:{},...this.createdAtRange?.[1]?{created_at_to:this.createdAtRange[1]}:{}};try{let{data:t}=await W.getAggregate(e);this.totalUsed=t.total||0;let n=Array.from(new Set((t.items||[]).map(e=>e.date))).sort(),r=Array.from(new Set((t.items||[]).map(e=>e.api_id))),i=e=>`hsl(${e*57%360}, 70%, 60%)`,a=r.map((e,r)=>{let a=t.apis?.[e]?.title||e,o={};return(t.items||[]).filter(t=>t.api_id===e).forEach(e=>{o[e.date]=e.amount||0}),{key:e,label:a,data:n.map(e=>o[e]||0),color:i(r)}});this.barChartLabels=n,this.barChartSeries=a}finally{this.aggLoading=!1}}}}),Q={class:`text-[26px] font-bold mb-5 text-[var(--el-text-color-primary)]`},$={class:`inline-block w-9`},te={class:`inline-block`},ne={key:1,class:`summary-card`},re={class:`icon-wrapper`},ie={class:`text-left`},ae={class:`description`},oe={class:`value`},se={class:`chart-wrapper`},ce={key:0},le={key:1},ue={class:`flex flex-wrap gap-2`},de={class:`key`},fe={key:0,class:`cursor-pointer`},pe={class:`created-at`},me={class:`created-at`},he={key:1,class:`detail-json`},ge={key:2,class:`text-gray-400`},_e={key:1,class:`detail-json`},ve={key:2,class:`text-gray-400`},ye={class:`float-right`};function be(r,u,d,ee,m,g){let _=b(`el-col`),v=b(`el-row`),y=b(`el-radio-button`),C=b(`el-radio-group`),w=b(`el-option`),T=b(`el-select`),E=b(`el-skeleton-item`),D=b(`el-skeleton`),O=b(`el-date-picker`),k=b(`font-awesome-icon`),A=b(`el-button`),j=b(`el-card`),M=b(`bar-chart`),N=b(`el-table-column`),P=b(`el-tag`),F=b(`copy-to-clipboard`),I=b(`el-table`),L=b(`el-tab-pane`),R=b(`el-tabs`),z=b(`el-dialog`),B=b(`pagination`),V=h(`loading`);return l(),a(v,null,{default:x(()=>[o(_,{span:24},{default:x(()=>[o(v,null,{default:x(()=>[o(_,{span:24},{default:x(()=>[n(`h2`,Q,c(r.$t(`common.title.allUsages`)),1)]),_:1})]),_:1}),o(v,null,{default:x(()=>[o(_,{md:4,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:x(()=>[n(`span`,null,c(r.$t(`application.field.type`)),1),o(C,{modelValue:r.type,"onUpdate:modelValue":u[0]||=e=>r.type=e},{default:x(()=>[o(y,{value:r.serviceType.API,label:r.$t(`application.field.api`)},null,8,[`value`,`label`]),o(y,{value:r.serviceType.Proxy,label:r.$t(`application.field.proxy`)},null,8,[`value`,`label`])]),_:1},8,[`modelValue`])]),_:1}),f(o(_,{md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:x(()=>[n(`span`,$,c(r.$t(`usage.field.application`)),1),o(T,{modelValue:r.applicationIds,"onUpdate:modelValue":u[1]||=e=>r.applicationIds=e,placeholder:r.$t(`usage.field.application`),clearable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:r.onApplicationsChange},{default:x(()=>[(l(!0),t(s,null,e(r.applications,e=>(l(),a(w,{key:e.id,label:e.service?.title,value:e?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`])]),_:1},512),[[S,!1]]),r.type===r.serviceType.API?(l(),a(_,{key:0,md:6,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:x(()=>[n(`span`,te,c(r.$t(`usage.field.api`)),1),r.apisLoading?(l(),a(D,{key:0,animated:``,class:`w-full`},{template:x(()=>[o(E,{variant:`rect`,style:{height:`32px`,"border-radius":`4px`}})]),_:1})):(l(),a(T,{key:1,modelValue:r.apiIds,"onUpdate:modelValue":u[2]||=e=>r.apiIds=e,placeholder:r.$t(`usage.field.api`),clearable:``,filterable:``,multiple:``,"collapse-tags":``,"collapse-tags-tooltip":``,class:`w-full`,onChange:r.onApisChange},{default:x(()=>[(l(!0),t(s,null,e(r.apis,e=>(l(),a(w,{key:e?.id,label:e?.title,value:e?.id},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`onChange`]))]),_:1})):p(``,!0),r.type===r.serviceType.API?(l(),a(_,{key:1,md:8,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:x(()=>[o(O,{modelValue:r.createdAtRange,"onUpdate:modelValue":u[3]||=e=>r.createdAtRange=e,type:`datetimerange`,class:`w-full`,shortcuts:r.shortcuts,"range-separator":r.$t(`usage.placeholder.to`),"start-placeholder":r.$t(`usage.placeholder.startDate`),"end-placeholder":r.$t(`usage.placeholder.endDate`),onChange:r.onTimeRangeChanged},null,8,[`modelValue`,`shortcuts`,`range-separator`,`start-placeholder`,`end-placeholder`,`onChange`])]),_:1})):p(``,!0),r.type===r.serviceType.API?(l(),a(_,{key:2,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center`},{default:x(()=>[o(T,{modelValue:r.statusCodeFilter,"onUpdate:modelValue":u[4]||=e=>r.statusCodeFilter=e,placeholder:r.$t(`usage.option.statusCodeAll`),class:`w-full`,clearable:``,filterable:``,"allow-create":``,"default-first-option":``,loading:r.statusCodeOptionsLoading,onChange:r.onStatusCodeChange},{default:x(()=>[(l(!0),t(s,null,e(r.statusCodeOptions,e=>(l(),a(w,{key:e,label:String(e),value:String(e)},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`,`loading`,`onChange`])]),_:1})):p(``,!0),r.type===r.serviceType.API?(l(),a(_,{key:3,md:3,xs:24,class:`mb-5 flex px-2 gap-2 items-center justify-end`},{default:x(()=>[o(A,{type:`primary`,plain:``,loading:r.exporting,class:`w-full whitespace-nowrap`,onClick:r.onExport},{default:x(()=>[o(k,{icon:`fa-solid fa-file-export`,class:`mr-1`}),i(` `+c(r.$t(`usage.button.export`)),1)]),_:1},8,[`loading`,`onClick`])]),_:1})):p(``,!0)]),_:1}),o(v,null,{default:x(()=>[o(_,{span:24},{default:x(()=>[r.type===r.serviceType.API?(l(),a(v,{key:0,gutter:24,class:`mb-5`},{default:x(()=>[o(_,{md:6,xs:24},{default:x(()=>[o(j,{shadow:`hover`,class:`h-full`},{default:x(()=>[r.aggLoading?(l(),a(D,{key:0})):(l(),t(`div`,ne,[n(`div`,re,[o(k,{icon:`fa-solid fa-cubes`,class:`icon`})]),n(`div`,ie,[n(`p`,ae,c(r.$t(`usage.title.totalUsed`)),1),n(`p`,oe,c(r.totalUsedString),1)])]))]),_:1})]),_:1}),o(_,{md:18,xs:24},{default:x(()=>[o(j,{shadow:`hover`,class:`h-full`},{default:x(()=>[n(`div`,se,[r.aggLoading?(l(),a(D,{key:0,class:`w-full`})):(l(),a(M,{key:1,data:r.barChartData,options:r.barChartOptions,class:`chart`},null,8,[`data`,`options`]))])]),_:1})]),_:1})]),_:1})):p(``,!0),o(j,{shadow:`hover`},{default:x(()=>[r.type===r.serviceType.API?f((l(),a(I,{key:0,data:r.apiUsages,stripe:``,"table-layout":`fixed`,"empty-text":r.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:x(()=>[o(N,{label:r.$t(`application.field.name`),width:`160px`},{default:x(e=>[n(`span`,null,c(e.row?.api?.title),1)]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.field.statusCode`),width:`120px`},{default:x(e=>[n(`span`,null,c(e.row.status_code),1)]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.field.elapsed`),width:`120px`},{default:x(e=>[n(`span`,null,c(r.formatElapsed(e.row.elapsed)),1)]),_:1},8,[`label`]),o(N,{prop:`deducted_amount`,label:r.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:x(e=>[r.getDeductedAmount(e.row)===r.getOriginalAmount(e.row)?(l(),t(`div`,ce,[n(`span`,null,c(r.getDeductedAmount(e.row)),1)])):(l(),t(`div`,le,[u[7]||=n(`p`,null,null,-1),n(`p`,null,[n(`span`,null,c(r.getDeductedAmount(e.row)),1)]),n(`p`,null,[n(`del`,null,c(r.getOriginalAmount(e.row)),1)])]))]),_:1},8,[`label`]),o(N,{prop:`remaining_amount`,label:r.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:x(e=>[n(`span`,null,c(r.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),o(N,{prop:`metadata`,label:r.$t(`usage.field.metadata`),width:`260px`,"class-name":`text-center`},{default:x(o=>[n(`div`,ue,[o.row.original_amount>o.row.deducted_amount&&o.row.original_amount>0?(l(),a(P,{key:0,type:`success`,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:x(()=>[i(c(((o.row.original_amount-o.row.deducted_amount)*100/o.row.original_amount).toFixed(0)+`% OFF`),1)]),_:2},1024)):p(``,!0),(l(!0),t(s,null,e(r.getSimpleMetadata(o.row.metadata),(e,t)=>(l(),a(P,{key:t,style:{textWrap:`wrap`,height:`fit-content`,lineHeight:`20px`,borderRadius:`10px`}},{default:x(()=>[i(c(t)+`: `+c(e),1)]),_:2},1024))),128))])]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.button.viewDetail`),width:`120px`,"class-name":`text-center`},{default:x(e=>[e.row.id?(l(),a(A,{key:0,type:`primary`,plain:``,size:`small`,class:`!px-2 !py-1 !text-xs !h-auto !min-h-0`,onClick:t=>r.onShowDetail(e.row)},{default:x(()=>[i(c(r.$t(`usage.button.viewDetail`)),1)]),_:1},8,[`onClick`])):p(``,!0)]),_:1},8,[`label`]),o(N,{prop:`trace_id`,label:r.$t(`application.field.traceId`),width:`200px`,"class-name":`text-center`},{default:x(e=>[n(`span`,de,c(e.row.trace_id),1),e.row.trace_id?(l(),t(`span`,fe,[o(F,{content:e.row.trace_id,class:`inline-block`},null,8,[`content`])])):p(``,!0)]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.field.createdAt`),width:`200px`},{default:x(e=>[n(`span`,pe,c(r.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,r.loading]]):p(``,!0),r.type===r.serviceType.Proxy?f((l(),a(I,{key:1,data:r.proxyUsages,stripe:``,"table-layout":`fixed`,"empty-text":r.$t(`common.message.noData`),class:`min-h-[calc(100vh-350px)] mb-5`},{default:x(()=>[o(N,{label:r.$t(`application.field.name`),width:`160px`},{default:x(e=>[n(`span`,null,c(e.row?.service?.title),1)]),_:1},8,[`label`]),o(N,{prop:`remaining_amount`,label:r.$t(`usage.field.remainingAmount`),width:`160px`,"class-name":`text-center`},{default:x(e=>[n(`span`,null,c(r.getRemainingAmount(e.row)),1),n(`span`,null,c(r.getOriginalAmount(e.row)),1)]),_:1},8,[`label`]),o(N,{prop:`deducted_amount`,label:r.$t(`usage.field.deductedAmount`),width:`150px`,"class-name":`text-center`},{default:x(e=>[n(`span`,null,c(r.getDeductedAmount(e.row)),1)]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.field.balanceAfter`),width:`160px`,"class-name":`text-center`},{default:x(e=>[n(`span`,null,c(r.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),o(N,{prop:`metadata`,label:r.$t(`usage.field.metadata`),width:`200px`,"class-name":`text-center`},{default:x(n=>[(l(!0),t(s,null,e(n.row.metadata,(e,t)=>(l(),a(P,{key:t,class:`mb-2`},{default:x(()=>[i(c(t)+`: `+c(e),1)]),_:2},1024))),128))]),_:1},8,[`label`]),o(N,{label:r.$t(`usage.field.createdAt`),width:`200px`},{default:x(e=>[n(`span`,me,c(r.$dayjs.format(e.row.created_at)),1)]),_:1},8,[`label`])]),_:1},8,[`data`,`empty-text`])),[[V,r.loading]]):p(``,!0)]),_:1})]),_:1})]),_:1}),o(z,{modelValue:r.detailDialogVisible,"onUpdate:modelValue":u[6]||=e=>r.detailDialogVisible=e,title:r.$t(`usage.dialog.detailTitle`),width:`70%`,top:`5vh`,"destroy-on-close":``},{default:x(()=>[o(R,{modelValue:r.detailActiveTab,"onUpdate:modelValue":u[5]||=e=>r.detailActiveTab=e},{default:x(()=>[o(L,{label:r.$t(`usage.dialog.request`),name:`request`},{default:x(()=>[r.detailLoading?(l(),a(D,{key:0,rows:6,animated:``})):r.detailRow?.metadata?.request?(l(),t(`pre`,he,c(r.formatJson(r.detailRow.metadata.request)),1)):(l(),t(`p`,ge,c(r.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`]),o(L,{label:r.$t(`usage.dialog.response`),name:`response`},{default:x(()=>[r.detailLoading?(l(),a(D,{key:0,rows:6,animated:``})):r.detailRow?.metadata?.response?(l(),t(`pre`,_e,c(r.formatJson(r.detailRow.metadata.response)),1)):(l(),t(`p`,ve,c(r.$t(`usage.dialog.noData`)),1))]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),_:1},8,[`modelValue`,`title`]),o(v,null,{default:x(()=>[o(_,{span:10,offset:14},{default:x(()=>[n(`div`,ye,[o(B,{"current-page":r.page,"page-size":r.limit,total:r.total,onChange:r.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var xe=B(Z,[[`render`,be],[`__scopeId`,`data-v-38f1845c`]]);export{xe as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./rolldown-runtime--c01j_DQ.js";import{A as e,D as t,F as n,N as r,O as i,P as a,Wt as o,Z as s,dt as c,k as l,nt as u,tt as d,ut as f}from"./vendor-chart-BJCvKk8-.js";import{t as p}from"./button-DfsQodL-.js";import{n as m,t as h}from"./table-lRQt4LGt.js";import{t as g}from"./card-DjyfNde2.js";import{n as _,t as v}from"./row-d76bUVm3.js";import{t as y}from"./Pagination-DeCHT-PM.js";import{t as b}from"./skeleton-C4sltx62.js";import{t as x}from"./switch-BXfqi_p8.js";import{An as S,B as C,E as w,P as T,Pr as E,Tr as D,_r as O,gr as k,kr as A,lr as j,ur as M}from"./index-CxBOJBZd.js";import{t as N}from"./index.es-Dw2lhymn.js";import{t as P}from"./CopyToClipboard-D1o-dyv3.js";var F=n({name:`ConsoleApplicationList`,components:{Pagination:y,CopyToClipboard:P,ElTable:h,ElRow:v,ElButton:p,ElCol:_,ElTag:E,ElSkeleton:b,ElSwitch:x,ElTableColumn:m,ElCard:g,FontAwesomeIcon:N},data(){return{credentialType:j,serviceType:M,individualApplications:[],globalApplications:[],individualApplicationsTotal:void 0,globalApplicationsTotal:void 0,loading:!1,buying:!1,limit:10,form:{amount:1},active:{service:void 0,application:void 0}}},computed:{redirect(){return this.$route.query?.redirect},page(){return parseInt(this.$route.query.page?.toString()||`1`)},showPayment(){return!D()}},watch:{page:{handler(){this.onFetchData()}}},mounted(){this.onInitializeGlobalApplication(),this.onFetchData()},methods:{updateAllowConsumeGlobal(e,t){!e||!e.id||S.updateAllConsumeGlobal(e.id,{...e,allow_consume_global:!!t}).then(()=>{A.success(this.$t(`application.message.updateSuccessfully`).toString())}).catch(()=>{A.error(this.$t(`application.message.updateFailed`).toString())})},onGoUsage(e){this.$router.push({name:C,query:{application_id:e.id,type:e?.service?.type}})},onBuyMore(e){e?.id&&this.$router.push({name:T,params:{id:e.id}})},onPageChange(e){this.$router.push({name:this.$route.name?.toString(),query:{...this.$route.query,page:e}})},onFetchApplications(e=k.INDIVIDUAL){return new Promise((t,n)=>{S.getAll({limit:this.limit,...e===k.INDIVIDUAL?{offset:(this.page-1)*this.limit}:{},user_id:this.$store.getters.user.id,ordering:`-created_at`,type:O.USAGE,scope:e}).then(({data:n})=>{e===k.INDIVIDUAL?(this.individualApplications=n.items,this.individualApplicationsTotal=n.count):(this.globalApplications=n.items,this.globalApplicationsTotal=n.count),t(n)}).catch(e=>{A.error(this.$t(`application.message.fetchFailed`).toString()),n(e)})})},onFetchData(){this.loading=!0,Promise.all([this.onFetchApplications(k.INDIVIDUAL),this.onFetchApplications(k.GLOBAL)]).then(()=>{this.loading=!1}).catch(()=>{this.loading=!1})},onInitializeGlobalApplication(){S.create({type:O.USAGE,scope:k.GLOBAL,user_id:this.$store.getters.user.id}).finally(()=>{this.onFetchApplications(k.GLOBAL)})},getRemainingAmount(e){if(e.remaining_amount===void 0||e.remaining_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.remaining_amount?.toFixed(6)} ${t}`},getUsedAmount(e){if(e.used_amount===void 0||e.used_amount===null)return``;let t=this.$t(`service.unit.${e?.service?.unit||`credit`}s`);return`${e.used_amount?.toFixed(6)} ${t}`}}}),I={class:`title`},L={key:1,class:`summary-card`},R={class:`icon-wrapper`},z={class:`label`},B={class:`value`},V={class:`description`},H={key:1,class:`flex flex-row justify-between align-center`},U={class:`summary-card`},W={class:`flex justify-start items-center gap-2 mb-2 w-full`},G={class:`icon-wrapper !mb-0`},K={class:`text-[var(--el-text-color-regular)] text-[14px] truncate`},q={class:`label`},J={class:`value`},Y={class:`description`},X={class:`flex flex-col items-end gap-2`},Z={class:`copy`},Q={key:0,class:`expired-at`},$={class:`flex flex-wrap items-center justify-end gap-1`},ee={class:`pagination`};function te(n,p,m,h,g,_){let v=d(`el-col`),y=d(`el-row`),b=d(`el-skeleton`),x=d(`font-awesome-icon`),S=d(`el-card`),C=d(`copy-to-clipboard`),w=d(`el-button`),T=d(`el-table-column`),E=d(`el-tag`),D=d(`el-switch`),O=d(`el-table`),k=d(`pagination`),A=u(`loading`);return s(),i(y,{class:`application-list`},{default:f(()=>[a(v,{span:24},{default:f(()=>[a(y,null,{default:f(()=>[a(v,{span:24},{default:f(()=>[t(`h2`,I,o(n.$t(`common.title.allApplications`)),1)]),_:1})]),_:1}),a(y,{gutter:15,class:`mb-3`},{default:f(()=>[a(v,{md:12,xs:24},{default:f(()=>[a(S,{shadow:`hover`,class:`relative min-h-[180px] mb-2`,"body-style":{padding:`18px 20px`}},{default:f(()=>[n.loading?(s(),i(b,{key:0})):(s(),e(`div`,L,[t(`div`,R,[a(x,{icon:`fa-solid fa-cubes-stacked`})]),t(`p`,z,o(n.$t(`application.title.count`)),1),t(`p`,B,o(n.individualApplicationsTotal),1),t(`p`,V,o(n.$t(`application.message.countDescription`)),1)]))]),_:1})]),_:1}),n.showPayment&&n.globalApplications?.length>0?(s(),i(v,{key:0,md:12,xs:24},{default:f(()=>[a(S,{shadow:`hover`,class:`relative min-h-[180px] mb-2`,"body-style":{padding:`18px 20px`}},{default:f(()=>[n.loading?(s(),i(b,{key:0})):(s(),e(`div`,H,[t(`div`,U,[t(`div`,W,[t(`div`,G,[a(x,{icon:`fa-solid fa-wallet`})]),t(`span`,K,[r(o(n.$t(`application.field.id`))+`: `+o(n.globalApplications?.[0]?.id)+` `,1),n.globalApplications?.[0]?.id?(s(),i(C,{key:0,content:n.globalApplications?.[0]?.id,class:`inline-block`},null,8,[`content`])):l(``,!0)])]),t(`p`,q,o(n.$t(`application.title.globalBalance`)),1),t(`p`,J,o(n.globalApplications?.[0]?.remaining_amount?.toFixed(6)||`0.000000`)+` `+o(n.$t(`service.unit.credits`)),1),t(`p`,Y,o(n.$t(`application.message.globalBalanceDescription`)),1)]),t(`div`,X,[a(w,{class:`!m-0 !px-2`,size:`small`,round:``,onClick:p[0]||=e=>n.onGoUsage(n.globalApplications?.[0])},{default:f(()=>[a(x,{icon:`fa-solid fa-chart-line`,class:`mr-1 text-[12px]`}),r(` `+o(n.$t(`application.button.usage`)),1)]),_:1}),n.showPayment?(s(),i(w,{key:0,class:`!m-0 !px-2`,type:`primary`,round:``,size:`small`,onClick:p[1]||=e=>n.onBuyMore(n.globalApplications?.[0])},{default:f(()=>[a(x,{icon:`fa-solid fa-coins`,class:`mr-1 text-[12px]`}),r(` `+o(n.$t(`application.button.buyMore`)),1)]),_:1})):l(``,!0)])]))]),_:1})]),_:1})):l(``,!0)]),_:1}),a(y,null,{default:f(()=>[a(v,{span:24},{default:f(()=>[a(S,{shadow:`hover`,class:`applications-table-card`},{default:f(()=>[c((s(),i(O,{data:n.individualApplications,stripe:``,class:`applications-table !min-h-[calc(100vh-420px)]`,"table-layout":`fixed`,"empty-text":n.$t(`common.message.noData`)},{default:f(()=>[a(T,{prop:`id`,label:n.$t(`application.field.id`),width:`200px`,"class-name":`text-center`},{default:f(e=>[t(`span`,null,o(e.row.id),1),t(`span`,Z,[a(C,{content:e?.row?.id,class:`inline-block`},null,8,[`content`])])]),_:1},8,[`label`]),a(T,{label:n.$t(`application.field.type`),width:`90px`,"class-name":`hidden sm:table-cell`,"label-class-name":`hidden sm:table-cell`},{default:f(e=>[e.row?.type===`Period`?(s(),i(E,{key:0,type:`success`,effect:`dark`,round:``},{default:f(()=>[r(o(n.$t(`application.type.period`)),1)]),_:1})):e.row?.type===`Usage`?(s(),i(E,{key:1,effect:`dark`,round:``},{default:f(()=>[r(o(n.$t(`application.type.usage`)),1)]),_:1})):l(``,!0)]),_:1},8,[`label`]),a(T,{label:n.$t(`application.field.name`),width:`180px`},{default:f(e=>[t(`span`,null,o(e.row?.service?.title),1),e.row?.role===`grantee`?(s(),i(E,{key:0,type:`info`,size:`small`,round:``,class:`ml-2`},{default:f(()=>[r(o(n.$t(`application.badge.shared`)),1)]),_:1})):l(``,!0)]),_:1},8,[`label`]),a(T,{prop:`remaining_amount`,label:n.$t(`application.field.remainingAmount`),width:`150px`,"class-name":`text-center`},{default:f(e=>[t(`span`,null,o(n.getRemainingAmount(e.row)),1)]),_:1},8,[`label`]),a(T,{prop:`used_amount`,label:n.$t(`application.field.usedAmount`),width:`150px`,"class-name":`hidden sm:table-cell text-center`,"label-class-name":`hidden sm:table-cell`},{default:f(e=>[t(`span`,null,o(n.getUsedAmount(e.row)),1)]),_:1},8,[`label`]),a(T,{prop:`allow_consume_global`,label:n.$t(`application.field.allowConsumeGlobal`),width:`120px`,"class-name":`hidden sm:table-cell text-center`,"label-class-name":`hidden sm:table-cell`},{default:f(e=>[e.row.service?.type===n.serviceType.API?(s(),i(D,{key:0,modelValue:e.row.allow_consume_global,"onUpdate:modelValue":t=>e.row.allow_consume_global=t,"active-value":!0,"inactive-value":!1,onChange:t=>n.updateAllowConsumeGlobal(e.row,t)},null,8,[`modelValue`,`onUpdate:modelValue`,`onChange`])):l(``,!0)]),_:1},8,[`label`]),a(T,{label:n.$t(`application.field.expiredAt`),width:`180px`,"class-name":`hidden sm:table-cell`,"label-class-name":`hidden sm:table-cell`},{default:f(t=>[t.row.expired_at?(s(),e(`span`,Q,o(n.$dayjs.format(t.row.expired_at)),1)):l(``,!0)]),_:1},8,[`label`]),a(T,{fixed:`right`,width:`200px`},{default:f(e=>[t(`div`,$,[a(w,{class:`!m-0 !px-2`,size:`small`,round:``,onClick:t=>n.onGoUsage(e?.row)},{default:f(()=>[a(x,{icon:`fa-solid fa-chart-line`,class:`mr-1 text-[12px]`}),r(` `+o(n.$t(`application.button.usage`)),1)]),_:1},8,[`onClick`]),n.showPayment?(s(),i(w,{key:0,class:`!m-0 !px-2`,type:`primary`,round:``,size:`small`,onClick:t=>n.onBuyMore(e?.row)},{default:f(()=>[a(x,{icon:`fa-solid fa-coins`,class:`mr-1 text-[12px]`}),r(` `+o(n.$t(`application.button.buyMore`)),1)]),_:1},8,[`onClick`])):l(``,!0)])]),_:1})]),_:1},8,[`data`,`empty-text`])),[[A,n.loading]])]),_:1})]),_:1})]),_:1}),a(y,null,{default:f(()=>[a(v,{span:24},{default:f(()=>[t(`div`,ee,[a(k,{"current-page":n.page,"page-size":n.limit,total:n.individualApplicationsTotal,onChange:n.onPageChange},null,8,[`current-page`,`page-size`,`total`,`onChange`])])]),_:1})]),_:1})]),_:1})]),_:1})}var ne=w(F,[[`render`,te],[`__scopeId`,`data-v-7182b838`]]);export{ne as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{F as e}from"./vendor-chart-BJCvKk8-.js";var t=e({name:`AuthLogin`,data(){return{redirect:this.$route.query.redirect?.toString()}},async mounted(){this.$store.state.token.access?this.$router.push(this.redirect||`/`):this.$store.dispatch(`login`)}});export{t as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.wrapper[data-v-41b86eb8]{flex-direction:row-reverse;width:100%;height:100%;display:flex;overflow:hidden}.wrapper .navigator[data-v-41b86eb8]{width:60px;height:100%}.wrapper .main[data-v-41b86eb8]{background-color:var(--app-content-bg);flex:1;min-width:0;height:100%}.status-floating[data-v-41b86eb8]{top:calc(.5rem + var(--app-safe-area-top))}@media (width<=767px){.wrapper[data-v-41b86eb8]{width:100%;height:100%;padding-top:var(--app-safe-area-top);flex-direction:column;display:flex}.wrapper .main[data-v-41b86eb8]{height:calc(100% - 60px - var(--app-safe-area-bottom) - var(--app-safe-area-top));flex:1;width:100%}.wrapper .navigator[data-v-41b86eb8]{width:100%;height:calc(60px + var(--app-safe-area-bottom));padding-bottom:var(--app-safe-area-bottom)}}
|