@acedatacloud/nexior 3.276.1 → 3.276.3

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 (125) hide show
  1. package/dist/assets/{ApiCodeButton-CYsbafW5.js → ApiCodeButton-DpYCu-EK.js} +1 -1
  2. package/dist/assets/{AskUserQuestionCard-C0g0CXFW.js → AskUserQuestionCard-CFwxSrmZ.js} +1 -1
  3. package/dist/assets/{Auth-CiRBbchK.js → Auth-7LLt4q3p.js} +1 -1
  4. package/dist/assets/{Bare-DIrMb-SD.js → Bare-JAoG6sFQ.js} +1 -1
  5. package/dist/assets/{BotPlaceholder-By9wptjP.js → BotPlaceholder-BVXWzbpi.js} +1 -1
  6. package/dist/assets/{BottomFooter-Uv4jMxMb.js → BottomFooter-BTcNTyiV.js} +1 -1
  7. package/dist/assets/{Callback-C7CJR5pz.js → Callback-CW861dqy.js} +1 -1
  8. package/dist/assets/{Console-DXmaxlAf.js → Console-BOxYP152.js} +1 -1
  9. package/dist/assets/{Consumption-Dlo2Ec9d.js → Consumption-QfvilMcG.js} +1 -1
  10. package/dist/assets/{Conversation-CQAyzCiS.js → Conversation-C1Jb8AgW.js} +1 -1
  11. package/dist/assets/{CopyToClipboard-Dnrr0G1l.js → CopyToClipboard-C8gyDUMn.js} +1 -1
  12. package/dist/assets/{Detail-Cy86BsXm.js → Detail-BMuX9lMp.js} +2 -2
  13. package/dist/assets/{Extra-D4jX7JNq.js → Extra-BshQjZAE.js} +1 -1
  14. package/dist/assets/{FilePreview-BSXA8G7D.js → FilePreview-sx756NB5.js} +1 -1
  15. package/dist/assets/{Hailuo-hE8NOeDF.js → Hailuo-y5ZOpsGB.js} +1 -1
  16. package/dist/assets/{History-BXlSABUg.js → History-CBejCufL.js} +1 -1
  17. package/dist/assets/{ImagePreview-D9ovswSr.js → ImagePreview-DkXTeOKK.js} +1 -1
  18. package/dist/assets/{ImageWrapper-DHnmEVHU.js → ImageWrapper-3eqDS8_u.js} +1 -1
  19. package/dist/assets/{Index-Co_pnNJh.js → Index-05qa1gOC.js} +1 -1
  20. package/dist/assets/{Index-D_hiDGh4.js → Index-B8H2_z9_.js} +1 -1
  21. package/dist/assets/{Index-DGWrLTJE.js → Index-B9wup2zp.js} +1 -1
  22. package/dist/assets/{Index-D-FyzuHL.js → Index-BCYh1z7D.js} +1 -1
  23. package/dist/assets/{Index-BJvLg-Hr.js → Index-BJ5FlOXw.js} +1 -1
  24. package/dist/assets/{Index-DYOr_Bw7.js → Index-BJFLDUCM.js} +1 -1
  25. package/dist/assets/{Index-003wVSFJ.js → Index-BRWua7Pn.js} +1 -1
  26. package/dist/assets/{Index-Dd_knVh2.js → Index-BS_kWluw.js} +1 -1
  27. package/dist/assets/{Index-BW8qTV1f.js → Index-Be7Y4LIt.js} +1 -1
  28. package/dist/assets/{Index-DWP04HF5.js → Index-Bi4e1Cno.js} +1 -1
  29. package/dist/assets/{Index-CJEPmWEY.js → Index-CEt4sPAp.js} +1 -1
  30. package/dist/assets/{Index-58Qi_cxL.js → Index-CKtL81ue.js} +1 -1
  31. package/dist/assets/{Index-ChYFpwVJ.js → Index-CLgbPHLC.js} +1 -1
  32. package/dist/assets/{Index-BrduSgiQ.js → Index-CpdPDUM5.js} +1 -1
  33. package/dist/assets/{Index-DiYieqdu.js → Index-D1ObDODx.js} +1 -1
  34. package/dist/assets/{Index-CoK7DoWH.js → Index-DREci_3x.js} +1 -1
  35. package/dist/assets/{Index-BiOdQRhK.js → Index-DbNh8zrA.js} +1 -1
  36. package/dist/assets/{Index-COq5-NwQ.js → Index-Di-zu-p8.js} +1 -1
  37. package/dist/assets/{Index-DoxQqJpi.js → Index-DlZMH8SN.js} +1 -1
  38. package/dist/assets/{Index-DufJ3B-d.js → Index-DuiQE6-J.js} +1 -1
  39. package/dist/assets/{Index-BNbbHJf8.js → Index-N6d4HE9o.js} +1 -1
  40. package/dist/assets/{Index-D2ngXf5t.js → Index-VyvPGs_5.js} +1 -1
  41. package/dist/assets/{Index-BvbAkbHv.js → Index-d635oMC0.js} +1 -1
  42. package/dist/assets/{Index-CvGz__yA.js → Index-irgLZ7_Q.js} +1 -1
  43. package/dist/assets/{Index-BDmOZ8BK.js → Index-twlRmX4y.js} +1 -1
  44. package/dist/assets/Index-vDMn1c6V.js +1 -0
  45. package/dist/assets/{Invitees-C9f8nrLG.js → Invitees-C0R3g-Zf.js} +1 -1
  46. package/dist/assets/{List-8yNIAZjy.js → List-D6nFAmNC.js} +1 -1
  47. package/dist/assets/{List-CVJX6_3D.js → List-DWwcbcPH.js} +1 -1
  48. package/dist/assets/{List-CEy3lIJ0.js → List-DiYo0Int.js} +1 -1
  49. package/dist/assets/{Main-3tlzviLh.js → Main-DXUAcE9k.js} +1 -1
  50. package/dist/assets/{Model-uD01Jd7q.js → Model-CqYI1sS8.js} +1 -1
  51. package/dist/assets/{Navigator-Bvk7Sg3-.js → Navigator-C2kRAciX.js} +1 -1
  52. package/dist/assets/{NoTasks-BHtlhARF.js → NoTasks-Dk1WXppl.js} +1 -1
  53. package/dist/assets/{NotFound-DRX8DGal.js → NotFound-Bqzv83rR.js} +1 -1
  54. package/dist/assets/{Pagination-BkCNO3tT.js → Pagination-DYjyzEjF.js} +1 -1
  55. package/dist/assets/{Pay-BmHZYxVZ.js → Pay-DKdYx4a8.js} +1 -1
  56. package/dist/assets/{Player-DbKLHWva.js → Player-5nZKlwHx.js} +1 -1
  57. package/dist/assets/{Seedance-DaK5gz1R.js → Seedance-CNYLui9X.js} +1 -1
  58. package/dist/assets/{Status-CFr2tKQI.js → Status-Dx6FNAbD.js} +1 -1
  59. package/dist/assets/{Subscribe-BSt9SGNx.js → Subscribe-Q4ATea2Y.js} +1 -1
  60. package/dist/assets/{TabSwitcher-BBJl8JER.js → TabSwitcher-BRab7qRM.js} +1 -1
  61. package/dist/assets/{Tts-aZSlB020.js → Tts-DegoQTKa.js} +1 -1
  62. package/dist/assets/{VideoPlayer-qDDLVH7_.js → VideoPlayer-BLPGe-uP.js} +1 -1
  63. package/dist/assets/{avatar-eCfCXYQZ.js → avatar-TKtEO4Yl.js} +1 -1
  64. package/dist/assets/{basic-BkjEs-9l.js → basic-Db4GCedU.js} +1 -1
  65. package/dist/assets/{chat-gDB9t_v4.js → chat-C6NbygCS.js} +1 -1
  66. package/dist/assets/codingBridge-Df_5ydBi.js +2 -0
  67. package/dist/assets/{codingBridgeNotify-Bi55q9w-.js → codingBridgeNotify-4sUlZ3Lg.js} +2 -2
  68. package/dist/assets/{collapse-CMbK4fuu.js → collapse-BH0qROl8.js} +1 -1
  69. package/dist/assets/{createTaskActions-arWCKP9k.js → createTaskActions-xgaPM_qk.js} +1 -1
  70. package/dist/assets/{date-picker-Cltk5CTY.js → date-picker-DnWtfIDn.js} +1 -1
  71. package/dist/assets/{dropdown-DAFrPSyk.js → dropdown-BpL2qpyg.js} +1 -1
  72. package/dist/assets/{esm-BA04Lj3L.js → esm-D7H9sAYC.js} +3 -3
  73. package/dist/assets/{esm-DeGD4J_f.js → esm-D8MgG7kP.js} +1 -1
  74. package/dist/assets/{esm-QvpHdnog.js → esm-DRVKxMaD.js} +2 -2
  75. package/dist/assets/esm-I-Ydzkdh.js +1 -0
  76. package/dist/assets/{esm-DQZlBtbx.js → esm-SCvm8sjU.js} +2 -2
  77. package/dist/assets/{esm-Df6JthEK.js → esm-y0EduL6s.js} +1 -1
  78. package/dist/assets/{esm-B0wbogpo.js → esm-yeJT_40P.js} +1 -1
  79. package/dist/assets/{fish-C6pRkZNs.js → fish-C13ospyo.js} +1 -1
  80. package/dist/assets/{flux-BureCMjz.js → flux-CuTQgrEI.js} +1 -1
  81. package/dist/assets/{grokvideo-Be10n0vY.js → grokvideo-Cxkcup4s.js} +1 -1
  82. package/dist/assets/{hailuo-Chog44wU.js → hailuo-ld7fCVPo.js} +1 -1
  83. package/dist/assets/{headshots-924vcn5Y.js → headshots-BmUEgkoj.js} +1 -1
  84. package/dist/assets/{image-D5iIL2A6.js → image-CjzS-up0.js} +1 -1
  85. package/dist/assets/{index-uml6ohnH.js → index-BY8YIwDb.js} +3 -3
  86. package/dist/assets/{index.browser.esm-BY9GuW-m.js → index.browser.esm-li52u8xd.js} +1 -1
  87. package/dist/assets/{index.es-CcQaWbuV.js → index.es-CH5vwGaN.js} +1 -1
  88. package/dist/assets/{input-number-DmUFZAko.js → input-number-N0auilju.js} +1 -1
  89. package/dist/assets/{kling-BHZFLFYK.js → kling-COeQELLT.js} +1 -1
  90. package/dist/assets/{luma-Dcv_K5RA.js → luma-sQSQhtbj.js} +1 -1
  91. package/dist/assets/{midjourney-DCMb48nF.js → midjourney-CTQ-KItL.js} +1 -1
  92. package/dist/assets/{nanobanana-DwRFnrye.js → nanobanana-C22a0oYN.js} +1 -1
  93. package/dist/assets/{openaiimage-CLwqhOGr.js → openaiimage-Dq7MWBVX.js} +1 -1
  94. package/dist/assets/{pagination-BUM1iMKs.js → pagination-CjEVtILV.js} +1 -1
  95. package/dist/assets/{pika-DAgJisHy.js → pika-DU0QitGG.js} +1 -1
  96. package/dist/assets/{pixverse-C-TM8aUs.js → pixverse-C-xOT5MG.js} +1 -1
  97. package/dist/assets/{popover-CyCHcVkr.js → popover-1vWQQB0V.js} +1 -1
  98. package/dist/assets/{producer-bq3G_r4Z.js → producer-BGA_s87O.js} +1 -1
  99. package/dist/assets/{qrart-B2vZfZTU.js → qrart-tF6e5Ure.js} +1 -1
  100. package/dist/assets/{row-B7CXMj6b.js → row-JqIo0dw3.js} +1 -1
  101. package/dist/assets/{seedance-CL3W8t39.js → seedance-CPhZgXeS.js} +1 -1
  102. package/dist/assets/{seedream-DS0jiQwY.js → seedream-DueKINO1.js} +1 -1
  103. package/dist/assets/{select-CtOUS-1J.js → select-B14L-681.js} +1 -1
  104. package/dist/assets/{serp-CId26TBB.js → serp-DKsD2P4f.js} +1 -1
  105. package/dist/assets/{slider-Cr206S1m.js → slider-ypi7YrnL.js} +1 -1
  106. package/dist/assets/{solana-wallets-uKka48OL.js → solana-wallets-B-Ar3QV5.js} +2 -2
  107. package/dist/assets/{solana-wallets-vue-B_sh8k8r.js → solana-wallets-vue-BxEXL9wo.js} +1 -1
  108. package/dist/assets/{sora-CBCoTEze.js → sora-Bvuj-CwF.js} +1 -1
  109. package/dist/assets/{suno-BxABW3Fo.js → suno-DBUXJjOG.js} +1 -1
  110. package/dist/assets/{switch-D43pwmQF.js → switch-Dir3SgN_.js} +1 -1
  111. package/dist/assets/{tabs-B9RXb3Mw.js → tabs-CllsgUVI.js} +1 -1
  112. package/dist/assets/{upload-CnVhrWBT.js → upload-CgRMUkQi.js} +1 -1
  113. package/dist/assets/{veo-CFkAWwwa.js → veo-DJcppRgO.js} +1 -1
  114. package/dist/assets/{wan-BAsIAxdr.js → wan-CXX5Z70L.js} +1 -1
  115. package/dist/assets/{web-DwGrAYkm.js → web-AJVUYB9i.js} +1 -1
  116. package/dist/assets/{web-B_OK9lb7.js → web-B9iHXzqN.js} +1 -1
  117. package/dist/assets/{web-DerH3-Qz.js → web-Bgfp9ZAB.js} +1 -1
  118. package/dist/assets/{web-C3b7WxdC.js → web-Cr9qE3HH.js} +1 -1
  119. package/dist/assets/{web-DmBwudd1.js → web-jBZ5VzL9.js} +1 -1
  120. package/dist/assets/{webextrator-4c9pQKbi.js → webextrator-CXlTr4A9.js} +1 -1
  121. package/dist/index.html +1 -1
  122. package/package.json +1 -1
  123. package/dist/assets/Index-CRbLsroT.js +0 -1
  124. package/dist/assets/codingBridge-DmIjokyi.js +0 -2
  125. package/dist/assets/esm-wjnzAblK.js +0 -1
