@acedatacloud/nexior 3.10.4 → 3.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/dist/assets/{Auth-fCGySikp.js → Auth-Uv_IvbtF.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-BC0knnbs.js → BotPlaceholder-DwgRH20-.js} +1 -1
  3. package/dist/assets/{Callback-BGbyGLvp.js → Callback-ByCCzWcg.js} +1 -1
  4. package/dist/assets/{Console-fBL4i8uf.js → Console-DHwwvfxZ.js} +1 -1
  5. package/dist/assets/{Conversation-DmICjOOx.js → Conversation-BpaSz31f.js} +2 -2
  6. package/dist/assets/{CopyToClipboard-CdHjrONV.js → CopyToClipboard-B_zjEArC.js} +1 -1
  7. package/dist/assets/{Detail-cInuu5bC.js → Detail-CldUUlYK.js} +1 -1
  8. package/dist/assets/{EditArray-DC_vlLzS.js → EditArray-Bt1sWXgD.js} +1 -1
  9. package/dist/assets/{Extra-SeOUcjb8.js → Extra-D06dGtrC.js} +1 -1
  10. package/dist/assets/{FilePreview-B9JRPnA_.js → FilePreview-BTDh_yU5.js} +1 -1
  11. package/dist/assets/{History-CsFMSTaL.js → History-BjWm608N.js} +1 -1
  12. package/dist/assets/{ImagePreview-Bq6TmnB_.js → ImagePreview-B_rmftlm.js} +1 -1
  13. package/dist/assets/{ImageWrapper-BOvl3-ww.js → ImageWrapper-IsRbsLXL.js} +1 -1
  14. package/dist/assets/{Index-BLvNZPBX.js → Index-4bHarnDT.js} +1 -1
  15. package/dist/assets/{Index-ec-kjqE5.js → Index-B1debl89.js} +1 -1
  16. package/dist/assets/{Index-eklOiB1M.js → Index-BP7CYQ7P.js} +1 -1
  17. package/dist/assets/{Index-DIGc7JfA.js → Index-BSbUQIbg.js} +1 -1
  18. package/dist/assets/{Index-D2DRx_80.js → Index-C0q2dzjc.js} +1 -1
  19. package/dist/assets/{Index-CabE0hlE.js → Index-C86zmZAm.js} +1 -1
  20. package/dist/assets/{Index-D0FVvbog.js → Index-CD5ywDjH.js} +1 -1
  21. package/dist/assets/{Index-Ce39jMAv.js → Index-CMHnESeE.js} +1 -1
  22. package/dist/assets/{Index-Cucgh0cQ.js → Index-Cd_bZOhx.js} +1 -1
  23. package/dist/assets/{Index-DctQEcJj.js → Index-CeuNLk_f.js} +1 -1
  24. package/dist/assets/Index-DqWTPyqq.js +1 -0
  25. package/dist/assets/Index-PPPaGVos.css +1 -0
  26. package/dist/assets/{Index-CvsP3Vba.js → Index-U3dqcrDR.js} +1 -1
  27. package/dist/assets/{Index-DBBmJy7I.js → Index-Yx6X3Qm1.js} +1 -1
  28. package/dist/assets/{InfoIcon-9Wan39hE.js → InfoIcon-C_-GVrFj.js} +1 -1
  29. package/dist/assets/{Invitees-Cvq-SEAb.js → Invitees-BPVP0Aih.js} +1 -1
  30. package/dist/assets/{List-CwuM7-Uu.js → List-D-4zj9go.js} +1 -1
  31. package/dist/assets/{List-CIhFeK3Q.js → List-E-lT1rwt.js} +1 -1
  32. package/dist/assets/{List-D9TqBpdA.js → List-OpmDGTjj.js} +1 -1
  33. package/dist/assets/{Login-D-Um3iIv.js → Login-6lS0WBm3.js} +1 -1
  34. package/dist/assets/{Main-JdlREU9F.js → Main-CPaYaYMS.js} +1 -1
  35. package/dist/assets/{Navigator-C6jSlmBW.css → Navigator--ejw7E_g.css} +1 -1
  36. package/dist/assets/Navigator-DM74lcQp.js +1 -0
  37. package/dist/assets/{NoTasks-DN70KO5R.js → NoTasks-Cc2t-KhB.js} +1 -1
  38. package/dist/assets/{Pagination-Bk4PwhOS.js → Pagination-C5BddcIC.js} +1 -1
  39. package/dist/assets/{Status-PiW0hxrr.js → Status-CEpyyIqD.js} +1 -1
  40. package/dist/assets/{Subscribe-_k2xoqJV.js → Subscribe-DD2lmhnE.js} +1 -1
  41. package/dist/assets/{VideoPlayer-BoUYJJAY.js → VideoPlayer-pXfQbDQT.js} +1 -1
  42. package/dist/assets/_Uint8Array-C21Rl0N8.js +1 -0
  43. package/dist/assets/{_baseClone-Lvb_uHUX.js → _baseClone-B-ja3TJc.js} +1 -1
  44. package/dist/assets/_baseIteratee-JKg-PLGw.js +1 -0
  45. package/dist/assets/{_initCloneObject-By_nB0aA.js → _initCloneObject-VeD_6fht.js} +1 -1
  46. package/dist/assets/{castArray-pyQty71k.js → castArray-CjJRTN8w.js} +1 -1
  47. package/dist/assets/common-1iQSWUd1.js +1 -0
  48. package/dist/assets/common-Be4H6jdV.js +1 -0
  49. package/dist/assets/common-BghFkLWM.js +1 -0
  50. package/dist/assets/common-BrFby4Ky.js +1 -0
  51. package/dist/assets/common-Bvick_UR.js +1 -0
  52. package/dist/assets/common-C2rm-k66.js +1 -0
  53. package/dist/assets/common-C_J4y2JE.js +1 -0
  54. package/dist/assets/common-CkuUcrO9.js +1 -0
  55. package/dist/assets/common-D-6r_-m9.js +1 -0
  56. package/dist/assets/common-DG3cTgFD.js +1 -0
  57. package/dist/assets/common-DRBnXSRp.js +1 -0
  58. package/dist/assets/common-Dilv4fxi.js +1 -0
  59. package/dist/assets/common-DvIXsScc.js +1 -0
  60. package/dist/assets/common-DyFFpr0B.js +1 -0
  61. package/dist/assets/common-HS8SvCoT.js +1 -0
  62. package/dist/assets/{common-BmnICXcK.js → common-NwnpPmOh.js} +1 -1
  63. package/dist/assets/common-OL48uI-0.js +1 -0
  64. package/dist/assets/common-pw6hDCQ6.js +1 -0
  65. package/dist/assets/debounce-DPEiv4qa.js +1 -0
  66. package/dist/assets/{distribution-DvkLxkfU.js → distribution-mwsaLSCr.js} +1 -1
  67. package/dist/assets/dropdown-CpNXmULE.js +1 -0
  68. package/dist/assets/{index-CFlyKjX7.js → index-52Xy00cP.js} +1 -1
  69. package/dist/assets/index-BCDVF19o.js +1 -0
  70. package/dist/assets/index-BIeRBgdC.js +1 -0
  71. package/dist/assets/index-BO9akAqw.js +1 -0
  72. package/dist/assets/{index-kKC0Ivrh.js → index-BWD3Nss6.js} +1 -1
  73. package/dist/assets/index-BXSgDlie.js +1 -0
  74. package/dist/assets/{index-UcV0p3Hx.js → index-BXaZ87x3.js} +1 -1
  75. package/dist/assets/{index-BbIXTRxd.js → index-BeBmiTmh.js} +1 -1
  76. package/dist/assets/index-BeZMFg4Z.js +1 -0
  77. package/dist/assets/{index-BTFJb86a.js → index-Bzx9vpDl.js} +1 -1
  78. package/dist/assets/{index-DFneqctn.js → index-C094cc3A.js} +2 -2
  79. package/dist/assets/{index-gPxTnhlP.js → index-CY9KGeTn.js} +1 -1
  80. package/dist/assets/index-Cbr5I2Y9.js +638 -0
  81. package/dist/assets/{index-C2MdqaEN.js → index-D-qMYOzj.js} +1 -1
  82. package/dist/assets/index-D8KZMM1b.js +1 -0
  83. package/dist/assets/index-DFk1FoEG.js +1 -0
  84. package/dist/assets/{index-Bj6DujvH.js → index-DYcbA4Xy.js} +1 -1
  85. package/dist/assets/{index-T8sKVr0g.js → index-Dcs3jWJX.js} +1 -1
  86. package/dist/assets/{index-DTy3KHpU.js → index-De_ntG9v.js} +1 -1
  87. package/dist/assets/{index-Dv2Wumb_.js → index-DmkicCz4.js} +1 -1
  88. package/dist/assets/{index-apGSFDpN.js → index-EFW5HXXl.js} +1 -1
  89. package/dist/assets/{index-BQTBPAa8.js → index-HscBp0fS.js} +1 -1
  90. package/dist/assets/{index-DatrTq9p.js → index-IHqDwSxu.js} +1 -1
  91. package/dist/assets/{index-M0OikGrA.js → index-MUigFyNQ.js} +1 -1
  92. package/dist/assets/{index-_HE2vSD7.js → index-Tlw0DGaS.js} +1 -1
  93. package/dist/assets/{index-B13u5BWJ.js → index-XZ6jwXk2.js} +2 -2
  94. package/dist/assets/{index-CT9MQhzA.js → index-_Q_QIBBy.js} +2 -2
  95. package/dist/assets/{index-BmefQh1G.js → index-cur6am9k.js} +1 -1
  96. package/dist/assets/{index-Bs5qMSYG.js → index-v77iUQMy.js} +1 -1
  97. package/dist/assets/{index.es-ybdv8tNh.js → index.es-DaeHBJIN.js} +1 -1
  98. package/dist/assets/{isEqual-BVGhOXu9.js → isEqual-By-euu_c.js} +1 -1
  99. package/dist/assets/{isPlainObject-DgkzW7S8.js → isPlainObject-DC7IXBFc.js} +1 -1
  100. package/dist/assets/{order-C0QtiKvd.js → order-D77l3vr6.js} +1 -1
  101. package/dist/assets/pixverse-B3cYOTI7.js +1 -0
  102. package/dist/assets/pixverse-BHazkwmb.js +1 -0
  103. package/dist/assets/pixverse-BHrgrssK.js +1 -0
  104. package/dist/assets/pixverse-BUsFUNYe.js +1 -0
  105. package/dist/assets/pixverse-BVUmE2Nz.js +1 -0
  106. package/dist/assets/pixverse-BX5LFx92.js +1 -0
  107. package/dist/assets/pixverse-BklbmbzE.js +1 -0
  108. package/dist/assets/pixverse-Bla6EPVw.js +1 -0
  109. package/dist/assets/pixverse-BvOLrP6a.js +1 -0
  110. package/dist/assets/pixverse-C1faQ-22.js +1 -0
  111. package/dist/assets/pixverse-C7GS_3y9.js +1 -0
  112. package/dist/assets/pixverse-CBzURIc5.js +1 -0
  113. package/dist/assets/pixverse-CEDjTFh1.js +1 -0
  114. package/dist/assets/pixverse-CRJTE3NA.js +1 -0
  115. package/dist/assets/pixverse-D_oI8Wqy.js +1 -0
  116. package/dist/assets/pixverse-U_eVFZLQ.js +1 -0
  117. package/dist/assets/pixverse-h4_s6pBy.js +1 -0
  118. package/dist/assets/pixverse-nwssKDpx.js +1 -0
  119. package/dist/assets/{price-8qoTPL6E.js → price-DfAGvI7c.js} +1 -1
  120. package/dist/assets/site-BKEpp32T.js +1 -0
  121. package/dist/assets/site-Be_-UII9.js +1 -0
  122. package/dist/assets/site-BhvK4gec.js +1 -0
  123. package/dist/assets/site-BlMs9Zhy.js +1 -0
  124. package/dist/assets/site-Bx0QYEf2.js +1 -0
  125. package/dist/assets/site-C1NAEwMM.js +1 -0
  126. package/dist/assets/site-CQ4690VO.js +1 -0
  127. package/dist/assets/site-C_QQG80S.js +1 -0
  128. package/dist/assets/site-CozAKuXr.js +1 -0
  129. package/dist/assets/site-CsjaqKqY.js +1 -0
  130. package/dist/assets/site-CvoS6ApR.js +1 -0
  131. package/dist/assets/site-D551UBmE.js +1 -0
  132. package/dist/assets/site-DKA0eaC7.js +1 -0
  133. package/dist/assets/site-D_5Q7HUd.js +1 -0
  134. package/dist/assets/site-Dm90PXZn.js +1 -0
  135. package/dist/assets/site-God48tBE.js +1 -0
  136. package/dist/assets/site-QlkZcHVJ.js +1 -0
  137. package/dist/assets/site-r82zeRnp.js +1 -0
  138. package/dist/assets/{strings-C9YRIwNe.js → strings-CzjyDUaH.js} +1 -1
  139. package/dist/assets/{typescript-BDQrJx_d.js → typescript-BMcXT3c_.js} +1 -1
  140. package/dist/assets/use-form-item-DBbvHFR2.js +1 -0
  141. package/dist/index.html +1 -1
  142. package/package.json +1 -1
  143. package/dist/assets/Navigator-BUTtk3Bz.js +0 -1
  144. package/dist/assets/_Uint8Array-fEFMYpOd.js +0 -1
  145. package/dist/assets/_baseIteratee-HPhqSc1g.js +0 -1
  146. package/dist/assets/common-BAi-7ftK.js +0 -1
  147. package/dist/assets/common-BGY9t90P.js +0 -1
  148. package/dist/assets/common-BJFo0mZw.js +0 -1
  149. package/dist/assets/common-Bcq_MIlS.js +0 -1
  150. package/dist/assets/common-BybKAVeo.js +0 -1
  151. package/dist/assets/common-CYWD5JzP.js +0 -1
  152. package/dist/assets/common-Cfr7QgCY.js +0 -1
  153. package/dist/assets/common-D-jj8uKZ.js +0 -1
  154. package/dist/assets/common-D6TbLY99.js +0 -1
  155. package/dist/assets/common-D6g-en5p.js +0 -1
  156. package/dist/assets/common-D7NDbKHR.js +0 -1
  157. package/dist/assets/common-DBl6xTme.js +0 -1
  158. package/dist/assets/common-DN2fCvLM.js +0 -1
  159. package/dist/assets/common-DWWHkG3m.js +0 -1
  160. package/dist/assets/common-kbQ_8xWS.js +0 -1
  161. package/dist/assets/common-scHLGxvu.js +0 -1
  162. package/dist/assets/common-yN0h54h8.js +0 -1
  163. package/dist/assets/debounce-CgXMcR6c.js +0 -1
  164. package/dist/assets/dropdown-VTyHUdNA.js +0 -1
  165. package/dist/assets/index-BS8OlUCn.js +0 -1
  166. package/dist/assets/index-Btm_EBDa.js +0 -1
  167. package/dist/assets/index-Bxp11rQw.js +0 -1
  168. package/dist/assets/index-CjM5Z7DY.js +0 -1
  169. package/dist/assets/index-D5IVFX4z.js +0 -1
  170. package/dist/assets/index-DjX0Bpo4.js +0 -1
  171. package/dist/assets/index-oUdhbQ0k.js +0 -638
  172. package/dist/assets/index-pkU4FPE0.js +0 -1
  173. package/dist/assets/site-1MybM8Lz.js +0 -1
  174. package/dist/assets/site-7rvlMh0j.js +0 -1
  175. package/dist/assets/site-BTdZAF1K.js +0 -1
  176. package/dist/assets/site-BjgwOMVm.js +0 -1
  177. package/dist/assets/site-ClFPyYgF.js +0 -1
  178. package/dist/assets/site-CsHB7i33.js +0 -1
  179. package/dist/assets/site-D2NZaN1F.js +0 -1
  180. package/dist/assets/site-D7uG_csZ.js +0 -1
  181. package/dist/assets/site-DIwFDdEJ.js +0 -1
  182. package/dist/assets/site-DV2Pakla.js +0 -1
  183. package/dist/assets/site-DZ7On1Fx.js +0 -1
  184. package/dist/assets/site-DfqBiOCq.js +0 -1
  185. package/dist/assets/site-DnRrg2dn.js +0 -1
  186. package/dist/assets/site-MjZX59Qi.js +0 -1
  187. package/dist/assets/site-S_azWFU-.js +0 -1
  188. package/dist/assets/site-drwuU4DF.js +0 -1
  189. package/dist/assets/site-k4_NSywn.js +0 -1
  190. package/dist/assets/site-wmziKldF.js +0 -1
  191. package/dist/assets/use-form-item-DHA73KI5.js +0 -1
