@acedatacloud/nexior 3.17.7 → 3.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/dist/assets/{Auth-dzXu54ez.js → Auth-YkU_SytW.js} +1 -1
  2. package/dist/assets/{Callback-BRLf1vNX.js → Callback-xxVfD2p4.js} +1 -1
  3. package/dist/assets/{Console-BTWU1dGn.js → Console-BCzAamf-.js} +1 -1
  4. package/dist/assets/{Conversation-CBoisJCu.js → Conversation-BWSJhAFb.js} +10 -10
  5. package/dist/assets/{Conversation-Bf5vKePm.css → Conversation-t9mI4KIt.css} +1 -1
  6. package/dist/assets/{CopyToClipboard-IxJR61wg.js → CopyToClipboard-MNFOHaqI.js} +1 -1
  7. package/dist/assets/{Detail-CQaB0jBV.js → Detail-lydJ490z.js} +1 -1
  8. package/dist/assets/{EditArray-BEexyJll.js → EditArray-7TB_XCQ-.js} +1 -1
  9. package/dist/assets/{Extra-CbvGWu3X.js → Extra-CBGLz_VW.js} +1 -1
  10. package/dist/assets/{FilePreview-By9MS07q.js → FilePreview-D_6PFLOY.js} +1 -1
  11. package/dist/assets/{History-BATa21l2.js → History-BgdY4Y1R.js} +1 -1
  12. package/dist/assets/{ImagePreview-GXlfENrf.js → ImagePreview-CET7KBKE.js} +1 -1
  13. package/dist/assets/{ImageWrapper-Dtbv93SE.js → ImageWrapper-BH86BJsH.js} +1 -1
  14. package/dist/assets/Index-5gnVQGkt.js +1 -0
  15. package/dist/assets/Index-BmDYsPbN.js +1 -0
  16. package/dist/assets/{Index-B1xaDJNM.js → Index-Bolmm8xo.js} +1 -1
  17. package/dist/assets/Index-C5DJuhKj.js +1 -0
  18. package/dist/assets/Index-CHZtk3p_.js +1 -0
  19. package/dist/assets/Index-Ce75G1Zn.js +1 -0
  20. package/dist/assets/{Index-BGBX0Hbh.js → Index-D1j0pXfx.js} +1 -1
  21. package/dist/assets/Index-D5AYdUSj.css +1 -0
  22. package/dist/assets/{Index-HHYYDRsb.js → Index-DMJiWqIm.js} +1 -1
  23. package/dist/assets/{Index-DsGikYEE.js → Index-DahYAZoZ.js} +1 -1
  24. package/dist/assets/Index-DleiyNcv.js +1 -0
  25. package/dist/assets/Index-DxPsg9rS.js +1 -0
  26. package/dist/assets/Index-DzKQkHQz.js +1 -0
  27. package/dist/assets/{Index-BFQNJh_A.js → Index-YX9C99Fw.js} +1 -1
  28. package/dist/assets/{Index-ENANQbXH.js → Index-azHe5jHn.js} +1 -1
  29. package/dist/assets/{InfoIcon-CwVCPHCP.js → InfoIcon-nWEOcBLm.js} +1 -1
  30. package/dist/assets/{Invitees-cKRYypfO.js → Invitees-FtlIybpF.js} +1 -1
  31. package/dist/assets/List-CU4_X2Fj.js +1 -0
  32. package/dist/assets/List-CujK44q3.js +1 -0
  33. package/dist/assets/List-xLFrAXJP.js +1 -0
  34. package/dist/assets/{Login-2WKjLHHE.js → Login-WX-IkmIQ.js} +1 -1
  35. package/dist/assets/{Main-BFZm-MAx.js → Main-B7QToEHd.js} +1 -1
  36. package/dist/assets/{Navigator-Ceq4Wad_.css → Navigator-BVabXyZw.css} +1 -1
  37. package/dist/assets/{Navigator-DQZknvN0.js → Navigator-DeQEcJIk.js} +1 -1
  38. package/dist/assets/NoTasks-BdeBQAXO.js +1 -0
  39. package/dist/assets/{Pagination-azxdzNrH.js → Pagination-B7VBZ08A.js} +1 -1
  40. package/dist/assets/{Status-BJn6Jsz9.js → Status-nhyKVjFD.js} +1 -1
  41. package/dist/assets/{Subscribe-Cm2cvVEn.js → Subscribe-B4u5tphs.js} +1 -1
  42. package/dist/assets/{VideoPlayer-BdCTnWuK.js → VideoPlayer-Dhhv87vC.js} +1 -1
  43. package/dist/assets/{_Uint8Array-Djk9lJCp.js → _Uint8Array-BP0U7Iu_.js} +1 -1
  44. package/dist/assets/{_baseClone-_0JJYp5J.js → _baseClone-BBG0IH2E.js} +1 -1
  45. package/dist/assets/{_baseIteratee-CvFPRO8v.js → _baseIteratee-CxKAS7w7.js} +1 -1
  46. package/dist/assets/{_initCloneObject-CdQfCT40.js → _initCloneObject-D12d2S1r.js} +1 -1
  47. package/dist/assets/{castArray-B-n0ZfD-.js → castArray-DKMGoQO3.js} +1 -1
  48. package/dist/assets/{debounce-94P5SC1k.js → debounce-CH-Z-bEk.js} +1 -1
  49. package/dist/assets/{distribution-BwfEOWPq.js → distribution-Cm5iZXNQ.js} +1 -1
  50. package/dist/assets/{dropdown-D5AAT6ZH.js → dropdown-BgJeLUwR.js} +1 -1
  51. package/dist/assets/{index-CAScKEAu.js → index-98VGGErr.js} +2 -2
  52. package/dist/assets/{index-D6GwvWcD.js → index-B307mgep.js} +1 -1
  53. package/dist/assets/{index-HJfhXT93.js → index-B9tmKJTL.js} +1 -1
  54. package/dist/assets/{index-BSAjcrrC.js → index-BDa8awCt.js} +1 -1
  55. package/dist/assets/{index-Dd1VRLRi.css → index-BY-0WHwt.css} +1 -1
  56. package/dist/assets/{index-CJePgca8.js → index-B_oL3gLq.js} +1 -1
  57. package/dist/assets/{index-TJ2qXY2t.js → index-Be00AR5y.js} +1 -1
  58. package/dist/assets/{index-Cc85uiiK.js → index-BeqHYC-h.js} +1 -1
  59. package/dist/assets/{index-DWqHqFJY.js → index-BjvJ8MZp.js} +1 -1
  60. package/dist/assets/{index-74_Ssoda.js → index-ByXZ-2lh.js} +1 -1
  61. package/dist/assets/{index-Bzr3IjSr.js → index-CEAOvLtE.js} +1 -1
  62. package/dist/assets/{index-U_t6doDH.js → index-CQjyBwMm.js} +1 -1
  63. package/dist/assets/{index-BQExLqgj.js → index-CcyWuqA_.js} +1 -1
  64. package/dist/assets/{index-CSpB1F5W.js → index-ChfW7Lcp.js} +1 -1
  65. package/dist/assets/{index-Aqgtd2nL.js → index-CiX1WALY.js} +1 -1
  66. package/dist/assets/{index-NhRVpwT0.js → index-Cr8oY95Z.js} +1 -1
  67. package/dist/assets/{index-CXzCPe-2.js → index-CwD7WKHl.js} +1 -1
  68. package/dist/assets/{index-WRG1ce6I.js → index-D-7-e_ZW.js} +1 -1
  69. package/dist/assets/{index-CgrHCRIp.js → index-DE0NLUHP.js} +1 -1
  70. package/dist/assets/{index-C1rnYNjG.js → index-DQLaLsnP.js} +1 -1
  71. package/dist/assets/{index-4lEOv1Ve.js → index-DfAeDMXy.js} +1 -1
  72. package/dist/assets/{index-GI4Qjwb_.js → index-DlKgExzj.js} +1 -1
  73. package/dist/assets/{index-DpEzbAMX.js → index-DvdaM5kg.js} +1 -1
  74. package/dist/assets/{index-C4777Kma.js → index-DzX5B-3h.js} +1 -1
  75. package/dist/assets/{index-Bm0eHRgH.js → index-TZWWVHIQ.js} +1 -1
  76. package/dist/assets/{index-osd68rOb.js → index-W1lJvRgD.js} +1 -1
  77. package/dist/assets/{index-Cgnfn5bX.js → index-_DEa56hX.js} +1 -1
  78. package/dist/assets/{index-LAL8pDPz.js → index-bhFxQQDC.js} +1 -1
  79. package/dist/assets/{index-1c2qdYrk.js → index-nkzmx8qJ.js} +1 -1
  80. package/dist/assets/{index-Dw-sPEJy.js → index-w-DB8id9.js} +1 -1
  81. package/dist/assets/{index.es-Ds1LLYZB.js → index.es-BGVkY8oJ.js} +1 -1
  82. package/dist/assets/{isEqual-BCLzbsf0.js → isEqual-0nIQYJnJ.js} +1 -1
  83. package/dist/assets/{isPlainObject-Dgu9CGNL.js → isPlainObject-L3A-QG3u.js} +1 -1
  84. package/dist/assets/{order-BpuNlv-w.js → order-Clpmfbyf.js} +1 -1
  85. package/dist/assets/{price-lH10nUr5.js → price-Cu8efP-h.js} +1 -1
  86. package/dist/assets/{strings-CZWcdhe2.js → strings-BCHZaT3A.js} +1 -1
  87. package/dist/assets/{typescript-WjCVvA-y.js → typescript-1ic-flAv.js} +1 -1
  88. package/dist/assets/{use-form-item-DTrPd0ld.js → use-form-item-94xb2lbs.js} +1 -1
  89. package/dist/index.html +2 -2
  90. package/package.json +3 -3
  91. package/dist/assets/BotPlaceholder-DovcLg2h.js +0 -1
  92. package/dist/assets/Index-3VhuOM_h.js +0 -1
  93. package/dist/assets/Index-BMVRcaL2.js +0 -1
  94. package/dist/assets/Index-Bu-Ijnq-.js +0 -1
  95. package/dist/assets/Index-C-ur-OUi.js +0 -1
  96. package/dist/assets/Index-C8OKal7v.js +0 -1
  97. package/dist/assets/Index-CgwTK6_y.js +0 -1
  98. package/dist/assets/Index-D1W0vKj1.css +0 -1
  99. package/dist/assets/Index-G6NXKb-v.js +0 -1
  100. package/dist/assets/Index-U0r_bJMR.js +0 -1
  101. package/dist/assets/List-BuL_ha7Z.js +0 -1
  102. package/dist/assets/List-DO_90voW.js +0 -1
  103. package/dist/assets/List-HRuTvGfZ.css +0 -1
  104. package/dist/assets/List-un9qdR5s.js +0 -1
  105. package/dist/assets/NoTasks-Cgq80HtK.js +0 -1
  106. /package/dist/assets/{BotPlaceholder-C_P7dqM5.css → NoTasks-C_P7dqM5.css} +0 -0
