@acedatacloud/nexior 3.25.4 → 3.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (214) hide show
  1. package/dist/assets/Auth-C4N-kn3P.js +1 -0
  2. package/dist/assets/BotPlaceholder-BU17vEUy.js +1 -0
  3. package/dist/assets/Callback-CgCHMBvT.js +1 -0
  4. package/dist/assets/Console-BuuIvyQI.js +1 -0
  5. package/dist/assets/Conversation-Bd-g7wEx.js +2 -0
  6. package/dist/assets/Conversation-C5ZhOzsL.css +1 -0
  7. package/dist/assets/CopyToClipboard-Ab4hHs26.js +1 -0
  8. package/dist/assets/Detail-B0bGFPcr.js +2 -0
  9. package/dist/assets/Detail-BnMRXf6b.css +1 -0
  10. package/dist/assets/EditArray-BO1VlAtC.js +1 -0
  11. package/dist/assets/Extra-D3ij_ylf.js +1 -0
  12. package/dist/assets/FilePreview-DzYn5dam.js +1 -0
  13. package/dist/assets/History-A_7LOfGN.js +1 -0
  14. package/dist/assets/ImagePreview-hdi2mrdI.js +1 -0
  15. package/dist/assets/ImageWrapper-D9v7ltO5.js +1 -0
  16. package/dist/assets/Index--9DaVBY2.js +1 -0
  17. package/dist/assets/{Index-CJKfZTnK.css → Index-5_OZamQc.css} +1 -1
  18. package/dist/assets/Index-B4Oy-w03.js +1 -0
  19. package/dist/assets/Index-BQLNTE0F.js +1 -0
  20. package/dist/assets/Index-BggomWsw.js +1 -0
  21. package/dist/assets/Index-C1jYhkOD.js +1 -0
  22. package/dist/assets/Index-CEaJNUQF.js +1 -0
  23. package/dist/assets/Index-CFq2w4hh.js +1 -0
  24. package/dist/assets/Index-CJv4wGmX.js +1 -0
  25. package/dist/assets/{Index-D4pjoJx8.css → Index-CZ-Jgww0.css} +1 -1
  26. package/dist/assets/Index-Co3cnanu.js +1 -0
  27. package/dist/assets/Index-CucfTPS_.js +1 -0
  28. package/dist/assets/Index-DDch_lJc.js +1 -0
  29. package/dist/assets/Index-DKlMjuCB.js +1 -0
  30. package/dist/assets/Index-ZsIbmaS2.js +1 -0
  31. package/dist/assets/Index-qjyre1DA.js +1 -0
  32. package/dist/assets/{Index-B_mI8Xgk.css → Index-taSUffzl.css} +1 -1
  33. package/dist/assets/Index-y1E2fHPZ.js +1 -0
  34. package/dist/assets/Index-ym69MOSH.js +1 -0
  35. package/dist/assets/{Index-Cftqfxia.css → Index-zcIEejFp.css} +1 -1
  36. package/dist/assets/Invitees-X4GRTkxt.js +1 -0
  37. package/dist/assets/List-CBmU0M9l.js +1 -0
  38. package/dist/assets/List-CmRxS8VC.js +1 -0
  39. package/dist/assets/List-DMjesxby.js +1 -0
  40. package/dist/assets/Login-D-D_IgfX.js +1 -0
  41. package/dist/assets/Main-DFmVXhIL.js +1 -0
  42. package/dist/assets/Navigator-BfaRng3e.js +1 -0
  43. package/dist/assets/NoTasks-CgXSnfeV.js +1 -0
  44. package/dist/assets/Pagination-CtENlxBI.js +1 -0
  45. package/dist/assets/ScrollList-hBjgRYV4.js +1 -0
  46. package/dist/assets/Status-e-4FVvMB.js +1 -0
  47. package/dist/assets/Subscribe-P6oarsUJ.js +1 -0
  48. package/dist/assets/VideoPlayer-CsVaulnP.js +1 -0
  49. package/dist/assets/coin-BEmGht_E.js +1 -0
  50. package/dist/assets/coin-BTZicwhr.js +1 -0
  51. package/dist/assets/coin-BY1f2AGt.js +1 -0
  52. package/dist/assets/coin-BfOIeDbl.js +1 -0
  53. package/dist/assets/coin-BpqbFO16.js +1 -0
  54. package/dist/assets/coin-BsuV_YeV.js +1 -0
  55. package/dist/assets/coin-C0soSeyR.js +1 -0
  56. package/dist/assets/coin-C1vThE7K.js +1 -0
  57. package/dist/assets/coin-CIHIAMWv.js +1 -0
  58. package/dist/assets/coin-COhdbXyd.js +1 -0
  59. package/dist/assets/coin-Cbnm3Xy-.js +1 -0
  60. package/dist/assets/coin-CuoluQSV.js +1 -0
  61. package/dist/assets/coin-DCvKQ0Nc.js +1 -0
  62. package/dist/assets/coin-DESNZPRB.js +1 -0
  63. package/dist/assets/coin-F--7ubaN.js +1 -0
  64. package/dist/assets/coin-KEXVQu7Q.js +1 -0
  65. package/dist/assets/coin-ashRjWk0.js +1 -0
  66. package/dist/assets/coin-jcPx8ZMO.js +1 -0
  67. package/dist/assets/distribution-ahsMBsrL.js +1 -0
  68. package/dist/assets/index-BWdK6S1P.js +3 -0
  69. package/dist/assets/{index-vxVcmqZU.css → index-C42HKz1r.css} +1 -1
  70. package/dist/assets/{order-CbJUSC9X.js → order-5Q2NSU5A.js} +1 -1
  71. package/dist/assets/{order-BZ9Kv2I4.js → order-7sVfWX_m.js} +1 -1
  72. package/dist/assets/{order-f9zHR1lP.js → order-BspD8oHa.js} +1 -1
  73. package/dist/assets/order-Bu5wjTFd.js +1 -0
  74. package/dist/assets/{order-w6LXAmWz.js → order-CGebGmiZ.js} +1 -1
  75. package/dist/assets/{order-BB0J3GjT.js → order-Cg6Z4GIW.js} +1 -1
  76. package/dist/assets/{order-fBbym4d_.js → order-ChIfVdAa.js} +1 -1
  77. package/dist/assets/{order-CmcDCACm.js → order-CmN2xY-p.js} +1 -1
  78. package/dist/assets/{order-5epTOXB5.js → order-D1keYPzu.js} +1 -1
  79. package/dist/assets/{order-BhyGrCgu.js → order-DAOBmqsZ.js} +1 -1
  80. package/dist/assets/{order-DPsGB23O.js → order-DF-Nyswd.js} +1 -1
  81. package/dist/assets/{order-Ba5GCJgH.js → order-DNG0G59-.js} +1 -1
  82. package/dist/assets/{order-KcPEkF3d.js → order-DVTAHRL7.js} +1 -1
  83. package/dist/assets/{order-B7fZHiqs.js → order-DlAFUU9_.js} +1 -1
  84. package/dist/assets/{order-xSqKjqCY.js → order-DszuiA3J.js} +1 -1
  85. package/dist/assets/{order-sfgs-7Mz.js → order-P2ML4NX3.js} +1 -1
  86. package/dist/assets/{order-C4grkTjp.js → order-eMd8F_I4.js} +1 -1
  87. package/dist/assets/{order-BChEw5_v.js → order-ip3zUjH0.js} +1 -1
  88. package/dist/assets/{order-C3KncIF6.js → order-lRxQRPUo.js} +1 -1
  89. package/dist/assets/pagination-dbPQoMuV.js +1 -0
  90. package/dist/assets/price-DsQ2XKBW.js +1 -0
  91. package/dist/assets/vendor-BG5lCpoe.js +5564 -0
  92. package/dist/assets/vendor-Cp-P0JlL.css +1 -0
  93. package/dist/assets/vendor-axios-NIGUFBhG.js +6 -0
  94. package/dist/assets/vendor-chart-DlegxWjs.js +13 -0
  95. package/dist/assets/vendor-dayjs-BRrJyY8K.js +1 -0
  96. package/dist/assets/vendor-element-plus-7rF3khck.js +6 -0
  97. package/dist/assets/vendor-highlight-t6bI8mSi.css +1 -0
  98. package/dist/assets/vendor-highlight-xfJzRjy2.js +5 -0
  99. package/dist/assets/vendor-katex-CIur2ABi.css +1 -0
  100. package/dist/assets/vendor-katex-DHBGsivc.js +261 -0
  101. package/dist/assets/vendor-vue-Bb02XvLT.js +17 -0
  102. package/dist/assets/vendor-vue-router-D4avMJL1.js +5 -0
  103. package/dist/index.html +11 -2
  104. package/package.json +7 -1
  105. package/dist/assets/Auth-BHNFFaW0.js +0 -1
  106. package/dist/assets/BotPlaceholder-X527oxpB.js +0 -1
  107. package/dist/assets/Callback-BwvM2Leh.js +0 -1
  108. package/dist/assets/Console-Co0hX4yW.js +0 -1
  109. package/dist/assets/Conversation-B-OZlC82.css +0 -1
  110. package/dist/assets/Conversation-QA7hKXys.js +0 -283
  111. package/dist/assets/CopyToClipboard-CIkwptVu.js +0 -1
  112. package/dist/assets/Detail-B6zGS7Ui.css +0 -1
  113. package/dist/assets/Detail-DschNOpf.js +0 -1
  114. package/dist/assets/EditArray-D6OZGcO-.js +0 -1
  115. package/dist/assets/Extra-5Iq9o04S.js +0 -1
  116. package/dist/assets/FilePreview-NHNFD0Lq.js +0 -1
  117. package/dist/assets/History-pwiuyUOc.js +0 -1
  118. package/dist/assets/ImagePreview-dRRztBTN.js +0 -1
  119. package/dist/assets/ImageWrapper-BOEqMoAZ.js +0 -1
  120. package/dist/assets/Index-8AhOD6eW.js +0 -1
  121. package/dist/assets/Index-BgIeGjY2.js +0 -1
  122. package/dist/assets/Index-BwZBZoCO.js +0 -1
  123. package/dist/assets/Index-C4OpOA5V.js +0 -1
  124. package/dist/assets/Index-CFtAbBiB.js +0 -1
  125. package/dist/assets/Index-COlN-eC-.js +0 -1
  126. package/dist/assets/Index-CmRfVRCL.js +0 -1
  127. package/dist/assets/Index-DEX8v4L9.js +0 -1
  128. package/dist/assets/Index-DLovrzIx.js +0 -1
  129. package/dist/assets/Index-DOT63mlR.js +0 -1
  130. package/dist/assets/Index-DeDHuYXP.js +0 -1
  131. package/dist/assets/Index-Dhb0KcdB.js +0 -1
  132. package/dist/assets/Index-PXHiibWZ.js +0 -1
  133. package/dist/assets/Index-VnMSXV_o.js +0 -1
  134. package/dist/assets/Index-_ElaLMG0.js +0 -1
  135. package/dist/assets/Index-fpQ_5d8o.js +0 -1
  136. package/dist/assets/Invitees-BMRcxvWX.js +0 -1
  137. package/dist/assets/List-B0dEnow9.js +0 -18
  138. package/dist/assets/List-DV0E4VwB.js +0 -1
  139. package/dist/assets/List-GKL_gIHW.js +0 -1
  140. package/dist/assets/Login-CipyYI2X.js +0 -1
  141. package/dist/assets/Main-Cdl_IZ7q.js +0 -1
  142. package/dist/assets/Navigator-BW4Fq1YT.js +0 -1
  143. package/dist/assets/NoTasks-CTLWrX9X.js +0 -1
  144. package/dist/assets/Pagination-CEhDRM0w.js +0 -1
  145. package/dist/assets/ScrollList-DJyagTd9.js +0 -1
  146. package/dist/assets/Status-DdGv5F_f.js +0 -1
  147. package/dist/assets/Subscribe-CQzRmtqj.js +0 -1
  148. package/dist/assets/VideoPlayer-Cc0aqBXp.js +0 -1
  149. package/dist/assets/_baseClone-Ds-s3IuL.js +0 -1
  150. package/dist/assets/_baseIteratee-CPuZRdwJ.js +0 -1
  151. package/dist/assets/_initCloneObject-B9BC83jE.js +0 -1
  152. package/dist/assets/ar-D1hnTQ2h.js +0 -1
  153. package/dist/assets/castArray-DhOK83j4.js +0 -1
  154. package/dist/assets/de-BZu7ZZ9y.js +0 -1
  155. package/dist/assets/debounce-BUHPvvRx.js +0 -1
  156. package/dist/assets/distribution-OPhlJ0iO.js +0 -1
  157. package/dist/assets/dropdown-CaEtFY5K.js +0 -1
  158. package/dist/assets/el-DJ93mLwP.js +0 -1
  159. package/dist/assets/es-Idilhmtq.js +0 -1
  160. package/dist/assets/fi-BhhlDzr_.js +0 -1
  161. package/dist/assets/fr-fyTGkfid.js +0 -1
  162. package/dist/assets/index-1DvQjuZj.js +0 -1
  163. package/dist/assets/index-26q3vWe3.js +0 -12
  164. package/dist/assets/index-2amtGE73.js +0 -1
  165. package/dist/assets/index-4xbTEHb4.js +0 -1
  166. package/dist/assets/index-B3SbvjbA.js +0 -1
  167. package/dist/assets/index-BRW1meHI.js +0 -1
  168. package/dist/assets/index-BVPDEl6k.js +0 -1
  169. package/dist/assets/index-BaT0jRk-.js +0 -1
  170. package/dist/assets/index-Bd52b9MQ.js +0 -1
  171. package/dist/assets/index-BmMTzT1e.js +0 -1
  172. package/dist/assets/index-C7z3Qnen.js +0 -1
  173. package/dist/assets/index-CDNBMXQ3.js +0 -14
  174. package/dist/assets/index-CDNsPXeD.js +0 -1
  175. package/dist/assets/index-CNtJ-qZ0.js +0 -1
  176. package/dist/assets/index-CSXF3X1e.js +0 -1
  177. package/dist/assets/index-CTL_q_Ls.js +0 -1
  178. package/dist/assets/index-CW8-s5uS.js +0 -1
  179. package/dist/assets/index-CyrG-q_g.js +0 -1
  180. package/dist/assets/index-D4jtulwF.js +0 -1
  181. package/dist/assets/index-DGxwm39f.js +0 -1
  182. package/dist/assets/index-DKQ8F7GC.js +0 -1
  183. package/dist/assets/index-DND3fxYf.js +0 -10
  184. package/dist/assets/index-DVU3OOIj.js +0 -1
  185. package/dist/assets/index-DW12D-0Y.js +0 -6
  186. package/dist/assets/index-OA9O6lVC.js +0 -638
  187. package/dist/assets/index-fTsXD2fu.js +0 -1
  188. package/dist/assets/index-i6VHNkjA.js +0 -1
  189. package/dist/assets/index-jczR9H1q.js +0 -1
  190. package/dist/assets/index-oXM3BzcC.js +0 -1
  191. package/dist/assets/index-r5W6hzzQ.js +0 -1
  192. package/dist/assets/index-vNo-DKgh.js +0 -1
  193. package/dist/assets/index.es-D3TSGwa1.js +0 -1
  194. package/dist/assets/isEqual-vZWfltqX.js +0 -1
  195. package/dist/assets/isPlainObject-DkP5CYDL.js +0 -1
  196. package/dist/assets/it-CLf6lrMi.js +0 -1
  197. package/dist/assets/ja-DFyNu3tl.js +0 -1
  198. package/dist/assets/ko-DUrUYy0R.js +0 -1
  199. package/dist/assets/order-DnqhjHpP.js +0 -1
  200. package/dist/assets/pagination-Bwva12lc.js +0 -1
  201. package/dist/assets/pl-By8ttK5W.js +0 -1
  202. package/dist/assets/price-DX6_QWGs.js +0 -1
  203. package/dist/assets/pt-iBE8V_rF.js +0 -1
  204. package/dist/assets/ru-a9O4dLvt.js +0 -1
  205. package/dist/assets/sr-BuqPpavQ.js +0 -1
  206. package/dist/assets/strings-CE5wx3lU.js +0 -1
  207. package/dist/assets/sv-CiSSmJ4h.js +0 -1
  208. package/dist/assets/typescript-D5kqm2pC.js +0 -1
  209. package/dist/assets/uk-Ci2KIGcW.js +0 -1
  210. package/dist/assets/use-form-item-CLxXgCpM.js +0 -1
  211. package/dist/assets/vue-plyr-BqJN4-Iw.css +0 -1
  212. package/dist/assets/vue-plyr-QZFBikSk.js +0 -2
  213. package/dist/assets/zh-cn-CnyULPxw.js +0 -1
  214. package/dist/assets/zh-tw-ZQmLUxJy.js +0 -1