@@ -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-CtOUS-1J.js";import{n as E,t as D}from"./tabs-B9RXb3Mw.js";import{t as O}from"./upload-CnVhrWBT.js";import{t as k}from"./tooltip-C3PYfh8V.js";import{t as A}from"./image-D5iIL2A6.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-CMbK4fuu.js";import{t as F}from"./drawer-BvYPSxXh.js";import{n as I,r as te,t as ne}from"./dropdown-DAFrPSyk.js";import{t as L}from"./input-number-DmUFZAko.js";import{n as re,t as ie}from"./skeleton-Cn4UY-T8.js";import{t as ae}from"./slider-Cr206S1m.js";import{t as oe}from"./switch-D43pwmQF.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-uml6ohnH.js";import{t as X}from"./index.es-CcQaWbuV.js";import{n as le}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Z,n as ue,r as de,t as fe}from"./pagination-BUM1iMKs.js";import{n as pe,t as me}from"./NoTasks-BHtlhARF.js";import{t as he}from"./Consumption-Dlo2Ec9d.js";import{n as ge,r as Q,t as _e}from"./Player-DbKLHWva.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-B14L-681.js";import{n as E,t as D}from"./tabs-CllsgUVI.js";import{t as O}from"./upload-CgRMUkQi.js";import{t as k}from"./tooltip-C3PYfh8V.js";import{t as A}from"./image-CjzS-up0.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-BH0qROl8.js";import{t as F}from"./drawer-BvYPSxXh.js";import{n as I,r as te,t as ne}from"./dropdown-BpL2qpyg.js";import{t as L}from"./input-number-N0auilju.js";import{n as re,t as ie}from"./skeleton-Cn4UY-T8.js";import{t as ae}from"./slider-ypi7YrnL.js";import{t as oe}from"./switch-Dir3SgN_.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-BY8YIwDb.js";import{t as X}from"./index.es-CH5vwGaN.js";import{n as le}from"./taskDrawerMixin-Cr17Yxqk.js";import{i as Z,n as ue,r as de,t as fe}from"./pagination-CjEVtILV.js";import{n as pe,t as me}from"./NoTasks-Dk1WXppl.js";import{t as he}from"./Consumption-QfvilMcG.js";import{n as ge,r as Q,t as _e}from"./Player-5nZKlwHx.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{$ as e,Bt as t,D as n,E as r,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,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{t as y}from"./upload-CnVhrWBT.js";import{t as b}from"./tooltip-C3PYfh8V.js";import{t as x}from"./image-D5iIL2A6.js";import{t as S}from"./alert-BJj7gY4q.js";import{t as C}from"./drawer-BvYPSxXh.js";import{t as w}from"./switch-D43pwmQF.js";import{pi as T}from"./constants-C-bSXdJ_.js";import{At as E,E as D,Fn as O,Nt as ee,Ot as k,Sr as A,hn as j,jt as M,kr as N,kt as P,yr as F}from"./index-uml6ohnH.js";import{t as I}from"./index.es-CcQaWbuV.js";import{t as te}from"./CopyToClipboard-Dnrr0G1l.js";import{t as L}from"./FilePreview-BSXA8G7D.js";import{t as R}from"./ImagePreview-D9ovswSr.js";import{n as z}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as B}from"./BotPlaceholder-By9wptjP.js";import{i as V,n as H,t as U}from"./pagination-BUM1iMKs.js";import{n as W,t as G}from"./NoTasks-BHtlhARF.js";import{t as K}from"./Consumption-Dlo2Ec9d.js";import{t as q}from"./ApiCodeButton-CYsbafW5.js";import{t as J}from"./VideoPlayer-qDDLVH7_.js";var Y=s({name:`LayoutLuma`,components:{ElDrawer:C,ElButton:v,FontAwesomeIcon:I},mixins:[z]}),X={class:`main flex flex-row flex-1`},Z={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Q={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ne(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,X,[r(`div`,Z,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,Q,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var re=D(Y,[[`render`,ne],[`__scopeId`,`data-v-da4bcd3a`]]),ie=s({name:`EnhancementSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug(`set enhancement`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=!0)}}),ae={class:`relative`},oe={class:`flex justify-between`},se={class:`flex justify-start items-center`},ce={class:`text-sm font-bold`},le={class:`flex justify-end items-center`};function ue(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,ae,[r(`div`,oe,[r(`div`,se,[r(`span`,ce,l(e.$t(`luma.name.enhancement`)),1),a(c,{content:e.$t(`luma.description.enhancement`)},null,8,[`content`])]),r(`div`,le,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var de=D(ie,[[`render`,ue]]),fe=s({name:`CustomSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug(`set custom`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),pe={class:`relative`},me={class:`flex justify-between`},he={class:`flex justify-start items-center`},ge={class:`text-sm font-bold`},_e={class:`flex justify-end items-center`};function ve(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,pe,[r(`div`,me,[r(`div`,he,[r(`span`,ge,l(e.$t(`luma.name.custom`)),1),a(c,{content:e.$t(`luma.description.custom`)},null,8,[`content`])]),r(`div`,_e,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var ye=D(fe,[[`render`,ve]]),be=s({name:`LoopSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug(`set loop`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),xe={class:`relative`},Se={class:`flex justify-between`},Ce={class:`flex justify-start items-center`},we={class:`text-sm font-bold`},Te={class:`flex justify-end items-center`};function Ee(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,xe,[r(`div`,Se,[r(`div`,Ce,[r(`span`,we,l(e.$t(`luma.name.loop`)),1),a(c,{content:e.$t(`luma.description.loop`)},null,8,[`content`])]),r(`div`,Te,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var De=D(be,[[`render`,Ee]]),Oe=s({name:`EndImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/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?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetEndImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetEndImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ke={class:`relative`},Ae={class:`flex justify-between`},je={class:`flex justify-start items-center`},Me={class:`text-sm font-bold`};function Ne(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,ke,[r(`div`,Ae,[r(`div`,je,[r(`span`,Me,l(e.$t(`luma.name.endImageUrl`)),1),a(g,{content:e.$t(`luma.description.endImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(_,{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(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadEndImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Pe=D(Oe,[[`render`,Ne],[`__scopeId`,`data-v-cd768b26`]]),Fe=s({name:`StartImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/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?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ie={class:`relative`},Le={class:`flex justify-between`},Re={class:`flex justify-start items-center`},ze={class:`text-sm font-bold`};function Be(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ie,[r(`div`,Le,[r(`div`,Re,[r(`span`,ze,l(e.$t(`luma.name.startImageUrl`)),1),a(g,{content:e.$t(`luma.description.startImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{key:0,url:t.url||t.response.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Ve=D(Fe,[[`render`,Be],[`__scopeId`,`data-v-4d03e978`]]),He=s({name:`UploadVideo`,components:{ElUpload:y,ElButton:v,InfoIcon:V,FilePreview:L,FontAwesomeIcon:I},mixins:[P],data(){return{fileList:[],uploadUrl:A()+`/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.luma?.config?.video_url},set(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||=void 0},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadVideoExceed`))},onError(){N.error(this.$t(`luma.message.uploadVideoError`))},beforeUpload(e){let t=e.type===`video/mp4`,n=e.size/1024/1024<10;return t?n?!0:(N.error(this.$t(`luma.message.uploadVideoSizeExceed`)),!1):(N.error(this.$t(`luma.message.uploadVideoTypeFailed`)),!1)},onSetVideoUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e,action:`extend`})},async onSuccess(){this.onSetVideoUrl()}}}),Ue={class:`relative`},We={class:`flex justify-between`},Ge={class:`flex justify-start items-center`},Ke={class:`text-sm font-bold`};function qe(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`file-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ue,[r(`div`,We,[r(`div`,Ge,[r(`span`,Ke,l(e.$t(`luma.name.videoUrl`)),1),a(g,{content:e.$t(`luma.description.videoUrl`)},null,8,[`content`])])]),a(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.mp4`,name:`file`,class:`value`,"show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{key:0,url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadVideoUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`before-upload`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Je=D(He,[[`render`,qe],[`__scopeId`,`data-v-b4c637fa`]]),Ye=s({name:`PromptInput`,components:{PromptTextarea:W},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`luma.name.prompt`),info:e.$t(`luma.description.prompt`),placeholder:e.$t(`luma.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ze=D(Ye,[[`render`,Xe]]),Qe=s({name:`ExtendFromInput`,components:{VideoPlayer:J},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:`1080p`}}}},computed:{config(){return this.$store.state.luma?.config}}}),$e={class:`relative`},et={class:`flex mb-2`},tt={class:`text-sm font-bold`};function nt(e,t,i,a,s,c){let d=f(`video-player`);return u(),p(`div`,$e,[r(`div`,et,[r(`span`,tt,l(e.$t(`luma.name.extend`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(d,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var rt=s({name:`ConfigPanel`,components:{LoopSelector:De,StartImageInput:Ve,EndImageInput:Pe,EnhancementSelector:de,ElButton:v,FontAwesomeIcon:I,PromptInput:Ze,ExtendFromInput:D(Qe,[[`render`,nt]]),CustomSelector:ye,UploadVideo:Je,Consumption:K},emits:[`generate`],computed:{config(){return this.$store.state.luma?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),it={class:`flex flex-col h-full`},at={class:`flex-1 overflow-y-auto p-5`},ot={class:`flex flex-col items-center justify-center px-5 pb-5`};function st(e,t,s,c,d,h){let g=f(`extend-from-input`),_=f(`prompt-input`),v=f(`custom-selector`),y=f(`upload-video`),b=f(`start-image-input`),x=f(`end-image-input`),S=f(`enhancement-selector`),C=f(`loop-selector`),w=f(`consumption`),T=f(`font-awesome-icon`),E=f(`el-button`);return u(),p(`div`,it,[r(`div`,at,[e.config?.video_id||e.config?.video_url?(u(),n(g,{key:0,class:`mb-4`})):o(``,!0),a(_,{class:`mb-4`}),e.config?.video_id?o(``,!0):(u(),n(v,{key:1,class:`mb-4`})),e.config?.custom?(u(),n(y,{key:2,class:`mb-4`})):o(``,!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(u(),n(b,{key:3,class:`mb-4`})):o(``,!0),a(x,{class:`mb-4`}),a(S,{class:`mb-4`}),a(C,{class:`mb-4`})]),r(`div`,ot,[a(w,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(u(),n(E,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.extend`)),1)]),_:1},8,[`onClick`])):(u(),n(E,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var ct=D(rt,[[`render`,st]]),lt=s({name:`TaskPreview`,components:{ElImage:x,CopyToClipboard:te,FontAwesomeIcon:I,ElAlert:S,VideoPlayer:J,ElTooltip:b,ElButton:v,ApiCodeButton:q},props:{modelValue:{type:Object,required:!0}},emits:[`extend`],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug(`set config`,t),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:`extend`,thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit(`extend`)},onDownload(e){window.open(e,`_blank`)}}}),ut={class:`preview`},dt={class:`left`},ft={class:`main`},pt={class:`bot`},mt={class:`datetime`},ht={class:`info`},gt={key:0,class:`prompt mt-2`},_t={key:0},vt={key:1},yt={key:0,class:t({content:!0,failed:!0})},bt={key:0,class:`mb-4`},xt={key:1,class:t({operations:!0,"mt-2":!0,"mb-4":!0})},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},wt={key:1,class:t({content:!0})},Tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ot={key:2,class:t({content:!0})},kt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function At(e,t,n,s,c,d){let h=f(`el-image`),g=f(`video-player`),v=f(`el-button`),y=f(`el-tooltip`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,ut,[r(`div`,dt,[a(h,{src:`https://cdn.acedata.cloud/ahjfwi.png`,class:`avatar`})]),r(`div`,ft,[r(`div`,pt,[i(l(e.$t(`luma.name.lumaBot`))+` `,1),r(`span`,mt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,ht,[e.modelValue?.request?.prompt?(u(),p(`p`,gt,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,_t,` - (`+l(e.$t(`luma.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`span`,vt,` - (`+l(e.$t(`luma.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,yt,[e.modelValue.response.video_url?(u(),p(`div`,bt,[a(g,{src:e.modelValue.response.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response&&!e.config?.custom?(u(),p(`div`,xt,[a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.extendVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onExtend(t,e.modelValue?.response),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.extend`)),1)]),_:1})]),_:1},8,[`content`]),a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.downloadVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=_(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(b,{path:`/luma/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,St,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Ct,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.state===`failed`||e.modelValue?.response?.success===!1?(u(),p(`div`,wt,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,Tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,Et,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,Dt,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.traceId`))+`: `+l(e.modelValue?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):o(``,!0),!e.modelValue?.response||e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`div`,Ot,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,kt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var jt=s({name:`RecentPanel`,components:{BotPlaceholder:B,TaskPreview:D(lt,[[`render`,At],[`__scopeId`,`data-v-9c354ffe`]]),NoTasks:G,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`,`extend`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mt={key:0},Nt={key:2,class:`w-full h-full flex items-center justify-center`};function Pt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Mt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:t[1]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,r=>(u(),n(h,{key:r.id,"model-value":r,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Nt,[a(v)])):o(``,!0)],64)}var Ft=D(jt,[[`render`,Pt]]),It=T(`luma`),Lt=s({name:`LumaIndex`,components:{ConfigPanel:ct,Layout:re,RecentPanel:Ft},mixins:[E],inject:[`initialized`],emits:[`extend`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===F.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.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 U({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(`luma/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`luma/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){console.debug(`scrolling down`),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(`luma/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!k(this.uploadTracker,e=>this.$t(e),e=>N.warning(e)))return;let e={...this.config,callback_url:It};if(!this.hasText(e.prompt)){N.error(this.$t(`luma.message.promptRequired`));return}e.prompt=e.prompt?.trim();let t=this.credential?.token;if(!t){console.error(`no token specified`);return}N.info(this.$t(`luma.message.startingTask`)),O(`luma`,j.generate(e,{token:t})).then(()=>{N.success(this.$t(`luma.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?N.error(this.$t(`luma.message.usedUp`)):N.error(this.$t(`luma.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Rt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`loading`,`onReachTop`])]),_:1})}var zt=D(Lt,[[`render`,Rt]]);export{zt as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,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,y as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{t as y}from"./upload-CgRMUkQi.js";import{t as b}from"./tooltip-C3PYfh8V.js";import{t as x}from"./image-CjzS-up0.js";import{t as S}from"./alert-BJj7gY4q.js";import{t as C}from"./drawer-BvYPSxXh.js";import{t as w}from"./switch-Dir3SgN_.js";import{pi as T}from"./constants-C-bSXdJ_.js";import{At as E,E as D,Fn as O,Nt as ee,Ot as k,Sr as A,hn as j,jt as M,kr as N,kt as P,yr as F}from"./index-BY8YIwDb.js";import{t as I}from"./index.es-CH5vwGaN.js";import{t as te}from"./CopyToClipboard-C8gyDUMn.js";import{t as L}from"./FilePreview-sx756NB5.js";import{t as R}from"./ImagePreview-DkXTeOKK.js";import{n as z}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as B}from"./BotPlaceholder-BVXWzbpi.js";import{i as V,n as H,t as U}from"./pagination-CjEVtILV.js";import{n as W,t as G}from"./NoTasks-Dk1WXppl.js";import{t as K}from"./Consumption-QfvilMcG.js";import{t as q}from"./ApiCodeButton-DpYCu-EK.js";import{t as J}from"./VideoPlayer-BLPGe-uP.js";var Y=s({name:`LayoutLuma`,components:{ElDrawer:C,ElButton:v,FontAwesomeIcon:I},mixins:[z]}),X={class:`main flex flex-row flex-1`},Z={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},Q={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ne(t,n,i,o,s,c){let l=f(`font-awesome-icon`),g=f(`el-button`),_=f(`el-drawer`);return u(),p(`div`,X,[r(`div`,Z,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,Q,[e(t.$slots,`result`,{},void 0,!0)]),h(a(g,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:m(()=>[a(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[d,!t.tasksEmpty]]),a(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`,class:`drawer`},{default:m(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var re=D(Y,[[`render`,ne],[`__scopeId`,`data-v-da4bcd3a`]]),ie=s({name:`EnhancementSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.enhancement},set(e){console.debug(`set enhancement`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,enhancement:e})}}},mounted(){this.value===void 0&&(this.value=!0)}}),ae={class:`relative`},oe={class:`flex justify-between`},se={class:`flex justify-start items-center`},ce={class:`text-sm font-bold`},le={class:`flex justify-end items-center`};function ue(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,ae,[r(`div`,oe,[r(`div`,se,[r(`span`,ce,l(e.$t(`luma.name.enhancement`)),1),a(c,{content:e.$t(`luma.description.enhancement`)},null,8,[`content`])]),r(`div`,le,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var de=D(ie,[[`render`,ue]]),fe=s({name:`CustomSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.custom},set(e){console.debug(`set custom`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,custom:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),pe={class:`relative`},me={class:`flex justify-between`},he={class:`flex justify-start items-center`},ge={class:`text-sm font-bold`},_e={class:`flex justify-end items-center`};function ve(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,pe,[r(`div`,me,[r(`div`,he,[r(`span`,ge,l(e.$t(`luma.name.custom`)),1),a(c,{content:e.$t(`luma.description.custom`)},null,8,[`content`])]),r(`div`,_e,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var ye=D(fe,[[`render`,ve]]),be=s({name:`LoopSelector`,components:{ElSwitch:w,InfoIcon:V},computed:{value:{get(){return this.$store.state.luma?.config?.loop},set(e){console.debug(`set loop`,e),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,loop:e})}}},mounted(){this.value===void 0&&(this.value=!1)}}),xe={class:`relative`},Se={class:`flex justify-between`},Ce={class:`flex justify-start items-center`},we={class:`text-sm font-bold`},Te={class:`flex justify-end items-center`};function Ee(e,t,n,i,o,s){let c=f(`info-icon`),d=f(`el-switch`);return u(),p(`div`,xe,[r(`div`,Se,[r(`div`,Ce,[r(`span`,we,l(e.$t(`luma.name.loop`)),1),a(c,{content:e.$t(`luma.description.loop`)},null,8,[`content`])]),r(`div`,Te,[a(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])])])}var De=D(be,[[`render`,Ee]]),Oe=s({name:`EndImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/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?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetEndImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetEndImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ke={class:`relative`},Ae={class:`flex justify-between`},je={class:`flex justify-start items-center`},Me={class:`text-sm font-bold`};function Ne(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,ke,[r(`div`,Ae,[r(`div`,je,[r(`span`,Me,l(e.$t(`luma.name.endImageUrl`)),1),a(g,{content:e.$t(`luma.description.endImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.url&&t.percentage!==void 0?(u(),n(_,{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(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadEndImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Pe=D(Oe,[[`render`,Ne],[`__scopeId`,`data-v-cd768b26`]]),Fe=s({name:`StartImage`,components:{ElUpload:y,ElButton:v,ImagePreview:R,InfoIcon:V,FontAwesomeIcon:I},mixins:[M,P],data(){return{fileList:[],uploadUrl:A()+`/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?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||=void 0,this.onSetStartImageUrl()},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadReferencesExceed`))},onError(){N.error(this.$t(`luma.message.uploadReferencesError`))},onSetStartImageUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),Ie={class:`relative`},Le={class:`flex justify-between`},Re={class:`flex justify-start items-center`},ze={class:`text-sm font-bold`};function Be(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`image-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ie,[r(`div`,Le,[r(`div`,Re,[r(`span`,ze,l(e.$t(`luma.name.startImageUrl`)),1),a(g,{content:e.$t(`luma.description.startImageUrl`)},null,8,[`content`])])]),a(b,{ref:`uploader`,"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,name:`file`,accept:`.png,.jpg,.jpeg,.gif,.bmp,.webp`,limit:5,class:`upload-wrapper`,multiple:!1,action:e.uploadUrl,"list-type":`picture`,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{key:0,url:t.url||t.response.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadStartImageUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Ve=D(Fe,[[`render`,Be],[`__scopeId`,`data-v-4d03e978`]]),He=s({name:`UploadVideo`,components:{ElUpload:y,ElButton:v,InfoIcon:V,FilePreview:L,FontAwesomeIcon:I},mixins:[P],data(){return{fileList:[],uploadUrl:A()+`/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.luma?.config?.video_url},set(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||=void 0},methods:{onExceed(){N.warning(this.$t(`luma.message.uploadVideoExceed`))},onError(){N.error(this.$t(`luma.message.uploadVideoError`))},beforeUpload(e){let t=e.type===`video/mp4`,n=e.size/1024/1024<10;return t?n?!0:(N.error(this.$t(`luma.message.uploadVideoSizeExceed`)),!1):(N.error(this.$t(`luma.message.uploadVideoTypeFailed`)),!1)},onSetVideoUrl(){let e=this.urls?.[0];this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_url:e,action:`extend`})},async onSuccess(){this.onSetVideoUrl()}}}),Ue={class:`relative`},We={class:`flex justify-between`},Ge={class:`flex justify-start items-center`},Ke={class:`text-sm font-bold`};function qe(e,t,s,c,d,h){let g=f(`info-icon`),_=f(`file-preview`),v=f(`font-awesome-icon`),y=f(`el-button`),b=f(`el-upload`);return u(),p(`div`,Ue,[r(`div`,We,[r(`div`,Ge,[r(`span`,Ke,l(e.$t(`luma.name.videoUrl`)),1),a(g,{content:e.$t(`luma.description.videoUrl`)},null,8,[`content`])])]),a(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||=t=>e.fileList=t,accept:`.mp4`,name:`file`,class:`value`,"show-file-list":!0,limit:1,multiple:!1,action:e.uploadUrl,"before-upload":e.beforeUpload,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:m(({file:t})=>[t.percentage==null?o(``,!0):(u(),n(_,{key:0,url:t.url||t.response?.file_url,name:t.name,percentage:t.percentage,onRemove:n=>e.fileList.splice(e.fileList.indexOf(t),1)},null,8,[`url`,`name`,`percentage`,`onRemove`]))]),default:m(()=>[a(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:m(()=>[a(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),i(` `+l(e.$t(`luma.button.uploadVideoUrl`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`before-upload`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var Je=D(He,[[`render`,qe],[`__scopeId`,`data-v-b4c637fa`]]),Ye=s({name:`PromptInput`,components:{PromptTextarea:W},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Xe(e,t,r,i,a,o){let s=f(`prompt-textarea`);return u(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`luma.name.prompt`),info:e.$t(`luma.description.prompt`),placeholder:e.$t(`luma.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Ze=D(Ye,[[`render`,Xe]]),Qe=s({name:`ExtendFromInput`,components:{VideoPlayer:J},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:`1080p`}}}},computed:{config(){return this.$store.state.luma?.config}}}),$e={class:`relative`},et={class:`flex mb-2`},tt={class:`text-sm font-bold`};function nt(e,t,i,a,s,c){let d=f(`video-player`);return u(),p(`div`,$e,[r(`div`,et,[r(`span`,tt,l(e.$t(`luma.name.extend`)),1)]),r(`div`,null,[e.config?.video_url?(u(),n(d,{key:0,src:e.config?.video_url},null,8,[`src`])):o(``,!0)])])}var rt=s({name:`ConfigPanel`,components:{LoopSelector:De,StartImageInput:Ve,EndImageInput:Pe,EnhancementSelector:de,ElButton:v,FontAwesomeIcon:I,PromptInput:Ze,ExtendFromInput:D(Qe,[[`render`,nt]]),CustomSelector:ye,UploadVideo:Je,Consumption:K},emits:[`generate`],computed:{config(){return this.$store.state.luma?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),it={class:`flex flex-col h-full`},at={class:`flex-1 overflow-y-auto p-5`},ot={class:`flex flex-col items-center justify-center px-5 pb-5`};function st(e,t,s,c,d,h){let g=f(`extend-from-input`),_=f(`prompt-input`),v=f(`custom-selector`),y=f(`upload-video`),b=f(`start-image-input`),x=f(`end-image-input`),S=f(`enhancement-selector`),C=f(`loop-selector`),w=f(`consumption`),T=f(`font-awesome-icon`),E=f(`el-button`);return u(),p(`div`,it,[r(`div`,at,[e.config?.video_id||e.config?.video_url?(u(),n(g,{key:0,class:`mb-4`})):o(``,!0),a(_,{class:`mb-4`}),e.config?.video_id?o(``,!0):(u(),n(v,{key:1,class:`mb-4`})),e.config?.custom?(u(),n(y,{key:2,class:`mb-4`})):o(``,!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(u(),n(b,{key:3,class:`mb-4`})):o(``,!0),a(x,{class:`mb-4`}),a(S,{class:`mb-4`}),a(C,{class:`mb-4`})]),r(`div`,ot,[a(w,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),e.config?.video_url!==void 0||e.config?.custom?(u(),n(E,{key:0,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.extend`)),1)]),_:1},8,[`onClick`])):(u(),n(E,{key:1,type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:m(()=>[a(T,{icon:`fa-solid fa-magic`,class:`mr-2`}),i(` `+l(e.$t(`luma.button.generate`)),1)]),_:1},8,[`onClick`]))])])}var ct=D(rt,[[`render`,st]]),lt=s({name:`TaskPreview`,components:{ElImage:x,CopyToClipboard:te,FontAwesomeIcon:I,ElAlert:S,VideoPlayer:J,ElTooltip:b,ElButton:v,ApiCodeButton:q},props:{modelValue:{type:Object,required:!0}},emits:[`extend`],data(){return{}},computed:{application(){return this.$store.state.luma?.application},config(){return this.$store.state.luma?.config}},methods:{onExtend(e,t){console.debug(`set config`,t),this.$store.commit(`luma/setConfig`,{...this.$store.state.luma?.config,video_id:t.video_id,prompt:t.prompt,action:`extend`,thumbnail_url:t.thumbnail_url,video_url:t.video_url}),this.$emit(`extend`)},onDownload(e){window.open(e,`_blank`)}}}),ut={class:`preview`},dt={class:`left`},ft={class:`main`},pt={class:`bot`},mt={class:`datetime`},ht={class:`info`},gt={key:0,class:`prompt mt-2`},_t={key:0},vt={key:1},yt={key:0,class:t({content:!0,failed:!0})},bt={key:0,class:`mb-4`},xt={key:1,class:t({operations:!0,"mt-2":!0,"mb-4":!0})},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},wt={key:1,class:t({content:!0})},Tt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Et={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Dt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Ot={key:2,class:t({content:!0})},kt={class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function At(e,t,n,s,c,d){let h=f(`el-image`),g=f(`video-player`),v=f(`el-button`),y=f(`el-tooltip`),b=f(`api-code-button`),x=f(`font-awesome-icon`),S=f(`copy-to-clipboard`),C=f(`el-alert`);return u(),p(`div`,ut,[r(`div`,dt,[a(h,{src:`https://cdn.acedata.cloud/ahjfwi.png`,class:`avatar`})]),r(`div`,ft,[r(`div`,pt,[i(l(e.$t(`luma.name.lumaBot`))+` `,1),r(`span`,mt,l(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,ht,[e.modelValue?.request?.prompt?(u(),p(`p`,gt,[i(l(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?o(``,!0):(u(),p(`span`,_t,` - (`+l(e.$t(`luma.status.pending`))+`) `,1)),e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`span`,vt,` - (`+l(e.$t(`luma.status.processing`))+`) `,1)):o(``,!0)])):o(``,!0)]),e.modelValue?.response?.success===!0?(u(),p(`div`,yt,[e.modelValue.response.video_url?(u(),p(`div`,bt,[a(g,{src:e.modelValue.response.video_url},null,8,[`src`])])):o(``,!0),e.modelValue?.response&&!e.config?.custom?(u(),p(`div`,xt,[a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.extendVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=_(t=>e.onExtend(t,e.modelValue?.response),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.extend`)),1)]),_:1})]),_:1},8,[`content`]),a(y,{class:`box-item`,effect:`dark`,content:e.$t(`luma.message.downloadVideo`),placement:`top-start`},{default:m(()=>[a(v,{type:`info`,size:`small`,class:`btn-action`,onClick:t[1]||=_(t=>e.onDownload(e.modelValue?.response?.video_url),[`stop`])},{default:m(()=>[i(l(e.$t(`luma.button.download`)),1)]),_:1})]),_:1},8,[`content`]),a(b,{path:`/luma/videos`,body:e.modelValue?.request},null,8,[`body`])])):o(``,!0),a(C,{closable:!1,class:`mt-2 success`},{default:m(()=>[r(`p`,St,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,Ct,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0)]),_:1})])):o(``,!0),e.modelValue?.response?.state===`failed`||e.modelValue?.response?.success===!1?(u(),p(`div`,wt,[a(C,{closable:!1,class:`failure`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,Tt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,Et,[a(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failureReason`))+`: `+l(e.modelValue?.response?.error?.message)+` `,1),a(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(u(),p(`p`,$,[a(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.elapsed`))+`: `+l(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):o(``,!0),r(`p`,Dt,[a(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.traceId`))+`: `+l(e.modelValue?.trace_id)+` `,1),a(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])]),_:1})])):o(``,!0),!e.modelValue?.response||e.modelValue?.response?.state===`processing`||e.modelValue?.response?.state===`pending`?(u(),p(`div`,Ot,[a(C,{closable:!1,class:`info`},{template:m(()=>[a(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.failure`)),1)]),default:m(()=>[r(`p`,kt,[a(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),i(` `+l(e.$t(`luma.name.taskId`))+`: `+l(e.modelValue?.id)+` `,1),a(S,{content:e.modelValue?.id},null,8,[`content`])])]),_:1})])):o(``,!0)])])}var jt=s({name:`RecentPanel`,components:{BotPlaceholder:B,TaskPreview:D(lt,[[`render`,At],[`__scopeId`,`data-v-9c354ffe`]]),NoTasks:G,ScrollList:H},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`,`extend`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.luma?.tasks,items:this.$store.state.luma?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Mt={key:0},Nt={key:2,class:`w-full h-full flex items-center justify-center`};function Pt(e,t,r,i,s,l){let d=f(`bot-placeholder`),h=f(`task-preview`),_=f(`scroll-list`),v=f(`no-tasks`);return u(),p(g,null,[e.tasks?.items===void 0?(u(),p(`div`,Mt,[a(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(u(),n(_,{key:1,ref:`scrollList`,class:`tasks w-full h-full overflow-y-auto`,loading:e.loading,onReachTop:t[1]||=t=>e.$emit(`reach-top`)},{default:m(()=>[(u(!0),p(g,null,c(e.tasks?.items,r=>(u(),n(h,{key:r.id,"model-value":r,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):o(``,!0),e.tasks?.items?.length===0?(u(),p(`div`,Nt,[a(v)])):o(``,!0)],64)}var Ft=D(jt,[[`render`,Pt]]),It=T(`luma`),Lt=s({name:`LumaIndex`,components:{ConfigPanel:ct,Layout:re,RecentPanel:Ft},mixins:[E],inject:[`initialized`],emits:[`extend`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.luma?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.luma?.status?.getTasks===F.Request||this.fetchingTasks},credential(){return this.$store.state.luma.credential},config(){return this.$store.state.luma.config},application(){return this.$store.state.luma.application},tasks(){return this.$store.state.luma.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 U({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(`luma/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`luma/getApplications`),console.debug(`end onGetApplication`),await this.onGetTasks()},async onScrollDown(){console.debug(`scrolling down`),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(`luma/getTasks`,{limit:t,createdAtMin:n,createdAtMax:r})}finally{this.fetchingTasks=!1}},async onGenerate(){if(!k(this.uploadTracker,e=>this.$t(e),e=>N.warning(e)))return;let e={...this.config,callback_url:It};if(!this.hasText(e.prompt)){N.error(this.$t(`luma.message.promptRequired`));return}e.prompt=e.prompt?.trim();let t=this.credential?.token;if(!t){console.error(`no token specified`);return}N.info(this.$t(`luma.message.startingTask`)),O(`luma`,j.generate(e,{token:t})).then(()=>{N.success(this.$t(`luma.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?N.error(this.$t(`luma.message.usedUp`)):N.error(this.$t(`luma.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()},hasText(e){return typeof e==`string`&&e.trim().length>0}}});function Rt(e,t,r,i,o,s){let c=f(`config-panel`),l=f(`recent-panel`),d=f(`layout`);return u(),n(d,null,{config:m(()=>[a(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:m(()=>[a(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop,onExtend:t[0]||=t=>e.$emit(`extend`)},null,8,[`loading`,`onReachTop`])]),_:1})}var zt=D(Lt,[[`render`,Rt]]);export{zt as default};
@@ -1,2 +1,2 @@
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,v as m,x as h,y as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-CtOUS-1J.js";import{n as b,t as x}from"./tabs-B9RXb3Mw.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-D5iIL2A6.js";import{t as w}from"./alert-BJj7gY4q.js";import{n as T,r as E}from"./radio-IJQsW93X.js";import{n as D,t as O}from"./collapse-CMbK4fuu.js";import{t as k}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-DmUFZAko.js";import{t as te}from"./switch-D43pwmQF.js";import"./constants-C-bSXdJ_.js";import{E as A,Ir as j,Nt as M,kr as N,yr as P}from"./index-uml6ohnH.js";import{t as F}from"./index.es-CcQaWbuV.js";import{t as I}from"./CopyToClipboard-Dnrr0G1l.js";import{t as L}from"./Consumption-Dlo2Ec9d.js";var R=o({name:`LayoutWebextrator`,components:{ElDrawer:k,ElButton:_,FontAwesomeIcon:F},data(){return{drawer:!1}}}),z={class:`main flex flex-row flex-1`},B={class:`config w-[340px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},V={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function H(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,z,[n(`div`,B,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,V,[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-sliders`})]),_: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 U=A(R,[[`render`,H],[`__scopeId`,`data-v-f9e97e78`]]),W=o({name:`ModeSelector`,components:{ElRadioGroup:E,ElRadioButton:T,FontAwesomeIcon:F},computed:{value:{get(){return this.$store.state.webextrator?.config?.mode},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,mode:e})}}}}),G={class:`field`},K={class:`title font-bold`};function q(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-radio-button`),g=u(`el-radio-group`);return l(),f(`div`,G,[n(`h2`,K,c(e.$t(`webextrator.name.mode`)),1),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value w-full`},{default:p(()=>[i(h,{label:`extract`,value:`extract`},{default:p(()=>[i(m,{icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.extract`)),1)]),_:1}),i(h,{label:`render`,value:`render`},{default:p(()=>[i(m,{icon:`fa-solid fa-globe`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.render`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var J=A(W,[[`render`,q],[`__scopeId`,`data-v-31e6c11d`]]),Y=o({name:`UrlInput`,components:{ElInput:j},emits:[`submit`],computed:{url:{get(){return this.$store.state.webextrator?.config?.url||``},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,url:e})}}},methods:{onEnter(){this.$emit(`submit`)}}}),X={class:`field`},Z={class:`title font-bold`};function Q(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,X,[n(`h2`,Z,c(e.$t(`webextrator.name.url`)),1),i(d,{modelValue:e.url,"onUpdate:modelValue":t[0]||=t=>e.url=t,type:`textarea`,rows:2,class:`prompt`,placeholder:e.$t(`webextrator.placeholder.url`),onKeydown:m(g(e.onEnter,[`exact`,`prevent`]),[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeydown`])])}var ne=A(Y,[[`render`,Q],[`__scopeId`,`data-v-18488009`]]),re=o({name:`ExpectedTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{value:{get(){return this.$store.state.webextrator?.config?.expected_type},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,expected_type:e})}}},mounted(){this.value||=`general`}}),ie={class:`field`},ae={class:`title font-bold`};function oe(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,ie,[n(`h2`,ae,c(e.$t(`webextrator.name.expectedType`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`general`,label:e.$t(`webextrator.expectedType.general`)},null,8,[`label`]),i(d,{value:`article`,label:e.$t(`webextrator.expectedType.article`)},null,8,[`label`]),i(d,{value:`product`,label:e.$t(`webextrator.expectedType.product`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var se=A(re,[[`render`,oe],[`__scopeId`,`data-v-3b572c49`]]),ce=o({name:`LlmToggle`,components:{ElSwitch:te,ElTooltip:S,FontAwesomeIcon:F},computed:{value:{get(){return!!this.$store.state.webextrator?.config?.enable_llm},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,enable_llm:e})}}}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-tooltip`),g=u(`el-switch`);return l(),f(`div`,le,[n(`h2`,ue,[r(c(e.$t(`webextrator.name.enableLlm`))+` `,1),i(h,{effect:`dark`,content:e.$t(`webextrator.description.enableLlm`),placement:`top`},{default:p(()=>[i(m,{icon:`fa-solid fa-circle-info`,class:`ml-1 text-[var(--el-text-color-secondary)] text-xs`})]),_:1},8,[`content`])]),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-32fa7c89`]]),pe=[`image`,`font`,`media`,`stylesheet`,`xhr`,`fetch`],me=o({name:`AdvancedOptions`,components:{ElCollapse:O,ElCollapseItem:D,ElInput:j,ElInputNumber:ee,ElSelect:v,ElOption:y},data(){return{active:[]}},computed:{resourceKinds(){return pe},waitUntil:{get(){return this.$store.state.webextrator?.config?.wait_until||`networkidle`},set(e){this.commit({wait_until:e})}},waitForSelector:{get(){return this.$store.state.webextrator?.config?.wait_for_selector||``},set(e){this.commit({wait_for_selector:e})}},timeout:{get(){return this.$store.state.webextrator?.config?.timeout??30},set(e){this.commit({timeout:e})}},delay:{get(){return this.$store.state.webextrator?.config?.delay??0},set(e){this.commit({delay:e})}},blockResources:{get(){return this.$store.state.webextrator?.config?.block_resources||[]},set(e){this.commit({block_resources:e})}}},methods:{commit(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,...e})}}}),he={class:`field`},ge={class:`sub-title`},_e={class:`field`},ve={class:`sub-title`},ye={class:`field`},be={class:`sub-title`},xe={class:`field`},Se={class:`sub-title`},Ce={class:`field`},we={class:`sub-title`};function Te(e,r,a,o,d,m){let g=u(`el-option`),_=u(`el-select`),v=u(`el-input`),y=u(`el-input-number`),b=u(`el-collapse-item`),x=u(`el-collapse`);return l(),t(x,{modelValue:e.active,"onUpdate:modelValue":r[5]||=t=>e.active=t,class:`advanced`},{default:p(()=>[i(b,{title:e.$t(`webextrator.name.advanced`),name:`advanced`},{default:p(()=>[n(`div`,he,[n(`h2`,ge,c(e.$t(`webextrator.name.waitUntil`)),1),i(_,{modelValue:e.waitUntil,"onUpdate:modelValue":r[0]||=t=>e.waitUntil=t,class:`value`},{default:p(()=>[i(g,{value:`networkidle`,label:e.$t(`webextrator.waitUntil.networkidle`)},null,8,[`label`]),i(g,{value:`load`,label:e.$t(`webextrator.waitUntil.load`)},null,8,[`label`]),i(g,{value:`domcontentloaded`,label:e.$t(`webextrator.waitUntil.domcontentloaded`)},null,8,[`label`]),i(g,{value:`commit`,label:e.$t(`webextrator.waitUntil.commit`)},null,8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,_e,[n(`h2`,ve,c(e.$t(`webextrator.name.waitForSelector`)),1),i(v,{modelValue:e.waitForSelector,"onUpdate:modelValue":r[1]||=t=>e.waitForSelector=t,placeholder:e.$t(`webextrator.placeholder.waitForSelector`)},null,8,[`modelValue`,`placeholder`])]),n(`div`,ye,[n(`h2`,be,c(e.$t(`webextrator.name.timeout`)),1),i(y,{modelValue:e.timeout,"onUpdate:modelValue":r[2]||=t=>e.timeout=t,min:1,max:120,step:5,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,xe,[n(`h2`,Se,c(e.$t(`webextrator.name.delay`)),1),i(y,{modelValue:e.delay,"onUpdate:modelValue":r[3]||=t=>e.delay=t,min:0,max:30,step:1,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,Ce,[n(`h2`,we,c(e.$t(`webextrator.name.blockResources`)),1),i(_,{modelValue:e.blockResources,"onUpdate:modelValue":r[4]||=t=>e.blockResources=t,multiple:``,"collapse-tags":``,placeholder:e.$t(`webextrator.placeholder.blockResources`),class:`w-full`},{default:p(()=>[(l(!0),f(h,null,s(e.resourceKinds,n=>(l(),t(g,{key:n,label:e.$t(`webextrator.blockResource.${n}`),value:n},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var Ee=o({name:`WebextratorConfigPanel`,components:{ElButton:_,FontAwesomeIcon:F,ModeSelector:J,UrlInput:ne,ExpectedTypeSelector:se,LlmToggle:fe,AdvancedOptions:A(me,[[`render`,Te],[`__scopeId`,`data-v-8f36d2df`]]),Consumption:L},emits:[`run`],computed:{config(){return this.$store.state.webextrator?.config},service(){return this.$store.state.webextrator?.service},consumption(){return M(this.config||{},this.service?.cost)},running(){return this.$store.state.webextrator?.status?.run===P.Request},isExtract(){return(this.config?.mode||`extract`)===`extract`},canRun(){let e=(this.config?.url||``).trim();return/^https?:\/\//i.test(e)}},methods:{onRun(){this.canRun&&this.$emit(`run`)}}}),De={class:`flex flex-col h-full`},Oe={class:`flex-1 overflow-y-auto p-5`},ke={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ae(e,t,o,s,d,m){let g=u(`mode-selector`),_=u(`url-input`),v=u(`expected-type-selector`),y=u(`llm-toggle`),b=u(`advanced-options`),x=u(`consumption`),S=u(`font-awesome-icon`),C=u(`el-button`);return l(),f(`div`,De,[n(`div`,Oe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`,onSubmit:e.onRun},null,8,[`onSubmit`]),e.isExtract?(l(),f(h,{key:0},[i(v,{class:`mb-4`}),i(y,{class:`mb-4`})],64)):a(``,!0),i(b,{class:`mb-4`})]),n(`div`,ke,[i(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(C,{type:`primary`,class:`w-full`,round:``,loading:e.running,disabled:!e.canRun,onClick:e.onRun},{default:p(()=>[i(S,{icon:`fa-solid fa-bolt`,class:`mr-2`}),r(` `+c(e.$t(e.isExtract?`webextrator.button.extract`:`webextrator.button.render`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])])}var je=A(Ee,[[`render`,Ae]]),Me=e=>!!e&&e.kind!==`render`,Ne=o({name:`WebextratorResultPanel`,components:{ElAlert:w,ElImage:C,ElTabs:b,ElTabPane:x,FontAwesomeIcon:F,CopyToClipboard:I},data(){return{activeTab:`markdown`}},computed:{response(){return this.$store.state.webextrator?.response},running(){return this.$store.state.webextrator?.status?.run===P.Request},data(){return this.response?.data},renderData(){return this.data&&this.data.kind===`render`?this.data:void 0},extractData(){return Me(this.data)?this.data:void 0},finalUrl(){let e=this.data;return e?.finalUrl||e?.final_url||e?.url},contentTypeLabel(){let e=this.data;return e?.contentType||e?.content_type||e?.expected_type},screenshotSrc(){let e=this.data?.screenshot;if(e)return e.startsWith(`data:`)||e.startsWith(`http`)?e:`data:image/png;base64,${e}`},markdown(){let e=this.data;return e?.markdown||e?.content||``},plainText(){return this.data?.text||``},html(){return this.data?.html||``},links(){return Array.isArray(this.data?.links)?this.data.links:[]},linksPlain(){return this.links.join(`
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,v as m,x as h,y as g}from"./vendor-chart-mdwpew_o.js";import{t as _}from"./button-DWzbdjZV.js";import{r as v,t as y}from"./select-B14L-681.js";import{n as b,t as x}from"./tabs-CllsgUVI.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-CjzS-up0.js";import{t as w}from"./alert-BJj7gY4q.js";import{n as T,r as E}from"./radio-IJQsW93X.js";import{n as D,t as O}from"./collapse-BH0qROl8.js";import{t as k}from"./drawer-BvYPSxXh.js";import{t as ee}from"./input-number-N0auilju.js";import{t as te}from"./switch-Dir3SgN_.js";import"./constants-C-bSXdJ_.js";import{E as A,Ir as j,Nt as M,kr as N,yr as P}from"./index-BY8YIwDb.js";import{t as F}from"./index.es-CH5vwGaN.js";import{t as I}from"./CopyToClipboard-C8gyDUMn.js";import{t as L}from"./Consumption-QfvilMcG.js";var R=o({name:`LayoutWebextrator`,components:{ElDrawer:k,ElButton:_,FontAwesomeIcon:F},data(){return{drawer:!1}}}),z={class:`main flex flex-row flex-1`},B={class:`config w-[340px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},V={class:`result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function H(t,r,a,o,s,c){let d=u(`font-awesome-icon`),m=u(`el-button`),h=u(`el-drawer`);return l(),f(`div`,z,[n(`div`,B,[e(t.$slots,`config`,{},void 0,!0)]),n(`div`,V,[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-sliders`})]),_: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 U=A(R,[[`render`,H],[`__scopeId`,`data-v-f9e97e78`]]),W=o({name:`ModeSelector`,components:{ElRadioGroup:E,ElRadioButton:T,FontAwesomeIcon:F},computed:{value:{get(){return this.$store.state.webextrator?.config?.mode},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,mode:e})}}}}),G={class:`field`},K={class:`title font-bold`};function q(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-radio-button`),g=u(`el-radio-group`);return l(),f(`div`,G,[n(`h2`,K,c(e.$t(`webextrator.name.mode`)),1),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value w-full`},{default:p(()=>[i(h,{label:`extract`,value:`extract`},{default:p(()=>[i(m,{icon:`fa-solid fa-wand-magic-sparkles`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.extract`)),1)]),_:1}),i(h,{label:`render`,value:`render`},{default:p(()=>[i(m,{icon:`fa-solid fa-globe`,class:`mr-1`}),r(` `+c(e.$t(`webextrator.mode.render`)),1)]),_:1})]),_:1},8,[`modelValue`])])}var J=A(W,[[`render`,q],[`__scopeId`,`data-v-31e6c11d`]]),Y=o({name:`UrlInput`,components:{ElInput:j},emits:[`submit`],computed:{url:{get(){return this.$store.state.webextrator?.config?.url||``},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,url:e})}}},methods:{onEnter(){this.$emit(`submit`)}}}),X={class:`field`},Z={class:`title font-bold`};function Q(e,t,r,a,o,s){let d=u(`el-input`);return l(),f(`div`,X,[n(`h2`,Z,c(e.$t(`webextrator.name.url`)),1),i(d,{modelValue:e.url,"onUpdate:modelValue":t[0]||=t=>e.url=t,type:`textarea`,rows:2,class:`prompt`,placeholder:e.$t(`webextrator.placeholder.url`),onKeydown:m(g(e.onEnter,[`exact`,`prevent`]),[`enter`])},null,8,[`modelValue`,`placeholder`,`onKeydown`])])}var ne=A(Y,[[`render`,Q],[`__scopeId`,`data-v-18488009`]]),re=o({name:`ExpectedTypeSelector`,components:{ElSelect:v,ElOption:y},computed:{value:{get(){return this.$store.state.webextrator?.config?.expected_type},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,expected_type:e})}}},mounted(){this.value||=`general`}}),ie={class:`field`},ae={class:`title font-bold`};function oe(e,t,r,a,o,s){let d=u(`el-option`),m=u(`el-select`);return l(),f(`div`,ie,[n(`h2`,ae,c(e.$t(`webextrator.name.expectedType`)),1),i(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},{default:p(()=>[i(d,{value:`general`,label:e.$t(`webextrator.expectedType.general`)},null,8,[`label`]),i(d,{value:`article`,label:e.$t(`webextrator.expectedType.article`)},null,8,[`label`]),i(d,{value:`product`,label:e.$t(`webextrator.expectedType.product`)},null,8,[`label`])]),_:1},8,[`modelValue`])])}var se=A(re,[[`render`,oe],[`__scopeId`,`data-v-3b572c49`]]),ce=o({name:`LlmToggle`,components:{ElSwitch:te,ElTooltip:S,FontAwesomeIcon:F},computed:{value:{get(){return!!this.$store.state.webextrator?.config?.enable_llm},set(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,enable_llm:e})}}}}),le={class:`field`},ue={class:`title font-bold`};function de(e,t,a,o,s,d){let m=u(`font-awesome-icon`),h=u(`el-tooltip`),g=u(`el-switch`);return l(),f(`div`,le,[n(`h2`,ue,[r(c(e.$t(`webextrator.name.enableLlm`))+` `,1),i(h,{effect:`dark`,content:e.$t(`webextrator.description.enableLlm`),placement:`top`},{default:p(()=>[i(m,{icon:`fa-solid fa-circle-info`,class:`ml-1 text-[var(--el-text-color-secondary)] text-xs`})]),_:1},8,[`content`])]),i(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`},null,8,[`modelValue`])])}var fe=A(ce,[[`render`,de],[`__scopeId`,`data-v-32fa7c89`]]),pe=[`image`,`font`,`media`,`stylesheet`,`xhr`,`fetch`],me=o({name:`AdvancedOptions`,components:{ElCollapse:O,ElCollapseItem:D,ElInput:j,ElInputNumber:ee,ElSelect:v,ElOption:y},data(){return{active:[]}},computed:{resourceKinds(){return pe},waitUntil:{get(){return this.$store.state.webextrator?.config?.wait_until||`networkidle`},set(e){this.commit({wait_until:e})}},waitForSelector:{get(){return this.$store.state.webextrator?.config?.wait_for_selector||``},set(e){this.commit({wait_for_selector:e})}},timeout:{get(){return this.$store.state.webextrator?.config?.timeout??30},set(e){this.commit({timeout:e})}},delay:{get(){return this.$store.state.webextrator?.config?.delay??0},set(e){this.commit({delay:e})}},blockResources:{get(){return this.$store.state.webextrator?.config?.block_resources||[]},set(e){this.commit({block_resources:e})}}},methods:{commit(e){this.$store.commit(`webextrator/setConfig`,{...this.$store.state.webextrator?.config,...e})}}}),he={class:`field`},ge={class:`sub-title`},_e={class:`field`},ve={class:`sub-title`},ye={class:`field`},be={class:`sub-title`},xe={class:`field`},Se={class:`sub-title`},Ce={class:`field`},we={class:`sub-title`};function Te(e,r,a,o,d,m){let g=u(`el-option`),_=u(`el-select`),v=u(`el-input`),y=u(`el-input-number`),b=u(`el-collapse-item`),x=u(`el-collapse`);return l(),t(x,{modelValue:e.active,"onUpdate:modelValue":r[5]||=t=>e.active=t,class:`advanced`},{default:p(()=>[i(b,{title:e.$t(`webextrator.name.advanced`),name:`advanced`},{default:p(()=>[n(`div`,he,[n(`h2`,ge,c(e.$t(`webextrator.name.waitUntil`)),1),i(_,{modelValue:e.waitUntil,"onUpdate:modelValue":r[0]||=t=>e.waitUntil=t,class:`value`},{default:p(()=>[i(g,{value:`networkidle`,label:e.$t(`webextrator.waitUntil.networkidle`)},null,8,[`label`]),i(g,{value:`load`,label:e.$t(`webextrator.waitUntil.load`)},null,8,[`label`]),i(g,{value:`domcontentloaded`,label:e.$t(`webextrator.waitUntil.domcontentloaded`)},null,8,[`label`]),i(g,{value:`commit`,label:e.$t(`webextrator.waitUntil.commit`)},null,8,[`label`])]),_:1},8,[`modelValue`])]),n(`div`,_e,[n(`h2`,ve,c(e.$t(`webextrator.name.waitForSelector`)),1),i(v,{modelValue:e.waitForSelector,"onUpdate:modelValue":r[1]||=t=>e.waitForSelector=t,placeholder:e.$t(`webextrator.placeholder.waitForSelector`)},null,8,[`modelValue`,`placeholder`])]),n(`div`,ye,[n(`h2`,be,c(e.$t(`webextrator.name.timeout`)),1),i(y,{modelValue:e.timeout,"onUpdate:modelValue":r[2]||=t=>e.timeout=t,min:1,max:120,step:5,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,xe,[n(`h2`,Se,c(e.$t(`webextrator.name.delay`)),1),i(y,{modelValue:e.delay,"onUpdate:modelValue":r[3]||=t=>e.delay=t,min:0,max:30,step:1,"controls-position":`right`,class:`w-full`},null,8,[`modelValue`])]),n(`div`,Ce,[n(`h2`,we,c(e.$t(`webextrator.name.blockResources`)),1),i(_,{modelValue:e.blockResources,"onUpdate:modelValue":r[4]||=t=>e.blockResources=t,multiple:``,"collapse-tags":``,placeholder:e.$t(`webextrator.placeholder.blockResources`),class:`w-full`},{default:p(()=>[(l(!0),f(h,null,s(e.resourceKinds,n=>(l(),t(g,{key:n,label:e.$t(`webextrator.blockResource.${n}`),value:n},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])]),_:1},8,[`title`])]),_:1},8,[`modelValue`])}var Ee=o({name:`WebextratorConfigPanel`,components:{ElButton:_,FontAwesomeIcon:F,ModeSelector:J,UrlInput:ne,ExpectedTypeSelector:se,LlmToggle:fe,AdvancedOptions:A(me,[[`render`,Te],[`__scopeId`,`data-v-8f36d2df`]]),Consumption:L},emits:[`run`],computed:{config(){return this.$store.state.webextrator?.config},service(){return this.$store.state.webextrator?.service},consumption(){return M(this.config||{},this.service?.cost)},running(){return this.$store.state.webextrator?.status?.run===P.Request},isExtract(){return(this.config?.mode||`extract`)===`extract`},canRun(){let e=(this.config?.url||``).trim();return/^https?:\/\//i.test(e)}},methods:{onRun(){this.canRun&&this.$emit(`run`)}}}),De={class:`flex flex-col h-full`},Oe={class:`flex-1 overflow-y-auto p-5`},ke={class:`flex flex-col items-center justify-center px-5 pb-5`};function Ae(e,t,o,s,d,m){let g=u(`mode-selector`),_=u(`url-input`),v=u(`expected-type-selector`),y=u(`llm-toggle`),b=u(`advanced-options`),x=u(`consumption`),S=u(`font-awesome-icon`),C=u(`el-button`);return l(),f(`div`,De,[n(`div`,Oe,[i(g,{class:`mb-4`}),i(_,{class:`mb-4`,onSubmit:e.onRun},null,8,[`onSubmit`]),e.isExtract?(l(),f(h,{key:0},[i(v,{class:`mb-4`}),i(y,{class:`mb-4`})],64)):a(``,!0),i(b,{class:`mb-4`})]),n(`div`,ke,[i(x,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),i(C,{type:`primary`,class:`w-full`,round:``,loading:e.running,disabled:!e.canRun,onClick:e.onRun},{default:p(()=>[i(S,{icon:`fa-solid fa-bolt`,class:`mr-2`}),r(` `+c(e.$t(e.isExtract?`webextrator.button.extract`:`webextrator.button.render`)),1)]),_:1},8,[`loading`,`disabled`,`onClick`])])])}var je=A(Ee,[[`render`,Ae]]),Me=e=>!!e&&e.kind!==`render`,Ne=o({name:`WebextratorResultPanel`,components:{ElAlert:w,ElImage:C,ElTabs:b,ElTabPane:x,FontAwesomeIcon:F,CopyToClipboard:I},data(){return{activeTab:`markdown`}},computed:{response(){return this.$store.state.webextrator?.response},running(){return this.$store.state.webextrator?.status?.run===P.Request},data(){return this.response?.data},renderData(){return this.data&&this.data.kind===`render`?this.data:void 0},extractData(){return Me(this.data)?this.data:void 0},finalUrl(){let e=this.data;return e?.finalUrl||e?.final_url||e?.url},contentTypeLabel(){let e=this.data;return e?.contentType||e?.content_type||e?.expected_type},screenshotSrc(){let e=this.data?.screenshot;if(e)return e.startsWith(`data:`)||e.startsWith(`http`)?e:`data:image/png;base64,${e}`},markdown(){let e=this.data;return e?.markdown||e?.content||``},plainText(){return this.data?.text||``},html(){return this.data?.html||``},links(){return Array.isArray(this.data?.links)?this.data.links:[]},linksPlain(){return this.links.join(`
2
2
  `)},images(){return Array.isArray(this.data?.images)?this.data.images:[]},structuredPretty(){return this.extractData?.structured?JSON.stringify(this.extractData.structured,null,2):``},rawPretty(){return this.response?JSON.stringify(this.response,null,2):``},errorMessage(){if(this.response?.success===!1){let e=this.response?.error;return e?.message||e?.code||this.$t(`webextrator.message.failed`)}}},watch:{response:{handler(){this.resetTab()},immediate:!0}},methods:{resetTab(){this.markdown?this.activeTab=`markdown`:this.extractData?.structured?this.activeTab=`structured`:this.plainText?this.activeTab=`text`:this.html?this.activeTab=`html`:this.activeTab=`raw`}}}),Pe={class:`h-full overflow-y-auto p-6`},Fe={key:0,class:`max-w-4xl mx-auto py-4`},Ie={class:`flex items-center gap-2 mb-3 text-[var(--el-color-primary)] text-sm`},Le={key:1,class:`flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]`},Re={class:`text-base mb-1`},ze={class:`text-xs opacity-70`},Be={key:2,class:`max-w-4xl mx-auto py-4`},Ve={class:`text-xs whitespace-pre-wrap break-words`},He={key:3,class:`max-w-4xl mx-auto`},Ue={class:`mb-4`},We={class:`text-xl font-semibold leading-snug mb-1 break-words text-[var(--el-text-color-primary)]`},Ge={class:`flex flex-wrap items-center gap-x-3 gap-y-1 text-xs text-[var(--el-text-color-secondary)]`},Ke=[`href`],qe={key:1},Je={key:2},Ye={key:3},Xe={key:0,class:`mt-2 text-sm text-[var(--el-text-color-regular)] leading-relaxed line-clamp-3`},Ze={key:0,class:`mb-5`},Qe={class:`tab-toolbar`},$e={class:`content-block`},et={class:`tab-toolbar`},tt={class:`content-block`},$={class:`tab-toolbar`},nt={class:`content-block code`},rt={class:`tab-toolbar`},it={class:`links-list`},at=[`href`],ot={class:`grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-2`},st={class:`tab-toolbar`},ct={class:`content-block code`},lt={class:`tab-toolbar`},ut={class:`content-block code`};function dt(e,o,m,g,_,v){let y=u(`font-awesome-icon`),b=u(`el-alert`),x=u(`el-image`),S=u(`copy-to-clipboard`),C=u(`el-tab-pane`),w=u(`el-tabs`);return l(),f(`div`,Pe,[e.running?(l(),f(`div`,Fe,[n(`div`,Ie,[i(y,{icon:`fa-solid fa-circle-notch`,spin:``}),n(`span`,null,c(e.$t(`webextrator.message.running`)),1)]),o[1]||=d(`<div class="mb-6 animate-pulse" data-v-b05b4db0><div class="h-5 w-3/5 rounded bg-[var(--el-fill-color-dark)] mb-2" data-v-b05b4db0></div><div class="h-3 w-2/5 rounded bg-[var(--el-fill-color)] mb-4" data-v-b05b4db0></div><div class="h-64 w-full rounded bg-[var(--el-fill-color)] mb-3" data-v-b05b4db0></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)] mb-1" data-v-b05b4db0></div><div class="h-3 w-4/6 rounded bg-[var(--el-fill-color)]" data-v-b05b4db0></div></div>`,1)])):!e.response&&!e.errorMessage?(l(),f(`div`,Le,[i(y,{icon:`fa-solid fa-globe`,class:`text-6xl mb-4 opacity-30`}),n(`p`,Re,c(e.$t(`webextrator.description.intro`)),1),n(`p`,ze,c(e.$t(`webextrator.description.introHint`)),1)])):e.errorMessage?(l(),f(`div`,Be,[i(b,{type:`error`,closable:!1,"show-icon":``,title:e.$t(`webextrator.message.failed`)},{default:p(()=>[n(`pre`,Ve,c(e.errorMessage),1)]),_:1},8,[`title`])])):e.data?(l(),f(`div`,He,[n(`header`,Ue,[n(`h1`,We,c(e.data.title||e.$t(`webextrator.message.untitled`)),1),n(`div`,Ge,[e.finalUrl?(l(),f(`a`,{key:0,href:e.finalUrl,target:`_blank`,rel:`noopener`,class:`hover:underline truncate max-w-[60%]`},[i(y,{icon:`fa-solid fa-up-right-from-square`,class:`mr-1`}),r(c(e.finalUrl),1)],8,Ke)):a(``,!0),e.renderData?.status?(l(),f(`span`,qe,[i(y,{icon:`fa-solid fa-signal`,class:`mr-1`}),r(c(e.renderData.status),1)])):a(``,!0),e.response?.elapsed?(l(),f(`span`,Je,[i(y,{icon:`fa-solid fa-clock`,class:`mr-1`}),r(c(e.response.elapsed.toFixed(2))+`s `,1)])):a(``,!0),e.contentTypeLabel?(l(),f(`span`,Ye,[i(y,{icon:`fa-solid fa-tag`,class:`mr-1`}),r(c(e.contentTypeLabel),1)])):a(``,!0)]),e.extractData?.description?(l(),f(`p`,Xe,c(e.extractData.description),1)):a(``,!0)]),e.screenshotSrc?(l(),f(`figure`,Ze,[i(x,{src:e.screenshotSrc,fit:`contain`,"preview-src-list":[e.screenshotSrc],"preview-teleported":``,"hide-on-click-modal":``,class:`w-full max-h-[480px] rounded border border-[var(--app-border-subtle)] bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`])])):a(``,!0),i(w,{modelValue:e.activeTab,"onUpdate:modelValue":o[0]||=t=>e.activeTab=t,class:`result-tabs`},{default:p(()=>[e.markdown?(l(),t(C,{key:0,label:e.$t(`webextrator.tab.markdown`),name:`markdown`},{default:p(()=>[n(`div`,Qe,[i(S,{content:e.markdown},null,8,[`content`])]),n(`pre`,$e,c(e.markdown),1)]),_:1},8,[`label`])):a(``,!0),e.plainText?(l(),t(C,{key:1,label:e.$t(`webextrator.tab.text`),name:`text`},{default:p(()=>[n(`div`,et,[i(S,{content:e.plainText},null,8,[`content`])]),n(`pre`,tt,c(e.plainText),1)]),_:1},8,[`label`])):a(``,!0),e.extractData?.structured?(l(),t(C,{key:2,label:e.$t(`webextrator.tab.structured`),name:`structured`},{default:p(()=>[n(`div`,$,[i(S,{content:e.structuredPretty},null,8,[`content`])]),n(`pre`,nt,c(e.structuredPretty),1)]),_:1},8,[`label`])):a(``,!0),e.links.length?(l(),t(C,{key:3,label:`${e.$t(`webextrator.tab.links`)} (${e.links.length})`,name:`links`},{default:p(()=>[n(`div`,rt,[i(S,{content:e.linksPlain},null,8,[`content`])]),n(`ul`,it,[(l(!0),f(h,null,s(e.links,(e,t)=>(l(),f(`li`,{key:t,class:`truncate`},[n(`a`,{href:e,target:`_blank`,rel:`noopener`},c(e),9,at)]))),128))])]),_:1},8,[`label`])):a(``,!0),e.images.length?(l(),t(C,{key:4,label:`${e.$t(`webextrator.tab.images`)} (${e.images.length})`,name:`images`},{default:p(()=>[n(`div`,ot,[(l(!0),f(h,null,s(e.images,(n,r)=>(l(),t(x,{key:r,src:n,fit:`cover`,loading:`lazy`,"preview-src-list":e.images,"initial-index":r,"preview-teleported":``,"hide-on-click-modal":``,class:`aspect-square w-full rounded bg-[var(--el-fill-color-light)]`},null,8,[`src`,`preview-src-list`,`initial-index`]))),128))])]),_:1},8,[`label`])):a(``,!0),e.html?(l(),t(C,{key:5,label:e.$t(`webextrator.tab.html`),name:`html`},{default:p(()=>[n(`div`,st,[i(S,{content:e.html},null,8,[`content`])]),n(`pre`,ct,c(e.html),1)]),_:1},8,[`label`])):a(``,!0),i(C,{label:e.$t(`webextrator.tab.raw`),name:`raw`},{default:p(()=>[n(`div`,lt,[i(S,{content:e.rawPretty},null,8,[`content`])]),n(`pre`,ut,c(e.rawPretty),1)]),_:1},8,[`label`])]),_:1},8,[`modelValue`])])):a(``,!0)])}var ft=o({name:`WebextratorIndex`,components:{Layout:U,ConfigPanel:je,ResultPanel:A(Ne,[[`render`,dt],[`__scopeId`,`data-v-b05b4db0`]])},inject:[`initialized`],async mounted(){await this.$store.dispatch(`webextrator/getService`)},methods:{async onRun(){let e=this.$store.state.webextrator?.config;if(!e?.url)return;let t=(e.mode||`extract`)===`extract`;N.info(this.$t(t?`webextrator.message.extracting`:`webextrator.message.rendering`));try{await this.$store.dispatch(`webextrator/run`),N.success(this.$t(`webextrator.message.success`))}catch(e){let t=e?.response?.data?.error?.code||e?.response?.data?.code;t===`used_up`?N.error(this.$t(`webextrator.message.usedUp`)):t===`too_many_requests`?N.error(this.$t(`webextrator.message.busy`)):t===`timeout`?N.error(this.$t(`webextrator.message.timeout`)):N.error(this.$t(`webextrator.message.failed`))}}}});function pt(e,n,r,a,o,s){let c=u(`config-panel`),d=u(`result-panel`),f=u(`layout`);return l(),t(f,null,{config:p(()=>[i(c,{onRun:e.onRun},null,8,[`onRun`])]),result:p(()=>[i(d)]),_:1})}var mt=A(ft,[[`render`,pt]]);export{mt 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 i,M as a,N as o,O as s,P as c,Q as l,Ut as u,X as d,_ as f,et as p,k as m,lt as h,ut as g,x as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{r as y,t as b}from"./select-CtOUS-1J.js";import{t as x}from"./upload-CnVhrWBT.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-D5iIL2A6.js";import{t as w}from"./alert-BJj7gY4q.js";import{t as T}from"./drawer-BvYPSxXh.js";import{$n as E,Qn as D,Xn as O,Zn as k,er as A,ir as ee,pi as te,rr as j,tr 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,dn as z,jt as B,kr as V,kt as H,yr as U}from"./index-uml6ohnH.js";import{t as W}from"./index.es-CcQaWbuV.js";import{t as G}from"./CopyToClipboard-Dnrr0G1l.js";import{t as K}from"./ImagePreview-D9ovswSr.js";import{n as q}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as J}from"./BotPlaceholder-By9wptjP.js";import{i as Y,n as X,t as Z}from"./pagination-BUM1iMKs.js";import{n as Q,t as ne}from"./NoTasks-BHtlhARF.js";import{t as re}from"./Consumption-Dlo2Ec9d.js";import{t as ie}from"./ApiCodeButton-CYsbafW5.js";import{t as ae}from"./VideoPlayer-qDDLVH7_.js";var oe=c({name:`LayoutSora`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:W},mixins:[q]}),se={class:`main flex flex-row flex-1`},ce={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},le={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ue(t,n,i,a,s,c){let l=p(`font-awesome-icon`),u=p(`el-button`),_=p(`el-drawer`);return d(),m(`div`,se,[r(`div`,ce,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,le,[e(t.$slots,`result`,{},void 0,!0)]),g(o(u,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:h(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[f,!t.tasksEmpty]]),o(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:h(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var de=P(oe,[[`render`,ue],[`__scopeId`,`data-v-531ab990`]]),fe=c({name:`ModelSelector`,components:{ElSelect:y,ElOption:b},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:ee,label:`sora-2`},{value:j,label:`sora-2-pro`}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){let t=this.$store.state.sora?.config||{},n=O[e]||[10],r=t.duration,i=r&&n.includes(r)?r:n.includes(10)?10:n[0],a={...t,model:e,duration:i,size:t.size||`small`};this.$store.commit(`sora/setConfig`,a)}}},mounted(){this.value||=E}}),pe={class:`field`},me={class:`title font-bold`};function he(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,pe,[r(`h2`,me,u(e.$t(`sora.name.model`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ge=P(fe,[[`render`,he],[`__scopeId`,`data-v-0cb7913d`]]),_e=c({name:`ActionSelector`,components:{ElSelect:y,ElOption:b},data(){return{}},computed:{options(){return[{value:`text2video`,label:this.$t(`sora.button.action1`)},{value:`image2video`,label:this.$t(`sora.button.action2`)}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit(`sora/setConfig`,{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||=D}}),ve={class:`field`},ye={class:`title font-bold`},be={class:`float-left`};function xe(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,ve,[r(`h2`,ye,u(e.$t(`sora.name.action`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`),clearable:``},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},{default:h(()=>[r(`span`,be,u(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Se=P(_e,[[`render`,xe],[`__scopeId`,`data-v-7b82fa7f`]]),Ce=c({name:`DurationSelector`,components:{ElSelect:y,ElOption:b},computed:{model(){return this.$store.state.sora?.config?.model||`sora-2`},allowedDurations(){return O[this.model]||[10]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){let t=this.$store.state.sora?.config||{};this.$store.commit(`sora/setConfig`,{...t,duration:e})}}},watch:{allowedDurations(){let e=this.allowedDurations;if(!e.includes(this.value)){let t=e.includes(10)?10:e[0];this.value=t}}},mounted(){this.value||=10}}),we={class:`field`},Te={class:`control`},Ee={class:`title font-bold`};function De(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,we,[r(`div`,Te,[r(`h2`,Ee,u(e.$t(`sora.name.duration`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.optionsForModel,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])])}var Oe=P(Ce,[[`render`,De],[`__scopeId`,`data-v-c2934598`]]),ke=c({name:`OrientationSelector`,data(){return{options:[{value:`portrait`,labelKey:`sora.option.portrait`,width:13,height:25},{value:`landscape`,labelKey:`sora.option.landscape`,width:25,height:13}]}},computed:{active(){let e=this.options.findIndex(e=>e.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug(`set orientation`,e),this.$store.commit(`sora/setConfig`,{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||=A}}),Ae={class:`text-sm font-bold mb-2 block`},je={class:`items`},Me=[`onClick`],Ne={class:`name`};function Pe(e,n,a,o,s,c){return d(),m(`div`,null,[r(`span`,Ae,u(e.$t(`sora.name.orientation`)),1),r(`div`,je,[(d(!0),m(_,null,l(e.options,(n,a)=>(d(),m(`div`,{key:a,class:t({active:e.active===a,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.value])},[r(`div`,{class:`rect`,style:i({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Ne,u(e.$t(n.labelKey)),1)],10,Me))),128))])])}var Fe=P(ke,[[`render`,Pe],[`__scopeId`,`data-v-a20be6d9`]]),Ie=c({name:`StartEndImage`,components:{ElUpload:x,ElButton:v,InfoIcon:Y,FontAwesomeIcon:W,ImagePreview:K},mixins:[B,H],emits:[`change`],data(){return{fileList:[],uploadUrl:R()+`/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?.sora?.config?.image_urls},set(){}}},mounted(){this.value||=void 0,this.onSetStartEndImageUrl()},methods:{onExceed(){V.warning(this.$t(`sora.message.uploadReferencesExceed`))},onError(){V.error(this.$t(`sora.message.uploadReferencesError`))},onSetStartEndImageUrl(){let e=this.urls;this.$store.commit(`sora/setConfig`,{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Le={class:`relative`},Re={class:`flex justify-between`},ze={class:`flex justify-start items-center`},Be={class:`text-sm font-bold`};function Ve(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-upload`);return d(),m(`div`,Le,[r(`div`,Re,[r(`div`,ze,[r(`span`,Be,u(e.$t(`sora.name.startEndImage`)),1),o(g,{content:e.$t(`sora.description.uploadStartEndImage`)},null,8,[`content`])])]),o(b,{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:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{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`])):s(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`sora.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var He=P(Ie,[[`render`,Ve],[`__scopeId`,`data-v-4f7d9ba5`]]),Ue=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),We=c({name:`SizeSelector`,components:{ElSelect:y,ElOption:b},data(){return{options:k.map(e=>({value:e,label:Ue(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){let t=this.$store.state.sora?.config||{};this.$store.commit(`sora/setConfig`,{...t,size:e})}}},mounted(){this.value||=M}}),Ge={class:`field`},Ke={class:`control`},qe={class:`title font-bold`};function Je(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,u(e.$t(`sora.name.size`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])])}var Ye=P(We,[[`render`,Je],[`__scopeId`,`data-v-8c485f0f`]]),Xe=c({name:`PromptInput`,components:{PromptTextarea:Q},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){this.$store.commit(`sora/setConfig`,{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Ze(e,t,r,i,a,o){let s=p(`prompt-textarea`);return d(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`sora.name.prompt`),info:e.$t(`sora.description.prompt`),placeholder:e.$t(`sora.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Qe=c({name:`ConfigPanel`,components:{ElButton:v,Consumption:re,FontAwesomeIcon:W,PromptInput:P(Xe,[[`render`,Ze]]),ModelSelector:ge,StartEndImage:He,SizeSelector:Ye,ActionSelector:Se,OrientationSelector:Fe,DurationSelector:Oe},emits:[`generate`],computed:{config(){return this.$store.state.sora?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),$e={class:`flex flex-col h-full`},et={class:`flex-1 overflow-y-auto p-5`},tt={class:`flex flex-col items-center justify-center px-5 pb-5`};function nt(e,t,n,i,s,c){let l=p(`model-selector`),_=p(`action-selector`),v=p(`duration-selector`),y=p(`size-selector`),b=p(`orientation-selector`),x=p(`prompt-input`),S=p(`start-end-image`),C=p(`consumption`),w=p(`font-awesome-icon`),T=p(`el-button`);return d(),m(`div`,$e,[r(`div`,et,[o(l,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),g(o(S,{class:`mb-2`},null,512),[[f,e.config?.action===`image2video`]])]),r(`div`,tt,[o(C,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(T,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(w,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`sora.button.generate`)),1)]),_:1},8,[`onClick`])])])}var rt=P(Qe,[[`render`,nt]]),it=c({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:G,FontAwesomeIcon:W,ElAlert:w,VideoPlayer:ae,ElTooltip:S,ElButton:v,ApiCodeButton:ie},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenVideo(e){window.open(e,`_blank`)}}}),at={class:`preview`},ot={class:`left`},st={class:`main`},ct={class:`bot`},lt={class:`datetime`},ut={class:`info`},dt={key:0,class:`prompt mt-2`},ft={key:0},pt={key:1},mt={key:0,class:t({content:!0,failed:!0})},ht={key:0,class:`mb-4`},gt={key:1,class:t({operations:!0,"mt-2":!0})},_t={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},yt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},bt={key:1,class:t({content:!0})},xt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Tt={key:2,class:t({content:!0})},Et={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Dt(e,t,i,c,l,f){let g=p(`el-image`),_=p(`video-player`),v=p(`el-button`),y=p(`el-tooltip`),b=p(`api-code-button`),x=p(`font-awesome-icon`),S=p(`copy-to-clipboard`),C=p(`el-alert`);return d(),m(`div`,at,[r(`div`,ot,[o(g,{src:`https://cdn.acedata.cloud/z5id1u.png`,class:`avatar`})]),r(`div`,st,[r(`div`,ct,[a(u(e.$t(`sora.name.soraBot`))+` `,1),r(`span`,lt,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,ut,[e.modelValue?.request?.prompt?(d(),m(`p`,dt,[a(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?s(``,!0):(d(),m(`span`,ft,` - (`+u(e.$t(`sora.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`pending`?(d(),m(`span`,pt,` - (`+u(e.$t(`sora.status.processing`))+`) `,1)):s(``,!0)])):s(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(d(),m(`div`,mt,[e.modelValue?.response?.data[0]?.video_url?(d(),m(`div`,ht,[o(_,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):s(``,!0),e.modelValue?.response.success?(d(),m(`div`,gt,[o(y,{class:`box-item`,effect:`dark`,content:e.$t(`sora.message.downloadVideo`),placement:`top-start`},{default:h(()=>[e.modelValue?.response?.data[0]?.video_url?(d(),n(v,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:h(()=>[a(u(e.$t(`sora.button.download`)),1)]),_:1})):s(``,!0)]),_:1},8,[`content`]),o(b,{path:`/sora/videos`,body:e.modelValue?.request},null,8,[`body`])])):s(``,!0),o(C,{closable:!1,class:`mt-2 success`},{default:h(()=>[r(`p`,_t,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.model`))+`: `+u(e.modelValue?.request?.model),1)]),r(`p`,vt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,yt,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===!1?(d(),m(`div`,bt,[o(C,{closable:!1,class:`failure`},{template:h(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failure`)),1)]),default:h(()=>[r(`p`,xt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,St,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,Ct,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0),e.modelValue?.response?.trace_id?(d(),m(`p`,wt,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===void 0?(d(),m(`div`,Tt,[o(C,{closable:!1,class:`info`},{template:h(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failure`)),1)]),default:h(()=>[r(`p`,Et,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(d(),m(`p`,$,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0)])])}var Ot=c({name:`RecentPanel`,components:{TaskPreview:P(it,[[`render`,Dt],[`__scopeId`,`data-v-935f9471`]]),NoTasks:ne,BotPlaceholder:J,ScrollList:X},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),kt={key:0},At={key:2,class:`w-full h-full flex items-center justify-center`};function jt(e,t,r,i,a,c){let u=p(`bot-placeholder`),f=p(`task-preview`),g=p(`scroll-list`),v=p(`no-tasks`);return d(),m(_,null,[e.tasks?.items===void 0?(d(),m(`div`,kt,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(d(),n(g,{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:h(()=>[(d(!0),m(_,null,l(e.tasks?.items,(e,t)=>(d(),n(f,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):s(``,!0),e.tasks?.items?.length===0?(d(),m(`div`,At,[o(v)])):s(``,!0)],64)}var Mt=P(Ot,[[`render`,jt]]),Nt=te(`sora`),Pt=c({name:`SoraIndex`,components:{ConfigPanel:rt,Layout:de,RecentPanel:Mt},mixins:[N],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.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 Z({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(`sora/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`sora/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(`sora/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,callback_url:Nt},t=this.credential?.token;if(!t){console.error(`no token specified`);return}V.info(this.$t(`sora.message.startingTask`)),F(`sora`,z.generate(e,{token:t})).then(()=>{V.success(this.$t(`sora.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?V.error(this.$t(`sora.message.usedUp`)):V.error(this.$t(`sora.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ft(e,t,r,i,a,s){let c=p(`config-panel`),l=p(`recent-panel`),u=p(`layout`);return d(),n(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var It=P(Pt,[[`render`,Ft]]);export{It as default};
1
+ import"./rolldown-runtime--c01j_DQ.js";import{$ as e,Bt as t,D as n,E as r,Ht as i,M as a,N as o,O as s,P as c,Q as l,Ut as u,X as d,_ as f,et as p,k as m,lt as h,ut as g,x as _}from"./vendor-chart-mdwpew_o.js";import{t as v}from"./button-DWzbdjZV.js";import{r as y,t as b}from"./select-B14L-681.js";import{t as x}from"./upload-CgRMUkQi.js";import{t as S}from"./tooltip-C3PYfh8V.js";import{t as C}from"./image-CjzS-up0.js";import{t as w}from"./alert-BJj7gY4q.js";import{t as T}from"./drawer-BvYPSxXh.js";import{$n as E,Qn as D,Xn as O,Zn as k,er as A,ir as ee,pi as te,rr as j,tr 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,dn as z,jt as B,kr as V,kt as H,yr as U}from"./index-BY8YIwDb.js";import{t as W}from"./index.es-CH5vwGaN.js";import{t as G}from"./CopyToClipboard-C8gyDUMn.js";import{t as K}from"./ImagePreview-DkXTeOKK.js";import{n as q}from"./taskDrawerMixin-Cr17Yxqk.js";import{t as J}from"./BotPlaceholder-BVXWzbpi.js";import{i as Y,n as X,t as Z}from"./pagination-CjEVtILV.js";import{n as Q,t as ne}from"./NoTasks-Dk1WXppl.js";import{t as re}from"./Consumption-QfvilMcG.js";import{t as ie}from"./ApiCodeButton-DpYCu-EK.js";import{t as ae}from"./VideoPlayer-BLPGe-uP.js";var oe=c({name:`LayoutSora`,components:{ElDrawer:T,ElButton:v,FontAwesomeIcon:W},mixins:[q]}),se={class:`main flex flex-row flex-1`},ce={class:`config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]`},le={class:`result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]`};function ue(t,n,i,a,s,c){let l=p(`font-awesome-icon`),u=p(`el-button`),_=p(`el-drawer`);return d(),m(`div`,se,[r(`div`,ce,[e(t.$slots,`config`,{},void 0,!0)]),r(`div`,le,[e(t.$slots,`result`,{},void 0,!0)]),g(o(u,{circle:``,class:`menu`,onClick:n[0]||=e=>t.drawer=!0},{default:h(()=>[o(l,{icon:`fa-solid fa-magic`})]),_:1},512),[[f,!t.tasksEmpty]]),o(_,{modelValue:t.drawer,"onUpdate:modelValue":n[1]||=e=>t.drawer=e,direction:`ltr`,"with-header":!1,size:`350px`},{default:h(()=>[e(t.$slots,`config`,{},void 0,!0)]),_:3},8,[`modelValue`])])}var de=P(oe,[[`render`,ue],[`__scopeId`,`data-v-531ab990`]]),fe=c({name:`ModelSelector`,components:{ElSelect:y,ElOption:b},props:{modelValue:{type:String,default:void 0}},emits:[`update:modelValue`],data(){return{options:[{value:ee,label:`sora-2`},{value:j,label:`sora-2-pro`}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){let t=this.$store.state.sora?.config||{},n=O[e]||[10],r=t.duration,i=r&&n.includes(r)?r:n.includes(10)?10:n[0],a={...t,model:e,duration:i,size:t.size||`small`};this.$store.commit(`sora/setConfig`,a)}}},mounted(){this.value||=E}}),pe={class:`field`},me={class:`title font-bold`};function he(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,pe,[r(`h2`,me,u(e.$t(`sora.name.model`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var ge=P(fe,[[`render`,he],[`__scopeId`,`data-v-0cb7913d`]]),_e=c({name:`ActionSelector`,components:{ElSelect:y,ElOption:b},data(){return{}},computed:{options(){return[{value:`text2video`,label:this.$t(`sora.button.action1`)},{value:`image2video`,label:this.$t(`sora.button.action2`)}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit(`sora/setConfig`,{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||=D}}),ve={class:`field`},ye={class:`title font-bold`},be={class:`float-left`};function xe(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,ve,[r(`h2`,ye,u(e.$t(`sora.name.action`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`),clearable:``},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},{default:h(()=>[r(`span`,be,u(e.label),1)]),_:2},1032,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])}var Se=P(_e,[[`render`,xe],[`__scopeId`,`data-v-7b82fa7f`]]),Ce=c({name:`DurationSelector`,components:{ElSelect:y,ElOption:b},computed:{model(){return this.$store.state.sora?.config?.model||`sora-2`},allowedDurations(){return O[this.model]||[10]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){let t=this.$store.state.sora?.config||{};this.$store.commit(`sora/setConfig`,{...t,duration:e})}}},watch:{allowedDurations(){let e=this.allowedDurations;if(!e.includes(this.value)){let t=e.includes(10)?10:e[0];this.value=t}}},mounted(){this.value||=10}}),we={class:`field`},Te={class:`control`},Ee={class:`title font-bold`};function De(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,we,[r(`div`,Te,[r(`h2`,Ee,u(e.$t(`sora.name.duration`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.optionsForModel,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])])}var Oe=P(Ce,[[`render`,De],[`__scopeId`,`data-v-c2934598`]]),ke=c({name:`OrientationSelector`,data(){return{options:[{value:`portrait`,labelKey:`sora.option.portrait`,width:13,height:25},{value:`landscape`,labelKey:`sora.option.landscape`,width:25,height:13}]}},computed:{active(){let e=this.options.findIndex(e=>e.value===this.value);return e>=0?e:0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug(`set orientation`,e),this.$store.commit(`sora/setConfig`,{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||=A}}),Ae={class:`text-sm font-bold mb-2 block`},je={class:`items`},Me=[`onClick`],Ne={class:`name`};function Pe(e,n,a,o,s,c){return d(),m(`div`,null,[r(`span`,Ae,u(e.$t(`sora.name.orientation`)),1),r(`div`,je,[(d(!0),m(_,null,l(e.options,(n,a)=>(d(),m(`div`,{key:a,class:t({active:e.active===a,item:!0}),onClick:t=>e.value=n.value},[r(`div`,{class:t([`preview`,n.value])},[r(`div`,{class:`rect`,style:i({width:n.width+`px`,height:n.height+`px`})},null,4)],2),r(`p`,Ne,u(e.$t(n.labelKey)),1)],10,Me))),128))])])}var Fe=P(ke,[[`render`,Pe],[`__scopeId`,`data-v-a20be6d9`]]),Ie=c({name:`StartEndImage`,components:{ElUpload:x,ElButton:v,InfoIcon:Y,FontAwesomeIcon:W,ImagePreview:K},mixins:[B,H],emits:[`change`],data(){return{fileList:[],uploadUrl:R()+`/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?.sora?.config?.image_urls},set(){}}},mounted(){this.value||=void 0,this.onSetStartEndImageUrl()},methods:{onExceed(){V.warning(this.$t(`sora.message.uploadReferencesExceed`))},onError(){V.error(this.$t(`sora.message.uploadReferencesError`))},onSetStartEndImageUrl(){let e=this.urls;this.$store.commit(`sora/setConfig`,{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Le={class:`relative`},Re={class:`flex justify-between`},ze={class:`flex justify-start items-center`},Be={class:`text-sm font-bold`};function Ve(e,t,i,c,l,f){let g=p(`info-icon`),_=p(`image-preview`),v=p(`font-awesome-icon`),y=p(`el-button`),b=p(`el-upload`);return d(),m(`div`,Le,[r(`div`,Re,[r(`div`,ze,[r(`span`,Be,u(e.$t(`sora.name.startEndImage`)),1),o(g,{content:e.$t(`sora.description.uploadStartEndImage`)},null,8,[`content`])])]),o(b,{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:h(({file:t})=>[t.url&&t.percentage!==void 0?(d(),n(_,{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`])):s(``,!0)]),default:h(()=>[o(y,{round:``,type:`primary`,size:`small`,class:`btn btn-upload`},{default:h(()=>[o(v,{icon:`fa-solid fa-upload`,class:`icon mr-1`}),a(` `+u(e.$t(`sora.button.uploadReferences`)),1)]),_:1})]),_:1},8,[`file-list`,`action`,`on-exceed`,`on-error`,`on-success`,`headers`])])}var He=P(Ie,[[`render`,Ve],[`__scopeId`,`data-v-4f7d9ba5`]]),Ue=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),We=c({name:`SizeSelector`,components:{ElSelect:y,ElOption:b},data(){return{options:k.map(e=>({value:e,label:Ue(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){let t=this.$store.state.sora?.config||{};this.$store.commit(`sora/setConfig`,{...t,size:e})}}},mounted(){this.value||=M}}),Ge={class:`field`},Ke={class:`control`},qe={class:`title font-bold`};function Je(e,t,i,a,s,c){let f=p(`el-option`),g=p(`el-select`);return d(),m(`div`,Ge,[r(`div`,Ke,[r(`h2`,qe,u(e.$t(`sora.name.size`)),1),o(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||=t=>e.value=t,class:`value`,placeholder:e.$t(`sora.placeholder.select`)},{default:h(()=>[(d(!0),m(_,null,l(e.options,e=>(d(),n(f,{key:e.value,label:e.label,value:e.value},null,8,[`label`,`value`]))),128))]),_:1},8,[`modelValue`,`placeholder`])])])}var Ye=P(We,[[`render`,Je],[`__scopeId`,`data-v-8c485f0f`]]),Xe=c({name:`PromptInput`,components:{PromptTextarea:Q},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){this.$store.commit(`sora/setConfig`,{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||=``}});function Ze(e,t,r,i,a,o){let s=p(`prompt-textarea`);return d(),n(s,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||=t=>e.prompt=t,title:e.$t(`sora.name.prompt`),info:e.$t(`sora.description.prompt`),placeholder:e.$t(`sora.placeholder.prompt`)},null,8,[`modelValue`,`title`,`info`,`placeholder`])}var Qe=c({name:`ConfigPanel`,components:{ElButton:v,Consumption:re,FontAwesomeIcon:W,PromptInput:P(Xe,[[`render`,Ze]]),ModelSelector:ge,StartEndImage:He,SizeSelector:Ye,ActionSelector:Se,OrientationSelector:Fe,DurationSelector:Oe},emits:[`generate`],computed:{config(){return this.$store.state.sora?.config},consumption(){return I(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit(`generate`)}}}),$e={class:`flex flex-col h-full`},et={class:`flex-1 overflow-y-auto p-5`},tt={class:`flex flex-col items-center justify-center px-5 pb-5`};function nt(e,t,n,i,s,c){let l=p(`model-selector`),_=p(`action-selector`),v=p(`duration-selector`),y=p(`size-selector`),b=p(`orientation-selector`),x=p(`prompt-input`),S=p(`start-end-image`),C=p(`consumption`),w=p(`font-awesome-icon`),T=p(`el-button`);return d(),m(`div`,$e,[r(`div`,et,[o(l,{class:`mb-4`}),o(_,{class:`mb-4`}),o(v,{class:`mb-4`}),o(y,{class:`mb-4`}),o(b,{class:`mb-4`}),o(x,{class:`mb-4`}),g(o(S,{class:`mb-2`},null,512),[[f,e.config?.action===`image2video`]])]),r(`div`,tt,[o(C,{value:e.consumption,service:e.service},null,8,[`value`,`service`]),o(T,{type:`primary`,class:`btn w-full`,round:``,onClick:e.onGenerate},{default:h(()=>[o(w,{icon:`fa-solid fa-magic`,class:`mr-2`}),a(` `+u(e.$t(`sora.button.generate`)),1)]),_:1},8,[`onClick`])])])}var rt=P(Qe,[[`render`,nt]]),it=c({name:`TaskPreview`,components:{ElImage:C,CopyToClipboard:G,FontAwesomeIcon:W,ElAlert:w,VideoPlayer:ae,ElTooltip:S,ElButton:v,ApiCodeButton:ie},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log(`on download`),window.open(t,`_blank`)},onOpenVideo(e){window.open(e,`_blank`)}}}),at={class:`preview`},ot={class:`left`},st={class:`main`},ct={class:`bot`},lt={class:`datetime`},ut={class:`info`},dt={key:0,class:`prompt mt-2`},ft={key:0},pt={key:1},mt={key:0,class:t({content:!0,failed:!0})},ht={key:0,class:`mb-4`},gt={key:1,class:t({operations:!0,"mt-2":!0})},_t={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},vt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},yt={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},bt={key:1,class:t({content:!0})},xt={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},St={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},Ct={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-2`},wt={key:1,class:`text-[var(--el-text-color-regular)] text-xs mb-0`},Tt={key:2,class:t({content:!0})},Et={class:`text-[var(--el-text-color-regular)] text-xs mb-2`},$={key:0,class:`text-[var(--el-text-color-regular)] text-xs mb-0`};function Dt(e,t,i,c,l,f){let g=p(`el-image`),_=p(`video-player`),v=p(`el-button`),y=p(`el-tooltip`),b=p(`api-code-button`),x=p(`font-awesome-icon`),S=p(`copy-to-clipboard`),C=p(`el-alert`);return d(),m(`div`,at,[r(`div`,ot,[o(g,{src:`https://cdn.acedata.cloud/z5id1u.png`,class:`avatar`})]),r(`div`,st,[r(`div`,ct,[a(u(e.$t(`sora.name.soraBot`))+` `,1),r(`span`,lt,u(e.$dayjs.format(``+new Date(parseFloat((e.modelValue?.created_at||``).toString())*1e3))),1)]),r(`div`,ut,[e.modelValue?.request?.prompt?(d(),m(`p`,dt,[a(u(e.modelValue?.request?.prompt)+` `,1),e.modelValue?.response?s(``,!0):(d(),m(`span`,ft,` - (`+u(e.$t(`sora.status.pending`))+`) `,1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state===`pending`?(d(),m(`span`,pt,` - (`+u(e.$t(`sora.status.processing`))+`) `,1)):s(``,!0)])):s(``,!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(d(),m(`div`,mt,[e.modelValue?.response?.data[0]?.video_url?(d(),m(`div`,ht,[o(_,{src:e.modelValue?.response?.data[0]?.video_url},null,8,[`src`])])):s(``,!0),e.modelValue?.response.success?(d(),m(`div`,gt,[o(y,{class:`box-item`,effect:`dark`,content:e.$t(`sora.message.downloadVideo`),placement:`top-start`},{default:h(()=>[e.modelValue?.response?.data[0]?.video_url?(d(),n(v,{key:0,type:`info`,size:`small`,class:`btn-action`,onClick:t[0]||=t=>e.onDownload(t,e.modelValue?.response?.data[0]?.video_url)},{default:h(()=>[a(u(e.$t(`sora.button.download`)),1)]),_:1})):s(``,!0)]),_:1},8,[`content`]),o(b,{path:`/sora/videos`,body:e.modelValue?.request},null,8,[`body`])])):s(``,!0),o(C,{closable:!1,class:`mt-2 success`},{default:h(()=>[r(`p`,_t,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.model`))+`: `+u(e.modelValue?.request?.model),1)]),r(`p`,vt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,yt,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===!1?(d(),m(`div`,bt,[o(C,{closable:!1,class:`failure`},{template:h(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failure`)),1)]),default:h(()=>[r(`p`,xt,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),r(`p`,St,[o(x,{icon:`fa-solid fa-circle-info`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failureReason`))+`: `+u(e.modelValue?.response?.error?.message)+` `,1),o(S,{content:e.modelValue?.response?.error?.message},null,8,[`content`])]),e.modelValue?.elapsed?(d(),m(`p`,Ct,[o(x,{icon:`fa-solid fa-clock`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.elapsed`))+`: `+u(e.modelValue?.elapsed?.toFixed(2))+`s `,1)])):s(``,!0),e.modelValue?.response?.trace_id?(d(),m(`p`,wt,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0),e.modelValue?.response?.success===void 0?(d(),m(`div`,Tt,[o(C,{closable:!1,class:`info`},{template:h(()=>[o(x,{icon:`fa-solid fa-exclamation-triangle`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.failure`)),1)]),default:h(()=>[r(`p`,Et,[o(x,{icon:`fa-solid fa-magic`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.taskId`))+`: `+u(e.modelValue?.id)+` `,1),o(S,{content:e.modelValue?.id},null,8,[`content`])]),e.modelValue?.response?.trace_id?(d(),m(`p`,$,[o(x,{icon:`fa-solid fa-hashtag`,class:`mr-1`}),a(` `+u(e.$t(`sora.name.traceId`))+`: `+u(e.modelValue?.response?.trace_id)+` `,1),o(S,{content:e.modelValue?.response?.trace_id},null,8,[`content`])])):s(``,!0)]),_:1})])):s(``,!0)])])}var Ot=c({name:`RecentPanel`,components:{TaskPreview:P(it,[[`render`,Dt],[`__scopeId`,`data-v-935f9471`]]),NoTasks:ne,BotPlaceholder:J,ScrollList:X},props:{loading:{type:Boolean,default:!1}},emits:[`reach-top`],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),kt={key:0},At={key:2,class:`w-full h-full flex items-center justify-center`};function jt(e,t,r,i,a,c){let u=p(`bot-placeholder`),f=p(`task-preview`),g=p(`scroll-list`),v=p(`no-tasks`);return d(),m(_,null,[e.tasks?.items===void 0?(d(),m(`div`,kt,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(d(),n(g,{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:h(()=>[(d(!0),m(_,null,l(e.tasks?.items,(e,t)=>(d(),n(f,{key:t,"model-value":e},null,8,[`model-value`]))),128))]),_:1},8,[`loading`])):s(``,!0),e.tasks?.items?.length===0?(d(),m(`div`,At,[o(v)])):s(``,!0)],64)}var Mt=P(Ot,[[`render`,jt]]),Nt=te(`sora`),Pt=c({name:`SoraIndex`,components:{ConfigPanel:rt,Layout:de,RecentPanel:Mt},mixins:[N],inject:[`initialized`],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.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 Z({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(`sora/getService`),console.debug(`end onGetService`)},async onGetApplication(){console.debug(`start onGetApplication`),await this.$store.dispatch(`sora/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(`sora/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,callback_url:Nt},t=this.credential?.token;if(!t){console.error(`no token specified`);return}V.info(this.$t(`sora.message.startingTask`)),F(`sora`,z.generate(e,{token:t})).then(()=>{V.success(this.$t(`sora.message.startTaskSuccess`))}).catch(e=>{(e?.response?.data)?.error?.code===`used_up`?V.error(this.$t(`sora.message.usedUp`)):V.error(this.$t(`sora.message.startTaskFailed`))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Ft(e,t,r,i,a,s){let c=p(`config-panel`),l=p(`recent-panel`),u=p(`layout`);return d(),n(u,null,{config:h(()=>[o(c,{onGenerate:e.onGenerate},null,8,[`onGenerate`])]),result:h(()=>[o(l,{ref:`recentPanel`,loading:e.loadingMore,onReachTop:e.onReachTop},null,8,[`loading`,`onReachTop`])]),_:1})}var It=P(Pt,[[`render`,Ft]]);export{It as default};