@@ -0,0 +1 @@
1
+ import{F as U}from"./index.es-BGVkY8oJ.js";import{E as I}from"./index-CcyWuqA_.js";import{E as L}from"./index-Be00AR5y.js";import{d as b,h as k,b as l,t as i,k as t,r as T,j as u,l as o,o as s,eJ as R,x as n,F as C,v as G,i as v,c6 as P,D as p,y as h,n as E,ah as j,eK as D,dr as B,dm as M}from"./index-98VGGErr.js";import{E as q,a as O}from"./index-Cr8oY95Z.js";import{I as A}from"./InfoIcon-nWEOcBLm.js";import{I as z}from"./ImagePreview-CET7KBKE.js";import{E as F}from"./index-B9tmKJTL.js";import{E as V}from"./index-bhFxQQDC.js";import{E as N}from"./index-DvdaM5kg.js";import{C as H,N as K,B as J}from"./NoTasks-BdeBQAXO.js";import{a as Q}from"./price-Cu8efP-h.js";import{C as W}from"./CopyToClipboard-MNFOHaqI.js";import{V as X}from"./VideoPlayer-Dhhv87vC.js";import{E as Y}from"./index-DfAeDMXy.js";import{E as Z}from"./index-DzX5B-3h.js";import{E as x}from"./index-nkzmx8qJ.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-CEAOvLtE.js";import"./typescript-1ic-flAv.js";import"./index-DQLaLsnP.js";import"./strings-BCHZaT3A.js";import"./castArray-DKMGoQO3.js";import"./isEqual-0nIQYJnJ.js";import"./_Uint8Array-BP0U7Iu_.js";import"./debounce-CH-Z-bEk.js";import"./_baseIteratee-CxKAS7w7.js";import"./index-ByXZ-2lh.js";import"./index-CwD7WKHl.js";import"./_baseClone-BBG0IH2E.js";import"./_initCloneObject-D12d2S1r.js";import"./index-CiX1WALY.js";import"./index-ChfW7Lcp.js";import"./vue-plyr-QZFBikSk.js";const ee=b({name:"LayoutHailuo",components:{ElDrawer:L,ElButton:I,FontAwesomeIcon:U},data(){return{drawer:!1}}}),te={class:"main"},oe={class:"config"},se={class:"result"};function ae(e,a,f,_,y,w){const d=o("font-awesome-icon"),m=o("el-button"),r=o("el-drawer");return s(),l("div",te,[i("div",oe,[T(e.$slots,"config",{},void 0,!0)]),i("div",se,[T(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:a[0]||(a[0]=g=>e.drawer=!0)},{default:u(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(r,{modelValue:e.drawer,"onUpdate:modelValue":a[1]||(a[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ne=k(ee,[["render",ae],["__scopeId","data-v-20539cd5"]]),le=b({name:"ModelSelector",components:{ElSelect:O,ElOption:q},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=R)}}),ie={class:"field"},re={class:"title font-bold"},ce={class:"float-left"};function ue(e,a,f,_,y,w){const d=o("el-option"),m=o("el-select");return s(),l("div",ie,[i("h2",re,n(e.$t("hailuo.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=r=>e.value=r),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:u(()=>[(s(!0),l(C,null,G(e.options,r=>(s(),v(d,{key:r.value,label:r.label,value:r.value},{default:u(()=>[i("span",ce,n(r.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const de=k(le,[["render",ue],["__scopeId","data-v-30ff1e69"]]),me=b({name:"StartImageUrlInput",components:{ElUpload:F,ElButton:I,InfoIcon:A,ImagePreview:z},data(){return{fileList:[],uploadUrl:P()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){V.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){V.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){V.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),pe={class:"relative"},he={class:"flex justify-between"},fe={class:"flex justify-start items-center"},_e={class:"text-sm font-bold"};function ge(e,a,f,_,y,w){const d=o("info-icon"),m=o("image-preview"),r=o("el-button"),g=o("el-upload");return s(),l("div",pe,[i("div",he,[i("div",fe,[i("span",_e,n(e.$t("hailuo.name.startImageUrl")),1),t(d,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=c=>e.fileList=c),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:c})=>[c.url&&c.percentage!==void 0?(s(),v(m,{key:0,url:c.url,name:c.name,percentage:c.percentage,onRemove:$=>e.fileList.splice(e.fileList.indexOf(c),1)},null,8,["url","name","percentage","onRemove"])):h("",!0)]),default:u(()=>[t(r,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:u(()=>[p(n(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const $e=k(me,[["render",ge],["__scopeId","data-v-a906df80"]]),ve="",be=b({name:"PromptInput",components:{ElInput:N,InfoIcon:A},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=ve)}}),ke={class:"field"},ye={class:"box"},we={class:"title font-bold"};function Ve(e,a,f,_,y,w){const d=o("info-icon"),m=o("el-input");return s(),l("div",ke,[i("div",ye,[i("h2",we,n(e.$t("hailuo.name.prompt")),1),t(d,{content:e.$t("hailuo.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":a[0]||(a[0]=r=>e.prompt=r),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("hailuo.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ie=k(be,[["render",Ve],["__scopeId","data-v-d54ffa64"]]),Ee=b({name:"PresetPanel",components:{ElButton:I,FontAwesomeIcon:U,PromptInput:Ie,StartImageUrlInput:$e,ModelSelector:de,Consumption:H},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return Q(this.config,this.service?.metadata?.price)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Se={class:"flex flex-col h-full"},Te={class:"flex-1 overflow-y-auto p-[15px]"},Ce={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ue(e,a,f,_,y,w){const d=o("prompt-input"),m=o("model-selector"),r=o("start-image-url-input"),g=o("consumption"),c=o("font-awesome-icon"),$=o("el-button");return s(),l("div",Se,[i("div",Te,[t(d,{class:"mb-4"}),t(m,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(s(),v(r,{key:0,class:"mb-2"})):h("",!0)]),i("div",Ce,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(s(),v($,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(c,{icon:"fa-solid fa-magic",class:"mr-2"}),p(" "+n(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(s(),v($,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(c,{icon:"fa-solid fa-magic",class:"mr-2"}),p(" "+n(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Ge=k(Ee,[["render",Ue]]),Ae=b({name:"TaskPreview",components:{ElImage:x,CopyToClipboard:W,FontAwesomeIcon:U,ElAlert:Z,VideoPlayer:X,ElTooltip:Y,ElButton:I},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),Le={class:"preview"},Re={class:"left"},Pe={class:"main"},je={class:"bot"},De={class:"datetime"},Be={class:"info"},Me={key:0,class:"prompt mt-2"},qe={key:0},Oe={key:1},ze={key:0,class:E({content:!0,failed:!0})},Fe={key:0,class:"mb-4"},Ne={key:1,class:E({operations:!0,"mt-2":!0})},He={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ke={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Je={key:1,class:E({content:!0})},Qe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},We={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xe={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ye={key:2,class:E({content:!0})},Ze={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function xe(e,a,f,_,y,w){const d=o("el-image"),m=o("video-player"),r=o("el-button"),g=o("el-tooltip"),c=o("font-awesome-icon"),$=o("copy-to-clipboard"),S=o("el-alert");return s(),l("div",Le,[i("div",Re,[t(d,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),i("div",Pe,[i("div",je,[p(n(e.$t("hailuo.name.hailuoBot"))+" ",1),i("span",De,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",Be,[e.modelValue?.request?.prompt?(s(),l("p",Me,[p(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(s(),l("span",qe," - ("+n(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(s(),l("span",Oe," - ("+n(e.$t("hailuo.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(s(),l("div",ze,[e.video?.video_url?(s(),l("div",Fe,[t(m,{src:e.video?.video_url},null,8,["src"])])):h("",!0),e.video?(s(),l("div",Ne,[t(g,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.video?.video_url?(s(),v(r,{key:0,type:"info",size:"small",class:"mb-2",onClick:a[0]||(a[0]=j(ut=>e.onDownload(e.video?.video_url),["stop"]))},{default:u(()=>[p(n(e.$t("hailuo.button.download")),1)]),_:1})):h("",!0)]),_:1},8,["content"])])):h("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(s(),l("p",He,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.model"))+": "+n(e.modelValue?.request?.model)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])):h("",!0),i("p",Ke,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(s(),l("div",Je,[t(S,{closable:!1,class:"failure"},{template:u(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failure")),1)]),default:u(()=>[i("p",Qe,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),i("p",We,[t(c,{icon:"fa-solid fa-circle-info",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t($,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),i("p",Xe,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t($,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===void 0?(s(),l("div",Ye,[t(S,{closable:!1,class:"info"},{template:u(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failure")),1)]),default:u(()=>[i("p",Ze,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):h("",!0)])])}const et=k(Ae,[["render",xe],["__scopeId","data-v-72acd507"]]),tt=b({name:"RecentPanel",components:{TaskPreview:et,BotPlaceholder:J,NoTasks:K},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),ot={key:0},st={key:1,class:"tasks w-full h-full overflow-y-auto"},at={key:2,class:"w-full h-full flex items-center justify-center"};function nt(e,a,f,_,y,w){const d=o("bot-placeholder"),m=o("task-preview"),r=o("no-tasks");return s(),l(C,null,[e.tasks?.items===void 0?(s(),l("div",ot,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(s(),l("div",st,[(s(!0),l(C,null,G(e.tasks?.items,g=>(s(),v(m,{key:g.id,"model-value":g},null,8,["model-value"]))),128))])):h("",!0),e.tasks?.items?.length===0?(s(),l("div",at,[t(r)])):h("",!0)],64)}const lt=k(tt,[["render",nt]]),it="https://webhook.acedata.cloud/hailuo",rt=b({name:"HailuoIndex",components:{ConfigPanel:Ge,Layout:ne,RecentPanel:lt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0}},computed:{loading(){return this.$store.state.hailuo?.status?.getApplications===M.Request},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,a){e?.items?.length>a?.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:a=5,createdAtMin:f,createdAtMax:_}=e||{};console.debug("limit",a,"createdAtMin",f,"createdAtMax",_),await this.$store.dispatch("hailuo/getTasks",{limit:a,createdAtMin:f,createdAtMax:_})},async onGenerate(){const e={...this.config,callback_url:it},a=this.credential?.token;if(!a){console.error("no token specified");return}V.info(this.$t("hailuo.message.startingTask")),D.generate(e,{token:a}).then(()=>{V.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===B?V.error(this.$t("hailuo.message.usedUp")):V.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function ct(e,a,f,_,y,w){const d=o("config-panel"),m=o("recent-panel"),r=o("layout");return s(),v(r,null,{config:u(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Kt=k(rt,[["render",ct]]);export{Kt as default};
@@ -0,0 +1 @@
1
+ import{F as S}from"./index.es-BGVkY8oJ.js";import{E as I}from"./index-CcyWuqA_.js";import{E as O}from"./index-Be00AR5y.js";import{d as v,h as b,b as m,t as n,k as t,r as T,j as u,l as s,o as a,ei as N,x as i,ej as q,ek as H,c6 as j,D as g,i as k,y as f,n as C,ah as z,F as D,v as K,el as J,dr as Q,dm as W}from"./index-98VGGErr.js";import{I as U}from"./InfoIcon-nWEOcBLm.js";import{E as A}from"./index-TZWWVHIQ.js";import{I as F}from"./ImagePreview-CET7KBKE.js";import{E as R}from"./index-B9tmKJTL.js";import{E}from"./index-bhFxQQDC.js";import{F as X}from"./FilePreview-D_6PFLOY.js";import{E as Y}from"./index-DvdaM5kg.js";import{V as M}from"./VideoPlayer-Dhhv87vC.js";import{C as Z,N as x,B as ee}from"./NoTasks-BdeBQAXO.js";import{a as te}from"./price-Cu8efP-h.js";import{C as oe}from"./CopyToClipboard-MNFOHaqI.js";import{E as se}from"./index-DfAeDMXy.js";import{E as ne}from"./index-DzX5B-3h.js";import{E as ae}from"./index-nkzmx8qJ.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-DQLaLsnP.js";import"./index-CwD7WKHl.js";import"./typescript-1ic-flAv.js";import"./_baseClone-BBG0IH2E.js";import"./_Uint8Array-BP0U7Iu_.js";import"./_initCloneObject-D12d2S1r.js";import"./isEqual-0nIQYJnJ.js";import"./index-CiX1WALY.js";import"./vue-plyr-QZFBikSk.js";import"./index-ChfW7Lcp.js";import"./debounce-CH-Z-bEk.js";const le=v({name:"LayoutLuma",components:{ElDrawer:O,ElButton:I,FontAwesomeIcon:S},data(){return{drawer:!1}}}),ie={class:"main"},re={class:"config"},ce={class:"result"};function me(e,o,p,h,w,y){const r=s("font-awesome-icon"),d=s("el-button"),c=s("el-drawer");return a(),m("div",ie,[n("div",re,[T(e.$slots,"config",{},void 0,!0)]),n("div",ce,[T(e.$slots,"result",{},void 0,!0)]),t(d,{circle:"",class:"menu",onClick:o[0]||(o[0]=_=>e.drawer=!0)},{default:u(()=>[t(r,{icon:"fa-solid fa-magic"})]),_:1}),t(c,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=_=>e.drawer=_),direction:"ltr","with-header":!1,size:"350px",class:"drawer"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=b(le,[["render",me],["__scopeId","data-v-e43f6bbe"]]),de=v({name:"EnhancementSelector",components:{ElSwitch:A,InfoIcon:U},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=N)}}),pe={class:"relative"},fe={class:"flex justify-between"},_e={class:"flex justify-start items-center"},he={class:"text-sm font-bold"},$e={class:"flex justify-end items-center"};function ge(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",pe,[n("div",fe,[n("div",_e,[n("span",he,i(e.$t("luma.name.enhancement")),1),t(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),n("div",$e,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const ve=b(de,[["render",ge]]),be=v({name:"CustomSelector",components:{ElSwitch:A,InfoIcon:U},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=q)}}),we={class:"relative"},ye={class:"flex justify-between"},ke={class:"flex justify-start items-center"},Ee={class:"text-sm font-bold"},Ve={class:"flex justify-end items-center"};function Ue(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",we,[n("div",ye,[n("div",ke,[n("span",Ee,i(e.$t("luma.name.custom")),1),t(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),n("div",Ve,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const Se=b(be,[["render",Ue]]),Ie=v({name:"LoopSelector",components:{ElSwitch:A,InfoIcon:U},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=H)}}),Le={class:"relative"},Ce={class:"flex justify-between"},Te={class:"flex justify-start items-center"},je={class:"text-sm font-bold"},Ae={class:"flex justify-end items-center"};function Re(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Le,[n("div",Ce,[n("div",Te,[n("span",je,i(e.$t("luma.name.loop")),1),t(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),n("div",Ae,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const Ge=b(Ie,[["render",Re]]),Pe=v({name:"EndImage",components:{ElUpload:R,ElButton:I,ImagePreview:F,InfoIcon:U,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetEndImageUrl()},methods:{onExceed(){E.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){E.error(this.$t("luma.message.uploadReferencesError"))},onSetEndImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,end_image_url:e})},async onSuccess(){this.onSetEndImageUrl()}}}),ze={class:"relative"},De={class:"flex justify-between"},Fe={class:"flex justify-start items-center"},Me={class:"text-sm font-bold"};function Be(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),_=s("el-button"),$=s("el-upload");return a(),m("div",ze,[n("div",De,[n("div",Fe,[n("span",Me,i(e.$t("luma.name.endImageUrl")),1),t(r,{content:e.$t("luma.description.endImageUrl")},null,8,["content"])])]),t($,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=l=>e.fileList=l),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:u(({file:l})=>[l.url&&l.percentage!==void 0?(a(),k(d,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Oe=b(Pe,[["render",Be],["__scopeId","data-v-7ab78c3e"]]),Ne=v({name:"StartImage",components:{ElUpload:R,ElButton:I,ImagePreview:F,InfoIcon:U,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.luma?.config?.start_image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){E.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){E.error(this.$t("luma.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,start_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),qe={class:"relative"},He={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},Je={class:"text-sm font-bold"};function Qe(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),_=s("el-button"),$=s("el-upload");return a(),m("div",qe,[n("div",He,[n("div",Ke,[n("span",Je,i(e.$t("luma.name.startImageUrl")),1),t(r,{content:e.$t("luma.description.startImageUrl")},null,8,["content"])])]),t($,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=l=>e.fileList=l),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:u(({file:l})=>[l.percentage!=null?(a(),k(d,{key:0,url:l.url||l.response.file_url,name:l.name,percentage:l.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const We=b(Ne,[["render",Qe],["__scopeId","data-v-425a8cec"]]),Xe=v({name:"UploadVideo",components:{ElUpload:R,ElButton:I,InfoIcon:U,FilePreview:X,FontAwesomeIcon:S},data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.luma?.config?.video_url},set(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e})}}},mounted(){this.value||(this.value=void 0)},methods:{onExceed(){E.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){E.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const o=e.type==="video/mp4",p=e.size/1024/1024<10;return o?p?!0:(E.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(E.error(this.$t("luma.message.uploadVideoTypeFailed")),!1)},onSetVideoUrl(){const e=this.urls?.[0];this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_url:e,action:"extend"})},async onSuccess(){this.onSetVideoUrl()}}}),Ye={class:"relative"},Ze={class:"flex justify-between"},xe={class:"flex justify-start items-center"},et={class:"text-sm font-bold"};function tt(e,o,p,h,w,y){const r=s("info-icon"),d=s("file-preview"),c=s("font-awesome-icon"),_=s("el-button"),$=s("el-upload");return a(),m("div",Ye,[n("div",Ze,[n("div",xe,[n("span",et,i(e.$t("luma.name.videoUrl")),1),t(r,{content:e.$t("luma.description.videoUrl")},null,8,["content"])])]),t($,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=l=>e.fileList=l),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:u(({file:l})=>[l.percentage!=null?(a(),k(d,{key:0,url:l.url||l.response?.file_url,name:l.name,percentage:l.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),g(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const ot=b(Xe,[["render",tt],["__scopeId","data-v-74e51526"]]),st="",nt=v({name:"PromptInput",components:{ElInput:Y,InfoIcon:U},computed:{prompt:{get(){return this.$store.state.luma?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=st)}}),at={class:"field"},lt={class:"box"},it={class:"title font-bold"};function rt(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-input");return a(),m("div",at,[n("div",lt,[n("h2",it,i(e.$t("luma.name.prompt")),1),t(r,{content:e.$t("luma.description.prompt"),class:"info"},null,8,["content"])]),t(d,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=c=>e.prompt=c),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("luma.placeholder.prompt"),maxlength:2e3,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ct=b(nt,[["render",rt],["__scopeId","data-v-e8284075"]]),mt=v({name:"ExtendFromInput",components:{VideoPlayer:M},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),ut={class:"relative"},dt={class:"flex mb-2"},pt={class:"text-sm font-bold"};function ft(e,o,p,h,w,y){const r=s("video-player");return a(),m("div",ut,[n("div",dt,[n("span",pt,i(e.$t("luma.name.extend")),1)]),n("div",null,[e.config?.video_url?(a(),k(r,{key:0,src:e.config?.video_url},null,8,["src"])):f("",!0)])])}const _t=b(mt,[["render",ft]]),ht=v({name:"ConfigPanel",components:{LoopSelector:Ge,StartImageInput:We,EndImageInput:Oe,EnhancementSelector:ve,ElButton:I,FontAwesomeIcon:S,PromptInput:ct,ExtendFromInput:_t,CustomSelector:Se,UploadVideo:ot,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.luma?.config},consumption(){return te(this.config,this.service?.metadata?.price)},service(){return this.$store.state.luma?.service}},methods:{onGenerate(){this.$emit("generate")}}}),$t={class:"flex flex-col h-full"},gt={class:"flex-1 overflow-y-auto p-[15px]"},vt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function bt(e,o,p,h,w,y){const r=s("extend-from-input"),d=s("prompt-input"),c=s("custom-selector"),_=s("upload-video"),$=s("start-image-input"),l=s("end-image-input"),V=s("enhancement-selector"),L=s("loop-selector"),B=s("consumption"),G=s("font-awesome-icon"),P=s("el-button");return a(),m("div",$t,[n("div",gt,[e.config?.video_id||e.config?.video_url?(a(),k(r,{key:0,class:"mb-4"})):f("",!0),t(d,{class:"mb-4"}),e.config?.video_id?f("",!0):(a(),k(c,{key:1,class:"mb-4"})),e.config?.custom?(a(),k(_,{key:2,class:"mb-4"})):f("",!0),!(e.config?.video_id||e.config?.video_url)&&!e.config?.custom?(a(),k($,{key:3,class:"mb-4"})):f("",!0),t(l,{class:"mb-4"}),t(V,{class:"mb-4"}),t(L,{class:"mb-4"})]),n("div",vt,[t(B,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),k(P,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(G,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.extend")),1)]),_:1},8,["onClick"])):(a(),k(P,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(G,{icon:"fa-solid fa-magic",class:"mr-2"}),g(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])}const wt=b(ht,[["render",bt]]),yt=v({name:"TaskPreview",components:{ElImage:ae,CopyToClipboard:oe,FontAwesomeIcon:S,ElAlert:ne,VideoPlayer:M,ElTooltip:se,ElButton:I},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,o){console.debug("set config",o),this.$store.commit("luma/setConfig",{...this.$store.state.luma?.config,video_id:o.video_id,prompt:o.prompt,action:"extend",thumbnail_url:o.thumbnail_url,video_url:o.video_url}),this.$emit("extend")},onDownload(e){window.open(e,"_blank")}}}),kt={class:"preview"},Et={class:"left"},Vt={class:"main"},Ut={class:"bot"},St={class:"datetime"},It={class:"info"},Lt={key:0,class:"prompt mt-2"},Ct={key:0},Tt={key:1},jt={key:0,class:C({content:!0,failed:!0})},At={key:0,class:"mb-4"},Rt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},Gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Pt={key:1,class:C({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Mt={key:2,class:C({content:!0})},Bt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Ot(e,o,p,h,w,y){const r=s("el-image"),d=s("video-player"),c=s("el-button"),_=s("el-tooltip"),$=s("font-awesome-icon"),l=s("copy-to-clipboard"),V=s("el-alert");return a(),m("div",kt,[n("div",Et,[t(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),n("div",Vt,[n("div",Ut,[g(i(e.$t("luma.name.lumaBot"))+" ",1),n("span",St,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),n("div",It,[e.modelValue?.request?.prompt?(a(),m("p",Lt,[g(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),m("span",Ct," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",Tt," - ("+i(e.$t("luma.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",jt,[e.modelValue.response.video_url?(a(),m("div",At,[t(d,{src:e.modelValue.response.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Rt,[t(_,{class:"box-item",effect:"dark",content:e.$t("luma.message.extendVideo"),placement:"top-start"},{default:u(()=>[t(c,{type:"info",size:"small",class:"btn-action",onClick:o[0]||(o[0]=z(L=>e.onExtend(L,e.modelValue?.response),["stop"]))},{default:u(()=>[g(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),t(_,{class:"box-item",effect:"dark",content:e.$t("luma.message.downloadVideo"),placement:"top-start"},{default:u(()=>[t(c,{type:"info",size:"small",class:"btn-action",onClick:o[1]||(o[1]=z(L=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:u(()=>[g(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"])])):f("",!0),t(V,{closable:!1,class:"mt-2 success"},{default:u(()=>[n("p",Gt,[t($,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0),e.modelValue?.response?.state==="failed"||e.modelValue?.response?.success===!1?(a(),m("div",Pt,[t(V,{closable:!1,class:"failure"},{template:u(()=>[t($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",zt,[t($,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])]),n("p",Dt,[t($,{icon:"fa-solid fa-circle-info",class:"mr-1"}),g(" "+i(e.$t("luma.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(l,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),n("p",Ft,[t($,{icon:"fa-solid fa-hashtag",class:"mr-1"}),g(" "+i(e.$t("luma.name.traceId"))+": "+i(e.modelValue?.trace_id)+" ",1),t(l,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):f("",!0),!e.modelValue?.response||e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("div",Mt,[t(V,{closable:!1,class:"info"},{template:u(()=>[t($,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),g(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",Bt,[t($,{icon:"fa-solid fa-magic",class:"mr-1"}),g(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0)])])}const Nt=b(yt,[["render",Ot],["__scopeId","data-v-1b4a59bc"]]),qt=v({name:"RecentPanel",components:{BotPlaceholder:ee,TaskPreview:Nt,NoTasks:x},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:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),Ht={key:0},Kt={key:1,class:"tasks w-full h-full overflow-y-auto"},Jt={key:2,class:"w-full h-full flex items-center justify-center"};function Qt(e,o,p,h,w,y){const r=s("bot-placeholder"),d=s("task-preview"),c=s("no-tasks");return a(),m(D,null,[e.tasks?.items===void 0?(a(),m("div",Ht,[t(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),m("div",Kt,[(a(!0),m(D,null,K(e.tasks?.items,_=>(a(),k(d,{key:_.id,"model-value":_,onExtend:o[0]||(o[0]=$=>e.$emit("extend"))},null,8,["model-value"]))),128))])):f("",!0),e.tasks?.items?.length===0?(a(),m("div",Jt,[t(c)])):f("",!0)],64)}const Wt=b(qt,[["render",Qt]]),Xt="https://webhook.acedata.cloud/luma",Yt=v({name:"LumaIndex",components:{ConfigPanel:wt,Layout:ue,RecentPanel:Wt},inject:["initialized"],emits:["extend"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.luma?.status?.getApplications===W.Request},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,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},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"),setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:p,createdAtMax:h}=e||{};console.debug("limit",o,"createdAtMin",p,"createdAtMax",h),await this.$store.dispatch("luma/getTasks",{limit:o,createdAtMin:p,createdAtMax:h})},async onGenerate(){const e={...this.config,callback_url:Xt},o=this.credential?.token;if(!o){console.error("no token specified");return}E.info(this.$t("luma.message.startingTask")),J.generate(e,{token:o}).then(()=>{E.success(this.$t("luma.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===Q?E.error(this.$t("luma.message.usedUp")):E.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Zt(e,o,p,h,w,y){const r=s("config-panel"),d=s("recent-panel"),c=s("layout");return a(),k(c,null,{config:u(()=>[t(r,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(d,{onReachTop:e.onReachTop,onExtend:o[0]||(o[0]=_=>e.$emit("extend"))},null,8,["onReachTop"])]),_:1})}const To=b(Yt,[["render",Zt]]);export{To as default};
@@ -1 +1 @@
1
- import{F as A}from"./index.es-Ds1LLYZB.js";import{E as G}from"./index-BQExLqgj.js";import{E as P}from"./index-TJ2qXY2t.js";import{d as $,h as v,b as l,t as c,k as t,r as E,j as p,l as i,o,c6 as L,x as n,D as _,F as w,v as I,i as V,n as T,c as D,y as g,eL as j,dr as z,de as O,dl as B,dm as C}from"./index-CAScKEAu.js";import{I as M}from"./InfoIcon-CwVCPHCP.js";import{E as q}from"./index-HJfhXT93.js";import{E as k}from"./index-LAL8pDPz.js";import{a as F,E as N}from"./index-Cc85uiiK.js";import{E as U}from"./index-1c2qdYrk.js";import{E as H,a as J}from"./index-DWqHqFJY.js";import{A as K}from"./Status-BJn6Jsz9.js";import{C as Q}from"./CopyToClipboard-IxJR61wg.js";import{E as W}from"./index-C4777Kma.js";import{a as X,E as Y}from"./index-CSpB1F5W.js";import"./use-form-item-DTrPd0ld.js";import"./index-r5W6hzzQ.js";import"./index-4lEOv1Ve.js";import"./index-C1rnYNjG.js";import"./typescript-WjCVvA-y.js";import"./index-CXzCPe-2.js";import"./_baseClone-_0JJYp5J.js";import"./_Uint8Array-Djk9lJCp.js";import"./_initCloneObject-CdQfCT40.js";import"./isEqual-BCLzbsf0.js";import"./debounce-94P5SC1k.js";import"./index-Aqgtd2nL.js";import"./strings-CZWcdhe2.js";import"./isPlainObject-Dgu9CGNL.js";const Z=$({name:"LayoutHeadshots",components:{ElDrawer:P,ElButton:G,FontAwesomeIcon:A},data(){return{drawer:!1}}}),x={class:"main"},ee={class:"config"},te={class:"result"};function se(e,s,m,u,b,y){const d=i("font-awesome-icon"),h=i("el-button"),a=i("el-drawer");return o(),l("div",x,[c("div",ee,[E(e.$slots,"config",{},void 0,!0)]),c("div",te,[E(e.$slots,"result",{},void 0,!0)]),t(h,{circle:"",class:"menu",onClick:s[0]||(s[0]=r=>e.drawer=!0)},{default:p(()=>[t(d,{icon:"fa-solid fa-gear"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=r=>e.drawer=r),"with-header":!1,size:"340px",class:"drawer"},{default:p(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const oe=v(Z,[["render",se],["__scopeId","data-v-14651d70"]]),ae=$({name:"ImageUrlsInput",components:{ElUpload:q,ElButton:G,InfoIcon:M},data(){return{fileList:[],uploadUrl:L()+"/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.headshots?.config?.image_urls},set(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrls()},methods:{onExceed(){k.warning(this.$t("headshots.message.uploadImageExceed"))},onError(){k.error(this.$t("headshots.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),ne={class:"field"},ie={class:"title font-bold"},le={class:"upload-wrapper"};function re(e,s,m,u,b,y){const d=i("el-button"),h=i("el-upload"),a=i("info-icon");return o(),l("div",ne,[c("h2",ie,n(e.$t("headshots.name.endImageUrls")),1),c("div",le,[t(h,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value","show-file-list":!0,limit:2,multiple:!0,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[t(d,{size:"small",type:"primary",round:""},{default:p(()=>[_(n(e.$t("headshots.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),t(a,{content:e.$t("headshots.description.endImageUrls"),class:"info"},null,8,["content"])])}const ce=v(ae,[["render",re],["__scopeId","data-v-a6bd8c31"]]),de="fast",pe=$({name:"ModeSelector",components:{ElRadioButton:N,ElRadioGroup:F},data(){return{options:[{label:this.$t("headshots.button.fast"),value:"fast"},{label:this.$t("headshots.button.relax"),value:"relax"}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug("set mode",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||(this.value=de)}}),me={class:"field"},ue={class:"title font-bold"};function he(e,s,m,u,b,y){const d=i("el-radio-button"),h=i("el-radio-group");return o(),l("div",me,[c("h2",ue,n(e.$t("headshots.name.mode")),1),t(h,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=a=>e.value=a),size:"small",class:"mode"},{default:p(()=>[(o(!0),l(w,null,I(e.options,a=>(o(),V(d,{key:a.value,label:a.value},{default:p(()=>[_(n(a.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const _e=v(pe,[["render",he],["__scopeId","data-v-a2a0d5fa"]]),fe=$({name:"StylizeSelector",components:{ElTabs:J,ElTabPane:H,ElImage:U},data(){return{tab:"styles",value:"",elements:{styles:{displayName:this.$t("headshots.styleCategory.styles"),items:[{image:"https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png",label:this.$t("headshots.styleTag.malePportrait"),value:"male_portrait"},{image:"https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png",label:this.$t("headshots.styleTag.malePportrait2"),value:"male_portrait2"},{image:"https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png",label:this.$t("headshots.styleTag.kindergarten"),value:"kindergarten"},{image:"https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp",label:this.$t("headshots.styleTag.logoTshirt"),value:"logo_tshirt"},{image:"https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg",label:this.$t("headshots.styleTag.wedding"),value:"wedding"},{image:"https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp",label:this.$t("headshots.styleTag.businessPphoto"),value:"business_photo"},{image:"https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg",label:this.$t("headshots.styleTag.bobSuit"),value:"bob_suit"},{image:"https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp",label:this.$t("headshots.styleTag.femalePortrait"),value:"female_portrait"}]}}}},watch:{value(e){console.debug("set template",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||(this.value=""),console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value="":this.value=e,console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})}}}),ge={class:"field"},$e=["onClick"],ve={class:"name"};function be(e,s,m,u,b,y){const d=i("el-image"),h=i("el-tab-pane"),a=i("el-tabs");return o(),l("div",ge,[t(a,{modelValue:e.tab,"onUpdate:modelValue":s[0]||(s[0]=r=>e.tab=r)},{default:p(()=>[(o(!0),l(w,null,I(e.elements,(r,f)=>(o(),V(h,{key:f,label:r.displayName,name:f,class:"pane"},{default:p(()=>[(o(!0),l(w,null,I(r.items,(S,R)=>(o(),l("div",{key:R,class:T({item:!0,active:e.value===S.value}),onClick:ht=>e.onToggle(S.value)},[t(d,{src:S.image,fit:"fill",class:"preview"},null,8,["src"]),c("span",ve,n(S.label),1)],10,$e))),128))]),_:2},1032,["label","name"]))),128))]),_:1},8,["modelValue"])])}const ye=v(fe,[["render",be],["__scopeId","data-v-be4bd25d"]]),ke=$({name:"PresetPanel",components:{ModeSelector:_e,ImageUrlsInput:ce,ElButton:G,FontAwesomeIcon:A,ElementsSelector:ye},emits:["generate"],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit("generate")}}}),we={class:"panel"},Ie={class:"config"},Te={class:"actions"};function Se(e,s,m,u,b,y){const d=i("elements-selector"),h=i("mode-selector"),a=i("image-urls-input"),r=i("font-awesome-icon"),f=i("el-button");return o(),l("div",we,[c("div",Ie,[t(d,{class:"mb-4"}),t(h,{class:"mb-4"}),t(a,{class:"mb-4"}),c("div",Te,[t(f,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(r,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("headshots.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ve=v(ke,[["render",Se],["__scopeId","data-v-78172a54"]]),Ee=$({name:"ImageGallery",props:{modelValue:{type:Object,required:!0}},setup(e){return{images:D(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:u=>{window.open(u,"_blank")}}}}),Ce={class:"image-gallery"},Ae=["src"],Ge=["onClick"];function Ue(e,s,m,u,b,y){return o(),l("div",Ce,[(o(!0),l(w,null,I(e.images,(d,h)=>(o(),l("div",{key:h,class:"image-container"},[c("img",{src:d.image_url,alt:"Image"},null,8,Ae),d.image_url?(o(),l("button",{key:0,class:"view-button",onClick:a=>e.viewImage(d.image_url)},n(e.$t("headshots.button.viewImage")),9,Ge)):g("",!0)]))),128))])}const Re=v(Ee,[["render",Ue],["__scopeId","data-v-03641510"]]),Pe=$({name:"TaskPreview",components:{ElImage:U,CopyToClipboard:Q,FontAwesomeIcon:A,ElAlert:W,ImageGallery:Re},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,s){e.stopPropagation(),console.log("on download"),window.open(s,"_blank")},onReload(e){const s=e.target,m=new URL(s.src),u=m.searchParams.get("retry");if(!u)m.searchParams.set("retry","1");else if(parseInt(u)<2)m.searchParams.set("retry",(parseInt(u)+1).toString());else return;s.src=m.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),Le={class:"preview"},De={class:"left"},je={class:"main"},ze={class:"bot"},Oe={class:"datetime"},Be={class:"info"},Me={key:0,class:"prompt mt-2"},qe={key:0},Fe={key:1},Ne={key:0,class:T({content:!0,failed:!0})},He={class:"image-wrapper"},Je={class:"description"},Ke={key:1,class:T({content:!0})},Qe={class:"description"},We={class:"description"},Xe={class:"description"},Ye={key:2,class:T({content:!0})},Ze={class:"description"},xe={key:3,class:T({content:!0})},et={class:"description"};function tt(e,s,m,u,b,y){const d=i("el-image"),h=i("image-gallery"),a=i("font-awesome-icon"),r=i("copy-to-clipboard"),f=i("el-alert");return o(),l("div",Le,[c("div",De,[t(d,{src:"https://cdn.acedata.cloud/isxyfw.png",class:"avatar"})]),c("div",je,[c("div",ze,[_(n(e.$t("headshots.name.headshotsBot"))+" ",1),c("span",Oe,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",Be,[e.modelValue?.request?.template?(o(),l("p",Me,[_(n(e.modelValue?.request?.template)+" ",1),e.modelValue?.response?g("",!0):(o(),l("span",qe," - ("+n(e.$t("headshots.status.pending"))+") ",1)),e.modelValue?.response?.status==="unknown"?(o(),l("span",Fe," - ("+n(e.$t("headshots.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(o(),l("div",Ne,[c("div",He,[t(h,{"model-value":e.modelValue},null,8,["model-value"])]),t(f,{closable:!1,class:"mt-2 success"},{default:p(()=>[c("p",Je,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(o(),l("div",Ke,[t(f,{closable:!1,class:"failure"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",Qe,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",We,[t(a,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(r,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),c("p",Xe,[t(a,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("headshots.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(r,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?g("",!0):(o(),l("div",Ye,[t(f,{closable:!1,class:"info"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",Ze,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])),e.modelValue?.response?.status==="unknown"?(o(),l("div",xe,[t(f,{closable:!1,class:"info"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",et,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])])}const st=v(Pe,[["render",tt],["__scopeId","data-v-77229910"]]),ot=$({name:"RecentPanel",components:{TaskPreview:st,ElSkeleton:Y,ElSkeletonItem:X},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),at={key:0,class:"tasks"},nt={class:"left"},it={class:"main"},lt={key:1,class:"tasks"},rt={key:2,class:"description"};function ct(e,s,m,u,b,y){const d=i("el-skeleton-item"),h=i("el-skeleton"),a=i("task-preview");return o(),l("div",{ref:"panel",class:"panel recent",onScroll:s[0]||(s[0]=(...r)=>e.onHandleScroll&&e.onHandleScroll(...r))},[e.tasks?.items===void 0?(o(),l("div",at,[(o(),l(w,null,I(3,r=>c("div",{key:r,class:"task placeholder"},[c("div",nt,[t(h,{animated:""},{template:p(()=>[t(d,{variant:"image",class:"avatar"})]),_:1})]),c("div",it,[t(h,{animated:""},{template:p(()=>[t(d,{variant:"p",class:"title"}),t(d,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(o(),l("div",lt,[(o(!0),l(w,null,I(e.tasks?.items,(r,f)=>(o(),V(a,{key:f,"model-value":r,class:"preview"},null,8,["model-value"]))),128))])):g("",!0),e.tasks?.items?.length===0?(o(),l("p",rt,n(e.$t("headshots.message.noTasks")),1)):g("",!0)],544)}const dt=v(ot,[["render",ct],["__scopeId","data-v-d79bcb1f"]]),pt="https://webhook.acedata.cloud/headshots",mt=$({name:"HeadshotsIndex",components:{ConfigPanel:Ve,Layout:oe,ApplicationStatus:K,RecentPanel:dt},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.headshots?.status?.getApplications===C.Request},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===C.Request},needApply(){return this.$store.state.headshots.status.getApplications===C.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("headshots/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("headshots/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){O.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===B&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:m,createdAtMax:u}=e||{};console.debug("limit",s,"createdAtMin",m,"createdAtMax",u),await this.$store.dispatch("headshots/getTasks",{limit:s,createdAtMin:m,createdAtMax:u})},async onGeneratePicture(){const e={...this.config,callback_url:pt},s=this.credential?.token;if(!s){console.error("no token specified");return}k.info(this.$t("headshots.message.startingTask")),j.generate(e,{token:s}).then(()=>{k.success(this.$t("headshots.message.startTaskSuccess")),this.$store.commit("headshots/setConfig",{config:void 0})}).catch(m=>{m?.response?.data?.error?.code===z?k.error(this.$t("headshots.message.usedUp")):k.error(this.$t("headshots.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function ut(e,s,m,u,b,y){const d=i("config-panel"),h=i("application-status"),a=i("recent-panel"),r=i("layout");return o(),V(r,null,{config:p(()=>[t(d,{onGenerate:e.onGeneratePicture},null,8,["onGenerate"])]),result:p(()=>[t(h,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:"mb-4",onRefresh:e.onGetApplication,onSelect:s[0]||(s[0]=f=>e.$store.dispatch("headshots/setApplication",f))},null,8,["initializing","application","applications","service","need-apply","onRefresh"]),t(a,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Ft=v(mt,[["render",ut],["__scopeId","data-v-19d3c623"]]);export{Ft as default};
1
+ import{F as A}from"./index.es-BGVkY8oJ.js";import{E as G}from"./index-CcyWuqA_.js";import{E as P}from"./index-Be00AR5y.js";import{d as $,h as v,b as l,t as c,k as t,r as E,j as p,l as i,o,c6 as L,x as n,D as _,F as w,v as I,i as V,n as T,c as D,y as g,eL as j,dr as z,de as O,dl as B,dm as C}from"./index-98VGGErr.js";import{I as M}from"./InfoIcon-nWEOcBLm.js";import{E as q}from"./index-B9tmKJTL.js";import{E as k}from"./index-bhFxQQDC.js";import{a as F,E as N}from"./index-BeqHYC-h.js";import{E as U}from"./index-nkzmx8qJ.js";import{E as H,a as J}from"./index-BjvJ8MZp.js";import{A as K}from"./Status-nhyKVjFD.js";import{C as Q}from"./CopyToClipboard-MNFOHaqI.js";import{E as W}from"./index-DzX5B-3h.js";import{a as X,E as Y}from"./index-ChfW7Lcp.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-DfAeDMXy.js";import"./index-DQLaLsnP.js";import"./typescript-1ic-flAv.js";import"./index-CwD7WKHl.js";import"./_baseClone-BBG0IH2E.js";import"./_Uint8Array-BP0U7Iu_.js";import"./_initCloneObject-D12d2S1r.js";import"./isEqual-0nIQYJnJ.js";import"./debounce-CH-Z-bEk.js";import"./index-CiX1WALY.js";import"./strings-BCHZaT3A.js";import"./isPlainObject-L3A-QG3u.js";const Z=$({name:"LayoutHeadshots",components:{ElDrawer:P,ElButton:G,FontAwesomeIcon:A},data(){return{drawer:!1}}}),x={class:"main"},ee={class:"config"},te={class:"result"};function se(e,s,m,u,b,y){const d=i("font-awesome-icon"),h=i("el-button"),a=i("el-drawer");return o(),l("div",x,[c("div",ee,[E(e.$slots,"config",{},void 0,!0)]),c("div",te,[E(e.$slots,"result",{},void 0,!0)]),t(h,{circle:"",class:"menu",onClick:s[0]||(s[0]=r=>e.drawer=!0)},{default:p(()=>[t(d,{icon:"fa-solid fa-gear"})]),_:1}),t(a,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=r=>e.drawer=r),"with-header":!1,size:"340px",class:"drawer"},{default:p(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const oe=v(Z,[["render",se],["__scopeId","data-v-14651d70"]]),ae=$({name:"ImageUrlsInput",components:{ElUpload:q,ElButton:G,InfoIcon:M},data(){return{fileList:[],uploadUrl:L()+"/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.headshots?.config?.image_urls},set(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrls()},methods:{onExceed(){k.warning(this.$t("headshots.message.uploadImageExceed"))},onError(){k.error(this.$t("headshots.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,image_urls:e})},async onSuccess(){this.onSetImageUrls()}}}),ne={class:"field"},ie={class:"title font-bold"},le={class:"upload-wrapper"};function re(e,s,m,u,b,y){const d=i("el-button"),h=i("el-upload"),a=i("info-icon");return o(),l("div",ne,[c("h2",ie,n(e.$t("headshots.name.endImageUrls")),1),c("div",le,[t(h,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=r=>e.fileList=r),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value","show-file-list":!0,limit:2,multiple:!0,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:p(()=>[t(d,{size:"small",type:"primary",round:""},{default:p(()=>[_(n(e.$t("headshots.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])]),t(a,{content:e.$t("headshots.description.endImageUrls"),class:"info"},null,8,["content"])])}const ce=v(ae,[["render",re],["__scopeId","data-v-a6bd8c31"]]),de="fast",pe=$({name:"ModeSelector",components:{ElRadioButton:N,ElRadioGroup:F},data(){return{options:[{label:this.$t("headshots.button.fast"),value:"fast"},{label:this.$t("headshots.button.relax"),value:"relax"}]}},computed:{value:{get(){return this.$store.state.headshots.config?.mode},set(e){console.debug("set mode",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots.config,mode:e})}}},mounted(){this.value||(this.value=de)}}),me={class:"field"},ue={class:"title font-bold"};function he(e,s,m,u,b,y){const d=i("el-radio-button"),h=i("el-radio-group");return o(),l("div",me,[c("h2",ue,n(e.$t("headshots.name.mode")),1),t(h,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=a=>e.value=a),size:"small",class:"mode"},{default:p(()=>[(o(!0),l(w,null,I(e.options,a=>(o(),V(d,{key:a.value,label:a.value},{default:p(()=>[_(n(a.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const _e=v(pe,[["render",he],["__scopeId","data-v-a2a0d5fa"]]),fe=$({name:"StylizeSelector",components:{ElTabs:J,ElTabPane:H,ElImage:U},data(){return{tab:"styles",value:"",elements:{styles:{displayName:this.$t("headshots.styleCategory.styles"),items:[{image:"https://static.aipedias.com/aicamera/common/20241008/20241008202314260779439.png",label:this.$t("headshots.styleTag.malePportrait"),value:"male_portrait"},{image:"https://static.aipedias.com/aicamera/common/20241008/202410082022241e9755548.png",label:this.$t("headshots.styleTag.malePportrait2"),value:"male_portrait2"},{image:"https://static.aipedias.com/aicamera/common/20241101/20241101170130d78f66521.png",label:this.$t("headshots.styleTag.kindergarten"),value:"kindergarten"},{image:"https://static.aipedias.com/aicamera/common/20240923/20240923123233accf60398.webp",label:this.$t("headshots.styleTag.logoTshirt"),value:"logo_tshirt"},{image:"https://static.aipedias.com/aicamera/common/20241025/202410252012329472d0656.jpg",label:this.$t("headshots.styleTag.wedding"),value:"wedding"},{image:"https://static.aipedias.com/aicamera/common/20240915/20240915145045254931400.webp",label:this.$t("headshots.styleTag.businessPphoto"),value:"business_photo"},{image:"https://static.aipedias.com/aicamera/common/20240810/20240810194526040341795.jpg",label:this.$t("headshots.styleTag.bobSuit"),value:"bob_suit"},{image:"https://static.aipedias.com/aicamera/common/20240717/20240717152654e0b348173.webp",label:this.$t("headshots.styleTag.femalePortrait"),value:"female_portrait"}]}}}},watch:{value(e){console.debug("set template",e),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:e})}},mounted(){this.value||(this.value=""),console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})},methods:{onToggle(e){this.value===e?this.value="":this.value=e,console.debug("set template",this.value),this.$store.commit("headshots/setConfig",{...this.$store.state.headshots?.config,template:this.value})}}}),ge={class:"field"},$e=["onClick"],ve={class:"name"};function be(e,s,m,u,b,y){const d=i("el-image"),h=i("el-tab-pane"),a=i("el-tabs");return o(),l("div",ge,[t(a,{modelValue:e.tab,"onUpdate:modelValue":s[0]||(s[0]=r=>e.tab=r)},{default:p(()=>[(o(!0),l(w,null,I(e.elements,(r,f)=>(o(),V(h,{key:f,label:r.displayName,name:f,class:"pane"},{default:p(()=>[(o(!0),l(w,null,I(r.items,(S,R)=>(o(),l("div",{key:R,class:T({item:!0,active:e.value===S.value}),onClick:ht=>e.onToggle(S.value)},[t(d,{src:S.image,fit:"fill",class:"preview"},null,8,["src"]),c("span",ve,n(S.label),1)],10,$e))),128))]),_:2},1032,["label","name"]))),128))]),_:1},8,["modelValue"])])}const ye=v(fe,[["render",be],["__scopeId","data-v-be4bd25d"]]),ke=$({name:"PresetPanel",components:{ModeSelector:_e,ImageUrlsInput:ce,ElButton:G,FontAwesomeIcon:A,ElementsSelector:ye},emits:["generate"],computed:{config(){return this.$store.state.headshots?.config}},methods:{onGenerate(){this.$emit("generate")}}}),we={class:"panel"},Ie={class:"config"},Te={class:"actions"};function Se(e,s,m,u,b,y){const d=i("elements-selector"),h=i("mode-selector"),a=i("image-urls-input"),r=i("font-awesome-icon"),f=i("el-button");return o(),l("div",we,[c("div",Ie,[t(d,{class:"mb-4"}),t(h,{class:"mb-4"}),t(a,{class:"mb-4"}),c("div",Te,[t(f,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[t(r,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+n(e.$t("headshots.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ve=v(ke,[["render",Se],["__scopeId","data-v-78172a54"]]),Ee=$({name:"ImageGallery",props:{modelValue:{type:Object,required:!0}},setup(e){return{images:D(()=>e.modelValue?.response?.data?.slice(0,2)||[]),viewImage:u=>{window.open(u,"_blank")}}}}),Ce={class:"image-gallery"},Ae=["src"],Ge=["onClick"];function Ue(e,s,m,u,b,y){return o(),l("div",Ce,[(o(!0),l(w,null,I(e.images,(d,h)=>(o(),l("div",{key:h,class:"image-container"},[c("img",{src:d.image_url,alt:"Image"},null,8,Ae),d.image_url?(o(),l("button",{key:0,class:"view-button",onClick:a=>e.viewImage(d.image_url)},n(e.$t("headshots.button.viewImage")),9,Ge)):g("",!0)]))),128))])}const Re=v(Ee,[["render",Ue],["__scopeId","data-v-03641510"]]),Pe=$({name:"TaskPreview",components:{ElImage:U,CopyToClipboard:Q,FontAwesomeIcon:A,ElAlert:W,ImageGallery:Re},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.headshots?.application},config(){return this.$store.state.headshots?.config}},methods:{onDownload(e,s){e.stopPropagation(),console.log("on download"),window.open(s,"_blank")},onReload(e){const s=e.target,m=new URL(s.src),u=m.searchParams.get("retry");if(!u)m.searchParams.set("retry","1");else if(parseInt(u)<2)m.searchParams.set("retry",(parseInt(u)+1).toString());else return;s.src=m.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),Le={class:"preview"},De={class:"left"},je={class:"main"},ze={class:"bot"},Oe={class:"datetime"},Be={class:"info"},Me={key:0,class:"prompt mt-2"},qe={key:0},Fe={key:1},Ne={key:0,class:T({content:!0,failed:!0})},He={class:"image-wrapper"},Je={class:"description"},Ke={key:1,class:T({content:!0})},Qe={class:"description"},We={class:"description"},Xe={class:"description"},Ye={key:2,class:T({content:!0})},Ze={class:"description"},xe={key:3,class:T({content:!0})},et={class:"description"};function tt(e,s,m,u,b,y){const d=i("el-image"),h=i("image-gallery"),a=i("font-awesome-icon"),r=i("copy-to-clipboard"),f=i("el-alert");return o(),l("div",Le,[c("div",De,[t(d,{src:"https://cdn.acedata.cloud/isxyfw.png",class:"avatar"})]),c("div",je,[c("div",ze,[_(n(e.$t("headshots.name.headshotsBot"))+" ",1),c("span",Oe,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",Be,[e.modelValue?.request?.template?(o(),l("p",Me,[_(n(e.modelValue?.request?.template)+" ",1),e.modelValue?.response?g("",!0):(o(),l("span",qe," - ("+n(e.$t("headshots.status.pending"))+") ",1)),e.modelValue?.response?.status==="unknown"?(o(),l("span",Fe," - ("+n(e.$t("headshots.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(o(),l("div",Ne,[c("div",He,[t(h,{"model-value":e.modelValue},null,8,["model-value"])]),t(f,{closable:!1,class:"mt-2 success"},{default:p(()=>[c("p",Je,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(o(),l("div",Ke,[t(f,{closable:!1,class:"failure"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",Qe,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",We,[t(a,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t(r,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),c("p",Xe,[t(a,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+n(e.$t("headshots.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t(r,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?g("",!0):(o(),l("div",Ye,[t(f,{closable:!1,class:"info"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",Ze,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])),e.modelValue?.response?.status==="unknown"?(o(),l("div",xe,[t(f,{closable:!1,class:"info"},{template:p(()=>[t(a,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+n(e.$t("headshots.name.failure")),1)]),default:p(()=>[c("p",et,[t(a,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+n(e.$t("headshots.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t(r,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])])}const st=v(Pe,[["render",tt],["__scopeId","data-v-77229910"]]),ot=$({name:"RecentPanel",components:{TaskPreview:st,ElSkeleton:Y,ElSkeletonItem:X},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.headshots?.tasks,items:this.$store.state.headshots?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),at={key:0,class:"tasks"},nt={class:"left"},it={class:"main"},lt={key:1,class:"tasks"},rt={key:2,class:"description"};function ct(e,s,m,u,b,y){const d=i("el-skeleton-item"),h=i("el-skeleton"),a=i("task-preview");return o(),l("div",{ref:"panel",class:"panel recent",onScroll:s[0]||(s[0]=(...r)=>e.onHandleScroll&&e.onHandleScroll(...r))},[e.tasks?.items===void 0?(o(),l("div",at,[(o(),l(w,null,I(3,r=>c("div",{key:r,class:"task placeholder"},[c("div",nt,[t(h,{animated:""},{template:p(()=>[t(d,{variant:"image",class:"avatar"})]),_:1})]),c("div",it,[t(h,{animated:""},{template:p(()=>[t(d,{variant:"p",class:"title"}),t(d,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(o(),l("div",lt,[(o(!0),l(w,null,I(e.tasks?.items,(r,f)=>(o(),V(a,{key:f,"model-value":r,class:"preview"},null,8,["model-value"]))),128))])):g("",!0),e.tasks?.items?.length===0?(o(),l("p",rt,n(e.$t("headshots.message.noTasks")),1)):g("",!0)],544)}const dt=v(ot,[["render",ct],["__scopeId","data-v-d79bcb1f"]]),pt="https://webhook.acedata.cloud/headshots",mt=$({name:"HeadshotsIndex",components:{ConfigPanel:Ve,Layout:oe,ApplicationStatus:K,RecentPanel:dt},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.headshots?.status?.getApplications===C.Request},service(){return this.$store.state.headshots.service},credential(){return this.$store.state.headshots.credential},config(){return this.$store.state.headshots.config},initializing(){return this.$store.state.headshots.status.getApplications===C.Request},needApply(){return this.$store.state.headshots.status.getApplications===C.Success&&!this.application},application(){return this.$store.state.headshots.application},applications(){return this.$store.state.headshots.applications},tasks(){return this.$store.state.headshots.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.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=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("headshots/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("headshots/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){O.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===B&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:m,createdAtMax:u}=e||{};console.debug("limit",s,"createdAtMin",m,"createdAtMax",u),await this.$store.dispatch("headshots/getTasks",{limit:s,createdAtMin:m,createdAtMax:u})},async onGeneratePicture(){const e={...this.config,callback_url:pt},s=this.credential?.token;if(!s){console.error("no token specified");return}k.info(this.$t("headshots.message.startingTask")),j.generate(e,{token:s}).then(()=>{k.success(this.$t("headshots.message.startTaskSuccess")),this.$store.commit("headshots/setConfig",{config:void 0})}).catch(m=>{m?.response?.data?.error?.code===z?k.error(this.$t("headshots.message.usedUp")):k.error(this.$t("headshots.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function ut(e,s,m,u,b,y){const d=i("config-panel"),h=i("application-status"),a=i("recent-panel"),r=i("layout");return o(),V(r,null,{config:p(()=>[t(d,{onGenerate:e.onGeneratePicture},null,8,["onGenerate"])]),result:p(()=>[t(h,{initializing:e.initializing,application:e.application,applications:e.applications,service:e.service,"need-apply":e.needApply,class:"mb-4",onRefresh:e.onGetApplication,onSelect:s[0]||(s[0]=f=>e.$store.dispatch("headshots/setApplication",f))},null,8,["initializing","application","applications","service","need-apply","onRefresh"]),t(a,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Ft=v(mt,[["render",ut],["__scopeId","data-v-19d3c623"]]);export{Ft as default};
@@ -0,0 +1 @@
1
+ import{F as q}from"./index.es-BGVkY8oJ.js";import{E as H}from"./index-CcyWuqA_.js";import{E as de}from"./index-Be00AR5y.js";import{aj as pe,ap as me,bI as fe,ak as ae,c9 as he,_ as _e,d as C,a as $e,al as ve,c as T,bh as ge,bn as ye,aw as le,b as h,o as a,i as w,r as U,f as oe,e as E,j as g,b8 as re,E as G,n as ke,g as we,h as A,t as r,k as n,l as c,eM as se,x as $,F as N,v as J,eN as Q,c6 as be,D as I,eO as Y,eP as x,y as k,J as K,cN as ee,eQ as O,dm as B,ah as V,eR as D,an as Ce,K as Se,eS as Ae,de as Le,dl as je}from"./index-98VGGErr.js";import{E as ce}from"./index-TZWWVHIQ.js";import{E as Ee,a as Te}from"./index-Cr8oY95Z.js";import{I as M}from"./InfoIcon-nWEOcBLm.js";import{E as Pe}from"./index-B9tmKJTL.js";import{E as j}from"./index-bhFxQQDC.js";import{E as Z}from"./index-DvdaM5kg.js";import{E as Ve,a as ue}from"./index-DE0NLUHP.js";import{E as X}from"./index-nkzmx8qJ.js";import{C as Ie,N as Fe,B as ze}from"./NoTasks-BdeBQAXO.js";import{a as Ue}from"./price-Cu8efP-h.js";import{E as Re,a as Ge,b as De}from"./index-BDa8awCt.js";import{E as Me}from"./index-DfAeDMXy.js";import{E as Oe}from"./index-w-DB8id9.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-DQLaLsnP.js";import"./index-CEAOvLtE.js";import"./typescript-1ic-flAv.js";import"./strings-BCHZaT3A.js";import"./castArray-DKMGoQO3.js";import"./isEqual-0nIQYJnJ.js";import"./_Uint8Array-BP0U7Iu_.js";import"./debounce-CH-Z-bEk.js";import"./_baseIteratee-CxKAS7w7.js";import"./index-ByXZ-2lh.js";import"./index-CwD7WKHl.js";import"./_baseClone-BBG0IH2E.js";import"./_initCloneObject-D12d2S1r.js";import"./index-CiX1WALY.js";import"./index-ChfW7Lcp.js";import"./dropdown-BgJeLUwR.js";const Be=pe({size:{type:[Number,String],values:he,default:"",validator:e=>ae(e)},shape:{type:String,values:["circle","square"],default:"circle"},icon:{type:fe},src:{type:String,default:""},alt:String,srcSet:String,fit:{type:me(String),default:"cover"}}),We={error:e=>e instanceof Event},Ne=C({name:"ElAvatar"}),qe=C({...Ne,props:Be,emits:We,setup(e,{emit:t}){const i=e,o=$e("avatar"),l=ve(!1),u=T(()=>{const{size:s,icon:p,shape:y}=i,f=[o.b()];return ge(s)&&f.push(o.m(s)),p&&f.push(o.m("icon")),y&&f.push(o.m(y)),f}),d=T(()=>{const{size:s}=i;return ae(s)?o.cssVarBlock({size:ye(s)||""}):void 0}),m=T(()=>({objectFit:i.fit}));le(()=>i.src,()=>l.value=!1);function _(s){l.value=!0,t("error",s)}return(s,p)=>(a(),h("span",{class:ke(E(u)),style:oe(E(d))},[(s.src||s.srcSet)&&!l.value?(a(),h("img",{key:0,src:s.src,alt:s.alt,srcset:s.srcSet,style:oe(E(m)),onError:_},null,44,["src","alt","srcset"])):s.icon?(a(),w(E(G),{key:1},{default:g(()=>[(a(),w(re(s.icon)))]),_:1})):U(s.$slots,"default",{key:2})],6))}});var He=_e(qe,[["__file","avatar.vue"]]);const Ke=we(He),Ze=C({name:"LayoutSuno",components:{ElDrawer:de,ElButton:H,FontAwesomeIcon:q},data(){return{drawer:!1,preview:!1}},computed:{}}),Xe={class:"main"},Je={class:"config"},Qe={class:"result"},Ye={class:"preview"};function xe(e,t,i,o,l,u){const d=c("font-awesome-icon"),m=c("el-button"),_=c("el-drawer");return a(),h("div",Xe,[r("div",Je,[U(e.$slots,"config",{},void 0,!0)]),r("div",Qe,[U(e.$slots,"result",{},void 0,!0)]),r("div",Ye,[U(e.$slots,"preview",{},void 0,!0)]),n(m,{circle:"",class:"menu",onClick:t[0]||(t[0]=s=>e.drawer=!0)},{default:g(()=>[n(d,{icon:"fa-solid fa-magic"})]),_:1}),n(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=s=>e.drawer=s),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:g(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const et=A(Ze,[["render",xe],["__scopeId","data-v-c954d282"]]),tt=C({name:"VersionSelector",components:{ElSelect:Te,ElOption:Ee,ElSwitch:ce},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{label:this.$t("suno.model.model1"),value:"chirp-v2-xxl-alpha"},{label:this.$t("suno.model.model2"),value:"chirp-v3-0"},{label:this.$t("suno.model.model3"),value:"chirp-v3-5"},{label:this.$t("suno.model.model4"),value:"chirp-v4"},{label:this.$t("suno.model.model45"),value:"chirp-v4-5"}]}},computed:{custom:{get(){return this.$store.state.suno?.config?.custom},set(e){console.debug("set custom",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,custom:e})}},model:{get(){return this.$store.state.suno?.config?.model},set(e){console.debug("set model",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e})}}},mounted(){this.model||(console.debug("set default type",se),this.model=se)}}),ot={class:"field"},st={class:"title font-bold"};function nt(e,t,i,o,l,u){const d=c("el-switch"),m=c("el-option"),_=c("el-select");return a(),h("div",ot,[r("h2",st,$(e.$t("suno.name.type")),1),n(d,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=s=>e.custom=s),class:"value"},null,8,["modelValue"]),n(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=s=>e.model=s),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:g(()=>[(a(!0),h(N,null,J(e.options,s=>(a(),w(m,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const it=A(tt,[["render",nt],["__scopeId","data-v-5a66a01f"]]),at=C({name:"UploadAudio",components:{ElUpload:Pe,ElButton:H,InfoIcon:M,FontAwesomeIcon:q},emits:["change"],data(){return{fileList:[],uploadUrl:be()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.suno?.config?.audio_id},set(){}}},watch:{urls:{handler(e){this.$emit("change",e)}}},mounted(){this.value||(this.value=void 0),this.onSetAudio()},methods:{onExceed(){j.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){j.error(this.$t("suno.message.uploadReferencesError"))},async onSuccess(){const e=this.urls?.[0];await this.onGenerateAudioId(e)},async onGenerateAudioId(e){const t={audio_url:e},i=this.credential?.token;if(!i){console.error("no token specified");return}j.info(this.$t("suno.message.startingUploadAudio")),Q.upload(t,{token:i}).then(o=>{console.debug("get upload music success",o.data);const l=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:l,action:"upload_extend"}),j.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{j.error(o?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),lt={class:"relative"},rt={class:"flex justify-between"},ct={class:"flex justify-start items-center"},ut={class:"text-sm font-bold"};function dt(e,t,i,o,l,u){const d=c("info-icon"),m=c("font-awesome-icon"),_=c("el-button"),s=c("el-upload");return a(),h("div",lt,[r("div",rt,[r("div",ct,[r("span",ut,$(e.$t("suno.name.referenceAudios")),1),n(d,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),n(s,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=p=>e.fileList=p),name:"file",limit:1,class:"upload-wrapper",action:e.uploadUrl,accept:".mp3","show-file-list":!0,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{default:g(()=>[n(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:g(()=>[n(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+$(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const pt=A(at,[["render",dt],["__scopeId","data-v-6236152c"]]),mt="",ft=C({name:"PromptInput",components:{ElInput:Z,ElSwitch:ce,InfoIcon:M},data(){return{}},computed:{prompt:{get(){return this.$store.state.suno?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,prompt:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}},mounted(){this.prompt||(this.prompt=mt)}}),ht={class:"field"},_t={class:"box"},$t={class:"title-info"},vt={class:"title font-bold"},gt={class:"instrumental"},yt={class:"title inline-block"};function kt(e,t,i,o,l,u){const d=c("info-icon"),m=c("el-switch"),_=c("el-input");return a(),h("div",ht,[r("div",_t,[r("div",$t,[r("h2",vt,$(e.$t("suno.name.prompt")),1),n(d,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),r("div",gt,[n(m,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=s=>e.instrumental=s),class:"value mr-2"},null,8,["modelValue"]),r("h2",yt,$(e.$t("suno.name.instrumental")),1)])]),n(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const wt=A(ft,[["render",kt],["__scopeId","data-v-d7004a7c"]]),bt="",Ct=C({name:"LyricInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{lyric:{get(){return this.$store.state.suno?.config?.lyric},set(e){console.debug("set lyric",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,lyric:e})}},config(){return this.$store.state.suno?.config}},mounted(){this.lyric||(this.lyric=bt)}}),St={class:"field"},At={class:"box"},Lt={class:"title font-bold"};function jt(e,t,i,o,l,u){const d=c("info-icon"),m=c("el-input");return a(),h("div",St,[r("div",At,[r("h2",Lt,$(e.$t("suno.name.lyrics")),1),n(d,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(a(),w(m,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(a(),w(m,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const Et=A(Ct,[["render",jt],["__scopeId","data-v-99dfded8"]]),Tt=C({name:"StyleInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{style:{get(){return this.$store.state.suno?.config?.style},set(e){console.debug("set style",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,style:e})}},config(){return this.$store.state.suno?.config}}}),Pt={class:"field"},Vt={class:"title-container"},It={class:"titlefont-bold"};function Ft(e,t,i,o,l,u){const d=c("info-icon"),m=c("el-input");return a(),h("div",Pt,[r("div",Vt,[r("h2",It,$(e.$t("suno.name.style")),1),n(d,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),n(m,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const zt=A(Tt,[["render",Ft],["__scopeId","data-v-85bbfcaa"]]),Ut=C({name:"TitleInput",components:{ElInput:Z,InfoIcon:M},data(){return{}},computed:{title:{get(){return this.$store.state.suno?.config?.title},set(e){console.debug("set title",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,title:e})}},instrumental:{get(){return this.$store.state.suno?.config?.instrumental},set(e){console.debug("set instrumental",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,instrumental:e})}}}}),Rt={class:"field"},Gt={class:"title-container"},Dt={class:"title font-bold"};function Mt(e,t,i,o,l,u){const d=c("info-icon"),m=c("el-input");return a(),h("div",Rt,[r("div",Gt,[r("h2",Dt,$(e.$t("suno.name.title")),1),n(d,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),n(m,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ot=A(Ut,[["render",Mt],["__scopeId","data-v-ce70fe34"]]);function R(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const i=e%60,o=i<10?`0${i}`:i,l=t<10?`0${t}`:t;return o+":"+l}const Bt=C({name:"ExtendFromInput",components:{ElImage:X,ElIcon:G,ElInputNumber:Ve,VideoPlay:x,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:R,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),Wt={class:"field"},Nt={class:"box"},qt={class:"title font-bold"},Ht={class:"input-wrapper"},Kt={class:"task"},Zt={class:"left"},Xt={key:2,class:"duration"},Jt={class:"info"},Qt={class:"title"},Yt={class:"style"};function xt(e,t,i,o,l,u){const d=c("el-input-number"),m=c("el-image"),_=c("video-pause"),s=c("el-icon"),p=c("video-play"),y=ee("loading");return a(),h("div",Wt,[r("div",Nt,[r("h2",qt,$(e.$t("suno.name.extend")),1),r("div",Ht,[n(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),class:"value",min:0,max:e.audio?.duration,controls:!1,placeholder:e.$t("suno.placeholder.extend.continue_at"),onChange:e.handleChange},null,8,["modelValue","max","placeholder","onChange"])])]),r("div",Kt,[e.audio?(a(),h("div",{key:0,class:"audio",onClick:t[3]||(t[3]=f=>e.onClick(e.audio))},[K((a(),h("div",Zt,[n(m,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),h("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=f=>e.onPause(e.audio))},[n(s,null,{default:g(()=>[n(_)]),_:1})])):k("",!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="paused")?(a(),h("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=f=>e.onPlay(e.audio))},[n(s,null,{default:g(()=>[n(p)]),_:1})])):k("",!0),e.audio?.duration?(a(),h("div",Xt,$(e.useFormatDuring(e.audio?.duration)),1)):k("",!0)])),[[y,!e.audio?.audio_url]]),r("div",Jt,[r("h2",Qt,$(e.audio?.title),1),r("p",Yt,$(e.audio?.style),1)])])):k("",!0)])])}const eo=A(Bt,[["render",xt],["__scopeId","data-v-bcce4821"]]),to=C({name:"CoverFromInput",components:{ElImage:X,ElIcon:G,VideoPlay:x,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:R,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})}}}),oo={class:"field"},so={class:"box"},no={class:"title font-bold"},io={class:"task"},ao={class:"left"},lo={key:2,class:"duration"},ro={class:"info"},co={class:"title"},uo={class:"style"};function po(e,t,i,o,l,u){const d=c("el-image"),m=c("video-pause"),_=c("el-icon"),s=c("video-play"),p=ee("loading");return a(),h("div",oo,[r("div",so,[r("h2",no,$(e.$t("suno.name.cover")),1)]),r("div",io,[e.audio?(a(),h("div",{key:0,class:"audio",onClick:t[2]||(t[2]=y=>e.onClick(e.audio))},[K((a(),h("div",ao,[n(d,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),h("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=y=>e.onPause(e.audio))},[n(_,null,{default:g(()=>[n(m)]),_:1})])):k("",!0),e.audio?.audio_url&&(e.$store.state?.suno?.audio?.id!==e.audio.id||e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="paused")?(a(),h("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=y=>e.onPlay(e.audio))},[n(_,null,{default:g(()=>[n(s)]),_:1})])):k("",!0),e.audio?.duration?(a(),h("div",lo,$(e.useFormatDuring(e.audio?.duration)),1)):k("",!0)])),[[p,!e.audio?.audio_url]]),r("div",ro,[r("h2",co,$(e.audio?.title),1),r("p",uo,$(e.audio?.style),1)])])):k("",!0)])])}const mo=A(to,[["render",po],["__scopeId","data-v-06640216"]]),fo=C({name:"PresetPanel",components:{TypeSelector:it,PromptInput:wt,LyricInput:Et,StyleInput:zt,TitleInput:Ot,ExtendFromInput:eo,CoverFromInput:mo,UploadAudio:pt,FontAwesomeIcon:q,ElButton:H,Consumption:Ie},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Ue(this.config,this.service?.metadata?.price)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),ho={class:"flex flex-col h-full"},_o={class:"flex-1 overflow-y-auto p-[15px]"},$o={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function vo(e,t,i,o,l,u){const d=c("type-selector"),m=c("upload-audio"),_=c("prompt-input"),s=c("lyric-input"),p=c("style-input"),y=c("title-input"),f=c("extend-from-input"),b=c("cover-from-input"),F=c("consumption"),P=c("font-awesome-icon"),L=c("el-button");return a(),h("div",ho,[r("div",_o,[n(d,{class:"mb-4"}),n(m,{class:"mb-4"}),e.config?.custom?k("",!0):(a(),w(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(a(),w(s,{key:1,class:"mb-4"})):k("",!0),e.config?.custom?(a(),w(p,{key:2,class:"mb-4"})):k("",!0),e.config?.custom?(a(),w(y,{key:3,class:"mb-4"})):k("",!0),e.config?.action==="extend"?(a(),w(f,{key:4,class:"mb-4"})):k("",!0),e.config?.action==="cover"?(a(),w(b,{key:5,class:"mb-4"})):k("",!0)]),r("div",$o,[n(F,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(a(),w(L,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:g(()=>[n(P,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+$(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(a(),w(L,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:g(()=>[n(P,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+$(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const go=A(fo,[["render",vo],["__scopeId","data-v-b9fab929"]]);var W={exports:{}},yo=W.exports,ne;function ko(){return ne||(ne=1,function(e,t){(function(i,o){o()})(yo,function(){function i(s,p){return typeof p>"u"?p={autoBom:!1}:typeof p!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),p={autoBom:!p}),p.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(s.type)?new Blob(["\uFEFF",s],{type:s.type}):s}function o(s,p,y){var f=new XMLHttpRequest;f.open("GET",s),f.responseType="blob",f.onload=function(){_(f.response,p,y)},f.onerror=function(){console.error("could not download file")},f.send()}function l(s){var p=new XMLHttpRequest;p.open("HEAD",s,!1);try{p.send()}catch{}return 200<=p.status&&299>=p.status}function u(s){try{s.dispatchEvent(new MouseEvent("click"))}catch{var p=document.createEvent("MouseEvents");p.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),s.dispatchEvent(p)}}var d=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof O=="object"&&O.global===O?O:void 0,m=d.navigator&&/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),_=d.saveAs||(typeof window!="object"||window!==d?function(){}:"download"in HTMLAnchorElement.prototype&&!m?function(s,p,y){var f=d.URL||d.webkitURL,b=document.createElement("a");p=p||s.name||"download",b.download=p,b.rel="noopener",typeof s=="string"?(b.href=s,b.origin===location.origin?u(b):l(b.href)?o(s,p,y):u(b,b.target="_blank")):(b.href=f.createObjectURL(s),setTimeout(function(){f.revokeObjectURL(b.href)},4e4),setTimeout(function(){u(b)},0))}:"msSaveOrOpenBlob"in navigator?function(s,p,y){if(p=p||s.name||"download",typeof s!="string")navigator.msSaveOrOpenBlob(i(s,y),p);else if(l(s))o(s,p,y);else{var f=document.createElement("a");f.href=s,f.target="_blank",setTimeout(function(){u(f)})}}:function(s,p,y,f){if(f=f||open("","_blank"),f&&(f.document.title=f.document.body.innerText="downloading..."),typeof s=="string")return o(s,p,y);var b=s.type==="application/octet-stream",F=/constructor/i.test(d.HTMLElement)||d.safari,P=/CriOS\/[\d]+/.test(navigator.userAgent);if((P||b&&F||m)&&typeof FileReader<"u"){var L=new FileReader;L.onloadend=function(){var z=L.result;z=P?z:z.replace(/^data:[^;]*;/,"data:attachment/file;"),f?f.location.href=z:location=z,f=null},L.readAsDataURL(s)}else{var v=d.URL||d.webkitURL,S=v.createObjectURL(s);f?f.location=S:location.href=S,f=null,setTimeout(function(){v.revokeObjectURL(S)},4e4)}});d.saveAs=_.saveAs=_,e.exports=_})}(W)),W.exports}var wo=ko();const bo="https://webhook.acedata.cloud/suno",Co=C({name:"TaskPreview",components:{ElImage:X,ElIcon:G,ElTooltip:Me,ElButton:H,FontAwesomeIcon:q,VideoPlay:x,VideoPause:Y,ElDropdown:De,ElDropdownMenu:Ge,ElDropdownItem:Re},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===B.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(i=>({...i,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:R,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.log("on extend"),console.debug("set config",t),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e.stopPropagation(),console.log("on download",t);const o=new URL(t).pathname,l=o.substring(o.lastIndexOf("/")+1);console.log("on preview",l),fetch(t).then(u=>u.blob()).then(u=>{wo.saveAs(u,l)})},onPreview(e,t){e.stopPropagation(),console.log("on preview",t),window.open(t,"_blank")},async onGetStems(e){await this.onGenerateAudioUrl("stems",e)},onCover(e){console.log("on cover"),console.debug("set config",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:e.model,custom:!0,instrumental:!1,style:e.style,action:"cover",audio:e,audio_id:e.id})},async onConcatMusic(e){await this.onGenerateAudioUrl("concat",e)},async onGenerateAudioUrl(e,t){const i={action:e,audio_id:t,callback_url:bo},o=this.credential?.token;if(!o){console.error("no token specified");return}j.info(this.$t("suno.message.startingTask")),Q.audio(i,{token:o}).then(()=>{j.success(this.$t("suno.message.startTaskSuccess"))}).catch(l=>{j.error(l?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),So={class:"task"},Ao=["onClick"],Lo={class:"left"},jo=["onClick"],Eo=["onClick"],To={key:2,class:"duration"},Po={class:"info"},Vo={class:"title"},Io={class:"style"},Fo={class:"right"},zo={class:"el-dropdown-link"},Uo={class:"el-dropdown-link"};function Ro(e,t,i,o,l,u){const d=c("el-image"),m=c("video-pause"),_=c("el-icon"),s=c("video-play"),p=c("el-button"),y=c("font-awesome-icon"),f=c("el-tooltip"),b=c("el-dropdown-item"),F=c("el-dropdown-menu"),P=c("el-dropdown"),L=ee("loading");return a(),h("div",So,[(a(!0),h(N,null,J(e.audios,v=>(a(),h("div",{key:v.id,class:"audio",onClick:V(S=>e.onClick(v),["stop"])},[K((a(),h("div",Lo,[n(d,{src:v?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),v?.audio_url&&e.$store.state?.suno?.audio?.id===v.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),h("div",{key:0,class:"overlay",onClick:V(S=>e.onPause(v),["stop"])},[n(_,null,{default:g(()=>[n(m)]),_:1})],8,jo)):k("",!0),v?.audio_url&&(e.$store.state?.suno?.audio?.id!==v.id||e.$store.state?.suno?.audio?.id===v.id&&e.$store.state?.suno?.audio?.state==="paused")?(a(),h("div",{key:1,class:"overlay",onClick:V(S=>e.onPlay(v),["stop"])},[n(_,null,{default:g(()=>[n(s)]),_:1})],8,Eo)):k("",!0),v?.duration?(a(),h("div",To,$(e.useFormatDuring(v?.duration)),1)):k("",!0)])),[[L,!v?.audio_url]]),r("div",Po,[r("h2",Vo,$(v?.title),1),r("p",Io,$(v?.style),1)]),r("div",Fo,[v?.audio_url?(a(),w(p,{key:0,size:"small",round:"",onClick:V(S=>e.onExtend(S,v),["stop"])},{default:g(()=>[I($(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):k("",!0),n(f,{effect:"dark",content:e.$t("suno.button.video"),placement:"top"},{default:g(()=>[v?.video_url?(a(),w(y,{key:0,icon:"fa-solid fa-clapperboard",class:"icon icon-preview",onClick:S=>e.onPreview(S,v?.video_url)},null,8,["onClick"])):k("",!0)]),_:2},1032,["content"]),n(P,null,{dropdown:g(()=>[n(F,null,{default:g(()=>[v?.video_url?(a(),w(b,{key:0,onClick:V(S=>e.onDownload(S,v?.video_url),["stop"])},{default:g(()=>[I($(e.$t("suno.button.download_video")),1)]),_:2},1032,["onClick"])):k("",!0),v?.audio_url?(a(),w(b,{key:1,onClick:V(S=>e.onDownload(S,v?.audio_url),["stop"])},{default:g(()=>[I($(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):k("",!0)]),_:2},1024)]),default:g(()=>[r("span",zo,[n(f,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:g(()=>[v?.audio_url||v?.video_url?(a(),w(y,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):k("",!0)]),_:2},1032,["content"])])]),_:2},1024),n(P,null,{dropdown:g(()=>[n(F,null,{default:g(()=>[v.id?(a(),w(b,{key:0,onClick:V(S=>e.onGetStems(v.id),["stop"])},{default:g(()=>[I($(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):k("",!0),n(b,{onClick:V(S=>e.onCover(v),["stop"])},{default:g(()=>[I($(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),v?.id&&v?.action==="extend"?(a(),w(b,{key:1,onClick:V(S=>e.onConcatMusic(v?.id),["stop"])},{default:g(()=>[I($(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):k("",!0)]),_:2},1024)]),default:g(()=>[r("span",Uo,[n(f,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:g(()=>[v?.audio_url||v?.video_url?(a(),w(y,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):k("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,Ao))),128))])}const Go=A(Co,[["render",Ro]]),Do={class:"player-slider"},Mo=C({__name:"PlayerSlider",setup(e){const t=D(),i=T({get:()=>t.state.suno?.audio?.progress,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:d})}),o=T({get:()=>t.state.suno?.audio?.duration,set:d=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:d})}),l=()=>{},u=d=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:d});return(d,m)=>(a(),h("div",Do,[n(E(ue),{modelValue:i.value,"onUpdate:modelValue":m[0]||(m[0]=_=>i.value=_),"show-tooltip":!1,min:0,max:o.value,onChange:u,onInput:l},null,8,["modelValue","max"])]))}}),Oo="/assets/disk-XFRmVAfp.png",Bo={class:"flex player-song"},Wo=["src"],No={class:"ml-2 text-xs flex flex-col justify-between"},qo={class:"w-52 2xl:w-96 cursor-pointer truncate"},Ho={class:"flex"},Ko={class:"ml-2 text-dc"},Zo=C({__name:"PlayerSong",setup(e){const t=D(),i=T({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return le(i,(o,l)=>{if(o?.audio_url!==l?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const u=new Audio(o.audio_url);o.state==="playing"?u.play():u.pause(),u.addEventListener("loadedmetadata",()=>{u.currentTime=0,u.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:u.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:u})}else if(o?.progress!==l?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const u=t.state.suno.audio;u.object&&(u.object.currentTime=u.progress)}else o?.state!==l?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==l?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,l)=>(a(),h("div",Bo,[r("img",{alt:"",class:"w-11 h-11 rounded",src:i.value?.image_url||E(Oo)},null,8,Wo),r("div",No,[r("div",qo,[r("div",Ho,[r("span",null,$(i.value?.title||"Music"),1),r("span",Ko,"- "+$(i.value?.style||"SmallRuralDog"),1)])])])]))}}),Xo={class:"flex justify-end items-center gap-x-2.5"},Jo={class:"text-xs"},Qo=C({__name:"PlayerAction",setup(e){const t=D(),i=T({get:()=>t.state.suno?.audio?.progress,set:l=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:l})}),o=T({get:()=>t.state.suno?.audio?.duration,set:l=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:l})});return(l,u)=>(a(),h("div",Xo,[r("span",Jo,$(E(R)(i.value))+" / "+$(E(R)(o.value)),1)]))}});var Yo={size:"1em",strokeWidth:4,strokeLinecap:"round",strokeLinejoin:"round",rtl:!1,theme:"outline",colors:{outline:{fill:"#333",background:"transparent"},filled:{fill:"#333",background:"#FFF"},twoTone:{fill:"#333",twoTone:"#2F88FF"},multiColor:{outStrokeColor:"#333",outFillColor:"#2F88FF",innerStrokeColor:"#FFF",innerFillColor:"#43CCF8"}},prefix:"i"};function xo(){return"icon-"+((1+Math.random())*4294967296|0).toString(16).substring(1)}function es(e,t,i){var o=typeof t.fill=="string"?[t.fill]:t.fill||[],l=[],u=t.theme||i.theme;switch(u){case"outline":l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push("none"),l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push("none");break;case"filled":l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push("#FFF"),l.push("#FFF");break;case"two-tone":l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone),l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone);break;case"multi-color":l.push(typeof o[0]=="string"?o[0]:"currentColor"),l.push(typeof o[1]=="string"?o[1]:i.colors.multiColor.outFillColor),l.push(typeof o[2]=="string"?o[2]:i.colors.multiColor.innerStrokeColor),l.push(typeof o[3]=="string"?o[3]:i.colors.multiColor.innerFillColor);break}return{size:t.size||i.size,strokeWidth:t.strokeWidth||i.strokeWidth,strokeLinecap:t.strokeLinecap||i.strokeLinecap,strokeLinejoin:t.strokeLinejoin||i.strokeLinejoin,colors:l,id:e}}var ts=Symbol("icon-context");function te(e,t,i){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(u){var d=xo(),m=Ce(ts,Yo);return function(){var _=u.size,s=u.strokeWidth,p=u.strokeLinecap,y=u.strokeLinejoin,f=u.theme,b=u.fill,F=u.spin,P=es(d,{size:_,strokeWidth:s,strokeLinecap:p,strokeLinejoin:y,theme:f,fill:b},m),L=[m.prefix+"-icon"];return L.push(m.prefix+"-icon-"+e),t&&m.rtl&&L.push(m.prefix+"-icon-rtl"),F&&L.push(m.prefix+"-icon-spin"),n("span",{class:L.join(" ")},[i(P)])}}};return o}const os=te("pause-one",!1,function(e){return n("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[n("path",{d:"M24 44C35.0457 44 44 35.0457 44 24C44 12.9543 35.0457 4 24 4C12.9543 4 4 12.9543 4 24C4 35.0457 12.9543 44 24 44Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),n("path",{d:"M19 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),n("path",{d:"M29 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),ss=te("play",!0,function(e){return n("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[n("path",{d:"M24 44C35.0457 44 44 35.0457 44 24C44 12.9543 35.0457 4 24 4C12.9543 4 4 12.9543 4 24C4 35.0457 12.9543 44 24 44Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),n("path",{d:"M20 24V17.0718L26 20.5359L32 24L26 27.4641L20 30.9282V24Z",fill:e.colors[3],stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null)])}),ns=te("volume-small",!0,function(e){return n("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[n("path",{d:"M24 6V42C17 42 11.7985 32.8391 11.7985 32.8391H6C4.89543 32.8391 4 31.9437 4 30.8391V17.0108C4 15.9062 4.89543 15.0108 6 15.0108H11.7985C11.7985 15.0108 17 6 24 6Z",fill:e.colors[1],stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linejoin":e.strokeLinejoin},null),n("path",{d:"M32 15L32 15C32.6232 15.5565 33.1881 16.1797 33.6841 16.8588C35.1387 18.8504 36 21.3223 36 24C36 26.6545 35.1535 29.1067 33.7218 31.0893C33.2168 31.7885 32.6391 32.4293 32 33",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),ie=C({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,i)=>(a(),w(re(t.icon),{theme:t.theme,size:t.size,spin:t.spin,fill:t.fill,"stroke-linecap":t.strokeLinecap,"stroke-linejoin":t.strokeLinejoin,"stroke-width":t.strokeWidth},null,8,["theme","size","spin","fill","stroke-linecap","stroke-linejoin","stroke-width"]))}}),is={class:"player-volume flex flex-col items-center pt-2"},as={class:"text-sm mt-3"},ls=C({__name:"PlayerVolumeSlider",setup(e){const t=D(),i=T({get:()=>t.state.suno.audio?.volume,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:u})}),o=T({get:()=>t.state.suno.audio?.muted,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:u})}),l=u=>t.dispatch("suno/setVolume",u);return(u,d)=>(a(),h("div",is,[n(E(ue),{modelValue:i.value,"onUpdate:modelValue":d[0]||(d[0]=m=>i.value=m),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:l},null,8,["modelValue","disabled"]),r("div",as,$(i.value),1)]))}}),rs={class:"flex items-center justify-center gap-x-3"},cs=C({__name:"PlayerController",setup(e){const t=D(),i=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=T(()=>t.state.suno.audio);return(l,u)=>(a(),h("div",rs,[n(ie,{icon:o.value?.state==="playing"?E(os):E(ss),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:i},null,8,["icon"]),n(E(Oe),{placement:"top",width:"50px",trigger:"click"},{reference:g(()=>[n(ie,{icon:E(ns),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:g(()=>[n(ls)]),_:1})]))}}),us={class:"flex flex-col items-stretch h-20"},ds={class:"flex grow px-5 items-center"},ps={class:"flex-1"},ms={class:"flex-1"},fs={class:"flex-1"},hs=C({__name:"Player",setup(e){return(t,i)=>(a(),h("div",us,[n(Mo),r("div",ds,[r("div",ps,[n(Zo)]),r("div",ms,[n(cs)]),r("div",fs,[n(Qo)])])]))}}),_s=C({name:"RecentPanel",components:{BotPlaceholder:ze,TaskPreview:Go,Player:hs,NoTasks:Fe},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),$s={key:0,class:"tasks"},vs={key:2,class:"w-full flex-1 flex items-center justify-center"},gs={class:"h-20"};function ys(e,t,i,o,l,u){const d=c("bot-placeholder"),m=c("task-preview"),_=c("no-tasks"),s=c("player");return a(),h(N,null,[e.tasks?.items===void 0?(a(),h("div",$s,[n(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),h("div",{key:1,class:"flex-1 w-full overflow-y-auto tasks p-2",onScroll:t[0]||(t[0]=(...p)=>e.onHandleScroll&&e.onHandleScroll(...p))},[(a(!0),h(N,null,J(e.tasks?.items,(p,y)=>(a(),w(m,{key:y,"model-value":p,class:"preview"},null,8,["model-value"]))),128))],32)):k("",!0),e.tasks?.items?.length===0?(a(),h("div",vs,[n(_)])):k("",!0),K(r("div",gs,[n(s)],512),[[Se,!!e.$store?.state?.suno?.audio?.object]])],64)}const ks=A(_s,[["render",ys]]),ws=C({name:"TaskPreview",components:{IconPicture:Ae,ElImage:X,ElAvatar:Ke,ElIcon:G},computed:{audio(){return this.$store.state.suno?.audio}}}),bs={key:0,class:"size-full overflow-hidden"},Cs={class:"relative h-[300px]"},Ss={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},As={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"},Ls={class:"p-4"},js={class:"flex items-center font-bold mb-2"},Es={class:"text-[var(--el-text-color-regular)] mb-2"},Ts={class:"text-xs text-[var(--el-text-color-regular)]"},Ps={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},Vs={key:1,class:"w-full h-full bg-gradient-to-b from-gray-200 to-gray-300"};function Is(e,t,i,o,l,u){const d=c("icon-picture"),m=c("el-icon"),_=c("el-image"),s=c("el-avatar");return e.audio?.object?(a(),h("div",bs,[r("div",Cs,[n(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:g(()=>[r("div",Ss,[n(m,{class:"text-3xl"},{default:g(()=>[n(d)]),_:1})])]),_:1},8,["src"]),r("h2",As,$(e.audio?.title),1)]),r("div",Ls,[r("div",js,[n(s,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),r("span",null,$(e.audio?.title),1)]),r("p",Es,$(e.audio?.style),1),r("p",Ts,$(e.$dayjs.format(e.audio?.created_at)),1),r("div",Ps,[r("p",null,$(e.audio?.lyric),1)])])])):(a(),h("div",Vs))}const Fs=A(ws,[["render",Is]]),zs="https://webhook.acedata.cloud/suno",Us=C({name:"SunoIndex",components:{Layout:et,ConfigPanel:go,RecentPanel:ks,PreviewPanel:Fs},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===B.Request},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===B.Request},needApply(){return this.$store.state.suno.status.getApplications===B.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("suno/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("suno/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){Le.create({application:this.application}).then(({data:e})=>{this.application=e,j.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===je&&j.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:i,createdAtMax:o}=e||{};console.debug("limit",t,"createdAtMin",i,"createdAtMax",o),await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:i,createdAtMax:o})},async onGenerateAudio(){const e={...this.config,callback_url:zs},t=this.credential?.token;if(!t){console.error("no token specified");return}j.info(this.$t("suno.message.startingTask")),Q.audio(e,{token:t}).then(()=>{j.success(this.$t("suno.message.startTaskSuccess"))}).catch(i=>{j.error(i?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Rs(e,t,i,o,l,u){const d=c("config-panel"),m=c("recent-panel"),_=c("preview-panel"),s=c("layout");return a(),w(s,null,{config:g(()=>[n(d,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:g(()=>[n(m,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),preview:g(()=>[n(_)]),_:1})}const yn=A(Us,[["render",Rs],["__scopeId","data-v-f5721d95"]]);export{yn as default};
@@ -0,0 +1 @@
1
+ import{F as A}from"./index.es-BGVkY8oJ.js";import{E as G}from"./index-CcyWuqA_.js";import{E as B}from"./index-Be00AR5y.js";import{d as g,h as b,b as r,t as i,k as o,r as R,j as c,l as s,o as n,ew as F,x as a,F as C,v as L,i as w,ex as M,y as u,c6 as q,D as v,J as S,K as T,n as U,ey as z,dr as N,dm as H}from"./index-98VGGErr.js";import{E as j,a as D}from"./index-Cr8oY95Z.js";import{V as P}from"./VideoPlayer-Dhhv87vC.js";import{I as O}from"./InfoIcon-nWEOcBLm.js";import{I as K}from"./ImagePreview-CET7KBKE.js";import{E as J}from"./index-B9tmKJTL.js";import{E}from"./index-bhFxQQDC.js";import{C as Q,B as W,N as X}from"./NoTasks-BdeBQAXO.js";import{E as Y}from"./index-DvdaM5kg.js";import{a as Z}from"./price-Cu8efP-h.js";import{C as x}from"./CopyToClipboard-MNFOHaqI.js";import{E as ee}from"./index-DfAeDMXy.js";import{E as oe}from"./index-DzX5B-3h.js";import{E as te}from"./index-nkzmx8qJ.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-CEAOvLtE.js";import"./typescript-1ic-flAv.js";import"./index-DQLaLsnP.js";import"./strings-BCHZaT3A.js";import"./castArray-DKMGoQO3.js";import"./isEqual-0nIQYJnJ.js";import"./_Uint8Array-BP0U7Iu_.js";import"./debounce-CH-Z-bEk.js";import"./_baseIteratee-CxKAS7w7.js";import"./index-ByXZ-2lh.js";import"./vue-plyr-QZFBikSk.js";import"./index-CwD7WKHl.js";import"./_baseClone-BBG0IH2E.js";import"./_initCloneObject-D12d2S1r.js";import"./index-ChfW7Lcp.js";import"./index-CiX1WALY.js";const se=g({name:"LayoutVeo",components:{ElDrawer:B,ElButton:G,FontAwesomeIcon:A},data(){return{drawer:!1}}}),ne={class:"main"},ae={class:"config"},le={class:"result"};function re(e,t,_,h,k,y){const d=s("font-awesome-icon"),p=s("el-button"),l=s("el-drawer");return n(),r("div",ne,[i("div",ae,[R(e.$slots,"config",{},void 0,!0)]),i("div",le,[R(e.$slots,"result",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=$=>e.drawer=!0)},{default:c(()=>[o(d,{icon:"fa-solid fa-magic"})]),_:1}),o(l,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"350px"},{default:c(()=>[R(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ie=b(se,[["render",re],["__scopeId","data-v-9ef3dd3f"]]),ce=g({name:"ModelSelector",components:{ElSelect:D,ElOption:j},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"veo2",label:"veo2"},{value:"veo2-fast",label:"veo2-fast"},{value:"veo3",label:"veo3"},{value:"veo3-fast",label:"veo3-fast"}]}},computed:{value:{get(){return this.$store.state.veo?.config?.model},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo.config,model:e})}}},mounted(){this.value||(this.value=F)}}),de={class:"field"},pe={class:"title font-bold"};function me(e,t,_,h,k,y){const d=s("el-option"),p=s("el-select");return n(),r("div",de,[i("h2",pe,a(e.$t("veo.name.model")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=l=>e.value=l),class:"value",placeholder:e.$t("veo.placeholder.select")},{default:c(()=>[(n(!0),r(C,null,L(e.options,l=>(n(),w(d,{key:l.value,label:l.label,value:l.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ue=b(ce,[["render",me],["__scopeId","data-v-ef445fc5"]]),fe=g({name:"ModelSelector",components:{ElSelect:D,ElOption:j},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("veo.button.action1")},{value:"image2video",label:this.$t("veo.button.action2")},{value:"get1080p",label:this.$t("veo.button.action3")}]},value:{get(){return this.$store.state.veo?.config?.action},set(e){this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,action:e})}}},mounted(){this.value||(this.value=M)}}),ve={class:"field"},_e={class:"title font-bold"},he={class:"float-left"};function $e(e,t,_,h,k,y){const d=s("el-option"),p=s("el-select");return n(),r("div",ve,[i("h2",_e,a(e.$t("veo.name.action")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=l=>e.value=l),class:"value",placeholder:e.$t("veo.placeholder.select"),clearable:""},{default:c(()=>[(n(!0),r(C,null,L(e.options,l=>(n(),w(d,{key:l.value,label:l.label,value:l.value},{default:c(()=>[i("span",he,a(l.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ge=b(fe,[["render",$e],["__scopeId","data-v-821be9a3"]]),be=g({name:"VideoFromInput",components:{VideoPlayer:P},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.veo?.config}}}),ke={class:"relative"},ye={class:"flex mb-2"},we={class:"text-sm font-bold"};function Ve(e,t,_,h,k,y){const d=s("video-player");return n(),r("div",ke,[i("div",ye,[i("span",we,a(e.$t("veo.name.action3")),1)]),i("div",null,[e.config?.video_url?(n(),w(d,{key:0,src:e.config?.video_url},null,8,["src"])):u("",!0)])])}const Ee=b(be,[["render",Ve]]),Ie=g({name:"StartEndImage",components:{ElUpload:J,ElButton:G,InfoIcon:O,FontAwesomeIcon:A,ImagePreview:K},emits:["change"],data(){return{fileList:[],uploadUrl:q()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.veo?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){E.warning(this.$t("veo.message.uploadReferencesExceed"))},onError(){E.error(this.$t("veo.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("veo/setConfig",{...this.$store.state?.veo?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Se={class:"relative"},Te={class:"flex justify-between"},Ce={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"};function Ge(e,t,_,h,k,y){const d=s("info-icon"),p=s("image-preview"),l=s("font-awesome-icon"),$=s("el-button"),f=s("el-upload");return n(),r("div",Se,[i("div",Te,[i("div",Ce,[i("span",Ae,a(e.$t("veo.name.startEndImage")),1),o(d,{content:e.$t("veo.description.uploadStartEndImage")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),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:c(({file:m})=>[m.url&&m.percentage!==void 0?(n(),w(p,{key:0,url:m.url,name:m.name,percentage:m.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(m),1)},null,8,["url","name","percentage","onRemove"])):u("",!0)]),default:c(()=>[o($,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:c(()=>[o(l,{icon:"fa-solid fa-upload",class:"icon mr-1"}),v(" "+a(e.$t("veo.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Ue=b(Ie,[["render",Ge],["__scopeId","data-v-43d971b7"]]),Re="",Le=g({name:"PromptInput",components:{ElInput:Y,InfoIcon:O},computed:{prompt:{get(){return this.$store.state.veo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Re)}}),je={class:"field"},De={class:"box"},Pe={class:"title font-bold"};function Oe(e,t,_,h,k,y){const d=s("info-icon"),p=s("el-input");return n(),r("div",je,[i("div",De,[i("h2",Pe,a(e.$t("veo.name.prompt")),1),o(d,{content:e.$t("veo.description.prompt"),class:"info"},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=l=>e.prompt=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("veo.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Be=b(Le,[["render",Oe],["__scopeId","data-v-9189572a"]]),Fe=g({name:"ConfigPanel",components:{ElButton:G,Consumption:Q,FontAwesomeIcon:A,PromptInput:Be,ModelSelector:ue,StartEndImage:Ue,ActionSelector:ge,VideoFromInput:Ee},emits:["generate"],computed:{config(){return this.$store.state.veo?.config},consumption(){return Z(this.config,this.service?.metadata?.price)},service(){return this.$store.state.veo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Me={class:"flex flex-col h-full"},qe={class:"flex-1 overflow-y-auto p-[15px]"},ze={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ne(e,t,_,h,k,y){const d=s("video-from-input"),p=s("action-selector"),l=s("prompt-input"),$=s("model-selector"),f=s("start-end-image"),m=s("consumption"),V=s("font-awesome-icon"),I=s("el-button");return n(),r("div",Me,[i("div",qe,[S(o(d,{class:"mb-4"},null,512),[[T,e.config?.action==="get1080p"]]),o(p,{class:"mb-4"}),S(o(l,{class:"mb-4"},null,512),[[T,e.config?.action!=="get1080p"]]),S(o($,{class:"mb-4"},null,512),[[T,e.config?.action!=="get1080p"]]),S(o(f,{class:"mb-2"},null,512),[[T,e.config?.action==="image2video"]])]),i("div",ze,[o(m,{value:e.consumption,service:e.service},null,8,["value","service"]),o(I,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:c(()=>[o(V,{icon:"fa-solid fa-magic",class:"mr-2"}),v(" "+a(e.$t("veo.button.generate")),1)]),_:1},8,["onClick"])])])}const He=b(Fe,[["render",Ne]]),Ke=g({name:"TaskPreview",components:{ElImage:te,CopyToClipboard:x,FontAwesomeIcon:A,ElAlert:oe,VideoPlayer:P,ElTooltip:ee,ElButton:G},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.veo?.application},config(){return this.$store.state.veo?.config}},methods:{onGet1080p(e,t){console.debug("set config",t),this.$store.commit("veo/setConfig",{...this.$store.state.veo?.config,video_id:t?.data?.[0]?.id,video_url:t?.data[0]?.video_url,action:"get1080p"})},onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Je={class:"preview"},Qe={class:"left"},We={class:"main"},Xe={class:"bot"},Ye={class:"datetime"},Ze={class:"info"},xe={key:0,class:"prompt mt-2"},eo={key:0},oo={key:1},to={key:0,class:U({content:!0,failed:!0})},so={key:0,class:"mb-4"},no={key:1,class:U({operations:!0,"mt-2":!0})},ao={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lo={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ro={key:1,class:U({content:!0})},io={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},co={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},po={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mo={key:2,class:U({content:!0})},uo={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},fo={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function vo(e,t,_,h,k,y){const d=s("el-image"),p=s("video-player"),l=s("el-button"),$=s("el-tooltip"),f=s("font-awesome-icon"),m=s("copy-to-clipboard"),V=s("el-alert");return n(),r("div",Je,[i("div",Qe,[o(d,{src:"https://cdn.acedata.cloud/8nxyy9.jpg",class:"avatar"})]),i("div",We,[i("div",Xe,[v(a(e.$t("veo.name.veoBot"))+" ",1),i("span",Ye,a(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",Ze,[e.modelValue?.request?.prompt?(n(),r("p",xe,[v(a(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?u("",!0):(n(),r("span",eo," - ("+a(e.$t("veo.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="running"?(n(),r("span",oo," - ("+a(e.$t("veo.status.processing"))+") ",1)):u("",!0)])):u("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(n(),r("div",to,[e.modelValue?.response?.data[0]?.video_url?(n(),r("div",so,[o(p,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):u("",!0),e.modelValue?.response.success?(n(),r("div",no,[o($,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),w(l,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=I=>e.onGet1080p(I,e.modelValue?.response))},{default:c(()=>[v(a(e.$t("veo.button.action3")),1)]),_:1})):u("",!0)]),_:1},8,["content"]),o($,{class:"box-item",effect:"dark",content:e.$t("veo.message.downloadVideo"),placement:"top-start"},{default:c(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),w(l,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[1]||(t[1]=I=>e.onDownload(I,e.modelValue?.response?.data[0]?.video_url))},{default:c(()=>[v(a(e.$t("veo.button.download")),1)]),_:1})):u("",!0)]),_:1},8,["content"])])):u("",!0),o(V,{closable:!1,class:"mt-2 success"},{default:c(()=>[i("p",ao,[o(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),v(" "+a(e.$t("veo.name.model"))+": "+a(e.modelValue?.request?.model),1)]),i("p",lo,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),v(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(m,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):u("",!0),e.modelValue?.response?.success===!1?(n(),r("div",ro,[o(V,{closable:!1,class:"failure"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),v(" "+a(e.$t("veo.name.failure")),1)]),default:c(()=>[i("p",io,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),v(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(m,{content:e.modelValue?.id},null,8,["content"])]),i("p",co,[o(f,{icon:"fa-solid fa-circle-info",class:"mr-1"}),v(" "+a(e.$t("veo.name.failureReason"))+": "+a(e.modelValue?.response?.error?.message)+" ",1),o(m,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),r("p",po,[o(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),v(" "+a(e.$t("veo.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(m,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):u("",!0)]),_:1})])):u("",!0),e.modelValue?.response?.success===void 0?(n(),r("div",mo,[o(V,{closable:!1,class:"info"},{template:c(()=>[o(f,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),v(" "+a(e.$t("veo.name.failure")),1)]),default:c(()=>[i("p",uo,[o(f,{icon:"fa-solid fa-magic",class:"mr-1"}),v(" "+a(e.$t("veo.name.taskId"))+": "+a(e.modelValue?.id)+" ",1),o(m,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),r("p",fo,[o(f,{icon:"fa-solid fa-hashtag",class:"mr-1"}),v(" "+a(e.$t("veo.name.traceId"))+": "+a(e.modelValue?.response?.trace_id)+" ",1),o(m,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):u("",!0)]),_:1})])):u("",!0)])])}const _o=b(Ke,[["render",vo],["__scopeId","data-v-5372c9d1"]]),ho=g({name:"RecentPanel",components:{TaskPreview:_o,NoTasks:X,BotPlaceholder:W},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.veo?.tasks,items:this.$store.state.veo?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),$o={key:0},go={key:1,class:"tasks h-full w-full overflow-y-auto"},bo={key:2,class:"w-full h-full flex items-center justify-center"};function ko(e,t,_,h,k,y){const d=s("bot-placeholder"),p=s("task-preview"),l=s("no-tasks");return n(),r(C,null,[e.tasks?.items===void 0?(n(),r("div",$o,[o(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),r("div",go,[(n(!0),r(C,null,L(e.tasks?.items,($,f)=>(n(),w(p,{key:f,"model-value":$},null,8,["model-value"]))),128))])):u("",!0),e.tasks?.items?.length===0?(n(),r("div",bo,[o(l)])):u("",!0)],64)}const yo=b(ho,[["render",ko]]),wo="https://webhook.acedata.cloud/veo",Vo=g({name:"VeoIndex",components:{ConfigPanel:He,Layout:ie,RecentPanel:yo},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.veo?.status?.getApplications===H.Request},credential(){return this.$store.state.veo.credential},config(){return this.$store.state.veo.config},tasks(){return this.$store.state.veo.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("veo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("veo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:_,createdAtMax:h}=e||{};console.debug("limit",t,"createdAtMin",_,"createdAtMax",h),await this.$store.dispatch("veo/getTasks",{limit:t,createdAtMin:_,createdAtMax:h})},async onGenerate(){const e={...this.config,callback_url:wo},t=this.credential?.token;if(!t){console.error("no token specified");return}E.info(this.$t("veo.message.startingTask")),z.generate(e,{token:t}).then(()=>{E.success(this.$t("veo.message.startTaskSuccess"))}).catch(_=>{_?.response?.data?.error?.code===N?E.error(this.$t("veo.message.usedUp")):E.error(this.$t("veo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Eo(e,t,_,h,k,y){const d=s("config-panel"),p=s("recent-panel"),l=s("layout");return n(),w(l,null,{config:c(()=>[o(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:c(()=>[o(p,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const rt=b(Vo,[["render",Eo]]);export{rt as default};
@@ -0,0 +1 @@
1
+ import{F as E}from"./index.es-BGVkY8oJ.js";import{E as S}from"./index-CcyWuqA_.js";import{E as U}from"./index-Be00AR5y.js";import{d as h,h as $,b as i,t as a,k as t,r as T,j as _,l as s,o as r,eG as j,x as l,F as y,v as I,i as V,eH as D,D as f,y as b,n as C,eI as P,dr as F,dm as R}from"./index-98VGGErr.js";import{E as L,a as M}from"./index-Cr8oY95Z.js";import{I as G}from"./InfoIcon-nWEOcBLm.js";import{E as B,a as O}from"./index-DE0NLUHP.js";import{E as q}from"./index-DvdaM5kg.js";import{C as N,N as z,B as H}from"./NoTasks-BdeBQAXO.js";import{a as X}from"./price-Cu8efP-h.js";import{C as K}from"./CopyToClipboard-MNFOHaqI.js";import{I as W}from"./ImageWrapper-BH86BJsH.js";import{E as J}from"./index-DzX5B-3h.js";import{E as Q}from"./index-nkzmx8qJ.js";import{E as w}from"./index-bhFxQQDC.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-DfAeDMXy.js";import"./index-DQLaLsnP.js";import"./typescript-1ic-flAv.js";import"./index-CEAOvLtE.js";import"./strings-BCHZaT3A.js";import"./castArray-DKMGoQO3.js";import"./isEqual-0nIQYJnJ.js";import"./_Uint8Array-BP0U7Iu_.js";import"./debounce-CH-Z-bEk.js";import"./_baseIteratee-CxKAS7w7.js";import"./index-ByXZ-2lh.js";import"./index-CiX1WALY.js";import"./index-ChfW7Lcp.js";const Y=h({name:"LayoutFlux",components:{ElDrawer:U,ElButton:S,FontAwesomeIcon:E},data(){return{drawer:!1}}}),Z={class:"main"},ee={class:"config"},te={class:"result"};function oe(e,o,p,u,g,v){const d=s("font-awesome-icon"),m=s("el-button"),n=s("el-drawer");return r(),i("div",Z,[a("div",ee,[T(e.$slots,"config",{},void 0,!0)]),a("div",te,[T(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:o[0]||(o[0]=c=>e.drawer=!0)},{default:_(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=c=>e.drawer=c),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const se=$(Y,[["render",oe],["__scopeId","data-v-126e6454"]]),ne=h({name:"ModelSelector",components:{ElSelect:M,ElOption:L},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"flux-schnell",label:"flux-schnell"},{value:"flux-dev",label:"flux-dev"},{value:"flux-pro",label:"flux-pro"},{value:"flux-pro-1.1",label:"flux-pro-1.1"},{value:"flux-pro-1.1-ultra",label:"flux-pro-1.1-ultra"},{value:"flux-kontext-pro",label:"flux-kontext-pro"},{value:"flux-kontext-max",label:"flux-kontext-max"}]}},computed:{value:{get(){return this.$store.state.flux?.config?.model},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,model:e})}}},mounted(){this.value||(this.value=j)}}),ae={class:"field"},le={class:"title font-bold"};function re(e,o,p,u,g,v){const d=s("el-option"),m=s("el-select");return r(),i("div",ae,[a("h2",le,l(e.$t("flux.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:_(()=>[(r(!0),i(y,null,I(e.options,n=>(r(),V(d,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ie=$(ne,[["render",re],["__scopeId","data-v-2e94cca6"]]),ce=h({name:"CountSelector",components:{ElSlider:O,InfoIcon:G,ElInputNumber:B},computed:{value:{get(){return this.$store.state.flux?.config?.count},set(e){console.debug("set count",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,count:e})}}},mounted(){this.value||(this.value=D)}}),ue={class:"flex justify-between"},de={class:"flex justify-start items-center"},me={class:"text-sm font-bold"},pe={class:"flex justify-end items-center"},fe={class:"w-full"};function _e(e,o,p,u,g,v){const d=s("info-icon"),m=s("el-input-number"),n=s("el-slider");return r(),i("div",null,[a("div",ue,[a("div",de,[a("span",me,l(e.$t("flux.name.numbers")),1),t(d,{content:e.$t("flux.description.numbers")},null,8,["content"])]),a("div",pe,[t(m,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),"controls-position":"right"},null,8,["modelValue"])])]),a("div",fe,[t(n,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=c=>e.value=c),min:1,max:4,step:1},null,8,["modelValue"])])])}const he=$(ce,[["render",_e]]),$e="",ge=h({name:"PromptInput",components:{ElInput:q,InfoIcon:G},computed:{prompt:{get(){return this.$store.state.flux?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),ve={class:"field"},be={class:"box"},xe={class:"title font-bold"};function ke(e,o,p,u,g,v){const d=s("info-icon"),m=s("el-input");return r(),i("div",ve,[a("div",be,[a("h2",xe,l(e.$t("flux.name.prompt")),1),t(d,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const we=$(ge,[["render",ke],["__scopeId","data-v-4c101a17"]]),ye=h({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:E,PromptInput:we,ModelSelector:ie,CountSelector:he,Consumption:N},emits:["generate"],computed:{config(){return this.$store.state.flux?.config},consumption(){return X(this.config,this.service?.metadata?.price)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ve={class:"flex flex-col h-full"},Te={class:"flex-1 overflow-y-auto p-[15px]"},Ee={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ie(e,o,p,u,g,v){const d=s("prompt-input"),m=s("model-selector"),n=s("count-selector"),c=s("consumption"),x=s("font-awesome-icon"),k=s("el-button");return r(),i("div",Ve,[a("div",Te,[t(d,{class:"mb-4"}),t(m,{class:"mb-4"}),t(n,{class:"mb-4"})]),a("div",Ee,[t(c,{value:e.consumption,service:e.service},null,8,["value","service"]),t(k,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[t(x,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])}const Ce=$(ye,[["render",Ie]]),Se=h({name:"TaskPreview",components:{ElImage:Q,CopyToClipboard:K,FontAwesomeIcon:E,ElAlert:J,ImageWrapper:W},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.flux?.application},config(){return this.$store.state.flux?.config},images(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(p=>{let u=p;o&&(u.action=o),e.push(u)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Ge={class:"preview"},Ae={class:"left"},Ue={class:"main"},je={class:"bot"},De={class:"datetime"},Pe={class:"info"},Fe={key:0,class:"prompt mt-2"},Re={key:0},Le={key:0,class:C({content:!0,failed:!0})},Me={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Be={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Oe={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},qe={key:1,class:C({content:!0})},Ne={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ze={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},He={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Xe={key:2,class:C({content:!0})},Ke={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function We(e,o,p,u,g,v){const d=s("el-image"),m=s("image-wrapper"),n=s("font-awesome-icon"),c=s("copy-to-clipboard"),x=s("el-alert");return r(),i("div",Ge,[a("div",Ae,[t(d,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),a("div",Ue,[a("div",je,[f(l(e.$t("flux.name.fluxBot"))+" ",1),a("span",De,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),a("div",Pe,[e.modelValue?.request?.prompt?(r(),i("p",Fe,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?b("",!0):(r(),i("span",Re," - ("+l(e.$t("flux.status.pending"))+") ",1))])):b("",!0)]),e.modelValue?.response?.success===!0?(r(),i("div",Le,[a("div",Me,[(r(!0),i(y,null,I(e.images,(k,A)=>(r(),V(m,{key:A,src:k?.image_url,"raw-src":k?.image_url,"model-value":k},null,8,["src","raw-src","model-value"]))),128))]),t(x,{closable:!1,class:"mt-2 success"},{default:_(()=>[a("p",Be,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.model"))+": "+l(e.modelValue?.request?.model),1)]),a("p",Oe,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(c,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):b("",!0),e.modelValue?.response?.success===!1?(r(),i("div",qe,[t(x,{closable:!1,class:"failure"},{template:_(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",Ne,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),a("p",ze,[t(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("flux.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(c,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),a("p",He,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(c,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):b("",!0),e.modelValue?.response?b("",!0):(r(),i("div",Xe,[t(x,{closable:!1,class:"info"},{template:_(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",Ke,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(c,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Je=$(Se,[["render",We],["__scopeId","data-v-fd5838a5"]]),Qe=h({name:"RecentPanel",components:{TaskPreview:Je,BotPlaceholder:H,NoTasks:z},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),Ye={key:0},Ze={key:1,class:"tasks h-full w-full overflow-y-auto"},et={key:2,class:"w-full h-full flex items-center justify-center"};function tt(e,o,p,u,g,v){const d=s("bot-placeholder"),m=s("task-preview"),n=s("no-tasks");return r(),i(y,null,[e.tasks?.items===void 0?(r(),i("div",Ye,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),i("div",Ze,[(r(!0),i(y,null,I(e.tasks?.items,c=>(r(),V(m,{key:c.id,"model-value":c},null,8,["model-value"]))),128))])):b("",!0),e.tasks?.items?.length===0?(r(),i("div",et,[t(n)])):b("",!0)],64)}const ot=$(Qe,[["render",tt]]),st="https://webhook.acedata.cloud/flux",nt=h({name:"FluxIndex",components:{ConfigPanel:Ce,Layout:se,RecentPanel:ot},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.flux?.status?.getApplications===R.Request},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("flux/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("flux/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:p,createdAtMax:u}=e||{};console.debug("limit",o,"createdAtMin",p,"createdAtMax",u),await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:p,createdAtMax:u})},async onGenerate(){const e={...this.config,callback_url:st},o=this.credential?.token;if(!o){console.error("no token specified");return}w.info(this.$t("flux.message.startingTask")),P.generate(e,{token:o}).then(()=>{w.success(this.$t("flux.message.startTaskSuccess"))}).catch(p=>{const u=p?.response?.data;u?.error?.code===F?w.error(this.$t("flux.message.usedUp")):w.error(this.$t("flux.message.startTaskFailed")+u?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function at(e,o,p,u,g,v){const d=s("config-panel"),m=s("recent-panel"),n=s("layout");return r(),V(n,null,{config:_(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[t(m,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Pt=$(nt,[["render",at]]);export{Pt as default};
@@ -1 +1 @@
1
- import{F as R}from"./index.es-Ds1LLYZB.js";import{E as C}from"./index-BQExLqgj.js";import{E as O}from"./index-TJ2qXY2t.js";import{d as $,h as g,b as r,t as l,k as t,r as U,j as m,l as s,o as a,em as j,x as i,F as V,v as S,i as I,en as q,D as _,eo as z,c6 as B,y as h,n as A,ep as F,dr as N,de as H,dl as K,dm as P}from"./index-CAScKEAu.js";import{I as D}from"./InfoIcon-CwVCPHCP.js";import{E as J}from"./index-Bm0eHRgH.js";import{E as G,a as L}from"./index-NhRVpwT0.js";import{a as Q,E as W}from"./index-Cc85uiiK.js";import{E as X}from"./index-HJfhXT93.js";import{E as w}from"./index-LAL8pDPz.js";import{E as Y}from"./index-DpEzbAMX.js";import{C as Z}from"./CopyToClipboard-IxJR61wg.js";import{s as x}from"./vue-plyr-QZFBikSk.js";import{E as ee}from"./index-4lEOv1Ve.js";import{E as te}from"./index-C4777Kma.js";import{E as oe}from"./index-1c2qdYrk.js";import{a as se,E as ae}from"./index-CSpB1F5W.js";import"./use-form-item-DTrPd0ld.js";import"./index-r5W6hzzQ.js";import"./index-C1rnYNjG.js";import"./index-Bzr3IjSr.js";import"./typescript-WjCVvA-y.js";import"./strings-CZWcdhe2.js";import"./castArray-B-n0ZfD-.js";import"./isEqual-BCLzbsf0.js";import"./_Uint8Array-Djk9lJCp.js";import"./debounce-94P5SC1k.js";import"./_baseIteratee-CvFPRO8v.js";import"./index-74_Ssoda.js";import"./index-CXzCPe-2.js";import"./_baseClone-_0JJYp5J.js";import"./_initCloneObject-CdQfCT40.js";import"./index-Aqgtd2nL.js";const ne=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:C,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ie={class:"main"},le={class:"config"},re={class:"result"};function ce(e,o,p,d,k,v){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),r("div",ie,[l("div",le,[U(e.$slots,"config",{},void 0,!0)]),l("div",re,[U(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=f=>e.drawer=!0)},{default:m(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=f=>e.drawer=f),"with-header":!1,size:"350px"},{default:m(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=g(ne,[["render",ce],["__scopeId","data-v-35c01ab3"]]),de=$({name:"IngredientsSelector",components:{ElSwitch:J,InfoIcon:D},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=j)}}),ue={class:"field"},me={class:"title font-bold"};function fe(e,o,p,d,k,v){const c=s("el-switch"),u=s("info-icon");return a(),r("div",ue,[l("h2",me,i(e.$t("pika.name.ingredients")),1),t(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(u,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const _e=g(de,[["render",fe],["__scopeId","data-v-17c0af5c"]]),he=$({name:"EffectSelector",components:{ElSelect:L,ElOption:G},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),$e={class:"field"},ge={class:"title font-bold"},ke={class:"float-left"};function ve(e,o,p,d,k,v){const c=s("el-option"),u=s("el-select");return a(),r("div",$e,[l("h2",ge,i(e.$t("pika.name.effect")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.label,value:n.value},{default:m(()=>[l("span",ke,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const be=g(he,[["render",ve],["__scopeId","data-v-d1c54475"]]),ye=$({name:"IngredientsModelSelector",components:{ElRadioButton:W,ElRadioGroup:Q},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=q)}}),we={class:"field"},Ie={class:"title font-bold"};function Ee(e,o,p,d,k,v){const c=s("el-radio-button"),u=s("el-radio-group");return a(),r("div",we,[l("h2",Ie,i(e.$t("pika.name.ingredientsModel")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),size:"small",class:"quality"},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.value},{default:m(()=>[_(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Ve=g(ye,[["render",Ee],["__scopeId","data-v-b948551f"]]),Se=$({name:"ModelSelector",components:{ElSelect:L,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=z)}}),Te={class:"field"},Ce={class:"title font-bold"};function Ae(e,o,p,d,k,v){const c=s("el-option"),u=s("el-select");return a(),r("div",Te,[l("h2",Ce,i(e.$t("pika.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=g(Se,[["render",Ae],["__scopeId","data-v-7b2e870a"]]),Pe=$({name:"ImageUrlInput",components:{ElUpload:X,ElButton:C,InfoIcon:D},data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){w.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){w.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){w.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Re={class:"field"},De={class:"title font-bold"},Ge={class:"upload-wrapper"};function Le(e,o,p,d,k,v){const c=s("el-button"),u=s("el-upload"),n=s("info-icon");return a(),r("div",Re,[l("h2",De,i(e.$t("pika.name.imageUrl")),1),l("div",Ge,[t(u,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value","show-file-list":!0,limit:3,multiple:!0,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{default:m(()=>[t(c,{size:"small",type:"primary",round:""},{default:m(()=>[_(i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(n,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Me=g(Pe,[["render",Le],["__scopeId","data-v-55a9552e"]]),Oe="",je=$({name:"PromptInput",components:{ElInput:Y,InfoIcon:D},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Oe)}}),qe={class:"field"},ze={class:"box"},Be={class:"title font-bold"};function Fe(e,o,p,d,k,v){const c=s("info-icon"),u=s("el-input");return a(),r("div",qe,[l("div",ze,[l("h2",Be,i(e.$t("pika.name.prompt")),1),t(c,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pika.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ne=g(je,[["render",Fe],["__scopeId","data-v-b94e7a3e"]]),He=$({name:"PresetPanel",components:{ImageUrlInput:Me,ElButton:C,FontAwesomeIcon:R,PromptInput:Ne,IngredientsSelector:_e,IngredientsModelSelector:Ve,ModelSelector:Ue,EffectSelector:be},emits:["generate"],computed:{config(){return this.$store.state.pika?.config}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"panel"},Je={class:"config"},Qe={class:"actions"};function We(e,o,p,d,k,v){const c=s("prompt-input"),u=s("model-selector"),n=s("ingredients-selector"),f=s("effect-selector"),b=s("image-url-input"),E=s("ingredients-model-selector"),T=s("font-awesome-icon"),y=s("el-button");return a(),r("div",Ke,[l("div",Je,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),t(n,{class:"mb-4"}),t(f,{class:"mb-4"}),e.config?.ingredients?(a(),I(b,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),I(E,{key:1,class:"mb-4"})):h("",!0),l("div",Qe,[t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])])}const Xe=g(He,[["render",We],["__scopeId","data-v-53b25bc4"]]),Ye=$({name:"VideoPlayer",components:{VuePlyr:x},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),Ze=["data-poster"],xe=["src"];function et(e,o,p,d,k,v){const c=s("vue-plyr");return a(),r("div",null,[t(c,{options:e.options,class:"video"},{default:m(()=>[l("video",{controls:"",crossorigin:"",playsinline:"","data-poster":e.modelValue?.image_url},[l("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,xe)],8,Ze)]),_:1},8,["options"])])}const tt=g(Ye,[["render",et],["__scopeId","data-v-fc420430"]]),ot=$({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:R,ElAlert:te,VideoPlayer:tt,ElTooltip:ee,ElButton:C},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(p=>{let d=p;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,p=new URL(o.src),d=p.searchParams.get("retry");if(!d)p.searchParams.set("retry","1");else if(parseInt(d)<2)p.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=p.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),st={class:"left"},at={class:"main"},nt={class:"bot"},it={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},ct={key:0},pt={key:1},dt={key:0,class:A({content:!0,failed:!0})},ut={class:"image-wrapper"},mt={key:0,class:A({operations:!0,"mt-2":!0})},ft={class:"description"},_t={key:1,class:A({content:!0})},ht={class:"description"},$t={class:"description"},gt={class:"description"},kt={key:2,class:A({content:!0})},vt={class:"description"};function bt(e,o,p,d,k,v){const c=s("el-image"),u=s("VideoPlayer"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),E=s("copy-to-clipboard"),T=s("el-alert");return a(!0),r(V,null,S(e.videos,(y,M)=>(a(),r("div",{key:M,class:"preview"},[l("div",st,[t(c,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",at,[l("div",nt,[_(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",it,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",lt,[e.modelValue?.request?.prompt?(a(),r("p",rt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",ct," - ("+i(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"||y?.state==="completed"?(a(),r("span",pt," - ("+i(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",dt,[l("div",ut,[t(u,{"model-value":y},null,8,["model-value"])]),y?(a(),r("div",mt,[t(f,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Dt=>e.onDownload(y?.video_url)},{default:m(()=>[_(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):h("",!0)]),_:2},1032,["content"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[l("p",ft,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",_t,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("pika.name.failure")),1)]),default:m(()=>[l("p",ht,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",$t,[t(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",gt,[t(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),r("div",kt,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("pika.name.failure")),1)]),default:m(()=>[l("p",vt,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const yt=g(ot,[["render",bt],["__scopeId","data-v-052d49ba"]]),wt=$({name:"RecentPanel",components:{TaskPreview:yt,ElSkeleton:ae,ElSkeletonItem:se},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),It={key:0,class:"tasks"},Et={class:"left"},Vt={class:"main"},St={key:1,class:"tasks"},Tt={key:2,class:"w-full h-full flex items-center justify-center"};function Ct(e,o,p,d,k,v){const c=s("el-skeleton-item"),u=s("el-skeleton"),n=s("task-preview");return a(),r("div",{ref:"panel",class:"panel recent",onScroll:o[0]||(o[0]=(...f)=>e.onHandleScroll&&e.onHandleScroll(...f))},[e.tasks?.items===void 0?(a(),r("div",It,[(a(),r(V,null,S(3,f=>l("div",{key:f,class:"task placeholder"},[l("div",Et,[t(u,{animated:""},{template:m(()=>[t(c,{variant:"image",class:"avatar"})]),_:1})]),l("div",Vt,[t(u,{animated:""},{template:m(()=>[t(c,{variant:"p",class:"title"}),t(c,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),r("div",St,[(a(!0),r(V,null,S(e.tasks?.items,(f,b)=>(a(),I(n,{key:b,"model-value":f,class:"preview"},null,8,["model-value"]))),128))])):h("",!0),e.tasks?.items?.length===0?(a(),r("p",Tt,i(e.$t("pika.message.noTasks")),1)):h("",!0)],544)}const At=g(wt,[["render",Ct],["__scopeId","data-v-1f6b602e"]]),Ut="https://webhook.acedata.cloud/pika",Pt=$({name:"PikaIndex",components:{ConfigPanel:Xe,Layout:pe,RecentPanel:At},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.pika?.status?.getApplications===P.Request},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){H.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===K&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:p,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",p,"createdAtMax",d),await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:p,createdAtMax:d})},async onGenerate(){const e={...this.config,callback_url:Ut},o=this.credential?.token;if(!o){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),F.generate(e,{token:o}).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(p=>{p?.response?.data?.error?.code===N?w.error(this.$t("pika.message.usedUp")):w.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Rt(e,o,p,d,k,v){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),I(n,null,{config:m(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(u,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const _o=g(Pt,[["render",Rt],["__scopeId","data-v-bc973743"]]);export{_o as default};
1
+ import{F as R}from"./index.es-BGVkY8oJ.js";import{E as C}from"./index-CcyWuqA_.js";import{E as O}from"./index-Be00AR5y.js";import{d as $,h as g,b as r,t as l,k as t,r as U,j as m,l as s,o as a,em as j,x as i,F as V,v as S,i as I,en as q,D as _,eo as z,c6 as B,y as h,n as A,ep as F,dr as N,de as H,dl as K,dm as P}from"./index-98VGGErr.js";import{I as D}from"./InfoIcon-nWEOcBLm.js";import{E as J}from"./index-TZWWVHIQ.js";import{E as G,a as L}from"./index-Cr8oY95Z.js";import{a as Q,E as W}from"./index-BeqHYC-h.js";import{E as X}from"./index-B9tmKJTL.js";import{E as w}from"./index-bhFxQQDC.js";import{E as Y}from"./index-DvdaM5kg.js";import{C as Z}from"./CopyToClipboard-MNFOHaqI.js";import{s as x}from"./vue-plyr-QZFBikSk.js";import{E as ee}from"./index-DfAeDMXy.js";import{E as te}from"./index-DzX5B-3h.js";import{E as oe}from"./index-nkzmx8qJ.js";import{a as se,E as ae}from"./index-ChfW7Lcp.js";import"./use-form-item-94xb2lbs.js";import"./index-r5W6hzzQ.js";import"./index-DQLaLsnP.js";import"./index-CEAOvLtE.js";import"./typescript-1ic-flAv.js";import"./strings-BCHZaT3A.js";import"./castArray-DKMGoQO3.js";import"./isEqual-0nIQYJnJ.js";import"./_Uint8Array-BP0U7Iu_.js";import"./debounce-CH-Z-bEk.js";import"./_baseIteratee-CxKAS7w7.js";import"./index-ByXZ-2lh.js";import"./index-CwD7WKHl.js";import"./_baseClone-BBG0IH2E.js";import"./_initCloneObject-D12d2S1r.js";import"./index-CiX1WALY.js";const ne=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:C,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ie={class:"main"},le={class:"config"},re={class:"result"};function ce(e,o,p,d,k,v){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),r("div",ie,[l("div",le,[U(e.$slots,"config",{},void 0,!0)]),l("div",re,[U(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=f=>e.drawer=!0)},{default:m(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=f=>e.drawer=f),"with-header":!1,size:"350px"},{default:m(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=g(ne,[["render",ce],["__scopeId","data-v-35c01ab3"]]),de=$({name:"IngredientsSelector",components:{ElSwitch:J,InfoIcon:D},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients},set(e){console.debug("set ingredients",e),e||this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,ingredients_mode:void 0,image_url:void 0}),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients:e,model:"2.0"})}}},mounted(){this.value===void 0&&(this.value=j)}}),ue={class:"field"},me={class:"title font-bold"};function fe(e,o,p,d,k,v){const c=s("el-switch"),u=s("info-icon");return a(),r("div",ue,[l("h2",me,i(e.$t("pika.name.ingredients")),1),t(c,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(u,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const _e=g(de,[["render",fe],["__scopeId","data-v-17c0af5c"]]),he=$({name:"EffectSelector",components:{ElSelect:L,ElOption:G},data(){return{}},computed:{options(){return[{value:"Levitate",label:this.$t("pika.style.effect1")},{value:"Decapitate",label:this.$t("pika.style.effect2")},{value:"Eye-pop",label:this.$t("pika.style.effect3")},{value:"Ta-da",label:this.$t("pika.style.effect4")},{value:"Deflate",label:this.$t("pika.style.effect5")},{value:"Crumble",label:this.$t("pika.style.effect6")},{value:"Dissolve",label:this.$t("pika.style.effect7")},{value:"Squish",label:this.$t("pika.style.effect8")},{value:"Inflate",label:this.$t("pika.style.effect9")},{value:"Melt",label:this.$t("pika.style.effect10")},{value:"Cake-ify",label:this.$t("pika.style.effect11")},{value:"Crush",label:this.$t("pika.style.effect12")},{value:"Explode",label:this.$t("pika.style.effect13")}]},value:{get(){return this.$store.state.pika?.config?.effect},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,effect:e})}}}}),$e={class:"field"},ge={class:"title font-bold"},ke={class:"float-left"};function ve(e,o,p,d,k,v){const c=s("el-option"),u=s("el-select");return a(),r("div",$e,[l("h2",ge,i(e.$t("pika.name.effect")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.label,value:n.value},{default:m(()=>[l("span",ke,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const be=g(he,[["render",ve],["__scopeId","data-v-d1c54475"]]),ye=$({name:"IngredientsModelSelector",components:{ElRadioButton:W,ElRadioGroup:Q},data(){return{options:[{label:this.$t("pika.button.precise"),value:"precise"},{label:this.$t("pika.button.creative"),value:"creative"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.ingredients_mode},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,ingredients_mode:e})}}},mounted(){this.value||(this.value=q)}}),we={class:"field"},Ie={class:"title font-bold"};function Ee(e,o,p,d,k,v){const c=s("el-radio-button"),u=s("el-radio-group");return a(),r("div",we,[l("h2",Ie,i(e.$t("pika.name.ingredientsModel")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),size:"small",class:"quality"},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.value},{default:m(()=>[_(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Ve=g(ye,[["render",Ee],["__scopeId","data-v-b948551f"]]),Se=$({name:"ModelSelector",components:{ElSelect:L,ElOption:G},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"2.0",label:"2.0"},{value:"1.5",label:"1.5"}]}},computed:{value:{get(){return this.$store.state.pika?.config?.model},set(e){this.$store.commit("pika/setConfig",{...this.$store.state.pika.config,model:e})}}},mounted(){this.value||(this.value=z)}}),Te={class:"field"},Ce={class:"title font-bold"};function Ae(e,o,p,d,k,v){const c=s("el-option"),u=s("el-select");return a(),r("div",Te,[l("h2",Ce,i(e.$t("pika.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:m(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),I(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=g(Se,[["render",Ae],["__scopeId","data-v-7b2e870a"]]),Pe=$({name:"ImageUrlInput",components:{ElUpload:X,ElButton:C,InfoIcon:D},data(){return{fileList:[],uploadUrl:B()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state.pika?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){w.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){w.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){w.error(this.$t("pika.message.uploadStartImageError"))},onSetStartImageUrl(){this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,image_url:this.urls})},async onSuccess(){this.onSetStartImageUrl()}}}),Re={class:"field"},De={class:"title font-bold"},Ge={class:"upload-wrapper"};function Le(e,o,p,d,k,v){const c=s("el-button"),u=s("el-upload"),n=s("info-icon");return a(),r("div",Re,[l("h2",De,i(e.$t("pika.name.imageUrl")),1),l("div",Ge,[t(u,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=f=>e.fileList=f),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value","show-file-list":!0,limit:3,multiple:!0,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{default:m(()=>[t(c,{size:"small",type:"primary",round:""},{default:m(()=>[_(i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(n,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const Me=g(Pe,[["render",Le],["__scopeId","data-v-55a9552e"]]),Oe="",je=$({name:"PromptInput",components:{ElInput:Y,InfoIcon:D},computed:{prompt:{get(){return this.$store.state.pika?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pika/setConfig",{...this.$store.state.pika?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Oe)}}),qe={class:"field"},ze={class:"box"},Be={class:"title font-bold"};function Fe(e,o,p,d,k,v){const c=s("info-icon"),u=s("el-input");return a(),r("div",qe,[l("div",ze,[l("h2",Be,i(e.$t("pika.name.prompt")),1),t(c,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pika.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ne=g(je,[["render",Fe],["__scopeId","data-v-b94e7a3e"]]),He=$({name:"PresetPanel",components:{ImageUrlInput:Me,ElButton:C,FontAwesomeIcon:R,PromptInput:Ne,IngredientsSelector:_e,IngredientsModelSelector:Ve,ModelSelector:Ue,EffectSelector:be},emits:["generate"],computed:{config(){return this.$store.state.pika?.config}},methods:{onGenerate(){this.$emit("generate")}}}),Ke={class:"panel"},Je={class:"config"},Qe={class:"actions"};function We(e,o,p,d,k,v){const c=s("prompt-input"),u=s("model-selector"),n=s("ingredients-selector"),f=s("effect-selector"),b=s("image-url-input"),E=s("ingredients-model-selector"),T=s("font-awesome-icon"),y=s("el-button");return a(),r("div",Ke,[l("div",Je,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),t(n,{class:"mb-4"}),t(f,{class:"mb-4"}),e.config?.ingredients?(a(),I(b,{key:0,class:"mb-4"})):h("",!0),e.config?.ingredients?(a(),I(E,{key:1,class:"mb-4"})):h("",!0),l("div",Qe,[t(y,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:m(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])])}const Xe=g(He,[["render",We],["__scopeId","data-v-53b25bc4"]]),Ye=$({name:"VideoPlayer",components:{VuePlyr:x},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),Ze=["data-poster"],xe=["src"];function et(e,o,p,d,k,v){const c=s("vue-plyr");return a(),r("div",null,[t(c,{options:e.options,class:"video"},{default:m(()=>[l("video",{controls:"",crossorigin:"",playsinline:"","data-poster":e.modelValue?.image_url},[l("source",{size:"1080",src:e.modelValue?.video_url,type:"video/mp4"},null,8,xe)],8,Ze)]),_:1},8,["options"])])}const tt=g(Ye,[["render",et],["__scopeId","data-v-fc420430"]]),ot=$({name:"TaskPreview",components:{ElImage:oe,CopyToClipboard:Z,FontAwesomeIcon:R,ElAlert:te,VideoPlayer:tt,ElTooltip:ee,ElButton:C},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pika?.application},config(){return this.$store.state.pika?.config},videos(){let e=[];const o=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(p=>{let d=p;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const o=e.target,p=new URL(o.src),d=p.searchParams.get("retry");if(!d)p.searchParams.set("retry","1");else if(parseInt(d)<2)p.searchParams.set("retry",(parseInt(d)+1).toString());else return;o.src=p.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),st={class:"left"},at={class:"main"},nt={class:"bot"},it={class:"datetime"},lt={class:"info"},rt={key:0,class:"prompt mt-2"},ct={key:0},pt={key:1},dt={key:0,class:A({content:!0,failed:!0})},ut={class:"image-wrapper"},mt={key:0,class:A({operations:!0,"mt-2":!0})},ft={class:"description"},_t={key:1,class:A({content:!0})},ht={class:"description"},$t={class:"description"},gt={class:"description"},kt={key:2,class:A({content:!0})},vt={class:"description"};function bt(e,o,p,d,k,v){const c=s("el-image"),u=s("VideoPlayer"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),E=s("copy-to-clipboard"),T=s("el-alert");return a(!0),r(V,null,S(e.videos,(y,M)=>(a(),r("div",{key:M,class:"preview"},[l("div",st,[t(c,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",at,[l("div",nt,[_(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",it,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",lt,[e.modelValue?.request?.prompt?(a(),r("p",rt,[_(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),r("span",ct," - ("+i(e.$t("pika.status.pending"))+") ",1)),y?.state==="processing"||y?.state==="pending"||y?.state==="completed"?(a(),r("span",pt," - ("+i(e.$t("pika.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",dt,[l("div",ut,[t(u,{"model-value":y},null,8,["model-value"])]),y?(a(),r("div",mt,[t(f,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:m(()=>[y?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Dt=>e.onDownload(y?.video_url)},{default:m(()=>[_(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):h("",!0)]),_:2},1032,["content"])])):h("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:m(()=>[l("p",ft,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),r("div",_t,[t(T,{closable:!1,class:"failure"},{template:m(()=>[t(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("pika.name.failure")),1)]),default:m(()=>[l("p",ht,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",$t,[t(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(E,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",gt,[t(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(E,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0),!e.modelValue?.response||y?.state==="processing"||y?.state==="pending"?(a(),r("div",kt,[t(T,{closable:!1,class:"info"},{template:m(()=>[t(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+i(e.$t("pika.name.failure")),1)]),default:m(()=>[l("p",vt,[t(b,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(E,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):h("",!0)])]))),128)}const yt=g(ot,[["render",bt],["__scopeId","data-v-052d49ba"]]),wt=$({name:"RecentPanel",components:{TaskPreview:yt,ElSkeleton:ae,ElSkeletonItem:se},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{onHandleScroll(){const e=this.$refs.panel;console.log("reach-top reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),It={key:0,class:"tasks"},Et={class:"left"},Vt={class:"main"},St={key:1,class:"tasks"},Tt={key:2,class:"w-full h-full flex items-center justify-center"};function Ct(e,o,p,d,k,v){const c=s("el-skeleton-item"),u=s("el-skeleton"),n=s("task-preview");return a(),r("div",{ref:"panel",class:"panel recent",onScroll:o[0]||(o[0]=(...f)=>e.onHandleScroll&&e.onHandleScroll(...f))},[e.tasks?.items===void 0?(a(),r("div",It,[(a(),r(V,null,S(3,f=>l("div",{key:f,class:"task placeholder"},[l("div",Et,[t(u,{animated:""},{template:m(()=>[t(c,{variant:"image",class:"avatar"})]),_:1})]),l("div",Vt,[t(u,{animated:""},{template:m(()=>[t(c,{variant:"p",class:"title"}),t(c,{variant:"image",class:"icon"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),r("div",St,[(a(!0),r(V,null,S(e.tasks?.items,(f,b)=>(a(),I(n,{key:b,"model-value":f,class:"preview"},null,8,["model-value"]))),128))])):h("",!0),e.tasks?.items?.length===0?(a(),r("p",Tt,i(e.$t("pika.message.noTasks")),1)):h("",!0)],544)}const At=g(wt,[["render",Ct],["__scopeId","data-v-1f6b602e"]]),Ut="https://webhook.acedata.cloud/pika",Pt=$({name:"PikaIndex",components:{ConfigPanel:Xe,Layout:pe,RecentPanel:At},inject:["initialized"],data(){return{task:void 0,job:0}},computed:{loading(){return this.$store.state.pika?.status?.getApplications===P.Request},service(){return this.$store.state.pika.service},credential(){return this.$store.state.pika.credential},config(){return this.$store.state.pika.config},initializing(){return this.$store.state.pika.status.getApplications===P.Request},needApply(){return this.$store.state.pika.status.getApplications===P.Success&&!this.application},application(){return this.$store.state.pika.application},applications(){return this.$store.state.pika.applications},tasks(){return this.$store.state.pika.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){clearInterval(this.job)},methods:{async onReachTop(){console.debug("reached top"),await this.onGetTasks({createdAtMax:this.tasks?.items?.[0]?.created_at})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pika/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pika/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},onApply(){H.create({application:this.application}).then(({data:e})=>{this.application=e,w.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===K&&w.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");e&&(e.scrollTop=e.scrollHeight)},500)},async onGetTasks(e){if(this.loading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:p,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",p,"createdAtMax",d),await this.$store.dispatch("pika/getTasks",{limit:o,createdAtMin:p,createdAtMax:d})},async onGenerate(){const e={...this.config,callback_url:Ut},o=this.credential?.token;if(!o){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),F.generate(e,{token:o}).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(p=>{p?.response?.data?.error?.code===N?w.error(this.$t("pika.message.usedUp")):w.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Rt(e,o,p,d,k,v){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),I(n,null,{config:m(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:m(()=>[t(u,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const _o=g(Pt,[["render",Rt],["__scopeId","data-v-bc973743"]]);export{_o as default};
@@ -0,0 +1 @@
1
+ .main[data-v-c954d282]{flex:1;display:flex;flex-direction:row}.main .config[data-v-c954d282]{width:300px;height:100%;overflow-y:scroll;border-right:1px solid var(--el-border-color)}.main .result[data-v-c954d282]{flex:1;width:calc(100% - 600px);height:100%;display:flex;flex-direction:column;border-right:1px solid var(--el-border-color)}.main .preview[data-v-c954d282]{width:300px;height:100%;display:flex;flex-direction:column}.menu[data-v-c954d282]{display:none}@media (max-width: 767px){.main .config[data-v-c954d282]{display:none}.main .result[data-v-c954d282]{width:100%}.main .preview[data-v-c954d282]{display:none}.main .menu[data-v-c954d282]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-5a66a01f]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-5a66a01f]{font-size:14px;margin:0;width:30%}.field .value[data-v-5a66a01f]{flex:1}.title[data-v-6236152c]{font-size:14px;margin-bottom:0;width:30%}.btn.btn-upload[data-v-6236152c]{position:absolute;top:5px;right:0}.upload-wrapper{height:auto;display:flex}.upload-wrapper .el-upload-list{margin:0;width:100%}.field .box[data-v-d7004a7c]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title-info[data-v-d7004a7c]{display:flex;align-items:center}.field .box .instrumental[data-v-d7004a7c]{right:10px;z-index:1000}.field .box .title[data-v-d7004a7c]{font-size:14px;margin-bottom:10px}.field .box[data-v-99dfded8]{display:flex;flex-direction:row;align-items:center;position:relative}.field .box .title[data-v-99dfded8]{font-size:14px;margin-bottom:10px}.field .title-container[data-v-85bbfcaa]{display:flex;flex-direction:row;align-items:center}.field .title-container .title[data-v-85bbfcaa]{font-size:14px;margin-bottom:10px}.field .title-container .right-aligned-switch[data-v-85bbfcaa]{float:left}.field .title-container[data-v-ce70fe34]{display:flex;flex-direction:row;align-items:center}.field .title-container .title[data-v-ce70fe34]{font-size:14px;margin-bottom:10px}.field .title-container .right-aligned-switch[data-v-ce70fe34]{float:left}.field .box[data-v-bcce4821]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative;margin-bottom:10px}.field .box .title[data-v-bcce4821]{font-size:14px;margin-bottom:10px}.field .box .input-wrapper[data-v-bcce4821]{width:150px;margin-left:30px}.field .box[data-v-06640216]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative;margin-bottom:10px}.field .box .title[data-v-06640216]{font-size:14px;margin-bottom:10px}.field .box .input-wrapper[data-v-06640216]{width:150px;margin-left:30px}.panel[data-v-b9fab929]{height:100%;padding:15px;display:flex;flex-direction:column}.panel .config[data-v-b9fab929]{width:100%;height:calc(100% - 50px);flex:1;position:relative}.panel .actions[data-v-b9fab929]{height:50px;display:flex;justify-content:center;align-items:center}.panel .actions .btn[data-v-b9fab929]{width:100%}.task{display:flex;flex-direction:column;cursor:pointer}.task .audio{display:flex;margin-bottom:10px;border-radius:10px}.task .audio:hover{background-color:var(--el-bg-color-page)}.task .audio .left{position:relative;width:60px;height:60px;margin-right:16px;flex-shrink:0}.task .audio .left:hover .overlay{display:block}.task .audio .left .cover{width:100%;height:100%;border-radius:4px}.task .audio .left .duration{position:absolute;right:0;bottom:0;background-color:#000000b3;padding:2px 4px;color:#fff;border-radius:2px;font-size:10px}.task .audio .left .overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;display:none;transition:opacity .3s;border-radius:4px;text-align:center;line-height:70px;cursor:pointer}.task .audio .left .overlay .el-icon{font-size:20px;color:#fff}.task .audio .info{flex:1}.task .audio .info .title{font-size:14px;font-weight:700;margin-top:5px}.task .audio .info .style{font-size:12px;margin-bottom:0;color:var(--el-text-color-secondary)}.task .audio .right{width:120px;display:flex;align-items:center;justify-content:flex-end;padding-right:1px}.task .audio .right .icon{display:block;z-index:100;cursor:pointer;margin-right:15px}.task .audio .right .el-button{margin-right:15px}.player-slider .el-slider{height:10px}.player-slider .el-slider .el-slider__runway,.player-slider .el-slider .el-slider__bar{height:2px;border-radius:0}.player-slider .el-slider .el-slider__button-wrapper{width:10px;height:10px;top:-10.5px}.player-slider .el-slider .el-slider__button{width:8px;height:8px}.el-popover.el-popper{min-width:auto}.status[data-v-f5721d95]{margin-bottom:10px}.panel.detail[data-v-f5721d95]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-f5721d95]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-f5721d95]{position:relative}