@@ -0,0 +1 @@
1
+ import{bF as L}from"./vendor-BG5lCpoe.js";import{o as D,N,J as C,K as R,q,r as T,p as W,n as Z,B as Y,i as H}from"./vendor-element-plus-7rF3khck.js";import{d as b,c as i,a as r,l as o,P as U,S as u,al as s,o as n,Z as l,F as V,ai as A,R as S,V as I,a2 as J,Y as h,W as $,U as K,_ as Q}from"./vendor-vue-Bb02XvLT.js";import{_ as k,bb as G,bc as z,bd as y,be as M,bf as X,bg as x,bh as ee,bi as te,S as oe,bj as se,bk as ae,a6 as ne,a3 as P}from"./index-BWdK6S1P.js";import{I as B,S as le}from"./ScrollList-hBjgRYV4.js";import{I as re}from"./ImagePreview-hdi2mrdI.js";import{C as ie,N as ce}from"./NoTasks-CgXSnfeV.js";import{a as de}from"./price-DsQ2XKBW.js";import{C as ue}from"./CopyToClipboard-Ab4hHs26.js";import{V as pe}from"./VideoPlayer-CsVaulnP.js";import{B as me}from"./BotPlaceholder-BU17vEUy.js";import{l as fe}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const _e=b({name:"LayoutSora",components:{ElDrawer:N,ElButton:D,FontAwesomeIcon:L},data(){return{drawer:!1}}}),he={class:"main flex flex-row flex-1"},$e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},ge={class:"result h-full p-[15px] flex-1 flex flex-col"};function ve(e,t,p,m,g,v){const c=s("font-awesome-icon"),d=s("el-button"),a=s("el-drawer");return n(),i("div",he,[r("div",$e,[U(e.$slots,"config",{},void 0,!0)]),r("div",ge,[U(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=w=>e.drawer=!0)},{default:u(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(a,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=w=>e.drawer=w),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const be=k(_e,[["render",ve],["__scopeId","data-v-966c9b2c"]]),ke=b({name:"ModelSelector",components:{ElSelect:R,ElOption:C},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:X,label:"sora-2"},{value:x,label:"sora-2-pro"}]}},computed:{value:{get(){return this.$store.state.sora?.config?.model},set(e){const t=this.$store.state.sora?.config||{},p=z[e]||[y],m=t.duration,g=m&&p.includes(m)?m:p.includes(y)?y:p[0],v={...t,model:e,duration:g,size:t.size||M};this.$store.commit("sora/setConfig",v)}}},mounted(){this.value||(this.value=G)}}),we={class:"field"},Se={class:"title font-bold"};function ye(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",we,[r("h2",Se,l(e.$t("sora.name.model")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=k(ke,[["render",ye],["__scopeId","data-v-3a7abba8"]]),Ee=b({name:"ActionSelector",components:{ElSelect:R,ElOption:C},data(){return{}},computed:{options(){return[{value:"text2video",label:this.$t("sora.button.action1")},{value:"image2video",label:this.$t("sora.button.action2")}]},value:{get(){return this.$store.state.sora?.config?.action},set(e){this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,action:e})}}},mounted(){this.value||(this.value=ee)}}),Te={class:"field"},Ie={class:"title font-bold"},Ae={class:"float-left"};function Le(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",Te,[r("h2",Ie,l(e.$t("sora.name.action")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select"),clearable:""},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},{default:u(()=>[r("span",Ae,l(a.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=k(Ee,[["render",Le],["__scopeId","data-v-7b82fa7f"]]),Ce=b({name:"DurationSelector",components:{ElSelect:R,ElOption:C},computed:{model(){return this.$store.state.sora?.config?.model||G},allowedDurations(){return z[this.model]||[y]},optionsForModel(){return this.allowedDurations.map(e=>({value:e,label:`${e}s`}))},value:{get(){return this.$store.state.sora?.config?.duration},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,duration:e})}}},watch:{allowedDurations(){const e=this.allowedDurations;if(!e.includes(this.value)){const t=e.includes(y)?y:e[0];this.value=t}}},mounted(){this.value||(this.value=y)}}),Re={class:"field"},Oe={class:"control"},Ue={class:"title font-bold"};function Pe(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",Re,[r("div",Oe,[r("h2",Ue,l(e.$t("sora.name.duration")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.optionsForModel,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const Ge=k(Ce,[["render",Pe],["__scopeId","data-v-c2934598"]]),ze=b({name:"OrientationSelector",data(){return{options:[{value:"portrait",label:"竖屏",width:13,height:25},{value:"landscape",label:"横屏",width:25,height:13}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.sora?.config?.orientation},set(e){console.debug("set orientation",e),this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,orientation:e})}}},mounted(){this.value||(this.value=te)}}),Me={class:"text-sm font-bold mb-2 block"},Be={class:"items"},je=["onClick"],Fe={class:"name"};function Ne(e,t,p,m,g,v){return n(),i("div",null,[r("span",Me,l(e.$t("sora.name.orientation")),1),r("div",Be,[(n(!0),i(V,null,A(e.options,(c,d)=>(n(),i("div",{key:d,class:I({active:e.active===d,item:!0}),onClick:a=>e.value=c.value},[r("div",{class:I(["preview",c.value])},[r("div",{class:"rect",style:J({width:c.width+"px",height:c.height+"px"})},null,4)],2),r("p",Fe,l(c.label),1)],10,je))),128))])])}const qe=k(ze,[["render",Ne],["__scopeId","data-v-d6940af8"]]),We=b({name:"StartEndImage",components:{ElUpload:q,ElButton:D,InfoIcon:B,FontAwesomeIcon:L,ImagePreview:re},emits:["change"],data(){return{fileList:[],uploadUrl:oe()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)},value:{get(){return this.$store.state?.sora?.config?.image_urls},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartEndImageUrl()},methods:{onExceed(){T.warning(this.$t("sora.message.uploadReferencesExceed"))},onError(){T.error(this.$t("sora.message.uploadReferencesError"))},onSetStartEndImageUrl(){const e=this.urls;this.$store.commit("sora/setConfig",{...this.$store.state?.sora?.config,image_urls:e})},async onSuccess(){this.onSetStartEndImageUrl()}}}),Ze={class:"relative"},Ye={class:"flex justify-between"},He={class:"flex justify-start items-center"},Je={class:"text-sm font-bold"};function Ke(e,t,p,m,g,v){const c=s("info-icon"),d=s("image-preview"),a=s("font-awesome-icon"),w=s("el-button"),_=s("el-upload");return n(),i("div",Ze,[r("div",Ye,[r("div",He,[r("span",Je,l(e.$t("sora.name.startEndImage")),1),o(c,{content:e.$t("sora.description.uploadStartEndImage")},null,8,["content"])])]),o(_,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=f=>e.fileList=f),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:2,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[f.url&&f.percentage!==void 0?(n(),S(d,{key:0,url:f.url,name:f.name,percentage:f.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])):$("",!0)]),default:u(()=>[o(w,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:u(()=>[o(a,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+l(e.$t("sora.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Qe=k(We,[["render",Ke],["__scopeId","data-v-fd6e5c97"]]),Xe=e=>e&&e.charAt(0).toUpperCase()+e.slice(1),xe=b({name:"SizeSelector",components:{ElSelect:R,ElOption:C},data(){return{options:se.map(e=>({value:e,label:Xe(e)}))}},computed:{value:{get(){return this.$store.state.sora?.config?.size},set(e){const t=this.$store.state.sora?.config||{};this.$store.commit("sora/setConfig",{...t,size:e})}}},mounted(){this.value||(this.value=M)}}),et={class:"field"},tt={class:"control"},ot={class:"title font-bold"};function st(e,t,p,m,g,v){const c=s("el-option"),d=s("el-select");return n(),i("div",et,[r("div",tt,[r("h2",ot,l(e.$t("sora.name.size")),1),o(d,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=a=>e.value=a),class:"value",placeholder:e.$t("sora.placeholder.select")},{default:u(()=>[(n(!0),i(V,null,A(e.options,a=>(n(),S(c,{key:a.value,label:a.label,value:a.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])])}const at=k(xe,[["render",st],["__scopeId","data-v-8c485f0f"]]),nt="",lt=b({name:"PromptInput",components:{ElInput:W,InfoIcon:B},computed:{prompt:{get(){return this.$store.state.sora?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("sora/setConfig",{...this.$store.state.sora?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=nt)}}),rt={class:"field"},it={class:"box"},ct={class:"title font-bold"};function dt(e,t,p,m,g,v){const c=s("info-icon"),d=s("el-input");return n(),i("div",rt,[r("div",it,[r("h2",ct,l(e.$t("sora.name.prompt")),1),o(c,{content:e.$t("sora.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=a=>e.prompt=a),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("sora.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ut=k(lt,[["render",dt],["__scopeId","data-v-cf3a1497"]]),pt=b({name:"ConfigPanel",components:{ElButton:D,Consumption:ie,FontAwesomeIcon:L,PromptInput:ut,ModelSelector:Ve,StartEndImage:Qe,SizeSelector:at,ActionSelector:De,OrientationSelector:qe,DurationSelector:Ge},emits:["generate"],computed:{config(){return this.$store.state.sora?.config},consumption(){return de(this.config,this.service?.cost)},service(){return this.$store.state.sora?.service}},methods:{onGenerate(){this.$emit("generate")}}}),mt={class:"flex flex-col h-full"},ft={class:"flex-1 overflow-y-auto p-[15px]"},_t={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function ht(e,t,p,m,g,v){const c=s("model-selector"),d=s("action-selector"),a=s("duration-selector"),w=s("size-selector"),_=s("orientation-selector"),f=s("prompt-input"),E=s("start-end-image"),O=s("consumption"),j=s("font-awesome-icon"),F=s("el-button");return n(),i("div",mt,[r("div",ft,[o(c,{class:"mb-4"}),o(d,{class:"mb-4"}),o(a,{class:"mb-4"}),o(w,{class:"mb-4"}),o(_,{class:"mb-4"}),o(f,{class:"mb-4"}),K(o(E,{class:"mb-2"},null,512),[[Q,e.config?.action==="image2video"]])]),r("div",_t,[o(O,{value:e.consumption,service:e.service},null,8,["value","service"]),o(F,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[o(j,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+l(e.$t("sora.button.generate")),1)]),_:1},8,["onClick"])])])}const $t=k(pt,[["render",ht]]),gt=b({name:"TaskPreview",components:{ElImage:H,CopyToClipboard:ue,FontAwesomeIcon:L,ElAlert:Y,VideoPlayer:pe,ElTooltip:Z,ElButton:D},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.sora?.application},config(){return this.$store.state.sora?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),vt={class:"preview"},bt={class:"left"},kt={class:"main"},wt={class:"bot"},St={class:"datetime"},yt={class:"info"},Vt={key:0,class:"prompt mt-2"},Et={key:0},Tt={key:1},It={key:0,class:I({content:!0,failed:!0})},At={key:0,class:"mb-4"},Lt={key:1,class:I({operations:!0,"mt-2":!0})},Dt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ct={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Rt={key:1,class:I({content:!0})},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Pt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Gt={key:2,class:I({content:!0})},zt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Mt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function Bt(e,t,p,m,g,v){const c=s("el-image"),d=s("video-player"),a=s("el-button"),w=s("el-tooltip"),_=s("font-awesome-icon"),f=s("copy-to-clipboard"),E=s("el-alert");return n(),i("div",vt,[r("div",bt,[o(c,{src:"https://cdn.acedata.cloud/z5id1u.png",class:"avatar"})]),r("div",kt,[r("div",wt,[h(l(e.$t("sora.name.soraBot"))+" ",1),r("span",St,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",yt,[e.modelValue?.request?.prompt?(n(),i("p",Vt,[h(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?$("",!0):(n(),i("span",Et," - ("+l(e.$t("sora.status.pending"))+") ",1)),Array.isArray(e.modelValue?.response?.data)&&e.modelValue?.response?.data[0]?.state==="pending"?(n(),i("span",Tt," - ("+l(e.$t("sora.status.processing"))+") ",1)):$("",!0)])):$("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(n(),i("div",It,[e.modelValue?.response?.data[0]?.video_url?(n(),i("div",At,[o(d,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):$("",!0),e.modelValue?.response.success?(n(),i("div",Lt,[o(w,{class:"box-item",effect:"dark",content:e.$t("sora.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.modelValue?.response?.data[0]?.video_url?(n(),S(a,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=O=>e.onDownload(O,e.modelValue?.response?.data[0]?.video_url))},{default:u(()=>[h(l(e.$t("sora.button.download")),1)]),_:1})):$("",!0)]),_:1},8,["content"])])):$("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:u(()=>[r("p",Dt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.model"))+": "+l(e.modelValue?.request?.model),1)]),r("p",Ct,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):$("",!0),e.modelValue?.response?.success===!1?(n(),i("div",Rt,[o(E,{closable:!1,class:"failure"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[r("p",Ot,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),r("p",Ut,[o(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+l(e.$t("sora.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),o(f,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",Pt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0),e.modelValue?.response?.success===void 0?(n(),i("div",Gt,[o(E,{closable:!1,class:"info"},{template:u(()=>[o(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+l(e.$t("sora.name.failure")),1)]),default:u(()=>[r("p",zt,[o(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+l(e.$t("sora.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),o(f,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",Mt,[o(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+l(e.$t("sora.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),o(f,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):$("",!0)]),_:1})])):$("",!0)])])}const jt=k(gt,[["render",Bt],["__scopeId","data-v-183a4d07"]]),Ft=b({name:"RecentPanel",components:{TaskPreview:jt,NoTasks:ce,BotPlaceholder:me,ScrollList:le},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.sora?.tasks,items:this.$store.state.sora?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Nt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Wt(e,t,p,m,g,v){const c=s("bot-placeholder"),d=s("task-preview"),a=s("scroll-list"),w=s("no-tasks");return n(),i(V,null,[e.tasks?.items===void 0?(n(),i("div",Nt,[o(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),S(a,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(n(!0),i(V,null,A(e.tasks?.items,(_,f)=>(n(),S(d,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):$("",!0),e.tasks?.items?.length===0?(n(),i("div",qt,[o(w)])):$("",!0)],64)}const Zt=k(Ft,[["render",Wt]]),Yt="https://webhook.acedata.cloud/sora",Ht=b({name:"SoraIndex",components:{ConfigPanel:$t,Layout:be,RecentPanel:Zt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.sora?.status?.getApplications===P.Request},tasksLoading(){return this.$store.state.sora?.status?.getTasks===P.Request||this.fetchingTasks},credential(){return this.$store.state.sora.credential},config(){return this.$store.state.sora.config},tasks(){return this.$store.state.sora.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await fe({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("sora/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("sora/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:p,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",p,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("sora/getTasks",{limit:t,createdAtMin:p,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Yt},t=this.credential?.token;if(!t){console.error("no token specified");return}T.info(this.$t("sora.message.startingTask")),ae.generate(e,{token:t}).then(()=>{T.success(this.$t("sora.message.startTaskSuccess"))}).catch(p=>{p?.response?.data?.error?.code===ne?T.error(this.$t("sora.message.usedUp")):T.error(this.$t("sora.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Jt(e,t,p,m,g,v){const c=s("config-panel"),d=s("recent-panel"),a=s("layout");return n(),S(a,null,{config:u(()=>[o(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[o(d,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const mo=k(Ht,[["render",Jt]]);export{mo as default};
@@ -0,0 +1 @@
1
+ import{bF as L}from"./vendor-BG5lCpoe.js";import{o as R,N as B,J as I,K as C,P as F,Q as O,q as N,r as x,p as z,n as X,B as Q,i as Y}from"./vendor-element-plus-7rF3khck.js";import{d as _,c as r,a as l,l as o,P as U,S as d,al as s,o as a,Z as c,F as V,ai as S,R as w,V as T,a2 as H,Y as k,W as y}from"./vendor-vue-Bb02XvLT.js";import{_ as h,bl as J,bm as K,bn as W,bo as Z,bp as ee,bq as te,S as se,br as oe,a6 as ne,a3 as D}from"./index-BWdK6S1P.js";import{I as A,S as ae}from"./ScrollList-hBjgRYV4.js";import{I as le}from"./ImagePreview-hdi2mrdI.js";import{C as ie,N as re}from"./NoTasks-CgXSnfeV.js";import{a as ce}from"./price-DsQ2XKBW.js";import{C as pe}from"./CopyToClipboard-Ab4hHs26.js";import{V as de}from"./VideoPlayer-CsVaulnP.js";import{B as ue}from"./BotPlaceholder-BU17vEUy.js";import{l as me}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const ve=_({name:"LayoutPixverse",components:{ElDrawer:B,ElButton:R,FontAwesomeIcon:L},data(){return{drawer:!1}}}),fe={class:"main flex flex-row flex-1"},_e={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},he={class:"result h-full p-[15px] flex-1 flex flex-col"};function $e(e,t,u,m,$,g){const i=s("font-awesome-icon"),p=s("el-button"),n=s("el-drawer");return a(),r("div",fe,[l("div",_e,[U(e.$slots,"config",{},void 0,!0)]),l("div",he,[U(e.$slots,"result",{},void 0,!0)]),o(p,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:d(()=>[o(i,{icon:"fa-solid fa-magic"})]),_:1}),o(n,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"350px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ge=h(ve,[["render",$e],["__scopeId","data-v-0646853d"]]),be=_({name:"ModelSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"v3.5",label:"v3.5"},{value:"v4",label:"v4"},{value:"v4.5",label:"v4.5"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.model},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,model:e})}}},mounted(){this.value||(this.value=J)}}),ye={class:"field"},ke={class:"title font-bold"};function we(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",ye,[l("h2",ke,c(e.$t("pixverse.name.model")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ve=h(be,[["render",we],["__scopeId","data-v-e8f337ca"]]),Se=_({name:"QualitySelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"360p",label:"360p"},{value:"540p",label:"540p"},{value:"720p",label:"720p"},{value:"1080p",label:"1080p"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.quality},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,quality:e})}}},mounted(){this.value||(this.value=K)}}),xe={class:"field"},Ee={class:"title font-bold"};function Te(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",xe,[l("h2",Ee,c(e.$t("pixverse.name.quality")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=h(Se,[["render",Te],["__scopeId","data-v-64aeaae9"]]),Ce=_({name:"MotionSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"normal",label:this.$t("pixverse.name.motion1")},{value:"fast",label:this.$t("pixverse.name.motion2")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.motion},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,motion:e})}}},mounted(){this.value||(this.value=W)}}),Le={class:"field"},Re={class:"title font-bold"};function Pe(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",Le,[l("h2",Re,c(e.$t("pixverse.name.motion")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=h(Ce,[["render",Pe],["__scopeId","data-v-94237408"]]),Ae=_({name:"StyleSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"cyberpunk",label:this.$t("pixverse.name.style1")},{value:"anime",label:this.$t("pixverse.name.style2")},{value:"comic",label:this.$t("pixverse.name.style3")},{value:"clay",label:this.$t("pixverse.name.style4")},{value:"3d_animation",label:this.$t("pixverse.name.style5")},{value:"realistic",label:this.$t("pixverse.name.style6")}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.style},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,style:e})}}},mounted(){this.value||(this.value=Z)}}),De={class:"field"},Ge={class:"title font-bold"};function je(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",De,[l("h2",Ge,c(e.$t("pixverse.name.style")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Me=h(Ae,[["render",je],["__scopeId","data-v-64e17b3c"]]),qe=_({name:"SeedSelector",components:{ElSlider:O,InfoIcon:A,ElInputNumber:F},computed:{value:{get(){return this.$store.state?.pixverse?.config?.seed},set(e){console.debug("set seed",e),this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,seed:e})}}},mounted(){this.value||(this.value=void 0)}}),Be={class:"flex justify-between"},Fe={class:"flex justify-start items-center"},Oe={class:"text-sm font-bold"},Ne={class:"flex justify-end items-center"},ze={class:"w-full"};function Xe(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input-number"),n=s("el-slider");return a(),r("div",null,[l("div",Be,[l("div",Fe,[l("span",Oe,c(e.$t("pixverse.name.seed")),1),o(i,{content:e.$t("pixverse.description.seed")},null,8,["content"])]),l("div",Ne,[o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=f=>e.value=f),"controls-position":"right"},null,8,["modelValue"])])]),l("div",ze,[o(n,{modelValue:e.value,"onUpdate:modelValue":t[1]||(t[1]=f=>e.value=f),min:0,max:1e3,step:1},null,8,["modelValue"])])])}const Qe=h(qe,[["render",Xe]]),Ye=_({name:"DurationSelector",components:{ElSelect:C,ElOption:I},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:5,label:"5s"},{value:8,label:"8s"}]}},computed:{value:{get(){return this.$store.state.pixverse?.config?.duration},set(e){this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,duration:e})}}},mounted(){this.value||(this.value=ee)}}),He={class:"field"},Je={class:"title font-bold"};function Ke(e,t,u,m,$,g){const i=s("el-option"),p=s("el-select");return a(),r("div",He,[l("h2",Je,c(e.$t("pixverse.name.duration")),1),o(p,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=n=>e.value=n),class:"value",placeholder:e.$t("pixverse.placeholder.select")},{default:d(()=>[(a(!0),r(V,null,S(e.options,n=>(a(),w(i,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const We=h(Ye,[["render",Ke],["__scopeId","data-v-065c77ef"]]),Ze=_({name:"RatioSelector",data(){return{options:[{value:"1:1",label:"1:1",width:20,height:20},{value:"4:3",label:"4:3",width:20,height:15},{value:"3:4",label:"3:4",width:15,height:20},{value:"16:9",label:"16:9",width:25,height:13},{value:"9:16",label:"9:16",width:13,height:25}]}},computed:{active(){return this.options.findIndex(e=>e.value===this.value)||0},value:{get(){return this.$store.state.pixverse.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse.config,aspect_ratio:e})}}},mounted(){this.value||(this.value=te)}}),et={class:"text-sm font-bold mb-2 block"},tt={class:"items"},st=["onClick"],ot={class:"name"};function nt(e,t,u,m,$,g){return a(),r("div",null,[l("span",et,c(e.$t("pixverse.name.aspectRatio")),1),l("div",tt,[(a(!0),r(V,null,S(e.options,(i,p)=>(a(),r("div",{key:p,class:T({active:e.active===p,item:!0}),onClick:n=>e.value=i.value},[l("div",{class:T(["preview",i.label])},[l("div",{class:"rect",style:H({width:i.width+"px",height:i.height+"px"})},null,4)],2),l("p",ot,c(i.label),1)],10,st))),128))])])}const at=h(Ze,[["render",nt],["__scopeId","data-v-32a7677f"]]),lt=_({name:"StartImage",components:{ElUpload:N,ElButton:R,InfoIcon:A,FontAwesomeIcon:L,ImagePreview:le},emits:["change"],data(){return{fileList:[],uploadUrl:se()+"/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?.pixverse?.config?.image_url},set(){}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){x.warning(this.$t("pixverse.message.uploadReferencesExceed"))},onError(){x.error(this.$t("pixverse.message.uploadReferencesError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("pixverse/setConfig",{...this.$store.state?.pixverse?.config,image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),it={class:"relative"},rt={class:"flex justify-between"},ct={class:"flex justify-start items-center"},pt={class:"text-sm font-bold"};function dt(e,t,u,m,$,g){const i=s("info-icon"),p=s("image-preview"),n=s("font-awesome-icon"),f=s("el-button"),b=s("el-upload");return a(),r("div",it,[l("div",rt,[l("div",ct,[l("span",pt,c(e.$t("pixverse.name.startImage")),1),o(i,{content:e.$t("pixverse.description.uploadStartImage")},null,8,["content"])])]),o(b,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=v=>e.fileList=v),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:d(({file:v})=>[v.url&&v.percentage!==void 0?(a(),w(p,{key:0,url:v.url,name:v.name,percentage:v.percentage,onRemove:E=>e.fileList.splice(e.fileList.indexOf(v),1)},null,8,["url","name","percentage","onRemove"])):y("",!0)]),default:d(()=>[o(f,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:d(()=>[o(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),k(" "+c(e.$t("pixverse.button.uploadReferences")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const ut=h(lt,[["render",dt],["__scopeId","data-v-666104e4"]]),mt="",vt=_({name:"PromptInput",components:{ElInput:z,InfoIcon:A},computed:{prompt:{get(){return this.$store.state.pixverse?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("pixverse/setConfig",{...this.$store.state.pixverse?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=mt)}}),ft={class:"field"},_t={class:"box"},ht={class:"title font-bold"};function $t(e,t,u,m,$,g){const i=s("info-icon"),p=s("el-input");return a(),r("div",ft,[l("div",_t,[l("h2",ht,c(e.$t("pixverse.name.prompt")),1),o(i,{content:e.$t("pixverse.description.prompt"),class:"info"},null,8,["content"])]),o(p,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("pixverse.placeholder.prompt"),maxlength:500,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const gt=h(vt,[["render",$t],["__scopeId","data-v-b3dd608e"]]),bt=_({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:L,PromptInput:gt,ModelSelector:Ve,QualitySelector:Ie,MotionSelector:Ue,StyleSelector:Me,DurationSelector:We,StartImage:ut,SeedSelector:Qe,RatioSelector:at,Consumption:ie},emits:["generate"],computed:{config(){return this.$store.state.pixverse?.config},consumption(){return ce(this.config,this.service?.cost)},service(){return this.$store.state.pixverse?.service}},methods:{onGenerate(){this.$emit("generate")}}}),yt={class:"flex flex-col h-full"},kt={class:"flex-1 overflow-y-auto p-[15px]"},wt={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Vt(e,t,u,m,$,g){const i=s("prompt-input"),p=s("model-selector"),n=s("style-selector"),f=s("ratio-selector"),b=s("motion-selector"),v=s("quality-selector"),E=s("start-image"),P=s("seed-selector"),G=s("duration-selector"),j=s("consumption"),M=s("font-awesome-icon"),q=s("el-button");return a(),r("div",yt,[l("div",kt,[o(i,{class:"mb-4"}),o(p,{class:"mb-4"}),o(n,{class:"mb-4"}),o(f,{class:"mb-4"}),o(b,{class:"mb-4"}),o(v,{class:"mb-4"}),o(E,{class:"mb-2"}),o(P,{class:"mb-4"}),o(G,{class:"mb-4"})]),l("div",wt,[o(j,{value:e.consumption,service:e.service},null,8,["value","service"]),o(q,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[o(M,{icon:"fa-solid fa-magic",class:"mr-2"}),k(" "+c(e.$t("pixverse.button.generate")),1)]),_:1},8,["onClick"])])])}const St=h(bt,[["render",Vt]]),xt=_({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:pe,FontAwesomeIcon:L,ElAlert:Q,VideoPlayer:de,ElTooltip:X,ElButton:R},props:{modelValue:{type:Object,required:!0}},data(){return{}},computed:{application(){return this.$store.state.pixverse?.application},config(){return this.$store.state.pixverse?.config}},methods:{onDownload(e,t){e.stopPropagation(),console.log("on download"),window.open(t,"_blank")},onOpenVideo(e){window.open(e,"_blank")}}}),Et={class:"preview"},Tt={class:"left"},It={class:"main"},Ct={class:"bot"},Lt={class:"datetime"},Rt={class:"info"},Pt={key:0,class:"prompt mt-2"},Ut={key:0},At={key:1},Dt={key:0,class:T({content:!0,failed:!0})},Gt={key:0,class:"mb-4"},jt={key:1,class:T({operations:!0,"mt-2":!0})},Mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Bt={key:1,class:T({content:!0})},Ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ot={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function zt(e,t,u,m,$,g){const i=s("el-image"),p=s("video-player"),n=s("el-button"),f=s("el-tooltip"),b=s("font-awesome-icon"),v=s("copy-to-clipboard"),E=s("el-alert");return a(),r("div",Et,[l("div",Tt,[o(i,{src:"https://cdn.acedata.cloud/viy61r.jpg",class:"avatar"})]),l("div",It,[l("div",Ct,[k(c(e.$t("pixverse.name.pixverseBot"))+" ",1),l("span",Lt,c(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",Rt,[e.modelValue?.request?.prompt?(a(),r("p",Pt,[k(c(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?y("",!0):(a(),r("span",Ut," - ("+c(e.$t("pixverse.status.pending"))+") ",1)),e.modelValue?.response?.data&&(e.modelValue?.response?.data[0]?.state==="processing"||e.modelValue?.response?.data[0]?.state==="pending")?(a(),r("span",At," - ("+c(e.$t("pixverse.status.processing"))+") ",1)):y("",!0)])):y("",!0)]),e.modelValue?.response?.success===!0&&e.modelValue?.response?.data?(a(),r("div",Dt,[e.modelValue?.response?.data[0]?.video_url?(a(),r("div",Gt,[o(p,{src:e.modelValue?.response?.data[0]?.video_url},null,8,["src"])])):y("",!0),e.modelValue?.response.success?(a(),r("div",jt,[o(f,{class:"box-item",effect:"dark",content:e.$t("pixverse.message.downloadVideo"),placement:"top-start"},{default:d(()=>[e.modelValue?.response?.data[0]?.video_url?(a(),w(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=P=>e.onDownload(P,e.modelValue?.response?.data[0]?.video_url))},{default:d(()=>[k(c(e.$t("pixverse.button.download")),1)]),_:1})):y("",!0)]),_:1},8,["content"])])):y("",!0),o(E,{closable:!1,class:"mt-2 success"},{default:d(()=>[l("p",Mt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.model"))+": "+c(e.modelValue?.request?.model),1)]),l("p",qt,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):y("",!0),e.modelValue?.response?.success===!1?(a(),r("div",Bt,[o(E,{closable:!1,class:"info"},{template:d(()=>[o(b,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failure")),1)]),default:d(()=>[l("p",Ft,[o(b,{icon:"fa-solid fa-circle-info",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.failureReason"))+": "+c(e.modelValue?.response?.error?.message)+" ",1),o(v,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),l("p",Ot,[o(b,{icon:"fa-solid fa-magic",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.taskId"))+": "+c(e.modelValue?.id)+" ",1),o(v,{content:e.modelValue?.id},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),r("p",Nt,[o(b,{icon:"fa-solid fa-hashtag",class:"mr-1"}),k(" "+c(e.$t("pixverse.name.traceId"))+": "+c(e.modelValue?.response?.trace_id)+" ",1),o(v,{content:e.modelValue?.response?.trace_id},null,8,["content"])])):y("",!0)]),_:1})])):y("",!0)])])}const Xt=h(xt,[["render",zt],["__scopeId","data-v-3f3bff8a"]]),Qt=_({name:"RecentPanel",components:{TaskPreview:Xt,NoTasks:re,BotPlaceholder:ue,ScrollList:ae},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pixverse?.tasks,items:this.$store.state.pixverse?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Yt={key:0},Ht={key:2,class:"w-full h-full flex items-center justify-center"};function Jt(e,t,u,m,$,g){const i=s("bot-placeholder"),p=s("task-preview"),n=s("scroll-list"),f=s("no-tasks");return a(),r(V,null,[e.tasks?.items===void 0?(a(),r("div",Yt,[o(i)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"h-full w-full overflow-y-auto tasks",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),r(V,null,S(e.tasks?.items,(b,v)=>(a(),w(p,{key:v,"model-value":b},null,8,["model-value"]))),128))]),_:1},8,["loading"])):y("",!0),e.tasks?.items?.length===0?(a(),r("div",Ht,[o(f)])):y("",!0)],64)}const Kt=h(Qt,[["render",Jt]]),Wt="https://webhook.acedata.cloud/pixverse",Zt=_({name:"PixverseIndex",components:{ConfigPanel:St,Layout:ge,RecentPanel:Kt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pixverse?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.pixverse?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.pixverse.credential},config(){return this.$store.state.pixverse.config},tasks(){return this.$store.state.pixverse.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await me({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("pixverse/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("pixverse/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:u,createdAtMax:m}=e||{};console.debug("limit",t,"createdAtMin",u,"createdAtMax",m),this.fetchingTasks=!0;try{await this.$store.dispatch("pixverse/getTasks",{limit:t,createdAtMin:u,createdAtMax:m})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Wt},t=this.credential?.token;if(!t){console.error("no token specified");return}x.info(this.$t("pixverse.message.startingTask")),oe.generate(e,{token:t}).then(()=>{x.success(this.$t("pixverse.message.startTaskSuccess"))}).catch(u=>{u?.response?.data?.error?.code===ne?x.error(this.$t("pixverse.message.usedUp")):x.error(this.$t("pixverse.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function es(e,t,u,m,$,g){const i=s("config-panel"),p=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:d(()=>[o(i,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[o(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const hs=h(Zt,[["render",es]]);export{hs as default};
@@ -1 +1 @@
1
- .menu[data-v-3808ec00]{display:none}@media (max-width: 767px){.config[data-v-3808ec00]{display:none}.result[data-v-3808ec00]{width:100%}.menu[data-v-3808ec00]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-b4bd8f04]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-b4bd8f04]{font-size:14px;margin:0;width:30%}.field .value[data-v-b4bd8f04]{flex:1}.title[data-v-b7590ecc]{font-size:14px;margin-bottom:10px}.items[data-v-b7590ecc]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.items .item[data-v-b7590ecc]{width:45px;height:70px;border:2px solid var(--el-border-color);display:flex;flex-direction:column;align-items:center;cursor:pointer;border-radius:5px}.items .item .preview[data-v-b7590ecc]{margin-top:8px;width:30px;height:30px;display:flex;flex-direction:row;align-items:center;justify-content:center}.items .item .preview .rect[data-v-b7590ecc]{border:2px solid var(--el-border-color);width:20px;height:20px;border-radius:2px}.items .item .name[data-v-b7590ecc]{display:block;font-size:12px;color:var(--el-text-color-primary)}.items .item.active[data-v-b7590ecc],.items .item.active .rect[data-v-b7590ecc]{border-color:var(--el-color-primary)}.field[data-v-8410479c]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-8410479c]{font-size:14px;margin:0;width:30%}.field .value[data-v-8410479c]{flex:1}.field[data-v-0c88983e]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-0c88983e]{font-size:14px;margin:0;width:30%}.field .value[data-v-0c88983e]{flex:1}.field[data-v-f8ddf849]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-f8ddf849]{font-size:14px;margin:0;width:30%}.field .value[data-v-f8ddf849]{flex:1}.field .info[data-v-f8ddf849]{width:20px}.field[data-v-de71e0b0]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-de71e0b0]{font-size:14px;margin:0;width:30%}.field .value[data-v-de71e0b0]{flex:1}.field[data-v-51a39efa]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-51a39efa]{font-size:14px;margin:0;width:30%}.field .value[data-v-51a39efa]{flex:1}.field[data-v-72e35835]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-72e35835]{font-size:14px;margin:0;width:30%}.field .value[data-v-72e35835]{flex:1}.field[data-v-b3a5e331]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-b3a5e331]{font-size:14px;margin:0;width:30%}.field .value[data-v-b3a5e331]{flex:1}.field[data-v-54186505]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-54186505]{font-size:14px;margin:0;width:30%}.field .value[data-v-54186505]{flex:1}.field[data-v-49d801fd]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-49d801fd]{font-size:14px;margin:0;width:30%}.field .value[data-v-49d801fd]{flex:1}.field[data-v-a20833bb]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-a20833bb]{font-size:14px;margin:0;width:30%}.field .value[data-v-a20833bb]{flex:1}.field[data-v-aca7f79f]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-aca7f79f]{font-size:14px;margin:0;width:30%}.field .value[data-v-aca7f79f]{flex:1}.field[data-v-d939305d]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-d939305d]{font-size:14px;margin:0;width:30%}.field .value[data-v-d939305d]{flex:1}.field[data-v-65c34adf]{display:flex;flex-direction:column;align-items:left}.field .title[data-v-65c34adf]{font-size:14px;margin:0 0 10px;width:30%}.field .pane[data-v-65c34adf]{display:flex;flex-direction:row;justify-content:left;align-items:center;max-height:210px;overflow-y:scroll}@media (max-width: 767px){.field .pane[data-v-65c34adf]{justify-content:center}}.field .pane .item[data-v-65c34adf]{position:relative;width:60px;height:60px;margin-right:8px;margin-bottom:8px;border-width:3px;border-style:solid;border-color:var(--el-border-color);border-radius:5px;overflow:initial;cursor:pointer}.field .pane .item.hidden[data-v-65c34adf]{display:none}.field .pane .item.active[data-v-65c34adf]{border-color:var(--el-color-primary)}.field .pane .item .preview[data-v-65c34adf]{width:52px;height:52px}.field .pane .item .name[data-v-65c34adf]{position:absolute;bottom:0;left:0;right:0;width:60px;background-color:#00000080;color:#fff;font-size:10px;text-align:center;padding:0 5px}.field .title[data-v-b986940a]{font-size:14px;margin:0 0 10px;width:30%}.field .description[data-v-b986940a]{display:block;font-size:12px;margin:10px 0 0;color:var(--el-text-color-secondary)}.upload-wrapper[data-v-b986940a]{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.field .title[data-v-004a0f07]{font-size:14px;margin:0 0 10px;width:30%}.preview[data-v-9ee64fb6]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-9ee64fb6]{width:70px}.preview .left .avatar[data-v-9ee64fb6]{background-color:#fff;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-9ee64fb6]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-9ee64fb6]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-9ee64fb6]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-9ee64fb6]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content .el-alert[data-v-9ee64fb6]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-9ee64fb6]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-9ee64fb6]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-9ee64fb6]{border-color:var(--el-color-info)}.preview .main .description[data-v-9ee64fb6]{color:var(--el-text-color-regular);font-size:12px;margin-bottom:8px}.status[data-v-6a326101]{margin-bottom:10px}.panel.detail[data-v-6a326101]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-6a326101]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-6a326101]{position:relative}
1
+ .menu[data-v-3808ec00]{display:none}@media (max-width: 767px){.config[data-v-3808ec00]{display:none}.result[data-v-3808ec00]{width:100%}.menu[data-v-3808ec00]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-b4bd8f04]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-b4bd8f04]{font-size:14px;margin:0;width:30%}.field .value[data-v-b4bd8f04]{flex:1}.title[data-v-b7590ecc]{font-size:14px;margin-bottom:10px}.items[data-v-b7590ecc]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.items .item[data-v-b7590ecc]{width:45px;height:70px;border:2px solid var(--el-border-color);display:flex;flex-direction:column;align-items:center;cursor:pointer;border-radius:5px}.items .item .preview[data-v-b7590ecc]{margin-top:8px;width:30px;height:30px;display:flex;flex-direction:row;align-items:center;justify-content:center}.items .item .preview .rect[data-v-b7590ecc]{border:2px solid var(--el-border-color);width:20px;height:20px;border-radius:2px}.items .item .name[data-v-b7590ecc]{display:block;font-size:12px;color:var(--el-text-color-primary)}.items .item.active[data-v-b7590ecc],.items .item.active .rect[data-v-b7590ecc]{border-color:var(--el-color-primary)}.field[data-v-8410479c]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-8410479c]{font-size:14px;margin:0;width:30%}.field .value[data-v-8410479c]{flex:1}.field[data-v-0c88983e]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-0c88983e]{font-size:14px;margin:0;width:30%}.field .value[data-v-0c88983e]{flex:1}.field[data-v-f8ddf849]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-f8ddf849]{font-size:14px;margin:0;width:30%}.field .value[data-v-f8ddf849]{flex:1}.field .info[data-v-f8ddf849]{width:20px}.field[data-v-de71e0b0]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-de71e0b0]{font-size:14px;margin:0;width:30%}.field .value[data-v-de71e0b0]{flex:1}.field[data-v-51a39efa]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-51a39efa]{font-size:14px;margin:0;width:30%}.field .value[data-v-51a39efa]{flex:1}.field[data-v-72e35835]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-72e35835]{font-size:14px;margin:0;width:30%}.field .value[data-v-72e35835]{flex:1}.field[data-v-b3a5e331]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-b3a5e331]{font-size:14px;margin:0;width:30%}.field .value[data-v-b3a5e331]{flex:1}.field[data-v-54186505]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-54186505]{font-size:14px;margin:0;width:30%}.field .value[data-v-54186505]{flex:1}.field[data-v-49d801fd]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-49d801fd]{font-size:14px;margin:0;width:30%}.field .value[data-v-49d801fd]{flex:1}.field[data-v-a20833bb]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-a20833bb]{font-size:14px;margin:0;width:30%}.field .value[data-v-a20833bb]{flex:1}.field[data-v-aca7f79f]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-aca7f79f]{font-size:14px;margin:0;width:30%}.field .value[data-v-aca7f79f]{flex:1}.field[data-v-d939305d]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-d939305d]{font-size:14px;margin:0;width:30%}.field .value[data-v-d939305d]{flex:1}.field[data-v-65c34adf]{display:flex;flex-direction:column;align-items:left}.field .title[data-v-65c34adf]{font-size:14px;margin:0 0 10px;width:30%}.field .pane[data-v-65c34adf]{display:flex;flex-direction:row;justify-content:left;align-items:center;max-height:210px;overflow-y:scroll}@media (max-width: 767px){.field .pane[data-v-65c34adf]{justify-content:center}}.field .pane .item[data-v-65c34adf]{position:relative;width:60px;height:60px;margin-right:8px;margin-bottom:8px;border-width:3px;border-style:solid;border-color:var(--el-border-color);border-radius:5px;overflow:initial;cursor:pointer}.field .pane .item.hidden[data-v-65c34adf]{display:none}.field .pane .item.active[data-v-65c34adf]{border-color:var(--el-color-primary)}.field .pane .item .preview[data-v-65c34adf]{width:52px;height:52px}.field .pane .item .name[data-v-65c34adf]{position:absolute;bottom:0;left:0;right:0;width:60px;background-color:#00000080;color:#fff;font-size:10px;text-align:center;padding:0 5px}.field .title[data-v-b986940a]{font-size:14px;margin:0 0 10px;width:30%}.field .description[data-v-b986940a]{display:block;font-size:12px;margin:10px 0 0;color:var(--el-text-color-secondary)}.upload-wrapper[data-v-b986940a]{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.field .title[data-v-004a0f07]{font-size:14px;margin:0 0 10px;width:30%}.preview[data-v-9ee64fb6]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-9ee64fb6]{width:70px}.preview .left .avatar[data-v-9ee64fb6]{background-color:#fff;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-9ee64fb6]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-9ee64fb6]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-9ee64fb6]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-9ee64fb6]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content .el-alert[data-v-9ee64fb6]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-9ee64fb6]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-9ee64fb6]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-9ee64fb6]{border-color:var(--el-color-info)}.preview .main .description[data-v-9ee64fb6]{color:var(--el-text-color-regular);font-size:12px;margin-bottom:8px}.status[data-v-b90a878d]{margin-bottom:10px}.panel.detail[data-v-b90a878d]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-b90a878d]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-b90a878d]{position:relative}
@@ -0,0 +1 @@
1
+ import{bF as S}from"./vendor-BG5lCpoe.js";import{o as L,N as j,J as P,K as G,P as F,Q as B,q as D,r as y,p as M,B as O,i as N}from"./vendor-element-plus-7rF3khck.js";import{d as $,c as i,a as l,l as t,P as E,S as f,al as s,o as a,Z as r,F as V,ai as I,R as w,Y as h,W as k,V as U}from"./vendor-vue-Bb02XvLT.js";import{_ as v,bs as q,bt as z,bu as X,S as K,bv as W,a6 as H,a3 as A}from"./index-BWdK6S1P.js";import{I as C,S as J}from"./ScrollList-hBjgRYV4.js";import{I as Q}from"./ImagePreview-hdi2mrdI.js";import{C as Y,N as Z}from"./NoTasks-CgXSnfeV.js";import{a as ee}from"./price-DsQ2XKBW.js";import{C as te}from"./CopyToClipboard-Ab4hHs26.js";import{I as oe}from"./ImageWrapper-D9v7ltO5.js";import{B as se}from"./BotPlaceholder-BU17vEUy.js";import{l as ne}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const le=$({name:"LayoutFlux",components:{ElDrawer:j,ElButton:L,FontAwesomeIcon:S},data(){return{drawer:!1}}}),ae={class:"main flex flex-row flex-1"},re={class:"config w-[300px] flex-none h-full overflow-y-auto border-r border-[var(--el-border-color)]"},ie={class:"result h-full p-[15px] flex-1 flex flex-col min-w-0 overflow-x-hidden"};function ce(e,o,m,d,b,x){const c=s("font-awesome-icon"),u=s("el-button"),n=s("el-drawer");return a(),i("div",ae,[l("div",re,[E(e.$slots,"config",{},void 0,!0)]),l("div",ie,[E(e.$slots,"result",{},void 0,!0)]),t(u,{circle:"",class:"menu",onClick:o[0]||(o[0]=p=>e.drawer=!0)},{default:f(()=>[t(c,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":o[1]||(o[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:f(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ue=v(le,[["render",ce],["__scopeId","data-v-8a4bf519"]]),de=$({name:"ModelSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{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=q)}}),pe={class:"field"},me={class:"title font-bold"};function fe(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",pe,[l("h2",me,r(e.$t("flux.name.model")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(de,[["render",fe],["__scopeId","data-v-8df4b8a7"]]),he=$({name:"CountSelector",components:{ElSlider:B,InfoIcon:C,ElInputNumber:F},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=z)}}),ge={class:"flex justify-between"},$e={class:"flex justify-start items-center"},ve={class:"text-sm font-bold"},be={class:"flex justify-end items-center"},xe={class:"w-full"};function ke(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input-number"),n=s("el-slider");return a(),i("div",null,[l("div",ge,[l("div",$e,[l("span",ve,r(e.$t("flux.name.numbers")),1),t(c,{content:e.$t("flux.description.numbers")},null,8,["content"])]),l("div",be,[t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=p=>e.value=p),"controls-position":"right"},null,8,["modelValue"])])]),l("div",xe,[t(n,{modelValue:e.value,"onUpdate:modelValue":o[1]||(o[1]=p=>e.value=p),min:1,max:4,step:1},null,8,["modelValue"])])])}const we=v(he,[["render",ke]]),ye=$({name:"ActionSelector",components:{ElSelect:G,ElOption:P},props:{modelValue:{type:String,default:void 0}},emits:["update:modelValue"],data(){return{options:[{value:"generate",label:this.$t("flux.name.generate")},{value:"edits",label:this.$t("flux.name.edits")}]}},computed:{value:{get(){return this.$store.state.flux?.config?.action},set(e){this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,action:e})}}},mounted(){this.value||(this.value=X)}}),Ve={class:"field"},Te={class:"title font-bold"};function Se(e,o,m,d,b,x){const c=s("el-option"),u=s("el-select");return a(),i("div",Ve,[l("h2",Te,r(e.$t("flux.name.task")),1),t(u,{modelValue:e.value,"onUpdate:modelValue":o[0]||(o[0]=n=>e.value=n),class:"value",placeholder:e.$t("flux.placeholder.select")},{default:f(()=>[(a(!0),i(V,null,I(e.options,n=>(a(),w(c,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ie=v(ye,[["render",Se],["__scopeId","data-v-81fd05e5"]]),Ee=$({name:"ImageUrlInput",components:{ElUpload:D,ElButton:L,InfoIcon:C,FontAwesomeIcon:S,ImagePreview:Q},emits:["change"],data(){return{fileList:[],uploadUrl:K()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},watch:{urls:{handler(e){console.debug("URLs changed:",e),this.$store.commit("flux/setConfig",{...this.$store.state.flux.config,image_url:e[0]})}}},methods:{onExceed(){y.warning(this.$t("flux.message.uploadStartImageExceed"))},onError(){y.error(this.$t("flux.message.uploadStartImageError"))}}}),Le={class:"relative"},Ue={class:"flex justify-between"},Ce={class:"flex justify-start items-center"},Ae={class:"text-sm font-bold"};function Pe(e,o,m,d,b,x){const c=s("info-icon"),u=s("image-preview"),n=s("font-awesome-icon"),p=s("el-button"),g=s("el-upload");return a(),i("div",Le,[l("div",Ue,[l("div",Ce,[l("span",Ae,r(e.$t("flux.name.imageUrl")),1),t(c,{content:e.$t("flux.description.imageUrl")},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":o[0]||(o[0]=_=>e.fileList=_),name:"file",limit:5,class:"upload-wrapper",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,headers:e.headers},{file:f(({file:_})=>[t(u,{url:_.url||_.response?.file_url,name:_.name,percentage:_.percentage,onRemove:T=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])]),default:f(()=>[t(p,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:f(()=>[t(n,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+r(e.$t("flux.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","headers"])])}const Ge=v(Ee,[["render",Pe],["__scopeId","data-v-04710032"]]),Re="",je=$({name:"PromptInput",components:{ElInput:M,InfoIcon:C},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=Re)}}),Fe={class:"field"},Be={class:"box"},De={class:"title font-bold"};function Me(e,o,m,d,b,x){const c=s("info-icon"),u=s("el-input");return a(),i("div",Fe,[l("div",Be,[l("h2",De,r(e.$t("flux.name.prompt")),1),t(c,{content:e.$t("flux.description.prompt"),class:"info"},null,8,["content"])]),t(u,{modelValue:e.prompt,"onUpdate:modelValue":o[0]||(o[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("flux.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Oe=v(je,[["render",Me],["__scopeId","data-v-4c101a17"]]),Ne=$({name:"PresetPanel",components:{ElButton:L,FontAwesomeIcon:S,PromptInput:Oe,ModelSelector:_e,CountSelector:we,Consumption:Y,ActionSelector:Ie,ImageUrlInput:Ge},emits:["generate"],computed:{config(){return this.$store.state.flux?.config},consumption(){return ee(this.config,this.service?.cost)},service(){return this.$store.state.flux?.service}},methods:{onGenerate(){this.$emit("generate")}}}),qe={class:"flex flex-col h-full"},ze={class:"flex-1 overflow-y-auto p-[15px]"},Xe={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ke(e,o,m,d,b,x){const c=s("action-selector"),u=s("prompt-input"),n=s("image-url-input"),p=s("model-selector"),g=s("count-selector"),_=s("consumption"),T=s("font-awesome-icon"),R=s("el-button");return a(),i("div",qe,[l("div",ze,[t(c,{class:"mb-4"}),t(u,{class:"mb-4"}),e.config?.action==="edits"?(a(),w(n,{key:0,class:"mb-4"})):k("",!0),t(p,{class:"mb-4"}),t(g,{class:"mb-4"})]),l("div",Xe,[t(_,{value:e.consumption,service:e.service},null,8,["value","service"]),t(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:f(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+r(e.$t("flux.button.generate")),1)]),_:1},8,["onClick"])])])}const We=v(Ne,[["render",Ke]]),He=$({name:"TaskPreview",components:{ElImage:N,CopyToClipboard:te,FontAwesomeIcon:S,ElAlert:O,ImageWrapper:oe},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 d=m;o&&(d.action=o),e.push(d)}),e}},methods:{onDownload(e,o){e.stopPropagation(),console.log("on download"),window.open(o,"_blank")},onOpenImage(e){window.open(e,"_blank")}}}),Je={class:"preview"},Qe={class:"left"},Ye={class:"main"},Ze={class:"bot"},et={class:"datetime"},tt={class:"info"},ot={key:0,class:"prompt mt-2"},st={key:0},nt={key:0,class:U({content:!0,failed:!0})},lt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:1,class:U({content:!0})},ct={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:2,class:U({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function ft(e,o,m,d,b,x){const c=s("el-image"),u=s("image-wrapper"),n=s("font-awesome-icon"),p=s("copy-to-clipboard"),g=s("el-alert");return a(),i("div",Je,[l("div",Qe,[t(c,{src:"https://cdn.acedata.cloud/ogm2oa.png",class:"avatar"})]),l("div",Ye,[l("div",Ze,[h(r(e.$t("flux.name.fluxBot"))+" ",1),l("span",et,r(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",tt,[e.modelValue?.request?.prompt?(a(),i("p",ot,[h(r(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?k("",!0):(a(),i("span",st," - ("+r(e.$t("flux.status.pending"))+") ",1))])):k("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",nt,[l("div",lt,[(a(!0),i(V,null,I(e.images,(_,T)=>(a(),w(u,{key:T,src:_?.image_url,"raw-src":_?.image_url,"model-value":_},null,8,["src","raw-src","model-value"]))),128))]),t(g,{closable:!1,class:"mt-2 success"},{default:f(()=>[l("p",at,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.model"))+": "+r(e.modelValue?.request?.model),1)]),l("p",rt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?.success===!1?(a(),i("div",it,[t(g,{closable:!1,class:"failure"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",ct,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",ut,[t(n,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+r(e.$t("flux.name.failureReason"))+": "+r(e.modelValue?.response?.error?.message)+" ",1),t(p,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",dt,[t(n,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+r(e.$t("flux.name.traceId"))+": "+r(e.modelValue?.response?.trace_id)+" ",1),t(p,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):k("",!0),e.modelValue?.response?k("",!0):(a(),i("div",pt,[t(g,{closable:!1,class:"info"},{template:f(()=>[t(n,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+r(e.$t("flux.name.failure")),1)]),default:f(()=>[l("p",mt,[t(n,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+r(e.$t("flux.name.taskId"))+": "+r(e.modelValue?.id)+" ",1),t(p,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const _t=v(He,[["render",ft],["__scopeId","data-v-fd5838a5"]]),ht=$({name:"RecentPanel",components:{TaskPreview:_t,BotPlaceholder:se,NoTasks:Z,ScrollList:J},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.flux?.tasks,items:this.$store.state.flux?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),gt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function vt(e,o,m,d,b,x){const c=s("bot-placeholder"),u=s("task-preview"),n=s("scroll-list"),p=s("no-tasks");return a(),i(V,null,[e.tasks?.items===void 0?(a(),i("div",gt,[t(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),w(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:o[0]||(o[0]=g=>e.$emit("reach-top"))},{default:f(()=>[(a(!0),i(V,null,I(e.tasks?.items,g=>(a(),w(u,{key:g.id,"model-value":g},null,8,["model-value"]))),128))]),_:1},8,["loading"])):k("",!0),e.tasks?.items?.length===0?(a(),i("div",$t,[t(p)])):k("",!0)],64)}const bt=v(ht,[["render",vt]]),xt="https://webhook.acedata.cloud/flux",kt=$({name:"FluxIndex",components:{ConfigPanel:We,Layout:ue,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.flux?.status?.getApplications===A.Request},tasksLoading(){return this.$store.state.flux?.status?.getTasks===A.Request||this.fetchingTasks},credential(){return this.$store.state.flux?.credential},config(){return this.$store.state.flux?.config},application(){return this.$store.state.flux?.application},tasks(){return this.$store.state.flux?.tasks}},watch:{tasks:{handler(e,o){e?.items?.length>o?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ne({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("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(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:o=5,createdAtMin:m,createdAtMax:d}=e||{};console.debug("limit",o,"createdAtMin",m,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("flux/getTasks",{limit:o,createdAtMin:m,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:xt},o=this.credential?.token;if(!o){console.error("no token specified");return}y.info(this.$t("flux.message.startingTask")),W.generate(e,{token:o}).then(()=>{y.success(this.$t("flux.message.startTaskSuccess"))}).catch(m=>{const d=m?.response?.data;d?.error?.code===H?y.error(this.$t("flux.message.usedUp")):y.error(this.$t("flux.message.startTaskFailed")+d?.error?.message)}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,o,m,d,b,x){const c=s("config-panel"),u=s("recent-panel"),n=s("layout");return a(),w(n,null,{config:f(()=>[t(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:f(()=>[t(u,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Dt=v(kt,[["render",wt]]);export{Dt as default};
@@ -0,0 +1 @@
1
+ import{bF as C}from"./vendor-BG5lCpoe.js";import{o as V,N as R,J as A,K as B,q as M,r as S,p as j,n as D,B as q,i as O}from"./vendor-element-plus-7rF3khck.js";import{d as k,c,a as i,l as t,P as E,S as u,al as o,o as a,Z as n,F as L,ai as G,R as v,Y as p,W as h,V as T,a1 as z}from"./vendor-vue-Bb02XvLT.js";import{_ as b,bw as F,S as N,bx as H,a6 as K,a3 as U}from"./index-BWdK6S1P.js";import{I as P,S as J}from"./ScrollList-hBjgRYV4.js";import{I as W}from"./ImagePreview-hdi2mrdI.js";import{C as Y,N as Z}from"./NoTasks-CgXSnfeV.js";import{a as Q}from"./price-DsQ2XKBW.js";import{C as X}from"./CopyToClipboard-Ab4hHs26.js";import{V as x}from"./VideoPlayer-CsVaulnP.js";import{B as ee}from"./BotPlaceholder-BU17vEUy.js";import{l as te}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const oe=k({name:"LayoutHailuo",components:{ElDrawer:R,ElButton:V,FontAwesomeIcon:C},data(){return{drawer:!1}}}),se={class:"main flex flex-row flex-1"},ae={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},ne={class:"result h-full p-[15px] flex-1 flex flex-col"};function le(e,s,f,_,w,y){const d=o("font-awesome-icon"),m=o("el-button"),r=o("el-drawer");return a(),c("div",se,[i("div",ae,[E(e.$slots,"config",{},void 0,!0)]),i("div",ne,[E(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:s[0]||(s[0]=g=>e.drawer=!0)},{default:u(()=>[t(d,{icon:"fa-solid fa-magic"})]),_:1}),t(r,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:u(()=>[E(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const ie=b(oe,[["render",le],["__scopeId","data-v-096d9205"]]),re=k({name:"ModelSelector",components:{ElSelect:B,ElOption:A},data(){return{}},computed:{options(){return[{value:"minimax-t2v",label:this.$t("hailuo.button.model1")},{value:"minimax-i2v",label:this.$t("hailuo.button.model2")}]},value:{get(){return this.$store.state.hailuo?.config?.model},set(e){this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,model:e})}}},mounted(){this.value||(this.value=F)}}),ce={class:"field"},ue={class:"title font-bold"},de={class:"float-left"};function me(e,s,f,_,w,y){const d=o("el-option"),m=o("el-select");return a(),c("div",ce,[i("h2",ue,n(e.$t("hailuo.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=r=>e.value=r),class:"value",placeholder:e.$t("hailuo.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),c(L,null,G(e.options,r=>(a(),v(d,{key:r.value,label:r.label,value:r.value},{default:u(()=>[i("span",de,n(r.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const pe=b(re,[["render",me],["__scopeId","data-v-30ff1e69"]]),he=k({name:"StartImageUrlInput",components:{ElUpload:M,ElButton:V,InfoIcon:P,ImagePreview:W},data(){return{fileList:[],uploadUrl:N()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.hailuo?.config?.first_image_url},set(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetStartImageUrl()},methods:{onExceed(){S.warning(this.$t("hailuo.message.uploadStartImageExceed"))},onError(){S.error(this.$t("hailuo.message.uploadStartImageError"))},async onRemove(){S.error(this.$t("hailuo.message.uploadStartImageError"))},onSetStartImageUrl(){const e=this.urls?.[0];this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,first_image_url:e})},async onSuccess(){this.onSetStartImageUrl()}}}),fe={class:"relative"},_e={class:"flex justify-between"},ge={class:"flex justify-start items-center"},$e={class:"text-sm font-bold"};function ve(e,s,f,_,w,y){const d=o("info-icon"),m=o("image-preview"),r=o("el-button"),g=o("el-upload");return a(),c("div",fe,[i("div",_e,[i("div",ge,[i("span",$e,n(e.$t("hailuo.name.startImageUrl")),1),t(d,{content:e.$t("hailuo.description.startImageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=l=>e.fileList=l),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:l})=>[l.url&&l.percentage!==void 0?(a(),v(m,{key:0,url:l.url,name:l.name,percentage:l.percentage,onRemove:$=>e.fileList.splice(e.fileList.indexOf(l),1)},null,8,["url","name","percentage","onRemove"])):h("",!0)]),default:u(()=>[t(r,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:u(()=>[p(n(e.$t("hailuo.button.uploadStartImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const ke=b(he,[["render",ve],["__scopeId","data-v-a906df80"]]),be="",we=k({name:"PromptInput",components:{ElInput:j,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.hailuo?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("hailuo/setConfig",{...this.$store.state.hailuo?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=be)}}),ye={class:"field"},Se={class:"box"},Ve={class:"title font-bold"};function Te(e,s,f,_,w,y){const d=o("info-icon"),m=o("el-input");return a(),c("div",ye,[i("div",Se,[i("h2",Ve,n(e.$t("hailuo.name.prompt")),1),t(d,{content:e.$t("hailuo.description.prompt"),class:"info"},null,8,["content"])]),t(m,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=r=>e.prompt=r),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("hailuo.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Ie=b(we,[["render",Te],["__scopeId","data-v-d54ffa64"]]),Ee=k({name:"PresetPanel",components:{ElButton:V,FontAwesomeIcon:C,PromptInput:Ie,StartImageUrlInput:ke,ModelSelector:pe,Consumption:Y},emits:["generate"],computed:{config(){return this.$store.state.hailuo?.config},consumption(){return Q(this.config,this.service?.cost)},service(){return this.$store.state.hailuo?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Le={class:"flex flex-col h-full"},Ce={class:"flex-1 overflow-y-auto p-[15px]"},Ue={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function Ge(e,s,f,_,w,y){const d=o("prompt-input"),m=o("model-selector"),r=o("start-image-url-input"),g=o("consumption"),l=o("font-awesome-icon"),$=o("el-button");return a(),c("div",Le,[i("div",Ce,[t(d,{class:"mb-4"}),t(m,{class:"mb-4"}),e.config?.model==="minimax-i2v"?(a(),v(r,{key:0,class:"mb-2"})):h("",!0)]),i("div",Ue,[t(g,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.video_url!==void 0||e.config?.custom?(a(),v($,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),p(" "+n(e.$t("hailuo.button.extend")),1)]),_:1},8,["onClick"])):(a(),v($,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(l,{icon:"fa-solid fa-magic",class:"mr-2"}),p(" "+n(e.$t("hailuo.button.generate")),1)]),_:1},8,["onClick"]))])])}const Pe=b(Ee,[["render",Ge]]),Re=k({name:"TaskPreview",components:{ElImage:O,CopyToClipboard:X,FontAwesomeIcon:C,ElAlert:q,VideoPlayer:x,ElTooltip:D,ElButton:V},props:{modelValue:{type:Object,required:!0}},computed:{application(){return this.$store.state.hailuo?.application},config(){return this.$store.state.hailuo?.config},video(){return this.modelValue?.response?.data?.[0]}},methods:{onDownload(e){console.debug("on download hailuo video",e),window.open(e,"_blank")}}}),Ae={class:"preview"},Be={class:"left"},Me={class:"main"},je={class:"bot"},De={class:"datetime"},qe={class:"info"},Oe={key:0,class:"prompt mt-2"},ze={key:0},Fe={key:1},Ne={key:0,class:T({content:!0,failed:!0})},He={key:0,class:"mb-4"},Ke={key:1,class:T({operations:!0,"mt-2":!0})},Je={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},We={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ye={key:1,class:T({content:!0})},Ze={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Qe={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Xe={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},xe={key:2,class:T({content:!0})},et={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function tt(e,s,f,_,w,y){const d=o("el-image"),m=o("video-player"),r=o("el-button"),g=o("el-tooltip"),l=o("font-awesome-icon"),$=o("copy-to-clipboard"),I=o("el-alert");return a(),c("div",Ae,[i("div",Be,[t(d,{src:"https://cdn.acedata.cloud/0qg4gp.png",class:"avatar"})]),i("div",Me,[i("div",je,[p(n(e.$t("hailuo.name.hailuoBot"))+" ",1),i("span",De,n(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),i("div",qe,[e.modelValue?.request?.prompt?(a(),c("p",Oe,[p(n(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?h("",!0):(a(),c("span",ze," - ("+n(e.$t("hailuo.status.pending"))+") ",1)),e.video?.state==="processing"||e.video?.state==="pending"||e.video?.state==="running"?(a(),c("span",Fe," - ("+n(e.$t("hailuo.status.processing"))+") ",1)):h("",!0)])):h("",!0)]),e.modelValue?.response?.success===!0?(a(),c("div",Ne,[e.video?.video_url?(a(),c("div",He,[t(m,{src:e.video?.video_url},null,8,["src"])])):h("",!0),e.video?(a(),c("div",Ke,[t(g,{class:"box-item",effect:"dark",content:e.$t("hailuo.message.downloadVideo"),placement:"top-start"},{default:u(()=>[e.video?.video_url?(a(),v(r,{key:0,type:"info",size:"small",class:"mb-2",onClick:s[0]||(s[0]=z(dt=>e.onDownload(e.video?.video_url),["stop"]))},{default:u(()=>[p(n(e.$t("hailuo.button.download")),1)]),_:1})):h("",!0)]),_:1},8,["content"])])):h("",!0),t(I,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(a(),c("p",Je,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.model"))+": "+n(e.modelValue?.request?.model)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])):h("",!0),i("p",We,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===!1?(a(),c("div",Ye,[t(I,{closable:!1,class:"failure"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failure")),1)]),default:u(()=>[i("p",Ze,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])]),i("p",Qe,[t(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failureReason"))+": "+n(e.modelValue?.response?.error?.message)+" ",1),t($,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),i("p",Xe,[t(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.traceId"))+": "+n(e.modelValue?.response?.trace_id)+" ",1),t($,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):h("",!0),e.modelValue?.response?.success===void 0?(a(),c("div",xe,[t(I,{closable:!1,class:"info"},{template:u(()=>[t(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.failure")),1)]),default:u(()=>[i("p",et,[t(l,{icon:"fa-solid fa-magic",class:"mr-1"}),p(" "+n(e.$t("hailuo.name.taskId"))+": "+n(e.modelValue?.id)+" ",1),t($,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):h("",!0)])])}const ot=b(Re,[["render",tt],["__scopeId","data-v-72acd507"]]),st=k({name:"RecentPanel",components:{TaskPreview:ot,BotPlaceholder:ee,NoTasks:Z,ScrollList:J},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.hailuo?.tasks,items:this.$store.state.hailuo?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),at={key:0},nt={key:2,class:"w-full h-full flex items-center justify-center"};function lt(e,s,f,_,w,y){const d=o("bot-placeholder"),m=o("task-preview"),r=o("scroll-list"),g=o("no-tasks");return a(),c(L,null,[e.tasks?.items===void 0?(a(),c("div",at,[t(d)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),v(r,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=l=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),c(L,null,G(e.tasks?.items,l=>(a(),v(m,{key:l.id,"model-value":l},null,8,["model-value"]))),128))]),_:1},8,["loading"])):h("",!0),e.tasks?.items?.length===0?(a(),c("div",nt,[t(g)])):h("",!0)],64)}const it=b(st,[["render",lt]]),rt="https://webhook.acedata.cloud/hailuo",ct=k({name:"HailuoIndex",components:{ConfigPanel:Pe,Layout:ie,RecentPanel:it},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.hailuo?.status?.getApplications===U.Request},tasksLoading(){return this.$store.state.hailuo?.status?.getTasks===U.Request||this.fetchingTasks},credential(){return this.$store.state.hailuo.credential},config(){return this.$store.state.hailuo.config},application(){return this.$store.state.hailuo.application},tasks(){return this.$store.state.hailuo.tasks}},watch:{tasks:{handler(e,s){e?.items?.length>s?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await te({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("hailuo/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("hailuo/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:f,createdAtMax:_}=e||{};console.debug("limit",s,"createdAtMin",f,"createdAtMax",_),this.fetchingTasks=!0;try{await this.$store.dispatch("hailuo/getTasks",{limit:s,createdAtMin:f,createdAtMax:_})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:rt},s=this.credential?.token;if(!s){console.error("no token specified");return}S.info(this.$t("hailuo.message.startingTask")),H.generate(e,{token:s}).then(()=>{S.success(this.$t("hailuo.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===K?S.error(this.$t("hailuo.message.usedUp")):S.error(this.$t("hailuo.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function ut(e,s,f,_,w,y){const d=o("config-panel"),m=o("recent-panel"),r=o("layout");return a(),v(r,null,{config:u(()=>[t(d,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Et=b(ct,[["render",ut]]);export{Et as default};
@@ -0,0 +1 @@
1
+ import{C as I}from"./CopyToClipboard-Ab4hHs26.js";import{aC as E,aD as F,aE as T,_ as N}from"./index-BWdK6S1P.js";import{d as P,a as y,s as O}from"./distribution-ahsMBsrL.js";import{ae as B,bF as M}from"./vendor-BG5lCpoe.js";import{g as R}from"./price-DsQ2XKBW.js";import{G as q,t as z,u as U,n as V,s as A,m as G,o as H,w as Q,x as W,O as Y}from"./vendor-element-plus-7rF3khck.js";import{d as Z,R as r,S as o,l as i,al as a,a as e,Z as s,c as p,Y as _,W as k,o as n}from"./vendor-vue-Bb02XvLT.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";const j=Z({name:"ConsoleDistributionList",components:{CopyToClipboard:I,FontAwesomeIcon:M,QrCode:B,ElProgress:Y,ElRow:W,ElCol:Q,ElButton:H,ElDivider:G,ElCard:A,ElTooltip:V,ElTable:U,ElTableColumn:z,ElSkeleton:q},data(){return{invitees:[],inviteesCount:void 0,distributionLevels:[],distributionLink:void 0,distributionStatus:void 0,loading:!1}},computed:{redirect(){return this.$route.query.redirect},page(){return parseInt(this.$route.query.page?.toString()||"1")},distributionLevelMap(){let t={};return this.distributionLevels.forEach(l=>{t[l.level]=l}),t}},watch:{page:{handler(){this.onFetchData()}}},async mounted(){this.onFetchData(),this.onGenerateDistributionLink()},methods:{getPriceString:R,goHistory(){this.$router.push({name:T})},goInvitees(){this.$router.push({name:F})},onPageChange(t){this.$router.push({name:this.$route.name?.toString(),query:{page:t}})},getPercentageForNextLevel(){const t=this.distributionLevelMap[this.distributionStatus?.level?.level]?.threshold,l=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor((this.distributionStatus?.price-t)/(l-t)*100)},getDeltaForNextLevel(){const t=this.distributionLevelMap[this.distributionStatus?.level?.level+1]?.threshold;return Math.floor(t-this.distributionStatus?.price)},async onFetchData(){this.loading=!0,await y.initialize(),Promise.all([this.onFetchDistributionStatus(),this.onFetchDistributionLevels(),this.onFetchInvitees()]).finally(()=>{this.loading=!1})},async onGenerateDistributionLink(){const l=`${window.location.origin}?inviter_id=${this.$store.getters.user.id}`;try{const v=(await O.create(l))?.data?.data?.url;this.distributionLink=(v||l).replace("surl.id","share.acedata.cloud")}catch{this.distributionLink=l}},async onFetchDistributionStatus(){const{data:t}=await y.getAll({user_id:this.$store.getters.user.id});t.items&&t.items.length>0&&(this.distributionStatus=t.items[0])},async onFetchDistributionLevels(){const{data:t}=await P.getAll({limit:20,user_id:this.$store.getters.user.id});this.distributionLevels=t.items},async onFetchInvitees(){const{data:t}=await E.getInvitees({});this.invitees=t.items,this.inviteesCount=t.count}}}),J={class:"title"},K={key:1},X={class:"icon-wrapper"},x={class:"text-left"},tt={class:"description"},et={class:"value"},it={key:1},st={class:"icon-wrapper"},ot={class:"text-left"},nt={class:"description"},at={class:"value"},lt={key:1},rt={class:"icon-wrapper"},dt={class:"text-left"},ct={class:"description"},ut={class:"value"},pt={key:1},ht={class:"icon-wrapper"},_t={class:"text-left"},mt={class:"description"},bt={class:"value"},vt={key:1},ft={class:"title"},gt={class:"clear-both overflow-hidden"},kt={class:"float-left description"},wt={class:"float-right description"},$t={class:"description"},yt={class:"level"},Lt={class:"level"},St={class:"level"},Ct={key:1},Dt={class:"title"},It={class:"link-wrapper text-center"},Et=["href"],Ft={class:"qr-wrapper ml-auto mr-auto"},Tt={class:"mt-0"},Nt={class:"description"},Pt={class:"more"};function Ot(t,l,v,Bt,Mt,Rt){const d=a("el-col"),m=a("el-row"),c=a("el-skeleton"),b=a("font-awesome-icon"),f=a("el-button"),u=a("el-card"),w=a("el-tooltip"),L=a("el-progress"),$=a("el-divider"),g=a("el-table-column"),S=a("el-table"),C=a("copy-to-clipboard"),D=a("qr-code");return n(),r(m,{class:"panel"},{default:o(()=>[i(d,{span:24},{default:o(()=>[i(m,null,{default:o(()=>[i(d,{span:24},{default:o(()=>[e("h2",J,s(t.$t("common.title.distribution")),1)]),_:1})]),_:1}),i(m,{gutter:15},{default:o(()=>[i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",K,[e("div",X,[i(b,{icon:"fa-solid fa-wallet",class:"icon"})]),e("div",x,[e("p",tt,s(t.$t("distribution.title.price")),1),e("p",et,s(t.getPriceString({value:t.distributionStatus?.price})),1)]),i(f,{type:"primary",round:"",size:"small",class:"btn",onClick:t.goHistory},{default:o(()=>[_(s(t.$t("distribution.button.detail")),1)]),_:1},8,["onClick"])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",it,[e("div",st,[i(b,{icon:"fa-solid fa-coins",class:"icon"})]),e("div",ot,[e("p",nt,s(t.$t("distribution.title.reward")),1),e("p",at,s(t.getPriceString({value:t.distributionStatus?.reward})),1)]),i(w,{effect:"dark",content:t.$t("distribution.message.developingWithDrawal"),placement:"top"},{default:o(()=>[i(f,{type:"primary",round:"",size:"small",class:"btn"},{default:o(()=>[_(s(t.$t("distribution.button.withdrawal")),1)]),_:1})]),_:1},8,["content"])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",lt,[e("div",rt,[i(b,{icon:"fa-solid fa-percent",class:"icon"})]),e("div",dt,[e("p",ct,s(t.$t("distribution.title.percentage")),1),e("p",ut,s(t.distributionStatus?.level?.percentage)+"%",1)])]))]),_:1})]),_:1}),i(d,{md:6,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"item-mini mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",pt,[e("div",ht,[i(b,{icon:"fa-regular fa-user",class:"icon"})]),e("div",_t,[e("p",mt,s(t.$t("distribution.title.inviteesCount")),1),e("p",bt,s(t.inviteesCount),1)]),i(f,{type:"primary",round:"",size:"small",class:"btn",onClick:t.goInvitees},{default:o(()=>[_(s(t.$t("distribution.button.detail")),1)]),_:1},8,["onClick"])]))]),_:1})]),_:1})]),_:1}),i(m,{gutter:15},{default:o(()=>[i(d,{md:12,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"level-info mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",vt,[e("h4",ft,s(t.$t("distribution.title.levelInfo")),1),e("div",gt,[e("div",kt,[e("p",null,s(t.$t("distribution.title.currentLevel"))+": L"+s(t.distributionStatus?.level?.level),1),e("p",null,s(t.$t("distribution.title.currentPercentage"))+": "+s(t.distributionLevelMap[t.distributionStatus?.level?.level]?.percentage)+"% ",1)]),e("div",wt,[e("p",null,s(t.$t("distribution.title.nextLevel"))+": L"+s(t.distributionStatus?.level?.level+1),1),e("p",null,s(t.$t("distribution.title.nextPercentage"))+": "+s(t.distributionLevelMap[t.distributionStatus?.level?.level+1]?.percentage)+"% ",1)])]),i(L,{"text-inside":!0,"stroke-width":20,percentage:t.getPercentageForNextLevel(),class:"mb-2"},null,8,["percentage"]),e("p",$t,s(t.$t("distribution.message.deltaPriceForNextLevel"))+": $"+s(t.getDeltaForNextLevel()),1),i($),t.distributionLevels?(n(),r(S,{key:0,data:t.distributionLevels,stripe:""},{default:o(()=>[i(g,{label:t.$t("distribution.field.level")},{default:o(h=>[e("span",yt,"L"+s(h.row?.level),1)]),_:1},8,["label"]),i(g,{label:t.$t("distribution.field.threshold")},{default:o(h=>[e("span",Lt,"$"+s(h.row?.threshold),1)]),_:1},8,["label"]),i(g,{label:t.$t("distribution.field.percentage")},{default:o(h=>[e("span",St,s(h.row?.percentage)+"%",1)]),_:1},8,["label"])]),_:1},8,["data"])):k("",!0)]))]),_:1})]),_:1}),i(d,{md:12,xs:24},{default:o(()=>[i(u,{shadow:"hover",class:"distribution-info mb-4"},{default:o(()=>[t.loading?(n(),r(c,{key:0})):(n(),p("div",Ct,[e("h4",Dt,s(t.$t("distribution.title.distributionLink")),1),i($),e("div",It,[k("",!0),e("a",{href:t.distributionLink,class:"link"},s(t.distributionLink),9,Et),i(C,{content:t.distributionLink},null,8,["content"])]),e("div",Ft,[t.distributionLink?(n(),r(D,{key:0,value:t.distributionLink,size:180,margin:2,class:"block mb-2 ml-auto mr-auto",type:"image/png",color:{dark:"#000000",light:"#ffffff"}},null,8,["value"])):k("",!0),e("p",Tt,s(t.$t("distribution.message.distributionQrDescription")),1)]),e("p",Nt,[_(s(t.$t("distribution.message.distributionLinkDescription"))+" ",1),e("span",Pt,[i(w,{effect:"dark",content:t.$t("distribution.message.distributionLinkDescription2"),placement:"top"},{default:o(()=>[_(s(t.$t("distribution.message.technicalDetail")),1)]),_:1},8,["content"])])])]))]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const jt=N(j,[["render",Ot],["__scopeId","data-v-a8befdf2"]]);export{jt as default};
@@ -0,0 +1 @@
1
+ import{bF as P,bQ as q}from"./vendor-BG5lCpoe.js";import{o as L,N as B,j as O,J as G,K as M,A as j,z,q as N,r as V,p as F,n as K,B as Y,i as Z}from"./vendor-element-plus-7rF3khck.js";import{d as $,c as r,a as l,l as t,P as U,S as u,al as o,o as a,Z as i,F as E,ai as T,R as I,Y as h,W as g,V as A}from"./vendor-vue-Bb02XvLT.js";import{_ as k,aY as H,aZ as J,a_ as Q,S as W,a$ as X,a6 as x,X as ee,a2 as te,a3 as C}from"./index-BWdK6S1P.js";import{I as D,S as se}from"./ScrollList-hBjgRYV4.js";import{I as oe}from"./ImagePreview-hdi2mrdI.js";import{C as ae,N as ne}from"./NoTasks-CgXSnfeV.js";import{a as ie}from"./price-DsQ2XKBW.js";import{C as le}from"./CopyToClipboard-Ab4hHs26.js";import{B as re}from"./BotPlaceholder-BU17vEUy.js";import{l as ce}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const pe=$({name:"LayoutPika",components:{ElDrawer:B,ElButton:L,FontAwesomeIcon:P},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},ue={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},me={class:"result h-full p-[15px] flex-1 flex flex-col"};function fe(e,s,c,d,v,b){const p=o("font-awesome-icon"),m=o("el-button"),n=o("el-drawer");return a(),r("div",de,[l("div",ue,[U(e.$slots,"config",{},void 0,!0)]),l("div",me,[U(e.$slots,"result",{},void 0,!0)]),t(m,{circle:"",class:"menu",onClick:s[0]||(s[0]=y=>e.drawer=!0)},{default:u(()=>[t(p,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=y=>e.drawer=y),direction:"ltr","with-header":!1,size:"350px"},{default:u(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=k(pe,[["render",fe],["__scopeId","data-v-80748529"]]),he=$({name:"IngredientsSelector",components:{ElSwitch:O,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=H)}}),ge={class:"field"},$e={class:"title font-bold"};function ke(e,s,c,d,v,b){const p=o("el-switch"),m=o("info-icon");return a(),r("div",ge,[l("h2",$e,i(e.$t("pika.name.ingredients")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value"},null,8,["modelValue"]),t(m,{content:e.$t("pika.description.ingredients"),class:"info"},null,8,["content"])])}const ve=k(he,[["render",ke],["__scopeId","data-v-17c0af5c"]]),be=$({name:"EffectSelector",components:{ElSelect:M,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})}}}}),ye={class:"field"},we={class:"title font-bold"},Ve={class:"float-left"};function Ie(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",ye,[l("h2",we,i(e.$t("pika.name.effect")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select"),clearable:""},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},{default:u(()=>[l("span",Ve,i(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Se=k(be,[["render",Ie],["__scopeId","data-v-d1c54475"]]),Ee=$({name:"IngredientsModelSelector",components:{ElRadioButton:z,ElRadioGroup:j},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)}}),Te={class:"field"},Ce={class:"title font-bold"};function Pe(e,s,c,d,v,b){const p=o("el-radio-button"),m=o("el-radio-group");return a(),r("div",Te,[l("h2",Ce,i(e.$t("pika.name.ingredientsModel")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),size:"small",class:"quality"},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.value},{default:u(()=>[h(i(n.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])}const Le=k(Ee,[["render",Pe],["__scopeId","data-v-b948551f"]]),Ae=$({name:"ModelSelector",components:{ElSelect:M,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=Q)}}),Re={class:"field"},Ue={class:"title font-bold"};function De(e,s,c,d,v,b){const p=o("el-option"),m=o("el-select");return a(),r("div",Re,[l("h2",Ue,i(e.$t("pika.name.model")),1),t(m,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("pika.placeholder.select")},{default:u(()=>[(a(!0),r(E,null,T(e.options,n=>(a(),I(p,{key:n.value,label:n.label,value:n.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=k(Ae,[["render",De],["__scopeId","data-v-7b2e870a"]]),Me=$({name:"ImageUrlInput",components:{ElUpload:N,ElButton:L,InfoIcon:D,ImagePreview:oe,FontAwesomeIcon:P},data(){return{fileList:[],uploadUrl:W()+"/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(){V.warning(this.$t("pika.message.uploadStartImageExceed"))},onError(){V.error(this.$t("pika.message.uploadStartImageError"))},async onRemove(){V.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()}}}),qe={class:"field"},Be={class:"title font-bold"},Oe={class:"upload-wrapper"};function je(e,s,c,d,v,b){const p=o("image-preview"),m=o("font-awesome-icon"),n=o("el-button"),y=o("el-upload"),_=o("info-icon");return a(),r("div",qe,[l("h2",Be,i(e.$t("pika.name.imageUrl")),1),l("div",Oe,[t(y,{"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 upload-wrapper",limit:3,multiple:!0,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:u(({file:f})=>[t(p,{url:f.url||f.response?.file_url,name:f.name,percentage:f.percentage,onRemove:S=>e.fileList.splice(e.fileList.indexOf(f),1)},null,8,["url","name","percentage","onRemove"])]),default:u(()=>[t(n,{size:"small",type:"primary",round:""},{default:u(()=>[t(m,{icon:"fa-solid fa-upload",class:"mr-1"}),h(" "+i(e.$t("pika.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])]),t(_,{content:e.$t("pika.description.imageUrl"),class:"info"},null,8,["content"])])}const ze=k(Me,[["render",je],["__scopeId","data-v-18cda67a"]]),Ne="",Fe=$({name:"PromptInput",components:{ElInput:F,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=Ne)}}),Ke={class:"field"},Ye={class:"box"},Ze={class:"title font-bold"};function He(e,s,c,d,v,b){const p=o("info-icon"),m=o("el-input");return a(),r("div",Ke,[l("div",Ye,[l("h2",Ze,i(e.$t("pika.name.prompt")),1),t(p,{content:e.$t("pika.description.prompt"),class:"info"},null,8,["content"])]),t(m,{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 Je=k(Fe,[["render",He],["__scopeId","data-v-b94e7a3e"]]),Qe=$({name:"PresetPanel",components:{ImageUrlInput:ze,ElButton:L,FontAwesomeIcon:P,Consumption:ae,PromptInput:Je,IngredientsSelector:ve,IngredientsModelSelector:Le,ModelSelector:Ge,EffectSelector:Se},emits:["generate"],computed:{config(){return this.$store.state.pika?.config},consumption(){return ie(this.config,this.service?.cost)},service(){return this.$store.state.pika?.service}},methods:{onGenerate(){this.$emit("generate")}}}),We={class:"flex flex-col h-full"},Xe={class:"flex-1 overflow-y-auto p-[15px]"},xe={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function et(e,s,c,d,v,b){const p=o("prompt-input"),m=o("model-selector"),n=o("ingredients-selector"),y=o("effect-selector"),_=o("image-url-input"),f=o("ingredients-model-selector"),S=o("consumption"),w=o("font-awesome-icon"),R=o("el-button");return a(),r("div",We,[l("div",Xe,[t(p,{class:"mb-4"}),t(m,{class:"mb-4"}),t(n,{class:"mb-4"}),t(y,{class:"mb-4"}),e.config?.ingredients?(a(),I(_,{key:0,class:"mb-4"})):g("",!0),e.config?.ingredients?(a(),I(f,{key:1,class:"mb-4"})):g("",!0)]),l("div",xe,[t(S,{value:e.consumption,service:e.service},null,8,["value","service"]),t(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:u(()=>[t(w,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+i(e.$t("pika.button.generate")),1)]),_:1},8,["onClick"])])])}const tt=k(Qe,[["render",et]]),st=$({name:"VideoPlayer",components:{VuePlyr:q},props:{modelValue:{type:Object,required:!0}},data(){return{options:{quality:{default:"1080p"}}}}}),ot=["data-poster"],at=["src"];function nt(e,s,c,d,v,b){const p=o("vue-plyr");return a(),r("div",null,[t(p,{options:e.options,class:"video"},{default:u(()=>[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,at)],8,ot)]),_:1},8,["options"])])}const it=k(st,[["render",nt],["__scopeId","data-v-fc420430"]]),lt=$({name:"TaskPreview",components:{ElImage:Z,CopyToClipboard:le,FontAwesomeIcon:P,ElAlert:Y,VideoPlayer:it,ElTooltip:K,ElButton:L},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(c=>{let d=c;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,c=new URL(s.src),d=c.searchParams.get("retry");if(!d)c.searchParams.set("retry","1");else if(parseInt(d)<2)c.searchParams.set("retry",(parseInt(d)+1).toString());else return;s.src=c.toString()},onOpenVideo(e){window.open(e,"_blank")}}}),rt={class:"left"},ct={class:"main"},pt={class:"bot"},dt={class:"datetime"},ut={class:"info"},mt={key:0,class:"prompt mt-2"},ft={key:0},_t={key:1},ht={key:0,class:A({content:!0,failed:!0})},gt={class:"image-wrapper"},$t={key:0,class:A({operations:!0,"mt-2":!0})},kt={key:0,class:"description"},vt={class:"description"},bt={key:1,class:A({content:!0})},yt={class:"description"},wt={class:"description"},Vt={class:"description"},It={key:2,class:A({content:!0})},St={class:"description"};function Et(e,s,c,d,v,b){const p=o("el-image"),m=o("VideoPlayer"),n=o("el-button"),y=o("el-tooltip"),_=o("font-awesome-icon"),f=o("copy-to-clipboard"),S=o("el-alert");return a(!0),r(E,null,T(e.videos,(w,R)=>(a(),r("div",{key:R,class:"preview"},[l("div",rt,[t(p,{src:"https://cdn.acedata.cloud/i80tgn.png",class:"avatar"})]),l("div",ct,[l("div",pt,[h(i(e.$t("pika.name.pikaBot"))+" ",1),l("span",dt,i(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),l("div",ut,[e.modelValue?.request?.prompt?(a(),r("p",mt,[h(i(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?g("",!0):(a(),r("span",ft," - ("+i(e.$t("pika.status.pending"))+") ",1)),w?.state==="processing"||w?.state==="pending"?(a(),r("span",_t," - ("+i(e.$t("pika.status.processing"))+") ",1)):g("",!0)])):g("",!0)]),e.modelValue?.response?.success===!0?(a(),r("div",ht,[l("div",gt,[t(m,{"model-value":w},null,8,["model-value"])]),w?(a(),r("div",$t,[t(y,{class:"box-item",effect:"dark",content:e.$t("pika.message.downloadVideo"),placement:"top-start"},{default:u(()=>[w?.video_url?(a(),I(n,{key:0,type:"info",size:"small",class:"btn-action",onClick:Mt=>e.onDownload(w?.video_url)},{default:u(()=>[h(i(e.$t("pika.button.download")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1032,["content"])])):g("",!0),t(S,{closable:!1,class:"mt-2 success"},{default:u(()=>[e.modelValue?.request?.model?(a(),r("p",kt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.model"))+": "+i(e.modelValue?.request?.model),1)])):g("",!0),l("p",vt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),e.modelValue?.response?.success===!1?(a(),r("div",bt,[t(S,{closable:!1,class:"failure"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",yt,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),l("p",wt,[t(_,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+i(e.$t("pika.name.failureReason"))+": "+i(e.modelValue?.response?.error?.message)+" ",1),t(f,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),l("p",Vt,[t(_,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+i(e.$t("pika.name.traceId"))+": "+i(e.modelValue?.response?.trace_id)+" ",1),t(f,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0),!e.modelValue?.response||w?.state==="processing"||w?.state==="pending"?(a(),r("div",It,[t(S,{closable:!1,class:"info"},{template:u(()=>[t(_,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+i(e.$t("pika.name.failure")),1)]),default:u(()=>[l("p",St,[t(_,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+i(e.$t("pika.name.taskId"))+": "+i(e.modelValue?.id)+" ",1),t(f,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):g("",!0)])]))),128)}const Tt=k(lt,[["render",Et],["__scopeId","data-v-4c2810f1"]]),Ct=$({name:"RecentPanel",components:{TaskPreview:Tt,BotPlaceholder:re,NoTasks:ne,ScrollList:se},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.pika?.tasks,items:this.$store.state.pika?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Pt={key:0},Lt={key:2,class:"w-full h-full flex items-center justify-center"};function At(e,s,c,d,v,b){const p=o("bot-placeholder"),m=o("task-preview"),n=o("scroll-list"),y=o("no-tasks");return a(),r(E,null,[e.tasks?.items===void 0?(a(),r("div",Pt,[t(p)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),I(n,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=_=>e.$emit("reach-top"))},{default:u(()=>[(a(!0),r(E,null,T(e.tasks?.items,(_,f)=>(a(),I(m,{key:f,"model-value":_},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(a(),r("div",Lt,[t(y)])):g("",!0)],64)}const Rt=k(Ct,[["render",At]]),Ut="https://webhook.acedata.cloud/pika",Dt=$({name:"PikaIndex",components:{ConfigPanel:tt,Layout:_e,RecentPanel:Rt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.pika?.status?.getApplications===C.Request},tasksLoading(){return this.$store.state.pika?.status?.getTasks===C.Request||this.fetchingTasks},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===C.Request},needApply(){return this.$store.state.pika.status.getApplications===C.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},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await ce({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("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(){ee.create({application:this.application}).then(({data:e})=>{this.application=e,V.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===te&&V.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:s=5,createdAtMin:c,createdAtMax:d}=e||{};console.debug("limit",s,"createdAtMin",c,"createdAtMax",d),this.fetchingTasks=!0;try{await this.$store.dispatch("pika/getTasks",{limit:s,createdAtMin:c,createdAtMax:d})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Ut},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("pika.message.startingTask")),X.generate(e,{token:s}).then(()=>{V.success(this.$t("pika.message.startTaskSuccess")),this.$store.commit("pika/setConfig",{config:void 0})}).catch(c=>{c?.response?.data?.error?.code===x?V.error(this.$t("pika.message.usedUp")):V.error(this.$t("pika.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Gt(e,s,c,d,v,b){const p=o("config-panel"),m=o("recent-panel"),n=o("layout");return a(),I(n,null,{config:u(()=>[t(p,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:u(()=>[t(m,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const xt=k(Dt,[["render",Gt],["__scopeId","data-v-456819d1"]]);export{xt as default};
@@ -0,0 +1 @@
1
+ import{bF as q}from"./vendor-BG5lCpoe.js";import{o as U,N as W,p as H,q as K,r as I,J as B,K as G,n as x,B as J,i as Y}from"./vendor-element-plus-7rF3khck.js";import{d as k,c as l,a as c,l as a,P,S as $,al as s,o as n,Z as o,Y as u,F as V,ai as N,R as A,W as f,V as C,a1 as Z}from"./vendor-vue-Bb02XvLT.js";import{_ as y,S as Q,bB as X,bC as ee,bD as T,bE as S,bF as M,bG as j,bH as D,bI as te,a6 as ae,a3 as F}from"./index-BWdK6S1P.js";import{I as O,S as oe}from"./ScrollList-hBjgRYV4.js";import{I as z}from"./ImagePreview-hdi2mrdI.js";import{C as ne,N as se}from"./NoTasks-CgXSnfeV.js";import{a as le}from"./price-DsQ2XKBW.js";import{C as re}from"./CopyToClipboard-Ab4hHs26.js";import{I as ie}from"./ImageWrapper-D9v7ltO5.js";import{B as ce}from"./BotPlaceholder-BU17vEUy.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const ue=k({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:U,FontAwesomeIcon:q},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},me={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},pe={class:"result h-full p-[15px] flex-1 flex flex-col"};function fe(e,t,b,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),m=s("el-drawer");return n(),l("div",de,[c("div",me,[P(e.$slots,"config",{},void 0,!0)]),c("div",pe,[P(e.$slots,"result",{},void 0,!0)]),a(g,{circle:"",class:"menu",onClick:t[0]||(t[0]=p=>e.drawer=!0)},{default:$(()=>[a(_,{icon:"fa-solid fa-magic"})]),_:1}),a(m,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=p=>e.drawer=p),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[P(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const he=y(ue,[["render",fe],["__scopeId","data-v-3794959b"]]),_e="",ge=k({name:"PromptInput",components:{ElInput:H,InfoIcon:O},computed:{prompt:{get(){return this.$store.state.nanobanana?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=_e)}}),be={class:"field"},$e={class:"box"},ve={class:"title font-bold"};function ke(e,t,b,r,d,h){const _=s("info-icon"),g=s("el-input");return n(),l("div",be,[c("div",$e,[c("h2",ve,o(e.$t("nanobanana.name.prompt")),1),a(_,{content:e.$t("nanobanana.description.prompt"),class:"info"},null,8,["content"])]),a(g,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=m=>e.prompt=m),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("nanobanana.placeholder.prompt"),maxlength:300,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const ye=y(ge,[["render",ke],["__scopeId","data-v-38b040ab"]]),we=k({name:"ImageUrlsInput",components:{ElUpload:K,ElButton:U,InfoIcon:O,ImagePreview:z,FontAwesomeIcon:q},data(){return{fileList:[],uploadUrl:Q()+"/api/v1/files/",suppressWatch:!1}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url).filter(e=>!!e)},value(){return this.$store.state.nanobanana?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const r=(this.fileList||[]).filter(d=>!d?.response?.file_url);this.fileList=r.length?r:[];return}const t=[];e.forEach(r=>{const d=this.fileList.find(h=>h?.response?.file_url===r||h?.url===r);d?t.push(d):t.push({name:r.split("/").pop()||r,url:r,status:"success",percentage:100,response:{file_url:r}})}),(this.fileList||[]).filter(r=>!r?.response?.file_url).forEach(r=>{t.some(h=>h===r||h?.url===r?.url||h?.response?.file_url===r?.response?.file_url)||t.push(r)}),this.fileList=t}}},mounted(){},methods:{onChange(e){if(!e?.url&&e?.raw)try{e.url=URL.createObjectURL(e.raw)}catch{}},onRemove(e){if(e?.url&&typeof e.url=="string"&&e.url.startsWith("blob:"))try{URL.revokeObjectURL(e.url)}catch{}this.onSetImageUrls()},onExceed(){I.warning(this.$t("nanobanana.message.uploadImageExceed"))},onError(){I.error(this.$t("nanobanana.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,image_urls:e}),this.$nextTick(()=>{this.suppressWatch=!1})},async onSuccess(e,t){e?.file_url&&(t.url=e.file_url,t.response=e),this.onSetImageUrls()},onRemovePreview(e,t){if(this.fileList.splice(e,1),t?.url&&typeof t.url=="string"&&t.url.startsWith("blob:"))try{URL.revokeObjectURL(t.url)}catch{}this.onSetImageUrls()}}}),Ve={class:"field flex items-center justify-between"},Ae={class:"title font-bold text-[14px] mb-[10px]"},Ne={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Re={class:"controls flex items-center"},Ie={class:"file-list flex flex-wrap gap-[10px]"};function Ee(e,t,b,r,d,h){const _=s("font-awesome-icon"),g=s("el-button"),m=s("el-upload"),p=s("info-icon"),w=s("image-preview");return n(),l(V,null,[c("div",Ve,[c("h2",Ae,o(e.$t("nanobanana.name.imageUrls")),1),c("div",Ne,[c("div",Re,[a(m,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=i=>e.fileList=i),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file",class:"value",limit:5,multiple:!0,"show-file-list":!1,action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-change":e.onChange,"on-remove":e.onRemove,headers:e.headers},{default:$(()=>[a(g,{size:"small",type:"primary",round:""},{default:$(()=>[a(_,{icon:"fa-solid fa-upload",class:"mr-1"}),u(" "+o(e.$t("nanobanana.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),a(p,{content:e.$t("nanobanana.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Ie,[(n(!0),l(V,null,N(e.fileList,(i,v)=>(n(),A(w,{key:i.uid||i?.response?.file_url||i.url||v,url:i.url||i?.response?.file_url,name:i.name,percentage:i.percentage,onRemove:R=>e.onRemovePreview(v,i)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Le=y(we,[["render",Ee]]),Se=k({name:"AspectRatioSelector",components:{ElSelect:G,ElOption:B},data(){return{options:["1:1","3:2","2:3","16:9","9:16","4:3","3:4"]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.aspect_ratio},set(e){console.debug("set aspect_ratio",e);const t={...this.$store.state.nanobanana?.config||{}};e?t.aspect_ratio=e:delete t.aspect_ratio,this.$store.commit("nanobanana/setConfig",t)}}}}),Te={class:"field"},qe={class:"title font-bold"};function Ue(e,t,b,r,d,h){const _=s("el-option"),g=s("el-select");return n(),l("div",Te,[c("h2",qe,o(e.$t("nanobanana.name.aspectRatio")),1),a(g,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=m=>e.value=m),class:"value",clearable:"",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(V,null,N(e.options,m=>(n(),A(_,{key:m,label:m,value:m},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ce=y(Se,[["render",Ue],["__scopeId","data-v-67f08a08"]]),Oe=k({name:"NanobananaModelSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{options:[{value:ee,label:this.$t("nanobanana.model.nanoBanana")},{value:T,label:this.$t("nanobanana.model.nanoBananaPro")}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.model},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,model:e})}},modelDescription(){return this.$t("nanobanana.description.model")}},mounted(){this.value||(this.value=X)}}),Pe={class:"field"},Be={class:"label"},Ge={class:"box"},Me={class:"title font-bold"};function je(e,t,b,r,d,h){const _=s("info-icon"),g=s("el-option"),m=s("el-select");return n(),l("div",Pe,[c("div",Be,[c("div",Ge,[c("h2",Me,o(e.$t("nanobanana.name.model")),1),a(_,{content:e.modelDescription,class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select")},{default:$(()=>[(n(!0),l(V,null,N(e.options,p=>(n(),A(g,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const De=y(Oe,[["render",je],["__scopeId","data-v-e279ee32"]]),Fe=k({name:"NanobananaResolutionSelector",components:{ElSelect:G,ElOption:B,InfoIcon:O},data(){return{cachedResolution:S,options:[{value:M,label:M},{value:j,label:j},{value:D,label:D}]}},computed:{value:{get(){return this.$store.state.nanobanana?.config?.resolution},set(e){this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:e})}},isProModel(){return this.$store.state.nanobanana?.config?.model===T}},watch:{value(e){this.isProModel&&e&&(this.cachedResolution=e)},isProModel(e){e?this.value||(this.value=this.cachedResolution||S):(this.value&&(this.cachedResolution=this.value),this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}},mounted(){this.isProModel&&!this.value&&(this.value=S),!this.isProModel&&this.value&&(this.cachedResolution=this.value,this.$store.commit("nanobanana/setConfig",{...this.$store.state.nanobanana?.config,resolution:void 0}))}}),ze={class:"field"},We={class:"label"},He={class:"box"},Ke={class:"title font-bold"};function xe(e,t,b,r,d,h){const _=s("info-icon"),g=s("el-option"),m=s("el-select");return n(),l("div",ze,[c("div",We,[c("div",He,[c("h2",Ke,o(e.$t("nanobanana.name.resolution")),1),a(_,{content:e.$t("nanobanana.description.resolutionProOnly"),class:"info"},null,8,["content"])])]),a(m,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=p=>e.value=p),class:"value",placeholder:e.$t("nanobanana.placeholder.select"),disabled:!e.isProModel},{default:$(()=>[(n(!0),l(V,null,N(e.options,p=>(n(),A(g,{key:p.value,label:p.label,value:p.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder","disabled"])])}const Je=y(Fe,[["render",xe],["__scopeId","data-v-05ae87bb"]]),Ye=k({name:"ConfigPanel",components:{ElButton:U,FontAwesomeIcon:q,PromptInput:ye,Consumption:ne,ImageUrlsInput:Le,AspectRatioSelector:Ce,ModelSelector:De,ResolutionSelector:Je},emits:["generate"],computed:{config(){return this.$store.state.nanobanana?.config},consumption(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;return le({...e,action:t?"edit":"generate"},this.service?.cost)},service(){return this.$store.state.nanobanana?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},Qe={class:"flex-1 overflow-y-auto p-[15px]"},Xe={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function et(e,t,b,r,d,h){const _=s("model-selector"),g=s("resolution-selector"),m=s("prompt-input"),p=s("aspect-ratio-selector"),w=s("image-urls-input"),i=s("consumption"),v=s("font-awesome-icon"),R=s("el-button");return n(),l("div",Ze,[c("div",Qe,[a(_,{class:"mb-4"}),a(g,{class:"mb-4"}),a(m,{class:"mb-4"}),a(p,{class:"mb-4"}),a(w,{class:"mb-4"})]),c("div",Xe,[a(i,{value:e.consumption,service:e.service},null,8,["value","service"]),a(R,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[a(v,{icon:"fa-solid fa-magic",class:"mr-2"}),u(" "+o(e.$t("nanobanana.button.generate")),1)]),_:1},8,["onClick"])])])}const tt=y(Ye,[["render",et]]),at=k({name:"TaskPreview",components:{ElImage:Y,CopyToClipboard:re,FontAwesomeIcon:q,ElAlert:J,ImageWrapper:ie,ElButton:U,ElTooltip:x,ImagePreview:z},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{e.push(t)}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.nanobanana?.config||{}};delete t.action,t.image_urls=[e],this.$store.commit("nanobanana/setConfig",t)}}}),ot={class:"preview"},nt={class:"left"},st={class:"main"},lt={class:"bot"},rt={class:"datetime"},it={class:"info"},ct={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},ut={key:1,class:"prompt mt-2"},dt={key:0},mt={key:0,class:C({content:!0,failed:!0})},pt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},ft={class:C({operations:!0,"mt-2":!0,"mb-2":!0})},ht={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},_t={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},gt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},$t={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},kt={key:1,class:C({content:!0})},yt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Nt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},It={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Et={key:2,class:C({content:!0})},Lt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},St={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},qt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Ut={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Ct(e,t,b,r,d,h){const _=s("el-image"),g=s("image-preview"),m=s("image-wrapper"),p=s("el-button"),w=s("el-tooltip"),i=s("font-awesome-icon"),v=s("copy-to-clipboard"),R=s("el-alert");return n(),l("div",ot,[c("div",nt,[a(_,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",st,[c("div",lt,[u(o(e.$t("nanobanana.name.nanobananaBot"))+" ",1),c("span",rt,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",it,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(n(),l("div",ct,[(n(!0),l(V,null,N(e.modelValue?.request?.image_urls,(E,L)=>(n(),A(g,{key:L,url:E,name:`image-${L+1}`,closable:!1},null,8,["url","name"]))),128))])):f("",!0),e.modelValue?.request?.prompt?(n(),l("p",ut,[u(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?f("",!0):(n(),l("span",dt," - ("+o(e.$t("nanobanana.status.pending"))+") ",1))])):f("",!0)]),e.modelValue?.response?.success===!0?(n(),l("div",mt,[c("div",pt,[(n(!0),l(V,null,N(e.images,(E,L)=>(n(),A(m,{key:L,src:E?.image_url,"raw-src":E?.image_url},null,8,["src","raw-src"]))),128))]),c("div",ft,[a(w,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[a(p,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Z(E=>e.onEdit(e.images?.[0]?.image_url),["stop"]))},{default:$(()=>[u(o(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),a(R,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(n(),l("p",ht,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",_t,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",gt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",bt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),c("p",$t,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),l("p",vt,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):f("",!0)]),_:1})])):f("",!0),e.modelValue?.response?.success===!1?(n(),l("div",kt,[a(R,{closable:!1,class:"failure"},{template:$(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",yt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",wt,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Vt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",At,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),c("p",Nt,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",Rt,[a(i,{icon:"fa-solid fa-circle-info",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),a(v,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),l("p",It,[a(i,{icon:"fa-solid fa-hashtag",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),a(v,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):f("",!0)]),_:1})])):f("",!0),!e.modelValue?.response||!e.modelValue?.response?.data?.[0]?.image_url?(n(),l("div",Et,[a(R,{closable:!1,class:"info"},{template:$(()=>[a(i,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(n(),l("p",Lt,[a(i,{icon:"fa-solid fa-cube",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.model"))+": "+o(e.modelValue?.request?.model),1)])):f("",!0),e.modelValue?.request?.resolution?(n(),l("p",St,[a(i,{icon:"fa-solid fa-image",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.resolution"))+": "+o(e.modelValue?.request?.resolution),1)])):f("",!0),e.modelValue?.request?.aspect_ratio?(n(),l("p",Tt,[a(i,{icon:"fa-solid fa-up-right-from-square",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.aspectRatio"))+": "+o(e.modelValue?.request?.aspect_ratio),1)])):f("",!0),e.modelValue?.request?.action?(n(),l("p",qt,[a(i,{icon:"fa-solid fa-bolt",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.task"))+": "+o(e.modelValue?.request?.action==="generate"?e.$t("nanobanana.name.generate"):e.$t("nanobanana.name.edits")),1)])):f("",!0),c("p",Ut,[a(i,{icon:"fa-solid fa-magic",class:"mr-1"}),u(" "+o(e.$t("nanobanana.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),a(v,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})])):f("",!0)])])}const Ot=y(at,[["render",Ct],["__scopeId","data-v-9e0f580a"]]),Pt=k({name:"RecentPanel",components:{TaskPreview:Ot,BotPlaceholder:ce,NoTasks:se,ScrollList:oe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.nanobanana?.tasks,items:this.$store.state.nanobanana?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Bt={key:0},Gt={key:2,class:"w-full h-full flex items-center justify-center"};function Mt(e,t,b,r,d,h){const _=s("bot-placeholder"),g=s("task-preview"),m=s("scroll-list"),p=s("no-tasks");return n(),l(V,null,[e.tasks?.items===void 0?(n(),l("div",Bt,[a(_)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),A(m,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=w=>e.$emit("reach-top"))},{default:$(()=>[(n(!0),l(V,null,N(e.tasks?.items,w=>(n(),A(g,{key:w.id,"model-value":w},null,8,["model-value"]))),128))]),_:1},8,["loading"])):f("",!0),e.tasks?.items?.length===0?(n(),l("div",Gt,[a(p)])):f("",!0)],64)}const jt=y(Pt,[["render",Mt]]),Dt="https://webhook.acedata.cloud/nanobanana",Ft=k({name:"NanobananaIndex",components:{ConfigPanel:tt,Layout:he,RecentPanel:jt},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.nanobanana?.status?.getApplications===F.Request},tasksLoading(){return this.$store.state.nanobanana?.status?.getTasks===F.Request},credential(){return this.$store.state.nanobanana?.credential},config(){return this.$store.state.nanobanana?.config},application(){return this.$store.state.nanobanana?.application},tasks(){return this.$store.state.nanobanana?.tasks}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){if(console.debug("reached top"),this.loading||this.tasksLoading)return;const e=this.tasks?.total,t=this.tasks?.items?.length||0;if(e!==void 0&&e<=t)return;const b=this.tasks?.items?.[0];if(!b?.created_at)return;const d=this.$refs.recentPanel?.getScrollElement?.(),h=d?.scrollHeight||0,_=d?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:b.created_at}),await this.$nextTick(),d){const g=d.scrollHeight;d.scrollTop=g-h+_}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("nanobanana/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("nanobanana/getApplications"),console.debug("end onGetApplication"),await this.onGetTasks()},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.tasksLoading){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=20,createdAtMin:b,createdAtMax:r}=e||{};console.debug("limit",t,"createdAtMin",b,"createdAtMax",r),await this.$store.dispatch("nanobanana/getTasks",{limit:t,createdAtMin:b,createdAtMax:r})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;delete e.action,!t&&"image_urls"in e&&delete e.image_urls,e?.aspect_ratio||delete e.aspect_ratio,e?.model!==T&&"resolution"in e&&delete e.resolution,e?.model===T&&!e?.resolution&&(e.resolution=S);const b={...e,action:t?"edit":"generate",callback_url:Dt},r=this.credential?.token;if(!r){console.error("no token specified");return}I.info(this.$t("nanobanana.message.startingTask")),te.generate(b,{token:r}).then(()=>{I.success(this.$t("nanobanana.message.startTaskSuccess"))}).catch(d=>{const h=d?.response?.data;h?.error?.code===ae?I.error(this.$t("nanobanana.message.usedUp")):I.error(this.$t("nanobanana.message.startTaskFailed")+(h?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function zt(e,t,b,r,d,h){const _=s("config-panel"),g=s("recent-panel"),m=s("layout");return n(),A(m,null,{config:$(()=>[a(_,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[a(g,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const la=y(Ft,[["render",zt]]);export{la as default};
@@ -0,0 +1 @@
1
+ import{bF as B,bR as Y,bS as H,l as oe,bT as se,bU as G,bV as ne,bW as ie,bX as ae,bY as le}from"./vendor-BG5lCpoe.js";import{o as J,N as re,j as ee,J as ce,K as ue,q as de,r as k,p as N,P as pe,e as W,i as X,f as me,g as he,h as _e,n as fe,Q as te,U as $e,G as ge,T as ve,V as ye}from"./vendor-element-plus-7rF3khck.js";import{d as y,c as d,a as s,l as o,P as M,S as p,al as a,o as i,Z as m,F as j,ai as O,R as v,Y as I,W as g,U as K,as as Q,a1 as T,b as E,z as S,w as ke,X as we,_ as be}from"./vendor-vue-Bb02XvLT.js";import{_ as w,bz as Z,bA as q,S as Ce,a3 as L,X as Ve,a2 as Ae}from"./index-BWdK6S1P.js";import{I as F,S as Pe}from"./ScrollList-hBjgRYV4.js";import{C as Se,N as Te}from"./NoTasks-CgXSnfeV.js";import{a as Ie}from"./price-DsQ2XKBW.js";import{l as Ee}from"./pagination-dbPQoMuV.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";const Ue=y({name:"LayoutSuno",components:{ElDrawer:re,ElButton:J,FontAwesomeIcon:B},data(){return{drawer:!1,preview:!1}},computed:{}}),Le={class:"main flex flex-row flex-1"},je={class:"config w-[300px] h-full overflow-y-scroll border-r border-[var(--el-border-color)]"},De={class:"result h-full flex flex-col flex-1 border-r border-[var(--el-border-color)]"},Ge={class:"preview h-full w-[300px] flex flex-col"};function Fe(e,t,l,n,u,r){const c=a("font-awesome-icon"),h=a("el-button"),_=a("el-drawer");return i(),d("div",Le,[s("div",je,[M(e.$slots,"config",{},void 0,!0)]),s("div",De,[M(e.$slots,"result",{},void 0,!0)]),s("div",Ge,[M(e.$slots,"preview",{},void 0,!0)]),o(h,{circle:"",class:"menu",onClick:t[0]||(t[0]=f=>e.drawer=!0)},{default:p(()=>[o(c,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=f=>e.drawer=f),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:p(()=>[M(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Re=w(Ue,[["render",Fe],["__scopeId","data-v-6cc632e5"]]),ze=y({name:"VersionSelector",components:{ElSelect:ue,ElOption:ce,ElSwitch:ee},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"},{label:this.$t("suno.model.model45plus"),value:"chirp-v4-5-plus"},{label:this.$t("suno.model.model5"),value:"chirp-v5"}]}},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",Z),this.model=Z)}}),Me={class:"field"},Oe={class:"title font-bold"};function qe(e,t,l,n,u,r){const c=a("el-switch"),h=a("el-option"),_=a("el-select");return i(),d("div",Me,[s("h2",Oe,m(e.$t("suno.name.type")),1),o(c,{modelValue:e.custom,"onUpdate:modelValue":t[0]||(t[0]=f=>e.custom=f),class:"value"},null,8,["modelValue"]),o(_,{modelValue:e.model,"onUpdate:modelValue":t[1]||(t[1]=f=>e.model=f),class:"value",placeholder:e.$t("suno.placeholder.select")},{default:p(()=>[(i(!0),d(j,null,O(e.options,f=>(i(),v(h,{key:f.value,label:f.label,value:f.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Be=w(ze,[["render",qe],["__scopeId","data-v-5ebe40d6"]]),Ne=y({name:"UploadAudio",components:{ElUpload:de,ElButton:J,InfoIcon:F,FontAwesomeIcon:B},emits:["change"],data(){return{fileList:[],uploadUrl:Ce()+"/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(){k.warning(this.$t("suno.message.uploadReferencesExceed"))},onError(){k.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},l=this.credential?.token;if(!l){console.error("no token specified");return}k.info(this.$t("suno.message.startingUploadAudio")),q.upload(t,{token:l}).then(n=>{console.debug("get upload music success",n.data);const u=n.data?.data.audio_id;this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,audio_id:u,action:"upload_extend"}),k.success(this.$t("suno.message.startUploadAudioSuccess"))}).catch(n=>{k.error(n?.response?.data?.error?.message||this.$t("suno.message.startUploadAudioFailed"))})},onSetAudio(){}}}),We={class:"relative"},Xe={class:"flex justify-between"},Ke={class:"flex justify-start items-center"},Ye={class:"text-sm font-bold"};function He(e,t,l,n,u,r){const c=a("info-icon"),h=a("font-awesome-icon"),_=a("el-button"),f=a("el-upload");return i(),d("div",We,[s("div",Xe,[s("div",Ke,[s("span",Ye,m(e.$t("suno.name.referenceAudios")),1),o(c,{content:e.$t("suno.description.uploadAudios")},null,8,["content"])])]),o(f,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=C=>e.fileList=C),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:p(()=>[o(_,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[o(h,{icon:"fa-solid fa-upload",class:"icon mr-1"}),I(" "+m(e.$t("suno.button.uploadAudios")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","headers"])])}const Je=w(Ne,[["render",He],["__scopeId","data-v-6236152c"]]),Qe="",Ze=y({name:"PromptInput",components:{ElInput:N,ElSwitch:ee,InfoIcon:F},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=Qe)}}),xe={class:"field"},et={class:"box"},tt={class:"title-info"},ot={class:"title font-bold"},st={class:"instrumental"},nt={class:"title inline-block"};function it(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-switch"),_=a("el-input");return i(),d("div",xe,[s("div",et,[s("div",tt,[s("h2",ot,m(e.$t("suno.name.prompt")),1),o(c,{content:e.$t("suno.description.prompt"),class:"info"},null,8,["content"])]),s("div",st,[o(h,{modelValue:e.instrumental,"onUpdate:modelValue":t[0]||(t[0]=f=>e.instrumental=f),class:"value mr-2"},null,8,["modelValue"]),s("h2",nt,m(e.$t("suno.name.instrumental")),1)])]),o(_,{modelValue:e.prompt,"onUpdate:modelValue":t[1]||(t[1]=f=>e.prompt=f),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("suno.placeholder.prompt"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const at=w(Ze,[["render",it],["__scopeId","data-v-d7004a7c"]]),lt="",rt=y({name:"LyricInput",components:{ElInput:N,InfoIcon:F},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=lt)}}),ct={class:"field"},ut={class:"box"},dt={class:"title font-bold"};function pt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",ct,[s("div",ut,[s("h2",dt,m(e.$t("suno.name.lyrics")),1),o(c,{content:e.$t("suno.description.lyrics"),class:"info"},null,8,["content"])]),e.config?.action!=="extend"?(i(),v(h,{key:0,modelValue:e.lyric,"onUpdate:modelValue":t[0]||(t[0]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"])):(i(),v(h,{key:1,modelValue:e.lyric,"onUpdate:modelValue":t[1]||(t[1]=_=>e.lyric=_),rows:3,type:"textarea",class:"lyrics",placeholder:e.$t("suno.placeholder.extend.lyrics"),maxlength:3e3,"show-word-limit":""},null,8,["modelValue","placeholder"]))])}const mt=w(rt,[["render",pt],["__scopeId","data-v-99dfded8"]]),ht=y({name:"StyleInput",components:{ElInput:N,InfoIcon:F},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}}}),_t={class:"field"},ft={class:"title-container"},$t={class:"titlefont-bold"};function gt(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",_t,[s("div",ft,[s("h2",$t,m(e.$t("suno.name.style")),1),o(c,{content:e.$t("suno.description.style"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.style,"onUpdate:modelValue":t[0]||(t[0]=_=>e.style=_),rows:3,type:"textarea",class:"style",placeholder:e.$t("suno.placeholder.style"),maxlength:200,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const vt=w(ht,[["render",gt],["__scopeId","data-v-85bbfcaa"]]),yt=y({name:"TitleInput",components:{ElInput:N,InfoIcon:F},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})}}}}),kt={class:"field"},wt={class:"title-container"},bt={class:"title font-bold"};function Ct(e,t,l,n,u,r){const c=a("info-icon"),h=a("el-input");return i(),d("div",kt,[s("div",wt,[s("h2",bt,m(e.$t("suno.name.title")),1),o(c,{content:e.$t("suno.description.title"),class:"info"},null,8,["content"])]),o(h,{modelValue:e.title,"onUpdate:modelValue":t[0]||(t[0]=_=>e.title=_),rows:3,type:"textarea",class:"title",placeholder:e.$t("suno.placeholder.title"),maxlength:80,"show-word-limit":""},null,8,["modelValue","placeholder"])])}const Vt=w(yt,[["render",Ct],["__scopeId","data-v-ce70fe34"]]);function D(e){const t=Math.floor(e)%60;e=Math.floor(e/60);const l=e%60,n=l<10?`0${l}`:l,u=t<10?`0${t}`:t;return n+":"+u}const At=y({name:"ExtendFromInput",components:{ElImage:X,ElIcon:W,ElInputNumber:pe,VideoPlay:H,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){if(e===void 0){this.value=void 0;return}e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:D,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})}}}),Pt={class:"field"},St={class:"box"},Tt={class:"title font-bold"},It={class:"input-wrapper"},Et={class:"task"},Ut={class:"left"},Lt={key:2,class:"duration"},jt={class:"info"},Dt={class:"title"},Gt={class:"style"};function Ft(e,t,l,n,u,r){const c=a("el-input-number"),h=a("el-image"),_=a("video-pause"),f=a("el-icon"),C=a("video-play"),V=Q("loading");return i(),d("div",Pt,[s("div",St,[s("h2",Tt,m(e.$t("suno.name.extend")),1),s("div",It,[o(c,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=b=>e.value=b),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"])])]),s("div",Et,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[3]||(t[3]=b=>e.onClick(e.audio))},[K((i(),d("div",Ut,[o(h,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[1]||(t[1]=b=>e.onPause(e.audio))},[o(f,null,{default:p(()=>[o(_)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[2]||(t[2]=b=>e.onPlay(e.audio))},[o(f,null,{default:p(()=>[o(C)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Lt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[V,!e.audio?.audio_url]]),s("div",jt,[s("h2",Dt,m(e.audio?.title),1),s("p",Gt,m(e.audio?.style),1)])])):g("",!0)])])}const Rt=w(At,[["render",Ft],["__scopeId","data-v-bcce4821"]]),zt=y({name:"CoverFromInput",components:{ElImage:X,ElIcon:W,VideoPlay:H,VideoPause:Y},data(){return{}},computed:{audio(){return this.$store.state.suno?.config?.audio},value:{get(){return this.$store.state.suno?.config?.continue_at},set(e){console.debug("set continue_at",e),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,continue_at:e?parseInt(e):void 0})}}},mounted(){this.value||(this.value=void 0)},methods:{handleChange(e){e<0?this.value=0:e>this.audio?.duration?this.value=this.audio?.duration:this.value=e},useFormatDuring:D,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})}}}),Mt={class:"field"},Ot={class:"box"},qt={class:"title font-bold"},Bt={class:"task"},Nt={class:"left"},Wt={key:2,class:"duration"},Xt={class:"info"},Kt={class:"title"},Yt={class:"style"};function Ht(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=Q("loading");return i(),d("div",Mt,[s("div",Ot,[s("h2",qt,m(e.$t("suno.name.cover")),1)]),s("div",Bt,[e.audio?(i(),d("div",{key:0,class:"audio",onClick:t[2]||(t[2]=V=>e.onClick(e.audio))},[K((i(),d("div",Nt,[o(c,{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"?(i(),d("div",{key:0,class:"overlay",onClick:t[0]||(t[0]=V=>e.onPause(e.audio))},[o(_,null,{default:p(()=>[o(h)]),_:1})])):g("",!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")?(i(),d("div",{key:1,class:"overlay",onClick:t[1]||(t[1]=V=>e.onPlay(e.audio))},[o(_,null,{default:p(()=>[o(f)]),_:1})])):g("",!0),e.audio?.duration?(i(),d("div",Wt,m(e.useFormatDuring(e.audio?.duration)),1)):g("",!0)])),[[C,!e.audio?.audio_url]]),s("div",Xt,[s("h2",Kt,m(e.audio?.title),1),s("p",Yt,m(e.audio?.style),1)])])):g("",!0)])])}const Jt=w(zt,[["render",Ht],["__scopeId","data-v-06640216"]]),Qt=y({name:"PresetPanel",components:{TypeSelector:Be,PromptInput:at,LyricInput:mt,StyleInput:vt,TitleInput:Vt,ExtendFromInput:Rt,CoverFromInput:Jt,UploadAudio:Je,FontAwesomeIcon:B,ElButton:J,Consumption:Se},emits:["generate"],computed:{config(){return this.$store.state.suno?.config},consumption(){return Ie(this.config,this.service?.cost)},service(){return this.$store.state.suno?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Zt={class:"flex flex-col h-full"},xt={class:"flex-1 overflow-y-auto p-[15px]"},eo={class:"flex flex-col items-center justify-center px-[15px] pb-[15px]"};function to(e,t,l,n,u,r){const c=a("type-selector"),h=a("upload-audio"),_=a("prompt-input"),f=a("lyric-input"),C=a("style-input"),V=a("title-input"),b=a("extend-from-input"),A=a("cover-from-input"),R=a("consumption"),U=a("font-awesome-icon"),z=a("el-button");return i(),d("div",Zt,[s("div",xt,[o(c,{class:"mb-4"}),o(h,{class:"mb-4"}),e.config?.custom?g("",!0):(i(),v(_,{key:0,class:"mb-4"})),e.config?.custom&&!e.config.instrumental?(i(),v(f,{key:1,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(C,{key:2,class:"mb-4"})):g("",!0),e.config?.custom?(i(),v(V,{key:3,class:"mb-4"})):g("",!0),e.config?.action==="extend"?(i(),v(b,{key:4,class:"mb-4"})):g("",!0),e.config?.action==="cover"?(i(),v(A,{key:5,class:"mb-4"})):g("",!0)]),s("div",eo,[o(R,{value:e.consumption,service:e.service},null,8,["value","service"]),e.config?.action!=="extend"?(i(),v(z,{key:0,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.generate")),1)]),_:1},8,["onClick"])):(i(),v(z,{key:1,type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[o(U,{icon:"fa-solid fa-magic",class:"mr-2"}),I(" "+m(e.$t("suno.button.extend")),1)]),_:1},8,["onClick"]))])])}const oo=w(Qt,[["render",to],["__scopeId","data-v-8c98e5e5"]]),so="https://webhook.acedata.cloud/suno",no=y({name:"TaskPreview",components:{ElImage:X,ElIcon:W,ElTooltip:fe,FontAwesomeIcon:B,VideoPlay:H,VideoPause:Y,ElDropdown:_e,ElDropdownMenu:he,ElDropdownItem:me,Loading:oe},props:{modelValue:{type:Object,required:!0}},data(){return{isFetchingVideoUrl:!1}},computed:{loading(){return this.$store.state.suno?.status?.getApplications===L.Request},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},task(){return this.$store.state.suno?.tasks},audios(){const e=this.modelValue?.response?.data??[],t=this.modelValue?.request?.action;return t?e.map(l=>({...l,action:t})):e},application(){return this.$store.state.suno?.application},active(){return this.$store.state.suno?.tasks?.active}},methods:{useFormatDuring:D,onPlay(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"playing"}),console.log("on play")},onPause(e){this.$store.dispatch("suno/setAudio",{...this.$store.state.suno.audio,...e,state:"paused"}),console.log("on pause")},onClick(e){this.$store.state?.suno?.audio?.id!==e.id&&this.onPlay({...e,progress:0})},onExtend(e,t){e.stopPropagation(),console.log("on extend"),console.debug("set config",t),this.$store.commit("suno/setConfig",{...this.$store.state.suno?.config,model:t.model,custom:!0,instrumental:!1,style:t.style,action:"extend",audio:t,audio_id:t.id,continue_at:t.duration})},onDownload(e,t){e&&e.stopPropagation(),console.log("on download",t);const n=new URL(t).pathname,u=n.substring(n.lastIndexOf("/")+1);console.log("on preview",u),fetch(t).then(r=>r.blob()).then(r=>{se.saveAs(r,u)})},async handleVideoDownload(e){if(e.video_url){this.onDownload(null,e.video_url);return}if(!this.isFetchingVideoUrl)try{this.isFetchingVideoUrl=!0;const t=await this.fetchVideoUrlFromApi(e?.id);console.log(`get videoUrl: ${t}`),e.video_url=t,this.onDownload(null,t)}catch(t){console.error("get videoUrl failed:",t),k.error(this.$t("suno.message.getVideoUrlFailed"))}finally{this.isFetchingVideoUrl=!1}},async fetchVideoUrlFromApi(e){return new Promise((t,l)=>{const n={audio_id:e},u=this.credential?.token;if(!u){console.error("no token specified"),l(new Error("No token specified"));return}q.mp4(n,{token:u}).then(r=>{const c=r.data?.data?.video_url;c?t(c):l(new Error("Video URL not found in response"))}).catch(r=>{l(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 l={action:e,audio_id:t,callback_url:so},n=this.credential?.token;if(!n){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),q.audio(l,{token:n}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(u=>{k.error(u?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{await this.onGetTasks(),await this.onScrollDown()})},async onScrollDown(){setTimeout(()=>{const e=document.querySelector(".tasks");e&&(e.scrollTop=e.scrollHeight)},1e3)},async onGetTasks(){if(this.loading){console.debug("loading");return}await this.$store.dispatch("suno/getTasks",{limit:30,offset:0})}}}),io={class:"task"},ao=["onClick"],lo={class:"left"},ro=["onClick"],co=["onClick"],uo={key:2,class:"duration"},po={class:"info"},mo={class:"title"},ho={class:"style"},_o={class:"right"},fo={class:"el-dropdown-link"},$o={class:"flex items-center min-w-[120px]"},go={class:"el-dropdown-link"};function vo(e,t,l,n,u,r){const c=a("el-image"),h=a("video-pause"),_=a("el-icon"),f=a("video-play"),C=a("font-awesome-icon"),V=a("el-tooltip"),b=a("Loading"),A=a("el-dropdown-item"),R=a("el-dropdown-menu"),U=a("el-dropdown"),z=Q("loading");return i(),d("div",io,[(i(!0),d(j,null,O(e.audios,$=>(i(),d("div",{key:$.id,class:"audio",onClick:T(P=>e.onClick($),["stop"])},[K((i(),d("div",lo,[o(c,{src:$?.image_url,class:"cover",fit:"cover",lazy:""},null,8,["src"]),$?.audio_url&&e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="playing"?(i(),d("div",{key:0,class:"overlay",onClick:T(P=>e.onPause($),["stop"])},[o(_,null,{default:p(()=>[o(h)]),_:1})],8,ro)):g("",!0),$?.audio_url&&(e.$store.state?.suno?.audio?.id!==$.id||e.$store.state?.suno?.audio?.id===$.id&&e.$store.state?.suno?.audio?.state==="paused")?(i(),d("div",{key:1,class:"overlay",onClick:T(P=>e.onPlay($),["stop"])},[o(_,null,{default:p(()=>[o(f)]),_:1})],8,co)):g("",!0),$?.duration?(i(),d("div",uo,m(e.useFormatDuring($?.duration)),1)):g("",!0)])),[[z,!$?.audio_url]]),s("div",po,[s("h2",mo,m($?.title),1),s("p",ho,m($?.style),1)]),s("div",_o,[o(U,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[o(A,{disabled:e.isFetchingVideoUrl,onClick:P=>e.handleVideoDownload($)},{default:p(()=>[s("div",$o,[e.isFetchingVideoUrl?(i(),v(_,{key:0,class:"is-loading mr-2"},{default:p(()=>[o(b)]),_:1})):g("",!0),s("span",null,m(e.$t("suno.button.download_video")),1)])]),_:2},1032,["disabled","onClick"]),$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onDownload(P,$?.audio_url),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.download_audio")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",fo,[o(V,{effect:"dark",content:e.$t("suno.button.download"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-download",class:"icon icon-download"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024),o(U,null,{dropdown:p(()=>[o(R,null,{default:p(()=>[$?.audio_url?(i(),v(A,{key:0,onClick:T(P=>e.onExtend(P,$),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.extend")),1)]),_:2},1032,["onClick"])):g("",!0),$.id?(i(),v(A,{key:1,onClick:T(P=>e.onGetStems($.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.get_stems")),1)]),_:2},1032,["onClick"])):g("",!0),o(A,{onClick:T(P=>e.onCover($),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.cover_music")),1)]),_:2},1032,["onClick"]),$?.id&&$?.action==="extend"?(i(),v(A,{key:2,onClick:T(P=>e.onConcatMusic($?.id),["stop"])},{default:p(()=>[I(m(e.$t("suno.button.concat_music")),1)]),_:2},1032,["onClick"])):g("",!0)]),_:2},1024)]),default:p(()=>[s("span",go,[o(V,{effect:"dark",content:e.$t("suno.button.more"),placement:"top"},{default:p(()=>[$?.audio_url||$?.video_url?(i(),v(C,{key:0,icon:"fa-solid fa-ellipsis",class:"icon icon-ellipsis"})):g("",!0)]),_:2},1032,["content"])])]),_:2},1024)])],8,ao))),128))])}const yo=w(no,[["render",vo]]),ko={class:"player-slider"},wo=y({__name:"PlayerSlider",setup(e){const t=G(),l=E({get:()=>t.state.suno?.audio?.progress,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:c})}),n=E({get:()=>t.state.suno?.audio?.duration,set:c=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:c})}),u=()=>{},r=c=>t.dispatch("suno/setAudio",{...t.state.suno.audio,progress:c});return(c,h)=>(i(),d("div",ko,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":h[0]||(h[0]=_=>l.value=_),"show-tooltip":!1,min:0,max:n.value,onChange:r,onInput:u},null,8,["modelValue","max"])]))}}),bo="/assets/disk-XFRmVAfp.png",Co={class:"flex player-song"},Vo=["src"],Ao={class:"ml-2 text-xs flex flex-col justify-between"},Po={class:"w-52 2xl:w-96 cursor-pointer truncate"},So={class:"flex"},To={class:"ml-2 text-dc"},Io=y({__name:"PlayerSong",setup(e){const t=G(),l=E({get:()=>t.state.suno.audio,set:n=>t.commit("suno/setAudio",n)});return ke(l,(n,u)=>{if(n?.audio_url!==u?.audio_url){console.log("audio changed",n),n.object&&(console.log("111",n.object),n.object.pause(),delete n.object);const r=new Audio(n.audio_url);n.state==="playing"?r.play():r.pause(),r.addEventListener("loadedmetadata",()=>{r.currentTime=0,r.addEventListener("timeupdate",()=>{t.commit("suno/setAudio",{...t.state.suno.audio,progress:r.currentTime})})}),t.commit("suno/setAudio",{...t.state.suno.audio,object:r})}else if(n?.progress!==u?.progress&&Math.abs(n.progress-n.object.currentTime)>2){console.log("progress changed",n.progress);const r=t.state.suno.audio;r.object&&(r.object.currentTime=r.progress)}else n?.state!==u?.state&&(console.log("state changed",n.state),n.object&&(n.state==="playing"?n.object.play():n.object.pause()));n?.volume!==u?.volume&&(console.log("volume changed",n.volume),n.object&&(n.object.volume=n.volume/100))}),(n,u)=>(i(),d("div",Co,[s("img",{alt:"",class:"w-11 h-11 rounded",src:l.value?.image_url||S(bo)},null,8,Vo),s("div",Ao,[s("div",Po,[s("div",So,[s("span",null,m(l.value?.title||"Music"),1),s("span",To,"- "+m(l.value?.style||"SmallRuralDog"),1)])])])]))}}),Eo={class:"flex justify-end items-center gap-x-2.5"},Uo={class:"text-xs"},Lo=y({__name:"PlayerAction",setup(e){const t=G(),l=E({get:()=>t.state.suno?.audio?.progress,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,progress:u})}),n=E({get:()=>t.state.suno?.audio?.duration,set:u=>t.commit("suno/setAudio",{...t.state.suno.audio,duration:u})});return(u,r)=>(i(),d("div",Eo,[s("span",Uo,m(S(D)(l.value))+" / "+m(S(D)(n.value)),1)]))}}),x=y({__name:"IconPark",props:{icon:{},theme:{},size:{},spin:{type:Boolean},fill:{},strokeLinecap:{},strokeLinejoin:{},strokeWidth:{}},setup(e){return(t,l)=>(i(),v(we(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"]))}}),jo={class:"player-volume flex flex-col items-center pt-2"},Do={class:"text-sm mt-3"},Go=y({__name:"PlayerVolumeSlider",setup(e){const t=G(),l=E({get:()=>t.state.suno.audio?.volume,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,volume:r})}),n=E({get:()=>t.state.suno.audio?.muted,set:r=>t.commit("suno/setAudio",{...t.state.suno.audio,muted:r})}),u=r=>t.dispatch("suno/setVolume",r);return(r,c)=>(i(),d("div",jo,[o(S(te),{modelValue:l.value,"onUpdate:modelValue":c[0]||(c[0]=h=>l.value=h),vertical:"",height:"100px","show-tooltip":!1,max:100,min:0,size:"small",disabled:n.value,onInput:u},null,8,["modelValue","disabled"]),s("div",Do,m(l.value),1)]))}}),Fo={class:"flex items-center justify-center gap-x-3"},Ro=y({__name:"PlayerController",setup(e){const t=G(),l=()=>t.dispatch("suno/setAudio",{...t.state.suno.audio,state:t.state.suno.audio.state==="playing"?"paused":"playing"}),n=E(()=>t.state.suno.audio);return(u,r)=>(i(),d("div",Fo,[o(x,{icon:n.value?.state==="playing"?S(ne):S(ie),size:"45",theme:"filled",class:"text-[var(--el-color-primary)] cursor-pointer",onClick:l},null,8,["icon"]),o(S($e),{placement:"top",width:"50px",trigger:"click"},{reference:p(()=>[o(x,{icon:S(ae),size:"20","stroke-width":2,class:"cursor-pointer"},null,8,["icon"])]),default:p(()=>[o(Go)]),_:1})]))}}),zo={class:"flex flex-col items-stretch h-20"},Mo={class:"flex grow px-5 items-center"},Oo={class:"flex-1"},qo={class:"flex-1"},Bo={class:"flex-1"},No=y({__name:"Player",setup(e){return(t,l)=>(i(),d("div",zo,[o(wo),s("div",Mo,[s("div",Oo,[o(Io)]),s("div",qo,[o(Ro)]),s("div",Bo,[o(Lo)])])]))}}),Wo=y({name:"RecentPanel",components:{ElSkeletonItem:ve,ElSkeleton:ge,TaskPreview:yo,Player:No,NoTasks:Te,ScrollList:Pe},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.suno?.tasks,items:this.$store.state.suno?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Xo={key:0,class:"tasks"},Ko={class:"left w-[70px] p-[10px] flex items-center"},Yo={class:"main w-[calc(100%-70px)] flex-1 p-[10px]"},Ho={key:2,class:"w-full flex-1 flex items-center justify-center"},Jo={class:"h-20"};function Qo(e,t,l,n,u,r){const c=a("el-skeleton-item"),h=a("el-skeleton"),_=a("task-preview"),f=a("scroll-list"),C=a("no-tasks"),V=a("player");return i(),d(j,null,[e.tasks?.items===void 0?(i(),d("div",Xo,[(i(),d(j,null,O(3,b=>s("div",{key:b,class:"flex"},[s("div",Ko,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"image",class:"avatar w-[50px] h-[50px]"})]),_:1})]),s("div",Yo,[o(h,{animated:""},{template:p(()=>[o(c,{variant:"p",class:"w-[200px] h-[15px] mb-[5px] mt-[10px]"}),o(c,{variant:"text"})]),_:1})])])),64))])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(i(),v(f,{key:1,ref:"scrollList",class:"flex-1 w-full overflow-y-auto tasks p-2",loading:e.loading,onReachTop:t[0]||(t[0]=b=>e.$emit("reach-top"))},{default:p(()=>[(i(!0),d(j,null,O(e.tasks?.items,(b,A)=>(i(),v(_,{key:A,"model-value":b,class:"preview"},null,8,["model-value"]))),128))]),_:1},8,["loading"])):g("",!0),e.tasks?.items?.length===0?(i(),d("div",Ho,[o(C)])):g("",!0),K(s("div",Jo,[o(V)],512),[[be,!!e.$store?.state?.suno?.audio?.object]])],64)}const Zo=w(Wo,[["render",Qo]]),xo=y({name:"TaskPreview",components:{IconPicture:le,ElImage:X,ElAvatar:ye,ElIcon:W},computed:{audio(){return this.$store.state.suno?.audio}}}),es={key:0,class:"size-full overflow-hidden"},ts={class:"relative h-[300px]"},os={class:"flex items-center justify-center size-full bg-[var(--el-bg-color)]"},ss={class:"absolute bottom-0 left-0 right-0 m-0 p-4 text-white z-10 bg-gradient-to-t from-black/70 to-transparent"},ns={class:"p-4"},is={class:"flex items-center font-bold mb-2"},as={class:"text-[var(--el-text-color-regular)] mb-2"},ls={class:"text-xs text-[var(--el-text-color-regular)]"},rs={class:"mt-4 text-sm leading-[25px] whitespace-pre-wrap"},cs={key:1,class:"w-full h-full"};function us(e,t,l,n,u,r){const c=a("icon-picture"),h=a("el-icon"),_=a("el-image"),f=a("el-avatar");return e.audio?.object?(i(),d("div",es,[s("div",ts,[o(_,{src:e.audio.image_url,fit:"cover",class:"size-full"},{error:p(()=>[s("div",os,[o(h,{class:"text-3xl"},{default:p(()=>[o(c)]),_:1})])]),_:1},8,["src"]),s("h2",ss,m(e.audio?.title),1)]),s("div",ns,[s("div",is,[o(f,{size:30,src:e.audio?.image_url,class:"mr-2"},null,8,["src"]),s("span",null,m(e.audio?.title),1)]),s("p",as,m(e.audio?.style),1),s("p",ls,m(e.$dayjs.format(e.audio?.created_at)),1),s("div",rs,[s("p",null,m(e.audio?.lyric),1)])])])):(i(),d("div",cs))}const ds=w(xo,[["render",us]]),ps="https://webhook.acedata.cloud/suno",ms=y({name:"SunoIndex",components:{Layout:Re,ConfigPanel:oo,RecentPanel:Zo,PreviewPanel:ds},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.suno?.status?.getApplications===L.Request},tasksLoading(){return this.$store.state.suno?.status?.getTasks===L.Request||this.fetchingTasks},service(){return this.$store.state.suno.service},credential(){return this.$store.state.suno.credential},config(){return this.$store.state.suno.config},initializing(){return this.$store.state.suno.status.getApplications===L.Request},needApply(){return this.$store.state.suno.status.getApplications===L.Success&&!this.application},application(){return this.$store.state.suno.application},tasks(){return this.$store.state.suno.tasks},applications(){return this.$store.state.suno.applications}},watch:{tasks:{handler(e,t){e?.items?.length>t?.items?.length&&console.debug("new tasks detected")},deep:!0},initialized:{async handler(e){e&&(console.debug("layout initialized"),await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await Ee({tasks:this.tasks,getTasks:()=>this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("suno/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplications"),await this.$store.dispatch("suno/getApplications"),console.debug("end onGetApplications"),await this.onGetTasks()},onApply(){Ve.create({application:this.application}).then(({data:e})=>{this.application=e,k.success(this.$t("application.message.applySuccessfully"))}).catch(e=>{e?.response?.data?.code===Ae&&k.error(this.$t("application.message.alreadyApplied"))})},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks){console.debug("loading");return}console.debug("start onGetTasks",e);const{limit:t=5,createdAtMin:l,createdAtMax:n}=e||{};console.debug("limit",t,"createdAtMin",l,"createdAtMax",n),this.fetchingTasks=!0;try{await this.$store.dispatch("suno/getTasks",{limit:t,createdAtMin:l,createdAtMax:n})}finally{this.fetchingTasks=!1}},async onGenerateAudio(){const e={...this.config,callback_url:ps},t=this.credential?.token;if(!t){console.error("no token specified");return}k.info(this.$t("suno.message.startingTask")),q.audio(e,{token:t}).then(()=>{k.success(this.$t("suno.message.startTaskSuccess"))}).catch(l=>{k.error(l?.response?.data?.error?.message||this.$t("suno.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function hs(e,t,l,n,u,r){const c=a("config-panel"),h=a("recent-panel"),_=a("preview-panel"),f=a("layout");return i(),v(f,null,{config:p(()=>[o(c,{onGenerate:e.onGenerateAudio},null,8,["onGenerate"])]),result:p(()=>[o(h,{ref:"recentPanel",class:"panel recent",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),preview:p(()=>[o(_)]),_:1})}const Ps=w(ms,[["render",hs],["__scopeId","data-v-d1296b1a"]]);export{Ps as default};
@@ -1 +1 @@
1
- .menu[data-v-80748529]{display:none}@media (max-width: 767px){.config[data-v-80748529]{display:none}.result[data-v-80748529]{width:100%}.menu[data-v-80748529]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-17c0af5c]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-17c0af5c]{font-size:14px;margin:0;width:30%}.field .value[data-v-17c0af5c]{flex:1;margin-left:60px}.field[data-v-d1c54475]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-d1c54475]{font-size:14px;margin:0;width:30%}.field .value[data-v-d1c54475]{flex:1}.field[data-v-b948551f]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-b948551f]{font-size:14px;margin:0;width:30%}.field .value[data-v-b948551f]{flex:1}.quality .el-radio-button--small .el-radio-button__inner{padding:8px 11px}.field[data-v-7b2e870a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-7b2e870a]{font-size:14px;margin:0;width:30%}.field .value[data-v-7b2e870a]{width:80px}.field[data-v-18cda67a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-18cda67a]{font-size:14px;margin:0;width:30%}.field .value[data-v-18cda67a]{flex:1;margin-left:60px}.field .upload-wrapper[data-v-18cda67a]{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.field .info[data-v-18cda67a]{margin-left:auto}.field .box[data-v-b94e7a3e]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-b94e7a3e]{font-size:14px;margin-bottom:10px}.field .info[data-v-b94e7a3e]{margin-left:auto}.video[data-v-fc420430]{max-width:100%;height:450px}.preview[data-v-4c2810f1]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-4c2810f1]{width:70px}.preview .left .avatar[data-v-4c2810f1]{background-color:#222;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-4c2810f1]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-4c2810f1]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-4c2810f1]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-4c2810f1]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content .el-alert[data-v-4c2810f1]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-4c2810f1]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-4c2810f1]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-4c2810f1]{border-color:var(--el-color-info)}.preview .main .image-wrapper[data-v-4c2810f1]{position:relative;width:-moz-fit-content;width:fit-content;min-height:50px;min-width:100px}.preview .main .image-wrapper .image[data-v-4c2810f1]{max-height:400px;max-width:500px;display:block;width:-moz-fit-content;width:fit-content}.preview .main .image-wrapper .btn-raw[data-v-4c2810f1]{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1000;display:none}.preview .main .image-wrapper .play-icon[data-v-4c2810f1]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;color:#fff;z-index:500;pointer-events:none}.preview .main .image-wrapper:hover .image[data-v-4c2810f1]{filter:brightness(.6)}.preview .main .image-wrapper:hover .btn-raw[data-v-4c2810f1]{display:block}.preview .main .image-wrapper:hover .play-icon[data-v-4c2810f1]{display:none}.preview .main .operations[data-v-4c2810f1]{display:flex;justify-content:left;flex-direction:row;width:100%;align-items:baseline;flex-wrap:wrap;overflow:hidden;text-align:center;color:var(--el-text-color-regular);font-size:14px;overflow-y:scroll}.preview .main .operations.full[data-v-4c2810f1]{height:70px}.preview .main .operations .btn-action[data-v-4c2810f1],.status[data-v-1bcbbdd4]{margin-bottom:10px}.panel.detail[data-v-1bcbbdd4]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-1bcbbdd4]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-1bcbbdd4]{position:relative}
1
+ .menu[data-v-80748529]{display:none}@media (max-width: 767px){.config[data-v-80748529]{display:none}.result[data-v-80748529]{width:100%}.menu[data-v-80748529]{display:block;position:absolute;right:8px;top:45px;z-index:1000}}.field[data-v-17c0af5c]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-17c0af5c]{font-size:14px;margin:0;width:30%}.field .value[data-v-17c0af5c]{flex:1;margin-left:60px}.field[data-v-d1c54475]{display:flex;flex-direction:row;align-items:center}.field .title[data-v-d1c54475]{font-size:14px;margin:0;width:30%}.field .value[data-v-d1c54475]{flex:1}.field[data-v-b948551f]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-b948551f]{font-size:14px;margin:0;width:30%}.field .value[data-v-b948551f]{flex:1}.quality .el-radio-button--small .el-radio-button__inner{padding:8px 11px}.field[data-v-7b2e870a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-7b2e870a]{font-size:14px;margin:0;width:30%}.field .value[data-v-7b2e870a]{width:80px}.field[data-v-18cda67a]{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.field .title[data-v-18cda67a]{font-size:14px;margin:0;width:30%}.field .value[data-v-18cda67a]{flex:1;margin-left:60px}.field .upload-wrapper[data-v-18cda67a]{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.field .info[data-v-18cda67a]{margin-left:auto}.field .box[data-v-b94e7a3e]{display:flex;flex-direction:row;align-items:center;justify-content:space-between;position:relative}.field .box .title[data-v-b94e7a3e]{font-size:14px;margin-bottom:10px}.field .info[data-v-b94e7a3e]{margin-left:auto}.video[data-v-fc420430]{max-width:100%;height:450px}.preview[data-v-4c2810f1]{width:100%;height:-moz-fit-content;height:fit-content;text-align:left;display:flex;flex-direction:row;margin-bottom:15px}.preview .left[data-v-4c2810f1]{width:70px}.preview .left .avatar[data-v-4c2810f1]{background-color:#222;padding:2px;width:50px;height:50px;margin:10px;border-radius:50%}.preview .main[data-v-4c2810f1]{flex:1;width:calc(100% - 70px);padding:10px 10px 0}.preview .main .bot[data-v-4c2810f1]{font-size:16px;font-weight:700;color:#2ecc71;margin-bottom:0;margin-top:0}.preview .main .bot .datetime[data-v-4c2810f1]{font-size:12px;font-weight:400;color:var(--el-text-color-secondary);margin-left:10px}.preview .main .info .prompt[data-v-4c2810f1]{font-size:14px;font-weight:700;color:var(--el-text-color-regular);margin-bottom:10px}.preview .main .content .el-alert[data-v-4c2810f1]{border-left-width:2px;border-left-style:solid}.preview .main .content .el-alert.failure[data-v-4c2810f1]{border-color:var(--el-color-danger)}.preview .main .content .el-alert.success[data-v-4c2810f1]{border-color:var(--el-color-success)}.preview .main .content .el-alert.info[data-v-4c2810f1]{border-color:var(--el-color-info)}.preview .main .image-wrapper[data-v-4c2810f1]{position:relative;width:-moz-fit-content;width:fit-content;min-height:50px;min-width:100px}.preview .main .image-wrapper .image[data-v-4c2810f1]{max-height:400px;max-width:500px;display:block;width:-moz-fit-content;width:fit-content}.preview .main .image-wrapper .btn-raw[data-v-4c2810f1]{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1000;display:none}.preview .main .image-wrapper .play-icon[data-v-4c2810f1]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;color:#fff;z-index:500;pointer-events:none}.preview .main .image-wrapper:hover .image[data-v-4c2810f1]{filter:brightness(.6)}.preview .main .image-wrapper:hover .btn-raw[data-v-4c2810f1]{display:block}.preview .main .image-wrapper:hover .play-icon[data-v-4c2810f1]{display:none}.preview .main .operations[data-v-4c2810f1]{display:flex;justify-content:left;flex-direction:row;width:100%;align-items:baseline;flex-wrap:wrap;overflow:hidden;text-align:center;color:var(--el-text-color-regular);font-size:14px;overflow-y:scroll}.preview .main .operations.full[data-v-4c2810f1]{height:70px}.preview .main .operations .btn-action[data-v-4c2810f1],.status[data-v-456819d1]{margin-bottom:10px}.panel.detail[data-v-456819d1]{width:100%;flex:1;overflow-y:scroll}.panel.recent[data-v-456819d1]{height:100%;width:100%;margin-bottom:10px;position:relative;justify-content:initial}.panel.operation[data-v-456819d1]{position:relative}
@@ -0,0 +1 @@
1
+ import{E as T,a as D,b as E}from"./EditArray-BO1VlAtC.js";import{d as U,_ as F}from"./index-BWdK6S1P.js";import"./vendor-BG5lCpoe.js";import{H as V,j as _,I as q,s as A,w as j,i as B,x as L,m as N}from"./vendor-element-plus-7rF3khck.js";import{d as R,R as O,S as s,l as t,al as n,a as l,Z as o,Y as m,c as y,ai as Q,F as W,o as g,U as k,W as H,_ as C}from"./vendor-vue-Bb02XvLT.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-D4avMJL1.js";import"./vendor-dayjs-BRrJyY8K.js";import"./vendor-katex-DHBGsivc.js";const K=R({name:"SiteIndex",components:{EditText:E,EditImage:D,EditArray:T,ElDivider:N,ElRow:L,ElImage:B,ElCol:j,ElCard:A,ElForm:q,ElSwitch:_,ElFormItem:V},data(){return{editing:{title:!1}}},computed:{site(){return this.$store.getters.site}},methods:{onSave(e){const a={...this.site,...e};U.update(this.site?.id,a).then(()=>{console.debug("getSite for id",this.site?.id),this.$store.dispatch("getSite")})}}}),Y={class:"title"},Z={class:"title"},z={class:"block w-full"},G={class:"block tip"},J={class:"block w-full"},M={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},x={class:"block w-full"},ee={class:"block tip"},te={class:"block w-full"},ie={class:"block tip"},se={class:"title"},le={class:"block w-full"},oe={class:"block tip"},ae={class:"block w-full"},de={class:"block tip"},ne={class:"title"},re={class:"block tip"},me={class:"block tip"},ue={class:"title"},pe={class:"w-full"},fe={class:"block tip w-full"},be={key:0},ve={class:"block w-full"},he={class:"block w-full"};function ce(e,a,$e,we,ge,ke){const f=n("el-col"),h=n("el-row"),u=n("el-divider"),d=n("el-form-item"),p=n("edit-text"),c=n("el-image"),$=n("edit-image"),I=n("edit-array"),b=n("el-form"),v=n("el-card"),w=n("el-switch");return g(),O(h,{class:"panel"},{default:s(()=>[t(f,{span:24},{default:s(()=>[t(h,null,{default:s(()=>[t(f,{span:24},{default:s(()=>[l("h2",Y,o(e.$t("common.title.site")),1)]),_:1})]),_:1}),t(h,{gutter:15},{default:s(()=>[t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",Z,o(e.$t("site.title.basicConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.origin")},{default:s(()=>[l("span",z,o(e.site.origin),1),l("span",G,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",J,[m(o(e.site.title)+" ",1),t(p,{"model-value":e.site.title,title:e.$t("site.title.editTitle"),placeholder:e.$t("site.placeholder.title"),onConfirm:a[0]||(a[0]=i=>e.onSave({title:i}))},null,8,["model-value","title","placeholder"])]),l("span",M,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",P,[t(c,{src:e.site.logo,class:"logo"},null,8,["src"]),t($,{"model-value":e.site.logo,title:e.$t("site.title.editLogo"),tip:e.$t("site.message.editLogoTip"),onConfirm:a[1]||(a[1]=i=>e.onSave({logo:i}))},null,8,["model-value","title","tip"])]),l("span",X,o(e.$t("site.message.logoTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.favicon")},{default:s(()=>[l("span",x,[t(c,{src:e.site.favicon,class:"favicon"},null,8,["src"]),t($,{"model-value":e.site.favicon,title:e.$t("site.title.editFavicon"),tip:e.$t("site.message.editFaviconTip"),onConfirm:a[2]||(a[2]=i=>e.onSave({favicon:i}))},null,8,["model-value","title","tip"])]),l("span",ee,o(e.$t("site.message.faviconTip")),1)]),_:1},8,["label"]),t(u,{"border-style":"dashed"}),t(d,{label:e.$t("site.field.admins")},{default:s(()=>[l("span",te,[m(o(e.site.admins?.join(", "))+" ",1),t(I,{"model-value":e.site?.admins||[],title:e.$t("site.title.editAdmins"),placeholder:e.$t("site.placeholder.admins"),tip:e.$t("site.message.adminsTip2"),min:1,"min-error-message":e.$t("site.message.atLeastOneAdmin"),onConfirm:a[3]||(a[3]=i=>e.onSave({admins:i}))},null,8,["model-value","title","placeholder","tip","min-error-message"])]),l("span",ie,o(e.$t("site.message.adminsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",se,o(e.$t("site.title.seoConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.description")},{default:s(()=>[l("span",le,[m(o(e.site.description)+" ",1),t(p,{"model-value":e.site.description,title:e.$t("site.title.editDescription"),placeholder:e.$t("site.placeholder.description"),onConfirm:a[4]||(a[4]=i=>e.onSave({description:i}))},null,8,["model-value","title","placeholder"])]),l("span",oe,o(e.$t("site.message.descriptionTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.keywords")},{default:s(()=>[l("span",ae,[m(o(e.site.keywords?.join(", "))+" ",1),t(I,{"model-value":e.site?.keywords||[],title:e.$t("site.title.editKeywords"),placeholder:e.$t("site.placeholder.keywords"),tip:e.$t("site.message.keywordsTip2"),onConfirm:a[5]||(a[5]=i=>e.onSave({keywords:i}))},null,8,["model-value","title","placeholder","tip"])]),l("span",de,o(e.$t("site.message.keywordsTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1})]),_:1}),t(f,{md:12,xs:24},{default:s(()=>[t(v,{shadow:"hover",class:"mb-4"},{default:s(()=>[l("h4",ne,o(e.$t("site.title.distributionConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[t(d,{label:e.$t("site.field.distributionDefaultInviterId")},{default:s(()=>[m(o(e.site.distribution?.default_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.default_inviter_id,title:e.$t("site.title.editDistributionDefaultInviterId"),placeholder:e.$t("site.placeholder.editDistributionDefaultInviterId"),onConfirm:a[6]||(a[6]=i=>e.onSave({distribution:{...e.site.distribution,default_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",re,o(e.$t("site.message.distributionDefaultInviterIdTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.distributionForceInviterId")},{default:s(()=>[m(o(e.site.distribution?.force_inviter_id)+" ",1),t(p,{"model-value":e.site.distribution?.force_inviter_id,title:e.$t("site.title.editDistributionForceInviterId"),placeholder:e.$t("site.placeholder.editDistributionForceInviterId"),onConfirm:a[7]||(a[7]=i=>e.onSave({distribution:{...e.site.distribution,force_inviter_id:i}}))},null,8,["model-value","title","placeholder"]),l("span",me,o(e.$t("site.message.distributionForceInviterIdTip")),1)]),_:1},8,["label"])]),_:1},8,["model"])]),_:1}),t(v,{shadow:"hover"},{default:s(()=>[l("h4",ue,o(e.$t("site.title.featuresConfig")),1),t(u),t(b,{model:e.site,class:"form","label-width":"auto",style:{"max-width":"600px"}},{default:s(()=>[(g(),y(W,null,Q(["chat","midjourney","qrart","suno","luma","pika","kling","flux","hailuo","headshots","support"],(i,S)=>t(d,{key:S,label:e.$t("site.field.features"+i.charAt(0).toUpperCase()+i.slice(1))},{default:s(()=>[l("div",pe,[t(w,{"model-value":e.site.features[i]?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],enabled:r}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),l("span",fe,o(e.$t("site.message.features"+i.charAt(0).toUpperCase()+i.slice(1))),1),i==="support"?k((g(),y("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(w,{"model-value":e.site.features[i]?.wechat?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.qr")},{default:s(()=>[l("span",ve,[t(c,{src:e.site.features[i]?.wechat?.qr},null,8,["src"]),t($,{"model-value":e.site.features[i]?.wechat?.qr,title:e.$t("site.title.editQR"),tip:e.$t("site.message.editQRTip"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],wechat:{...e.site.features[i]?.wechat,qr:r}}}})},null,8,["model-value","title","tip","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.wechat?.enabled]]),t(d,{label:"Discord"},{default:s(()=>[t(w,{"model-value":e.site.features[i]?.discord?.enabled||!1,"inline-prompt":"","active-text":e.$t("site.button.enabled"),"inactive-text":e.$t("site.button.disabled"),"onUpdate:modelValue":r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,enabled:r}}}})},null,8,["model-value","active-text","inactive-text","onUpdate:modelValue"])]),_:2},1024),k(t(d,{label:e.$t("site.field.url")},{default:s(()=>[l("span",he,[m(o(e.site.features[i]?.discord?.url)+" ",1),t(p,{"model-value":e.site.features[i]?.discord?.url,title:e.$t("site.title.editUrl"),placeholder:e.$t("site.placeholder.editUrl"),onConfirm:r=>e.onSave({features:{...e.site.features,[i]:{...e.site.features[i],discord:{...e.site.features[i]?.discord,url:r}}}})},null,8,["model-value","title","placeholder","onConfirm"])])]),_:2},1032,["label"]),[[C,e.site.features[i]?.discord?.enabled]])],512)),[[C,e.site.features[i]?.enabled]]):H("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Ve=F(K,[["render",ce],["__scopeId","data-v-61e4ae55"]]);export{Ve as default};