@@ -1 +1 @@
1
- import{F as I}from"./index.es-ybdv8tNh.js";import{E as S}from"./index-apGSFDpN.js";import{E as z}from"./index-Btm_EBDa.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,eb as O,x as i,ec as N,ed as q,c2 as j,D as $,i as k,y as f,n as C,ad as D,F,v as H,ee as K,dl as J,dh as Q}from"./index-oUdhbQ0k.js";import{I as U}from"./InfoIcon-9Wan39hE.js";import{E as A}from"./index-Dv2Wumb_.js";import{I as M}from"./ImagePreview-Bq6TmnB_.js";import{E as R}from"./index-CjM5Z7DY.js";import{E as V}from"./index-D5IVFX4z.js";import{F as W}from"./FilePreview-B9JRPnA_.js";import{E as X}from"./index-_HE2vSD7.js";import{V as B}from"./VideoPlayer-BoUYJJAY.js";import{C as Y}from"./CopyToClipboard-CdHjrONV.js";import{E as Z}from"./index-BbIXTRxd.js";import{E as x}from"./index-M0OikGrA.js";import{E as ee}from"./index-kKC0Ivrh.js";import{B as te}from"./BotPlaceholder-BC0knnbs.js";import{N as oe}from"./NoTasks-DN70KO5R.js";import"./use-form-item-DHA73KI5.js";import"./index-r5W6hzzQ.js";import"./index-BS8OlUCn.js";import"./index-CT9MQhzA.js";import"./typescript-BDQrJx_d.js";import"./_baseClone-Lvb_uHUX.js";import"./_Uint8Array-fEFMYpOd.js";import"./_initCloneObject-By_nB0aA.js";import"./isEqual-BVGhOXu9.js";import"./index-UcV0p3Hx.js";import"./vue-plyr-QZFBikSk.js";import"./debounce-CgXMcR6c.js";import"./index-pkU4FPE0.js";const se=v({name:"LayoutLuma",components:{ElDrawer:z,ElButton:S,FontAwesomeIcon:I},data(){return{drawer:!1}}}),ne={class:"main"},ae={class:"config"},le={class:"result"};function ie(e,o,p,h,w,y){const r=s("font-awesome-icon"),d=s("el-button"),c=s("el-drawer");return a(),m("div",ne,[n("div",ae,[T(e.$slots,"config",{},void 0,!0)]),n("div",le,[T(e.$slots,"result",{},void 0,!0)]),t(d,{round:"",class:"menu",onClick:o[0]||(o[0]=g=>e.drawer=!0)},{default:u(()=>[t(r,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(c,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=g=>e.drawer=g),"with-header":!1,size:"340px",class:"drawer"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const re=b(se,[["render",ie],["__scopeId","data-v-ef27a6b5"]]),ce=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=O)}}),me={class:"relative"},ue={class:"flex justify-between"},de={class:"flex justify-start items-center"},pe={class:"text-sm font-bold"},fe={class:"flex justify-end items-center"};function _e(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",me,[n("div",ue,[n("div",de,[n("span",pe,i(e.$t("luma.name.enhancement")),1),t(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),n("div",fe,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const he=b(ce,[["render",_e]]),$e=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=N)}}),ge={class:"relative"},ve={class:"flex justify-between"},be={class:"flex justify-start items-center"},we={class:"text-sm font-bold"},ye={class:"flex justify-end items-center"};function ke(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",ge,[n("div",ve,[n("div",be,[n("span",we,i(e.$t("luma.name.custom")),1),t(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),n("div",ye,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const Ve=b($e,[["render",ke]]),Ee=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=q)}}),Ue={class:"relative"},Ie={class:"flex justify-between"},Se={class:"flex justify-start items-center"},Le={class:"text-sm font-bold"},Ce={class:"flex justify-end items-center"};function Te(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ue,[n("div",Ie,[n("div",Se,[n("span",Le,i(e.$t("luma.name.loop")),1),t(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),n("div",Ce,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const je=b(Ee,[["render",Te]]),Ae=v({name:"EndImage",components:{ElUpload:R,ElButton:S,ImagePreview:M,InfoIcon:U,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.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()}}}),Re={class:"relative"},Ge={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},De={class:"text-sm font-bold"};function Fe(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",Re,[n("div",Ge,[n("div",Pe,[n("span",De,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Me=b(Ae,[["render",Fe],["__scopeId","data-v-7ab78c3e"]]),Be=v({name:"StartImage",components:{ElUpload:R,ElButton:S,ImagePreview:M,InfoIcon:U,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.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()}}}),ze={class:"relative"},Oe={class:"flex justify-between"},Ne={class:"flex justify-start items-center"},qe={class:"text-sm font-bold"};function He(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",ze,[n("div",Oe,[n("div",Ne,[n("span",qe,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Ke=b(Be,[["render",He],["__scopeId","data-v-425a8cec"]]),Je=v({name:"UploadVideo",components:{ElUpload:R,ElButton:S,InfoIcon:U,FilePreview:W,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){V.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const o=e.type==="video/mp4",p=e.size/1024/1024<10;return o?p?!0:(V.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(V.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()}}}),Qe={class:"relative"},We={class:"flex justify-between"},Xe={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function Ze(e,o,p,h,w,y){const r=s("info-icon"),d=s("file-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",Qe,[n("div",We,[n("div",Xe,[n("span",Ye,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const xe=b(Je,[["render",Ze],["__scopeId","data-v-74e51526"]]),et="",tt=v({name:"PromptInput",components:{ElInput:X,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=et)}}),ot={class:"field"},st={class:"box"},nt={class:"title font-bold"};function at(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-input");return a(),m("div",ot,[n("div",st,[n("h2",nt,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 lt=b(tt,[["render",at],["__scopeId","data-v-e8284075"]]),it=v({name:"ExtendFromInput",components:{VideoPlayer:B},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),rt={class:"relative"},ct={class:"flex mb-2"},mt={class:"text-sm font-bold"};function ut(e,o,p,h,w,y){const r=s("video-player");return a(),m("div",rt,[n("div",ct,[n("span",mt,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 dt=b(it,[["render",ut]]),pt=v({name:"ConfigPanel",components:{LoopSelector:je,StartImageInput:Ke,EndImageInput:Me,EnhancementSelector:he,ElButton:S,FontAwesomeIcon:I,PromptInput:lt,ExtendFromInput:dt,CustomSelector:Ve,UploadVideo:xe},emits:["generate"],computed:{config(){return this.$store.state.luma?.config}},methods:{onGenerate(){this.$emit("generate")}}}),ft={class:"panel"},_t={class:"config"},ht={class:"actions"};function $t(e,o,p,h,w,y){const r=s("extend-from-input"),d=s("prompt-input"),c=s("custom-selector"),g=s("upload-video"),_=s("start-image-input"),l=s("end-image-input"),E=s("enhancement-selector"),L=s("loop-selector"),G=s("font-awesome-icon"),P=s("el-button");return a(),m("div",ft,[n("div",_t,[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(g,{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(E,{class:"mb-4"}),t(L,{class:"mb-4"}),n("div",ht,[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"}),$(" "+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"}),$(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])])}const gt=b(pt,[["render",$t],["__scopeId","data-v-17a7da59"]]),vt=v({name:"TaskPreview",components:{ElImage:ee,CopyToClipboard:Y,FontAwesomeIcon:I,ElAlert:x,VideoPlayer:B,ElTooltip:Z,ElButton:S},props:{modelValue:{type:Object,required:!0}},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})},onDownload(e){window.open(e,"_blank")}}}),bt={class:"preview"},wt={class:"left"},yt={class:"main"},kt={class:"bot"},Vt={class:"datetime"},Et={class:"info"},Ut={key:0,class:"prompt mt-2"},It={key:0},St={key:1},Lt={key:0,class:C({content:!0,failed:!0})},Ct={key:0,class:"mb-4"},Tt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},jt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},At={key:1,class:C({content:!0})},Rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Dt={key:2,class:C({content:!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Mt(e,o,p,h,w,y){const r=s("el-image"),d=s("video-player"),c=s("el-button"),g=s("el-tooltip"),_=s("font-awesome-icon"),l=s("copy-to-clipboard"),E=s("el-alert");return a(),m("div",bt,[n("div",wt,[t(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),n("div",yt,[n("div",kt,[$(i(e.$t("luma.name.lumaBot"))+" ",1),n("span",Vt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),n("div",Et,[e.modelValue?.request?.prompt?(a(),m("p",Ut,[$(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),m("span",It," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",St," - ("+i(e.$t("luma.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Lt,[e.modelValue.response.video_url?(a(),m("div",Ct,[t(d,{src:e.modelValue.response.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Tt,[t(g,{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]=D(L=>e.onExtend(L,e.modelValue?.response),["stop"]))},{default:u(()=>[$(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),t(g,{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]=D(L=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:u(()=>[$(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"])])):f("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[n("p",jt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+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",At,[t(E,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",Rt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])]),n("p",Gt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),$(" "+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",Pt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),$(" "+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",Dt,[t(E,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",Ft,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0)])])}const Bt=b(vt,[["render",Mt],["__scopeId","data-v-8435b346"]]),zt=v({name:"RecentPanel",components:{BotPlaceholder:te,TaskPreview:Bt,NoTasks:oe},emits:["reach-top"],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")}}}),Ot={key:0},Nt={key:1,class:"tasks w-full h-full overflow-y-auto"},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Ht(e,o,p,h,w,y){const r=s("bot-placeholder"),d=s("task-preview"),c=s("no-tasks");return a(),m(F,null,[e.tasks?.items===void 0?(a(),m("div",Ot,[t(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),m("div",Nt,[(a(!0),m(F,null,H(e.tasks?.items,(g,_)=>(a(),k(d,{key:_,"model-value":g},null,8,["model-value"]))),128))])):f("",!0),e.tasks?.items?.length===0?(a(),m("div",qt,[t(c)])):f("",!0)],64)}const Kt=b(zt,[["render",Ht]]),Jt="https://webhook.acedata.cloud/luma",Qt=v({name:"LumaIndex",components:{ConfigPanel:gt,Layout:re,RecentPanel:Kt},data(){return{task:void 0,job:0,timer:void 0}},computed:{loading(){return this.$store.state.luma?.status?.getApplications===Q.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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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(){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:Jt},o=this.credential?.token;if(!o){console.error("no token specified");return}V.info(this.$t("luma.message.startingTask")),K.generate(e,{token:o}).then(()=>{V.success(this.$t("luma.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===J?V.error(this.$t("luma.message.usedUp")):V.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Wt(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},null,8,["onReachTop"])]),_:1})}const So=b(Qt,[["render",Wt]]);export{So as default};
1
+ import{F as I}from"./index.es-DaeHBJIN.js";import{E as S}from"./index-EFW5HXXl.js";import{E as z}from"./index-D8KZMM1b.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,ed as O,x as i,ee as N,ef as q,c4 as j,D as $,i as k,y as f,n as C,af as D,F,v as H,eg as K,dn as J,dj as Q}from"./index-Cbr5I2Y9.js";import{I as U}from"./InfoIcon-C_-GVrFj.js";import{E as A}from"./index-DmkicCz4.js";import{I as M}from"./ImagePreview-B_rmftlm.js";import{E as R}from"./index-BXSgDlie.js";import{E as V}from"./index-BeZMFg4Z.js";import{F as W}from"./FilePreview-BTDh_yU5.js";import{E as X}from"./index-Tlw0DGaS.js";import{V as B}from"./VideoPlayer-pXfQbDQT.js";import{C as Y}from"./CopyToClipboard-B_zjEArC.js";import{E as Z}from"./index-BeBmiTmh.js";import{E as x}from"./index-MUigFyNQ.js";import{E as ee}from"./index-BWD3Nss6.js";import{B as te}from"./BotPlaceholder-DwgRH20-.js";import{N as oe}from"./NoTasks-Cc2t-KhB.js";import"./use-form-item-DBbvHFR2.js";import"./index-r5W6hzzQ.js";import"./index-DFk1FoEG.js";import"./index-_Q_QIBBy.js";import"./typescript-BMcXT3c_.js";import"./_baseClone-B-ja3TJc.js";import"./_Uint8Array-C21Rl0N8.js";import"./_initCloneObject-VeD_6fht.js";import"./isEqual-By-euu_c.js";import"./index-BXaZ87x3.js";import"./vue-plyr-QZFBikSk.js";import"./debounce-DPEiv4qa.js";import"./index-BCDVF19o.js";const se=v({name:"LayoutLuma",components:{ElDrawer:z,ElButton:S,FontAwesomeIcon:I},data(){return{drawer:!1}}}),ne={class:"main"},ae={class:"config"},le={class:"result"};function ie(e,o,p,h,w,y){const r=s("font-awesome-icon"),d=s("el-button"),c=s("el-drawer");return a(),m("div",ne,[n("div",ae,[T(e.$slots,"config",{},void 0,!0)]),n("div",le,[T(e.$slots,"result",{},void 0,!0)]),t(d,{round:"",class:"menu",onClick:o[0]||(o[0]=g=>e.drawer=!0)},{default:u(()=>[t(r,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(c,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=g=>e.drawer=g),"with-header":!1,size:"340px",class:"drawer"},{default:u(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const re=b(se,[["render",ie],["__scopeId","data-v-ef27a6b5"]]),ce=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=O)}}),me={class:"relative"},ue={class:"flex justify-between"},de={class:"flex justify-start items-center"},pe={class:"text-sm font-bold"},fe={class:"flex justify-end items-center"};function _e(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",me,[n("div",ue,[n("div",de,[n("span",pe,i(e.$t("luma.name.enhancement")),1),t(r,{content:e.$t("luma.description.enhancement")},null,8,["content"])]),n("div",fe,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const he=b(ce,[["render",_e]]),$e=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=N)}}),ge={class:"relative"},ve={class:"flex justify-between"},be={class:"flex justify-start items-center"},we={class:"text-sm font-bold"},ye={class:"flex justify-end items-center"};function ke(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",ge,[n("div",ve,[n("div",be,[n("span",we,i(e.$t("luma.name.custom")),1),t(r,{content:e.$t("luma.description.custom")},null,8,["content"])]),n("div",ye,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const Ve=b($e,[["render",ke]]),Ee=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=q)}}),Ue={class:"relative"},Ie={class:"flex justify-between"},Se={class:"flex justify-start items-center"},Le={class:"text-sm font-bold"},Ce={class:"flex justify-end items-center"};function Te(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-switch");return a(),m("div",Ue,[n("div",Ie,[n("div",Se,[n("span",Le,i(e.$t("luma.name.loop")),1),t(r,{content:e.$t("luma.description.loop")},null,8,["content"])]),n("div",Ce,[t(d,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=c=>e.value=c),class:"value"},null,8,["modelValue"])])])])}const je=b(Ee,[["render",Te]]),Ae=v({name:"EndImage",components:{ElUpload:R,ElButton:S,ImagePreview:M,InfoIcon:U,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.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()}}}),Re={class:"relative"},Ge={class:"flex justify-between"},Pe={class:"flex justify-start items-center"},De={class:"text-sm font-bold"};function Fe(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",Re,[n("div",Ge,[n("div",Pe,[n("span",De,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadEndImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Me=b(Ae,[["render",Fe],["__scopeId","data-v-7ab78c3e"]]),Be=v({name:"StartImage",components:{ElUpload:R,ElButton:S,ImagePreview:M,InfoIcon:U,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadReferencesExceed"))},onError(){V.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()}}}),ze={class:"relative"},Oe={class:"flex justify-between"},Ne={class:"flex justify-start items-center"},qe={class:"text-sm font-bold"};function He(e,o,p,h,w,y){const r=s("info-icon"),d=s("image-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",ze,[n("div",Oe,[n("div",Ne,[n("span",qe,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Ke=b(Be,[["render",He],["__scopeId","data-v-425a8cec"]]),Je=v({name:"UploadVideo",components:{ElUpload:R,ElButton:S,InfoIcon:U,FilePreview:W,FontAwesomeIcon:I},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(){V.warning(this.$t("luma.message.uploadVideoExceed"))},onError(){V.error(this.$t("luma.message.uploadVideoError"))},beforeUpload(e){const o=e.type==="video/mp4",p=e.size/1024/1024<10;return o?p?!0:(V.error(this.$t("luma.message.uploadVideoSizeExceed")),!1):(V.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()}}}),Qe={class:"relative"},We={class:"flex justify-between"},Xe={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function Ze(e,o,p,h,w,y){const r=s("info-icon"),d=s("file-preview"),c=s("font-awesome-icon"),g=s("el-button"),_=s("el-upload");return a(),m("div",Qe,[n("div",We,[n("div",Xe,[n("span",Ye,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:E=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):f("",!0)]),default:u(()=>[t(g,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[t(c,{icon:"fa-solid fa-upload",class:"icon mr-1"}),$(" "+i(e.$t("luma.button.uploadVideoUrl")),1)]),_:1})]),_:1},8,["file-list","action","before-upload","on-exceed","on-error","on-success","headers"])])}const xe=b(Je,[["render",Ze],["__scopeId","data-v-74e51526"]]),et="",tt=v({name:"PromptInput",components:{ElInput:X,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=et)}}),ot={class:"field"},st={class:"box"},nt={class:"title font-bold"};function at(e,o,p,h,w,y){const r=s("info-icon"),d=s("el-input");return a(),m("div",ot,[n("div",st,[n("h2",nt,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 lt=b(tt,[["render",at],["__scopeId","data-v-e8284075"]]),it=v({name:"ExtendFromInput",components:{VideoPlayer:B},props:{modelValue:{type:Object,required:!1,default:void 0}},data(){return{options:{quality:{default:"1080p"}}}},computed:{config(){return this.$store.state.luma?.config}}}),rt={class:"relative"},ct={class:"flex mb-2"},mt={class:"text-sm font-bold"};function ut(e,o,p,h,w,y){const r=s("video-player");return a(),m("div",rt,[n("div",ct,[n("span",mt,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 dt=b(it,[["render",ut]]),pt=v({name:"ConfigPanel",components:{LoopSelector:je,StartImageInput:Ke,EndImageInput:Me,EnhancementSelector:he,ElButton:S,FontAwesomeIcon:I,PromptInput:lt,ExtendFromInput:dt,CustomSelector:Ve,UploadVideo:xe},emits:["generate"],computed:{config(){return this.$store.state.luma?.config}},methods:{onGenerate(){this.$emit("generate")}}}),ft={class:"panel"},_t={class:"config"},ht={class:"actions"};function $t(e,o,p,h,w,y){const r=s("extend-from-input"),d=s("prompt-input"),c=s("custom-selector"),g=s("upload-video"),_=s("start-image-input"),l=s("end-image-input"),E=s("enhancement-selector"),L=s("loop-selector"),G=s("font-awesome-icon"),P=s("el-button");return a(),m("div",ft,[n("div",_t,[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(g,{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(E,{class:"mb-4"}),t(L,{class:"mb-4"}),n("div",ht,[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"}),$(" "+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"}),$(" "+i(e.$t("luma.button.generate")),1)]),_:1},8,["onClick"]))])])])}const gt=b(pt,[["render",$t],["__scopeId","data-v-17a7da59"]]),vt=v({name:"TaskPreview",components:{ElImage:ee,CopyToClipboard:Y,FontAwesomeIcon:I,ElAlert:x,VideoPlayer:B,ElTooltip:Z,ElButton:S},props:{modelValue:{type:Object,required:!0}},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})},onDownload(e){window.open(e,"_blank")}}}),bt={class:"preview"},wt={class:"left"},yt={class:"main"},kt={class:"bot"},Vt={class:"datetime"},Et={class:"info"},Ut={key:0,class:"prompt mt-2"},It={key:0},St={key:1},Lt={key:0,class:C({content:!0,failed:!0})},Ct={key:0,class:"mb-4"},Tt={key:1,class:C({operations:!0,"mt-2":!0,"mb-4":!0})},jt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},At={key:1,class:C({content:!0})},Rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Gt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Dt={key:2,class:C({content:!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Mt(e,o,p,h,w,y){const r=s("el-image"),d=s("video-player"),c=s("el-button"),g=s("el-tooltip"),_=s("font-awesome-icon"),l=s("copy-to-clipboard"),E=s("el-alert");return a(),m("div",bt,[n("div",wt,[t(r,{src:"https://cdn.acedata.cloud/ahjfwi.png",class:"avatar"})]),n("div",yt,[n("div",kt,[$(i(e.$t("luma.name.lumaBot"))+" ",1),n("span",Vt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),n("div",Et,[e.modelValue?.request?.prompt?(a(),m("p",Ut,[$(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(a(),m("span",It," - ("+i(e.$t("luma.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"?(a(),m("span",St," - ("+i(e.$t("luma.status.processing"))+") ",1)):f("",!0)])):f("",!0)]),e.modelValue?.response?.success===!0?(a(),m("div",Lt,[e.modelValue.response.video_url?(a(),m("div",Ct,[t(d,{src:e.modelValue.response.video_url},null,8,["src"])])):f("",!0),e.modelValue?.response&&!e.config?.custom?(a(),m("div",Tt,[t(g,{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]=D(L=>e.onExtend(L,e.modelValue?.response),["stop"]))},{default:u(()=>[$(i(e.$t("luma.button.extend")),1)]),_:1})]),_:1},8,["content"]),t(g,{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]=D(L=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:u(()=>[$(i(e.$t("luma.button.download")),1)]),_:1})]),_:1},8,["content"])])):f("",!0),t(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[n("p",jt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+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",At,[t(E,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",Rt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])]),n("p",Gt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),$(" "+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",Pt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),$(" "+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",Dt,[t(E,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),$(" "+i(e.$t("luma.name.failure")),1)]),default:u(()=>[n("p",Ft,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),$(" "+i(e.$t("luma.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(l,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):f("",!0)])])}const Bt=b(vt,[["render",Mt],["__scopeId","data-v-8435b346"]]),zt=v({name:"RecentPanel",components:{BotPlaceholder:te,TaskPreview:Bt,NoTasks:oe},emits:["reach-top"],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")}}}),Ot={key:0},Nt={key:1,class:"tasks w-full h-full overflow-y-auto"},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Ht(e,o,p,h,w,y){const r=s("bot-placeholder"),d=s("task-preview"),c=s("no-tasks");return a(),m(F,null,[e.tasks?.items===void 0?(a(),m("div",Ot,[t(r)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),m("div",Nt,[(a(!0),m(F,null,H(e.tasks?.items,(g,_)=>(a(),k(d,{key:_,"model-value":g},null,8,["model-value"]))),128))])):f("",!0),e.tasks?.items?.length===0?(a(),m("div",qt,[t(c)])):f("",!0)],64)}const Kt=b(zt,[["render",Ht]]),Jt="https://webhook.acedata.cloud/luma",Qt=v({name:"LumaIndex",components:{ConfigPanel:gt,Layout:re,RecentPanel:Kt},data(){return{task:void 0,job:0,timer:void 0}},computed:{loading(){return this.$store.state.luma?.status?.getApplications===Q.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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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(){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:Jt},o=this.credential?.token;if(!o){console.error("no token specified");return}V.info(this.$t("luma.message.startingTask")),K.generate(e,{token:o}).then(()=>{V.success(this.$t("luma.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===J?V.error(this.$t("luma.message.usedUp")):V.error(this.$t("luma.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Wt(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},null,8,["onReachTop"])]),_:1})}const So=b(Qt,[["render",Wt]]);export{So as default};
@@ -1 +1 @@
1
- import{F as R}from"./index.es-ybdv8tNh.js";import{E as A}from"./index-apGSFDpN.js";import{E as O}from"./index-Btm_EBDa.js";import{d as $,h as g,b as r,t as l,k as t,r as U,j as m,l as o,o as a,ef as q,x as i,F as V,v as S,i as I,eg as j,D as _,eh as B,c2 as F,y as h,n as C,ei as N,dl as z,d9 as H,dg as K,dh as P}from"./index-oUdhbQ0k.js";import{I as D}from"./InfoIcon-9Wan39hE.js";import{E as J}from"./index-Dv2Wumb_.js";import{E as G,a as L}from"./index-BTFJb86a.js";import{a as Q,E as W}from"./index-Bxp11rQw.js";import{E as X}from"./index-CjM5Z7DY.js";import{E as w}from"./index-D5IVFX4z.js";import{E as Y}from"./index-_HE2vSD7.js";import{C as Z}from"./CopyToClipboard-CdHjrONV.js";import{s as x}from"./vue-plyr-QZFBikSk.js";import{E as ee}from"./index-BbIXTRxd.js";import{E as te}from"./index-M0OikGrA.js";import{E as se}from"./index-kKC0Ivrh.js";import{a as oe,E as ae}from"./index-pkU4FPE0.js";import"./use-form-item-DHA73KI5.js";import"./index-r5W6hzzQ.js";import"./index-BS8OlUCn.js";import"./index-DjX0Bpo4.js";import"./typescript-BDQrJx_d.js";import"./strings-C9YRIwNe.js";import"./castArray-pyQty71k.js";import"./isEqual-BVGhOXu9.js";import"./_Uint8Array-fEFMYpOd.js";import"./debounce-CgXMcR6c.js";import"./_baseIteratee-HPhqSc1g.js";import"./index-T8sKVr0g.js";import"./index-CT9MQhzA.js";import"./_baseClone-Lvb_uHUX.js";import"./_initCloneObject-By_nB0aA.js";import"./index-UcV0p3Hx.js";const ne=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ie={class:"main"},le={class:"config"},re={class:"result"};function ce(e,s,p,d,k,v){const c=o("font-awesome-icon"),u=o("el-button"),n=o("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,{round:"",class:"menu",onClick:s[0]||(s[0]=f=>e.drawer=!0)},{default:m(()=>[t(c,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=f=>e.drawer=f),"with-header":!1,size:"340px",class:"drawer"},{default:m(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=g(ne,[["render",ce],["__scopeId","data-v-d0a34fc4"]]),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=q)}}),ue={class:"field"},me={class:"title font-bold"};function fe(e,s,p,d,k,v){const c=o("el-switch"),u=o("info-icon");return a(),r("div",ue,[l("h2",me,i(e.$t("pika.name.ingredients")),1),t(c,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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,s,p,d,k,v){const c=o("el-option"),u=o("el-select");return a(),r("div",$e,[l("h2",ge,i(e.$t("pika.name.effect")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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=j)}}),we={class:"field"},Ie={class:"title font-bold"};function Ee(e,s,p,d,k,v){const c=o("el-radio-button"),u=o("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":s[0]||(s[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=B)}}),Te={class:"field"},Ae={class:"title font-bold"};function Ce(e,s,p,d,k,v){const c=o("el-option"),u=o("el-select");return a(),r("div",Te,[l("h2",Ae,i(e.$t("pika.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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",Ce],["__scopeId","data-v-7b2e870a"]]),Pe=$({name:"ImageUrlInput",components:{ElUpload:X,ElButton:A,InfoIcon:D},data(){return{fileList:[],uploadUrl:F()+"/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,s,p,d,k,v){const c=o("el-button"),u=o("el-upload"),n=o("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":s[0]||(s[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="",qe=$({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)}}),je={class:"field"},Be={class:"box"},Fe={class:"title font-bold"};function Ne(e,s,p,d,k,v){const c=o("info-icon"),u=o("el-input");return a(),r("div",je,[l("div",Be,[l("h2",Fe,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":s[0]||(s[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 ze=g(qe,[["render",Ne],["__scopeId","data-v-b94e7a3e"]]),He=$({name:"PresetPanel",components:{ImageUrlInput:Me,ElButton:A,FontAwesomeIcon:R,PromptInput:ze,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,s,p,d,k,v){const c=o("prompt-input"),u=o("model-selector"),n=o("ingredients-selector"),f=o("effect-selector"),b=o("image-url-input"),E=o("ingredients-model-selector"),T=o("font-awesome-icon"),y=o("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,s,p,d,k,v){const c=o("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"]]),st=$({name:"TaskPreview",components:{ElImage:se,CopyToClipboard:Z,FontAwesomeIcon:R,ElAlert:te,VideoPlayer:tt,ElTooltip:ee,ElButton:A},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 s=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(p=>{let d=p;s&&(d.action=s),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const s=e.target,p=new URL(s.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;s.src=p.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),ot={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:C({content:!0,failed:!0})},ut={class:"image-wrapper"},mt={key:0,class:C({operations:!0,"mt-2":!0})},ft={class:"description"},_t={key:1,class:C({content:!0})},ht={class:"description"},$t={class:"description"},gt={class:"description"},kt={key:2,class:C({content:!0})},vt={class:"description"};function bt(e,s,p,d,k,v){const c=o("el-image"),u=o("VideoPlayer"),n=o("el-button"),f=o("el-tooltip"),b=o("font-awesome-icon"),E=o("copy-to-clipboard"),T=o("el-alert");return a(!0),r(V,null,S(e.videos,(y,M)=>(a(),r("div",{key:M,class:"preview"},[l("div",ot,[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(st,[["render",bt],["__scopeId","data-v-238de5c9"]]),wt=$({name:"RecentPanel",components:{TaskPreview:yt,ElSkeleton:ae,ElSkeletonItem:oe},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 At(e,s,p,d,k,v){const c=o("el-skeleton-item"),u=o("el-skeleton"),n=o("task-preview");return a(),r("div",{ref:"panel",class:"panel recent",onScroll:s[0]||(s[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 Ct=g(wt,[["render",At],["__scopeId","data-v-1f6b602e"]]),Ut="https://webhook.acedata.cloud/pika",Pt=$({name:"PikaIndex",components:{ConfigPanel:Xe,Layout:pe,RecentPanel:Ct},data(){return{task:void 0,job:0,timer:void 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,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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:s=5,createdAtMin:p,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",p,"createdAtMax",d),await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:p,createdAtMax:d})},async onGenerate(){const e={...this.config,callback_url:Ut},s=this.credential?.token;if(!s){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),N.generate(e,{token:s}).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(p=>{p?.response?.data?.error?.code===z?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,s,p,d,k,v){const c=o("config-panel"),u=o("recent-panel"),n=o("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 fs=g(Pt,[["render",Rt],["__scopeId","data-v-f27a6245"]]);export{fs as default};
1
+ import{F as R}from"./index.es-DaeHBJIN.js";import{E as A}from"./index-EFW5HXXl.js";import{E as O}from"./index-D8KZMM1b.js";import{d as $,h as k,b as r,t as l,k as t,r as U,j as m,l as o,o as a,eh as j,x as i,F as V,v as S,i as I,ei as q,D as _,ej as B,c4 as F,y as h,n as C,ek as N,dn as z,db as H,di as K,dj as P}from"./index-Cbr5I2Y9.js";import{I as D}from"./InfoIcon-C_-GVrFj.js";import{E as J}from"./index-DmkicCz4.js";import{E as G,a as L}from"./index-Bzx9vpDl.js";import{a as Q,E as W}from"./index-BIeRBgdC.js";import{E as X}from"./index-BXSgDlie.js";import{E as w}from"./index-BeZMFg4Z.js";import{E as Y}from"./index-Tlw0DGaS.js";import{C as Z}from"./CopyToClipboard-B_zjEArC.js";import{s as x}from"./vue-plyr-QZFBikSk.js";import{E as ee}from"./index-BeBmiTmh.js";import{E as te}from"./index-MUigFyNQ.js";import{E as se}from"./index-BWD3Nss6.js";import{a as oe,E as ae}from"./index-BCDVF19o.js";import"./use-form-item-DBbvHFR2.js";import"./index-r5W6hzzQ.js";import"./index-DFk1FoEG.js";import"./index-BO9akAqw.js";import"./typescript-BMcXT3c_.js";import"./strings-CzjyDUaH.js";import"./castArray-CjJRTN8w.js";import"./isEqual-By-euu_c.js";import"./_Uint8Array-C21Rl0N8.js";import"./debounce-DPEiv4qa.js";import"./_baseIteratee-JKg-PLGw.js";import"./index-Dcs3jWJX.js";import"./index-_Q_QIBBy.js";import"./_baseClone-B-ja3TJc.js";import"./_initCloneObject-VeD_6fht.js";import"./index-BXaZ87x3.js";const ne=$({name:"LayoutPika",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:R},data(){return{drawer:!1}}}),ie={class:"main"},le={class:"config"},re={class:"result"};function ce(e,s,p,d,g,v){const c=o("font-awesome-icon"),u=o("el-button"),n=o("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,{round:"",class:"menu",onClick:s[0]||(s[0]=f=>e.drawer=!0)},{default:m(()=>[t(c,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=f=>e.drawer=f),"with-header":!1,size:"340px",class:"drawer"},{default:m(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const pe=k(ne,[["render",ce],["__scopeId","data-v-d0a34fc4"]]),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,s,p,d,g,v){const c=o("el-switch"),u=o("info-icon");return a(),r("div",ue,[l("h2",me,i(e.$t("pika.name.ingredients")),1),t(c,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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=k(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"},ke={class:"title font-bold"},ge={class:"float-left"};function ve(e,s,p,d,g,v){const c=o("el-option"),u=o("el-select");return a(),r("div",$e,[l("h2",ke,i(e.$t("pika.name.effect")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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",ge,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const be=k(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,s,p,d,g,v){const c=o("el-radio-button"),u=o("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":s[0]||(s[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=k(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=B)}}),Te={class:"field"},Ae={class:"title font-bold"};function Ce(e,s,p,d,g,v){const c=o("el-option"),u=o("el-select");return a(),r("div",Te,[l("h2",Ae,i(e.$t("pika.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[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=k(Se,[["render",Ce],["__scopeId","data-v-7b2e870a"]]),Pe=$({name:"ImageUrlInput",components:{ElUpload:X,ElButton:A,InfoIcon:D},data(){return{fileList:[],uploadUrl:F()+"/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,s,p,d,g,v){const c=o("el-button"),u=o("el-upload"),n=o("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":s[0]||(s[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=k(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"},Be={class:"box"},Fe={class:"title font-bold"};function Ne(e,s,p,d,g,v){const c=o("info-icon"),u=o("el-input");return a(),r("div",qe,[l("div",Be,[l("h2",Fe,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":s[0]||(s[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 ze=k(je,[["render",Ne],["__scopeId","data-v-b94e7a3e"]]),He=$({name:"PresetPanel",components:{ImageUrlInput:Me,ElButton:A,FontAwesomeIcon:R,PromptInput:ze,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,s,p,d,g,v){const c=o("prompt-input"),u=o("model-selector"),n=o("ingredients-selector"),f=o("effect-selector"),b=o("image-url-input"),E=o("ingredients-model-selector"),T=o("font-awesome-icon"),y=o("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=k(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,s,p,d,g,v){const c=o("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=k(Ye,[["render",et],["__scopeId","data-v-fc420430"]]),st=$({name:"TaskPreview",components:{ElImage:se,CopyToClipboard:Z,FontAwesomeIcon:R,ElAlert:te,VideoPlayer:tt,ElTooltip:ee,ElButton:A},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 s=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(p=>{let d=p;s&&(d.action=s),e.push(d)}),e}},methods:{onDownload(e){console.log("on download"),window.open(e,"_blank")},onReload(e){const s=e.target,p=new URL(s.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;s.src=p.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),ot={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:C({content:!0,failed:!0})},ut={class:"image-wrapper"},mt={key:0,class:C({operations:!0,"mt-2":!0})},ft={class:"description"},_t={key:1,class:C({content:!0})},ht={class:"description"},$t={class:"description"},kt={class:"description"},gt={key:2,class:C({content:!0})},vt={class:"description"};function bt(e,s,p,d,g,v){const c=o("el-image"),u=o("VideoPlayer"),n=o("el-button"),f=o("el-tooltip"),b=o("font-awesome-icon"),E=o("copy-to-clipboard"),T=o("el-alert");return a(!0),r(V,null,S(e.videos,(y,M)=>(a(),r("div",{key:M,class:"preview"},[l("div",ot,[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",kt,[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",gt,[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=k(st,[["render",bt],["__scopeId","data-v-238de5c9"]]),wt=$({name:"RecentPanel",components:{TaskPreview:yt,ElSkeleton:ae,ElSkeletonItem:oe},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 At(e,s,p,d,g,v){const c=o("el-skeleton-item"),u=o("el-skeleton"),n=o("task-preview");return a(),r("div",{ref:"panel",class:"panel recent",onScroll:s[0]||(s[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 Ct=k(wt,[["render",At],["__scopeId","data-v-1f6b602e"]]),Ut="https://webhook.acedata.cloud/pika",Pt=$({name:"PikaIndex",components:{ConfigPanel:Xe,Layout:pe,RecentPanel:Ct},data(){return{task:void 0,job:0,timer:void 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,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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:s=5,createdAtMin:p,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",p,"createdAtMax",d),await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:p,createdAtMax:d})},async onGenerate(){const e={...this.config,callback_url:Ut},s=this.credential?.token;if(!s){console.error("no token specified");return}w.info(this.$t("pika.message.startingTask")),N.generate(e,{token:s}).then(()=>{w.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(p=>{p?.response?.data?.error?.code===z?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,s,p,d,g,v){const c=o("config-panel"),u=o("recent-panel"),n=o("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 fs=k(Pt,[["render",Rt],["__scopeId","data-v-f27a6245"]]);export{fs as default};
@@ -1 +1 @@
1
- import{F as q}from"./index.es-ybdv8tNh.js";import{E as H}from"./index-apGSFDpN.js";import{E as de}from"./index-Btm_EBDa.js";import{af as pe,al as me,bE as he,ag as ie,c5 as fe,_ as _e,d as C,a as $e,ah as ve,c as j,bd as ge,bj as ke,as as ae,b as _,o as a,i as w,r as U,f as oe,e as A,j as $,b4 as le,E as G,n as ye,g as we,h as L,t as l,k as s,l as c,ev as se,x as v,F as z,v as N,ew as Q,c2 as be,D as P,ex as x,ey as ee,y,J as Z,cJ as te,ez as O,dh as B,eA as R,aj as Ce,K as Se,eB as Ae,d9 as Le,dg as Ee}from"./index-oUdhbQ0k.js";import{E as re}from"./index-Dv2Wumb_.js";import{E as je,a as Ve}from"./index-BTFJb86a.js";import{I as D}from"./InfoIcon-9Wan39hE.js";import{E as Ie}from"./index-CjM5Z7DY.js";import{E}from"./index-D5IVFX4z.js";import{E as K}from"./index-_HE2vSD7.js";import{E as Te,a as ce}from"./index-BQTBPAa8.js";import{E as X}from"./index-kKC0Ivrh.js";import{E as Pe,a as Fe,b as Ue}from"./index-C2MdqaEN.js";import{E as ze}from"./index-BbIXTRxd.js";import{E as Me}from"./index-DatrTq9p.js";import{N as Ge}from"./NoTasks-DN70KO5R.js";import{a as Re,E as De}from"./index-pkU4FPE0.js";import{E as Oe}from"./index-DjX0Bpo4.js";import"./use-form-item-DHA73KI5.js";import"./index-r5W6hzzQ.js";import"./index-BS8OlUCn.js";import"./strings-C9YRIwNe.js";import"./castArray-pyQty71k.js";import"./isEqual-BVGhOXu9.js";import"./_Uint8Array-fEFMYpOd.js";import"./typescript-BDQrJx_d.js";import"./debounce-CgXMcR6c.js";import"./_baseIteratee-HPhqSc1g.js";import"./index-T8sKVr0g.js";import"./index-CT9MQhzA.js";import"./_baseClone-Lvb_uHUX.js";import"./_initCloneObject-By_nB0aA.js";import"./index-UcV0p3Hx.js";import"./dropdown-VTyHUdNA.js";const Be=pe({size:{type:[Number,String],values:fe,default:"",validator:e=>ie(e)},shape:{type:String,values:["circle","square"],default:"circle"},icon:{type:he},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"),r=ve(!1),d=j(()=>{const{size:n,icon:m,shape:k}=i,h=[o.b()];return ge(n)&&h.push(o.m(n)),m&&h.push(o.m("icon")),k&&h.push(o.m(k)),h}),u=j(()=>{const{size:n}=i;return ie(n)?o.cssVarBlock({size:ke(n)||""}):void 0}),p=j(()=>({objectFit:i.fit}));ae(()=>i.src,()=>r.value=!1);function f(n){r.value=!0,t("error",n)}return(n,m)=>(a(),_("span",{class:ye(A(d)),style:oe(A(u))},[(n.src||n.srcSet)&&!r.value?(a(),_("img",{key:0,src:n.src,alt:n.alt,srcset:n.srcSet,style:oe(A(p)),onError:f},null,44,["src","alt","srcset"])):n.icon?(a(),w(A(G),{key:1},{default:$(()=>[(a(),w(le(n.icon)))]),_:1})):U(n.$slots,"default",{key:2})],6))}});var He=_e(qe,[["__file","avatar.vue"]]);const Ze=we(He),Ke=C({name:"LayoutSuno",components:{ElDrawer:de,ElButton:H,FontAwesomeIcon:q},data(){return{drawer:!1,preview:!1}},computed:{}}),Xe={class:"main"},Je={class:"config"},Ye={class:"result"},Qe={class:"preview"};function xe(e,t,i,o,r,d){const u=c("font-awesome-icon"),p=c("el-button"),f=c("el-drawer");return a(),_("div",Xe,[l("div",Je,[U(e.$slots,"config",{},void 0,!0)]),l("div",Ye,[U(e.$slots,"result",{},void 0,!0)]),l("div",Qe,[U(e.$slots,"preview",{},void 0,!0)]),s(p,{round:"",class:"menu",onClick:t[0]||(t[0]=n=>e.drawer=!0)},{default:$(()=>[s(u,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),s(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=n=>e.drawer=n),"with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const et=L(Ke,[["render",xe],["__scopeId","data-v-230fd591"]]),tt=C({name:"VersionSelector",components:{ElSelect:Ve,ElOption:je,ElSwitch:re},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,r,d){const u=c("el-switch"),p=c("el-option"),f=c("el-select");return a(),_("div",ot,[l("h2",st,v(e.$t("suno.name.type")),1),s(u,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=n=>e.custom=n),class:"value"},null,8,["modelValue"]),s(f,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=n=>e.model=n),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:$(()=>[(a(!0),_(z,null,N(e.options,n=>(a(),w(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const it=L(tt,[["render",nt],["__scopeId","data-v-5a66a01f"]]),at=C({name:"UploadAudio",components:{ElUpload:Ie,ElButton:H,InfoIcon:D,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(){E.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){E.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}E.info(this.$t("suno.message.startingUploadAudio")),Q.upload(t,{token:i}).then(o=>{console.debug("get upload music success",o.data);const r=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:r,action:"upload_extend"}),E.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{E.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,r,d){const u=c("info-icon"),p=c("font-awesome-icon"),f=c("el-button"),n=c("el-upload");return a(),_("div",lt,[l("div",rt,[l("div",ct,[l("span",ut,v(e.$t("suno.name.referenceAudios")),1),s(u,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),s(n,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),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:$(()=>[s(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:$(()=>[s(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),P(" "+v(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const pt=L(at,[["render",dt],["__scopeId","data-v-6236152c"]]),mt="",ht=C({name:"PromptInput",components:{ElInput:K,ElSwitch:re,InfoIcon:D},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)}}),ft={class:"field"},_t={class:"box"},$t={class:"title-info"},vt={class:"title font-bold"},gt={class:"instrumental"},kt={class:"title inline-block"};function yt(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-switch"),f=c("el-input");return a(),_("div",ft,[l("div",_t,[l("div",$t,[l("h2",vt,v(e.$t("suno.name.prompt")),1),s(u,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),l("div",gt,[s(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=n=>e.instrumental=n),class:"value mr-2"},null,8,["modelValue"]),l("h2",kt,v(e.$t("suno.name.instrumental")),1)])]),s(f,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const wt=L(ht,[["render",yt],["__scopeId","data-v-d7004a7c"]]),bt="",Ct=C({name:"LyricInput",components:{ElInput:K,InfoIcon:D},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 Et(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",St,[l("div",At,[l("h2",Lt,v(e.$t("suno.name.lyrics")),1),s(u,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(a(),w(p,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=f=>e.lyric=f),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(a(),w(p,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=f=>e.lyric=f),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const jt=L(Ct,[["render",Et],["__scopeId","data-v-99dfded8"]]),Vt=C({name:"StyleInput",components:{ElInput:K,InfoIcon:D},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}}}),It={class:"field"},Tt={class:"title-container"},Pt={class:"titlefont-bold"};function Ft(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",It,[l("div",Tt,[l("h2",Pt,v(e.$t("suno.name.style")),1),s(u,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=f=>e.style=f),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ut=L(Vt,[["render",Ft],["__scopeId","data-v-85bbfcaa"]]),zt=C({name:"TitleInput",components:{ElInput:K,InfoIcon:D},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})}}}}),Mt={class:"field"},Gt={class:"title-container"},Rt={class:"title font-bold"};function Dt(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",Mt,[l("div",Gt,[l("h2",Rt,v(e.$t("suno.name.title")),1),s(u,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=f=>e.title=f),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ot=L(zt,[["render",Dt],["__scopeId","data-v-ce70fe34"]]);function M(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const i=e%60,o=i<10?`0${i}`:i,r=t<10?`0${t}`:t;return o+":"+r}const Bt=C({name:"ExtendFromInput",components:{ElImage:X,ElIcon:G,ElInputNumber:Te,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:M,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"},Zt={class:"task"},Kt={class:"left"},Xt={key:2,class:"duration"},Jt={class:"info"},Yt={class:"title"},Qt={class:"style"};function xt(e,t,i,o,r,d){const u=c("el-input-number"),p=c("el-image"),f=c("video-pause"),n=c("el-icon"),m=c("video-play"),k=te("loading");return a(),_("div",Wt,[l("div",Nt,[l("h2",qt,v(e.$t("suno.name.extend")),1),l("div",Ht,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=h=>e.value=h),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"])])]),l("div",Zt,[e.audio?(a(),_("div",{key:0,class:"audio",onClick:t[3]||(t[3]=h=>e.onClick(e.audio))},[Z((a(),_("div",Kt,[s(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),_("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=h=>e.onPause(e.audio))},[s(n,null,{default:$(()=>[s(f)]),_:1})])):y("",!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(),_("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=h=>e.onPlay(e.audio))},[s(n,null,{default:$(()=>[s(m)]),_:1})])):y("",!0),e.audio?.duration?(a(),_("div",Xt,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[k,!e.audio?.audio_url]]),l("div",Jt,[l("h2",Yt,v(e.audio?.title),1),l("p",Qt,v(e.audio?.style),1)])])):y("",!0)])])}const eo=L(Bt,[["render",xt],["__scopeId","data-v-bcce4821"]]),to=C({name:"CoverFromInput",components:{ElImage:X,ElIcon:G,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:M,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,r,d){const u=c("el-image"),p=c("video-pause"),f=c("el-icon"),n=c("video-play"),m=te("loading");return a(),_("div",oo,[l("div",so,[l("h2",no,v(e.$t("suno.name.cover")),1)]),l("div",io,[e.audio?(a(),_("div",{key:0,class:"audio",onClick:t[2]||(t[2]=k=>e.onClick(e.audio))},[Z((a(),_("div",ao,[s(u,{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(),_("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=k=>e.onPause(e.audio))},[s(f,null,{default:$(()=>[s(p)]),_:1})])):y("",!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(),_("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPlay(e.audio))},[s(f,null,{default:$(()=>[s(n)]),_:1})])):y("",!0),e.audio?.duration?(a(),_("div",lo,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[m,!e.audio?.audio_url]]),l("div",ro,[l("h2",co,v(e.audio?.title),1),l("p",uo,v(e.audio?.style),1)])])):y("",!0)])])}const mo=L(to,[["render",po],["__scopeId","data-v-06640216"]]),ho=C({name:"PresetPanel",components:{TypeSelector:it,PromptInput:wt,LyricInput:jt,StyleInput:Ut,TitleInput:Ot,ExtendFromInput:eo,CoverFromInput:mo,UploadAudio:pt,FontAwesomeIcon:q,ElButton:H},emits:["generate"],computed:{config(){return this.$store.state.suno?.config}},methods:{onGenerate(){this.$emit("generate")}}}),fo={class:"panel"},_o={class:"config"},$o={class:"actions"};function vo(e,t,i,o,r,d){const u=c("type-selector"),p=c("upload-audio"),f=c("prompt-input"),n=c("lyric-input"),m=c("style-input"),k=c("title-input"),h=c("extend-from-input"),b=c("cover-from-input"),T=c("font-awesome-icon"),V=c("el-button");return a(),_("div",fo,[l("div",_o,[s(u,{class:"mb-4"}),s(p,{class:"mb-4"}),e.config?.custom?y("",!0):(a(),w(f,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(a(),w(n,{key:1,class:"mb-4"})):y("",!0),e.config?.custom?(a(),w(m,{key:2,class:"mb-4"})):y("",!0),e.config?.custom?(a(),w(k,{key:3,class:"mb-4"})):y("",!0),e.config?.action==="extend"?(a(),w(h,{key:4,class:"mb-4"})):y("",!0),e.config?.action==="cover"?(a(),w(b,{key:5,class:"mb-4"})):y("",!0),l("div",$o,[e.config?.action!=="extend"?(a(),w(V,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),P(" "+v(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(a(),w(V,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),P(" "+v(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])])}const go=L(ho,[["render",vo],["__scopeId","data-v-dc0dc608"]]);var W={exports:{}},ko=W.exports,ne;function yo(){return ne||(ne=1,function(e,t){(function(i,o){o()})(ko,function(){function i(n,m){return typeof m>"u"?m={autoBom:!1}:typeof m!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),m={autoBom:!m}),m.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(n.type)?new Blob(["\uFEFF",n],{type:n.type}):n}function o(n,m,k){var h=new XMLHttpRequest;h.open("GET",n),h.responseType="blob",h.onload=function(){f(h.response,m,k)},h.onerror=function(){console.error("could not download file")},h.send()}function r(n){var m=new XMLHttpRequest;m.open("HEAD",n,!1);try{m.send()}catch{}return 200<=m.status&&299>=m.status}function d(n){try{n.dispatchEvent(new MouseEvent("click"))}catch{var m=document.createEvent("MouseEvents");m.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),n.dispatchEvent(m)}}var u=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof O=="object"&&O.global===O?O:void 0,p=u.navigator&&/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),f=u.saveAs||(typeof window!="object"||window!==u?function(){}:"download"in HTMLAnchorElement.prototype&&!p?function(n,m,k){var h=u.URL||u.webkitURL,b=document.createElement("a");m=m||n.name||"download",b.download=m,b.rel="noopener",typeof n=="string"?(b.href=n,b.origin===location.origin?d(b):r(b.href)?o(n,m,k):d(b,b.target="_blank")):(b.href=h.createObjectURL(n),setTimeout(function(){h.revokeObjectURL(b.href)},4e4),setTimeout(function(){d(b)},0))}:"msSaveOrOpenBlob"in navigator?function(n,m,k){if(m=m||n.name||"download",typeof n!="string")navigator.msSaveOrOpenBlob(i(n,k),m);else if(r(n))o(n,m,k);else{var h=document.createElement("a");h.href=n,h.target="_blank",setTimeout(function(){d(h)})}}:function(n,m,k,h){if(h=h||open("","_blank"),h&&(h.document.title=h.document.body.innerText="downloading..."),typeof n=="string")return o(n,m,k);var b=n.type==="application/octet-stream",T=/constructor/i.test(u.HTMLElement)||u.safari,V=/CriOS\/[\d]+/.test(navigator.userAgent);if((V||b&&T||p)&&typeof FileReader<"u"){var I=new FileReader;I.onloadend=function(){var S=I.result;S=V?S:S.replace(/^data:[^;]*;/,"data:attachment/file;"),h?h.location.href=S:location=S,h=null},I.readAsDataURL(n)}else{var g=u.URL||u.webkitURL,F=g.createObjectURL(n);h?h.location=F:location.href=F,h=null,setTimeout(function(){g.revokeObjectURL(F)},4e4)}});u.saveAs=f.saveAs=f,e.exports=f})}(W)),W.exports}var wo=yo();const bo="https://webhook.acedata.cloud/suno",Co=C({name:"TaskPreview",components:{ElImage:X,ElIcon:G,ElTooltip:ze,ElButton:H,FontAwesomeIcon:q,VideoPlay:ee,VideoPause:x,ElDropdown:Ue,ElDropdownMenu:Fe,ElDropdownItem:Pe},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(){let e=[];const t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(i=>{let o=i;t&&(o.action=t),e.push(o)}),e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:M,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,r=o.substring(o.lastIndexOf("/")+1);console.log("on preview",r),fetch(t).then(d=>d.blob()).then(d=>{wo.saveAs(d,r)})},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}E.info(this.$t("suno.message.startingTask")),Q.audio(i,{token:o}).then(()=>{E.success(this.$t("suno.message.startTaskSuccess"))}).catch(r=>{E.error(r?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");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"},Eo=["onClick"],jo=["onClick"],Vo={key:2,class:"duration"},Io={class:"info"},To={class:"title"},Po={class:"style"},Fo={class:"right"},Uo={class:"el-dropdown-link"},zo={class:"el-dropdown-link"};function Mo(e,t,i,o,r,d){const u=c("el-image"),p=c("video-pause"),f=c("el-icon"),n=c("video-play"),m=c("el-button"),k=c("font-awesome-icon"),h=c("el-tooltip"),b=c("el-dropdown-item"),T=c("el-dropdown-menu"),V=c("el-dropdown"),I=te("loading");return a(),_("div",So,[(a(!0),_(z,null,N(e.audios,(g,F)=>(a(),_("div",{key:F,class:"audio",onClick:S=>e.onClick(g)},[Z((a(),_("div",Lo,[s(u,{src:g?.image_url,class:"cover",fit:"cover"},null,8,["src"]),g?.audio_url&&e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),_("div",{key:0,class:"overlay",onClick:S=>e.onPause(g)},[s(f,null,{default:$(()=>[s(p)]),_:1})],8,Eo)):y("",!0),g?.audio_url&&(e.$store.state?.suno?.audio?.id!==g.id||e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="paused")?(a(),_("div",{key:1,class:"overlay",onClick:S=>e.onPlay(g)},[s(f,null,{default:$(()=>[s(n)]),_:1})],8,jo)):y("",!0),g?.duration?(a(),_("div",Vo,v(e.useFormatDuring(g?.duration)),1)):y("",!0)])),[[I,!g?.audio_url]]),l("div",Io,[l("h2",To,v(g?.title),1),l("p",Po,v(g?.style),1)]),l("div",Fo,[g?.audio_url?(a(),w(m,{key:0,size:"small",round:"",onClick:S=>e.onExtend(S,g)},{default:$(()=>[P(v(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):y("",!0),s(h,{effect:"dark",content:e.$t("suno.button.video"),placement:"top"},{default:$(()=>[g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-clapperboard",class:"icon icon-preview",onClick:S=>e.onPreview(S,g?.video_url)},null,8,["onClick"])):y("",!0)]),_:2},1032,["content"]),s(V,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g?.video_url?(a(),w(b,{key:0,onClick:S=>e.onDownload(S,g?.video_url)},{default:$(()=>[P(v(e.$t("suno.button.download_video")),1)]),_:2},1032,["onClick"])):y("",!0),g?.audio_url?(a(),w(b,{key:1,onClick:S=>e.onDownload(S,g?.audio_url)},{default:$(()=>[P(v(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[l("span",Uo,[s(h,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(V,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g.id?(a(),w(b,{key:0,onClick:S=>e.onGetStems(g.id)},{default:$(()=>[P(v(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):y("",!0),s(b,{onClick:S=>e.onCover(g)},{default:$(()=>[P(v(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),g?.id&&g?.action==="extend"?(a(),w(b,{key:1,onClick:S=>e.onConcatMusic(g?.id)},{default:$(()=>[P(v(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[l("span",zo,[s(h,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,Ao))),128))])}const Go=L(Co,[["render",Mo]]),Ro={class:"player-slider"},Do=C({__name:"PlayerSlider",setup(e){const t=R(),i=j({get:()=>t.state.suno?.audio?.progress,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:u})}),o=j({get:()=>t.state.suno?.audio?.duration,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:u})}),r=()=>{},d=u=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:u});return(u,p)=>(a(),_("div",Ro,[s(A(ce),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=f=>i.value=f),"show-tooltip":!1,min:0,max:o.value,onChange:d,onInput:r},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"},Zo={class:"ml-2 text-dc"},Ko=C({__name:"PlayerSong",setup(e){const t=R(),i=j({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return ae(i,(o,r)=>{if(o?.audio_url!==r?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const d=new Audio(o.audio_url);o.state==="playing"?d.play():d.pause(),d.addEventListener("loadedmetadata",()=>{d.currentTime=0,d.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:d.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:d})}else if(o?.progress!==r?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const d=t.state.suno.audio;d.object&&(d.object.currentTime=d.progress)}else o?.state!==r?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==r?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,r)=>(a(),_("div",Bo,[l("img",{alt:"",class:"w-11 h-11 rounded",src:i.value?.image_url||A(Oo)},null,8,Wo),l("div",No,[l("div",qo,[l("div",Ho,[l("span",null,v(i.value?.title||"Music"),1),l("span",Zo,"- "+v(i.value?.style||"SmallRuralDog"),1)])])])]))}}),Xo={class:"flex justify-end items-center gap-x-2.5"},Jo={class:"text-xs"},Yo=C({__name:"PlayerAction",setup(e){const t=R(),i=j({get:()=>t.state.suno?.audio?.progress,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:r})}),o=j({get:()=>t.state.suno?.audio?.duration,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:r})});return(r,d)=>(a(),_("div",Xo,[l("span",Jo,v(A(M)(i.value))+" / "+v(A(M)(o.value)),1)]))}});var Qo={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||[],r=[],d=t.theme||i.theme;switch(d){case"outline":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("none"),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("none");break;case"filled":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("#FFF"),r.push("#FFF");break;case"two-tone":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone);break;case"multi-color":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.multiColor.outFillColor),r.push(typeof o[2]=="string"?o[2]:i.colors.multiColor.innerStrokeColor),r.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:r,id:e}}var ts=Symbol("icon-context");function J(e,t,i){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(d){var u=xo(),p=Ce(ts,Qo);return function(){var f=d.size,n=d.strokeWidth,m=d.strokeLinecap,k=d.strokeLinejoin,h=d.theme,b=d.fill,T=d.spin,V=es(u,{size:f,strokeWidth:n,strokeLinecap:m,strokeLinejoin:k,theme:h,fill:b},p),I=[p.prefix+"-icon"];return I.push(p.prefix+"-icon-"+e),t&&p.rtl&&I.push(p.prefix+"-icon-rtl"),T&&I.push(p.prefix+"-icon-spin"),s("span",{class:I.join(" ")},[i(V)])}}};return o}const os=J("pause-one",!1,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("path",{d:"M19 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M29 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),ss=J("play",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("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=J("volume-mute",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("rect",{opacity:"0.01",x:"30",y:"18",width:"13",height:"13",fill:e.colors[2]},null),s("mask",{id:e.id+"603476ab",maskUnits:"userSpaceOnUse",x:"30",y:"18",width:"13",height:"13",style:{maskType:"alpha"}},[s("rect",{x:"30",y:"18",width:"13",height:"13",fill:e.colors[2]},null)]),s("g",{mask:"url(#"+e.id+"603476ab)"},[s("path",{d:"M40.7348 20.2858L32.2495 28.7711",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M32.2496 20.2858L40.7349 28.7711",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)]),s("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)])}),ue=J("volume-small",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("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)])}),Y=C({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,i)=>(a(),w(le(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={class:"mt-2"},rs=C({__name:"PlayerVolumeSlider",setup(e){const t=R(),i=j({get:()=>t.state.suno.audio?.volume,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:u})}),o=j({get:()=>t.state.suno.audio?.muted,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:u})}),r=()=>t.dispatch("suno/toggleMuted"),d=u=>t.dispatch("suno/setVolume",u);return(u,p)=>(a(),_("div",is,[l("div",null,[s(A(ce),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=f=>i.value=f),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:d},null,8,["modelValue","disabled"])]),l("div",as,v(i.value),1),l("div",ls,[s(Y,{icon:o.value?A(ns):A(ue),size:"16",theme:"filled",class:"hover-text",onClick:r},null,8,["icon"])])]))}}),cs={class:"flex items-center justify-center gap-x-3"},us=C({__name:"PlayerController",setup(e){const t=R(),i=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=j(()=>t.state.suno.audio);return(r,d)=>(a(),_("div",cs,[s(Y,{icon:o.value?.state==="playing"?A(os):A(ss),size:"45",theme:"filled",class:"control",onClick:i},null,8,["icon"]),s(A(Me),{placement:"top",width:"50px"},{reference:$(()=>[s(Y,{icon:A(ue),size:"20","stroke-width":3,class:"hover-text"},null,8,["icon"])]),default:$(()=>[s(rs)]),_:1})]))}}),ds={class:"flex flex-col items-stretch h-20"},ps={class:"flex grow px-5 items-center"},ms={class:"flex-1"},hs={class:"flex-1"},fs={class:"flex-1"},_s=C({__name:"Player",setup(e){return(t,i)=>(a(),_("div",ds,[s(Do),l("div",ps,[l("div",ms,[s(Ko)]),l("div",hs,[s(us)]),l("div",fs,[s(Yo)])])]))}}),$s=C({name:"RecentPanel",components:{TaskPreview:Go,ElSkeleton:De,ElSkeletonItem:Re,Player:_s,NoTasks:Ge},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 reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),vs={key:0,class:"tasks"},gs={class:"left"},ks={class:"main"},ys={key:1,class:"tasks"},ws={key:2,class:"w-full h-full flex items-center justify-center"},bs={class:"flex-1 flex flex-col"},Cs={class:"h-20"};function Ss(e,t,i,o,r,d){const u=c("el-skeleton-item"),p=c("el-skeleton"),f=c("task-preview"),n=c("no-tasks"),m=c("player");return a(),_(z,null,[l("div",{ref:"panel",class:"panel recent",onScroll:t[0]||(t[0]=(...k)=>e.onHandleScroll&&e.onHandleScroll(...k))},[e.tasks?.items===void 0?(a(),_("div",vs,[(a(),_(z,null,N(3,k=>l("div",{key:k,class:"task placeholder"},[l("div",gs,[s(p,{animated:""},{template:$(()=>[s(u,{variant:"image",class:"avatar"})]),_:1})]),l("div",ks,[s(p,{animated:""},{template:$(()=>[s(u,{variant:"p",class:"title"}),s(u,{variant:"text",style:{"margin-right":"16px"}}),s(u,{variant:"text",style:{width:"80%"}})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),_("div",ys,[(a(!0),_(z,null,N(e.tasks?.items,(k,h)=>(a(),w(f,{key:h,"model-value":k,class:"preview"},null,8,["model-value"]))),128))])):y("",!0),e.tasks?.items?.length===0?(a(),_("div",ws,[s(n)])):y("",!0)],544),Z(l("div",bs,[l("div",Cs,[s(m)])],512),[[Se,!!e.$store?.state?.suno?.audio?.object]])],64)}const As=L($s,[["render",Ss],["__scopeId","data-v-959f8920"]]),Ls=C({name:"TaskPreview",components:{ElScrollbar:Oe,IconPicture:Ae,ElImage:X,ElAvatar:Ze,ElIcon:G},data(){return{showCloseIcon:!0}},computed:{audio(){return this.$store.state.suno?.audio}},methods:{closeCard(){this.showCloseIcon=!this.showCloseIcon}}}),Es={key:0,class:"card"},js={class:"image-container"},Vs={class:"image-slot"},Is={class:"title"},Ts={class:"content"},Ps={class:"artist"},Fs={class:"style"},Us={class:"time"},zs={class:"lyrics"},Ms={key:1,class:"gradient-background"};function Gs(e,t,i,o,r,d){const u=c("icon-picture"),p=c("el-icon"),f=c("el-image"),n=c("el-avatar"),m=c("el-scrollbar");return a(),w(m,{class:"right-panel"},{default:$(()=>[e.audio?.object?(a(),_("div",Es,[l("div",js,[s(f,{src:e.audio.image_url,fit:"cover"},{error:$(()=>[l("div",Vs,[s(p,null,{default:$(()=>[s(u)]),_:1})])]),_:1},8,["src"]),l("h2",Is,v(e.audio?.title),1)]),l("div",Ts,[l("div",Ps,[s(n,{size:30,src:e.audio?.image_url},null,8,["src"]),l("span",null,v(e.audio?.prompt),1)]),l("p",Fs,v(e.audio?.style),1),l("p",Us,v(e.$dayjs.format(e.audio?.created_at)),1),l("div",zs,[l("p",null,v(e.audio?.lyric),1)])])])):(a(),_("div",Ms))]),_:1})}const Rs=L(Ls,[["render",Gs],["__scopeId","data-v-9b29e9f9"]]),Ds="https://webhook.acedata.cloud/suno",Os=C({name:"SunoIndex",components:{Layout:et,ConfigPanel:go,RecentPanel:As,PreviewPanel:Rs},data(){return{task:void 0,job:0,timer:void 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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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,E.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ee&&E.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:Ds},t=this.credential?.token;if(!t){console.error("no token specified");return}E.info(this.$t("suno.message.startingTask")),Q.audio(e,{token:t}).then(()=>{E.success(this.$t("suno.message.startTaskSuccess"))}).catch(i=>{E.error(i?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Bs(e,t,i,o,r,d){const u=c("config-panel"),p=c("recent-panel"),f=c("preview-panel"),n=c("layout");return a(),w(n,null,{config:$(()=>[s(u,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:$(()=>[s(p,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),preview:$(()=>[s(f)]),_:1})}const Cn=L(Os,[["render",Bs],["__scopeId","data-v-69332928"]]);export{Cn as default};
1
+ import{F as q}from"./index.es-DaeHBJIN.js";import{E as H}from"./index-EFW5HXXl.js";import{E as de}from"./index-D8KZMM1b.js";import{ah as pe,an as me,bG as he,ai as ie,c7 as fe,_ as _e,d as C,a as $e,aj as ve,c as j,bf as ge,bl as ke,au as ae,b as _,o as a,i as w,r as U,f as oe,e as L,j as $,b6 as le,E as M,n as ye,g as we,h as A,t as l,k as s,l as c,eB as se,x as v,F as z,v as N,eC as Q,c4 as be,D as P,eD as x,eE as ee,y,J as Z,cL as te,eF as O,dj as B,eG as R,al as Ce,K as Se,eH as Le,db as Ae,di as Ee}from"./index-Cbr5I2Y9.js";import{E as re}from"./index-DmkicCz4.js";import{E as je,a as Ve}from"./index-Bzx9vpDl.js";import{I as D}from"./InfoIcon-C_-GVrFj.js";import{E as Ie}from"./index-BXSgDlie.js";import{E}from"./index-BeZMFg4Z.js";import{E as K}from"./index-Tlw0DGaS.js";import{E as Te,a as ce}from"./index-HscBp0fS.js";import{E as X}from"./index-BWD3Nss6.js";import{E as Pe,a as Fe,b as Ue}from"./index-D-qMYOzj.js";import{E as ze}from"./index-BeBmiTmh.js";import{E as Ge}from"./index-IHqDwSxu.js";import{N as Me}from"./NoTasks-Cc2t-KhB.js";import{a as Re,E as De}from"./index-BCDVF19o.js";import{E as Oe}from"./index-BO9akAqw.js";import"./use-form-item-DBbvHFR2.js";import"./index-r5W6hzzQ.js";import"./index-DFk1FoEG.js";import"./strings-CzjyDUaH.js";import"./castArray-CjJRTN8w.js";import"./isEqual-By-euu_c.js";import"./_Uint8Array-C21Rl0N8.js";import"./typescript-BMcXT3c_.js";import"./debounce-DPEiv4qa.js";import"./_baseIteratee-JKg-PLGw.js";import"./index-Dcs3jWJX.js";import"./index-_Q_QIBBy.js";import"./_baseClone-B-ja3TJc.js";import"./_initCloneObject-VeD_6fht.js";import"./index-BXaZ87x3.js";import"./dropdown-CpNXmULE.js";const Be=pe({size:{type:[Number,String],values:fe,default:"",validator:e=>ie(e)},shape:{type:String,values:["circle","square"],default:"circle"},icon:{type:he},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"),r=ve(!1),d=j(()=>{const{size:n,icon:m,shape:k}=i,h=[o.b()];return ge(n)&&h.push(o.m(n)),m&&h.push(o.m("icon")),k&&h.push(o.m(k)),h}),u=j(()=>{const{size:n}=i;return ie(n)?o.cssVarBlock({size:ke(n)||""}):void 0}),p=j(()=>({objectFit:i.fit}));ae(()=>i.src,()=>r.value=!1);function f(n){r.value=!0,t("error",n)}return(n,m)=>(a(),_("span",{class:ye(L(d)),style:oe(L(u))},[(n.src||n.srcSet)&&!r.value?(a(),_("img",{key:0,src:n.src,alt:n.alt,srcset:n.srcSet,style:oe(L(p)),onError:f},null,44,["src","alt","srcset"])):n.icon?(a(),w(L(M),{key:1},{default:$(()=>[(a(),w(le(n.icon)))]),_:1})):U(n.$slots,"default",{key:2})],6))}});var He=_e(qe,[["__file","avatar.vue"]]);const Ze=we(He),Ke=C({name:"LayoutSuno",components:{ElDrawer:de,ElButton:H,FontAwesomeIcon:q},data(){return{drawer:!1,preview:!1}},computed:{}}),Xe={class:"main"},Je={class:"config"},Ye={class:"result"},Qe={class:"preview"};function xe(e,t,i,o,r,d){const u=c("font-awesome-icon"),p=c("el-button"),f=c("el-drawer");return a(),_("div",Xe,[l("div",Je,[U(e.$slots,"config",{},void 0,!0)]),l("div",Ye,[U(e.$slots,"result",{},void 0,!0)]),l("div",Qe,[U(e.$slots,"preview",{},void 0,!0)]),s(p,{round:"",class:"menu",onClick:t[0]||(t[0]=n=>e.drawer=!0)},{default:$(()=>[s(u,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),s(f,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=n=>e.drawer=n),"with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const et=A(Ke,[["render",xe],["__scopeId","data-v-230fd591"]]),tt=C({name:"VersionSelector",components:{ElSelect:Ve,ElOption:je,ElSwitch:re},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,r,d){const u=c("el-switch"),p=c("el-option"),f=c("el-select");return a(),_("div",ot,[l("h2",st,v(e.$t("suno.name.type")),1),s(u,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=n=>e.custom=n),class:"value"},null,8,["modelValue"]),s(f,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=n=>e.model=n),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:$(()=>[(a(!0),_(z,null,N(e.options,n=>(a(),w(p,{key:n.value,label:n.label,value:n.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:Ie,ElButton:H,InfoIcon:D,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(){E.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){E.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}E.info(this.$t("suno.message.startingUploadAudio")),Q.upload(t,{token:i}).then(o=>{console.debug("get upload music success",o.data);const r=o.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:r,action:"upload_extend"}),E.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(o=>{E.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,r,d){const u=c("info-icon"),p=c("font-awesome-icon"),f=c("el-button"),n=c("el-upload");return a(),_("div",lt,[l("div",rt,[l("div",ct,[l("span",ut,v(e.$t("suno.name.referenceAudios")),1),s(u,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),s(n,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=m=>e.fileList=m),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:$(()=>[s(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:$(()=>[s(p,{icon:"fa-solid fa-upload",class:"icon mr-1"}),P(" "+v(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="",ht=C({name:"PromptInput",components:{ElInput:K,ElSwitch:re,InfoIcon:D},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)}}),ft={class:"field"},_t={class:"box"},$t={class:"title-info"},vt={class:"title font-bold"},gt={class:"instrumental"},kt={class:"title inline-block"};function yt(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-switch"),f=c("el-input");return a(),_("div",ft,[l("div",_t,[l("div",$t,[l("h2",vt,v(e.$t("suno.name.prompt")),1),s(u,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),l("div",gt,[s(p,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=n=>e.instrumental=n),class:"value mr-2"},null,8,["modelValue"]),l("h2",kt,v(e.$t("suno.name.instrumental")),1)])]),s(f,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const wt=A(ht,[["render",yt],["__scopeId","data-v-d7004a7c"]]),bt="",Ct=C({name:"LyricInput",components:{ElInput:K,InfoIcon:D},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"},Lt={class:"box"},At={class:"title font-bold"};function Et(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",St,[l("div",Lt,[l("h2",At,v(e.$t("suno.name.lyrics")),1),s(u,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(a(),w(p,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=f=>e.lyric=f),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(a(),w(p,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=f=>e.lyric=f),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const jt=A(Ct,[["render",Et],["__scopeId","data-v-99dfded8"]]),Vt=C({name:"StyleInput",components:{ElInput:K,InfoIcon:D},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}}}),It={class:"field"},Tt={class:"title-container"},Pt={class:"titlefont-bold"};function Ft(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",It,[l("div",Tt,[l("h2",Pt,v(e.$t("suno.name.style")),1),s(u,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=f=>e.style=f),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ut=A(Vt,[["render",Ft],["__scopeId","data-v-85bbfcaa"]]),zt=C({name:"TitleInput",components:{ElInput:K,InfoIcon:D},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})}}}}),Gt={class:"field"},Mt={class:"title-container"},Rt={class:"title font-bold"};function Dt(e,t,i,o,r,d){const u=c("info-icon"),p=c("el-input");return a(),_("div",Gt,[l("div",Mt,[l("h2",Rt,v(e.$t("suno.name.title")),1),s(u,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),s(p,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=f=>e.title=f),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ot=A(zt,[["render",Dt],["__scopeId","data-v-ce70fe34"]]);function G(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const i=e%60,o=i<10?`0${i}`:i,r=t<10?`0${t}`:t;return o+":"+r}const Bt=C({name:"ExtendFromInput",components:{ElImage:X,ElIcon:M,ElInputNumber:Te,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:G,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"},Zt={class:"task"},Kt={class:"left"},Xt={key:2,class:"duration"},Jt={class:"info"},Yt={class:"title"},Qt={class:"style"};function xt(e,t,i,o,r,d){const u=c("el-input-number"),p=c("el-image"),f=c("video-pause"),n=c("el-icon"),m=c("video-play"),k=te("loading");return a(),_("div",Wt,[l("div",Nt,[l("h2",qt,v(e.$t("suno.name.extend")),1),l("div",Ht,[s(u,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=h=>e.value=h),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"])])]),l("div",Zt,[e.audio?(a(),_("div",{key:0,class:"audio",onClick:t[3]||(t[3]=h=>e.onClick(e.audio))},[Z((a(),_("div",Kt,[s(p,{src:e.audio?.image_url,class:"cover",fit:"cover"},null,8,["src"]),e.audio?.audio_url&&e.$store.state?.suno?.audio?.id===e.audio.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),_("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=h=>e.onPause(e.audio))},[s(n,null,{default:$(()=>[s(f)]),_:1})])):y("",!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(),_("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=h=>e.onPlay(e.audio))},[s(n,null,{default:$(()=>[s(m)]),_:1})])):y("",!0),e.audio?.duration?(a(),_("div",Xt,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[k,!e.audio?.audio_url]]),l("div",Jt,[l("h2",Yt,v(e.audio?.title),1),l("p",Qt,v(e.audio?.style),1)])])):y("",!0)])])}const eo=A(Bt,[["render",xt],["__scopeId","data-v-bcce4821"]]),to=C({name:"CoverFromInput",components:{ElImage:X,ElIcon:M,VideoPlay:ee,VideoPause:x},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:G,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,r,d){const u=c("el-image"),p=c("video-pause"),f=c("el-icon"),n=c("video-play"),m=te("loading");return a(),_("div",oo,[l("div",so,[l("h2",no,v(e.$t("suno.name.cover")),1)]),l("div",io,[e.audio?(a(),_("div",{key:0,class:"audio",onClick:t[2]||(t[2]=k=>e.onClick(e.audio))},[Z((a(),_("div",ao,[s(u,{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(),_("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=k=>e.onPause(e.audio))},[s(f,null,{default:$(()=>[s(p)]),_:1})])):y("",!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(),_("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=k=>e.onPlay(e.audio))},[s(f,null,{default:$(()=>[s(n)]),_:1})])):y("",!0),e.audio?.duration?(a(),_("div",lo,v(e.useFormatDuring(e.audio?.duration)),1)):y("",!0)])),[[m,!e.audio?.audio_url]]),l("div",ro,[l("h2",co,v(e.audio?.title),1),l("p",uo,v(e.audio?.style),1)])])):y("",!0)])])}const mo=A(to,[["render",po],["__scopeId","data-v-06640216"]]),ho=C({name:"PresetPanel",components:{TypeSelector:it,PromptInput:wt,LyricInput:jt,StyleInput:Ut,TitleInput:Ot,ExtendFromInput:eo,CoverFromInput:mo,UploadAudio:pt,FontAwesomeIcon:q,ElButton:H},emits:["generate"],computed:{config(){return this.$store.state.suno?.config}},methods:{onGenerate(){this.$emit("generate")}}}),fo={class:"panel"},_o={class:"config"},$o={class:"actions"};function vo(e,t,i,o,r,d){const u=c("type-selector"),p=c("upload-audio"),f=c("prompt-input"),n=c("lyric-input"),m=c("style-input"),k=c("title-input"),h=c("extend-from-input"),b=c("cover-from-input"),T=c("font-awesome-icon"),V=c("el-button");return a(),_("div",fo,[l("div",_o,[s(u,{class:"mb-4"}),s(p,{class:"mb-4"}),e.config?.custom?y("",!0):(a(),w(f,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(a(),w(n,{key:1,class:"mb-4"})):y("",!0),e.config?.custom?(a(),w(m,{key:2,class:"mb-4"})):y("",!0),e.config?.custom?(a(),w(k,{key:3,class:"mb-4"})):y("",!0),e.config?.action==="extend"?(a(),w(h,{key:4,class:"mb-4"})):y("",!0),e.config?.action==="cover"?(a(),w(b,{key:5,class:"mb-4"})):y("",!0),l("div",$o,[e.config?.action!=="extend"?(a(),w(V,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),P(" "+v(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(a(),w(V,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[s(T,{icon:"fa-solid fa-magic",class:"mr-2"}),P(" "+v(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])])}const go=A(ho,[["render",vo],["__scopeId","data-v-dc0dc608"]]);var W={exports:{}},ko=W.exports,ne;function yo(){return ne||(ne=1,function(e,t){(function(i,o){o()})(ko,function(){function i(n,m){return typeof m>"u"?m={autoBom:!1}:typeof m!="object"&&(console.warn("Deprecated: Expected third argument to be a object"),m={autoBom:!m}),m.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(n.type)?new Blob(["\uFEFF",n],{type:n.type}):n}function o(n,m,k){var h=new XMLHttpRequest;h.open("GET",n),h.responseType="blob",h.onload=function(){f(h.response,m,k)},h.onerror=function(){console.error("could not download file")},h.send()}function r(n){var m=new XMLHttpRequest;m.open("HEAD",n,!1);try{m.send()}catch{}return 200<=m.status&&299>=m.status}function d(n){try{n.dispatchEvent(new MouseEvent("click"))}catch{var m=document.createEvent("MouseEvents");m.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),n.dispatchEvent(m)}}var u=typeof window=="object"&&window.window===window?window:typeof self=="object"&&self.self===self?self:typeof O=="object"&&O.global===O?O:void 0,p=u.navigator&&/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),f=u.saveAs||(typeof window!="object"||window!==u?function(){}:"download"in HTMLAnchorElement.prototype&&!p?function(n,m,k){var h=u.URL||u.webkitURL,b=document.createElement("a");m=m||n.name||"download",b.download=m,b.rel="noopener",typeof n=="string"?(b.href=n,b.origin===location.origin?d(b):r(b.href)?o(n,m,k):d(b,b.target="_blank")):(b.href=h.createObjectURL(n),setTimeout(function(){h.revokeObjectURL(b.href)},4e4),setTimeout(function(){d(b)},0))}:"msSaveOrOpenBlob"in navigator?function(n,m,k){if(m=m||n.name||"download",typeof n!="string")navigator.msSaveOrOpenBlob(i(n,k),m);else if(r(n))o(n,m,k);else{var h=document.createElement("a");h.href=n,h.target="_blank",setTimeout(function(){d(h)})}}:function(n,m,k,h){if(h=h||open("","_blank"),h&&(h.document.title=h.document.body.innerText="downloading..."),typeof n=="string")return o(n,m,k);var b=n.type==="application/octet-stream",T=/constructor/i.test(u.HTMLElement)||u.safari,V=/CriOS\/[\d]+/.test(navigator.userAgent);if((V||b&&T||p)&&typeof FileReader<"u"){var I=new FileReader;I.onloadend=function(){var S=I.result;S=V?S:S.replace(/^data:[^;]*;/,"data:attachment/file;"),h?h.location.href=S:location=S,h=null},I.readAsDataURL(n)}else{var g=u.URL||u.webkitURL,F=g.createObjectURL(n);h?h.location=F:location.href=F,h=null,setTimeout(function(){g.revokeObjectURL(F)},4e4)}});u.saveAs=f.saveAs=f,e.exports=f})}(W)),W.exports}var wo=yo();const bo="https://webhook.acedata.cloud/suno",Co=C({name:"TaskPreview",components:{ElImage:X,ElIcon:M,ElTooltip:ze,ElButton:H,FontAwesomeIcon:q,VideoPlay:ee,VideoPause:x,ElDropdown:Ue,ElDropdownMenu:Fe,ElDropdownItem:Pe},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(){let e=[];const t=this.modelValue?.request?.action;return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(i=>{let o=i;t&&(o.action=t),e.push(o)}),e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:G,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,r=o.substring(o.lastIndexOf("/")+1);console.log("on preview",r),fetch(t).then(d=>d.blob()).then(d=>{wo.saveAs(d,r)})},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}E.info(this.$t("suno.message.startingTask")),Q.audio(i,{token:o}).then(()=>{E.success(this.$t("suno.message.startTaskSuccess"))}).catch(r=>{E.error(r?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".recent");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"},Lo=["onClick"],Ao={class:"left"},Eo=["onClick"],jo=["onClick"],Vo={key:2,class:"duration"},Io={class:"info"},To={class:"title"},Po={class:"style"},Fo={class:"right"},Uo={class:"el-dropdown-link"},zo={class:"el-dropdown-link"};function Go(e,t,i,o,r,d){const u=c("el-image"),p=c("video-pause"),f=c("el-icon"),n=c("video-play"),m=c("el-button"),k=c("font-awesome-icon"),h=c("el-tooltip"),b=c("el-dropdown-item"),T=c("el-dropdown-menu"),V=c("el-dropdown"),I=te("loading");return a(),_("div",So,[(a(!0),_(z,null,N(e.audios,(g,F)=>(a(),_("div",{key:F,class:"audio",onClick:S=>e.onClick(g)},[Z((a(),_("div",Ao,[s(u,{src:g?.image_url,class:"cover",fit:"cover"},null,8,["src"]),g?.audio_url&&e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="playing"?(a(),_("div",{key:0,class:"overlay",onClick:S=>e.onPause(g)},[s(f,null,{default:$(()=>[s(p)]),_:1})],8,Eo)):y("",!0),g?.audio_url&&(e.$store.state?.suno?.audio?.id!==g.id||e.$store.state?.suno?.audio?.id===g.id&&e.$store.state?.suno?.audio?.state==="paused")?(a(),_("div",{key:1,class:"overlay",onClick:S=>e.onPlay(g)},[s(f,null,{default:$(()=>[s(n)]),_:1})],8,jo)):y("",!0),g?.duration?(a(),_("div",Vo,v(e.useFormatDuring(g?.duration)),1)):y("",!0)])),[[I,!g?.audio_url]]),l("div",Io,[l("h2",To,v(g?.title),1),l("p",Po,v(g?.style),1)]),l("div",Fo,[g?.audio_url?(a(),w(m,{key:0,size:"small",round:"",onClick:S=>e.onExtend(S,g)},{default:$(()=>[P(v(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):y("",!0),s(h,{effect:"dark",content:e.$t("suno.button.video"),placement:"top"},{default:$(()=>[g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-clapperboard",class:"icon icon-preview",onClick:S=>e.onPreview(S,g?.video_url)},null,8,["onClick"])):y("",!0)]),_:2},1032,["content"]),s(V,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g?.video_url?(a(),w(b,{key:0,onClick:S=>e.onDownload(S,g?.video_url)},{default:$(()=>[P(v(e.$t("suno.button.download_video")),1)]),_:2},1032,["onClick"])):y("",!0),g?.audio_url?(a(),w(b,{key:1,onClick:S=>e.onDownload(S,g?.audio_url)},{default:$(()=>[P(v(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[l("span",Uo,[s(h,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024),s(V,null,{dropdown:$(()=>[s(T,null,{default:$(()=>[g.id?(a(),w(b,{key:0,onClick:S=>e.onGetStems(g.id)},{default:$(()=>[P(v(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):y("",!0),s(b,{onClick:S=>e.onCover(g)},{default:$(()=>[P(v(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),g?.id&&g?.action==="extend"?(a(),w(b,{key:1,onClick:S=>e.onConcatMusic(g?.id)},{default:$(()=>[P(v(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):y("",!0)]),_:2},1024)]),default:$(()=>[l("span",zo,[s(h,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:$(()=>[g?.audio_url||g?.video_url?(a(),w(k,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):y("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,Lo))),128))])}const Mo=A(Co,[["render",Go]]),Ro={class:"player-slider"},Do=C({__name:"PlayerSlider",setup(e){const t=R(),i=j({get:()=>t.state.suno?.audio?.progress,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:u})}),o=j({get:()=>t.state.suno?.audio?.duration,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:u})}),r=()=>{},d=u=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:u});return(u,p)=>(a(),_("div",Ro,[s(L(ce),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=f=>i.value=f),"show-tooltip":!1,min:0,max:o.value,onChange:d,onInput:r},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"},Zo={class:"ml-2 text-dc"},Ko=C({__name:"PlayerSong",setup(e){const t=R(),i=j({get:()=>t.state.suno.audio,set:o=>t.commit("suno/setAudio",o)});return ae(i,(o,r)=>{if(o?.audio_url!==r?.audio_url){console.log("audio changed",o),o.object&&(console.log("111",o.object),o.object.pause(),delete o.object);const d=new Audio(o.audio_url);o.state==="playing"?d.play():d.pause(),d.addEventListener("loadedmetadata",()=>{d.currentTime=0,d.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:d.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:d})}else if(o?.progress!==r?.progress&&Math.abs(o.progress-o.object.currentTime)>2){console.log("progress changed",o.progress);const d=t.state.suno.audio;d.object&&(d.object.currentTime=d.progress)}else o?.state!==r?.state&&(console.log("state changed",o.state),o.object&&(o.state==="playing"?o.object.play():o.object.pause()));o?.volume!==r?.volume&&(console.log("volume changed",o.volume),o.object&&(o.object.volume=o.volume/100))}),(o,r)=>(a(),_("div",Bo,[l("img",{alt:"",class:"w-11 h-11 rounded",src:i.value?.image_url||L(Oo)},null,8,Wo),l("div",No,[l("div",qo,[l("div",Ho,[l("span",null,v(i.value?.title||"Music"),1),l("span",Zo,"- "+v(i.value?.style||"SmallRuralDog"),1)])])])]))}}),Xo={class:"flex justify-end items-center gap-x-2.5"},Jo={class:"text-xs"},Yo=C({__name:"PlayerAction",setup(e){const t=R(),i=j({get:()=>t.state.suno?.audio?.progress,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:r})}),o=j({get:()=>t.state.suno?.audio?.duration,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:r})});return(r,d)=>(a(),_("div",Xo,[l("span",Jo,v(L(G)(i.value))+" / "+v(L(G)(o.value)),1)]))}});var Qo={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||[],r=[],d=t.theme||i.theme;switch(d){case"outline":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("none"),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("none");break;case"filled":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push("#FFF"),r.push("#FFF");break;case"two-tone":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone),r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.twoTone.twoTone);break;case"multi-color":r.push(typeof o[0]=="string"?o[0]:"currentColor"),r.push(typeof o[1]=="string"?o[1]:i.colors.multiColor.outFillColor),r.push(typeof o[2]=="string"?o[2]:i.colors.multiColor.innerStrokeColor),r.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:r,id:e}}var ts=Symbol("icon-context");function J(e,t,i){var o={name:"icon-"+e,props:["size","strokeWidth","strokeLinecap","strokeLinejoin","theme","fill","spin"],setup:function(d){var u=xo(),p=Ce(ts,Qo);return function(){var f=d.size,n=d.strokeWidth,m=d.strokeLinecap,k=d.strokeLinejoin,h=d.theme,b=d.fill,T=d.spin,V=es(u,{size:f,strokeWidth:n,strokeLinecap:m,strokeLinejoin:k,theme:h,fill:b},p),I=[p.prefix+"-icon"];return I.push(p.prefix+"-icon-"+e),t&&p.rtl&&I.push(p.prefix+"-icon-rtl"),T&&I.push(p.prefix+"-icon-spin"),s("span",{class:I.join(" ")},[i(V)])}}};return o}const os=J("pause-one",!1,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("path",{d:"M19 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M29 18V30",stroke:e.colors[2],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)])}),ss=J("play",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("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=J("volume-mute",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("rect",{opacity:"0.01",x:"30",y:"18",width:"13",height:"13",fill:e.colors[2]},null),s("mask",{id:e.id+"603476ab",maskUnits:"userSpaceOnUse",x:"30",y:"18",width:"13",height:"13",style:{maskType:"alpha"}},[s("rect",{x:"30",y:"18",width:"13",height:"13",fill:e.colors[2]},null)]),s("g",{mask:"url(#"+e.id+"603476ab)"},[s("path",{d:"M40.7348 20.2858L32.2495 28.7711",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null),s("path",{d:"M32.2496 20.2858L40.7349 28.7711",stroke:e.colors[0],"stroke-width":e.strokeWidth,"stroke-linecap":e.strokeLinecap,"stroke-linejoin":e.strokeLinejoin},null)]),s("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)])}),ue=J("volume-small",!0,function(e){return s("svg",{width:e.size,height:e.size,viewBox:"0 0 48 48",fill:"none"},[s("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),s("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)])}),Y=C({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,i)=>(a(),w(le(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={class:"mt-2"},rs=C({__name:"PlayerVolumeSlider",setup(e){const t=R(),i=j({get:()=>t.state.suno.audio?.volume,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:u})}),o=j({get:()=>t.state.suno.audio?.muted,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:u})}),r=()=>t.dispatch("suno/toggleMuted"),d=u=>t.dispatch("suno/setVolume",u);return(u,p)=>(a(),_("div",is,[l("div",null,[s(L(ce),{modelValue:i.value,"onUpdate:modelValue":p[0]||(p[0]=f=>i.value=f),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:o.value,onInput:d},null,8,["modelValue","disabled"])]),l("div",as,v(i.value),1),l("div",ls,[s(Y,{icon:o.value?L(ns):L(ue),size:"16",theme:"filled",class:"hover-text",onClick:r},null,8,["icon"])])]))}}),cs={class:"flex items-center justify-center gap-x-3"},us=C({__name:"PlayerController",setup(e){const t=R(),i=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),o=j(()=>t.state.suno.audio);return(r,d)=>(a(),_("div",cs,[s(Y,{icon:o.value?.state==="playing"?L(os):L(ss),size:"45",theme:"filled",class:"control",onClick:i},null,8,["icon"]),s(L(Ge),{placement:"top",width:"50px"},{reference:$(()=>[s(Y,{icon:L(ue),size:"20","stroke-width":3,class:"hover-text"},null,8,["icon"])]),default:$(()=>[s(rs)]),_:1})]))}}),ds={class:"flex flex-col items-stretch h-20"},ps={class:"flex grow px-5 items-center"},ms={class:"flex-1"},hs={class:"flex-1"},fs={class:"flex-1"},_s=C({__name:"Player",setup(e){return(t,i)=>(a(),_("div",ds,[s(Do),l("div",ps,[l("div",ms,[s(Ko)]),l("div",hs,[s(us)]),l("div",fs,[s(Yo)])])]))}}),$s=C({name:"RecentPanel",components:{TaskPreview:Mo,ElSkeleton:De,ElSkeletonItem:Re,Player:_s,NoTasks:Me},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 reach-top reach-top"),e.scrollTop===0&&this.$emit("reach-top")}}}),vs={key:0,class:"tasks"},gs={class:"left"},ks={class:"main"},ys={key:1,class:"tasks"},ws={key:2,class:"w-full h-full flex items-center justify-center"},bs={class:"flex-1 flex flex-col"},Cs={class:"h-20"};function Ss(e,t,i,o,r,d){const u=c("el-skeleton-item"),p=c("el-skeleton"),f=c("task-preview"),n=c("no-tasks"),m=c("player");return a(),_(z,null,[l("div",{ref:"panel",class:"panel recent",onScroll:t[0]||(t[0]=(...k)=>e.onHandleScroll&&e.onHandleScroll(...k))},[e.tasks?.items===void 0?(a(),_("div",vs,[(a(),_(z,null,N(3,k=>l("div",{key:k,class:"task placeholder"},[l("div",gs,[s(p,{animated:""},{template:$(()=>[s(u,{variant:"image",class:"avatar"})]),_:1})]),l("div",ks,[s(p,{animated:""},{template:$(()=>[s(u,{variant:"p",class:"title"}),s(u,{variant:"text",style:{"margin-right":"16px"}}),s(u,{variant:"text",style:{width:"80%"}})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),_("div",ys,[(a(!0),_(z,null,N(e.tasks?.items,(k,h)=>(a(),w(f,{key:h,"model-value":k,class:"preview"},null,8,["model-value"]))),128))])):y("",!0),e.tasks?.items?.length===0?(a(),_("div",ws,[s(n)])):y("",!0)],544),Z(l("div",bs,[l("div",Cs,[s(m)])],512),[[Se,!!e.$store?.state?.suno?.audio?.object]])],64)}const Ls=A($s,[["render",Ss],["__scopeId","data-v-959f8920"]]),As=C({name:"TaskPreview",components:{ElScrollbar:Oe,IconPicture:Le,ElImage:X,ElAvatar:Ze,ElIcon:M},data(){return{showCloseIcon:!0}},computed:{audio(){return this.$store.state.suno?.audio}},methods:{closeCard(){this.showCloseIcon=!this.showCloseIcon}}}),Es={key:0,class:"card"},js={class:"image-container"},Vs={class:"image-slot"},Is={class:"title"},Ts={class:"content"},Ps={class:"artist"},Fs={class:"style"},Us={class:"time"},zs={class:"lyrics"},Gs={key:1,class:"gradient-background"};function Ms(e,t,i,o,r,d){const u=c("icon-picture"),p=c("el-icon"),f=c("el-image"),n=c("el-avatar"),m=c("el-scrollbar");return a(),w(m,{class:"right-panel"},{default:$(()=>[e.audio?.object?(a(),_("div",Es,[l("div",js,[s(f,{src:e.audio.image_url,fit:"cover"},{error:$(()=>[l("div",Vs,[s(p,null,{default:$(()=>[s(u)]),_:1})])]),_:1},8,["src"]),l("h2",Is,v(e.audio?.title),1)]),l("div",Ts,[l("div",Ps,[s(n,{size:30,src:e.audio?.image_url},null,8,["src"]),l("span",null,v(e.audio?.prompt),1)]),l("p",Fs,v(e.audio?.style),1),l("p",Us,v(e.$dayjs.format(e.audio?.created_at)),1),l("div",zs,[l("p",null,v(e.audio?.lyric),1)])])])):(a(),_("div",Gs))]),_:1})}const Rs=A(As,[["render",Ms],["__scopeId","data-v-9b29e9f9"]]),Ds="https://webhook.acedata.cloud/suno",Os=C({name:"SunoIndex",components:{Layout:et,ConfigPanel:go,RecentPanel:Ls,PreviewPanel:Rs},data(){return{task:void 0,job:0,timer:void 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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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(){Ae.create({application:this.application}).then(({data:e})=>{this.application=e,E.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ee&&E.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:Ds},t=this.credential?.token;if(!t){console.error("no token specified");return}E.info(this.$t("suno.message.startingTask")),Q.audio(e,{token:t}).then(()=>{E.success(this.$t("suno.message.startTaskSuccess"))}).catch(i=>{E.error(i?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function Bs(e,t,i,o,r,d){const u=c("config-panel"),p=c("recent-panel"),f=c("preview-panel"),n=c("layout");return a(),w(n,null,{config:$(()=>[s(u,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:$(()=>[s(p,{class:"panel recent",onReachTop:e.onReachTop},null,8,["onReachTop"])]),preview:$(()=>[s(f)]),_:1})}const Cn=A(Os,[["render",Bs],["__scopeId","data-v-69332928"]]);export{Cn as default};
@@ -1 +1 @@
1
- import{F as E}from"./index.es-ybdv8tNh.js";import{E as C}from"./index-apGSFDpN.js";import{E as D}from"./index-Btm_EBDa.js";import{d as h,h as $,b as i,t as a,k as t,r as T,j as _,l as n,o as r,ep as U,x as l,F as w,v as I,i as y,eq as P,D as f,y as k,n as S,er as F,dl as R,dh as j}from"./index-oUdhbQ0k.js";import{E as L,a as M}from"./index-BTFJb86a.js";import{I as G}from"./InfoIcon-9Wan39hE.js";import{E as q,a as B}from"./index-BQTBPAa8.js";import{E as O}from"./index-_HE2vSD7.js";import{C as N}from"./CopyToClipboard-CdHjrONV.js";import{I as z}from"./ImageWrapper-BOvl3-ww.js";import{E as H}from"./index-M0OikGrA.js";import{E as X}from"./index-kKC0Ivrh.js";import{B as K}from"./BotPlaceholder-BC0knnbs.js";import{N as W}from"./NoTasks-DN70KO5R.js";import{E as x}from"./index-D5IVFX4z.js";import"./use-form-item-DHA73KI5.js";import"./index-r5W6hzzQ.js";import"./index-BbIXTRxd.js";import"./index-BS8OlUCn.js";import"./typescript-BDQrJx_d.js";import"./index-DjX0Bpo4.js";import"./strings-C9YRIwNe.js";import"./castArray-pyQty71k.js";import"./isEqual-BVGhOXu9.js";import"./_Uint8Array-fEFMYpOd.js";import"./debounce-CgXMcR6c.js";import"./_baseIteratee-HPhqSc1g.js";import"./index-T8sKVr0g.js";import"./index-UcV0p3Hx.js";import"./index-pkU4FPE0.js";const J=h({name:"LayoutFlux",components:{ElDrawer:D,ElButton:C,FontAwesomeIcon:E},data(){return{drawer:!1}}}),Q={class:"main"},Y={class:"config"},Z={class:"result"};function ee(e,o,m,c,g,v){const d=n("font-awesome-icon"),p=n("el-button"),s=n("el-drawer");return r(),i("div",Q,[a("div",Y,[T(e.$slots,"config",{},void 0,!0)]),a("div",Z,[T(e.$slots,"result",{},void 0,!0)]),t(p,{round:"",class:"menu",onClick:o[0]||(o[0]=u=>e.drawer=!0)},{default:_(()=>[t(d,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=u=>e.drawer=u),"with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const te=$(J,[["render",ee],["__scopeId","data-v-76342769"]]),oe=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=U)}}),se={class:"field"},ne={class:"title font-bold"};function ae(e,o,m,c,g,v){const d=n("el-option"),p=n("el-select");return r(),i("div",se,[a("h2",ne,l(e.$t("flux.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:_(()=>[(r(!0),i(w,null,I(e.options,s=>(r(),y(d,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const le=$(oe,[["render",ae],["__scopeId","data-v-2e94cca6"]]),re=h({name:"CountSelector",components:{ElSlider:B,InfoIcon:G,ElInputNumber:q},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=P)}}),ie={class:"flex justify-between"},ce={class:"flex justify-start items-center"},ue={class:"text-sm font-bold"},de={class:"flex justify-end items-center"},pe={class:"w-full"};function me(e,o,m,c,g,v){const d=n("info-icon"),p=n("el-input-number"),s=n("el-slider");return r(),i("div",null,[a("div",ie,[a("div",ce,[a("span",ue,l(e.$t("flux.name.numbers")),1),t(d,{content:e.$t("flux.description.numbers")},null,8,["content"])]),a("div",de,[t(p,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),"controls-position":"right"},null,8,["modelValue"])])]),a("div",pe,[t(s,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=u=>e.value=u),min:1,max:4,step:1},null,8,["modelValue"])])])}const fe=$(re,[["render",me]]),_e="",he=h({name:"PromptInput",components:{ElInput:O,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)}}),$e={class:"field"},ge={class:"box"},ve={class:"title font-bold"};function be(e,o,m,c,g,v){const d=n("info-icon"),p=n("el-input");return r(),i("div",$e,[a("div",ge,[a("h2",ve,l(e.$t("flux.name.prompt")),1),t(d,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ke=$(he,[["render",be],["__scopeId","data-v-4c101a17"]]),xe=h({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:E,PromptInput:ke,ModelSelector:le,CountSelector:fe},emits:["generate"],computed:{config(){return this.$store.state.flux?.config}},methods:{onGenerate(){this.$emit("generate")}}}),we={class:"panel"},ye={class:"config"},Ve={class:"actions"};function Te(e,o,m,c,g,v){const d=n("prompt-input"),p=n("model-selector"),s=n("count-selector"),u=n("font-awesome-icon"),b=n("el-button");return r(),i("div",we,[a("div",ye,[t(d,{class:"mb-4"}),t(p,{class:"mb-4"}),t(s,{class:"mb-4"}),a("div",Ve,[t(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[t(u,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ee=$(xe,[["render",Te],["__scopeId","data-v-534faaf3"]]),Ie=h({name:"TaskPreview",components:{ElImage:X,CopyToClipboard:N,FontAwesomeIcon:E,ElAlert:H,ImageWrapper:z},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(m=>{let c=m;o&&(c.action=o),e.push(c)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Se={class:"preview"},Ce={class:"left"},Ge={class:"main"},Ae={class:"bot"},De={class:"datetime"},Ue={class:"info"},Pe={key:0,class:"prompt mt-2"},Fe={key:0},Re={key:0,class:S({content:!0,failed:!0})},je={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Le={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Me={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},qe={key:1,class:S({content:!0})},Be={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Oe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ne={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ze={key:2,class:S({content:!0})},He={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Xe(e,o,m,c,g,v){const d=n("el-image"),p=n("image-wrapper"),s=n("font-awesome-icon"),u=n("copy-to-clipboard"),b=n("el-alert");return r(),i("div",Se,[a("div",Ce,[t(d,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),a("div",Ge,[a("div",Ae,[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",Ue,[e.modelValue?.request?.prompt?(r(),i("p",Pe,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?k("",!0):(r(),i("span",Fe," - ("+l(e.$t("flux.status.pending"))+") ",1))])):k("",!0)]),e.modelValue?.response?.success===!0?(r(),i("div",Re,[a("div",je,[(r(!0),i(w,null,I(e.images,(V,A)=>(r(),y(p,{key:A,src:V?.image_url,"raw-src":V?.image_url,"model-value":V},null,8,["src","raw-src","model-value"]))),128))]),t(b,{closable:!1,class:"mt-2 success"},{default:_(()=>[a("p",Le,[t(s,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.model"))+": "+l(e.modelValue?.request?.model),1)]),a("p",Me,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?.success===!1?(r(),i("div",qe,[t(b,{closable:!1,class:"failure"},{template:_(()=>[t(s,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",Be,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),a("p",Oe,[t(s,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("flux.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(u,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),a("p",Ne,[t(s,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?k("",!0):(r(),i("div",ze,[t(b,{closable:!1,class:"info"},{template:_(()=>[t(s,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",He,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Ke=$(Ie,[["render",Xe],["__scopeId","data-v-fd5838a5"]]),We=h({name:"RecentPanel",components:{TaskPreview:Ke,BotPlaceholder:K,NoTasks:W},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")}}}),Je={key:0},Qe={key:1,class:"tasks h-full w-full overflow-y-auto"},Ye={key:2,class:"w-full h-full flex items-center justify-center"};function Ze(e,o,m,c,g,v){const d=n("bot-placeholder"),p=n("task-preview"),s=n("no-tasks");return r(),i(w,null,[e.tasks?.items===void 0?(r(),i("div",Je,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),i("div",Qe,[(r(!0),i(w,null,I(e.tasks?.items,(u,b)=>(r(),y(p,{key:b,"model-value":u},null,8,["model-value"]))),128))])):k("",!0),e.tasks?.items?.length===0?(r(),i("div",Ye,[t(s)])):k("",!0)],64)}const et=$(We,[["render",Ze]]),tt="https://webhook.acedata.cloud/flux",ot=h({name:"FluxIndex",components:{ConfigPanel:Ee,Layout:te,RecentPanel:et},data(){return{task:void 0,job:0,timer:void 0}},computed:{loading(){return this.$store.state.flux?.status?.getApplications===j.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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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:m,createdAtMax:c}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",c),await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:m,createdAtMax:c})},async onGenerate(){const e={...this.config,callback_url:tt},o=this.credential?.token;if(!o){console.error("no token specified");return}x.info(this.$t("flux.message.startingTask")),F.generate(e,{token:o}).then(()=>{x.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const c=m?.response?.data;c?.error?.code===R?x.error(this.$t("flux.message.usedUp")):x.error(this.$t("flux.message.startTaskFailed")+c?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function st(e,o,m,c,g,v){const d=n("config-panel"),p=n("recent-panel"),s=n("layout");return r(),y(s,null,{config:_(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[t(p,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Ut=$(ot,[["render",st]]);export{Ut as default};
1
+ import{F as E}from"./index.es-DaeHBJIN.js";import{E as C}from"./index-EFW5HXXl.js";import{E as D}from"./index-D8KZMM1b.js";import{d as h,h as $,b as i,t as a,k as t,r as T,j as _,l as n,o as r,ev as U,x as l,F as w,v as I,i as y,ew as P,D as f,y as k,n as S,ex as j,dn as F,dj as R}from"./index-Cbr5I2Y9.js";import{E as L,a as M}from"./index-Bzx9vpDl.js";import{I as G}from"./InfoIcon-C_-GVrFj.js";import{E as B,a as O}from"./index-HscBp0fS.js";import{E as q}from"./index-Tlw0DGaS.js";import{C as N}from"./CopyToClipboard-B_zjEArC.js";import{I as z}from"./ImageWrapper-IsRbsLXL.js";import{E as H}from"./index-MUigFyNQ.js";import{E as X}from"./index-BWD3Nss6.js";import{B as K}from"./BotPlaceholder-DwgRH20-.js";import{N as W}from"./NoTasks-Cc2t-KhB.js";import{E as x}from"./index-BeZMFg4Z.js";import"./use-form-item-DBbvHFR2.js";import"./index-r5W6hzzQ.js";import"./index-BeBmiTmh.js";import"./index-DFk1FoEG.js";import"./typescript-BMcXT3c_.js";import"./index-BO9akAqw.js";import"./strings-CzjyDUaH.js";import"./castArray-CjJRTN8w.js";import"./isEqual-By-euu_c.js";import"./_Uint8Array-C21Rl0N8.js";import"./debounce-DPEiv4qa.js";import"./_baseIteratee-JKg-PLGw.js";import"./index-Dcs3jWJX.js";import"./index-BXaZ87x3.js";import"./index-BCDVF19o.js";const J=h({name:"LayoutFlux",components:{ElDrawer:D,ElButton:C,FontAwesomeIcon:E},data(){return{drawer:!1}}}),Q={class:"main"},Y={class:"config"},Z={class:"result"};function ee(e,o,p,c,g,v){const d=n("font-awesome-icon"),m=n("el-button"),s=n("el-drawer");return r(),i("div",Q,[a("div",Y,[T(e.$slots,"config",{},void 0,!0)]),a("div",Z,[T(e.$slots,"result",{},void 0,!0)]),t(m,{round:"",class:"menu",onClick:o[0]||(o[0]=u=>e.drawer=!0)},{default:_(()=>[t(d,{icon:"fa-solid fa-gear",class:"icon-menu"})]),_:1}),t(s,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=u=>e.drawer=u),"with-header":!1,size:"340px",class:"drawer"},{default:_(()=>[T(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const te=$(J,[["render",ee],["__scopeId","data-v-76342769"]]),oe=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=U)}}),se={class:"field"},ne={class:"title font-bold"};function ae(e,o,p,c,g,v){const d=n("el-option"),m=n("el-select");return r(),i("div",se,[a("h2",ne,l(e.$t("flux.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=s=>e.value=s),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:_(()=>[(r(!0),i(w,null,I(e.options,s=>(r(),y(d,{key:s.value,label:s.label,value:s.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const le=$(oe,[["render",ae],["__scopeId","data-v-2e94cca6"]]),re=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=P)}}),ie={class:"flex justify-between"},ce={class:"flex justify-start items-center"},ue={class:"text-sm font-bold"},de={class:"flex justify-end items-center"},me={class:"w-full"};function pe(e,o,p,c,g,v){const d=n("info-icon"),m=n("el-input-number"),s=n("el-slider");return r(),i("div",null,[a("div",ie,[a("div",ce,[a("span",ue,l(e.$t("flux.name.numbers")),1),t(d,{content:e.$t("flux.description.numbers")},null,8,["content"])]),a("div",de,[t(m,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=u=>e.value=u),"controls-position":"right"},null,8,["modelValue"])])]),a("div",me,[t(s,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=u=>e.value=u),min:1,max:4,step:1},null,8,["modelValue"])])])}const fe=$(re,[["render",pe]]),_e="",he=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)}}),$e={class:"field"},ge={class:"box"},ve={class:"title font-bold"};function be(e,o,p,c,g,v){const d=n("info-icon"),m=n("el-input");return r(),i("div",$e,[a("div",ge,[a("h2",ve,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]=s=>e.prompt=s),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ke=$(he,[["render",be],["__scopeId","data-v-4c101a17"]]),xe=h({name:"PresetPanel",components:{ElButton:C,FontAwesomeIcon:E,PromptInput:ke,ModelSelector:le,CountSelector:fe},emits:["generate"],computed:{config(){return this.$store.state.flux?.config}},methods:{onGenerate(){this.$emit("generate")}}}),we={class:"panel"},ye={class:"config"},Ve={class:"actions"};function Te(e,o,p,c,g,v){const d=n("prompt-input"),m=n("model-selector"),s=n("count-selector"),u=n("font-awesome-icon"),b=n("el-button");return r(),i("div",we,[a("div",ye,[t(d,{class:"mb-4"}),t(m,{class:"mb-4"}),t(s,{class:"mb-4"}),a("div",Ve,[t(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:_(()=>[t(u,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+l(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])])}const Ee=$(xe,[["render",Te],["__scopeId","data-v-534faaf3"]]),Ie=h({name:"TaskPreview",components:{ElImage:X,CopyToClipboard:N,FontAwesomeIcon:E,ElAlert:H,ImageWrapper:z},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 c=p;o&&(c.action=o),e.push(c)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Se={class:"preview"},Ce={class:"left"},Ge={class:"main"},Ae={class:"bot"},De={class:"datetime"},Ue={class:"info"},Pe={key:0,class:"prompt mt-2"},je={key:0},Fe={key:0,class:S({content:!0,failed:!0})},Re={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},Le={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Me={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Be={key:1,class:S({content:!0})},Oe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ne={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},ze={key:2,class:S({content:!0})},He={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Xe(e,o,p,c,g,v){const d=n("el-image"),m=n("image-wrapper"),s=n("font-awesome-icon"),u=n("copy-to-clipboard"),b=n("el-alert");return r(),i("div",Se,[a("div",Ce,[t(d,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),a("div",Ge,[a("div",Ae,[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",Ue,[e.modelValue?.request?.prompt?(r(),i("p",Pe,[f(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?k("",!0):(r(),i("span",je," - ("+l(e.$t("flux.status.pending"))+") ",1))])):k("",!0)]),e.modelValue?.response?.success===!0?(r(),i("div",Fe,[a("div",Re,[(r(!0),i(w,null,I(e.images,(V,A)=>(r(),y(m,{key:A,src:V?.image_url,"raw-src":V?.image_url,"model-value":V},null,8,["src","raw-src","model-value"]))),128))]),t(b,{closable:!1,class:"mt-2 success"},{default:_(()=>[a("p",Le,[t(s,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.model"))+": "+l(e.modelValue?.request?.model),1)]),a("p",Me,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?.success===!1?(r(),i("div",Be,[t(b,{closable:!1,class:"failure"},{template:_(()=>[t(s,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",Oe,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),a("p",qe,[t(s,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+l(e.$t("flux.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(u,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),a("p",Ne,[t(s,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+l(e.$t("flux.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(u,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?k("",!0):(r(),i("div",ze,[t(b,{closable:!1,class:"info"},{template:_(()=>[t(s,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+l(e.$t("flux.name.failure")),1)]),default:_(()=>[a("p",He,[t(s,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+l(e.$t("flux.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(u,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const Ke=$(Ie,[["render",Xe],["__scopeId","data-v-fd5838a5"]]),We=h({name:"RecentPanel",components:{TaskPreview:Ke,BotPlaceholder:K,NoTasks:W},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")}}}),Je={key:0},Qe={key:1,class:"tasks h-full w-full overflow-y-auto"},Ye={key:2,class:"w-full h-full flex items-center justify-center"};function Ze(e,o,p,c,g,v){const d=n("bot-placeholder"),m=n("task-preview"),s=n("no-tasks");return r(),i(w,null,[e.tasks?.items===void 0?(r(),i("div",Je,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(r(),i("div",Qe,[(r(!0),i(w,null,I(e.tasks?.items,(u,b)=>(r(),y(m,{key:b,"model-value":u},null,8,["model-value"]))),128))])):k("",!0),e.tasks?.items?.length===0?(r(),i("div",Ye,[t(s)])):k("",!0)],64)}const et=$(We,[["render",Ze]]),tt="https://webhook.acedata.cloud/flux",ot=h({name:"FluxIndex",components:{ConfigPanel:Ee,Layout:te,RecentPanel:et},data(){return{task:void 0,job:0,timer:void 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}},async mounted(){await this.onGetService(),await this.onGetApplication(),await this.onScrollDown(),await this.onGetTasks(),await this.onScrollDown(),this.job=setInterval(()=>{this.onGetTasks()},5e3)},async unmounted(){clearInterval(this.job),clearInterval(this.timer)},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:c}=e||{};console.debug("limit",o,"createdAtMin",p,"createdAtMax",c),await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:p,createdAtMax:c})},async onGenerate(){const e={...this.config,callback_url:tt},o=this.credential?.token;if(!o){console.error("no token specified");return}x.info(this.$t("flux.message.startingTask")),j.generate(e,{token:o}).then(()=>{x.success(this.$t("flux.message.startTaskSuccess"))}).catch(p=>{const c=p?.response?.data;c?.error?.code===F?x.error(this.$t("flux.message.usedUp")):x.error(this.$t("flux.message.startTaskFailed")+c?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})}}});function st(e,o,p,c,g,v){const d=n("config-panel"),m=n("recent-panel"),s=n("layout");return r(),y(s,null,{config:_(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:_(()=>[t(m,{onReachTop:e.onReachTop},null,8,["onReachTop"])]),_:1})}const Ut=$(ot,[["render",st]]);export{Ut as default};