@acedatacloud/nexior 3.276.14 → 3.277.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.
Files changed (126) hide show
  1. package/dist/assets/{ApiCodeButton-Bbnpv2we.js → ApiCodeButton-8YzSdLWx.js} +1 -1
  2. package/dist/assets/{AskUserQuestionCard-BVxoetPM.js → AskUserQuestionCard-nsK22sY7.js} +1 -1
  3. package/dist/assets/{Auth-CNen58mm.js → Auth-DRhrQZY6.js} +1 -1
  4. package/dist/assets/{Bare-CGAgBPOB.js → Bare-Do_HisxP.js} +1 -1
  5. package/dist/assets/{BotPlaceholder-DwmD_q7g.js → BotPlaceholder-CGjSVeUk.js} +1 -1
  6. package/dist/assets/{BottomFooter-CEzUsQct.js → BottomFooter-DMl3rPpW.js} +1 -1
  7. package/dist/assets/{Callback-iH6gl5RZ.js → Callback-Bz6GSuWa.js} +1 -1
  8. package/dist/assets/{Console-D-TGm246.js → Console-DxlcFHl3.js} +1 -1
  9. package/dist/assets/{Consumption-fBw5c2fv.js → Consumption-BKLhsHgd.js} +1 -1
  10. package/dist/assets/{Conversation-Db8OI0L6.js → Conversation-BpUlvLwg.js} +1 -1
  11. package/dist/assets/{CopyToClipboard-Dw5puTqb.js → CopyToClipboard-Cx0LOUlj.js} +1 -1
  12. package/dist/assets/{Detail-CwyQYM3g.js → Detail-6xMgONUm.js} +2 -2
  13. package/dist/assets/{Extra-BBboONST.js → Extra-CIY6q676.js} +1 -1
  14. package/dist/assets/{FilePreview-QJNK0WA2.js → FilePreview-DWn7VaIk.js} +1 -1
  15. package/dist/assets/{Hailuo-oOc1n_8n.js → Hailuo-jTsANDKz.js} +1 -1
  16. package/dist/assets/{History-DUBBRNc_.js → History-UPQKY9mv.js} +1 -1
  17. package/dist/assets/{ImagePreview-j8UOiTmY.js → ImagePreview--SDvXZzb.js} +1 -1
  18. package/dist/assets/{ImageWrapper-B2i7ZIND.js → ImageWrapper-CmewVMkV.js} +1 -1
  19. package/dist/assets/{Index-t6Jgc_Ua.js → Index-84gbjpna.js} +1 -1
  20. package/dist/assets/{Index-CDkRF2hQ.js → Index-9AGlB_au.js} +1 -1
  21. package/dist/assets/{Index-Csm8l8XE.js → Index-B-vaWx5A.js} +1 -1
  22. package/dist/assets/{Index-DqWmPcIJ.js → Index-B237u6Yw.js} +1 -1
  23. package/dist/assets/{Index-BTdyPJrt.js → Index-B5u3ksH1.js} +1 -1
  24. package/dist/assets/{Index-D-F8ZQNH.css → Index-BKGx51e-.css} +1 -1
  25. package/dist/assets/{Index-bZ2eC93Z.js → Index-BQ7z8P36.js} +1 -1
  26. package/dist/assets/Index-BWdPzjh-.js +1 -0
  27. package/dist/assets/{Index-CWc2Xre6.js → Index-BXIF-RWG.js} +1 -1
  28. package/dist/assets/{Index-CiXvUNJ8.js → Index-BXoTzH0F.js} +1 -1
  29. package/dist/assets/{Index-Cic686gl.js → Index-CGV0FjKt.js} +1 -1
  30. package/dist/assets/{Index-PwBzw5zz.js → Index-CVj4rTjm.js} +1 -1
  31. package/dist/assets/{Index-BuHPy3VQ.js → Index-CVus44dD.js} +1 -1
  32. package/dist/assets/{Index-eUm2e3Dg.js → Index-CWxWbL0g.js} +1 -1
  33. package/dist/assets/{Index-B4FOwiSY.js → Index-CjNu4deI.js} +1 -1
  34. package/dist/assets/{Index-DSkkPOuY.js → Index-D1RdgHa_.js} +1 -1
  35. package/dist/assets/{Index-DrYXsJXl.js → Index-D8jnHygv.js} +1 -1
  36. package/dist/assets/{Index-d-cy26fm.js → Index-D9PJAquY.js} +1 -1
  37. package/dist/assets/{Index-Dt5nN_pF.js → Index-DM6Sq_kC.js} +1 -1
  38. package/dist/assets/{Index-DRkOF5di.js → Index-DUYu1oUt.js} +1 -1
  39. package/dist/assets/{Index-DCtMoJPV.js → Index-DYTm-GNN.js} +1 -1
  40. package/dist/assets/{Index-Craz4iUs.js → Index-Dl1PE0QP.js} +1 -1
  41. package/dist/assets/{Index-D21pa7we.js → Index-DpYR6Sfv.js} +1 -1
  42. package/dist/assets/{Index-tJVQwQxJ.js → Index-Kc3Za46A.js} +1 -1
  43. package/dist/assets/{Index-CFo7aI_z.js → Index-VxHVQlHG.js} +1 -1
  44. package/dist/assets/{Index-UHom_TYH.js → Index-baEFKopZ.js} +1 -1
  45. package/dist/assets/{Index-Cf2TydGq.js → Index-puKo85vG.js} +1 -1
  46. package/dist/assets/{Invitees-X-GM1iAs.js → Invitees-CV1hT6qL.js} +1 -1
  47. package/dist/assets/{List-BjzUfDGL.js → List-BvYbsGMZ.js} +1 -1
  48. package/dist/assets/{List-Dule_pxm.js → List-D9AJjFfi.js} +1 -1
  49. package/dist/assets/{List-C57rcn3v.js → List-Norajyml.js} +1 -1
  50. package/dist/assets/{Main-0LOwc6E9.js → Main-GI82KBnh.js} +1 -1
  51. package/dist/assets/{Model-CzvoV7ym.js → Model-16AzQ58m.js} +1 -1
  52. package/dist/assets/{Navigator-D31Vqv1W.js → Navigator-D8Wzqu62.js} +1 -1
  53. package/dist/assets/{NoTasks-vOEmwSFQ.js → NoTasks-l_P0QgKI.js} +1 -1
  54. package/dist/assets/{NotFound-g-g99Hgd.js → NotFound-DRMuoYVd.js} +1 -1
  55. package/dist/assets/{Pagination-BrKhHCVU.js → Pagination-DqEvDqEC.js} +1 -1
  56. package/dist/assets/{Pay-CasL-0lk.js → Pay-Co29OpCU.js} +1 -1
  57. package/dist/assets/{Player-BeKsc7BW.js → Player-BiUwM2kG.js} +1 -1
  58. package/dist/assets/{Seedance-aCh0t58m.js → Seedance-CN0ZvcFv.js} +1 -1
  59. package/dist/assets/{Status-BZbIXVeT.js → Status-BEFWDnq9.js} +1 -1
  60. package/dist/assets/{Subscribe-DFm1FT9k.js → Subscribe-DFAR5MgJ.js} +1 -1
  61. package/dist/assets/{TabSwitcher-ChpsZAHj.js → TabSwitcher-CG60fKzQ.js} +1 -1
  62. package/dist/assets/{Tts-DHy0H9vF.js → Tts-CKyvoPlt.js} +1 -1
  63. package/dist/assets/{VideoPlayer-C6O7JCcj.js → VideoPlayer-BtXLkAAR.js} +1 -1
  64. package/dist/assets/{avatar-CJaAkR4u.js → avatar-lihDYhEX.js} +1 -1
  65. package/dist/assets/{basic-fTQpqVx3.js → basic-DIGC5On1.js} +1 -1
  66. package/dist/assets/{chat-4c2gdzaU.js → chat-Cvd9rsSR.js} +1 -1
  67. package/dist/assets/codingBridge-BEZBg9aj.js +2 -0
  68. package/dist/assets/{codingBridgeNotify-Cd3sO6PS.js → codingBridgeNotify-wulcISIB.js} +2 -2
  69. package/dist/assets/{collapse-6hEfnElE.js → collapse-Dmu2GYt3.js} +1 -1
  70. package/dist/assets/{createTaskActions-Bqo-fGQq.js → createTaskActions-BlusFyDF.js} +1 -1
  71. package/dist/assets/{date-picker-BULvgRJu.js → date-picker-BQ3bLfrE.js} +1 -1
  72. package/dist/assets/{dropdown-CPemIUgw.js → dropdown-vKgqHRPn.js} +1 -1
  73. package/dist/assets/{esm-C_mhJFSi.js → esm-18YwGFrg.js} +2 -2
  74. package/dist/assets/{esm-B-63frdI.js → esm-BkObZSGP.js} +1 -1
  75. package/dist/assets/{esm-BwKgXwfT.js → esm-CIr9avGQ.js} +3 -3
  76. package/dist/assets/esm-CdevuNOa.js +1 -0
  77. package/dist/assets/{esm-dDvPMSAk.js → esm-D5CKhKE5.js} +1 -1
  78. package/dist/assets/{esm-B09dJTiV.js → esm-DSkRMMbX.js} +2 -2
  79. package/dist/assets/{esm-CSszv0A8.js → esm-p68kwW3W.js} +1 -1
  80. package/dist/assets/{fish-D0MRHzev.js → fish-BKtKfVFt.js} +1 -1
  81. package/dist/assets/{flux-Q8UP_79t.js → flux-BHptuJew.js} +1 -1
  82. package/dist/assets/{grokvideo-BmGuOcoY.js → grokvideo-BNmqrx7a.js} +1 -1
  83. package/dist/assets/{hailuo-D4t3b5r0.js → hailuo-BL3cUsU4.js} +1 -1
  84. package/dist/assets/{headshots-oed2z6H2.js → headshots-ZghebsTv.js} +1 -1
  85. package/dist/assets/{image-DhZ3AYYg.js → image-CWcemTUB.js} +1 -1
  86. package/dist/assets/{index-CZaid7Ez.js → index-BmC-XXKj.js} +3 -3
  87. package/dist/assets/{index.browser.esm-DP3TGf8g.js → index.browser.esm-BJm1NApd.js} +1 -1
  88. package/dist/assets/{index.es-SMgxJgUT.js → index.es-Cawr8qgY.js} +1 -1
  89. package/dist/assets/{input-number-BLiYIcDP.js → input-number-lf5l-6Rs.js} +1 -1
  90. package/dist/assets/{kling-BzClI2Ea.js → kling-C0V46HIX.js} +1 -1
  91. package/dist/assets/{luma-DU9G57WM.js → luma-Dt5EUxmk.js} +1 -1
  92. package/dist/assets/{midjourney-Cc0ajBsl.js → midjourney-UrHtOXuT.js} +1 -1
  93. package/dist/assets/{nanobanana-BY58gC77.js → nanobanana-ByYhUkA2.js} +1 -1
  94. package/dist/assets/{openaiimage-tGjAf4lm.js → openaiimage-IYFXzFLb.js} +1 -1
  95. package/dist/assets/{pagination-8ujfpoRu.js → pagination-B3P0PVH-.js} +1 -1
  96. package/dist/assets/{pika-CgJnavji.js → pika-BE0KyZge.js} +1 -1
  97. package/dist/assets/{pixverse-BCJeX-Nw.js → pixverse-DQSwTd9O.js} +1 -1
  98. package/dist/assets/{popover-l_NEWD77.js → popover-pb4ZQ5wn.js} +1 -1
  99. package/dist/assets/{producer-D4z9F8wF.js → producer-Dz1qOUNB.js} +1 -1
  100. package/dist/assets/{qrart-BBrOqeL5.js → qrart-av7RaoP2.js} +1 -1
  101. package/dist/assets/{row-UUMjQQpA.js → row-DvxqZ877.js} +1 -1
  102. package/dist/assets/{seedance-dkFENRGb.js → seedance-C-h-m6TK.js} +1 -1
  103. package/dist/assets/{seedream-pZlfw7_H.js → seedream-Bx7Kn4Rp.js} +1 -1
  104. package/dist/assets/{select-BdxNJvVA.js → select-BITgEgfP.js} +1 -1
  105. package/dist/assets/{serp-FUo1xZRs.js → serp-DzqNeSdI.js} +1 -1
  106. package/dist/assets/{slider-DCyKC0oi.js → slider-EtRPxD2X.js} +1 -1
  107. package/dist/assets/{solana-wallets-BUDqS69n.js → solana-wallets-BY2b12bw.js} +2 -2
  108. package/dist/assets/{solana-wallets-vue-Dpf0qyDD.js → solana-wallets-vue-BhLdYmVf.js} +1 -1
  109. package/dist/assets/{sora-BlVuN_Ii.js → sora-NiHaB36E.js} +1 -1
  110. package/dist/assets/{suno-CMBHVDrg.js → suno-Dag49Y0o.js} +1 -1
  111. package/dist/assets/{switch-BLmaNxij.js → switch-DyO-foN-.js} +1 -1
  112. package/dist/assets/{tabs-Vpcr2eiv.js → tabs-UUQ9uIYf.js} +1 -1
  113. package/dist/assets/{upload-cst9ChUG.js → upload-DMzqzxP6.js} +1 -1
  114. package/dist/assets/{veo-CxUtDftf.js → veo-Bz9pEUS3.js} +1 -1
  115. package/dist/assets/{wan-CWDRGL7F.js → wan-CVRGdpoR.js} +1 -1
  116. package/dist/assets/{web-DjicWepk.js → web-BxKaidPB.js} +1 -1
  117. package/dist/assets/{web-CxcIP-Cm.js → web-CGDzHxq4.js} +1 -1
  118. package/dist/assets/{web-CVFBwohm.js → web-Cg3QDtE3.js} +1 -1
  119. package/dist/assets/{web-GneIBay4.js → web-D1b4Pjox.js} +1 -1
  120. package/dist/assets/{web-c3SDcorL.js → web-NdOMHV9T.js} +1 -1
  121. package/dist/assets/{webextrator-I0TZD5lE.js → webextrator-mxX-6NeJ.js} +1 -1
  122. package/dist/index.html +1 -1
  123. package/package.json +1 -1
  124. package/dist/assets/Index-81Ej0AoN.js +0 -1
  125. package/dist/assets/codingBridge-Dgq-US77.js +0 -2
  126. package/dist/assets/esm-DS6UqAt9.js +0 -1
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,Ht as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,et as d,k as f,lt as p,x as m,y as h}from"./vendor-chart-mdwpew_o.js";import{t as g}from"./button-DWzbdjZV.js";import{r as _,t as v}from"./select-BdxNJvVA.js";import{t as y}from"./upload-cst9ChUG.js";import{t as b}from"./tooltip-C3PYfh8V.js";import{t as x}from"./image-DhZ3AYYg.js";import{t as S}from"./alert-BJj7gY4q.js";import{Ct as C,Et as w,St as T,_t as E,bt as D,gt as O,ht as k,pi as A,vt as ee,wt as te,xt as j,yt as M}from"./constants-C-bSXdJ_.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-CZaid7Ez.js";import{t as W}from"./index.es-SMgxJgUT.js";import{t as G}from"./CopyToClipboard-Dw5puTqb.js";import{t as K}from"./ImagePreview-j8UOiTmY.js";import{t as q}from"./BotPlaceholder-DwmD_q7g.js";import{i as J,n as Y,t as X}from"./pagination-8ujfpoRu.js";import{n as Z,t as Q}from"./NoTasks-vOEmwSFQ.js";import{t as ne}from"./Consumption-fBw5c2fv.js";import{t as re}from"./ApiCodeButton-Bbnpv2we.js";import{t as ie}from"./Seedance-aCh0t58m.js";import{t as ae}from"./VideoPlayer-C6O7JCcj.js";var oe=s({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,n,r,i,a,o){let s=d(`prompt-textarea`);return u(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[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=s({name:`GrokVideoModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:D,label:this.$t(`grokvideo.model.default`)},{value:M,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(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,ue,[n(`div`,de,[n(`div`,fe,[n(`h2`,pe,l(e.$t(`grokvideo.name.model`)),1),a(g,{content:e.$t(`grokvideo.description.model`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`grokvideo.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{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=s({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(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,_e,[n(`div`,ve,[n(`div`,ye,[n(`h2`,be,l(e.$t(`grokvideo.name.duration`)),1),a(g,{content:e.$t(`grokvideo.description.duration`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`grokvideo.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{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=s({name:`GrokVideoResolutionSelector`,components:{InfoIcon:J},data(){return{options:[{value:C,label:`480p`},{value:te,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||=E}}),we={class:`resolution`},Te={class:`header`},Ee={class:`title font-bold`},De={class:`items`},Oe=[`onClick`];function ke(t,r,i,o,s,p){let h=d(`info-icon`);return u(),f(`div`,we,[n(`div`,Te,[n(`h2`,Ee,l(t.$t(`grokvideo.name.resolution`)),1),a(h,{content:t.$t(`grokvideo.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,De,[(u(!0),f(m,null,c(t.options,n=>(u(),f(`div`,{key:n.value,class:e([`item`,{active:t.value===n.value}]),onClick:e=>t.value=n.value},l(n.label),11,Oe))),128))])])}var Ae=P(Ce,[[`render`,ke],[`__scopeId`,`data-v-f1ebb899`]]),je=s({name:`GrokVideoRatioSelector`,components:{InfoIcon:J},computed:{options(){return[{value:j,label:`16:9`,w:32,h:18},{value:T,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||=O}}),Me={class:`ratio`},Ne={class:`header`},Pe={class:`title font-bold`},Fe={class:`items`},Ie=[`onClick`],Le={class:`preview`},Re={class:`name`};function ze(t,i,o,s,p,h){let g=d(`info-icon`);return u(),f(`div`,Me,[n(`div`,Ne,[n(`h2`,Pe,l(t.$t(`grokvideo.name.ratio`)),1),a(g,{content:t.$t(`grokvideo.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Fe,[(u(!0),f(m,null,c(t.options,i=>(u(),f(`div`,{key:i.value,class:e([`item`,{active:t.value===i.value}]),onClick:e=>t.value=i.value},[n(`div`,Le,[n(`div`,{class:`rect`,style:r({width:i.w+`px`,height:i.h+`px`})},null,4)]),n(`div`,Re,l(i.label),1)],10,Ie))),128))])])}var Be=P(je,[[`render`,ze],[`__scopeId`,`data-v-70115284`]]),Ve=s({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 w(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,m,h){let g=d(`info-icon`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`el-button`),b=d(`el-upload`);return u(),f(`div`,He,[n(`div`,Ue,[n(`div`,We,[n(`span`,Ge,l(e.$t(`grokvideo.name.image`)),1),e.required?(u(),f(`span`,Ke,l(e.$t(`grokvideo.name.required`)),1)):o(``,!0),a(g,{content:e.$t(`grokvideo.description.image`)},null,8,[`content`])])]),a(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:p(({file:n})=>[n.url&&n.percentage!==void 0?(u(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:p(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:p(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`grokvideo.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])}var Je=s({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,t,r,o,s,c){let m=d(`prompt-input`),h=d(`model-selector`),g=d(`ratio-selector`),_=d(`resolution-selector`),v=d(`duration-selector`),y=d(`image-input`),b=d(`consumption`),x=d(`font-awesome-icon`),S=d(`el-button`);return u(),f(`div`,Ye,[n(`div`,Xe,[a(m,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),a(y,{class:`mb-2`})]),n(`div`,Ze,[a(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(S,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:p(()=>[a(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`grokvideo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var $e=P(Je,[[`render`,Qe]]),et=s({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:ee}},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:e({content:!0})},ft={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},pt={key:1,class:e({content:!0})},mt={key:0,class:`mb-4`},ht={key:1,class:e({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:e({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:e({content:!0})},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Ot(e,t,r,s,c,m){let g=d(`el-image`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`copy-to-clipboard`),b=d(`el-alert`),x=d(`video-player`),S=d(`el-button`),C=d(`el-tooltip`),w=d(`api-code-button`);return u(),f(`div`,tt,[n(`div`,nt,[a(g,{src:e.grokVideoLogo,class:`avatar`},null,8,[`src`])]),n(`div`,rt,[n(`div`,it,[i(l(e.$t(`grokvideo.name.bot`))+` `,1),n(`span`,at,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ot,[e.inputImage?(u(),f(`div`,st,[a(_,{url:e.inputImage,name:`image`,closable:!1},null,8,[`url`])])):o(``,!0),e.modelValue?.request?.prompt?(u(),f(`p`,ct,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.state===`processing`||e.video?.state===`pending`?(u(),f(`span`,ut,` - (`+l(e.$t(`grokvideo.status.processing`))+`) `,1)):o(``,!0):(u(),f(`span`,lt,` - (`+l(e.$t(`grokvideo.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(u(),f(`div`,pt,[e.video?.video_url?(u(),f(`div`,mt,[a(x,{src:e.video?.video_url},null,8,[`src`])])):o(``,!0),e.video?.video_url?(u(),f(`div`,ht,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`grokvideo.message.downloadVideo`),placement:`top-start`},{default:p(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=h(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:p(()=>[i(l(e.$t(`grokvideo.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:`/grok/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(b,{closable:!1,class:`mt-2 success`},{default:p(()=>[e.modelValue?.request?.model?(u(),f(`p`,gt,[a(v,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.video?.duration?(u(),f(`p`,_t,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.duration`))+`: `+l(e.video?.duration)+`s `,1)])):o(``,!0),e.modelValue?.request?.resolution?(u(),f(`p`,vt,[a(v,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.resolution`))+`: `+l(e.modelValue?.request?.resolution)+` `,1),e.modelValue?.request?.aspect_ratio?(u(),f(`span`,yt,` · `+l(e.modelValue?.request?.aspect_ratio),1)):o(``,!0)])):o(``,!0),n(`p`,bt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),f(`p`,xt,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,St,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),f(`div`,Ct,[a(b,{closable:!1,class:`failure`},{template:p(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.failure`)),1)]),default:p(()=>[n(`p`,wt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(u(),f(`p`,Tt,[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,Et,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),f(`div`,$,[a(b,{closable:!1,class:`info`},{template:p(()=>[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.status`)),1)]),default:p(()=>[n(`p`,Dt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})])):(u(),f(`div`,dt,[a(b,{closable:!1,class:`info`},{template:p(()=>[a(v,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.status.pending`)),1)]),default:p(()=>[n(`p`,ft,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var kt=s({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(e,n,r,i,s,l){let h=d(`bot-placeholder`),g=d(`task-preview`),_=d(`scroll-list`),v=d(`no-tasks`);return u(),f(m,null,[e.tasks?.items===void 0?(u(),f(`div`,At,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(u(!0),f(m,null,c(e.tasks?.items,e=>(u(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),f(`div`,jt,[a(v)])):o(``,!0)],64)}var Nt=P(kt,[[`render`,Mt]]),Pt=A(`grok`),Ft=s({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(w(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,n,r,i,o,s){let c=d(`config-panel`),l=d(`recent-panel`),f=d(`layout`);return u(),t(f,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:p(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Lt=P(Ft,[[`render`,It]]);export{Lt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{Bt as e,D as t,E as n,Ht as r,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,et as d,k as f,lt as p,x as m,y as h}from"./vendor-chart-mdwpew_o.js";import{t as g}from"./button-DWzbdjZV.js";import{r as _,t as v}from"./select-BITgEgfP.js";import{t as y}from"./upload-DMzqzxP6.js";import{t as b}from"./tooltip-C3PYfh8V.js";import{t as x}from"./image-CWcemTUB.js";import{t as S}from"./alert-BJj7gY4q.js";import{Ct as C,Et as w,St as T,_t as E,bt as D,gt as O,ht as k,pi as A,vt as ee,wt as te,xt as j,yt as M}from"./constants-C-bSXdJ_.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-BmC-XXKj.js";import{t as W}from"./index.es-Cawr8qgY.js";import{t as G}from"./CopyToClipboard-Cx0LOUlj.js";import{t as K}from"./ImagePreview--SDvXZzb.js";import{t as q}from"./BotPlaceholder-CGjSVeUk.js";import{i as J,n as Y,t as X}from"./pagination-B3P0PVH-.js";import{n as Z,t as Q}from"./NoTasks-l_P0QgKI.js";import{t as ne}from"./Consumption-BKLhsHgd.js";import{t as re}from"./ApiCodeButton-8YzSdLWx.js";import{t as ie}from"./Seedance-CN0ZvcFv.js";import{t as ae}from"./VideoPlayer-BtXLkAAR.js";var oe=s({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,n,r,i,a,o){let s=d(`prompt-textarea`);return u(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[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=s({name:`GrokVideoModelSelector`,components:{ElSelect:_,ElOption:v,InfoIcon:J},data(){return{options:[{value:D,label:this.$t(`grokvideo.model.default`)},{value:M,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(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,ue,[n(`div`,de,[n(`div`,fe,[n(`h2`,pe,l(e.$t(`grokvideo.name.model`)),1),a(g,{content:e.$t(`grokvideo.description.model`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`grokvideo.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{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=s({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(e,r,i,o,s,h){let g=d(`info-icon`),_=d(`el-option`),v=d(`el-select`);return u(),f(`div`,_e,[n(`div`,ve,[n(`div`,ye,[n(`h2`,be,l(e.$t(`grokvideo.name.duration`)),1),a(g,{content:e.$t(`grokvideo.description.duration`),class:`info`},null,8,[`content`])])]),a(v,{modelValue:e.value,"onUpdate:modelValue":r[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`grokvideo.placeholder.select`)},{default:p(()=>[(u(!0),f(m,null,c(e.options,e=>(u(),t(_,{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=s({name:`GrokVideoResolutionSelector`,components:{InfoIcon:J},data(){return{options:[{value:C,label:`480p`},{value:te,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||=E}}),we={class:`resolution`},Te={class:`header`},Ee={class:`title font-bold`},De={class:`items`},Oe=[`onClick`];function ke(t,r,i,o,s,p){let h=d(`info-icon`);return u(),f(`div`,we,[n(`div`,Te,[n(`h2`,Ee,l(t.$t(`grokvideo.name.resolution`)),1),a(h,{content:t.$t(`grokvideo.description.resolution`),class:`info`},null,8,[`content`])]),n(`div`,De,[(u(!0),f(m,null,c(t.options,n=>(u(),f(`div`,{key:n.value,class:e([`item`,{active:t.value===n.value}]),onClick:e=>t.value=n.value},l(n.label),11,Oe))),128))])])}var Ae=P(Ce,[[`render`,ke],[`__scopeId`,`data-v-f1ebb899`]]),je=s({name:`GrokVideoRatioSelector`,components:{InfoIcon:J},computed:{options(){return[{value:j,label:`16:9`,w:32,h:18},{value:T,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||=O}}),Me={class:`ratio`},Ne={class:`header`},Pe={class:`title font-bold`},Fe={class:`items`},Ie=[`onClick`],Le={class:`preview`},Re={class:`name`};function ze(t,i,o,s,p,h){let g=d(`info-icon`);return u(),f(`div`,Me,[n(`div`,Ne,[n(`h2`,Pe,l(t.$t(`grokvideo.name.ratio`)),1),a(g,{content:t.$t(`grokvideo.description.ratio`),class:`info`},null,8,[`content`])]),n(`div`,Fe,[(u(!0),f(m,null,c(t.options,i=>(u(),f(`div`,{key:i.value,class:e([`item`,{active:t.value===i.value}]),onClick:e=>t.value=i.value},[n(`div`,Le,[n(`div`,{class:`rect`,style:r({width:i.w+`px`,height:i.h+`px`})},null,4)]),n(`div`,Re,l(i.label),1)],10,Ie))),128))])])}var Be=P(je,[[`render`,ze],[`__scopeId`,`data-v-70115284`]]),Ve=s({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 w(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,m,h){let g=d(`info-icon`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`el-button`),b=d(`el-upload`);return u(),f(`div`,He,[n(`div`,Ue,[n(`div`,We,[n(`span`,Ge,l(e.$t(`grokvideo.name.image`)),1),e.required?(u(),f(`span`,Ke,l(e.$t(`grokvideo.name.required`)),1)):o(``,!0),a(g,{content:e.$t(`grokvideo.description.image`)},null,8,[`content`])])]),a(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:p(({file:n})=>[n.url&&n.percentage!==void 0?(u(),t(_,{key:0,url:n.url,name:n.name,percentage:n.percentage,onRemove:t=>e.fileList.splice(e.fileList.indexOf(n),1)},null,8,[`url`,`name`,`percentage`,`onRemove`])):o(``,!0)]),default:p(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:p(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`grokvideo.button.upload`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`on-remove`,`headers`])])}var Je=s({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,t,r,o,s,c){let m=d(`prompt-input`),h=d(`model-selector`),g=d(`ratio-selector`),_=d(`resolution-selector`),v=d(`duration-selector`),y=d(`image-input`),b=d(`consumption`),x=d(`font-awesome-icon`),S=d(`el-button`);return u(),f(`div`,Ye,[n(`div`,Xe,[a(m,{class:`mb-4`}),a(h,{class:`mb-4`}),a(g,{class:`mb-4`}),a(_,{class:`mb-4`}),a(v,{class:`mb-4`}),a(y,{class:`mb-2`})]),n(`div`,Ze,[a(b,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(S,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:p(()=>[a(x,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`grokvideo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var $e=P(Je,[[`render`,Qe]]),et=s({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:ee}},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:e({content:!0})},ft={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},pt={key:1,class:e({content:!0})},mt={key:0,class:`mb-4`},ht={key:1,class:e({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:e({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:e({content:!0})},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Ot(e,t,r,s,c,m){let g=d(`el-image`),_=d(`image-preview`),v=d(`font-awesome-icon`),y=d(`copy-to-clipboard`),b=d(`el-alert`),x=d(`video-player`),S=d(`el-button`),C=d(`el-tooltip`),w=d(`api-code-button`);return u(),f(`div`,tt,[n(`div`,nt,[a(g,{src:e.grokVideoLogo,class:`avatar`},null,8,[`src`])]),n(`div`,rt,[n(`div`,it,[i(l(e.$t(`grokvideo.name.bot`))+` `,1),n(`span`,at,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),n(`div`,ot,[e.inputImage?(u(),f(`div`,st,[a(_,{url:e.inputImage,name:`image`,closable:!1},null,8,[`url`])])):o(``,!0),e.modelValue?.request?.prompt?(u(),f(`p`,ct,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?e.video?.state===`processing`||e.video?.state===`pending`?(u(),f(`span`,ut,` - (`+l(e.$t(`grokvideo.status.processing`))+`) `,1)):o(``,!0):(u(),f(`span`,lt,` - (`+l(e.$t(`grokvideo.status.pending`))+`) `,1))])):o(``,!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(u(),f(`div`,pt,[e.video?.video_url?(u(),f(`div`,mt,[a(x,{src:e.video?.video_url},null,8,[`src`])])):o(``,!0),e.video?.video_url?(u(),f(`div`,ht,[a(C,{class:`box-item`,effect:`dark`,content:e.$t(`grokvideo.message.downloadVideo`),placement:`top-start`},{default:p(()=>[a(S,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=h(t=>e.onDownload(e.video?.video_url),[`stop`])},{default:p(()=>[i(l(e.$t(`grokvideo.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(w,{path:`/grok/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(b,{closable:!1,class:`mt-2 success`},{default:p(()=>[e.modelValue?.request?.model?(u(),f(`p`,gt,[a(v,{icon:`fa-solid fa-cube`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.model`))+`: `+l(e.modelValue?.request?.model),1)])):o(``,!0),e.video?.duration?(u(),f(`p`,_t,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.duration`))+`: `+l(e.video?.duration)+`s `,1)])):o(``,!0),e.modelValue?.request?.resolution?(u(),f(`p`,vt,[a(v,{icon:`fa-solid fa-expand`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.resolution`))+`: `+l(e.modelValue?.request?.resolution)+` `,1),e.modelValue?.request?.aspect_ratio?(u(),f(`span`,yt,` · `+l(e.modelValue?.request?.aspect_ratio),1)):o(``,!0)])):o(``,!0),n(`p`,bt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.elapsed?(u(),f(`p`,xt,[a(v,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,St,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):e.modelValue?.response?.success===!1?(u(),f(`div`,Ct,[a(b,{closable:!1,class:`failure`},{template:p(()=>[a(v,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.failure`)),1)]),default:p(()=>[n(`p`,wt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])]),e.modelValue?.response?.error?.message?(u(),f(`p`,Tt,[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(y,{content:e.modelValue?.response?.error?.message,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0),e.modelValue?.response?.trace_id?(u(),f(`p`,Et,[a(v,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(y,{content:e.modelValue?.response?.trace_id,class:`btn-copy inline-block`},null,8,[`content`])])):o(``,!0)]),_:1})])):(u(),f(`div`,$,[a(b,{closable:!1,class:`info`},{template:p(()=>[a(v,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.status`)),1)]),default:p(()=>[n(`p`,Dt,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})])):(u(),f(`div`,dt,[a(b,{closable:!1,class:`info`},{template:p(()=>[a(v,{icon:`fa-regular fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.status.pending`)),1)]),default:p(()=>[n(`p`,ft,[a(v,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`grokvideo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(y,{content:e.modelValue?.id,class:`btn-copy inline-block`},null,8,[`content`])])]),_:1})]))])])}var kt=s({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(e,n,r,i,s,l){let h=d(`bot-placeholder`),g=d(`task-preview`),_=d(`scroll-list`),v=d(`no-tasks`);return u(),f(m,null,[e.tasks?.items===void 0?(u(),f(`div`,At,[a(h)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),t(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:n[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(u(!0),f(m,null,c(e.tasks?.items,e=>(u(),t(g,{key:e.id,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),f(`div`,jt,[a(v)])):o(``,!0)],64)}var Nt=P(kt,[[`render`,Mt]]),Pt=A(`grok`),Ft=s({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(w(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,n,r,i,o,s){let c=d(`config-panel`),l=d(`recent-panel`),f=d(`layout`);return u(),t(f,null,{config:p(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:p(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var Lt=P(Ft,[[`render`,It]]);export{Lt as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,_ as u,et as d,k as f,lt as p,tt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{F as y,X as b,Y as x,tt as S,z as C}from"./use-deprecated-CPfQu7wa.js";import{r as w,t as T}from"./select-BdxNJvVA.js";import{n as E,t as D}from"./tabs-Vpcr2eiv.js";import{t as O}from"./upload-cst9ChUG.js";import{t as k}from"./tooltip-C3PYfh8V.js";import{t as A}from"./image-DhZ3AYYg.js";import{t as j}from"./avatar-DJGt2zYX.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as ee,t as P}from"./collapse-6hEfnElE.js";import{t as F}from"./drawer-BvYPSxXh.js";import{n as I,r as te,t as ne}from"./dropdown-CPemIUgw.js";import{t as L}from"./input-number-BLiYIcDP.js";import{n as re,t as ie}from"./skeleton-Cn4UY-T8.js";import{t as ae}from"./slider-DCyKC0oi.js";import{t as oe}from"./switch-BLmaNxij.js";import{An as se,pi as R}from"./constants-C-bSXdJ_.js";import{An as z,At as B,E as V,Fn as H,Ir as U,Nt as W,Ot as G,Sr as K,kr as q,kt as ce,nn as J,yr as Y}from"./index-CZaid7Ez.js";import{t as X}from"./index.es-SMgxJgUT.js";import{n as le}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Z,n as ue,r as de,t as fe}from"./pagination-8ujfpoRu.js";import{n as pe,t as me}from"./NoTasks-vOEmwSFQ.js";import{t as he}from"./Consumption-fBw5c2fv.js";import{n as ge,r as Q,t as _e}from"./Player-BeKsc7BW.js";var ve=o({name:`LayoutProducer`,components:{ElDrawer:F,ElButton:v,FontAwesomeIcon:X},mixins:[le],data(){return{preview:!1}},computed:{}}),ye={class:`main flex flex-row flex-1`},be={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},xe={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},Se={class:`preview h-full w-[300px] flex flex-col`};function Ce(t,r,a,o,s,c){let m=d(`font-awesome-icon`),g=d(`el-button`),_=d(`el-drawer`);return l(),f(`div`,ye,[n(`div`,be,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,xe,[e(t.$slots,`result`,{},void 0,!0)]),n(`div`,Se,[e(t.$slots,`preview`,{},void 0,!0)]),h(i(g,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(m,{icon:`fa-solid fa-magic`})]),_:1},512),[[u,!t.tasksEmpty]]),i(_,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var we=V(ve,[[`render`,Ce],[`__scopeId`,`data-v-cc984c6f`]]),Te=o({name:`TypeSelector`,components:{ElSelect:w,ElOption:T,ElSwitch:oe,InfoIcon:Z},data(){return{options:[{label:`FUZZ-2.0 Pro`,value:`FUZZ-2.0 Pro`,desc:this.$t(`producer.model.fuzz20proDesc`)},{label:`FUZZ-2.0`,value:`FUZZ-2.0`,desc:this.$t(`producer.model.fuzz20desc`)},{label:`FUZZ-2.0 Raw`,value:`FUZZ-2.0 Raw`,desc:this.$t(`producer.model.fuzz20rawDesc`)},{label:`FUZZ-1.1 Pro`,value:`FUZZ-1.1 Pro`,desc:this.$t(`producer.model.fuzz11proDesc`)},{label:`FUZZ-1.1`,value:`FUZZ-1.1`,desc:this.$t(`producer.model.fuzz11desc`)},{label:`FUZZ-1.0 Pro`,value:`FUZZ-1.0 Pro`,desc:this.$t(`producer.model.fuzz10proDesc`)},{label:`FUZZ-1.0`,value:`FUZZ-1.0`,desc:this.$t(`producer.model.fuzz10desc`)},{label:`FUZZ-0.8`,value:`FUZZ-0.8`,desc:this.$t(`producer.model.fuzz08desc`)}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||=se}}),Ee={class:`mb-3`},De={class:`flex items-center mb-1`},Oe={class:`text-sm font-bold`},ke={class:`model-option`},Ae={class:`model-option-name`},je={class:`model-option-desc`},Me={key:0,class:`flex items-center justify-between mb-3`},Ne={class:`flex items-center`},Pe={class:`text-sm font-bold`};function Fe(e,r,o,u,m,h){let _=d(`el-option`),v=d(`el-select`),y=d(`info-icon`),b=d(`el-switch`);return l(),f(`div`,null,[n(`div`,Ee,[n(`div`,De,[n(`span`,Oe,c(e.$t(`producer.name.model`)),1)]),i(v,{modelValue:e.model,"onUpdate:modelValue":r[0]||=t=>e.model=t,class:`w-full model-select`,size:`default`,placeholder:e.$t(`producer.placeholder.select`)},{default:p(()=>[(l(!0),f(g,null,s(e.options,e=>(l(),t(_,{key:e.value,label:e.label,value:e.value},{default:p(()=>[n(`div`,ke,[n(`span`,Ae,c(e.label),1),n(`span`,je,c(e.desc),1)])]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),e.custom?(l(),f(`div`,Me,[n(`div`,Ne,[n(`span`,Pe,c(e.$t(`producer.name.instrumental`)),1),i(y,{content:e.$t(`producer.description.instrumental`)},null,8,[`content`])]),i(b,{modelValue:e.instrumental,"onUpdate:modelValue":r[1]||=t=>e.instrumental=t},null,8,[`modelValue`])])):a(``,!0)])}var Ie=V(Te,[[`render`,Fe],[`__scopeId`,`data-v-42496b9a`]]),Le=o({name:`UploadAudio`,components:{ElUpload:O,ElButton:v,ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z,FontAwesomeIcon:X},mixins:[ce],emits:[`change`],data(){return{fileList:[],uploadUrl:K()+`/api/v1/files/`,audioPreviewUrl:null,uploading:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},hasUploadedAudio(){let e=this.$store.state.producer?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.producer?.config?.action||`upload_extend`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},methods:{onExceed(){q.warning(this.$t(`producer.message.uploadReferencesExceed`))},onError(){this.uploading=!1,q.error(this.$t(`producer.message.uploadReferencesError`))},async onSuccess(){let e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`),this.uploading=!1;return}this.uploading=!0,q.info(this.$t(`producer.message.startingUploadAudio`));try{let e=(await J.upload(t,{token:n})).data?.data.audio_id;this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,audio_id:e,action:`upload_extend`}),q.success(this.$t(`producer.message.startUploadAudioSuccess`))}catch(e){q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startUploadAudioFailed`))}finally{this.uploading=!1}}}}),Re={class:`relative`},ze={class:`flex justify-between items-center mb-2`},Be={class:`flex justify-start items-center`},Ve={class:`text-sm font-bold`},He={key:0,class:`mb-2`},Ue=[`src`],We={key:1,class:`mt-1`};function Ge(e,t,o,s,u,m){let h=d(`info-icon`),g=d(`font-awesome-icon`),_=d(`el-button`),v=d(`el-upload`),y=d(`el-radio-button`),b=d(`el-radio-group`);return l(),f(`div`,Re,[n(`div`,ze,[n(`div`,Be,[n(`span`,Ve,c(e.$t(`producer.name.referenceAudios`)),1),i(h,{content:e.$t(`producer.description.uploadAudios`)},null,8,[`content`])]),i(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper inline-upload`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[i(_,{round:``,type:`primary`,size:`small`,loading:e.uploading},{default:p(()=>[i(g,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),r(` `+c(e.$t(`producer.button.uploadAudios`)),1)]),_:1},8,[`loading`])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])]),e.audioPreviewUrl?(l(),f(`div`,He,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Ue)])):a(``,!0),e.hasUploadedAudio?(l(),f(`div`,We,[i(b,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||=t=>e.uploadAction=t,size:`small`},{default:p(()=>[i(y,{value:`upload_extend`},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1}),i(y,{value:`upload_cover`},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1})]),_:1},8,[`modelValue`])])):a(``,!0)])}var Ke=V(Le,[[`render`,Ge],[`__scopeId`,`data-v-7fd0580a`]]),qe=o({name:`PromptInput`,components:{PromptTextarea:pe},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Je(e,n,r,i,a,o){let s=d(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`producer.name.songDescription`),info:e.$t(`producer.description.prompt`),placeholder:e.$t(`producer.placeholder.prompt`),"min-rows":5,"max-rows":14},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ye=V(qe,[[`render`,Je]]),Xe=o({name:`LyricInput`,components:{ElInput:U,ElButton:v,FontAwesomeIcon:X,InfoIcon:Z},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||=``},methods:{async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t=this.config?.style||this.config?.title||`a beautiful song`;this.generatingLyrics=!0,q.info(this.$t(`producer.message.generatingLyrics`));try{let n=(await J.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:n.text,title:n.title}),q.success(this.$t(`producer.message.generateLyricsSuccess`)))}catch{q.error(this.$t(`producer.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}),Ze={class:`field`},Qe={class:`flex items-center justify-between mb-1`},$e={class:`flex items-center`},et={class:`text-sm font-bold`};function tt(e,o,s,u,m,h){let g=d(`info-icon`),_=d(`font-awesome-icon`),v=d(`el-button`),y=d(`el-input`);return l(),f(`div`,Ze,[n(`div`,Qe,[n(`div`,$e,[n(`span`,et,c(e.$t(`producer.name.lyrics`)),1),i(g,{content:e.$t(`producer.description.lyrics`)},null,8,[`content`])]),e.config?.action===`extend`?a(``,!0):(l(),t(v,{key:0,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:p(()=>[e.generatingLyrics?a(``,!0):(l(),t(_,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),r(` `+c(e.$t(`producer.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),e.config?.action===`extend`?(l(),t(y,{key:1,modelValue:e.lyric,"onUpdate:modelValue":o[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(l(),t(y,{key:0,modelValue:e.lyric,"onUpdate:modelValue":o[0]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`]))])}var nt=V(Xe,[[`render`,tt],[`__scopeId`,`data-v-88c6da2b`]]),rt=o({name:`StyleInput`,components:{ElInput:U,InfoIcon:Z},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style:e})}}}}),it={class:`field`},at={class:`flex items-center justify-between mb-1`},ot={class:`flex items-center`},st={class:`text-sm font-bold`};function ct(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,it,[n(`div`,at,[n(`div`,ot,[n(`span`,st,c(e.$t(`producer.name.style`)),1),i(u,{content:e.$t(`producer.description.style`)},null,8,[`content`])])]),i(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||=t=>e.style=t,rows:2,type:`textarea`,placeholder:e.$t(`producer.placeholder.style`)},null,8,[`modelValue`,`placeholder`])])}var lt=V(rt,[[`render`,ct]]),ut=o({name:`TitleInput`,components:{ElInput:U,InfoIcon:Z},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,title:e})}}}}),dt={class:`field`},ft={class:`flex items-center mb-1`},pt={class:`text-sm font-bold`};function mt(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,dt,[n(`div`,ft,[n(`span`,pt,c(e.$t(`producer.name.title`)),1),i(u,{content:e.$t(`producer.description.title`)},null,8,[`content`])]),i(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||=t=>e.title=t,placeholder:e.$t(`producer.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var ht=V(ut,[[`render`,mt]]),gt=o({name:`ExtendFromInput`,components:{ElImage:A,ElIcon:S,ElInputNumber:L,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),_t={class:`field`},vt={class:`box`},yt={class:`title font-bold`},bt={class:`input-wrapper`},xt={class:`task`},St={class:`left`},Ct={key:2,class:`duration`},wt={class:`info`},Tt={class:`title`},Et={class:`style`};function Dt(e,t,r,o,s,u){let g=d(`el-input-number`),_=d(`el-image`),v=d(`video-pause`),y=d(`el-icon`),b=d(`video-play`),x=m(`loading`);return l(),f(`div`,_t,[n(`div`,vt,[n(`h2`,yt,c(e.$t(`producer.name.extend`)),1),n(`div`,bt,[i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,xt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[3]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,St,[i(_,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[1]||=t=>e.onPause(e.audio)},[i(y,null,{default:p(()=>[i(v)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[2]||=t=>e.onPlay(e.audio)},[i(y,null,{default:p(()=>[i(b)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ct,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,wt,[n(`h2`,Tt,c(e.audio?.title),1),n(`p`,Et,c(e.audio?.style),1)])])):a(``,!0)])])}var Ot=V(gt,[[`render`,Dt],[`__scopeId`,`data-v-26d43480`]]),kt=o({name:`CoverFromInput`,components:{ElImage:A,ElIcon:S,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),At={class:`field`},jt={class:`box`},Mt={class:`title font-bold`},Nt={class:`task`},Pt={class:`left`},Ft={key:2,class:`duration`},It={class:`info`},Lt={class:`title`},Rt={class:`style`};function zt(e,t,r,o,s,u){let g=d(`el-image`),_=d(`video-pause`),v=d(`el-icon`),y=d(`video-play`),b=m(`loading`);return l(),f(`div`,At,[n(`div`,jt,[n(`h2`,Mt,c(e.$t(`producer.name.cover`)),1)]),n(`div`,Nt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[2]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,Pt,[i(g,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[0]||=t=>e.onPause(e.audio)},[i(v,null,{default:p(()=>[i(_)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[1]||=t=>e.onPlay(e.audio)},[i(v,null,{default:p(()=>[i(y)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ft,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,It,[n(`h2`,Lt,c(e.audio?.title),1),n(`p`,Rt,c(e.audio?.style),1)])])):a(``,!0)])])}var Bt=V(kt,[[`render`,zt],[`__scopeId`,`data-v-d8a8e583`]]),Vt=o({name:`VocalGenderSelector`,components:{ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),Ht={class:`mb-2`},Ut={class:`flex items-center mb-1`},Wt={class:`text-sm font-bold`};function Gt(e,t,a,o,s,u){let m=d(`info-icon`),h=d(`el-radio-button`),g=d(`el-radio-group`);return l(),f(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,c(e.$t(`producer.name.vocalGender`)),1),i(m,{content:e.$t(`producer.description.vocalGender`)},null,8,[`content`])]),i(g,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||=t=>e.vocalGender=t},{default:p(()=>[i(h,{value:``},{default:p(()=>[r(c(e.$t(`producer.gender.auto`)),1)]),_:1}),i(h,{value:`f`},{default:p(()=>[r(c(e.$t(`producer.gender.female`)),1)]),_:1}),i(h,{value:`m`},{default:p(()=>[r(c(e.$t(`producer.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Kt=V(Vt,[[`render`,Gt]]),qt=o({name:`AdvancedParams`,components:{ElCollapse:P,ElCollapseItem:ee,ElInput:U,ElSlider:ae,ElInputNumber:L,InfoIcon:Z},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??.5},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,weirdness:e})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,seed:e})}}},mounted(){let e=this.$store.state.producer?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.sound_strength==`number`&&e.sound_strength>1&&(t.sound_strength=e.sound_strength/100),typeof e.lyrics_strength==`number`&&e.lyrics_strength>1&&(t.lyrics_strength=e.lyrics_strength/100),Object.keys(t).length>0&&this.$store.commit(`producer/setConfig`,{...e,...t})}}),Jt={key:0,class:`mb-3`},Yt={class:`flex items-center mb-1`},Xt={class:`text-xs font-bold`},Zt={key:1,class:`mb-3`},Qt={class:`flex items-center mb-1`},$t={class:`text-xs font-bold`},en={class:`mb-3`},tn={class:`flex items-center justify-between mb-1`},nn={class:`flex items-center`},rn={class:`text-xs font-bold`},an={class:`text-xs text-[var(--el-text-color-secondary)]`},on={class:`mb-3`},sn={class:`flex items-center justify-between mb-1`},cn={class:`flex items-center`},ln={class:`text-xs font-bold`},un={class:`text-xs text-[var(--el-text-color-secondary)]`},dn={key:2,class:`mb-3`},fn={class:`flex items-center justify-between mb-1`},pn={class:`flex items-center`},mn={class:`text-xs font-bold`},hn={class:`text-xs text-[var(--el-text-color-secondary)]`},gn={class:`mb-3`},_n={class:`flex items-center mb-1`},vn={class:`text-xs font-bold`};function yn(e,r,o,s,u,m){let h=d(`info-icon`),g=d(`el-input`),_=d(`el-slider`),v=d(`el-input-number`),y=d(`el-collapse-item`),b=d(`el-collapse`);return l(),t(b,{modelValue:e.activeNames,"onUpdate:modelValue":r[6]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:p(()=>[i(y,{title:e.$t(`producer.name.advancedParams`),name:`advanced`},{default:p(()=>[e.config?.custom?(l(),f(`div`,Jt,[n(`div`,Yt,[n(`span`,Xt,c(e.$t(`producer.name.styleNegative`)),1),i(h,{content:e.$t(`producer.description.styleNegative`)},null,8,[`content`])]),i(g,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`producer.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,Zt,[n(`div`,Qt,[n(`span`,$t,c(e.$t(`producer.name.lyricPrompt`)),1),i(h,{content:e.$t(`producer.description.lyricPrompt`)},null,8,[`content`])]),i(g,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`producer.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),n(`div`,en,[n(`div`,tn,[n(`div`,nn,[n(`span`,rn,c(e.$t(`producer.name.weirdness`)),1),i(h,{content:e.$t(`producer.description.weirdness`)},null,8,[`content`])]),n(`span`,an,c(e.weirdness??.5),1)]),i(_,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])]),n(`div`,on,[n(`div`,sn,[n(`div`,cn,[n(`span`,ln,c(e.$t(`producer.name.soundStrength`)),1),i(h,{content:e.$t(`producer.description.soundStrength`)},null,8,[`content`])]),n(`span`,un,c(e.soundStrength??.7),1)]),i(_,{modelValue:e.soundStrength,"onUpdate:modelValue":r[3]||=t=>e.soundStrength=t,min:.2,max:1,step:.01},null,8,[`modelValue`])]),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,dn,[n(`div`,fn,[n(`div`,pn,[n(`span`,mn,c(e.$t(`producer.name.lyricsStrength`)),1),i(h,{content:e.$t(`producer.description.lyricsStrength`)},null,8,[`content`])]),n(`span`,hn,c(e.lyricsStrength??.7),1)]),i(_,{modelValue:e.lyricsStrength,"onUpdate:modelValue":r[4]||=t=>e.lyricsStrength=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):a(``,!0),n(`div`,gn,[n(`div`,_n,[n(`span`,vn,c(e.$t(`producer.name.seed`)),1),i(h,{content:e.$t(`producer.description.seed`)},null,8,[`content`])]),i(v,{modelValue:e.seed,"onUpdate:modelValue":r[5]||=t=>e.seed=t,min:0,controls:!1,size:`small`,placeholder:e.$t(`producer.placeholder.seed`),class:`w-full`},null,8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var bn=V(qt,[[`render`,yn],[`__scopeId`,`data-v-f9296888`]]),xn=o({name:`ReplaceSectionInput`,components:{ElInputNumber:L,ElImage:A,InfoIcon:Z},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`})}}}),Sn={class:`field`},Cn={class:`flex items-center mb-2`},wn={class:`text-sm font-bold m-0`},Tn={key:0,class:`task mb-2`},En={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Dn={class:`info flex-1 min-w-0`},On={class:`text-sm font-bold m-0 truncate`},kn={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},An={class:`flex gap-2`};function jn(e,t,r,o,s,u){let p=d(`info-icon`),g=d(`el-image`),_=d(`el-input-number`),v=m(`loading`);return l(),f(`div`,Sn,[n(`div`,Cn,[n(`h2`,wn,c(e.$t(`producer.name.replaceSection`)),1),i(p,{content:e.$t(`producer.description.replaceSection`)},null,8,[`content`])]),e.audio?(l(),f(`div`,Tn,[n(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,En,[i(g,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Dn,[n(`h2`,On,c(e.audio?.title),1),n(`p`,kn,c(e.audio?.style),1)])])])):a(``,!0),n(`div`,An,[i(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),i(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Mn=o({name:`PresetPanel`,components:{TypeSelector:Ie,PromptInput:Ye,LyricInput:nt,StyleInput:lt,TitleInput:ht,ExtendFromInput:Ot,CoverFromInput:Bt,UploadAudio:Ke,VocalGenderSelector:Kt,AdvancedParams:bn,ReplaceSectionInput:V(xn,[[`render`,jn]]),FontAwesomeIcon:X,ElButton:v,ElTabs:E,ElTabPane:D,Consumption:he},emits:[`generate`],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e===`custom`})}},consumption(){return W(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){let e=this.config?.action;return e===`extend`||e===`upload_extend`?this.$t(`producer.button.extend`):e===`cover`||e===`upload_cover`?this.$t(`producer.button.cover_music`):e===`variation`?this.$t(`producer.button.variation`):e===`replace_section`?this.$t(`producer.button.replace_section`):e===`stems`?this.$t(`producer.button.get_stems`):e===`swap_vocals`?this.$t(`producer.button.swap_vocals`):e===`swap_instrumentals`?this.$t(`producer.button.swap_instrumentals`):this.$t(`producer.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`producer/setConfig`,{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:``,lyric:``,style:``,title:``,model:this.$store.state.producer?.config?.model})}}}),Nn={class:`flex flex-col h-full`},Pn={class:`flex-1 overflow-y-auto p-5`},Fn={class:`pt-2 px-1`},In={class:`pt-2 px-1`},Ln={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Rn={class:`flex gap-2 w-full`};function zn(e,o,s,u,m,h){let g=d(`type-selector`),_=d(`upload-audio`),v=d(`prompt-input`),y=d(`extend-from-input`),b=d(`cover-from-input`),x=d(`replace-section-input`),S=d(`advanced-params`),C=d(`el-tab-pane`),w=d(`lyric-input`),T=d(`style-input`),E=d(`title-input`),D=d(`vocal-gender-selector`),O=d(`el-tabs`),k=d(`consumption`),A=d(`font-awesome-icon`),j=d(`el-button`);return l(),f(`div`,Nn,[n(`div`,Pn,[i(O,{modelValue:e.mode,"onUpdate:modelValue":o[0]||=t=>e.mode=t,class:`producer-mode-tabs`,stretch:``},{default:p(()=>[i(C,{label:e.$t(`producer.mode.simple`),name:`simple`},{default:p(()=>[n(`div`,Fn,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),i(v,{class:`mb-4`}),e.config?.action===`extend`?(l(),t(y,{key:0,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:1,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:2,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`]),i(C,{label:e.$t(`producer.mode.custom`),name:`custom`},{default:p(()=>[n(`div`,In,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(w,{key:0,class:`mb-4`})),i(T,{class:`mb-4`}),i(E,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(D,{key:1,class:`mb-4`})),e.config?.action===`extend`?(l(),t(y,{key:2,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:3,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:4,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Ln,[i(k,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Rn,[i(j,{class:`flex-1`,onClick:e.onClearAll},{default:p(()=>[i(A,{icon:`fa-solid fa-broom`,class:`mr-1`}),r(` `+c(e.$t(`producer.button.clear_all`)),1)]),_:1},8,[`onClick`]),i(j,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:p(()=>[i(A,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Bn=V(Mn,[[`render`,zn],[`__scopeId`,`data-v-4a4b209e`]]),Vn=ge(),Hn=R(`producer`),Un=o({name:`TaskPreview`,components:{ElImage:A,ElIcon:S,ElTooltip:k,FontAwesomeIcon:X,VideoPlay:b,VideoPause:x,ElDropdown:ne,ElDropdownMenu:te,ElDropdownItem:I,Loading:y,ApiCodeDialog:de},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,apiCodeVisible:!1,apiCodePath:`/producer/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===Y.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.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.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:Q,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=`/producer/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.debug(`set config`,t),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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();let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);fetch(t).then(e=>e.blob()).then(e=>{(0,Vn.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),q.error(this.$t(`producer.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}J.video(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(),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},onVariation(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:`variation`,audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl(`swap_vocals`,e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl(`swap_instrumentals`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,q.info(this.$t(`producer.message.fetchingWav`));let n=(await J.wav({audio_id:e.id},{token:t})).data?.data,r=Array.isArray(n)?n[0]?.file_url:n?.file_url||n?.audio_url;r?this.onDownload(null,r):q.error(this.$t(`producer.message.fetchWavFailed`))}catch{q.error(this.$t(`producer.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Hn},r=this.credential?.token;if(!r){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),J.audio(n,{token:r}).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`producer/getTasks`,{limit:30,offset:0})}}}),Wn={class:`task`},Gn=[`onClick`],Kn={class:`left`},qn=[`onClick`],Jn=[`onClick`],Yn={key:2,class:`duration`},Xn={class:`info`},Zn={class:`title`},Qn={class:`style`},$n={class:`right`},er={class:`el-dropdown-link`},tr={class:`flex items-center min-w-[120px]`},nr={class:`flex items-center min-w-[120px]`},rr={class:`el-dropdown-link`};function ir(e,o,u,v,y,b){let x=d(`el-image`),S=d(`video-pause`),C=d(`el-icon`),w=d(`video-play`),T=d(`font-awesome-icon`),E=d(`el-tooltip`),D=d(`Loading`),O=d(`el-dropdown-item`),k=d(`el-dropdown-menu`),A=d(`el-dropdown`),j=d(`api-code-dialog`),M=m(`loading`);return l(),f(`div`,Wn,[(l(!0),f(g,null,s(e.audios,o=>(l(),f(`div`,{key:o.id,class:`audio`,onClick:_(t=>e.onClick(o),[`stop`])},[h((l(),f(`div`,Kn,[i(x,{src:o?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),o?.audio_url&&e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:_(t=>e.onPause(o),[`stop`])},[i(C,null,{default:p(()=>[i(S)]),_:1})],8,qn)):a(``,!0),o?.audio_url&&(e.$store.state?.producer?.audio?.id!==o.id||e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:_(t=>e.onPlay(o),[`stop`])},[i(C,null,{default:p(()=>[i(w)]),_:1})],8,Jn)):a(``,!0),o?.duration?(l(),f(`div`,Yn,c(e.useFormatDuring(o?.duration)),1)):a(``,!0)])),[[M,!o?.audio_url]]),n(`div`,Xn,[n(`h2`,Zn,c(o?.title),1),n(`p`,Qn,c(o?.style),1)]),n(`div`,$n,[i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[i(O,{disabled:e.isFetchingVideoUrl,onClick:t=>e.handleVideoDownload(o)},{default:p(()=>[n(`div`,tr,[e.isFetchingVideoUrl?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onDownload(t,o?.audio_url),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.download_audio`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{disabled:e.isFetchingWav,onClick:t=>e.handleWavDownload(o)},{default:p(()=>[n(`div`,nr,[e.isFetchingWav?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,er,[i(E,{effect:`dark`,content:e.$t(`producer.button.download`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onExtend(t,o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:1,onClick:_(t=>e.onGetStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.get_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:2,onClick:_(t=>e.onGetAllStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.all_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(t=>e.onCover(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1},8,[`onClick`]),o?.id?(l(),t(O,{key:3,onClick:_(t=>e.onVariation(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.variation`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:4,onClick:_(t=>e.onSwapVocals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_vocals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:5,onClick:_(t=>e.onSwapInstrumentals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_instrumentals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:6,onClick:_(t=>e.onReplaceSection(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.replace_section`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(e.onViewCode,[`stop`])},{default:p(()=>[i(T,{icon:`fa-solid fa-code`,class:`mr-1`}),r(` `+c(e.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,rr,[i(E,{effect:`dark`,content:e.$t(`producer.button.more`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],8,Gn))),128)),i(j,{visible:e.apiCodeVisible,"onUpdate:visible":o[0]||=t=>e.apiCodeVisible=t,method:`POST`,path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.producer?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var ar=o({name:`RecentPanel`,components:{ElSkeletonItem:re,ElSkeleton:ie,TaskPreview:V(Un,[[`render`,ir]]),Player:_e,NoTasks:me,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),or={key:0,class:`tasks`},sr={class:`left w-[70px] p-[10px] flex items-center`},$={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},cr={key:2,class:`w-full flex-1 flex items-center justify-center`},lr={class:`h-20`};function ur(e,r,o,c,m,_){let v=d(`el-skeleton-item`),y=d(`el-skeleton`),b=d(`task-preview`),x=d(`scroll-list`),S=d(`no-tasks`),C=d(`player`);return l(),f(g,null,[e.tasks?.items===void 0?(l(),f(`div`,or,[(l(),f(g,null,s(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,sr,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,$,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),i(v,{variant:`text`})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(x,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:e.loading,onReachTop:r[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(l(!0),f(g,null,s(e.tasks?.items,(e,n)=>(l(),t(b,{key:n,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),f(`div`,cr,[i(S)])):a(``,!0),h(n(`div`,lr,[i(C,{namespace:`producer`})],512),[[u,!!e.$store?.state?.producer?.audio?.object]])],64)}var dr=V(ar,[[`render`,ur]]),fr=o({name:`TaskPreview`,components:{IconPicture:C,ElImage:A,ElAvatar:j,ElIcon:S},computed:{audio(){return this.$store.state.producer?.audio}}}),pr={key:0,class:`size-full overflow-hidden`},mr={class:`relative h-[300px]`},hr={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},gr={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`},_r={class:`p-4`},vr={class:`flex items-center font-bold mb-2`},yr={class:`text-[var(--el-text-color-regular)] mb-2`},br={class:`text-xs text-[var(--el-text-color-regular)]`},xr={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},Sr={key:1,class:`w-full h-full`};function Cr(e,t,r,a,o,s){let u=d(`icon-picture`),m=d(`el-icon`),h=d(`el-image`),g=d(`el-avatar`);return e.audio?.object?(l(),f(`div`,pr,[n(`div`,mr,[i(h,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:p(()=>[n(`div`,hr,[i(m,{class:`text-3xl`},{default:p(()=>[i(u)]),_:1})])]),_:1},8,[`src`]),n(`h2`,gr,c(e.audio?.title),1)]),n(`div`,_r,[n(`div`,vr,[i(g,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,c(e.audio?.title),1)]),n(`p`,yr,c(e.audio?.style),1),n(`p`,br,c(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,xr,[n(`p`,null,c(e.audio?.lyric),1)])])])):(l(),f(`div`,Sr))}var wr=V(fr,[[`render`,Cr]]),Tr=R(`producer`),Er=o({name:`ProducerIndex`,components:{Layout:we,ConfigPanel:Bn,RecentPanel:dr,PreviewPanel:wr},mixins:[B],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===Y.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===Y.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===Y.Request},needApply(){return this.$store.state.producer.status.getApplications===Y.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.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 fe({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(`producer/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`producer/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){z.create({application:this.application}).then(({data:e})=>{this.application=e,q.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&q.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(`producer/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!G(this.uploadTracker,e=>this.$t(e),e=>q.warning(e)))return;let e={...this.config,callback_url:Tr},t=this.credential?.token;if(!t){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),H(`producer`,J.audio(e,{token:t})).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Dr(e,n,r,a,o,s){let c=d(`config-panel`),u=d(`recent-panel`),f=d(`preview-panel`),m=d(`layout`);return l(),t(m,null,{config:p(()=>[i(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:p(()=>[i(u,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:p(()=>[i(f)]),_:1})}var Or=V(Er,[[`render`,Dr],[`__scopeId`,`data-v-a766e27a`]]);export{Or as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,_ as u,et as d,k as f,lt as p,tt as m,ut as h,x as g,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{F as y,X as b,Y as x,tt as S,z as C}from"./use-deprecated-CPfQu7wa.js";import{r as w,t as T}from"./select-BITgEgfP.js";import{n as E,t as D}from"./tabs-UUQ9uIYf.js";import{t as O}from"./upload-DMzqzxP6.js";import{t as k}from"./tooltip-C3PYfh8V.js";import{t as A}from"./image-CWcemTUB.js";import{t as j}from"./avatar-DJGt2zYX.js";import{n as M,r as N}from"./radio-IJQsW93X.js";import{n as ee,t as P}from"./collapse-Dmu2GYt3.js";import{t as F}from"./drawer-BvYPSxXh.js";import{n as I,r as te,t as ne}from"./dropdown-vKgqHRPn.js";import{t as L}from"./input-number-lf5l-6Rs.js";import{n as re,t as ie}from"./skeleton-Cn4UY-T8.js";import{t as ae}from"./slider-EtRPxD2X.js";import{t as oe}from"./switch-DyO-foN-.js";import{An as se,pi as R}from"./constants-C-bSXdJ_.js";import{An as z,At as B,E as V,Fn as H,Ir as U,Nt as W,Ot as G,Sr as K,kr as q,kt as ce,nn as J,yr as Y}from"./index-BmC-XXKj.js";import{t as X}from"./index.es-Cawr8qgY.js";import{n as le}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Z,n as ue,r as de,t as fe}from"./pagination-B3P0PVH-.js";import{n as pe,t as me}from"./NoTasks-l_P0QgKI.js";import{t as he}from"./Consumption-BKLhsHgd.js";import{n as ge,r as Q,t as _e}from"./Player-BiUwM2kG.js";var ve=o({name:`LayoutProducer`,components:{ElDrawer:F,ElButton:v,FontAwesomeIcon:X},mixins:[le],data(){return{preview:!1}},computed:{}}),ye={class:`main flex flex-row flex-1`},be={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},xe={class:`result h-full flex flex-col flex-1 min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`},Se={class:`preview h-full w-[300px] flex flex-col`};function Ce(t,r,a,o,s,c){let m=d(`font-awesome-icon`),g=d(`el-button`),_=d(`el-drawer`);return l(),f(`div`,ye,[n(`div`,be,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,xe,[e(t.$slots,`result`,{},void 0,!0)]),n(`div`,Se,[e(t.$slots,`preview`,{},void 0,!0)]),h(i(g,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(m,{icon:`fa-solid fa-magic`})]),_:1},512),[[u,!t.tasksEmpty]]),i(_,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var we=V(ve,[[`render`,Ce],[`__scopeId`,`data-v-cc984c6f`]]),Te=o({name:`TypeSelector`,components:{ElSelect:w,ElOption:T,ElSwitch:oe,InfoIcon:Z},data(){return{options:[{label:`FUZZ-2.0 Pro`,value:`FUZZ-2.0 Pro`,desc:this.$t(`producer.model.fuzz20proDesc`)},{label:`FUZZ-2.0`,value:`FUZZ-2.0`,desc:this.$t(`producer.model.fuzz20desc`)},{label:`FUZZ-2.0 Raw`,value:`FUZZ-2.0 Raw`,desc:this.$t(`producer.model.fuzz20rawDesc`)},{label:`FUZZ-1.1 Pro`,value:`FUZZ-1.1 Pro`,desc:this.$t(`producer.model.fuzz11proDesc`)},{label:`FUZZ-1.1`,value:`FUZZ-1.1`,desc:this.$t(`producer.model.fuzz11desc`)},{label:`FUZZ-1.0 Pro`,value:`FUZZ-1.0 Pro`,desc:this.$t(`producer.model.fuzz10proDesc`)},{label:`FUZZ-1.0`,value:`FUZZ-1.0`,desc:this.$t(`producer.model.fuzz10desc`)},{label:`FUZZ-0.8`,value:`FUZZ-0.8`,desc:this.$t(`producer.model.fuzz08desc`)}]}},computed:{custom:{get(){return this.$store.state.producer?.config?.custom||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e})}},instrumental:{get(){return this.$store.state.producer?.config?.instrumental||!1},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,instrumental:e})}},model:{get(){return this.$store.state.producer?.config?.model},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e})}}},mounted(){this.model||=se}}),Ee={class:`mb-3`},De={class:`flex items-center mb-1`},Oe={class:`text-sm font-bold`},ke={class:`model-option`},Ae={class:`model-option-name`},je={class:`model-option-desc`},Me={key:0,class:`flex items-center justify-between mb-3`},Ne={class:`flex items-center`},Pe={class:`text-sm font-bold`};function Fe(e,r,o,u,m,h){let _=d(`el-option`),v=d(`el-select`),y=d(`info-icon`),b=d(`el-switch`);return l(),f(`div`,null,[n(`div`,Ee,[n(`div`,De,[n(`span`,Oe,c(e.$t(`producer.name.model`)),1)]),i(v,{modelValue:e.model,"onUpdate:modelValue":r[0]||=t=>e.model=t,class:`w-full model-select`,size:`default`,placeholder:e.$t(`producer.placeholder.select`)},{default:p(()=>[(l(!0),f(g,null,s(e.options,e=>(l(),t(_,{key:e.value,label:e.label,value:e.value},{default:p(()=>[n(`div`,ke,[n(`span`,Ae,c(e.label),1),n(`span`,je,c(e.desc),1)])]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])]),e.custom?(l(),f(`div`,Me,[n(`div`,Ne,[n(`span`,Pe,c(e.$t(`producer.name.instrumental`)),1),i(y,{content:e.$t(`producer.description.instrumental`)},null,8,[`content`])]),i(b,{modelValue:e.instrumental,"onUpdate:modelValue":r[1]||=t=>e.instrumental=t},null,8,[`modelValue`])])):a(``,!0)])}var Ie=V(Te,[[`render`,Fe],[`__scopeId`,`data-v-42496b9a`]]),Le=o({name:`UploadAudio`,components:{ElUpload:O,ElButton:v,ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z,FontAwesomeIcon:X},mixins:[ce],emits:[`change`],data(){return{fileList:[],uploadUrl:K()+`/api/v1/files/`,audioPreviewUrl:null,uploading:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},hasUploadedAudio(){let e=this.$store.state.producer?.config?.action;return e===`upload_extend`||e===`upload_cover`},uploadAction:{get(){return this.$store.state.producer?.config?.action||`upload_extend`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,action:e})}}},watch:{urls:{handler(e){this.$emit(`change`,e)}}},methods:{onExceed(){q.warning(this.$t(`producer.message.uploadReferencesExceed`))},onError(){this.uploading=!1,q.error(this.$t(`producer.message.uploadReferencesError`))},async onSuccess(){let e=this.urls?.[0];if(!e){this.uploading=!1;return}this.audioPreviewUrl=e,await this.onGenerateAudioId(e)},async onGenerateAudioId(e){let t={audio_url:e},n=this.credential?.token;if(!n){console.error(`no token specified`),this.uploading=!1;return}this.uploading=!0,q.info(this.$t(`producer.message.startingUploadAudio`));try{let e=(await J.upload(t,{token:n})).data?.data.audio_id;this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,audio_id:e,action:`upload_extend`}),q.success(this.$t(`producer.message.startUploadAudioSuccess`))}catch(e){q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startUploadAudioFailed`))}finally{this.uploading=!1}}}}),Re={class:`relative`},ze={class:`flex justify-between items-center mb-2`},Be={class:`flex justify-start items-center`},Ve={class:`text-sm font-bold`},He={key:0,class:`mb-2`},Ue=[`src`],We={key:1,class:`mt-1`};function Ge(e,t,o,s,u,m){let h=d(`info-icon`),g=d(`font-awesome-icon`),_=d(`el-button`),v=d(`el-upload`),y=d(`el-radio-button`),b=d(`el-radio-group`);return l(),f(`div`,Re,[n(`div`,ze,[n(`div`,Be,[n(`span`,Ve,c(e.$t(`producer.name.referenceAudios`)),1),i(h,{content:e.$t(`producer.description.uploadAudios`)},null,8,[`content`])]),i(v,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,limit:1,class:`upload-wrapper inline-upload`,action:e.uploadUrl,accept:`.mp3,.wav,.m4a,audio/*`,"show-file-list":!1,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[i(_,{round:``,type:`primary`,size:`small`,loading:e.uploading},{default:p(()=>[i(g,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),r(` `+c(e.$t(`producer.button.uploadAudios`)),1)]),_:1},8,[`loading`])]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])]),e.audioPreviewUrl?(l(),f(`div`,He,[n(`audio`,{src:e.audioPreviewUrl,controls:``,class:`w-full`},null,8,Ue)])):a(``,!0),e.hasUploadedAudio?(l(),f(`div`,We,[i(b,{modelValue:e.uploadAction,"onUpdate:modelValue":t[1]||=t=>e.uploadAction=t,size:`small`},{default:p(()=>[i(y,{value:`upload_extend`},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1}),i(y,{value:`upload_cover`},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1})]),_:1},8,[`modelValue`])])):a(``,!0)])}var Ke=V(Le,[[`render`,Ge],[`__scopeId`,`data-v-7fd0580a`]]),qe=o({name:`PromptInput`,components:{PromptTextarea:pe},computed:{prompt:{get(){return this.$store.state.producer?.config?.prompt},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Je(e,n,r,i,a,o){let s=d(`prompt-textarea`);return l(),t(s,{modelValue:e.prompt,"onUpdate:modelValue":n[0]||=t=>e.prompt=t,title:e.$t(`producer.name.songDescription`),info:e.$t(`producer.description.prompt`),placeholder:e.$t(`producer.placeholder.prompt`),"min-rows":5,"max-rows":14},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ye=V(qe,[[`render`,Je]]),Xe=o({name:`LyricInput`,components:{ElInput:U,ElButton:v,FontAwesomeIcon:X,InfoIcon:Z},data(){return{generatingLyrics:!1}},computed:{lyric:{get(){return this.$store.state.producer?.config?.lyric},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:e})}},config(){return this.$store.state.producer?.config},credential(){return this.$store.state.producer?.credential}},mounted(){this.lyric||=``},methods:{async onGenerateLyrics(){let e=this.credential?.token;if(!e)return;let t=this.config?.style||this.config?.title||`a beautiful song`;this.generatingLyrics=!0,q.info(this.$t(`producer.message.generatingLyrics`));try{let n=(await J.lyric({prompt:t},{token:e})).data?.data;n?.text&&(this.lyric=n.text,n?.title&&!this.config?.title&&this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric:n.text,title:n.title}),q.success(this.$t(`producer.message.generateLyricsSuccess`)))}catch{q.error(this.$t(`producer.message.generateLyricsFailed`))}finally{this.generatingLyrics=!1}}}}),Ze={class:`field`},Qe={class:`flex items-center justify-between mb-1`},$e={class:`flex items-center`},et={class:`text-sm font-bold`};function tt(e,o,s,u,m,h){let g=d(`info-icon`),_=d(`font-awesome-icon`),v=d(`el-button`),y=d(`el-input`);return l(),f(`div`,Ze,[n(`div`,Qe,[n(`div`,$e,[n(`span`,et,c(e.$t(`producer.name.lyrics`)),1),i(g,{content:e.$t(`producer.description.lyrics`)},null,8,[`content`])]),e.config?.action===`extend`?a(``,!0):(l(),t(v,{key:0,size:`small`,loading:e.generatingLyrics,round:``,onClick:e.onGenerateLyrics},{default:p(()=>[e.generatingLyrics?a(``,!0):(l(),t(_,{key:0,icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`})),r(` `+c(e.$t(`producer.button.generate_lyrics`)),1)]),_:1},8,[`loading`,`onClick`]))]),e.config?.action===`extend`?(l(),t(y,{key:1,modelValue:e.lyric,"onUpdate:modelValue":o[1]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.extend.lyrics`)},null,8,[`modelValue`,`placeholder`])):(l(),t(y,{key:0,modelValue:e.lyric,"onUpdate:modelValue":o[0]||=t=>e.lyric=t,rows:5,type:`textarea`,class:`lyrics`,placeholder:e.$t(`producer.placeholder.lyrics`)},null,8,[`modelValue`,`placeholder`]))])}var nt=V(Xe,[[`render`,tt],[`__scopeId`,`data-v-88c6da2b`]]),rt=o({name:`StyleInput`,components:{ElInput:U,InfoIcon:Z},computed:{style:{get(){return this.$store.state.producer?.config?.style},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style:e})}}}}),it={class:`field`},at={class:`flex items-center justify-between mb-1`},ot={class:`flex items-center`},st={class:`text-sm font-bold`};function ct(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,it,[n(`div`,at,[n(`div`,ot,[n(`span`,st,c(e.$t(`producer.name.style`)),1),i(u,{content:e.$t(`producer.description.style`)},null,8,[`content`])])]),i(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||=t=>e.style=t,rows:2,type:`textarea`,placeholder:e.$t(`producer.placeholder.style`)},null,8,[`modelValue`,`placeholder`])])}var lt=V(rt,[[`render`,ct]]),ut=o({name:`TitleInput`,components:{ElInput:U,InfoIcon:Z},computed:{title:{get(){return this.$store.state.producer?.config?.title},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,title:e})}}}}),dt={class:`field`},ft={class:`flex items-center mb-1`},pt={class:`text-sm font-bold`};function mt(e,t,r,a,o,s){let u=d(`info-icon`),p=d(`el-input`);return l(),f(`div`,dt,[n(`div`,ft,[n(`span`,pt,c(e.$t(`producer.name.title`)),1),i(u,{content:e.$t(`producer.description.title`)},null,8,[`content`])]),i(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||=t=>e.title=t,placeholder:e.$t(`producer.placeholder.title`)},null,8,[`modelValue`,`placeholder`])])}var ht=V(ut,[[`render`,mt]]),gt=o({name:`ExtendFromInput`,components:{ElImage:A,ElIcon:S,ElInputNumber:L,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),_t={class:`field`},vt={class:`box`},yt={class:`title font-bold`},bt={class:`input-wrapper`},xt={class:`task`},St={class:`left`},Ct={key:2,class:`duration`},wt={class:`info`},Tt={class:`title`},Et={class:`style`};function Dt(e,t,r,o,s,u){let g=d(`el-input-number`),_=d(`el-image`),v=d(`video-pause`),y=d(`el-icon`),b=d(`video-play`),x=m(`loading`);return l(),f(`div`,_t,[n(`div`,vt,[n(`h2`,yt,c(e.$t(`producer.name.extend`)),1),n(`div`,bt,[i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.extend.continue_at`),onChange:e.handleChange},null,8,[`modelValue`,`max`,`placeholder`,`onChange`])])]),n(`div`,xt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[3]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,St,[i(_,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[1]||=t=>e.onPause(e.audio)},[i(y,null,{default:p(()=>[i(v)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[2]||=t=>e.onPlay(e.audio)},[i(y,null,{default:p(()=>[i(b)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ct,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[x,!e.audio?.audio_url]]),n(`div`,wt,[n(`h2`,Tt,c(e.audio?.title),1),n(`p`,Et,c(e.audio?.style),1)])])):a(``,!0)])])}var Ot=V(gt,[[`render`,Dt],[`__scopeId`,`data-v-26d43480`]]),kt=o({name:`CoverFromInput`,components:{ElImage:A,ElIcon:S,VideoPlay:b,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.producer?.config?.audio},value:{get(){return this.$store.state.producer?.config?.continue_at},set(e){console.debug(`set continue_at`,e),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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:Q,onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),At={class:`field`},jt={class:`box`},Mt={class:`title font-bold`},Nt={class:`task`},Pt={class:`left`},Ft={key:2,class:`duration`},It={class:`info`},Lt={class:`title`},Rt={class:`style`};function zt(e,t,r,o,s,u){let g=d(`el-image`),_=d(`video-pause`),v=d(`el-icon`),y=d(`video-play`),b=m(`loading`);return l(),f(`div`,At,[n(`div`,jt,[n(`h2`,Mt,c(e.$t(`producer.name.cover`)),1)]),n(`div`,Nt,[e.audio?(l(),f(`div`,{key:0,class:`audio`,onClick:t[2]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,Pt,[i(g,{src:e.audio?.image_url,class:`cover`,fit:`cover`},null,8,[`src`]),e.audio?.audio_url&&e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:t[0]||=t=>e.onPause(e.audio)},[i(v,null,{default:p(()=>[i(_)]),_:1})])):a(``,!0),e.audio?.audio_url&&(e.$store.state?.producer?.audio?.id!==e.audio.id||e.$store.state?.producer?.audio?.id===e.audio.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:t[1]||=t=>e.onPlay(e.audio)},[i(v,null,{default:p(()=>[i(y)]),_:1})])):a(``,!0),e.audio?.duration?(l(),f(`div`,Ft,c(e.useFormatDuring(e.audio?.duration)),1)):a(``,!0)])),[[b,!e.audio?.audio_url]]),n(`div`,It,[n(`h2`,Lt,c(e.audio?.title),1),n(`p`,Rt,c(e.audio?.style),1)])])):a(``,!0)])])}var Bt=V(kt,[[`render`,zt],[`__scopeId`,`data-v-d8a8e583`]]),Vt=o({name:`VocalGenderSelector`,components:{ElRadioGroup:N,ElRadioButton:M,InfoIcon:Z},computed:{vocalGender:{get(){return this.$store.state.producer?.config?.vocal_gender||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,vocal_gender:e||void 0})}}}}),Ht={class:`mb-2`},Ut={class:`flex items-center mb-1`},Wt={class:`text-sm font-bold`};function Gt(e,t,a,o,s,u){let m=d(`info-icon`),h=d(`el-radio-button`),g=d(`el-radio-group`);return l(),f(`div`,Ht,[n(`div`,Ut,[n(`span`,Wt,c(e.$t(`producer.name.vocalGender`)),1),i(m,{content:e.$t(`producer.description.vocalGender`)},null,8,[`content`])]),i(g,{modelValue:e.vocalGender,"onUpdate:modelValue":t[0]||=t=>e.vocalGender=t},{default:p(()=>[i(h,{value:``},{default:p(()=>[r(c(e.$t(`producer.gender.auto`)),1)]),_:1}),i(h,{value:`f`},{default:p(()=>[r(c(e.$t(`producer.gender.female`)),1)]),_:1}),i(h,{value:`m`},{default:p(()=>[r(c(e.$t(`producer.gender.male`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var Kt=V(Vt,[[`render`,Gt]]),qt=o({name:`AdvancedParams`,components:{ElCollapse:P,ElCollapseItem:ee,ElInput:U,ElSlider:ae,ElInputNumber:L,InfoIcon:Z},data(){return{activeNames:[]}},computed:{config(){return this.$store.state.producer?.config},styleNegative:{get(){return this.$store.state.producer?.config?.style_negative||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,style_negative:e||void 0})}},lyricPrompt:{get(){return this.$store.state.producer?.config?.lyric_prompt||``},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyric_prompt:e||void 0})}},weirdness:{get(){return this.$store.state.producer?.config?.weirdness??.5},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,weirdness:e})}},soundStrength:{get(){return this.$store.state.producer?.config?.sound_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,sound_strength:e})}},lyricsStrength:{get(){return this.$store.state.producer?.config?.lyrics_strength??.7},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,lyrics_strength:e})}},seed:{get(){return this.$store.state.producer?.config?.seed},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,seed:e})}}},mounted(){let e=this.$store.state.producer?.config;if(!e)return;let t={};typeof e.weirdness==`number`&&e.weirdness>1&&(t.weirdness=e.weirdness/100),typeof e.sound_strength==`number`&&e.sound_strength>1&&(t.sound_strength=e.sound_strength/100),typeof e.lyrics_strength==`number`&&e.lyrics_strength>1&&(t.lyrics_strength=e.lyrics_strength/100),Object.keys(t).length>0&&this.$store.commit(`producer/setConfig`,{...e,...t})}}),Jt={key:0,class:`mb-3`},Yt={class:`flex items-center mb-1`},Xt={class:`text-xs font-bold`},Zt={key:1,class:`mb-3`},Qt={class:`flex items-center mb-1`},$t={class:`text-xs font-bold`},en={class:`mb-3`},tn={class:`flex items-center justify-between mb-1`},nn={class:`flex items-center`},rn={class:`text-xs font-bold`},an={class:`text-xs text-[var(--el-text-color-secondary)]`},on={class:`mb-3`},sn={class:`flex items-center justify-between mb-1`},cn={class:`flex items-center`},ln={class:`text-xs font-bold`},un={class:`text-xs text-[var(--el-text-color-secondary)]`},dn={key:2,class:`mb-3`},fn={class:`flex items-center justify-between mb-1`},pn={class:`flex items-center`},mn={class:`text-xs font-bold`},hn={class:`text-xs text-[var(--el-text-color-secondary)]`},gn={class:`mb-3`},_n={class:`flex items-center mb-1`},vn={class:`text-xs font-bold`};function yn(e,r,o,s,u,m){let h=d(`info-icon`),g=d(`el-input`),_=d(`el-slider`),v=d(`el-input-number`),y=d(`el-collapse-item`),b=d(`el-collapse`);return l(),t(b,{modelValue:e.activeNames,"onUpdate:modelValue":r[6]||=t=>e.activeNames=t,class:`advanced-collapse`},{default:p(()=>[i(y,{title:e.$t(`producer.name.advancedParams`),name:`advanced`},{default:p(()=>[e.config?.custom?(l(),f(`div`,Jt,[n(`div`,Yt,[n(`span`,Xt,c(e.$t(`producer.name.styleNegative`)),1),i(h,{content:e.$t(`producer.description.styleNegative`)},null,8,[`content`])]),i(g,{modelValue:e.styleNegative,"onUpdate:modelValue":r[0]||=t=>e.styleNegative=t,size:`small`,placeholder:e.$t(`producer.placeholder.styleNegative`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,Zt,[n(`div`,Qt,[n(`span`,$t,c(e.$t(`producer.name.lyricPrompt`)),1),i(h,{content:e.$t(`producer.description.lyricPrompt`)},null,8,[`content`])]),i(g,{modelValue:e.lyricPrompt,"onUpdate:modelValue":r[1]||=t=>e.lyricPrompt=t,size:`small`,placeholder:e.$t(`producer.placeholder.lyricPrompt`)},null,8,[`modelValue`,`placeholder`])])):a(``,!0),n(`div`,en,[n(`div`,tn,[n(`div`,nn,[n(`span`,rn,c(e.$t(`producer.name.weirdness`)),1),i(h,{content:e.$t(`producer.description.weirdness`)},null,8,[`content`])]),n(`span`,an,c(e.weirdness??.5),1)]),i(_,{modelValue:e.weirdness,"onUpdate:modelValue":r[2]||=t=>e.weirdness=t,min:0,max:1,step:.01},null,8,[`modelValue`])]),n(`div`,on,[n(`div`,sn,[n(`div`,cn,[n(`span`,ln,c(e.$t(`producer.name.soundStrength`)),1),i(h,{content:e.$t(`producer.description.soundStrength`)},null,8,[`content`])]),n(`span`,un,c(e.soundStrength??.7),1)]),i(_,{modelValue:e.soundStrength,"onUpdate:modelValue":r[3]||=t=>e.soundStrength=t,min:.2,max:1,step:.01},null,8,[`modelValue`])]),e.config?.custom&&!e.config?.instrumental?(l(),f(`div`,dn,[n(`div`,fn,[n(`div`,pn,[n(`span`,mn,c(e.$t(`producer.name.lyricsStrength`)),1),i(h,{content:e.$t(`producer.description.lyricsStrength`)},null,8,[`content`])]),n(`span`,hn,c(e.lyricsStrength??.7),1)]),i(_,{modelValue:e.lyricsStrength,"onUpdate:modelValue":r[4]||=t=>e.lyricsStrength=t,min:0,max:1,step:.01},null,8,[`modelValue`])])):a(``,!0),n(`div`,gn,[n(`div`,_n,[n(`span`,vn,c(e.$t(`producer.name.seed`)),1),i(h,{content:e.$t(`producer.description.seed`)},null,8,[`content`])]),i(v,{modelValue:e.seed,"onUpdate:modelValue":r[5]||=t=>e.seed=t,min:0,controls:!1,size:`small`,placeholder:e.$t(`producer.placeholder.seed`),class:`w-full`},null,8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var bn=V(qt,[[`render`,yn],[`__scopeId`,`data-v-f9296888`]]),xn=o({name:`ReplaceSectionInput`,components:{ElInputNumber:L,ElImage:A,InfoIcon:Z},computed:{audio(){return this.$store.state.producer?.config?.audio},replaceSectionStart:{get(){return this.$store.state.producer?.config?.replace_section_start},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_start:e})}},replaceSectionEnd:{get(){return this.$store.state.producer?.config?.replace_section_end},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,replace_section_end:e})}}},methods:{onClick(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`})}}}),Sn={class:`field`},Cn={class:`flex items-center mb-2`},wn={class:`text-sm font-bold m-0`},Tn={key:0,class:`task mb-2`},En={class:`left relative w-[50px] h-[50px] mr-3 flex-shrink-0`},Dn={class:`info flex-1 min-w-0`},On={class:`text-sm font-bold m-0 truncate`},kn={class:`text-xs text-[var(--el-text-color-secondary)] m-0 truncate`},An={class:`flex gap-2`};function jn(e,t,r,o,s,u){let p=d(`info-icon`),g=d(`el-image`),_=d(`el-input-number`),v=m(`loading`);return l(),f(`div`,Sn,[n(`div`,Cn,[n(`h2`,wn,c(e.$t(`producer.name.replaceSection`)),1),i(p,{content:e.$t(`producer.description.replaceSection`)},null,8,[`content`])]),e.audio?(l(),f(`div`,Tn,[n(`div`,{class:`audio flex items-center`,onClick:t[0]||=t=>e.onClick(e.audio)},[h((l(),f(`div`,En,[i(g,{src:e.audio?.image_url,class:`w-full h-full rounded`,fit:`cover`},null,8,[`src`])])),[[v,!e.audio?.audio_url]]),n(`div`,Dn,[n(`h2`,On,c(e.audio?.title),1),n(`p`,kn,c(e.audio?.style),1)])])])):a(``,!0),n(`div`,An,[i(_,{modelValue:e.replaceSectionStart,"onUpdate:modelValue":t[1]||=t=>e.replaceSectionStart=t,class:`flex-1`,min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionStart`)},null,8,[`modelValue`,`max`,`placeholder`]),i(_,{modelValue:e.replaceSectionEnd,"onUpdate:modelValue":t[2]||=t=>e.replaceSectionEnd=t,class:`flex-1`,min:e.replaceSectionStart||0,max:e.audio?.duration,controls:!1,placeholder:e.$t(`producer.placeholder.replaceSectionEnd`)},null,8,[`modelValue`,`min`,`max`,`placeholder`])])])}var Mn=o({name:`PresetPanel`,components:{TypeSelector:Ie,PromptInput:Ye,LyricInput:nt,StyleInput:lt,TitleInput:ht,ExtendFromInput:Ot,CoverFromInput:Bt,UploadAudio:Ke,VocalGenderSelector:Kt,AdvancedParams:bn,ReplaceSectionInput:V(xn,[[`render`,jn]]),FontAwesomeIcon:X,ElButton:v,ElTabs:E,ElTabPane:D,Consumption:he},emits:[`generate`],computed:{config(){return this.$store.state.producer?.config},mode:{get(){return this.$store.state.producer?.config?.custom?`custom`:`simple`},set(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,custom:e===`custom`})}},consumption(){return W(this.config,this.service?.cost)},service(){return this.$store.state.producer?.service},generateButtonText(){let e=this.config?.action;return e===`extend`||e===`upload_extend`?this.$t(`producer.button.extend`):e===`cover`||e===`upload_cover`?this.$t(`producer.button.cover_music`):e===`variation`?this.$t(`producer.button.variation`):e===`replace_section`?this.$t(`producer.button.replace_section`):e===`stems`?this.$t(`producer.button.get_stems`):e===`swap_vocals`?this.$t(`producer.button.swap_vocals`):e===`swap_instrumentals`?this.$t(`producer.button.swap_instrumentals`):this.$t(`producer.button.generate`)}},methods:{onGenerate(){this.$emit(`generate`)},onClearAll(){this.$store.commit(`producer/setConfig`,{custom:this.$store.state.producer?.config?.custom||!1,instrumental:!1,prompt:``,lyric:``,style:``,title:``,model:this.$store.state.producer?.config?.model})}}}),Nn={class:`flex flex-col h-full`},Pn={class:`flex-1 overflow-y-auto p-5`},Fn={class:`pt-2 px-1`},In={class:`pt-2 px-1`},Ln={class:`flex flex-col items-center justify-center px-5 pb-5 gap-2`},Rn={class:`flex gap-2 w-full`};function zn(e,o,s,u,m,h){let g=d(`type-selector`),_=d(`upload-audio`),v=d(`prompt-input`),y=d(`extend-from-input`),b=d(`cover-from-input`),x=d(`replace-section-input`),S=d(`advanced-params`),C=d(`el-tab-pane`),w=d(`lyric-input`),T=d(`style-input`),E=d(`title-input`),D=d(`vocal-gender-selector`),O=d(`el-tabs`),k=d(`consumption`),A=d(`font-awesome-icon`),j=d(`el-button`);return l(),f(`div`,Nn,[n(`div`,Pn,[i(O,{modelValue:e.mode,"onUpdate:modelValue":o[0]||=t=>e.mode=t,class:`producer-mode-tabs`,stretch:``},{default:p(()=>[i(C,{label:e.$t(`producer.mode.simple`),name:`simple`},{default:p(()=>[n(`div`,Fn,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),i(v,{class:`mb-4`}),e.config?.action===`extend`?(l(),t(y,{key:0,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:1,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:2,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`]),i(C,{label:e.$t(`producer.mode.custom`),name:`custom`},{default:p(()=>[n(`div`,In,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(w,{key:0,class:`mb-4`})),i(T,{class:`mb-4`}),i(E,{class:`mb-4`}),e.config?.instrumental?a(``,!0):(l(),t(D,{key:1,class:`mb-4`})),e.config?.action===`extend`?(l(),t(y,{key:2,class:`mb-4`})):a(``,!0),e.config?.action===`cover`?(l(),t(b,{key:3,class:`mb-4`})):a(``,!0),e.config?.action===`replace_section`?(l(),t(x,{key:4,class:`mb-4`})):a(``,!0),i(S,{class:`mb-4`})])]),_:1},8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,Ln,[i(k,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),n(`div`,Rn,[i(j,{class:`flex-1`,onClick:e.onClearAll},{default:p(()=>[i(A,{icon:`fa-solid fa-broom`,class:`mr-1`}),r(` `+c(e.$t(`producer.button.clear_all`)),1)]),_:1},8,[`onClick`]),i(j,{type:`primary`,class:`flex-1`,round:``,onClick:e.onGenerate},{default:p(()=>[i(A,{icon:`fa-solid fa-magic`,class:`mr-2`}),r(` `+c(e.generateButtonText),1)]),_:1},8,[`onClick`])])])])}var Bn=V(Mn,[[`render`,zn],[`__scopeId`,`data-v-4a4b209e`]]),Vn=ge(),Hn=R(`producer`),Un=o({name:`TaskPreview`,components:{ElImage:A,ElIcon:S,ElTooltip:k,FontAwesomeIcon:X,VideoPlay:b,VideoPause:x,ElDropdown:ne,ElDropdownMenu:te,ElDropdownItem:I,Loading:y,ApiCodeDialog:de},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1,isFetchingWav:!1,apiCodeVisible:!1,apiCodePath:`/producer/audios`,apiCodeBody:{}}},computed:{loading(){return this.$store.state.producer?.status?.getApplications===Y.Request},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},task(){return this.$store.state.producer?.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.producer?.application},active(){return this.$store.state.producer?.tasks?.active}},methods:{useFormatDuring:Q,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=`/producer/audios`,this.apiCodeVisible=!0},onPlay(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`playing`}),console.log(`on play`)},onPause(e){this.$store.dispatch(`producer/setAudio`,{...this.$store.state.producer.audio,...e,state:`paused`}),console.log(`on pause`)},onClick(e){this.$store.state?.producer?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e?.stopPropagation(),console.debug(`set config`,t),this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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();let n=new URL(t).pathname,r=n.substring(n.lastIndexOf(`/`)+1);fetch(t).then(e=>e.blob()).then(e=>{(0,Vn.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),q.error(this.$t(`producer.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}J.video(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(),window.open(t,`_blank`)},async onGetStems(e){await this.onGenerateAudioUrl(`stems`,e)},onCover(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:`cover`,audio:e,audio_id:e.id})},onVariation(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.config,model:e.model,custom:!0,style:e.style,action:`variation`,audio:e,audio_id:e.id})},async onSwapVocals(e){await this.onGenerateAudioUrl(`swap_vocals`,e)},async onSwapInstrumentals(e){await this.onGenerateAudioUrl(`swap_instrumentals`,e)},async onGetAllStems(e){await this.onGenerateAudioUrl(`all_stems`,e)},onReplaceSection(e){this.$store.commit(`producer/setConfig`,{...this.$store.state.producer?.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)})},async handleWavDownload(e){if(!e?.id||this.isFetchingWav)return;let t=this.credential?.token;if(t)try{this.isFetchingWav=!0,q.info(this.$t(`producer.message.fetchingWav`));let n=(await J.wav({audio_id:e.id},{token:t})).data?.data,r=Array.isArray(n)?n[0]?.file_url:n?.file_url||n?.audio_url;r?this.onDownload(null,r):q.error(this.$t(`producer.message.fetchWavFailed`))}catch{q.error(this.$t(`producer.message.fetchWavFailed`))}finally{this.isFetchingWav=!1}},async onGenerateAudioUrl(e,t){let n={action:e,audio_id:t,callback_url:Hn},r=this.credential?.token;if(!r){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),J.audio(n,{token:r}).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{let e=document.querySelector(`.tasks`);e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug(`loading`);return}await this.$store.dispatch(`producer/getTasks`,{limit:30,offset:0})}}}),Wn={class:`task`},Gn=[`onClick`],Kn={class:`left`},qn=[`onClick`],Jn=[`onClick`],Yn={key:2,class:`duration`},Xn={class:`info`},Zn={class:`title`},Qn={class:`style`},$n={class:`right`},er={class:`el-dropdown-link`},tr={class:`flex items-center min-w-[120px]`},nr={class:`flex items-center min-w-[120px]`},rr={class:`el-dropdown-link`};function ir(e,o,u,v,y,b){let x=d(`el-image`),S=d(`video-pause`),C=d(`el-icon`),w=d(`video-play`),T=d(`font-awesome-icon`),E=d(`el-tooltip`),D=d(`Loading`),O=d(`el-dropdown-item`),k=d(`el-dropdown-menu`),A=d(`el-dropdown`),j=d(`api-code-dialog`),M=m(`loading`);return l(),f(`div`,Wn,[(l(!0),f(g,null,s(e.audios,o=>(l(),f(`div`,{key:o.id,class:`audio`,onClick:_(t=>e.onClick(o),[`stop`])},[h((l(),f(`div`,Kn,[i(x,{src:o?.image_url,class:`cover`,fit:`cover`,lazy:``},null,8,[`src`]),o?.audio_url&&e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`playing`?(l(),f(`div`,{key:0,class:`overlay`,onClick:_(t=>e.onPause(o),[`stop`])},[i(C,null,{default:p(()=>[i(S)]),_:1})],8,qn)):a(``,!0),o?.audio_url&&(e.$store.state?.producer?.audio?.id!==o.id||e.$store.state?.producer?.audio?.id===o.id&&e.$store.state?.producer?.audio?.state===`paused`)?(l(),f(`div`,{key:1,class:`overlay`,onClick:_(t=>e.onPlay(o),[`stop`])},[i(C,null,{default:p(()=>[i(w)]),_:1})],8,Jn)):a(``,!0),o?.duration?(l(),f(`div`,Yn,c(e.useFormatDuring(o?.duration)),1)):a(``,!0)])),[[M,!o?.audio_url]]),n(`div`,Xn,[n(`h2`,Zn,c(o?.title),1),n(`p`,Qn,c(o?.style),1)]),n(`div`,$n,[i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[i(O,{disabled:e.isFetchingVideoUrl,onClick:t=>e.handleVideoDownload(o)},{default:p(()=>[n(`div`,tr,[e.isFetchingVideoUrl?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_video`)),1)])]),_:1},8,[`disabled`,`onClick`]),o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onDownload(t,o?.audio_url),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.download_audio`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{disabled:e.isFetchingWav,onClick:t=>e.handleWavDownload(o)},{default:p(()=>[n(`div`,nr,[e.isFetchingWav?(l(),t(C,{key:0,class:`is-loading mr-2`},{default:p(()=>[i(D)]),_:1})):a(``,!0),n(`span`,null,c(e.$t(`producer.button.download_wav`)),1)])]),_:1},8,[`disabled`,`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,er,[i(E,{effect:`dark`,content:e.$t(`producer.button.download`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-download`,class:`icon icon-download`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024),i(A,null,{dropdown:p(()=>[i(k,null,{default:p(()=>[o?.audio_url?(l(),t(O,{key:0,onClick:_(t=>e.onExtend(t,o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.extend`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:1,onClick:_(t=>e.onGetStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.get_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),o.id?(l(),t(O,{key:2,onClick:_(t=>e.onGetAllStems(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.all_stems`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(t=>e.onCover(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.cover_music`)),1)]),_:1},8,[`onClick`]),o?.id?(l(),t(O,{key:3,onClick:_(t=>e.onVariation(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.variation`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:4,onClick:_(t=>e.onSwapVocals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_vocals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:5,onClick:_(t=>e.onSwapInstrumentals(o.id),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.swap_instrumentals`)),1)]),_:1},8,[`onClick`])):a(``,!0),o?.id?(l(),t(O,{key:6,onClick:_(t=>e.onReplaceSection(o),[`stop`])},{default:p(()=>[r(c(e.$t(`producer.button.replace_section`)),1)]),_:1},8,[`onClick`])):a(``,!0),i(O,{onClick:_(e.onViewCode,[`stop`])},{default:p(()=>[i(T,{icon:`fa-solid fa-code`,class:`mr-1`}),r(` `+c(e.$t(`common.button.viewCode`)),1)]),_:1},8,[`onClick`])]),_:2},1024)]),default:p(()=>[n(`span`,rr,[i(E,{effect:`dark`,content:e.$t(`producer.button.more`),placement:`top`},{default:p(()=>[o?.audio_url||o?.video_url?(l(),t(T,{key:0,icon:`fa-solid fa-ellipsis`,class:`icon icon-ellipsis`})):a(``,!0)]),_:2},1032,[`content`])])]),_:2},1024)])],8,Gn))),128)),i(j,{visible:e.apiCodeVisible,"onUpdate:visible":o[0]||=t=>e.apiCodeVisible=t,method:`POST`,path:e.apiCodePath,body:e.apiCodeBody,token:e.$store.state.producer?.credential?.token||``},null,8,[`visible`,`path`,`body`,`token`])])}var ar=o({name:`RecentPanel`,components:{ElSkeletonItem:re,ElSkeleton:ie,TaskPreview:V(Un,[[`render`,ir]]),Player:_e,NoTasks:me,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.producer?.tasks,items:this.$store.state.producer?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),or={key:0,class:`tasks`},sr={class:`left w-[70px] p-[10px] flex items-center`},$={class:`main w-[calc(100%-70px)] flex-1 p-[10px]`},cr={key:2,class:`w-full flex-1 flex items-center justify-center`},lr={class:`h-20`};function ur(e,r,o,c,m,_){let v=d(`el-skeleton-item`),y=d(`el-skeleton`),b=d(`task-preview`),x=d(`scroll-list`),S=d(`no-tasks`),C=d(`player`);return l(),f(g,null,[e.tasks?.items===void 0?(l(),f(`div`,or,[(l(),f(g,null,s(3,e=>n(`div`,{key:e,class:`flex`},[n(`div`,sr,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`image`,class:`avatar w-[50px] h-[50px]`})]),_:1})]),n(`div`,$,[i(y,{animated:``},{template:p(()=>[i(v,{variant:`p`,class:`w-[200px] h-[15px] mb-[5px] mt-[10px]`}),i(v,{variant:`text`})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(l(),t(x,{key:1,ref:`scrollList`,class:`flex-1 w-full overflow-y-auto tasks p-2`,loading:e.loading,onReachTop:r[0]||=t=>e.$emit(`reach-top`)},{default:p(()=>[(l(!0),f(g,null,s(e.tasks?.items,(e,n)=>(l(),t(b,{key:n,"model-value":e,class:`preview`},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):a(``,!0),e.tasks?.items?.length===0?(l(),f(`div`,cr,[i(S)])):a(``,!0),h(n(`div`,lr,[i(C,{namespace:`producer`})],512),[[u,!!e.$store?.state?.producer?.audio?.object]])],64)}var dr=V(ar,[[`render`,ur]]),fr=o({name:`TaskPreview`,components:{IconPicture:C,ElImage:A,ElAvatar:j,ElIcon:S},computed:{audio(){return this.$store.state.producer?.audio}}}),pr={key:0,class:`size-full overflow-hidden`},mr={class:`relative h-[300px]`},hr={class:`flex items-center justify-center size-full bg-[var(--el-bg-color)]`},gr={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`},_r={class:`p-4`},vr={class:`flex items-center font-bold mb-2`},yr={class:`text-[var(--el-text-color-regular)] mb-2`},br={class:`text-xs text-[var(--el-text-color-regular)]`},xr={class:`mt-4 text-sm leading-[25px] whitespace-pre-wrap`},Sr={key:1,class:`w-full h-full`};function Cr(e,t,r,a,o,s){let u=d(`icon-picture`),m=d(`el-icon`),h=d(`el-image`),g=d(`el-avatar`);return e.audio?.object?(l(),f(`div`,pr,[n(`div`,mr,[i(h,{src:e.audio.image_url,fit:`cover`,class:`size-full`},{error:p(()=>[n(`div`,hr,[i(m,{class:`text-3xl`},{default:p(()=>[i(u)]),_:1})])]),_:1},8,[`src`]),n(`h2`,gr,c(e.audio?.title),1)]),n(`div`,_r,[n(`div`,vr,[i(g,{size:30,src:e.audio?.image_url,class:`mr-2`},null,8,[`src`]),n(`span`,null,c(e.audio?.title),1)]),n(`p`,yr,c(e.audio?.style),1),n(`p`,br,c(e.$dayjs.format(e.audio?.created_at)),1),n(`div`,xr,[n(`p`,null,c(e.audio?.lyric),1)])])])):(l(),f(`div`,Sr))}var wr=V(fr,[[`render`,Cr]]),Tr=R(`producer`),Er=o({name:`ProducerIndex`,components:{Layout:we,ConfigPanel:Bn,RecentPanel:dr,PreviewPanel:wr},mixins:[B],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.producer?.status?.getApplications===Y.Request},tasksLoading(){return this.$store.state.producer?.status?.getTasks===Y.Request||this.fetchingTasks},service(){return this.$store.state.producer.service},credential(){return this.$store.state.producer.credential},config(){return this.$store.state.producer.config},initializing(){return this.$store.state.producer.status.getApplications===Y.Request},needApply(){return this.$store.state.producer.status.getApplications===Y.Success&&!this.application},application(){return this.$store.state.producer.application},tasks(){return this.$store.state.producer.tasks},applications(){return this.$store.state.producer.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 fe({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(`producer/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplications`),await this.$store.dispatch(`producer/getApplications`),console.debug(`end onGetApplications`),await this.onGetTasks()},onApply(){z.create({application:this.application}).then(({data:e})=>{this.application=e,q.success(this.$t(`application.message.applySuccessfully`))}).catch(e=>{e?.response?.data?.code===`duplication`&&q.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(`producer/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){if(!G(this.uploadTracker,e=>this.$t(e),e=>q.warning(e)))return;let e={...this.config,callback_url:Tr},t=this.credential?.token;if(!t){console.error(`no token specified`);return}q.info(this.$t(`producer.message.startingTask`)),H(`producer`,J.audio(e,{token:t})).then(()=>{q.success(this.$t(`producer.message.startTaskSuccess`))}).catch(e=>{q.error(e?.response?.data?.error?.message||this.$t(`producer.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Dr(e,n,r,a,o,s){let c=d(`config-panel`),u=d(`recent-panel`),f=d(`preview-panel`),m=d(`layout`);return l(),t(m,null,{config:p(()=>[i(c,{onGenerate:e.onGenerateAudio},null,8,[`onGenerate`])]),result:p(()=>[i(u,{ref:`recentPanel`,class:`panel recent`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),preview:p(()=>[i(f)]),_:1})}var Or=V(Er,[[`render`,Dr],[`__scopeId`,`data-v-a766e27a`]]);export{Or 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,Ut as o,X as s,et as c,k as l,lt as u,tt as d,ut as f}from"./vendor-chart-mdwpew_o.js";import{t as p}from"./button-DWzbdjZV.js";import{n as m,t as h}from"./row-UUMjQQpA.js";import{i as g,n as _,r as v,t as y}from"./container-DUnSq7iO.js";import{n as b,t as x}from"./dropdown-CPemIUgw.js";import{a as S,i as C,n as w,r as T,t as E}from"./avatar-CJaAkR4u.js";import{Bt as D,D as O,Dr as k,E as A,K as j,O as M,rt as N,xr as P,z as F}from"./index-CZaid7Ez.js";import{t as I}from"./BottomFooter-CEzUsQct.js";var L=a({name:`TopHeader`,components:{ElCol:m,Logo:w,ElRow:h,ElDropdown:x,ElMenu:T,ElMenuItem:C,ElDropdownItem:b,ElButton:p,ElSubMenu:S},data(){return{defaultAvatar:E,products:`chat`}},computed:{site(){return this.$store.state?.site},dark(){return this.$store.getters?.dark},active(){return this.$route.matched?.[0]?.path},user(){return this.$store.getters?.user},authenticated(){return this.$store.getters?.authenticated}},methods:{openTab(e){if(k()){O.open({url:e}).catch(t=>{console.warn(`Browser.open failed, falling back to window.open`,t),window.open(e,`_blank`)});return}window.open(e,`_blank`)},onSelect(e){e&&this.$router.push(e)},onHome(){this.$router.push({name:N})},onLogin(){this.$router.push({name:M})},onDownload(){this.$router.push({name:j})},onProfile(){let e=P();this.openTab(D(`${e}/user/profile`))},onVerify(){let e=P();this.openTab(D(`${e}/user/verify`))},onConsole(){this.$router.push({name:F})},async onLogout(){this.$store.dispatch(`logout`)}}}),R={key:0,class:`mt-4 pr-10`},z={key:1,class:`float-right`},B=[`src`];function V(a,p,m,h,g,_){let v=c(`logo`),y=c(`el-col`),b=c(`el-menu-item`),x=c(`el-sub-menu`),S=c(`el-menu`),C=c(`el-button`),w=c(`language-selector`),T=c(`dark-selector`),E=c(`el-dropdown-item`),D=c(`el-dropdown-menu`),O=c(`el-dropdown`),k=c(`el-row`),A=d(`t`);return s(),e(k,{class:`header`},{default:u(()=>[r(y,{md:4,xs:24,class:`brand-col`},{default:u(()=>[r(v,{onClick:a.onHome},null,8,[`onClick`])]),_:1}),r(y,{md:16,xs:13},{default:u(()=>[r(S,{"default-active":a.active,mode:`horizontal`,class:`menu`,ellipsis:!0,onSelect:a.onSelect},{default:u(()=>[r(x,{index:a.products},{title:u(()=>[n(o(a.$t(`common.nav.products`)),1)]),default:u(()=>[a.site?.features?.chatgpt?.enabled?f((s(),e(b,{key:0,index:`/chat`},null,512)),[[A,`index.title.chat`]]):i(``,!0),a.site?.features?.midjourney?.enabled?f((s(),e(b,{key:1,index:`/midjourney`},null,512)),[[A,`index.title.midjourney`]]):i(``,!0),a.site?.features?.qrart?.enabled?f((s(),e(b,{key:2,index:`/qrart`},null,512)),[[A,`index.title.qrart`]]):i(``,!0),a.site?.features?.suno?.enabled?f((s(),e(b,{key:3,index:`/suno`},null,512)),[[A,`index.title.suno`]]):i(``,!0),a.site?.features?.luma?.enabled?f((s(),e(b,{key:4,index:`/luma`},null,512)),[[A,`index.title.luma`]]):i(``,!0),a.site?.features?.headshots?.enabled?f((s(),e(b,{key:5,index:`/headshots`},null,512)),[[A,`index.title.headshots`]]):i(``,!0)]),_:1},8,[`index`]),f(r(b,{onRoute:e=>void 0,onClick:a.onDownload},null,8,[`onClick`]),[[A,`common.nav.mobileApp`]]),f(r(b,{onRoute:e=>void 0,onClick:p[0]||=e=>a.openTab(`https://platform.acedata.cloud`)},null,512),[[A,`common.nav.apiPlatform`]]),f(r(b,{onRoute:e=>void 0,onClick:p[1]||=e=>a.openTab(`https://platform.acedata.cloud/support`)},null,512),[[A,`common.nav.support`]]),f(r(b,{onRoute:e=>void 0,onClick:p[2]||=e=>a.openTab(`https://platform.acedata.cloud/earning`)},null,512),[[A,`common.nav.referral`]])]),_:1},8,[`default-active`,`onSelect`])]),_:1}),r(y,{md:4,xs:11},{default:u(()=>[a.authenticated?(s(),l(`div`,z,[t(`div`,{class:`console`,onClick:p[3]||=(...e)=>a.onConsole&&a.onConsole(...e)},o(a.$t(`common.button.console`)),1),r(O,{trigger:`click`},{dropdown:u(()=>[r(D,null,{default:u(()=>[r(E,{onClick:a.onProfile},{default:u(()=>[n(o(a.$t(`common.button.profile`)),1)]),_:1},8,[`onClick`]),r(E,{onClick:a.onLogout},{default:u(()=>[n(o(a.$t(`common.button.logout`)),1)]),_:1},8,[`onClick`])]),_:1})]),default:u(()=>[t(`img`,{src:a.user?.avatar||a.defaultAvatar,class:`avatar`},null,8,B)]),_:1})])):(s(),l(`div`,R,[r(C,{type:`primary`,class:`float-right`,size:`small`,round:``,onClick:a.onLogin},{default:u(()=>[n(o(a.$t(`common.button.login`)),1)]),_:1},8,[`onClick`]),r(w,{class:`locale float-right mr-4`}),r(T,{class:`float-right mr-4`})]))]),_:1})]),_:1})}var H=a({name:`LayoutIndex`,components:{TopHeader:A(L,[[`render`,V]]),BottomFooter:I,ElContainer:y,ElMain:g,ElFooter:_,ElHeader:v}});function U(t,n,i,a,o,l){let d=c(`top-header`),f=c(`el-header`),p=c(`router-view`),m=c(`el-main`),h=c(`bottom-footer`),g=c(`el-footer`),_=c(`el-container`);return s(),e(_,{class:`wrapper min-h-[100vh]`},{default:u(()=>[r(f,{class:`header p-0 h-auto`},{default:u(()=>[r(d)]),_:1}),r(m,{class:`main`},{default:u(()=>[r(p)]),_:1}),r(g,{class:`footer p-0 h-auto`},{default:u(()=>[r(h)]),_:1})]),_:1})}var W=A(H,[[`render`,U]]);export{W as default};
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,Ut as o,X as s,et as c,k as l,lt as u,tt as d,ut as f}from"./vendor-chart-mdwpew_o.js";import{t as p}from"./button-DWzbdjZV.js";import{n as m,t as h}from"./row-DvxqZ877.js";import{i as g,n as _,r as v,t as y}from"./container-DUnSq7iO.js";import{n as b,t as x}from"./dropdown-vKgqHRPn.js";import{a as S,i as C,n as w,r as T,t as E}from"./avatar-lihDYhEX.js";import{Bt as D,D as O,Dr as k,E as A,K as j,O as M,rt as N,xr as P,z as F}from"./index-BmC-XXKj.js";import{t as I}from"./BottomFooter-DMl3rPpW.js";var L=a({name:`TopHeader`,components:{ElCol:m,Logo:w,ElRow:h,ElDropdown:x,ElMenu:T,ElMenuItem:C,ElDropdownItem:b,ElButton:p,ElSubMenu:S},data(){return{defaultAvatar:E,products:`chat`}},computed:{site(){return this.$store.state?.site},dark(){return this.$store.getters?.dark},active(){return this.$route.matched?.[0]?.path},user(){return this.$store.getters?.user},authenticated(){return this.$store.getters?.authenticated}},methods:{openTab(e){if(k()){O.open({url:e}).catch(t=>{console.warn(`Browser.open failed, falling back to window.open`,t),window.open(e,`_blank`)});return}window.open(e,`_blank`)},onSelect(e){e&&this.$router.push(e)},onHome(){this.$router.push({name:N})},onLogin(){this.$router.push({name:M})},onDownload(){this.$router.push({name:j})},onProfile(){let e=P();this.openTab(D(`${e}/user/profile`))},onVerify(){let e=P();this.openTab(D(`${e}/user/verify`))},onConsole(){this.$router.push({name:F})},async onLogout(){this.$store.dispatch(`logout`)}}}),R={key:0,class:`mt-4 pr-10`},z={key:1,class:`float-right`},B=[`src`];function V(a,p,m,h,g,_){let v=c(`logo`),y=c(`el-col`),b=c(`el-menu-item`),x=c(`el-sub-menu`),S=c(`el-menu`),C=c(`el-button`),w=c(`language-selector`),T=c(`dark-selector`),E=c(`el-dropdown-item`),D=c(`el-dropdown-menu`),O=c(`el-dropdown`),k=c(`el-row`),A=d(`t`);return s(),e(k,{class:`header`},{default:u(()=>[r(y,{md:4,xs:24,class:`brand-col`},{default:u(()=>[r(v,{onClick:a.onHome},null,8,[`onClick`])]),_:1}),r(y,{md:16,xs:13},{default:u(()=>[r(S,{"default-active":a.active,mode:`horizontal`,class:`menu`,ellipsis:!0,onSelect:a.onSelect},{default:u(()=>[r(x,{index:a.products},{title:u(()=>[n(o(a.$t(`common.nav.products`)),1)]),default:u(()=>[a.site?.features?.chatgpt?.enabled?f((s(),e(b,{key:0,index:`/chat`},null,512)),[[A,`index.title.chat`]]):i(``,!0),a.site?.features?.midjourney?.enabled?f((s(),e(b,{key:1,index:`/midjourney`},null,512)),[[A,`index.title.midjourney`]]):i(``,!0),a.site?.features?.qrart?.enabled?f((s(),e(b,{key:2,index:`/qrart`},null,512)),[[A,`index.title.qrart`]]):i(``,!0),a.site?.features?.suno?.enabled?f((s(),e(b,{key:3,index:`/suno`},null,512)),[[A,`index.title.suno`]]):i(``,!0),a.site?.features?.luma?.enabled?f((s(),e(b,{key:4,index:`/luma`},null,512)),[[A,`index.title.luma`]]):i(``,!0),a.site?.features?.headshots?.enabled?f((s(),e(b,{key:5,index:`/headshots`},null,512)),[[A,`index.title.headshots`]]):i(``,!0)]),_:1},8,[`index`]),f(r(b,{onRoute:e=>void 0,onClick:a.onDownload},null,8,[`onClick`]),[[A,`common.nav.mobileApp`]]),f(r(b,{onRoute:e=>void 0,onClick:p[0]||=e=>a.openTab(`https://platform.acedata.cloud`)},null,512),[[A,`common.nav.apiPlatform`]]),f(r(b,{onRoute:e=>void 0,onClick:p[1]||=e=>a.openTab(`https://platform.acedata.cloud/support`)},null,512),[[A,`common.nav.support`]]),f(r(b,{onRoute:e=>void 0,onClick:p[2]||=e=>a.openTab(`https://platform.acedata.cloud/earning`)},null,512),[[A,`common.nav.referral`]])]),_:1},8,[`default-active`,`onSelect`])]),_:1}),r(y,{md:4,xs:11},{default:u(()=>[a.authenticated?(s(),l(`div`,z,[t(`div`,{class:`console`,onClick:p[3]||=(...e)=>a.onConsole&&a.onConsole(...e)},o(a.$t(`common.button.console`)),1),r(O,{trigger:`click`},{dropdown:u(()=>[r(D,null,{default:u(()=>[r(E,{onClick:a.onProfile},{default:u(()=>[n(o(a.$t(`common.button.profile`)),1)]),_:1},8,[`onClick`]),r(E,{onClick:a.onLogout},{default:u(()=>[n(o(a.$t(`common.button.logout`)),1)]),_:1},8,[`onClick`])]),_:1})]),default:u(()=>[t(`img`,{src:a.user?.avatar||a.defaultAvatar,class:`avatar`},null,8,B)]),_:1})])):(s(),l(`div`,R,[r(C,{type:`primary`,class:`float-right`,size:`small`,round:``,onClick:a.onLogin},{default:u(()=>[n(o(a.$t(`common.button.login`)),1)]),_:1},8,[`onClick`]),r(w,{class:`locale float-right mr-4`}),r(T,{class:`float-right mr-4`})]))]),_:1})]),_:1})}var H=a({name:`LayoutIndex`,components:{TopHeader:A(L,[[`render`,V]]),BottomFooter:I,ElContainer:y,ElMain:g,ElFooter:_,ElHeader:v}});function U(t,n,i,a,o,l){let d=c(`top-header`),f=c(`el-header`),p=c(`router-view`),m=c(`el-main`),h=c(`bottom-footer`),g=c(`el-footer`),_=c(`el-container`);return s(),e(_,{class:`wrapper min-h-[100vh]`},{default:u(()=>[r(f,{class:`header p-0 h-auto`},{default:u(()=>[r(d)]),_:1}),r(m,{class:`main`},{default:u(()=>[r(p)]),_:1}),r(g,{class:`footer p-0 h-auto`},{default:u(()=>[r(h)]),_:1})]),_:1})}var W=A(H,[[`render`,U]]);export{W as default};
@@ -1 +1 @@
1
- import{P as e,X as t,k as n}from"./vendor-chart-mdwpew_o.js";import{E as r}from"./index-CZaid7Ez.js";var i=e({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(e,r,i,o,s,c){return t(),n(`div`,a)}var s=r(i,[[`render`,o]]);export{s as default};
1
+ import{P as e,X as t,k as n}from"./vendor-chart-mdwpew_o.js";import{E as r}from"./index-BmC-XXKj.js";var i=e({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(e,r,i,o,s,c){return t(),n(`div`,a)}var s=r(i,[[`render`,o]]);export{s as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-BdxNJvVA.js";import{n as v,t as y}from"./collapse-6hEfnElE.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-C-bSXdJ_.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-CZaid7Ez.js";import{t as E}from"./index.es-SMgxJgUT.js";import{t as ee}from"./Consumption-fBw5c2fv.js";var te=o({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(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[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=o({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,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(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=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[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=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({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,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({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(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`img`,{key:0,src:e.data.image_url,alt:e.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({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(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`a`,{href:e.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,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`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({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(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,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?(l(),f(`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)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({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(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({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(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({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(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({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(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`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:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({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(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):e.noResults?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({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,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,D as t,E as n,M as r,N as i,O as a,P as o,Q as s,Ut as c,X as l,et as u,j as d,k as f,lt as p,x as m}from"./vendor-chart-mdwpew_o.js";import{t as h}from"./button-DWzbdjZV.js";import{r as g,t as _}from"./select-BITgEgfP.js";import{n as v,t as y}from"./collapse-Dmu2GYt3.js";import{t as b}from"./drawer-BvYPSxXh.js";import"./constants-C-bSXdJ_.js";import{E as x,Ir as S,Nt as C,kr as w,yr as T}from"./index-BmC-XXKj.js";import{t as E}from"./index.es-Cawr8qgY.js";import{t as ee}from"./Consumption-BKLhsHgd.js";var te=o({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(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,D,[n(`div`,O,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,k,[e(t.$slots,`result`,{},void 0,!0)]),i(m,{circle:``,class:`menu`,onClick:r[0]||=e=>t.drawer=!0},{default:p(()=>[i(d,{icon:`fa-solid fa-search`})]),_:1}),i(h,{modelValue:t.drawer,"onUpdate:modelValue":r[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`340px`,class:`drawer`},{default:p(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var j=x(te,[[`render`,A],[`__scopeId`,`data-v-72398911`]]),M=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,N,[n(`div`,P,[n(`h2`,F,c(e.$t(`serp.name.query`)),1)]),i(d,{modelValue:e.query,"onUpdate:modelValue":t[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=o({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,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,z,[n(`h2`,B,c(e.$t(`serp.name.type`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`search`,label:e.$t(`serp.type.search`)},null,8,[`label`]),i(d,{value:`images`,label:e.$t(`serp.type.images`)},null,8,[`label`]),i(d,{value:`news`,label:e.$t(`serp.type.news`)},null,8,[`label`]),i(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=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,W,[n(`h2`,G,c(e.$t(`serp.name.country`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[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=o({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,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,Y,[n(`h2`,X,c(e.$t(`serp.name.language`)),1),i(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`serp.placeholder.language`)},null,8,[`modelValue`,`placeholder`])])}var Q=o({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,t,a,o,s,d){let m=u(`query-input`),h=u(`type-selector`),g=u(`country-input`),_=u(`language-input`),v=u(`consumption`),y=u(`font-awesome-icon`),b=u(`el-button`);return l(),f(`div`,ne,[n(`div`,re,[i(m,{class:`mb-4`}),i(h,{class:`mb-4`}),i(g,{class:`mb-4`}),i(_,{class:`mb-4`})]),n(`div`,ie,[i(v,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(b,{type:`primary`,class:`btn w-full`,round:``,loading:e.searching,onClick:e.onSearch},{default:p(()=>[i(y,{icon:`fa-solid fa-search`,class:`mr-2`}),r(` `+c(e.$t(`serp.button.search`)),1)]),_:1},8,[`loading`,`onClick`])])])}var oe=x(Q,[[`render`,ae]]),se=o({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(e,t,i,o,u,d){return l(),f(`div`,ce,[n(`div`,le,[e.data.image_url?(l(),f(`img`,{key:0,src:e.data.image_url,alt:e.data.title,class:`w-28 h-28 rounded-lg object-cover flex-none shadow-sm`},null,8,ue)):a(``,!0),n(`div`,de,[e.data.type?(l(),f(`div`,fe,c(e.data.type),1)):a(``,!0),n(`h3`,pe,c(e.data.title),1),e.data.description?(l(),f(`p`,me,[r(c(e.data.description)+` `,1),e.data.description_link?(l(),f(`a`,{key:0,href:e.data.description_link,target:`_blank`,rel:`noopener noreferrer`,class:`text-[var(--el-color-primary)] hover:underline ml-1`},c(e.data.description_source||`Source`),9,he)):a(``,!0)])):a(``,!0),e.data.attributes&&Object.keys(e.data.attributes).length?(l(),f(`div`,ge,[(l(!0),f(m,null,s(e.data.attributes,(e,t)=>(l(),f(`div`,{key:t,class:`flex gap-2 mb-1 py-0.5`},[n(`span`,_e,c(t)+`:`,1),n(`span`,ve,c(e),1)]))),128))])):a(``,!0)])])])}var be=x(se,[[`render`,ye]]),xe=o({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(e,t,r,i,o,u){return l(),f(`div`,Se,[e.displayUrl?(l(),f(`div`,Ce,[n(`img`,{src:e.faviconUrl,alt:e.hostname,class:`w-4 h-4 rounded-sm flex-none`,loading:`lazy`,onError:t[0]||=(...t)=>e.onFaviconError&&e.onFaviconError(...t)},null,40,we),n(`span`,Te,c(e.hostname),1),n(`span`,Ee,c(e.pathname),1)])):a(``,!0),n(`a`,{href:e.data.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block`},c(e.data.title),9,De),e.data.date?(l(),f(`div`,Oe,c(e.data.date),1)):a(``,!0),e.data.snippet?(l(),f(`p`,ke,c(e.data.snippet),1)):a(``,!0),e.data.sitelinks?.length?(l(),f(`div`,Ae,[(l(!0),f(m,null,s(e.data.sitelinks,(e,t)=>(l(),f(`a`,{key:t,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`},c(e.title),9,je))),128))])):a(``,!0)])}var Ne=x(xe,[[`render`,Me]]),Pe=o({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(e,t,r,i,o,u){return l(),f(`div`,Fe,[n(`h3`,Ie,c(e.$t(`serp.name.imageResults`)),1),n(`div`,Le,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,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?(l(),f(`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)):a(``,!0),n(`div`,Be,[n(`span`,Ve,c(e.title),1)])],8,Re))),128))])])}var Ue=x(Pe,[[`render`,He]]),We=o({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(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,Ge,c(e.$t(`serp.name.videoResults`)),1),n(`div`,Ke,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,Je,[e.image_url?(l(),f(`img`,{key:0,src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,Ye)):a(``,!0),e.duration?(l(),f(`div`,Xe,c(e.duration),1)):a(``,!0)]),n(`div`,Ze,[n(`div`,Qe,c(e.title),1),n(`div`,$e,[e.source?(l(),f(`span`,et,c(e.source),1)):a(``,!0),e.channel?(l(),f(`span`,tt,` · `+c(e.channel),1)):a(``,!0),e.date?(l(),f(`span`,nt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,rt,c(e.snippet),1)):a(``,!0)])],8,qe))),128))])])}var at=x(We,[[`render`,it]]),ot=o({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(e,t,r,i,o,u){return l(),f(`div`,null,[n(`h3`,st,c(e.$t(`serp.name.newsResults`)),1),n(`div`,ct,[(l(!0),f(m,null,s(e.data,(e,t)=>(l(),f(`a`,{key:t,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`flex gap-4 group`},[n(`div`,ut,[n(`div`,dt,c(e.title),1),n(`div`,ft,[e.source?(l(),f(`span`,pt,c(e.source),1)):a(``,!0),e.date?(l(),f(`span`,mt,` · `+c(e.date),1)):a(``,!0)]),e.snippet?(l(),f(`p`,ht,c(e.snippet),1)):a(``,!0)]),e.image_url?(l(),f(`div`,gt,[n(`img`,{src:e.image_url,alt:e.title,class:`w-full h-full object-cover`,loading:`lazy`},null,8,_t)])):a(``,!0)],8,lt))),128))])])}var yt=x(ot,[[`render`,vt]]),bt=o({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(e,r,o,d,h,g){let _=u(`el-collapse-item`),v=u(`el-collapse`);return l(),f(`div`,xt,[n(`h3`,St,c(e.$t(`serp.name.peopleAlsoAsk`)),1),i(v,null,{default:p(()=>[(l(!0),f(m,null,s(e.data,(e,n)=>(l(),t(_,{key:n,title:e.question||e.title||``},{default:p(()=>[e.snippet?(l(),f(`p`,Ct,c(e.snippet),1)):a(``,!0),e.link?(l(),f(`a`,{key:1,href:e.link,target:`_blank`,rel:`noopener noreferrer`,class:`text-xs text-[var(--el-color-primary)] hover:underline`},c(e.title||e.link),9,wt)):a(``,!0)]),_:2},1032,[`title`]))),128))]),_:1})])}var Et=x(bt,[[`render`,Tt]]),Dt=o({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(e,t,a,o,d,p){let h=u(`font-awesome-icon`);return l(),f(`div`,Ot,[n(`h3`,kt,c(e.$t(`serp.name.relatedSearches`)),1),n(`div`,At,[(l(!0),f(m,null,s(e.data,(t,n)=>(l(),f(`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:n=>e.onSearch(t.query)},[i(h,{icon:`fa-solid fa-magnifying-glass`,class:`text-xs opacity-50`}),r(` `+c(t.query),1)],8,jt))),128))])])}var Nt=o({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(e,r,o,p,h,g){let _=u(`font-awesome-icon`),v=u(`knowledge-graph`),y=u(`organic-result`),b=u(`image-results`),x=u(`video-results`),S=u(`news-results`),C=u(`people-also-ask`),w=u(`related-searches`);return l(),f(`div`,$,[e.searching?(l(),f(`div`,Pt,[(l(),f(m,null,s(4,e=>n(`div`,{key:e,class:`mb-6 animate-pulse`},[...r[0]||=[d(`<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>`,4)]])),64))])):e.noResults?(l(),f(`div`,Ft,[i(_,{icon:`fa-solid fa-face-meh`,class:`text-5xl mb-4 opacity-40`}),n(`p`,It,c(e.$t(`serp.message.noResults`)),1)])):e.results?(l(),f(`div`,Lt,[e.results.knowledge_graph?.title?(l(),t(v,{key:0,data:e.results.knowledge_graph,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.organic?.length?(l(),f(`div`,Rt,[(l(!0),f(m,null,s(e.results.organic,(e,n)=>(l(),t(y,{key:n,data:e,class:`mb-1`},null,8,[`data`]))),128))])):a(``,!0),e.results.images?.length?(l(),t(b,{key:2,data:e.results.images,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.videos?.length?(l(),t(x,{key:3,data:e.results.videos,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.news?.length?(l(),t(S,{key:4,data:e.results.news,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.people_also_ask?.length?(l(),t(C,{key:5,data:e.results.people_also_ask,class:`mb-6`},null,8,[`data`])):a(``,!0),e.results.related_searches?.length?(l(),t(w,{key:6,data:e.results.related_searches,class:`mb-6`,onSearch:e.onRelatedSearch},null,8,[`data`,`onSearch`])):a(``,!0)])):(l(),f(`div`,zt,[i(_,{icon:`fa-solid fa-globe`,class:`text-5xl mb-4 opacity-30`}),n(`p`,Bt,c(e.$t(`serp.description.query`)),1)]))])}var Ht=o({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,n,r,a,o,s){let c=u(`search-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onSearch:e.onSearch},null,8,[`onSearch`])]),result:p(()=>[i(d,{onRelatedSearch:e.onRelatedSearch},null,8,[`onRelatedSearch`])]),_:1})}var Wt=x(Ht,[[`render`,Ut]]);export{Wt as default};
@@ -1 +1 @@
1
- import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,Ht as ee,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-BdxNJvVA.js";import{t as b}from"./upload-cst9ChUG.js";import{t as x}from"./tooltip-C3PYfh8V.js";import{t as S}from"./image-DhZ3AYYg.js";import{t as C}from"./alert-BJj7gY4q.js";import{t as w}from"./drawer-BvYPSxXh.js";import{t as T}from"./switch-BLmaNxij.js";import{cr as E,dr as D,fr as O,gr as k,lr as A,mr as j,or as M,pi as N,sr as P,ur as F}from"./constants-C-bSXdJ_.js";import{At as te,E as I,Fn as ne,Ir as L,Nt as R,Ot as z,Sr as B,fn as V,jt as H,kr as U,kt as W,yr as G}from"./index-CZaid7Ez.js";import{t as K}from"./index.es-SMgxJgUT.js";import{t as q}from"./CopyToClipboard-Dw5puTqb.js";import{t as J}from"./ImagePreview-j8UOiTmY.js";import{n as Y}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as X}from"./BotPlaceholder-DwmD_q7g.js";import{i as Z,n as re,t as ie}from"./pagination-8ujfpoRu.js";import{n as ae,t as oe}from"./NoTasks-vOEmwSFQ.js";import{t as se}from"./Consumption-fBw5c2fv.js";import{t as ce}from"./ApiCodeButton-Bbnpv2we.js";import{t as Q}from"./VideoPlayer-C6O7JCcj.js";var le=s({name:`LayoutVeo`,components:{ElDrawer:w,ElButton:_,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(t,n,ee,i,o,s){let c=f(`font-awesome-icon`),l=f(`el-button`),g=f(`el-drawer`);return u(),p(`div`,ue,[r(`div`,de,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,fe,[e(t.$slots,`result`,{},void 0,!0)]),h(a(l,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(c,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(g,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var me=I(le,[[`render`,pe],[`__scopeId`,`data-v-12b82bc3`]]),he=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},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||=A}}),ge={class:`field`},_e={class:`title font-bold`};function ve(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ge,[r(`h2`,_e,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ye=I(he,[[`render`,ve],[`__scopeId`,`data-v-a59d89c9`]]),be=s({name:`ActionSelector`,components:{ElSelect:v,ElOption:y},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||=M}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,xe,[r(`h2`,Se,l(e.$t(`veo.name.action`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,Ce,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=I(be,[[`render`,we],[`__scopeId`,`data-v-f4d8785c`]]),Ee=s({name:`TranslationSelector`,components:{ElSwitch:T,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,t,n,ee,i,o){let s=f(`info-icon`),c=f(`el-switch`);return u(),p(`div`,De,[r(`div`,Oe,[r(`div`,ke,[r(`span`,Ae,l(e.$t(`veo.name.translation`)),1),a(s,{content:e.$t(`veo.description.translation`)},null,8,[`content`])]),r(`div`,je,[a(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var Ne=I(Ee,[[`render`,Me]]),Pe=s({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||=P}}),Fe={class:`text-sm font-bold mb-2 block`},Ie={class:`items`},Le=[`onClick`],Re={class:`name`};function ze(e,n,i,a,o,s){return u(),p(`div`,null,[r(`span`,Fe,l(e.$t(`veo.name.ratio`)),1),r(`div`,Ie,[(u(!0),p(g,null,c(e.options,(n,i)=>(u(),p(`div`,{key:i,class:t({active:e.active===i,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.label])},[r(`div`,{class:`rect`,style:ee({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Re,l(n.label),1)],10,Le))),128))])])}var Be=I(Pe,[[`render`,ze],[`__scopeId`,`data-v-28c472c4`]]),Ve=s({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,t,ee,i,a,s){let c=f(`video-player`);return u(),p(`div`,He,[r(`div`,Ue,[r(`span`,We,l(e.$t(`veo.name.action3`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(c,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var Ke=I(Ve,[[`render`,Ge]]),qe=s({name:`VideoIdInput`,components:{ElInput:L},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,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,Je,[r(`h2`,Ye,l(e.$t(`veo.name.videoId`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.videoId`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var Ze=I(qe,[[`render`,Xe],[`__scopeId`,`data-v-6eba4026`]]),Qe=s({name:`StartEndImage`,components:{ElUpload:b,ElButton:_,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,t,ee,s,c,d){let h=f(`info-icon`),g=f(`image-preview`),_=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`);return u(),p(`div`,$e,[r(`div`,et,[r(`div`,tt,[r(`span`,nt,l(e.$t(`veo.name.startEndImage`)),1),a(h,{content:e.$t(`veo.description.uploadStartEndImage`)},null,8,[`content`])])]),a(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[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:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(g,{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`])):o(``,!0)]),default:m(()=>[a(v,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`veo.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var it=I(Qe,[[`render`,rt],[`__scopeId`,`data-v-f9a79b4a`]]),at=s({name:`UpsampleActionSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return k.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||=D}}),ot={class:`field`},st={class:`title font-bold`};function ct(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ot,[r(`h2`,st,l(e.$t(`veo.name.upsampleAction`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var lt=I(at,[[`render`,ct],[`__scopeId`,`data-v-8b74a7ae`]]),ut=s({name:`ExtendModelSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return O.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||!O.includes(this.value))&&(this.value=E)}}),dt={class:`field`},ft={class:`title font-bold`};function pt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,dt,[r(`h2`,ft,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var mt=I(ut,[[`render`,pt],[`__scopeId`,`data-v-cc3f9355`]]),ht=s({name:`MotionTypeSelector`,components:{ElSelect:v,ElOption:y},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||=F}}),gt={class:`field`},_t={class:`title font-bold`};function vt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,gt,[r(`h2`,_t,l(e.$t(`veo.name.motionType`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),filterable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var yt=I(ht,[[`render`,vt],[`__scopeId`,`data-v-3affff3c`]]),bt=s({name:`ImageMaskInput`,components:{ElInput:L},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,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,xt,[r(`h2`,St,l(e.$t(`veo.name.imageMask`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.imageMask`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var wt=I(bt,[[`render`,Ct],[`__scopeId`,`data-v-6cc27c68`]]),Tt=s({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,r,ee,i,a){let o=f(`prompt-textarea`);return u(),n(o,{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=I(Tt,[[`render`,Et]]),Ot=[`upsample`,`extend`,`reshoot`,`object_insert`,`object_remove`,`get1080p`],kt=[`text2video`,`image2video`,`ingredients2video`],At=s({name:`ConfigPanel`,components:{ElButton:_,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 R(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,t,ee,s,c,d){let h=f(`action-selector`),_=f(`video-from-input`),v=f(`video-id-input`),y=f(`upsample-action-selector`),b=f(`extend-model-selector`),x=f(`prompt-input`),S=f(`motion-type-selector`),C=f(`image-mask-input`),w=f(`translation-selector`),T=f(`aspect-ratio-selector`),E=f(`model-selector`),D=f(`start-end-image`),O=f(`consumption`),k=f(`font-awesome-icon`),A=f(`el-button`);return u(),p(`div`,jt,[r(`div`,Mt,[a(h,{class:`mb-4`}),e.isPostProcessing?(u(),p(g,{key:0},[e.config?.video_url?(u(),n(_,{key:0,class:`mb-4`})):o(``,!0),a(v,{class:`mb-4`})],64)):o(``,!0),e.config?.action===`upsample`?(u(),n(y,{key:1,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(b,{key:2,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(x,{key:3,class:`mb-4`})):o(``,!0),e.config?.action===`reshoot`?(u(),n(S,{key:4,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`?(u(),n(x,{key:5,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`||e.config?.action===`object_remove`?(u(),n(C,{key:6,class:`mb-4`})):o(``,!0),e.config?.action===`object_remove`?(u(),n(x,{key:7,class:`mb-4`})):o(``,!0),e.isGeneration?(u(),p(g,{key:8},[a(w,{class:`mb-4`}),a(T,{class:`mb-4`}),a(x,{class:`mb-4`}),e.config?.action===`ingredients2video`?o(``,!0):(u(),n(E,{key:0,class:`mb-4`})),e.config?.action===`image2video`||e.config?.action===`ingredients2video`?(u(),n(D,{key:1,class:`mb-2`})):o(``,!0)],64)):o(``,!0)]),r(`div`,Nt,[a(O,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(A,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(k,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`veo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Ft=I(At,[[`render`,Pt]]),It=s({name:`TaskPreview`,components:{ElImage:S,CopyToClipboard:q,FontAwesomeIcon:K,ElAlert:C,VideoPlayer:Q,ElTooltip:x,ElButton:_,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:t({content:!0,failed:!0})},qt={key:0,class:`mb-4`},Jt={key:1,class:t({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:t({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:t({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,t,ee,s,c,d){let h=f(`el-image`),g=f(`video-player`),_=f(`el-button`),v=f(`el-tooltip`),y=f(`api-code-button`),b=f(`font-awesome-icon`),x=f(`copy-to-clipboard`),S=f(`el-alert`);return u(),p(`div`,Lt,[r(`div`,Rt,[a(h,{src:`https://cdn.acedata.cloud/8nxyy9.jpg`,class:`avatar`})]),r(`div`,zt,[r(`div`,Bt,[i(l(e.$t(`veo.name.veoBot`))+` `,1),r(`span`,Vt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Ht,[e.modelValue?.request?.prompt?(u(),p(`p`,Ut,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,Wt,` - (`+l(e.$t(`veo.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`running`?(u(),p(`span`,Gt,` - (`+l(e.$t(`veo.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(u(),p(`div`,Kt,[e.modelValue?.response?.data[0]?.video_url?(u(),p(`div`,qt,[a(g,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response.success?(u(),p(`div`,Jt,[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`1080p`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample1080p`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:1,type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`4k`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample4k`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:2,type:`info`,size:`small`,class:`btn-action`,onClick:t[2]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`gif`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsampleGif`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:3,type:`info`,size:`small`,class:`btn-action`,onClick:t[3]||=t=>e.onPickAction(t,e.modelValue?.response,`extend`)},{default:m(()=>[i(l(e.$t(`veo.button.actionExtend`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:4,type:`info`,size:`small`,class:`btn-action`,onClick:t[4]||=t=>e.onPickAction(t,e.modelValue?.response,`reshoot`)},{default:m(()=>[i(l(e.$t(`veo.button.actionReshoot`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:5,type:`info`,size:`small`,class:`btn-action`,onClick:t[5]||=t=>e.onPickAction(t,e.modelValue?.response,`object_insert`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectInsert`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:6,type:`info`,size:`small`,class:`btn-action`,onClick:t[6]||=t=>e.onPickAction(t,e.modelValue?.response,`object_remove`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectRemove`)),1)]),_:1})):o(``,!0),a(v,{class:`box-item`,effect:`dark`,content:e.$t(`veo.message.downloadVideo`),placement:`top-start`},{default:m(()=>[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[7]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:m(()=>[i(l(e.$t(`veo.button.download`)),1)]),_:1})):o(``,!0)]),_:1},8,[`content`]),a(y,{path:`/veo/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(S,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Yt,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.model`))+`: `+l(e.modelValue?.request?.model),1)]),r(`p`,Xt,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Zt,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,Qt,[a(S,{closable:!1,class:`failure`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,$t,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,en,[a(b,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(x,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,tn,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===void 0?(u(),p(`div`,nn,[a(S,{closable:!1,class:`info`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,rn,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(u(),p(`p`,an,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0)])])}var sn=s({name:`RecentPanel`,components:{TaskPreview:I(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(e,t,r,ee,i,s){let l=f(`bot-placeholder`),d=f(`task-preview`),h=f(`scroll-list`),_=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,cn,[a(l)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(h,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,(e,t)=>(u(),n(d,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,ln,[a(_)])):o(``,!0)],64)}var dn=I(sn,[[`render`,un]]),fn=N(`veo`),pn=s({name:`VeoIndex`,components:{ConfigPanel:Ft,Layout:me,RecentPanel:dn},mixins:[te],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`)),ne(`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,r,ee,i,o){let s=f(`config-panel`),c=f(`recent-panel`),l=f(`layout`);return u(),n(l,null,{config:m(()=>[a(s,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(c,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var hn=I(pn,[[`render`,mn]]);export{hn as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,Ht as ee,M as i,N as a,O as o,P as s,Q as c,Ut as l,X as u,_ as d,et as f,k as p,lt as m,ut as h,x as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-BITgEgfP.js";import{t as b}from"./upload-DMzqzxP6.js";import{t as x}from"./tooltip-C3PYfh8V.js";import{t as S}from"./image-CWcemTUB.js";import{t as C}from"./alert-BJj7gY4q.js";import{t as w}from"./drawer-BvYPSxXh.js";import{t as T}from"./switch-DyO-foN-.js";import{cr as E,dr as D,fr as O,gr as k,lr as A,mr as j,or as M,pi as N,sr as P,ur as F}from"./constants-C-bSXdJ_.js";import{At as te,E as I,Fn as ne,Ir as L,Nt as R,Ot as z,Sr as B,fn as V,jt as H,kr as U,kt as W,yr as G}from"./index-BmC-XXKj.js";import{t as K}from"./index.es-Cawr8qgY.js";import{t as q}from"./CopyToClipboard-Cx0LOUlj.js";import{t as J}from"./ImagePreview--SDvXZzb.js";import{n as Y}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as X}from"./BotPlaceholder-CGjSVeUk.js";import{i as Z,n as re,t as ie}from"./pagination-B3P0PVH-.js";import{n as ae,t as oe}from"./NoTasks-l_P0QgKI.js";import{t as se}from"./Consumption-BKLhsHgd.js";import{t as ce}from"./ApiCodeButton-8YzSdLWx.js";import{t as Q}from"./VideoPlayer-BtXLkAAR.js";var le=s({name:`LayoutVeo`,components:{ElDrawer:w,ElButton:_,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(t,n,ee,i,o,s){let c=f(`font-awesome-icon`),l=f(`el-button`),g=f(`el-drawer`);return u(),p(`div`,ue,[r(`div`,de,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,fe,[e(t.$slots,`result`,{},void 0,!0)]),h(a(l,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(c,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(g,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var me=I(le,[[`render`,pe],[`__scopeId`,`data-v-12b82bc3`]]),he=s({name:`ModelSelector`,components:{ElSelect:v,ElOption:y},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||=A}}),ge={class:`field`},_e={class:`title font-bold`};function ve(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ge,[r(`h2`,_e,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ye=I(he,[[`render`,ve],[`__scopeId`,`data-v-a59d89c9`]]),be=s({name:`ActionSelector`,components:{ElSelect:v,ElOption:y},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||=M}}),xe={class:`field`},Se={class:`title font-bold`},Ce={class:`float-left`};function we(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,xe,[r(`h2`,Se,l(e.$t(`veo.name.action`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),clearable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},{default:m(()=>[r(`span`,Ce,l(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Te=I(be,[[`render`,we],[`__scopeId`,`data-v-f4d8785c`]]),Ee=s({name:`TranslationSelector`,components:{ElSwitch:T,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,t,n,ee,i,o){let s=f(`info-icon`),c=f(`el-switch`);return u(),p(`div`,De,[r(`div`,Oe,[r(`div`,ke,[r(`span`,Ae,l(e.$t(`veo.name.translation`)),1),a(s,{content:e.$t(`veo.description.translation`)},null,8,[`content`])]),r(`div`,je,[a(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var Ne=I(Ee,[[`render`,Me]]),Pe=s({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||=P}}),Fe={class:`text-sm font-bold mb-2 block`},Ie={class:`items`},Le=[`onClick`],Re={class:`name`};function ze(e,n,i,a,o,s){return u(),p(`div`,null,[r(`span`,Fe,l(e.$t(`veo.name.ratio`)),1),r(`div`,Ie,[(u(!0),p(g,null,c(e.options,(n,i)=>(u(),p(`div`,{key:i,class:t({active:e.active===i,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.label])},[r(`div`,{class:`rect`,style:ee({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Re,l(n.label),1)],10,Le))),128))])])}var Be=I(Pe,[[`render`,ze],[`__scopeId`,`data-v-28c472c4`]]),Ve=s({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,t,ee,i,a,s){let c=f(`video-player`);return u(),p(`div`,He,[r(`div`,Ue,[r(`span`,We,l(e.$t(`veo.name.action3`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(c,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var Ke=I(Ve,[[`render`,Ge]]),qe=s({name:`VideoIdInput`,components:{ElInput:L},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,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,Je,[r(`h2`,Ye,l(e.$t(`veo.name.videoId`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.videoId`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var Ze=I(qe,[[`render`,Xe],[`__scopeId`,`data-v-6eba4026`]]),Qe=s({name:`StartEndImage`,components:{ElUpload:b,ElButton:_,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,t,ee,s,c,d){let h=f(`info-icon`),g=f(`image-preview`),_=f(`font-awesome-icon`),v=f(`el-button`),y=f(`el-upload`);return u(),p(`div`,$e,[r(`div`,et,[r(`div`,tt,[r(`span`,nt,l(e.$t(`veo.name.startEndImage`)),1),a(h,{content:e.$t(`veo.description.uploadStartEndImage`)},null,8,[`content`])])]),a(y,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[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:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(g,{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`])):o(``,!0)]),default:m(()=>[a(v,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(_,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`veo.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var it=I(Qe,[[`render`,rt],[`__scopeId`,`data-v-f9a79b4a`]]),at=s({name:`UpsampleActionSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return k.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||=D}}),ot={class:`field`},st={class:`title font-bold`};function ct(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,ot,[r(`h2`,st,l(e.$t(`veo.name.upsampleAction`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var lt=I(at,[[`render`,ct],[`__scopeId`,`data-v-8b74a7ae`]]),ut=s({name:`ExtendModelSelector`,components:{ElSelect:v,ElOption:y},computed:{options(){return O.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||!O.includes(this.value))&&(this.value=E)}}),dt={class:`field`},ft={class:`title font-bold`};function pt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,dt,[r(`h2`,ft,l(e.$t(`veo.name.model`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`)},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var mt=I(ut,[[`render`,pt],[`__scopeId`,`data-v-cc3f9355`]]),ht=s({name:`MotionTypeSelector`,components:{ElSelect:v,ElOption:y},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||=F}}),gt={class:`field`},_t={class:`title font-bold`};function vt(e,t,ee,i,o,s){let d=f(`el-option`),h=f(`el-select`);return u(),p(`div`,gt,[r(`h2`,_t,l(e.$t(`veo.name.motionType`)),1),a(h,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`veo.placeholder.select`),filterable:``},{default:m(()=>[(u(!0),p(g,null,c(e.options,e=>(u(),n(d,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var yt=I(ht,[[`render`,vt],[`__scopeId`,`data-v-3affff3c`]]),bt=s({name:`ImageMaskInput`,components:{ElInput:L},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,t,n,ee,i,o){let s=f(`el-input`);return u(),p(`div`,xt,[r(`h2`,St,l(e.$t(`veo.name.imageMask`)),1),a(s,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,type:`text`,placeholder:e.$t(`veo.placeholder.imageMask`),clearable:``},null,8,[`modelValue`,`placeholder`])])}var wt=I(bt,[[`render`,Ct],[`__scopeId`,`data-v-6cc27c68`]]),Tt=s({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,r,ee,i,a){let o=f(`prompt-textarea`);return u(),n(o,{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=I(Tt,[[`render`,Et]]),Ot=[`upsample`,`extend`,`reshoot`,`object_insert`,`object_remove`,`get1080p`],kt=[`text2video`,`image2video`,`ingredients2video`],At=s({name:`ConfigPanel`,components:{ElButton:_,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 R(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,t,ee,s,c,d){let h=f(`action-selector`),_=f(`video-from-input`),v=f(`video-id-input`),y=f(`upsample-action-selector`),b=f(`extend-model-selector`),x=f(`prompt-input`),S=f(`motion-type-selector`),C=f(`image-mask-input`),w=f(`translation-selector`),T=f(`aspect-ratio-selector`),E=f(`model-selector`),D=f(`start-end-image`),O=f(`consumption`),k=f(`font-awesome-icon`),A=f(`el-button`);return u(),p(`div`,jt,[r(`div`,Mt,[a(h,{class:`mb-4`}),e.isPostProcessing?(u(),p(g,{key:0},[e.config?.video_url?(u(),n(_,{key:0,class:`mb-4`})):o(``,!0),a(v,{class:`mb-4`})],64)):o(``,!0),e.config?.action===`upsample`?(u(),n(y,{key:1,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(b,{key:2,class:`mb-4`})):o(``,!0),e.config?.action===`extend`?(u(),n(x,{key:3,class:`mb-4`})):o(``,!0),e.config?.action===`reshoot`?(u(),n(S,{key:4,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`?(u(),n(x,{key:5,class:`mb-4`})):o(``,!0),e.config?.action===`object_insert`||e.config?.action===`object_remove`?(u(),n(C,{key:6,class:`mb-4`})):o(``,!0),e.config?.action===`object_remove`?(u(),n(x,{key:7,class:`mb-4`})):o(``,!0),e.isGeneration?(u(),p(g,{key:8},[a(w,{class:`mb-4`}),a(T,{class:`mb-4`}),a(x,{class:`mb-4`}),e.config?.action===`ingredients2video`?o(``,!0):(u(),n(E,{key:0,class:`mb-4`})),e.config?.action===`image2video`||e.config?.action===`ingredients2video`?(u(),n(D,{key:1,class:`mb-2`})):o(``,!0)],64)):o(``,!0)]),r(`div`,Nt,[a(O,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),a(A,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(k,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`veo.button.generate`)),1)]),_:1},8,[`onClick`])])])}var Ft=I(At,[[`render`,Pt]]),It=s({name:`TaskPreview`,components:{ElImage:S,CopyToClipboard:q,FontAwesomeIcon:K,ElAlert:C,VideoPlayer:Q,ElTooltip:x,ElButton:_,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:t({content:!0,failed:!0})},qt={key:0,class:`mb-4`},Jt={key:1,class:t({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:t({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:t({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,t,ee,s,c,d){let h=f(`el-image`),g=f(`video-player`),_=f(`el-button`),v=f(`el-tooltip`),y=f(`api-code-button`),b=f(`font-awesome-icon`),x=f(`copy-to-clipboard`),S=f(`el-alert`);return u(),p(`div`,Lt,[r(`div`,Rt,[a(h,{src:`https://cdn.acedata.cloud/8nxyy9.jpg`,class:`avatar`})]),r(`div`,zt,[r(`div`,Bt,[i(l(e.$t(`veo.name.veoBot`))+` `,1),r(`span`,Vt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,Ht,[e.modelValue?.request?.prompt?(u(),p(`p`,Ut,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,Wt,` - (`+l(e.$t(`veo.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`running`?(u(),p(`span`,Gt,` - (`+l(e.$t(`veo.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(u(),p(`div`,Kt,[e.modelValue?.response?.data[0]?.video_url?(u(),p(`div`,qt,[a(g,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response.success?(u(),p(`div`,Jt,[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`1080p`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample1080p`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:1,type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`4k`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsample4k`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:2,type:`info`,size:`small`,class:`btn-action`,onClick:t[2]||=t=>e.onPickAction(t,e.modelValue?.response,`upsample`,`gif`)},{default:m(()=>[i(l(e.$t(`veo.button.actionUpsampleGif`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:3,type:`info`,size:`small`,class:`btn-action`,onClick:t[3]||=t=>e.onPickAction(t,e.modelValue?.response,`extend`)},{default:m(()=>[i(l(e.$t(`veo.button.actionExtend`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:4,type:`info`,size:`small`,class:`btn-action`,onClick:t[4]||=t=>e.onPickAction(t,e.modelValue?.response,`reshoot`)},{default:m(()=>[i(l(e.$t(`veo.button.actionReshoot`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:5,type:`info`,size:`small`,class:`btn-action`,onClick:t[5]||=t=>e.onPickAction(t,e.modelValue?.response,`object_insert`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectInsert`)),1)]),_:1})):o(``,!0),e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:6,type:`info`,size:`small`,class:`btn-action`,onClick:t[6]||=t=>e.onPickAction(t,e.modelValue?.response,`object_remove`)},{default:m(()=>[i(l(e.$t(`veo.button.actionObjectRemove`)),1)]),_:1})):o(``,!0),a(v,{class:`box-item`,effect:`dark`,content:e.$t(`veo.message.downloadVideo`),placement:`top-start`},{default:m(()=>[e.modelValue?.response?.data[0]?.video_url?(u(),n(_,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[7]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:m(()=>[i(l(e.$t(`veo.button.download`)),1)]),_:1})):o(``,!0)]),_:1},8,[`content`]),a(y,{path:`/veo/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(S,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,Yt,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.model`))+`: `+l(e.modelValue?.request?.model),1)]),r(`p`,Xt,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Zt,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===!1?(u(),p(`div`,Qt,[a(S,{closable:!1,class:`failure`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,$t,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,en,[a(b,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(x,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(b,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),e.modelValue?.response?.trace_id?(u(),p(`p`,tn,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.success===void 0?(u(),p(`div`,nn,[a(S,{closable:!1,class:`info`},{template:m(()=>[a(b,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.failure`)),1)]),default:m(()=>[r(`p`,rn,[a(b,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(x,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(u(),p(`p`,an,[a(b,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`veo.name.traceId`))+`: `+l(e.modelValue?.response?.trace_id)+` `,1),a(x,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):o(``,!0)]),_:1})])):o(``,!0)])])}var sn=s({name:`RecentPanel`,components:{TaskPreview:I(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(e,t,r,ee,i,s){let l=f(`bot-placeholder`),d=f(`task-preview`),h=f(`scroll-list`),_=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,cn,[a(l)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(h,{key:1,ref:`scrollList`,class:`tasks h-full w-full overflow-y-auto`,loading:e.loading,onReachTop:t[0]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,(e,t)=>(u(),n(d,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,ln,[a(_)])):o(``,!0)],64)}var dn=I(sn,[[`render`,un]]),fn=N(`veo`),pn=s({name:`VeoIndex`,components:{ConfigPanel:Ft,Layout:me,RecentPanel:dn},mixins:[te],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`)),ne(`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,r,ee,i,o){let s=f(`config-panel`),c=f(`recent-panel`),l=f(`layout`);return u(),n(l,null,{config:m(()=>[a(s,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(c,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var hn=I(pn,[[`render`,mn]]);export{hn as default};