@acedatacloud/nexior 3.36.0 → 3.37.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 (206) hide show
  1. package/dist/assets/{Auth-BP9lbJeI.js → Auth-B0r-juFO.js} +1 -1
  2. package/dist/assets/{BotPlaceholder-CInEMDBc.js → BotPlaceholder-DEITkzHi.js} +1 -1
  3. package/dist/assets/{Callback-BIjy-gtY.js → Callback-CGwf8d8n.js} +1 -1
  4. package/dist/assets/{Console-6tUky-J0.js → Console--9XSD6DQ.js} +1 -1
  5. package/dist/assets/{Consumption-BCbR6ZEO.js → Consumption-DTFyP44R.js} +1 -1
  6. package/dist/assets/{Conversation-rDdJVSyA.js → Conversation-BPr3j2Yr.js} +1 -1
  7. package/dist/assets/{CopyToClipboard-Djhvl2Fk.js → CopyToClipboard-COWZc6L9.js} +1 -1
  8. package/dist/assets/{Detail-Co0yJXVH.js → Detail-CCbd4Bq9.js} +2 -2
  9. package/dist/assets/{EditArray-BGybpge_.js → EditArray-UipmkzQk.js} +1 -1
  10. package/dist/assets/{Extra-CSmGC05b.js → Extra-Cr_5oVqv.js} +1 -1
  11. package/dist/assets/{FilePreview-BNzbUf36.js → FilePreview-DrDarXxz.js} +1 -1
  12. package/dist/assets/{History-B0U-8F9T.js → History-BjYNQalO.js} +1 -1
  13. package/dist/assets/{ImagePreview-SUR7TFTL.js → ImagePreview-COK_lQAf.js} +1 -1
  14. package/dist/assets/{ImageWrapper-D7m66Uzp.js → ImageWrapper-tWRqlRkx.js} +1 -1
  15. package/dist/assets/{Index-CLp6MIQW.js → Index-59yOvdC5.js} +1 -1
  16. package/dist/assets/{Index-F7xvFuGm.js → Index-8yjJ2a3P.js} +1 -1
  17. package/dist/assets/{Index-BWY2r3X1.js → Index-BCWGcmTi.js} +1 -1
  18. package/dist/assets/{Index-OBOZ0gNk.js → Index-BXkyiXCB.js} +1 -1
  19. package/dist/assets/{Index-BGbiVa-Y.js → Index-BlBSGmUe.js} +1 -1
  20. package/dist/assets/{Index-sUp19C7h.js → Index-C4phnzV_.js} +1 -1
  21. package/dist/assets/{Index-B2TA3Ri9.js → Index-CHASyFDL.js} +1 -1
  22. package/dist/assets/{Index-C-6TsdhC.js → Index-CN1RLB9p.js} +1 -1
  23. package/dist/assets/{Index-tw3XT7DO.js → Index-CbjsMkx4.js} +1 -1
  24. package/dist/assets/{Index-Dz8Os9xl.js → Index-CeV6UIvP.js} +1 -1
  25. package/dist/assets/{Index-BqOMnc5W.js → Index-CfiZClON.js} +1 -1
  26. package/dist/assets/{Index-CGhMkR7Q.js → Index-Ci3uTuoz.js} +1 -1
  27. package/dist/assets/{Index-DsAb9sPv.js → Index-DJNsKBey.js} +1 -1
  28. package/dist/assets/{Index-DvSICD7r.js → Index-DPhCvY6Q.js} +1 -1
  29. package/dist/assets/{Index-cXoD-6RA.js → Index-DUR-RnA2.js} +1 -1
  30. package/dist/assets/{Index-B5xoCX__.js → Index-DZVTbDSQ.js} +1 -1
  31. package/dist/assets/{Index-DaH7q9dg.js → Index-DcAVsgz9.js} +1 -1
  32. package/dist/assets/{Index-Ditj1i_I.js → Index-Di9hbLdf.js} +1 -1
  33. package/dist/assets/{Index-CB1O9Y15.js → Index-IByo75xV.js} +1 -1
  34. package/dist/assets/{Index-DIbGskQz.js → Index-Usv3XwZq.js} +1 -1
  35. package/dist/assets/{Index-DF06Um2_.js → Index-WI6f1axv.js} +1 -1
  36. package/dist/assets/{Index-DM3dFdE3.js → Index-XCNLSkUK.js} +1 -1
  37. package/dist/assets/{Index-LPobDCmU.js → Index-kyl5nTZY.js} +1 -1
  38. package/dist/assets/{Index-BN6WLQ8-.js → Index-qaJbU0TV.js} +1 -1
  39. package/dist/assets/{Invitees-B6HhiNiR.js → Invitees-BPtPfdut.js} +1 -1
  40. package/dist/assets/{List-pp0GRwAS.js → List-CC8Z4z5R.js} +1 -1
  41. package/dist/assets/{List-ClW1xhXU.js → List-DCYHG6Bs.js} +1 -1
  42. package/dist/assets/{List-Bdy41N41.js → List-LRyxDpuD.js} +1 -1
  43. package/dist/assets/{Main-Cd5cePch.js → Main-BXasj2-z.js} +1 -1
  44. package/dist/assets/{Navigator-B7XcI_Q3.js → Navigator-ChBqOOgE.js} +1 -1
  45. package/dist/assets/{NoTasks-BYOtsKOE.js → NoTasks-C1c_E_pm.js} +1 -1
  46. package/dist/assets/{OAuthCallback-gwIcXrf0.js → OAuthCallback-DoOW4czE.js} +1 -1
  47. package/dist/assets/{Pagination-B9EVrZod.js → Pagination-DE9cWxMh.js} +1 -1
  48. package/dist/assets/{ScrollList-Dw45lO0t.js → ScrollList-_cUBLaZZ.js} +1 -1
  49. package/dist/assets/{Status-B4E0LbhA.js → Status-Bj7S8VFR.js} +1 -1
  50. package/dist/assets/{Subscribe-GxJ9p8MU.js → Subscribe-hbnDVlYv.js} +1 -1
  51. package/dist/assets/{TransportWebHID-Bw1vVfFC.js → TransportWebHID-tGhjdJt8.js} +1 -1
  52. package/dist/assets/{VideoPlayer-gXXZbisY.js → VideoPlayer-CF6zk-Kd.js} +1 -1
  53. package/dist/assets/{avatar-Ce400va_.js → avatar-BUeF6xoP.js} +1 -1
  54. package/dist/assets/{bignumber-C8MaMqra.js → bignumber-8Qi93LJc.js} +1 -1
  55. package/dist/assets/chat-31KGdpkR.js +1 -0
  56. package/dist/assets/chat-5QRWcJal.js +1 -0
  57. package/dist/assets/chat-B_uUBJcC.js +1 -0
  58. package/dist/assets/chat-BgVAtUr2.js +1 -0
  59. package/dist/assets/chat-BnupdsJN.js +1 -0
  60. package/dist/assets/chat-BrVi9oZE.js +1 -0
  61. package/dist/assets/chat-CJvFUy-r.js +1 -0
  62. package/dist/assets/chat-CJxaBxSG.js +1 -0
  63. package/dist/assets/chat-Cs8PAKpi.js +1 -0
  64. package/dist/assets/chat-D5o5a9vy.js +1 -0
  65. package/dist/assets/chat-D663plUx.js +1 -0
  66. package/dist/assets/chat-D6aJ9yES.js +1 -0
  67. package/dist/assets/chat-DGFqT53J.js +1 -0
  68. package/dist/assets/chat-DfgE8GX2.js +1 -0
  69. package/dist/assets/chat-DsGsDTVU.js +1 -0
  70. package/dist/assets/chat-DspcIhhd.js +1 -0
  71. package/dist/assets/chat-xmUEa5R0.js +1 -0
  72. package/dist/assets/common--RPis4uD.js +1 -0
  73. package/dist/assets/common-B8BvNyfs.js +1 -0
  74. package/dist/assets/{common-Bty1Uj-r.js → common-CUuiVCrt.js} +1 -1
  75. package/dist/assets/common-Cb0kEQn2.js +1 -0
  76. package/dist/assets/common-CcDoK5RO.js +1 -0
  77. package/dist/assets/common-CuoiGAMd.js +1 -0
  78. package/dist/assets/common-D-Py9uWA.js +1 -0
  79. package/dist/assets/common-D6fUaGIJ.js +1 -0
  80. package/dist/assets/common-D7h23qyY.js +1 -0
  81. package/dist/assets/common-DVb-AGrc.js +1 -0
  82. package/dist/assets/common-DYlYYSbD.js +1 -0
  83. package/dist/assets/common-Djmhqy3P.js +1 -0
  84. package/dist/assets/common-DlLx_S-p.js +1 -0
  85. package/dist/assets/common-j-7E6E41.js +1 -0
  86. package/dist/assets/common-tFNuFE96.js +1 -0
  87. package/dist/assets/common-wi23CLzZ.js +1 -0
  88. package/dist/assets/common-z6suHQnB.js +1 -0
  89. package/dist/assets/{distribution-15g43T9Y.js → distribution-PHMiVGOn.js} +1 -1
  90. package/dist/assets/{index-CdkIaG4d.js → index-59WF-aDo.js} +5 -5
  91. package/dist/assets/{index-OUFJCHwB.js → index-BohILe2p.js} +1 -1
  92. package/dist/assets/{index-D9-Jfsua.js → index-BoskLER6.js} +1 -1
  93. package/dist/assets/{index-DPbfNZOF.js → index-BpCZBwAt.js} +1 -1
  94. package/dist/assets/{index--OT7e4dB.js → index-CPXKDHlp.js} +1 -1
  95. package/dist/assets/{index-DMrAP4TW.js → index-D220ynN6.js} +1 -1
  96. package/dist/assets/{index-fXvjznMr.js → index-DbW-B2qb.js} +1 -1
  97. package/dist/assets/{index-bCCSAr1s.js → index-DdsA_zOr.js} +1 -1
  98. package/dist/assets/{index.es-D2RJIOwI.js → index.es-CS-OHrjD.js} +1 -1
  99. package/dist/assets/{order-D9vIzBpI.js → order-BxvNPyOX.js} +1 -1
  100. package/dist/assets/{price-CwH8PfMf.js → price-DRZuZOgJ.js} +1 -1
  101. package/dist/assets/{solana-wallets-CDq-Ilig.js → solana-wallets-Cstdq8pH.js} +2 -2
  102. package/dist/assets/{solanaEmbed.esm-2gmdLOlb.js → solanaEmbed.esm-BhORHQgM.js} +1 -1
  103. package/dist/assets/{string_decoder-BLnC-ocM.js → string_decoder-TDqYXdue.js} +1 -1
  104. package/dist/assets/suno-06gLGObD.js +7 -0
  105. package/dist/assets/suno-B-FsRt1X.js +7 -0
  106. package/dist/assets/suno-B2EXqZt4.js +7 -0
  107. package/dist/assets/suno-B3IK9MDR.js +7 -0
  108. package/dist/assets/suno-B9KAYimG.js +7 -0
  109. package/dist/assets/suno-BI8nJNC_.js +7 -0
  110. package/dist/assets/suno-BIOa3dsr.js +7 -0
  111. package/dist/assets/suno-BVCBAsqt.js +7 -0
  112. package/dist/assets/suno-Bo1rn7Dg.js +7 -0
  113. package/dist/assets/{suno-DEtbzRzi.js → suno-BwogiZiG.js} +1 -1
  114. package/dist/assets/suno-C91sW6Ap.js +7 -0
  115. package/dist/assets/suno-CZkOHm1a.js +7 -0
  116. package/dist/assets/suno-DGJGFUIN.js +7 -0
  117. package/dist/assets/suno-DQlhiEem.js +7 -0
  118. package/dist/assets/suno-DilQRymq.js +7 -0
  119. package/dist/assets/suno-Gli-Hjyc.js +7 -0
  120. package/dist/assets/suno-rD0cce-f.js +7 -0
  121. package/dist/assets/{vendor-web3-CNlWJWvL.js → vendor-web3-UIIclDfr.js} +4 -4
  122. package/dist/assets/veo-BTBfy1G3.js +1 -0
  123. package/dist/assets/veo-B_fk4-zR.js +1 -0
  124. package/dist/assets/veo-BcpGS6l_.js +1 -0
  125. package/dist/assets/veo-C94T8_Wj.js +1 -0
  126. package/dist/assets/veo-CAf7mKc2.js +1 -0
  127. package/dist/assets/veo-CAngU7eV.js +1 -0
  128. package/dist/assets/{veo-DxVI4WnA.js → veo-CGw62z9A.js} +1 -1
  129. package/dist/assets/veo-CRScauop.js +1 -0
  130. package/dist/assets/veo-CogLxmQf.js +1 -0
  131. package/dist/assets/veo-CzAgkwxE.js +1 -0
  132. package/dist/assets/veo-DDFdf0BJ.js +1 -0
  133. package/dist/assets/veo-DdPaHX2w.js +1 -0
  134. package/dist/assets/veo-F1TpBrxm.js +1 -0
  135. package/dist/assets/veo-KAWv3HhC.js +1 -0
  136. package/dist/assets/veo-sMp12h6q.js +1 -0
  137. package/dist/assets/{veo-DZkpLzN3.js → veo-wgwSek4G.js} +1 -1
  138. package/dist/assets/veo-zp3bEPuF.js +1 -0
  139. package/dist/assets/{web-DzpfT-sD.js → web-BMZ6uYLn.js} +1 -1
  140. package/dist/assets/{web-Di9kk2JK.js → web-BR46pVjm.js} +1 -1
  141. package/dist/index.html +2 -2
  142. package/package.json +1 -1
  143. package/dist/assets/chat-80AFwtrY.js +0 -1
  144. package/dist/assets/chat-B0EMHVmg.js +0 -1
  145. package/dist/assets/chat-B1ri2YS-.js +0 -1
  146. package/dist/assets/chat-BEG2rE4I.js +0 -1
  147. package/dist/assets/chat-BXJ3jqVy.js +0 -1
  148. package/dist/assets/chat-BaWj6GkR.js +0 -1
  149. package/dist/assets/chat-Bf12ZxKk.js +0 -1
  150. package/dist/assets/chat-BidGEZdJ.js +0 -1
  151. package/dist/assets/chat-D3K6Y0Ze.js +0 -1
  152. package/dist/assets/chat-DXXgxmOm.js +0 -1
  153. package/dist/assets/chat-DXswCZ1D.js +0 -1
  154. package/dist/assets/chat-Dar25ncu.js +0 -1
  155. package/dist/assets/chat-DjKrQigG.js +0 -1
  156. package/dist/assets/chat-DmuJNSxr.js +0 -1
  157. package/dist/assets/chat-DnUQVRpG.js +0 -1
  158. package/dist/assets/chat-oy7Jsokj.js +0 -1
  159. package/dist/assets/chat-v2q-hWqX.js +0 -1
  160. package/dist/assets/common-5IW7PeCP.js +0 -1
  161. package/dist/assets/common-B8aG7Efa.js +0 -1
  162. package/dist/assets/common-BDh_3lNX.js +0 -1
  163. package/dist/assets/common-BEohz6cI.js +0 -1
  164. package/dist/assets/common-BFxVXE09.js +0 -1
  165. package/dist/assets/common-BTySlNze.js +0 -1
  166. package/dist/assets/common-BcnkXUqu.js +0 -1
  167. package/dist/assets/common-BgTIujtM.js +0 -1
  168. package/dist/assets/common-Bq5HdznI.js +0 -1
  169. package/dist/assets/common-CLoNat-F.js +0 -1
  170. package/dist/assets/common-CuzSNb1o.js +0 -1
  171. package/dist/assets/common-DNZ7FSIr.js +0 -1
  172. package/dist/assets/common-DZgzSeWK.js +0 -1
  173. package/dist/assets/common-KnJh6qYN.js +0 -1
  174. package/dist/assets/common-qTcriPbI.js +0 -1
  175. package/dist/assets/common-wHXkz5ey.js +0 -1
  176. package/dist/assets/suno-22kfl5ck.js +0 -7
  177. package/dist/assets/suno-7HaPHxZU.js +0 -7
  178. package/dist/assets/suno-B29yxho6.js +0 -7
  179. package/dist/assets/suno-BAJHVOPY.js +0 -7
  180. package/dist/assets/suno-BHBDnzhm.js +0 -7
  181. package/dist/assets/suno-BOD87qmS.js +0 -7
  182. package/dist/assets/suno-C-aj8gY0.js +0 -7
  183. package/dist/assets/suno-C1qgEZWK.js +0 -7
  184. package/dist/assets/suno-CqLyzrg6.js +0 -7
  185. package/dist/assets/suno-DD4a7suZ.js +0 -7
  186. package/dist/assets/suno-DDvBws7-.js +0 -7
  187. package/dist/assets/suno-DTJZ43lx.js +0 -7
  188. package/dist/assets/suno-Dn0e-NG-.js +0 -7
  189. package/dist/assets/suno-DrFDn-MP.js +0 -7
  190. package/dist/assets/suno-LKtIb9A1.js +0 -7
  191. package/dist/assets/suno-kgN2hSbn.js +0 -7
  192. package/dist/assets/veo-B3vKcF9g.js +0 -1
  193. package/dist/assets/veo-BWEVo4sN.js +0 -1
  194. package/dist/assets/veo-BZ9ijdJR.js +0 -1
  195. package/dist/assets/veo-BnqKyLxB.js +0 -1
  196. package/dist/assets/veo-BrYGMJEk.js +0 -1
  197. package/dist/assets/veo-CCZVdSlG.js +0 -1
  198. package/dist/assets/veo-CNOXWYSa.js +0 -1
  199. package/dist/assets/veo-Cdxre4kd.js +0 -1
  200. package/dist/assets/veo-CfCsfF2d.js +0 -1
  201. package/dist/assets/veo-DUZPY3TU.js +0 -1
  202. package/dist/assets/veo-DqS78-xy.js +0 -1
  203. package/dist/assets/veo-Dx6gi8Tw.js +0 -1
  204. package/dist/assets/veo-Lb3ECz4N.js +0 -1
  205. package/dist/assets/veo-PZ_tvW_f.js +0 -1
  206. package/dist/assets/veo-h4Fkhfad.js +0 -1
@@ -1 +1 @@
1
- import{F as G}from"./index.es-D2RJIOwI.js";import{m as R,W,t as H,u as x,w as A,O as N,P as B,q as Z,H as J,j as K}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as l,G as c,T as o,E as C,K as $,ai as n,D as a,R as s,Q as f,S as I,ag as T,J as E,O as v,M as q,X as Q}from"./vendor-vue-BhXato7y.js";import{_ as y,au as X,cx as Y,cy as ee,cz as te,cA as oe,cB as se,cC as U,cD as M,cE as O,cF as z,aN as ae,aJ as j}from"./index-CdkIaG4d.js";import{I as P,S as ne}from"./ScrollList-Dw45lO0t.js";import{I as F}from"./ImagePreview-SUR7TFTL.js";import{C as le}from"./Consumption-BCbR6ZEO.js";import{a as ie}from"./price-CwH8PfMf.js";import{C as re}from"./CopyToClipboard-Djhvl2Fk.js";import{I as ce}from"./ImageWrapper-D7m66Uzp.js";import{B as me}from"./BotPlaceholder-CInEMDBc.js";import{N as pe}from"./NoTasks-BYOtsKOE.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CNlWJWvL.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const ue=w({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:R,FontAwesomeIcon:G},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},ge={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-drawer");return a(),l("div",de,[c("div",ge,[C(e.$slots,"config",{},void 0,!0)]),c("div",fe,[C(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:$(()=>[o(u,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=y(ue,[["render",he],["__scopeId","data-v-bfe5cd4b"]]),$e="",ve=w({name:"PromptInput",components:{ElInput:H,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),be={class:"field"},ke={class:"box"},we={class:"title font-bold"};function ye(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-input");return a(),l("div",be,[c("div",ke,[c("h2",we,s(e.$t("openaiimage.name.prompt")),1),o(u,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ie=y(ve,[["render",ye],["__scopeId","data-v-92f61e4a"]]),Ee=w({name:"ImageUrlsInput",components:{ElUpload:x,ElButton:R,InfoIcon:P,ImagePreview:F,FontAwesomeIcon:G},data(){return{fileList:[],uploadUrl:X()+"/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.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(p=>!p?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const p=this.fileList.find(h=>h?.response?.file_url===i||h?.url===i);p?t.push(p):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(h=>h===i||h?.url===i?.url||h?.response?.file_url===i?.response?.file_url)||t.push(i)}),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(){A.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){A.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.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]"},Te={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Le={class:"controls flex items-center"},Se={class:"file-list flex flex-wrap gap-[10px]"};function Ge(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-upload"),g=n("info-icon"),k=n("image-preview");return a(),l(I,null,[c("div",Ve,[c("h2",Ae,s(e.$t("openaiimage.name.imageUrls")),1),c("div",Te,[c("div",Le,[o(_,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),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:$(()=>[o(d,{size:"small",type:"primary",round:""},{default:$(()=>[o(u,{icon:"fa-solid fa-upload",class:"mr-1"}),f(" "+s(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(g,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Se,[(a(!0),l(I,null,T(e.fileList,(r,b)=>(a(),E(k,{key:r.uid||r?.response?.file_url||r.url||b,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:L=>e.onRemovePreview(b,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Re=y(Ee,[["render",Ge]]),qe=w({name:"OpenAIImageModelSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:ee,label:this.$t("openaiimage.model.gptImage1")},{value:te,label:this.$t("openaiimage.model.gptImage15")},{value:oe,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=Y)}}),Pe={class:"field"},Ce={class:"label"},Ue={class:"box"},Me={class:"title font-bold"};function Oe(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",Pe,[c("div",Ce,[c("div",Ue,[c("h2",Me,s(e.$t("openaiimage.name.model")),1),o(u,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=y(qe,[["render",Oe],["__scopeId","data-v-cec771bd"]]),je=w({name:"OpenAIImageSizeSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:U,label:U},{value:M,label:M},{value:O,label:O}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.size},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})}}},mounted(){this.value||(this.value=se)}}),De={class:"field"},Ne={class:"label"},Be={class:"box"},Fe={class:"title font-bold"};function We(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",De,[c("div",Ne,[c("div",Be,[c("h2",Fe,s(e.$t("openaiimage.name.size")),1),o(u,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=y(je,[["render",We],["__scopeId","data-v-11116785"]]),xe=w({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:G,PromptInput:Ie,Consumption:le,ImageUrlsInput:Re,ModelSelector:ze,ResolutionSelector:He},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return ie({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,t,m,i,p,h){const u=n("model-selector"),d=n("resolution-selector"),_=n("prompt-input"),g=n("image-urls-input"),k=n("consumption"),r=n("font-awesome-icon"),b=n("el-button");return a(),l("div",Ze,[c("div",Je,[o(u,{class:"mb-4"}),o(d,{class:"mb-4"}),o(_,{class:"mb-4"}),o(g,{class:"mb-4"})]),c("div",Ke,[o(k,{value:e.consumption,service:e.service},null,8,["value","service"]),o(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[o(r,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+s(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=y(xe,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:K,CopyToClipboard:re,FontAwesomeIcon:G,ElAlert:J,ImageWrapper:ce,ElButton:R,ElTooltip:Z,ImagePreview:F},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const m=t;if(m?.image_url||m?.url){e.push(m);return}m?.b64_json&&e.push({...m,url:`data:image/png;base64,${m.b64_json}`})}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},at={class:"datetime"},nt={class:"info"},lt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},it={key:1,class:"prompt mt-2"},rt={key:0},ct={key:0,class:q({content:!0,failed:!0})},mt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},pt={class:q({operations:!0,"mt-2":!0,"mb-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={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"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:q({content:!0})},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},It={key:2,class:q({content:!0})},Et={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Lt(e,t,m,i,p,h){const u=n("el-image"),d=n("image-preview"),_=n("image-wrapper"),g=n("el-button"),k=n("el-tooltip"),r=n("font-awesome-icon"),b=n("copy-to-clipboard"),L=n("el-alert");return a(),l("div",et,[c("div",tt,[o(u,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",ot,[c("div",st,[f(s(e.$t("openaiimage.name.openaiimageBot"))+" ",1),c("span",at,s(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(a(),l("div",lt,[(a(!0),l(I,null,T(e.modelValue?.request?.image_urls,(V,S)=>(a(),E(d,{key:S,url:V,name:`image-${S+1}`,closable:!1},null,8,["url","name"]))),128))])):v("",!0),e.modelValue?.request?.prompt?(a(),l("p",it,[f(s(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(a(),l("span",rt," - ("+s(e.$t("openaiimage.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",ct,[c("div",mt,[(a(!0),l(I,null,T(e.images,(V,S)=>(a(),E(_,{key:S,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),c("div",pt,[o(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[o(g,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Q(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[f(s(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(L,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),l("p",ut,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",dt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",gt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",ft,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",ht,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),l("div",_t,[o(L,{closable:!1,class:"failure"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",$t,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",bt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",kt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",wt,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failureReason"))+": "+s(e.modelValue?.response?.error?.message)+" ",1),o(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",yt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(a(),l("div",It,[o(L,{closable:!1,class:"info"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",Et,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",Vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",At,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",Tt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const St=y(Ye,[["render",Lt],["__scopeId","data-v-e650f85d"]]),Gt=w({name:"RecentPanel",components:{TaskPreview:St,BotPlaceholder:me,NoTasks:pe,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Rt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Pt(e,t,m,i,p,h){const u=n("bot-placeholder"),d=n("task-preview"),_=n("scroll-list"),g=n("no-tasks");return a(),l(I,null,[e.tasks?.items===void 0?(a(),l("div",Rt,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E(_,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),l(I,null,T(e.tasks?.items,k=>(a(),E(d,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(a(),l("div",qt,[o(g)])):v("",!0)],64)}const Ct=y(Gt,[["render",Pt]]),D="https://webhook.acedata.cloud/openaiimage",Ut=w({name:"OpenAIImageIndex",components:{ConfigPanel:Xe,Layout:_e,RecentPanel:Ct},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.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 m=this.tasks?.items?.[0];if(!m?.created_at)return;const p=this.$refs.recentPanel?.getScrollElement?.(),h=p?.scrollHeight||0,u=p?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:m.created_at}),await this.$nextTick(),p){const d=p.scrollHeight;p.scrollTop=d-h+u}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/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:m,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",i),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:m,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const m={...e,action:"generate",callback_url:D},i={action:"edit",model:e?.model,prompt:e?.prompt,image_urls:e?.image_urls||[],callback_url:D},p=this.credential?.token;if(!p){console.error("no token specified");return}A.info(this.$t("openaiimage.message.startingTask")),(t?z.edit(i,{token:p}):z.generate(m,{token:p})).then(u=>{console.debug("task accepted",u.data?.task_id),A.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(u=>{const d=u?.response?.data;d?.error?.code===ae?A.error(this.$t("openaiimage.message.usedUp")):A.error(this.$t("openaiimage.message.startTaskFailed")+(d?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Mt(e,t,m,i,p,h){const u=n("config-panel"),d=n("recent-panel"),_=n("layout");return a(),E(_,null,{config:$(()=>[o(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[o(d,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const eo=y(Ut,[["render",Mt]]);export{eo as default};
1
+ import{F as G}from"./index.es-CS-OHrjD.js";import{m as R,W,t as H,u as x,w as A,O as N,P as B,q as Z,H as J,j as K}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as l,G as c,T as o,E as C,K as $,ai as n,D as a,R as s,Q as f,S as I,ag as T,J as E,O as v,M as q,X as Q}from"./vendor-vue-BhXato7y.js";import{_ as y,au as X,cx as Y,cy as ee,cz as te,cA as oe,cB as se,cC as U,cD as M,cE as O,cF as z,aN as ae,aJ as j}from"./index-59WF-aDo.js";import{I as P,S as ne}from"./ScrollList-_cUBLaZZ.js";import{I as F}from"./ImagePreview-COK_lQAf.js";import{C as le}from"./Consumption-DTFyP44R.js";import{a as ie}from"./price-DRZuZOgJ.js";import{C as re}from"./CopyToClipboard-COWZc6L9.js";import{I as ce}from"./ImageWrapper-tWRqlRkx.js";import{B as me}from"./BotPlaceholder-DEITkzHi.js";import{N as pe}from"./NoTasks-C1c_E_pm.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const ue=w({name:"LayoutNanobanana",components:{ElDrawer:W,ElButton:R,FontAwesomeIcon:G},data(){return{drawer:!1}}}),de={class:"main flex flex-row flex-1"},ge={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},fe={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function he(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-drawer");return a(),l("div",de,[c("div",ge,[C(e.$slots,"config",{},void 0,!0)]),c("div",fe,[C(e.$slots,"result",{},void 0,!0)]),o(d,{circle:"",class:"menu",onClick:t[0]||(t[0]=g=>e.drawer=!0)},{default:$(()=>[o(u,{icon:"fa-solid fa-magic"})]),_:1}),o(_,{modelValue:e.drawer,"onUpdate:modelValue":t[1]||(t[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:$(()=>[C(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const _e=y(ue,[["render",he],["__scopeId","data-v-bfe5cd4b"]]),$e="",ve=w({name:"PromptInput",components:{ElInput:H,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.openaiimage?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=$e)}}),be={class:"field"},ke={class:"box"},we={class:"title font-bold"};function ye(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-input");return a(),l("div",be,[c("div",ke,[c("h2",we,s(e.$t("openaiimage.name.prompt")),1),o(u,{content:e.$t("openaiimage.description.prompt"),class:"info"},null,8,["content"])]),o(d,{modelValue:e.prompt,"onUpdate:modelValue":t[0]||(t[0]=_=>e.prompt=_),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("openaiimage.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const Ie=y(ve,[["render",ye],["__scopeId","data-v-92f61e4a"]]),Ee=w({name:"ImageUrlsInput",components:{ElUpload:x,ElButton:R,InfoIcon:P,ImagePreview:F,FontAwesomeIcon:G},data(){return{fileList:[],uploadUrl:X()+"/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.openaiimage?.config?.image_urls}},watch:{value:{immediate:!0,handler(e){if(this.suppressWatch)return;if(!e||e.length===0){const i=(this.fileList||[]).filter(p=>!p?.response?.file_url);this.fileList=i.length?i:[];return}const t=[];e.forEach(i=>{const p=this.fileList.find(h=>h?.response?.file_url===i||h?.url===i);p?t.push(p):t.push({name:i.split("/").pop()||i,url:i,status:"success",percentage:100,response:{file_url:i}})}),(this.fileList||[]).filter(i=>!i?.response?.file_url).forEach(i=>{t.some(h=>h===i||h?.url===i?.url||h?.response?.file_url===i?.response?.file_url)||t.push(i)}),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(){A.warning(this.$t("openaiimage.message.uploadImageExceed"))},onError(){A.error(this.$t("openaiimage.message.uploadImageError"))},onSetImageUrls(){const e=this.urls;this.suppressWatch=!0,this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.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]"},Te={class:"upload-wrapper flex flex-col items-start gap-[8px]"},Le={class:"controls flex items-center"},Se={class:"file-list flex flex-wrap gap-[10px]"};function Ge(e,t,m,i,p,h){const u=n("font-awesome-icon"),d=n("el-button"),_=n("el-upload"),g=n("info-icon"),k=n("image-preview");return a(),l(I,null,[c("div",Ve,[c("h2",Ae,s(e.$t("openaiimage.name.imageUrls")),1),c("div",Te,[c("div",Le,[o(_,{"file-list":e.fileList,"onUpdate:fileList":t[0]||(t[0]=r=>e.fileList=r),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:$(()=>[o(d,{size:"small",type:"primary",round:""},{default:$(()=>[o(u,{icon:"fa-solid fa-upload",class:"mr-1"}),f(" "+s(e.$t("openaiimage.button.uploadImageUrls")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-change","on-remove","headers"]),o(g,{content:e.$t("openaiimage.description.imageUrls"),class:"ml-2"},null,8,["content"])])])]),c("div",Se,[(a(!0),l(I,null,T(e.fileList,(r,b)=>(a(),E(k,{key:r.uid||r?.response?.file_url||r.url||b,url:r.url||r?.response?.file_url,name:r.name,percentage:r.percentage,onRemove:L=>e.onRemovePreview(b,r)},null,8,["url","name","percentage","onRemove"]))),128))])],64)}const Re=y(Ee,[["render",Ge]]),qe=w({name:"OpenAIImageModelSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:ee,label:this.$t("openaiimage.model.gptImage1")},{value:te,label:this.$t("openaiimage.model.gptImage15")},{value:oe,label:this.$t("openaiimage.model.gptImage2")}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.model},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,model:e})}},modelDescription(){return this.$t("openaiimage.description.model")}},mounted(){this.value||(this.value=Y)}}),Pe={class:"field"},Ce={class:"label"},Ue={class:"box"},Me={class:"title font-bold"};function Oe(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",Pe,[c("div",Ce,[c("div",Ue,[c("h2",Me,s(e.$t("openaiimage.name.model")),1),o(u,{content:e.modelDescription,class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ze=y(qe,[["render",Oe],["__scopeId","data-v-cec771bd"]]),je=w({name:"OpenAIImageSizeSelector",components:{ElSelect:B,ElOption:N,InfoIcon:P},data(){return{options:[{value:U,label:U},{value:M,label:M},{value:O,label:O}]}},computed:{value:{get(){return this.$store.state.openaiimage?.config?.size},set(e){this.$store.commit("openaiimage/setConfig",{...this.$store.state.openaiimage?.config,size:e})}}},mounted(){this.value||(this.value=se)}}),De={class:"field"},Ne={class:"label"},Be={class:"box"},Fe={class:"title font-bold"};function We(e,t,m,i,p,h){const u=n("info-icon"),d=n("el-option"),_=n("el-select");return a(),l("div",De,[c("div",Ne,[c("div",Be,[c("h2",Fe,s(e.$t("openaiimage.name.size")),1),o(u,{content:e.$t("openaiimage.description.size"),class:"info"},null,8,["content"])])]),o(_,{modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=g=>e.value=g),class:"value",placeholder:e.$t("openaiimage.placeholder.select")},{default:$(()=>[(a(!0),l(I,null,T(e.options,g=>(a(),E(d,{key:g.value,label:g.label,value:g.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=y(je,[["render",We],["__scopeId","data-v-11116785"]]),xe=w({name:"ConfigPanel",components:{ElButton:R,FontAwesomeIcon:G,PromptInput:Ie,Consumption:le,ImageUrlsInput:Re,ModelSelector:ze,ResolutionSelector:He},emits:["generate"],computed:{config(){return this.$store.state.openaiimage?.config},consumption(){const e={...this.config||{}};return ie({...e},this.service?.cost)},service(){return this.$store.state.openaiimage?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Ze={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,t,m,i,p,h){const u=n("model-selector"),d=n("resolution-selector"),_=n("prompt-input"),g=n("image-urls-input"),k=n("consumption"),r=n("font-awesome-icon"),b=n("el-button");return a(),l("div",Ze,[c("div",Je,[o(u,{class:"mb-4"}),o(d,{class:"mb-4"}),o(_,{class:"mb-4"}),o(g,{class:"mb-4"})]),c("div",Ke,[o(k,{value:e.consumption,service:e.service},null,8,["value","service"]),o(b,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:$(()=>[o(r,{icon:"fa-solid fa-magic",class:"mr-2"}),f(" "+s(e.$t("openaiimage.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=y(xe,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:K,CopyToClipboard:re,FontAwesomeIcon:G,ElAlert:J,ImageWrapper:ce,ElButton:R,ElTooltip:Z,ImagePreview:F},props:{modelValue:{type:Object,required:!0}},computed:{images(){const e=[];return Array.isArray(this.modelValue?.response?.data)&&this.modelValue?.response?.data?.forEach(t=>{const m=t;if(m?.image_url||m?.url){e.push(m);return}m?.b64_json&&e.push({...m,url:`data:image/png;base64,${m.b64_json}`})}),e}},methods:{onEdit(e){if(!e)return;console.debug("Edit image:",e);const t={...this.$store.state.openaiimage?.config||{}};t.image_urls=[e],this.$store.commit("openaiimage/setConfig",t)}}}),et={class:"preview"},tt={class:"left"},ot={class:"main"},st={class:"bot"},at={class:"datetime"},nt={class:"info"},lt={key:0,class:"flex justify-start items-center gap-2 mt-2 w-full overflow-x-auto"},it={key:1,class:"prompt mt-2"},rt={key:0},ct={key:0,class:q({content:!0,failed:!0})},mt={class:"flex justify-start items-center gap-4 w-full overflow-x-auto"},pt={class:q({operations:!0,"mt-2":!0,"mb-2":!0})},ut={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={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"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:1,class:q({content:!0})},$t={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},bt={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},kt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},wt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},yt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},It={key:2,class:q({content:!0})},Et={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Vt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},At={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},Tt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"};function Lt(e,t,m,i,p,h){const u=n("el-image"),d=n("image-preview"),_=n("image-wrapper"),g=n("el-button"),k=n("el-tooltip"),r=n("font-awesome-icon"),b=n("copy-to-clipboard"),L=n("el-alert");return a(),l("div",et,[c("div",tt,[o(u,{src:"https://cdn.acedata.cloud/859plc.jpg",class:"avatar"})]),c("div",ot,[c("div",st,[f(s(e.$t("openaiimage.name.openaiimageBot"))+" ",1),c("span",at,s(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),c("div",nt,[e.modelValue?.request?.image_urls&&e.modelValue?.request?.image_urls.length>0?(a(),l("div",lt,[(a(!0),l(I,null,T(e.modelValue?.request?.image_urls,(V,S)=>(a(),E(d,{key:S,url:V,name:`image-${S+1}`,closable:!1},null,8,["url","name"]))),128))])):v("",!0),e.modelValue?.request?.prompt?(a(),l("p",it,[f(s(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?v("",!0):(a(),l("span",rt," - ("+s(e.$t("openaiimage.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?.success===!0?(a(),l("div",ct,[c("div",mt,[(a(!0),l(I,null,T(e.images,(V,S)=>(a(),E(_,{key:S,src:V?.image_url||V?.url||"","raw-src":V?.image_url||V?.url||""},null,8,["src","raw-src"]))),128))]),c("div",pt,[o(k,{class:"box-item",effect:"dark",content:e.$t("common.button.edit"),placement:"top-start"},{default:$(()=>[o(g,{type:"info",size:"small",class:"btn-action",onClick:t[0]||(t[0]=Q(V=>e.onEdit(e.images?.[0]?.image_url||e.images?.[0]?.url),["stop"]))},{default:$(()=>[f(s(e.$t("common.button.edit")),1)]),_:1})]),_:1},8,["content"])]),o(L,{closable:!1,class:"mt-2 success"},{default:$(()=>[e.modelValue?.request?.model?(a(),l("p",ut,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",dt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",gt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",ft,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",ht,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(a(),l("div",_t,[o(L,{closable:!1,class:"failure"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",$t,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",bt,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",kt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])]),c("p",wt,[o(r,{icon:"fa-solid fa-circle-info",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failureReason"))+": "+s(e.modelValue?.response?.error?.message)+" ",1),o(b,{content:e.modelValue?.response?.error?.message,class:"btn-copy"},null,8,["content"])]),e.modelValue?.response?.trace_id?(a(),l("p",yt,[o(r,{icon:"fa-solid fa-hashtag",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.traceId"))+": "+s(e.modelValue?.response?.trace_id)+" ",1),o(b,{content:e.modelValue?.response?.trace_id,class:"btn-copy"},null,8,["content"])])):v("",!0)]),_:1})])):(a(),l("div",It,[o(L,{closable:!1,class:"info"},{template:$(()=>[o(r,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.failure")),1)]),default:$(()=>[e.modelValue?.request?.model?(a(),l("p",Et,[o(r,{icon:"fa-solid fa-cube",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.model"))+": "+s(e.modelValue?.request?.model),1)])):v("",!0),e.modelValue?.request?.size?(a(),l("p",Vt,[o(r,{icon:"fa-solid fa-image",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.size"))+": "+s(e.modelValue?.request?.size),1)])):v("",!0),e.modelValue?.request?.action?(a(),l("p",At,[o(r,{icon:"fa-solid fa-bolt",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.task"))+": "+s(e.modelValue?.request?.action==="generate"?e.$t("openaiimage.name.generate"):e.$t("openaiimage.name.edits")),1)])):v("",!0),c("p",Tt,[o(r,{icon:"fa-solid fa-magic",class:"mr-1"}),f(" "+s(e.$t("openaiimage.name.taskId"))+": "+s(e.modelValue?.id)+" ",1),o(b,{content:e.modelValue?.id,class:"btn-copy"},null,8,["content"])])]),_:1})]))])])}const St=y(Ye,[["render",Lt],["__scopeId","data-v-e650f85d"]]),Gt=w({name:"RecentPanel",components:{TaskPreview:St,BotPlaceholder:me,NoTasks:pe,ScrollList:ne},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.openaiimage?.tasks,items:this.$store.state.openaiimage?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),Rt={key:0},qt={key:2,class:"w-full h-full flex items-center justify-center"};function Pt(e,t,m,i,p,h){const u=n("bot-placeholder"),d=n("task-preview"),_=n("scroll-list"),g=n("no-tasks");return a(),l(I,null,[e.tasks?.items===void 0?(a(),l("div",Rt,[o(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),E(_,{key:1,ref:"scrollList",class:"tasks h-full w-full overflow-y-auto",loading:e.loading,onReachTop:t[0]||(t[0]=k=>e.$emit("reach-top"))},{default:$(()=>[(a(!0),l(I,null,T(e.tasks?.items,k=>(a(),E(d,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(a(),l("div",qt,[o(g)])):v("",!0)],64)}const Ct=y(Gt,[["render",Pt]]),D="https://webhook.acedata.cloud/openaiimage",Ut=w({name:"OpenAIImageIndex",components:{ConfigPanel:Xe,Layout:_e,RecentPanel:Ct},inject:["initialized"],data(){return{task:void 0,job:0,loading:!1}},computed:{applicationsLoading(){return this.$store.state.openaiimage?.status?.getApplications===j.Request},tasksLoading(){return this.$store.state.openaiimage?.status?.getTasks===j.Request},credential(){return this.$store.state.openaiimage?.credential},config(){return this.$store.state.openaiimage?.config},application(){return this.$store.state.openaiimage?.application},tasks(){return this.$store.state.openaiimage?.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 m=this.tasks?.items?.[0];if(!m?.created_at)return;const p=this.$refs.recentPanel?.getScrollElement?.(),h=p?.scrollHeight||0,u=p?.scrollTop||0;this.loading=!0;try{if(await this.onGetTasks({createdAtMax:m.created_at}),await this.$nextTick(),p){const d=p.scrollHeight;p.scrollTop=d-h+u}}finally{this.loading=!1}},async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("openaiimage/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("openaiimage/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:m,createdAtMax:i}=e||{};console.debug("limit",t,"createdAtMin",m,"createdAtMax",i),await this.$store.dispatch("openaiimage/getTasks",{limit:t,createdAtMin:m,createdAtMax:i})},async onGenerate(){const e={...this.config||{}},t=Array.isArray(e?.image_urls)&&e.image_urls.length>0;!t&&"image_urls"in e&&delete e.image_urls;const m={...e,action:"generate",callback_url:D},i={action:"edit",model:e?.model,prompt:e?.prompt,image_urls:e?.image_urls||[],callback_url:D},p=this.credential?.token;if(!p){console.error("no token specified");return}A.info(this.$t("openaiimage.message.startingTask")),(t?z.edit(i,{token:p}):z.generate(m,{token:p})).then(u=>{console.debug("task accepted",u.data?.task_id),A.success(this.$t("openaiimage.message.startTaskSuccess"))}).catch(u=>{const d=u?.response?.data;d?.error?.code===ae?A.error(this.$t("openaiimage.message.usedUp")):A.error(this.$t("openaiimage.message.startTaskFailed")+(d?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function Mt(e,t,m,i,p,h){const u=n("config-panel"),d=n("recent-panel"),_=n("layout");return a(),E(_,null,{config:$(()=>[o(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:$(()=>[o(d,{ref:"recentPanel",loading:e.loading,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const eo=y(Ut,[["render",Mt]]);export{eo as default};
@@ -1 +1 @@
1
- import{E as T,a as D,b as E}from"./EditArray-BGybpge_.js";import{h as U,_ as V}from"./index-CdkIaG4d.js";import{M as F,k as A,N as _,x as q,A as B,j as L,B as N,p as j}from"./vendor-element-plus-ZfFlETcH.js";import{d as R,J as O,K as s,T as t,ai as n,G as l,R as o,Q as m,C as y,ag as Q,S as K,D as w,L as k,O as G,U as C}from"./vendor-vue-BhXato7y.js";import"./index.es-D2RJIOwI.js";import"./vendor-web3-CNlWJWvL.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const J=R({name:"SiteIndex",components:{EditText:E,EditImage:D,EditArray:T,ElDivider:j,ElRow:N,ElImage:L,ElCol:B,ElCard:q,ElForm:_,ElSwitch:A,ElFormItem:F},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")})}}}),M={class:"title"},W={class:"title"},z={class:"block w-full"},H={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},Y={class:"block w-full"},Z={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,ge,we,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"),g=n("el-switch");return w(),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",M,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",W,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",H,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",P,[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",X,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",Y,[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",Z,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(()=>[(w(),y(K,null,Q(["chat","midjourney","qrart","nanobanana","openaiimage","seedream","seedance","suno","luma","pika","kling","flux","hailuo","headshots","wan","producer","serp","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(g,{"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((w(),y("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(g,{"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(g,{"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]]):G("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Fe=V(J,[["render",ce],["__scopeId","data-v-38430f7a"]]);export{Fe as default};
1
+ import{E as T,a as D,b as E}from"./EditArray-UipmkzQk.js";import{h as U,_ as V}from"./index-59WF-aDo.js";import{M as F,k as A,N as _,x as q,A as B,j as L,B as N,p as j}from"./vendor-element-plus-ZfFlETcH.js";import{d as R,J as O,K as s,T as t,ai as n,G as l,R as o,Q as m,C as y,ag as Q,S as K,D as w,L as k,O as G,U as C}from"./vendor-vue-BhXato7y.js";import"./index.es-CS-OHrjD.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const J=R({name:"SiteIndex",components:{EditText:E,EditImage:D,EditArray:T,ElDivider:j,ElRow:N,ElImage:L,ElCol:B,ElCard:q,ElForm:_,ElSwitch:A,ElFormItem:F},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")})}}}),M={class:"title"},W={class:"title"},z={class:"block w-full"},H={class:"block tip"},P={class:"block w-full"},X={class:"block tip"},Y={class:"block w-full"},Z={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,ge,we,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"),g=n("el-switch");return w(),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",M,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",W,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",H,o(e.$t("site.message.originTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.title")},{default:s(()=>[l("span",P,[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",X,o(e.$t("site.message.titleTip")),1)]),_:1},8,["label"]),t(d,{label:e.$t("site.field.logo")},{default:s(()=>[l("span",Y,[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",Z,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(()=>[(w(),y(K,null,Q(["chat","midjourney","qrart","nanobanana","openaiimage","seedream","seedance","suno","luma","pika","kling","flux","hailuo","headshots","wan","producer","serp","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(g,{"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((w(),y("div",be,[t(d,{label:"WeChat"},{default:s(()=>[t(g,{"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(g,{"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]]):G("",!0)]),_:2},1032,["label"])),64))]),_:1},8,["model"])]),_:1})]),_:1})]),_:1})]),_:1})]),_:1})}const Fe=V(J,[["render",ce],["__scopeId","data-v-38430f7a"]]);export{Fe as default};
@@ -1 +1 @@
1
- import{F as L}from"./index.es-D2RJIOwI.js";import{m as I,W as X,t as H,O as R,P as U,k as P,u as M,w,q as J,H as K,j as Q}from"./vendor-element-plus-ZfFlETcH.js";import{d as b,C as i,G as r,T as s,E as D,K as p,ai as t,D as n,R as o,S as T,ag as A,J as y,O as v,Q as h,M as C,X as Y}from"./vendor-vue-BhXato7y.js";import{_ as E,cR as Z,cS as x,cT as ee,cU as G,cV as se,cW as te,cX as oe,cY as ne,au as j,cZ as ae,c_ as le,c$ as ie,d0 as re,a4 as ce,d1 as de,aN as me,aJ as O}from"./index-CdkIaG4d.js";import{I as S,S as ue}from"./ScrollList-Dw45lO0t.js";import{p as B}from"./pasteUploadMixin-BurWbGNQ.js";import{I as q}from"./ImagePreview-SUR7TFTL.js";import{C as pe}from"./Consumption-BCbR6ZEO.js";import{a as fe}from"./price-CwH8PfMf.js";import{C as _e}from"./CopyToClipboard-Djhvl2Fk.js";import{V as he}from"./VideoPlayer-gXXZbisY.js";import{I as ve}from"./ImageWrapper-D7m66Uzp.js";import{B as $e}from"./BotPlaceholder-CInEMDBc.js";import{N as ge}from"./NoTasks-BYOtsKOE.js";import{l as be}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CNlWJWvL.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const Ee=b({name:"LayoutSeedance",components:{ElDrawer:X,ElButton:I,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ye={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Se(e,a,u,f,g,$){const c=t("font-awesome-icon"),l=t("el-button"),m=t("el-drawer");return n(),i("div",ke,[r("div",we,[D(e.$slots,"config",{},void 0,!0)]),r("div",ye,[D(e.$slots,"result",{},void 0,!0)]),s(l,{circle:"",class:"menu",onClick:a[0]||(a[0]=d=>e.drawer=!0)},{default:p(()=>[s(c,{icon:"fa-solid fa-magic"})]),_:1}),s(m,{modelValue:e.drawer,"onUpdate:modelValue":a[1]||(a[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[D(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ve=E(Ee,[["render",Se],["__scopeId","data-v-02e4e4b3"]]),Te="",Le=b({name:"SeedancePromptInput",components:{ElInput:H,InfoIcon:S},computed:{prompt:{get(){return this.$store.state.seedance?.config?.prompt},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Te)}}),Ie={class:"field"},Ce={class:"box"},Ae={class:"title font-bold"};function Fe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-input");return n(),i("div",Ie,[r("div",Ce,[r("h2",Ae,o(e.$t("seedance.name.prompt")),1),s(c,{content:e.$t("seedance.description.prompt"),class:"info"},null,8,["content"])]),s(l,{modelValue:e.prompt,"onUpdate:modelValue":a[0]||(a[0]=m=>e.prompt=m),rows:4,type:"textarea",class:"prompt",placeholder:e.$t("seedance.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const De=E(Le,[["render",Fe],["__scopeId","data-v-865909f4"]]),Re=b({name:"SeedanceModelSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:x,label:this.$t("seedance.model.seedance10pro")},{value:ee,label:this.$t("seedance.model.seedance10proFast")},{value:G,label:this.$t("seedance.model.seedance15pro")},{value:se,label:this.$t("seedance.model.seedance10liteT2v")},{value:te,label:this.$t("seedance.model.seedance10liteI2v")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.model},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,model:e})}}},mounted(){this.value||(this.value=Z)}}),Ue={class:"field"},Ne={class:"label"},Oe={class:"box"},Pe={class:"title font-bold"};function Me(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Ue,[r("div",Ne,[r("div",Oe,[r("h2",Pe,o(e.$t("seedance.name.model")),1),s(c,{content:e.$t("seedance.description.model"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=E(Re,[["render",Me],["__scopeId","data-v-eaa1425a"]]),je=b({name:"SeedanceDurationSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:2,label:"2s"},{value:3,label:"3s"},{value:4,label:"4s"},{value:5,label:"5s"},{value:6,label:"6s"},{value:7,label:"7s"},{value:8,label:"8s"},{value:9,label:"9s"},{value:10,label:"10s"},{value:11,label:"11s"},{value:12,label:"12s"}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.duration},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,duration:e})}}},mounted(){this.value||(this.value=oe)}}),Be={class:"field"},qe={class:"label"},ze={class:"box"},We={class:"title font-bold"};function Xe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Be,[r("div",qe,[r("div",ze,[r("h2",We,o(e.$t("seedance.name.duration")),1),s(c,{content:e.$t("seedance.description.duration"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=E(je,[["render",Xe],["__scopeId","data-v-5c809a72"]]),Je=b({name:"SeedanceGenerateAudioSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{isSupported(){return this.$store.state.seedance?.config?.model===G},value:{get(){return this.$store.state.seedance?.config?.generate_audio??!1},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,generate_audio:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=ne)}}),Ke={key:0,class:"field"},Qe={class:"label"},Ye={class:"box"},Ze={class:"title font-bold"},xe={class:"value"};function es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return e.isSupported?(n(),i("div",Ke,[r("div",Qe,[r("div",Ye,[r("h2",Ze,o(e.$t("seedance.name.generateAudio")),1),s(c,{content:e.$t("seedance.description.generateAudio"),class:"info"},null,8,["content"])])]),r("div",xe,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])):v("",!0)}const ss=E(Je,[["render",es],["__scopeId","data-v-8d716dcc"]]),ts=b({name:"SeedanceFirstFrameImage",components:{ElUpload:M,ElButton:I,InfoIcon:S,FontAwesomeIcon:L,ImagePreview:q},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetFirstFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="first_frame");e&&u.push({url:e,role:"first_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetFirstFrameUrl()},async onRemove(){this.onSetFirstFrameUrl()}}}),os={class:"relative"},ns={class:"flex justify-between"},as={class:"flex justify-start items-center"},ls={class:"text-sm font-bold"};function is(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",os,[r("div",ns,[r("div",as,[r("span",ls,o(e.$t("seedance.name.firstFrame")),1),s(c,{content:e.$t("seedance.description.firstFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const rs=E(ts,[["render",is],["__scopeId","data-v-5294baf8"]]),cs=b({name:"SeedanceLastFrameImage",components:{ElUpload:M,ElButton:I,ImagePreview:q,InfoIcon:S,FontAwesomeIcon:L},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetLastFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="last_frame");e&&u.push({url:e,role:"last_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetLastFrameUrl()},async onRemove(){this.onSetLastFrameUrl()}}}),ds={class:"relative"},ms={class:"flex justify-between"},us={class:"flex justify-start items-center"},ps={class:"text-sm font-bold"};function fs(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",ds,[r("div",ms,[r("div",us,[r("span",ps,o(e.$t("seedance.name.lastFrame")),1),s(c,{content:e.$t("seedance.description.lastFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const _s=E(cs,[["render",fs],["__scopeId","data-v-f423739f"]]),hs=b({name:"SeedanceServiceTierSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:le,label:this.$t("seedance.serviceTier.default")},{value:ie,label:this.$t("seedance.serviceTier.flex")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.service_tier},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,service_tier:e})}}},mounted(){this.value||(this.value=ae)}}),vs={class:"field"},$s={class:"label"},gs={class:"box"},bs={class:"title font-bold"};function Es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",vs,[r("div",$s,[r("div",gs,[r("h2",bs,o(e.$t("seedance.name.serviceTier")),1),s(c,{content:e.$t("seedance.description.serviceTier"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ks=E(hs,[["render",Es],["__scopeId","data-v-a62125ec"]]),ws=b({name:"SeedanceReturnLastFrameSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{value:{get(){return this.$store.state.seedance?.config?.return_last_frame},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,return_last_frame:e})}}},mounted(){this.value===void 0&&(this.value=re)}}),ys={class:"field"},Ss={class:"label"},Vs={class:"box"},Ts={class:"title font-bold"},Ls={class:"value"};function Is(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return n(),i("div",ys,[r("div",Ss,[r("div",Vs,[r("h2",Ts,o(e.$t("seedance.name.returnLastFrame")),1),s(c,{content:e.$t("seedance.description.returnLastFrame"),class:"info"},null,8,["content"])])]),r("div",Ls,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])}const Cs=E(ws,[["render",Is],["__scopeId","data-v-cd179b1c"]]),As=b({name:"SeedanceConfigPanel",components:{ElButton:I,FontAwesomeIcon:L,PromptInput:De,ModelSelector:Ge,DurationSelector:He,GenerateAudioSwitch:ss,ServiceTierSelector:ks,ReturnLastFrameSwitch:Cs,FirstFrameImage:rs,LastFrameImage:_s,Consumption:pe},emits:["generate"],computed:{config(){return this.$store.state.seedance?.config},consumption(){return fe(this.config,this.service?.cost)},service(){return this.$store.state.seedance?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Fs={class:"flex flex-col h-full"},Ds={class:"flex-1 overflow-y-auto p-5"},Rs={class:"flex flex-col items-center justify-center px-5 pb-5"};function Us(e,a,u,f,g,$){const c=t("prompt-input"),l=t("model-selector"),m=t("duration-selector"),d=t("generate-audio-switch"),k=t("service-tier-selector"),_=t("return-last-frame-switch"),V=t("first-frame-image"),F=t("last-frame-image"),N=t("consumption"),z=t("font-awesome-icon"),W=t("el-button");return n(),i("div",Fs,[r("div",Ds,[s(c,{class:"mb-4"}),s(l,{class:"mb-4"}),s(m,{class:"mb-4"}),s(d,{class:"mb-4"}),s(k,{class:"mb-4"}),s(_,{class:"mb-4"}),s(V,{class:"mb-2"}),s(F,{class:"mb-2"})]),r("div",Rs,[s(N,{value:e.consumption,service:e.service},null,8,["value","service"]),s(W,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[s(z,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+o(e.$t("seedance.button.generate")),1)]),_:1},8,["onClick"])])])}const Ns=E(As,[["render",Us]]),Os=b({name:"SeedanceTaskPreview",components:{ElImage:Q,CopyToClipboard:_e,FontAwesomeIcon:L,ElAlert:K,VideoPlayer:he,ElTooltip:J,ElButton:I,ImageWrapper:ve},props:{modelValue:{type:Object,required:!0}},data(){return{seedanceLogo:ce}},computed:{video(){return this.modelValue?.response?.data}},methods:{onDownload(e){window.open(e,"_blank")}}}),Ps={class:"preview"},Ms={class:"left"},Gs={class:"main"},js={class:"bot"},Bs={class:"datetime"},qs={class:"info"},zs={key:0,class:"prompt mt-2"},Ws={key:0},Xs={key:1},Hs={key:0,class:C({content:!0})},Js={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ks={key:1,class:C({content:!0})},Qs={key:0,class:"mb-4"},Ys={key:1,class:"mb-4"},Zs={key:2,class:C({operations:!0,"mt-2":!0,"mb-2":!0})},xs={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},et={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},st={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},tt={key:0},ot={key:1},nt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:2,class:C({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ct={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mt={key:3,class:C({content:!0})},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"};function ft(e,a,u,f,g,$){const c=t("el-image"),l=t("font-awesome-icon"),m=t("copy-to-clipboard"),d=t("el-alert"),k=t("video-player"),_=t("image-wrapper"),V=t("el-button"),F=t("el-tooltip");return n(),i("div",Ps,[r("div",Ms,[s(c,{src:e.seedanceLogo,class:"avatar"},null,8,["src"])]),r("div",Gs,[r("div",js,[h(o(e.$t("seedance.name.seedanceBot"))+" ",1),r("span",Bs,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",qs,[e.modelValue?.request?.prompt?(n(),i("p",zs,[h(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?e.video?.status==="processing"||e.video?.status==="pending"?(n(),i("span",Xs," - ("+o(e.$t("seedance.status.processing"))+") ",1)):v("",!0):(n(),i("span",Ws," - ("+o(e.$t("seedance.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(n(),i("div",Ks,[e.video?.video_url?(n(),i("div",Qs,[s(k,{src:e.video?.video_url},null,8,["src"])])):v("",!0),e.video?.last_frame_url?(n(),i("div",Ys,[s(_,{src:e.video?.last_frame_url,"raw-src":e.video?.last_frame_url},null,8,["src","raw-src"])])):v("",!0),e.video?.video_url?(n(),i("div",Zs,[s(F,{class:"box-item",effect:"dark",content:e.$t("seedance.message.downloadVideo"),placement:"top-start"},{default:p(()=>[s(V,{type:"info",size:"small",class:"btn-action",onClick:a[0]||(a[0]=Y(N=>e.onDownload(e.video?.video_url),["stop"]))},{default:p(()=>[h(o(e.$t("seedance.button.download")),1)]),_:1})]),_:1},8,["content"])])):v("",!0),s(d,{closable:!1,class:"mt-2 success"},{default:p(()=>[e.modelValue?.request?.model?(n(),i("p",xs,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),h(" "+o(e.$t("seedance.name.model"))+": "+o(e.modelValue?.request?.model),1)])):v("",!0),e.video?.duration?(n(),i("p",et,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.name.duration"))+": "+o(e.video?.duration)+"s ",1)])):v("",!0),e.video?.resolution?(n(),i("p",st,[s(l,{icon:"fa-solid fa-expand",class:"mr-1"}),h(" "+o(e.$t("seedance.name.resolution"))+": "+o(e.video?.resolution)+" ",1),e.video?.ratio?(n(),i("span",tt," · "+o(e.video?.ratio),1)):v("",!0),e.video?.framespersecond?(n(),i("span",ot," · "+o(e.video?.framespersecond)+"fps",1)):v("",!0)])):v("",!0),e.modelValue?.request?.generate_audio?(n(),i("p",nt,[s(l,{icon:"fa-solid fa-volume-up",class:"mr-1"}),h(" "+o(e.$t("seedance.name.generateAudio"))+": "+o(e.$t("seedance.button.on")),1)])):v("",!0),r("p",at,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",lt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),i("div",it,[s(d,{closable:!1,class:"failure"},{template:p(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failure")),1)]),default:p(()=>[r("p",rt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.error?.message?(n(),i("p",ct,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(m,{content:e.modelValue?.response?.error?.message,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0),e.modelValue?.response?.trace_id?(n(),i("p",dt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",mt,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.status")),1)]),default:p(()=>[r("p",ut,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",pt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",Hs,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-regular fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.status.pending")),1)]),default:p(()=>[r("p",Js,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})]))])])}const _t=E(Os,[["render",ft],["__scopeId","data-v-43479338"]]),ht=b({name:"SeedanceRecentPanel",components:{TaskPreview:_t,BotPlaceholder:$e,NoTasks:ge,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],computed:{tasks(){return{...this.$store.state.seedance?.tasks,items:this.$store.state.seedance?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),vt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function gt(e,a,u,f,g,$){const c=t("bot-placeholder"),l=t("task-preview"),m=t("scroll-list"),d=t("no-tasks");return n(),i(T,null,[e.tasks?.items===void 0?(n(),i("div",vt,[s(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(m,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:a[0]||(a[0]=k=>e.$emit("reach-top"))},{default:p(()=>[(n(!0),i(T,null,A(e.tasks?.items,k=>(n(),y(l,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),i("div",$t,[s(d)])):v("",!0)],64)}const bt=E(ht,[["render",gt]]),Et="https://webhook.acedata.cloud/seedance",kt=b({name:"SeedanceIndex",components:{ConfigPanel:Ns,Layout:Ve,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.seedance?.status?.getApplications===O.Request},tasksLoading(){return this.$store.state.seedance?.status?.getTasks===O.Request||this.fetchingTasks},credential(){return this.$store.state.seedance?.credential},config(){return this.$store.state.seedance?.config},tasks(){return this.$store.state.seedance?.tasks}},watch:{initialized:{async handler(e){e&&(await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await be({tasks:this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){await this.$store.dispatch("seedance/getService")},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;const{limit:a=5,createdAtMin:u,createdAtMax:f}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch("seedance/getTasks",{limit:a,createdAtMin:u,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config||{}};if(typeof e?.prompt=="string"&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),Array.isArray(e?.images)){e.images=e.images.filter(c=>!!c?.url);const g=e.images.some(c=>c?.role==="first_frame"),$=e.images.some(c=>c?.role==="last_frame");!g&&$&&(e.images=e.images.map(c=>c?.role==="last_frame"?{...c,role:"first_frame"}:c))}!(Array.isArray(e?.images)&&e.images.length>0)&&"images"in e&&delete e.images;const u={...e,callback_url:Et},f=this.credential?.token;if(!f){console.error("no token specified");return}w.info(this.$t("seedance.message.startingTask")),de.generate(u,{token:f}).then(()=>{w.success(this.$t("seedance.message.startTaskSuccess"))}).catch(g=>{const $=g?.response?.data;$?.error?.code===me?w.error(this.$t("seedance.message.usedUp")):w.error(this.$t("seedance.message.startTaskFailed")+($?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,a,u,f,g,$){const c=t("config-panel"),l=t("recent-panel"),m=t("layout");return n(),y(m,null,{config:p(()=>[s(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[s(l,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const zt=E(kt,[["render",wt]]);export{zt as default};
1
+ import{F as L}from"./index.es-CS-OHrjD.js";import{m as I,W as X,t as H,O as R,P as U,k as P,u as M,w,q as J,H as K,j as Q}from"./vendor-element-plus-ZfFlETcH.js";import{d as b,C as i,G as r,T as s,E as D,K as p,ai as t,D as n,R as o,S as T,ag as A,J as y,O as v,Q as h,M as C,X as Y}from"./vendor-vue-BhXato7y.js";import{_ as E,cR as Z,cS as x,cT as ee,cU as G,cV as se,cW as te,cX as oe,cY as ne,au as j,cZ as ae,c_ as le,c$ as ie,d0 as re,a4 as ce,d1 as de,aN as me,aJ as O}from"./index-59WF-aDo.js";import{I as S,S as ue}from"./ScrollList-_cUBLaZZ.js";import{p as B}from"./pasteUploadMixin-BurWbGNQ.js";import{I as q}from"./ImagePreview-COK_lQAf.js";import{C as pe}from"./Consumption-DTFyP44R.js";import{a as fe}from"./price-DRZuZOgJ.js";import{C as _e}from"./CopyToClipboard-COWZc6L9.js";import{V as he}from"./VideoPlayer-CF6zk-Kd.js";import{I as ve}from"./ImageWrapper-tWRqlRkx.js";import{B as $e}from"./BotPlaceholder-DEITkzHi.js";import{N as ge}from"./NoTasks-C1c_E_pm.js";import{l as be}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const Ee=b({name:"LayoutSeedance",components:{ElDrawer:X,ElButton:I,FontAwesomeIcon:L},data(){return{drawer:!1}}}),ke={class:"main flex flex-row flex-1"},we={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ye={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function Se(e,a,u,f,g,$){const c=t("font-awesome-icon"),l=t("el-button"),m=t("el-drawer");return n(),i("div",ke,[r("div",we,[D(e.$slots,"config",{},void 0,!0)]),r("div",ye,[D(e.$slots,"result",{},void 0,!0)]),s(l,{circle:"",class:"menu",onClick:a[0]||(a[0]=d=>e.drawer=!0)},{default:p(()=>[s(c,{icon:"fa-solid fa-magic"})]),_:1}),s(m,{modelValue:e.drawer,"onUpdate:modelValue":a[1]||(a[1]=d=>e.drawer=d),direction:"ltr","with-header":!1,size:"350px"},{default:p(()=>[D(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const Ve=E(Ee,[["render",Se],["__scopeId","data-v-02e4e4b3"]]),Te="",Le=b({name:"SeedancePromptInput",components:{ElInput:H,InfoIcon:S},computed:{prompt:{get(){return this.$store.state.seedance?.config?.prompt},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Te)}}),Ie={class:"field"},Ce={class:"box"},Ae={class:"title font-bold"};function Fe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-input");return n(),i("div",Ie,[r("div",Ce,[r("h2",Ae,o(e.$t("seedance.name.prompt")),1),s(c,{content:e.$t("seedance.description.prompt"),class:"info"},null,8,["content"])]),s(l,{modelValue:e.prompt,"onUpdate:modelValue":a[0]||(a[0]=m=>e.prompt=m),rows:4,type:"textarea",class:"prompt",placeholder:e.$t("seedance.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const De=E(Le,[["render",Fe],["__scopeId","data-v-865909f4"]]),Re=b({name:"SeedanceModelSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:x,label:this.$t("seedance.model.seedance10pro")},{value:ee,label:this.$t("seedance.model.seedance10proFast")},{value:G,label:this.$t("seedance.model.seedance15pro")},{value:se,label:this.$t("seedance.model.seedance10liteT2v")},{value:te,label:this.$t("seedance.model.seedance10liteI2v")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.model},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,model:e})}}},mounted(){this.value||(this.value=Z)}}),Ue={class:"field"},Ne={class:"label"},Oe={class:"box"},Pe={class:"title font-bold"};function Me(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Ue,[r("div",Ne,[r("div",Oe,[r("h2",Pe,o(e.$t("seedance.name.model")),1),s(c,{content:e.$t("seedance.description.model"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ge=E(Re,[["render",Me],["__scopeId","data-v-eaa1425a"]]),je=b({name:"SeedanceDurationSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:2,label:"2s"},{value:3,label:"3s"},{value:4,label:"4s"},{value:5,label:"5s"},{value:6,label:"6s"},{value:7,label:"7s"},{value:8,label:"8s"},{value:9,label:"9s"},{value:10,label:"10s"},{value:11,label:"11s"},{value:12,label:"12s"}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.duration},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,duration:e})}}},mounted(){this.value||(this.value=oe)}}),Be={class:"field"},qe={class:"label"},ze={class:"box"},We={class:"title font-bold"};function Xe(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",Be,[r("div",qe,[r("div",ze,[r("h2",We,o(e.$t("seedance.name.duration")),1),s(c,{content:e.$t("seedance.description.duration"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const He=E(je,[["render",Xe],["__scopeId","data-v-5c809a72"]]),Je=b({name:"SeedanceGenerateAudioSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{isSupported(){return this.$store.state.seedance?.config?.model===G},value:{get(){return this.$store.state.seedance?.config?.generate_audio??!1},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,generate_audio:e})}}},watch:{isSupported(e){!e&&this.value&&(this.value=!1)}},mounted(){this.value===void 0&&(this.value=ne)}}),Ke={key:0,class:"field"},Qe={class:"label"},Ye={class:"box"},Ze={class:"title font-bold"},xe={class:"value"};function es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return e.isSupported?(n(),i("div",Ke,[r("div",Qe,[r("div",Ye,[r("h2",Ze,o(e.$t("seedance.name.generateAudio")),1),s(c,{content:e.$t("seedance.description.generateAudio"),class:"info"},null,8,["content"])])]),r("div",xe,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])):v("",!0)}const ss=E(Je,[["render",es],["__scopeId","data-v-8d716dcc"]]),ts=b({name:"SeedanceFirstFrameImage",components:{ElUpload:M,ElButton:I,InfoIcon:S,FontAwesomeIcon:L,ImagePreview:q},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetFirstFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="first_frame");e&&u.push({url:e,role:"first_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetFirstFrameUrl()},async onRemove(){this.onSetFirstFrameUrl()}}}),os={class:"relative"},ns={class:"flex justify-between"},as={class:"flex justify-start items-center"},ls={class:"text-sm font-bold"};function is(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",os,[r("div",ns,[r("div",as,[r("span",ls,o(e.$t("seedance.name.firstFrame")),1),s(c,{content:e.$t("seedance.description.firstFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const rs=E(ts,[["render",is],["__scopeId","data-v-5294baf8"]]),cs=b({name:"SeedanceLastFrameImage",components:{ElUpload:M,ElButton:I,ImagePreview:q,InfoIcon:S,FontAwesomeIcon:L},mixins:[B],data(){return{fileList:[],uploadUrl:j()+"/api/v1/files/"}},computed:{headers(){return{Authorization:`Bearer ${this.$store.state.token.access}`}},urls(){return this.fileList.map(e=>e?.response?.file_url)}},methods:{onExceed(){w.warning(this.$t("seedance.message.uploadExceed"))},onError(){w.error(this.$t("seedance.message.uploadError"))},onSetLastFrameUrl(){const e=this.urls?.[0],u=(this.$store.state.seedance?.config?.images||[]).filter(f=>f?.role!=="last_frame");e&&u.push({url:e,role:"last_frame"}),this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,images:u.length>0?u:void 0})},async onSuccess(){this.onSetLastFrameUrl()},async onRemove(){this.onSetLastFrameUrl()}}}),ds={class:"relative"},ms={class:"flex justify-between"},us={class:"flex justify-start items-center"},ps={class:"text-sm font-bold"};function fs(e,a,u,f,g,$){const c=t("info-icon"),l=t("image-preview"),m=t("font-awesome-icon"),d=t("el-button"),k=t("el-upload");return n(),i("div",ds,[r("div",ms,[r("div",us,[r("span",ps,o(e.$t("seedance.name.lastFrame")),1),s(c,{content:e.$t("seedance.description.lastFrame")},null,8,["content"])])]),s(k,{ref:"uploader","file-list":e.fileList,"onUpdate:fileList":a[0]||(a[0]=_=>e.fileList=_),name:"file",accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",limit:1,class:"upload-wrapper",multiple:!1,action:e.uploadUrl,"list-type":"picture","on-exceed":e.onExceed,"on-error":e.onError,"on-success":e.onSuccess,"on-remove":e.onRemove,headers:e.headers},{file:p(({file:_})=>[_.url&&_.percentage!==void 0?(n(),y(l,{key:0,url:_.url,name:_.name,percentage:_.percentage,onRemove:V=>e.fileList.splice(e.fileList.indexOf(_),1)},null,8,["url","name","percentage","onRemove"])):v("",!0)]),default:p(()=>[s(d,{round:"",type:"primary",size:"small",class:"btn btn-upload"},{default:p(()=>[s(m,{icon:"fa-solid fa-upload",class:"icon mr-1"}),h(" "+o(e.$t("seedance.button.upload")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-success","on-remove","headers"])])}const _s=E(cs,[["render",fs],["__scopeId","data-v-f423739f"]]),hs=b({name:"SeedanceServiceTierSelector",components:{ElSelect:U,ElOption:R,InfoIcon:S},data(){return{options:[{value:le,label:this.$t("seedance.serviceTier.default")},{value:ie,label:this.$t("seedance.serviceTier.flex")}]}},computed:{value:{get(){return this.$store.state.seedance?.config?.service_tier},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,service_tier:e})}}},mounted(){this.value||(this.value=ae)}}),vs={class:"field"},$s={class:"label"},gs={class:"box"},bs={class:"title font-bold"};function Es(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-option"),m=t("el-select");return n(),i("div",vs,[r("div",$s,[r("div",gs,[r("h2",bs,o(e.$t("seedance.name.serviceTier")),1),s(c,{content:e.$t("seedance.description.serviceTier"),class:"info"},null,8,["content"])])]),s(m,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=d=>e.value=d),class:"value",placeholder:e.$t("seedance.placeholder.select")},{default:p(()=>[(n(!0),i(T,null,A(e.options,d=>(n(),y(l,{key:d.value,label:d.label,value:d.value},null,8,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ks=E(hs,[["render",Es],["__scopeId","data-v-a62125ec"]]),ws=b({name:"SeedanceReturnLastFrameSwitch",components:{ElSwitch:P,InfoIcon:S},computed:{value:{get(){return this.$store.state.seedance?.config?.return_last_frame},set(e){this.$store.commit("seedance/setConfig",{...this.$store.state.seedance?.config,return_last_frame:e})}}},mounted(){this.value===void 0&&(this.value=re)}}),ys={class:"field"},Ss={class:"label"},Vs={class:"box"},Ts={class:"title font-bold"},Ls={class:"value"};function Is(e,a,u,f,g,$){const c=t("info-icon"),l=t("el-switch");return n(),i("div",ys,[r("div",Ss,[r("div",Vs,[r("h2",Ts,o(e.$t("seedance.name.returnLastFrame")),1),s(c,{content:e.$t("seedance.description.returnLastFrame"),class:"info"},null,8,["content"])])]),r("div",Ls,[s(l,{modelValue:e.value,"onUpdate:modelValue":a[0]||(a[0]=m=>e.value=m),"inline-prompt":"","active-text":e.$t("seedance.button.on"),"inactive-text":e.$t("seedance.button.off")},null,8,["modelValue","active-text","inactive-text"])])])}const Cs=E(ws,[["render",Is],["__scopeId","data-v-cd179b1c"]]),As=b({name:"SeedanceConfigPanel",components:{ElButton:I,FontAwesomeIcon:L,PromptInput:De,ModelSelector:Ge,DurationSelector:He,GenerateAudioSwitch:ss,ServiceTierSelector:ks,ReturnLastFrameSwitch:Cs,FirstFrameImage:rs,LastFrameImage:_s,Consumption:pe},emits:["generate"],computed:{config(){return this.$store.state.seedance?.config},consumption(){return fe(this.config,this.service?.cost)},service(){return this.$store.state.seedance?.service}},methods:{onGenerate(){this.$emit("generate")}}}),Fs={class:"flex flex-col h-full"},Ds={class:"flex-1 overflow-y-auto p-5"},Rs={class:"flex flex-col items-center justify-center px-5 pb-5"};function Us(e,a,u,f,g,$){const c=t("prompt-input"),l=t("model-selector"),m=t("duration-selector"),d=t("generate-audio-switch"),k=t("service-tier-selector"),_=t("return-last-frame-switch"),V=t("first-frame-image"),F=t("last-frame-image"),N=t("consumption"),z=t("font-awesome-icon"),W=t("el-button");return n(),i("div",Fs,[r("div",Ds,[s(c,{class:"mb-4"}),s(l,{class:"mb-4"}),s(m,{class:"mb-4"}),s(d,{class:"mb-4"}),s(k,{class:"mb-4"}),s(_,{class:"mb-4"}),s(V,{class:"mb-2"}),s(F,{class:"mb-2"})]),r("div",Rs,[s(N,{value:e.consumption,service:e.service},null,8,["value","service"]),s(W,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:p(()=>[s(z,{icon:"fa-solid fa-magic",class:"mr-2"}),h(" "+o(e.$t("seedance.button.generate")),1)]),_:1},8,["onClick"])])])}const Ns=E(As,[["render",Us]]),Os=b({name:"SeedanceTaskPreview",components:{ElImage:Q,CopyToClipboard:_e,FontAwesomeIcon:L,ElAlert:K,VideoPlayer:he,ElTooltip:J,ElButton:I,ImageWrapper:ve},props:{modelValue:{type:Object,required:!0}},data(){return{seedanceLogo:ce}},computed:{video(){return this.modelValue?.response?.data}},methods:{onDownload(e){window.open(e,"_blank")}}}),Ps={class:"preview"},Ms={class:"left"},Gs={class:"main"},js={class:"bot"},Bs={class:"datetime"},qs={class:"info"},zs={key:0,class:"prompt mt-2"},Ws={key:0},Xs={key:1},Hs={key:0,class:C({content:!0})},Js={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},Ks={key:1,class:C({content:!0})},Qs={key:0,class:"mb-4"},Ys={key:1,class:"mb-4"},Zs={key:2,class:C({operations:!0,"mt-2":!0,"mb-2":!0})},xs={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},et={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},st={key:2,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},tt={key:0},ot={key:1},nt={key:3,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},at={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},lt={key:4,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},it={key:2,class:C({content:!0})},rt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ct={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},dt={key:1,class:"text-[var(--el-text-color-regular)] text-xs mb-0"},mt={key:3,class:C({content:!0})},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"};function ft(e,a,u,f,g,$){const c=t("el-image"),l=t("font-awesome-icon"),m=t("copy-to-clipboard"),d=t("el-alert"),k=t("video-player"),_=t("image-wrapper"),V=t("el-button"),F=t("el-tooltip");return n(),i("div",Ps,[r("div",Ms,[s(c,{src:e.seedanceLogo,class:"avatar"},null,8,["src"])]),r("div",Gs,[r("div",js,[h(o(e.$t("seedance.name.seedanceBot"))+" ",1),r("span",Bs,o(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",qs,[e.modelValue?.request?.prompt?(n(),i("p",zs,[h(o(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?e.video?.status==="processing"||e.video?.status==="pending"?(n(),i("span",Xs," - ("+o(e.$t("seedance.status.processing"))+") ",1)):v("",!0):(n(),i("span",Ws," - ("+o(e.$t("seedance.status.pending"))+") ",1))])):v("",!0)]),e.modelValue?.response?e.modelValue?.response?.success===!0?(n(),i("div",Ks,[e.video?.video_url?(n(),i("div",Qs,[s(k,{src:e.video?.video_url},null,8,["src"])])):v("",!0),e.video?.last_frame_url?(n(),i("div",Ys,[s(_,{src:e.video?.last_frame_url,"raw-src":e.video?.last_frame_url},null,8,["src","raw-src"])])):v("",!0),e.video?.video_url?(n(),i("div",Zs,[s(F,{class:"box-item",effect:"dark",content:e.$t("seedance.message.downloadVideo"),placement:"top-start"},{default:p(()=>[s(V,{type:"info",size:"small",class:"btn-action",onClick:a[0]||(a[0]=Y(N=>e.onDownload(e.video?.video_url),["stop"]))},{default:p(()=>[h(o(e.$t("seedance.button.download")),1)]),_:1})]),_:1},8,["content"])])):v("",!0),s(d,{closable:!1,class:"mt-2 success"},{default:p(()=>[e.modelValue?.request?.model?(n(),i("p",xs,[s(l,{icon:"fa-solid fa-cube",class:"mr-1"}),h(" "+o(e.$t("seedance.name.model"))+": "+o(e.modelValue?.request?.model),1)])):v("",!0),e.video?.duration?(n(),i("p",et,[s(l,{icon:"fa-solid fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.name.duration"))+": "+o(e.video?.duration)+"s ",1)])):v("",!0),e.video?.resolution?(n(),i("p",st,[s(l,{icon:"fa-solid fa-expand",class:"mr-1"}),h(" "+o(e.$t("seedance.name.resolution"))+": "+o(e.video?.resolution)+" ",1),e.video?.ratio?(n(),i("span",tt," · "+o(e.video?.ratio),1)):v("",!0),e.video?.framespersecond?(n(),i("span",ot," · "+o(e.video?.framespersecond)+"fps",1)):v("",!0)])):v("",!0),e.modelValue?.request?.generate_audio?(n(),i("p",nt,[s(l,{icon:"fa-solid fa-volume-up",class:"mr-1"}),h(" "+o(e.$t("seedance.name.generateAudio"))+": "+o(e.$t("seedance.button.on")),1)])):v("",!0),r("p",at,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",lt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):e.modelValue?.response?.success===!1?(n(),i("div",it,[s(d,{closable:!1,class:"failure"},{template:p(()=>[s(l,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failure")),1)]),default:p(()=>[r("p",rt,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.error?.message?(n(),i("p",ct,[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.failureReason"))+": "+o(e.modelValue?.response?.error?.message)+" ",1),s(m,{content:e.modelValue?.response?.error?.message,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0),e.modelValue?.response?.trace_id?(n(),i("p",dt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",mt,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-solid fa-circle-info",class:"mr-1"}),h(" "+o(e.$t("seedance.name.status")),1)]),default:p(()=>[r("p",ut,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])]),e.modelValue?.response?.trace_id?(n(),i("p",pt,[s(l,{icon:"fa-solid fa-hashtag",class:"mr-1"}),h(" "+o(e.$t("seedance.name.traceId"))+": "+o(e.modelValue?.response?.trace_id)+" ",1),s(m,{content:e.modelValue?.response?.trace_id,class:"btn-copy inline-block"},null,8,["content"])])):v("",!0)]),_:1})])):(n(),i("div",Hs,[s(d,{closable:!1,class:"info"},{template:p(()=>[s(l,{icon:"fa-regular fa-clock",class:"mr-1"}),h(" "+o(e.$t("seedance.status.pending")),1)]),default:p(()=>[r("p",Js,[s(l,{icon:"fa-solid fa-magic",class:"mr-1"}),h(" "+o(e.$t("seedance.name.taskId"))+": "+o(e.modelValue?.id)+" ",1),s(m,{content:e.modelValue?.id,class:"btn-copy inline-block"},null,8,["content"])])]),_:1})]))])])}const _t=E(Os,[["render",ft],["__scopeId","data-v-43479338"]]),ht=b({name:"SeedanceRecentPanel",components:{TaskPreview:_t,BotPlaceholder:$e,NoTasks:ge,ScrollList:ue},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],computed:{tasks(){return{...this.$store.state.seedance?.tasks,items:this.$store.state.seedance?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),vt={key:0},$t={key:2,class:"w-full h-full flex items-center justify-center"};function gt(e,a,u,f,g,$){const c=t("bot-placeholder"),l=t("task-preview"),m=t("scroll-list"),d=t("no-tasks");return n(),i(T,null,[e.tasks?.items===void 0?(n(),i("div",vt,[s(c)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(n(),y(m,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:a[0]||(a[0]=k=>e.$emit("reach-top"))},{default:p(()=>[(n(!0),i(T,null,A(e.tasks?.items,k=>(n(),y(l,{key:k.id,"model-value":k},null,8,["model-value"]))),128))]),_:1},8,["loading"])):v("",!0),e.tasks?.items?.length===0?(n(),i("div",$t,[s(d)])):v("",!0)],64)}const bt=E(ht,[["render",gt]]),Et="https://webhook.acedata.cloud/seedance",kt=b({name:"SeedanceIndex",components:{ConfigPanel:Ns,Layout:Ve,RecentPanel:bt},inject:["initialized"],data(){return{task:void 0,job:0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.seedance?.status?.getApplications===O.Request},tasksLoading(){return this.$store.state.seedance?.status?.getTasks===O.Request||this.fetchingTasks},credential(){return this.$store.state.seedance?.credential},config(){return this.$store.state.seedance?.config},tasks(){return this.$store.state.seedance?.tasks}},watch:{initialized:{async handler(e){e&&(await this.onGetTasks(),await this.onScrollDown(),this.job=window.setInterval(()=>{this.onGetTasks()},5e3))},immediate:!0}},async mounted(){await this.onGetService()},async unmounted(){window.clearInterval(this.job)},methods:{async onReachTop(){await be({tasks:this.tasks,loading:this.loadingMore,setLoading:e=>this.loadingMore=e,isBlocked:()=>this.tasksLoading||this.applicationsLoading,fetch:e=>this.onGetTasks({createdAtMax:e}),getScrollElement:()=>this.getTasksScrollElement()})},async onGetService(){await this.$store.dispatch("seedance/getService")},async onScrollDown(){await this.$nextTick();const e=this.getTasksScrollElement();e&&(e.scrollTop=e.scrollHeight)},async onGetTasks(e){if(this.applicationsLoading||this.fetchingTasks)return;const{limit:a=5,createdAtMin:u,createdAtMax:f}=e||{};this.fetchingTasks=!0;try{await this.$store.dispatch("seedance/getTasks",{limit:a,createdAtMin:u,createdAtMax:f})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config||{}};if(typeof e?.prompt=="string"&&(e.prompt=e.prompt.trim(),e.prompt||delete e.prompt),Array.isArray(e?.images)){e.images=e.images.filter(c=>!!c?.url);const g=e.images.some(c=>c?.role==="first_frame"),$=e.images.some(c=>c?.role==="last_frame");!g&&$&&(e.images=e.images.map(c=>c?.role==="last_frame"?{...c,role:"first_frame"}:c))}!(Array.isArray(e?.images)&&e.images.length>0)&&"images"in e&&delete e.images;const u={...e,callback_url:Et},f=this.credential?.token;if(!f){console.error("no token specified");return}w.info(this.$t("seedance.message.startingTask")),de.generate(u,{token:f}).then(()=>{w.success(this.$t("seedance.message.startTaskSuccess"))}).catch(g=>{const $=g?.response?.data;$?.error?.code===me?w.error(this.$t("seedance.message.usedUp")):w.error(this.$t("seedance.message.startTaskFailed")+($?.error?.message||""))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function wt(e,a,u,f,g,$){const c=t("config-panel"),l=t("recent-panel"),m=t("layout");return n(),y(m,null,{config:p(()=>[s(c,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:p(()=>[s(l,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const zt=E(kt,[["render",wt]]);export{zt as default};
@@ -1 +1 @@
1
- import{F as R}from"./index.es-D2RJIOwI.js";import{m as S,W as O,O as C,P as G,u as M,w as V,t as j,q as B,H as N,j as F}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as i,G as r,T as t,E as U,K as d,ai as o,D as a,R as l,S as I,ag as E,J as $,Q as _,O as m,M as L,X as q}from"./vendor-vue-BhXato7y.js";import{_ as v,d2 as z,au as W,ao as H,d3 as J,aN as K,aJ as D}from"./index-CdkIaG4d.js";import{p as Q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as X}from"./ScrollList-Dw45lO0t.js";import{I as Y}from"./ImagePreview-SUR7TFTL.js";import{C as Z}from"./Consumption-BCbR6ZEO.js";import{a as x}from"./price-CwH8PfMf.js";import{C as ee}from"./CopyToClipboard-Djhvl2Fk.js";import{V as te}from"./VideoPlayer-gXXZbisY.js";import{B as oe}from"./BotPlaceholder-CInEMDBc.js";import{N as se}from"./NoTasks-BYOtsKOE.js";import{l as ne}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CNlWJWvL.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const ae=w({name:"LayoutWan",components:{ElDrawer:O,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),le={class:"main flex flex-row flex-1"},re={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ie={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ce(e,s,f,h,b,k){const u=o("font-awesome-icon"),p=o("el-button"),n=o("el-drawer");return a(),i("div",le,[r("div",re,[U(e.$slots,"config",{},void 0,!0)]),r("div",ie,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:s[0]||(s[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const de=v(ae,[["render",ce],["__scopeId","data-v-98681d9b"]]),ue=w({name:"ModelSelector",components:{ElSelect:G,ElOption:C},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=z)}}),pe={class:"field"},me={class:"title font-bold"},fe={class:"float-left"};function he(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",pe,[r("h2",me,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",fe,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(ue,[["render",he],["__scopeId","data-v-eb090beb"]]),ge="720p",$e=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ge)}}),we={class:"field"},ve={class:"title font-bold"},be={class:"float-left"};function ke(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",we,[r("h2",ve,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",be,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ye=v($e,[["render",ke],["__scopeId","data-v-3e39f44e"]]),Ve=5,Te=w({name:"DurationSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ve)}}),Ie={class:"field"},Se={class:"title font-bold"},Ee={class:"float-left"};function Le(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",Ie,[r("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",Ee,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=v(Te,[["render",Le],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:M,ElButton:S,InfoIcon:P,ImagePreview:Y},mixins:[Q],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.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ce={class:"relative"},Ge={class:"flex justify-between"},Ae={class:"flex justify-start items-center"},De={class:"text-sm font-bold"};function Pe(e,s,f,h,b,k){const u=o("info-icon"),p=o("image-preview"),n=o("el-button"),g=o("el-upload");return a(),i("div",Ce,[r("div",Ge,[r("div",Ae,[r("span",De,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=c=>e.fileList=c),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:c})=>[c.url&&c.percentage!==void 0?(a(),$(p,{key:0,url:c.url,name:c.name,percentage:c.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(c),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(n,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[_(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Pe],["__scopeId","data-v-c9ebe1b1"]]),Me="",je=w({name:"PromptInput",components:{ElInput:j,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Me)}}),Be={class:"field"},Ne={class:"box"},Fe={class:"title font-bold"};function qe(e,s,f,h,b,k){const u=o("info-icon"),p=o("el-input");return a(),i("div",Be,[r("div",Ne,[r("h2",Fe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ze=v(je,[["render",qe],["__scopeId","data-v-45557a2d"]]),We=w({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:ze,ImageUrlInput:Oe,ModelSelector:_e,ResolutionSelector:ye,DurationSelector:Ue,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return x(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),He={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,s,f,h,b,k){const u=o("prompt-input"),p=o("model-selector"),n=o("resolution-selector"),g=o("duration-selector"),c=o("image-url-input"),y=o("consumption"),T=o("font-awesome-icon"),A=o("el-button");return a(),i("div",He,[r("div",Je,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(a(),$(n,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(a(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(a(),$(c,{key:2,class:"mb-2"})):m("",!0)]),r("div",Ke,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=v(We,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:F,CopyToClipboard:ee,FontAwesomeIcon:R,ElAlert:N,VideoPlayer:te,ElTooltip:B,ElButton:S},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:H}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),Ze={class:"preview"},xe={class:"left"},et={class:"main"},tt={class:"bot"},ot={class:"datetime"},st={class:"info"},nt={key:0,class:"prompt mt-2"},at={key:0},lt={key:1},rt={key:0,class:L({content:!0,failed:!0})},it={key:0,class:"mb-4"},ct={key:1,class:L({operations:!0,"mt-2":!0})},dt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:1,class:L({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:2,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function $t(e,s,f,h,b,k){const u=o("el-image"),p=o("video-player"),n=o("el-button"),g=o("el-tooltip"),c=o("font-awesome-icon"),y=o("copy-to-clipboard"),T=o("el-alert");return a(),i("div",Ze,[r("div",xe,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),r("div",et,[r("div",tt,[_(l(e.$t("wan.name.wanBot"))+" ",1),r("span",ot,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",st,[e.modelValue?.request?.prompt?(a(),i("p",nt,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(a(),i("span",at," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(a(),i("span",lt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",rt,[e.modelValue?.response?.video_url?(a(),i("div",it,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(a(),i("div",ct,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(n,{type:"info",size:"small",class:"mb-2",onClick:s[0]||(s[0]=q(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[_(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(a(),i("p",dt,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),r("p",ut,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(a(),i("div",pt,[t(T,{closable:!1,class:"failure"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",mt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),r("p",ft,[t(c,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),r("p",ht,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(a(),i("div",_t,[t(T,{closable:!1,class:"info"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",gt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const wt=v(Ye,[["render",$t],["__scopeId","data-v-5cbc37f1"]]),vt=w({name:"RecentPanel",components:{TaskPreview:wt,BotPlaceholder:oe,NoTasks:se,ScrollList:X},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),bt={key:0},kt={key:2,class:"w-full h-full flex items-center justify-center"};function yt(e,s,f,h,b,k){const u=o("bot-placeholder"),p=o("task-preview"),n=o("scroll-list"),g=o("no-tasks");return a(),i(I,null,[e.tasks?.items===void 0?(a(),i("div",bt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(n,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=c=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),i(I,null,E(e.tasks?.items,c=>(a(),$(p,{key:c.id,"model-value":c},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(a(),i("div",kt,[t(g)])):m("",!0)],64)}const Vt=v(vt,[["render",yt]]),Tt="https://webhook.acedata.cloud/wan",It=w({name:"WanIndex",components:{ConfigPanel:Xe,Layout:de,RecentPanel:Vt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.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 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("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/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:h}=e||{};console.debug("limit",s,"createdAtMin",f,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:s,createdAtMin:f,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Tt},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),J.generate(e,{token:s}).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===K?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function St(e,s,f,h,b,k){const u=o("config-panel"),p=o("recent-panel"),n=o("layout");return a(),$(n,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Jt=v(It,[["render",St]]);export{Jt as default};
1
+ import{F as R}from"./index.es-CS-OHrjD.js";import{m as S,W as O,O as C,P as G,u as M,w as V,t as j,q as B,H as N,j as F}from"./vendor-element-plus-ZfFlETcH.js";import{d as w,C as i,G as r,T as t,E as U,K as d,ai as o,D as a,R as l,S as I,ag as E,J as $,Q as _,O as m,M as L,X as q}from"./vendor-vue-BhXato7y.js";import{_ as v,d2 as z,au as W,ao as H,d3 as J,aN as K,aJ as D}from"./index-59WF-aDo.js";import{p as Q}from"./pasteUploadMixin-BurWbGNQ.js";import{I as P,S as X}from"./ScrollList-_cUBLaZZ.js";import{I as Y}from"./ImagePreview-COK_lQAf.js";import{C as Z}from"./Consumption-DTFyP44R.js";import{a as x}from"./price-DRZuZOgJ.js";import{C as ee}from"./CopyToClipboard-COWZc6L9.js";import{V as te}from"./VideoPlayer-CF6zk-Kd.js";import{B as oe}from"./BotPlaceholder-DEITkzHi.js";import{N as se}from"./NoTasks-C1c_E_pm.js";import{l as ne}from"./pagination-DLJ2pbsx.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";import"./vue-plyr-QZFBikSk.js";const ae=w({name:"LayoutWan",components:{ElDrawer:O,ElButton:S,FontAwesomeIcon:R},data(){return{drawer:!1}}}),le={class:"main flex flex-row flex-1"},re={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},ie={class:"result h-full p-6 flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function ce(e,s,f,h,b,k){const u=o("font-awesome-icon"),p=o("el-button"),n=o("el-drawer");return a(),i("div",le,[r("div",re,[U(e.$slots,"config",{},void 0,!0)]),r("div",ie,[U(e.$slots,"result",{},void 0,!0)]),t(p,{circle:"",class:"menu",onClick:s[0]||(s[0]=g=>e.drawer=!0)},{default:d(()=>[t(u,{icon:"fa-solid fa-magic"})]),_:1}),t(n,{modelValue:e.drawer,"onUpdate:modelValue":s[1]||(s[1]=g=>e.drawer=g),direction:"ltr","with-header":!1,size:"340px"},{default:d(()=>[U(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const de=v(ae,[["render",ce],["__scopeId","data-v-98681d9b"]]),ue=w({name:"ModelSelector",components:{ElSelect:G,ElOption:C},data(){return{}},computed:{options(){return[{value:"wan2.6-t2v",label:this.$t("wan.button.modelT2v")},{value:"wan2.6-i2v",label:this.$t("wan.button.modelI2v")},{value:"wan2.6-i2v-flash",label:this.$t("wan.button.modelI2vFlash")},{value:"wan2.6-r2v",label:this.$t("wan.button.modelR2v")}]},value:{get(){return this.$store.state.wan?.config?.model},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,model:e})}}},mounted(){this.value||(this.value=z)}}),pe={class:"field"},me={class:"title font-bold"},fe={class:"float-left"};function he(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",pe,[r("h2",me,l(e.$t("wan.name.model")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",fe,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const _e=v(ue,[["render",he],["__scopeId","data-v-eb090beb"]]),ge="720p",$e=w({name:"ResolutionSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:"480p",label:this.$t("wan.name.resolution480p")},{value:"720p",label:this.$t("wan.name.resolution720p")},{value:"1080p",label:this.$t("wan.name.resolution1080p")}]},value:{get(){return this.$store.state.wan?.config?.resolution},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,resolution:e})}}},mounted(){this.value||(this.value=ge)}}),we={class:"field"},ve={class:"title font-bold"},be={class:"float-left"};function ke(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",we,[r("h2",ve,l(e.$t("wan.name.resolution")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",be,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const ye=v($e,[["render",ke],["__scopeId","data-v-3e39f44e"]]),Ve=5,Te=w({name:"DurationSelector",components:{ElSelect:G,ElOption:C},computed:{options(){return[{value:5,label:this.$t("wan.name.duration5s")},{value:10,label:this.$t("wan.name.duration10s")},{value:15,label:this.$t("wan.name.duration15s")}]},value:{get(){return this.$store.state.wan?.config?.duration},set(e){this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,duration:e})}}},mounted(){this.value||(this.value=Ve)}}),Ie={class:"field"},Se={class:"title font-bold"},Ee={class:"float-left"};function Le(e,s,f,h,b,k){const u=o("el-option"),p=o("el-select");return a(),i("div",Ie,[r("h2",Se,l(e.$t("wan.name.duration")),1),t(p,{modelValue:e.value,"onUpdate:modelValue":s[0]||(s[0]=n=>e.value=n),class:"value",placeholder:e.$t("wan.placeholder.select"),clearable:""},{default:d(()=>[(a(!0),i(I,null,E(e.options,n=>(a(),$(u,{key:n.value,label:n.label,value:n.value},{default:d(()=>[r("span",Ee,l(n.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","placeholder"])])}const Ue=v(Te,[["render",Le],["__scopeId","data-v-5f35a2cf"]]),Re=w({name:"ImageUrlInput",components:{ElUpload:M,ElButton:S,InfoIcon:P,ImagePreview:Y},mixins:[Q],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.url).filter(e=>e!==void 0)},value:{get(){return this.$store.state.wan?.config?.image_url},set(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})}}},mounted(){this.value||(this.value=void 0),this.onSetImageUrl()},methods:{onExceed(){V.warning(this.$t("wan.message.uploadImageExceed"))},onError(){V.error(this.$t("wan.message.uploadImageError"))},async onRemove(){V.error(this.$t("wan.message.uploadImageError"))},onSetImageUrl(){const e=this.urls?.[0];this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,image_url:e})},async onSuccess(){this.onSetImageUrl()}}}),Ce={class:"relative"},Ge={class:"flex justify-between"},Ae={class:"flex justify-start items-center"},De={class:"text-sm font-bold"};function Pe(e,s,f,h,b,k){const u=o("info-icon"),p=o("image-preview"),n=o("el-button"),g=o("el-upload");return a(),i("div",Ce,[r("div",Ge,[r("div",Ae,[r("span",De,l(e.$t("wan.name.imageUrl")),1),t(u,{content:e.$t("wan.description.imageUrl"),class:"info"},null,8,["content"])])]),t(g,{"file-list":e.fileList,"onUpdate:fileList":s[0]||(s[0]=c=>e.fileList=c),accept:".png,.jpg,.jpeg,.gif,.bmp,.webp",name:"file","show-file-list":!0,limit:1,multiple:!1,"list-type":"picture",action:e.uploadUrl,"on-exceed":e.onExceed,"on-error":e.onError,"on-remove":e.onRemove,"on-success":e.onSuccess,headers:e.headers},{file:d(({file:c})=>[c.url&&c.percentage!==void 0?(a(),$(p,{key:0,url:c.url,name:c.name,percentage:c.percentage,onRemove:y=>e.fileList.splice(e.fileList.indexOf(c),1)},null,8,["url","name","percentage","onRemove"])):m("",!0)]),default:d(()=>[t(n,{size:"small",type:"primary",class:"btn btn-upload",round:""},{default:d(()=>[_(l(e.$t("wan.button.uploadImageUrl")),1)]),_:1})]),_:1},8,["file-list","action","on-exceed","on-error","on-remove","on-success","headers"])])}const Oe=v(Re,[["render",Pe],["__scopeId","data-v-c9ebe1b1"]]),Me="",je=w({name:"PromptInput",components:{ElInput:j,InfoIcon:P},computed:{prompt:{get(){return this.$store.state.wan?.config?.prompt},set(e){console.debug("set prompt",e),this.$store.commit("wan/setConfig",{...this.$store.state.wan?.config,prompt:e})}}},mounted(){this.prompt||(this.prompt=Me)}}),Be={class:"field"},Ne={class:"box"},Fe={class:"title font-bold"};function qe(e,s,f,h,b,k){const u=o("info-icon"),p=o("el-input");return a(),i("div",Be,[r("div",Ne,[r("h2",Fe,l(e.$t("wan.name.prompt")),1),t(u,{content:e.$t("wan.description.prompt"),class:"info"},null,8,["content"])]),t(p,{modelValue:e.prompt,"onUpdate:modelValue":s[0]||(s[0]=n=>e.prompt=n),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("wan.placeholder.prompt")},null,8,["modelValue","placeholder"])])}const ze=v(je,[["render",qe],["__scopeId","data-v-45557a2d"]]),We=w({name:"PresetPanel",components:{ElButton:S,FontAwesomeIcon:R,PromptInput:ze,ImageUrlInput:Oe,ModelSelector:_e,ResolutionSelector:ye,DurationSelector:Ue,Consumption:Z},emits:["generate"],computed:{config(){return this.$store.state.wan?.config},consumption(){return x(this.config,this.service?.cost)},service(){return this.$store.state.wan?.service},supportsResolution(){const e=this.config?.model;return e==="wan2.6-t2v"||e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"},supportsDuration(){return this.config?.model==="wan2.6-t2v"},supportsImageUrl(){const e=this.config?.model;return e==="wan2.6-i2v"||e==="wan2.6-i2v-flash"}},methods:{onGenerate(){this.$emit("generate")}}}),He={class:"flex flex-col h-full"},Je={class:"flex-1 overflow-y-auto p-5"},Ke={class:"flex flex-col items-center justify-center px-5 pb-5"};function Qe(e,s,f,h,b,k){const u=o("prompt-input"),p=o("model-selector"),n=o("resolution-selector"),g=o("duration-selector"),c=o("image-url-input"),y=o("consumption"),T=o("font-awesome-icon"),A=o("el-button");return a(),i("div",He,[r("div",Je,[t(u,{class:"mb-4"}),t(p,{class:"mb-4"}),e.supportsResolution?(a(),$(n,{key:0,class:"mb-4"})):m("",!0),e.supportsDuration?(a(),$(g,{key:1,class:"mb-4"})):m("",!0),e.supportsImageUrl?(a(),$(c,{key:2,class:"mb-2"})):m("",!0)]),r("div",Ke,[t(y,{value:e.consumption,service:e.service},null,8,["value","service"]),t(A,{type:"primary",class:"btn w-full",round:"",onClick:e.onGenerate},{default:d(()=>[t(T,{icon:"fa-solid fa-magic",class:"mr-2"}),_(" "+l(e.$t("wan.button.generate")),1)]),_:1},8,["onClick"])])])}const Xe=v(We,[["render",Qe]]),Ye=w({name:"TaskPreview",components:{ElImage:F,CopyToClipboard:ee,FontAwesomeIcon:R,ElAlert:N,VideoPlayer:te,ElTooltip:B,ElButton:S},props:{modelValue:{type:Object,required:!0}},setup(){return{WAN_LOGO:H}},computed:{application(){return this.$store.state.wan?.application},config(){return this.$store.state.wan?.config}},methods:{onDownload(e){console.debug("on download wan video",e),window.open(e,"_blank")}}}),Ze={class:"preview"},xe={class:"left"},et={class:"main"},tt={class:"bot"},ot={class:"datetime"},st={class:"info"},nt={key:0,class:"prompt mt-2"},at={key:0},lt={key:1},rt={key:0,class:L({content:!0,failed:!0})},it={key:0,class:"mb-4"},ct={key:1,class:L({operations:!0,"mt-2":!0})},dt={key:0,class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ut={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},pt={key:1,class:L({content:!0})},mt={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ft={class:"text-[var(--el-text-color-regular)] text-xs mb-2"},ht={class:"text-[var(--el-text-color-regular)] text-xs mb-0"},_t={key:2,class:L({content:!0})},gt={class:"text-[var(--el-text-color-regular)] text-xs mb-0"};function $t(e,s,f,h,b,k){const u=o("el-image"),p=o("video-player"),n=o("el-button"),g=o("el-tooltip"),c=o("font-awesome-icon"),y=o("copy-to-clipboard"),T=o("el-alert");return a(),i("div",Ze,[r("div",xe,[t(u,{src:e.WAN_LOGO,class:"avatar"},null,8,["src"])]),r("div",et,[r("div",tt,[_(l(e.$t("wan.name.wanBot"))+" ",1),r("span",ot,l(e.$dayjs.format(""+new Date(parseFloat((e.modelValue?.created_at||"").toString())*1e3))),1)]),r("div",st,[e.modelValue?.request?.prompt?(a(),i("p",nt,[_(l(e.modelValue?.request?.prompt)+" ",1),e.modelValue?.response?m("",!0):(a(),i("span",at," - ("+l(e.$t("wan.status.pending"))+") ",1)),e.modelValue?.response?.state==="processing"||e.modelValue?.response?.state==="pending"||e.modelValue?.response?.state==="running"?(a(),i("span",lt," - ("+l(e.$t("wan.status.processing"))+") ",1)):m("",!0)])):m("",!0)]),e.modelValue?.response?.success===!0?(a(),i("div",rt,[e.modelValue?.response?.video_url?(a(),i("div",it,[t(p,{src:e.modelValue?.response?.video_url},null,8,["src"])])):m("",!0),e.modelValue?.response?.video_url?(a(),i("div",ct,[t(g,{class:"box-item",effect:"dark",content:e.$t("wan.message.downloadVideo"),placement:"top-start"},{default:d(()=>[t(n,{type:"info",size:"small",class:"mb-2",onClick:s[0]||(s[0]=q(A=>e.onDownload(e.modelValue?.response?.video_url),["stop"]))},{default:d(()=>[_(l(e.$t("wan.button.download")),1)]),_:1})]),_:1},8,["content"])])):m("",!0),t(T,{closable:!1,class:"mt-2 success"},{default:d(()=>[e.modelValue?.request?.model?(a(),i("p",dt,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.model"))+": "+l(e.modelValue?.request?.model)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])):m("",!0),r("p",ut,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===!1?(a(),i("div",pt,[t(T,{closable:!1,class:"failure"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",mt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])]),r("p",ft,[t(c,{icon:"fa-solid fa-circle-info",class:"mr-1"}),_(" "+l(e.$t("wan.name.failureReason"))+": "+l(e.modelValue?.response?.error?.message)+" ",1),t(y,{content:e.modelValue?.response?.error?.message},null,8,["content"])]),r("p",ht,[t(c,{icon:"fa-solid fa-hashtag",class:"mr-1"}),_(" "+l(e.$t("wan.name.traceId"))+": "+l(e.modelValue?.response?.trace_id)+" ",1),t(y,{content:e.modelValue?.response?.trace_id},null,8,["content"])])]),_:1})])):m("",!0),e.modelValue?.response?.success===void 0?(a(),i("div",_t,[t(T,{closable:!1,class:"info"},{template:d(()=>[t(c,{icon:"fa-solid fa-exclamation-triangle",class:"mr-1"}),_(" "+l(e.$t("wan.name.failure")),1)]),default:d(()=>[r("p",gt,[t(c,{icon:"fa-solid fa-magic",class:"mr-1"}),_(" "+l(e.$t("wan.name.taskId"))+": "+l(e.modelValue?.id)+" ",1),t(y,{content:e.modelValue?.id},null,8,["content"])])]),_:1})])):m("",!0)])])}const wt=v(Ye,[["render",$t],["__scopeId","data-v-5cbc37f1"]]),vt=w({name:"RecentPanel",components:{TaskPreview:wt,BotPlaceholder:oe,NoTasks:se,ScrollList:X},props:{loading:{type:Boolean,default:!1}},emits:["reach-top"],data(){return{job:0}},computed:{tasks(){return{...this.$store.state.wan?.tasks,items:this.$store.state.wan?.tasks?.items?.slice()}}},methods:{getScrollElement(){return this.$refs.scrollList?.getScrollElement?.()}}}),bt={key:0},kt={key:2,class:"w-full h-full flex items-center justify-center"};function yt(e,s,f,h,b,k){const u=o("bot-placeholder"),p=o("task-preview"),n=o("scroll-list"),g=o("no-tasks");return a(),i(I,null,[e.tasks?.items===void 0?(a(),i("div",bt,[t(u)])):e.tasks?.items?.length&&e.tasks?.items?.length>0?(a(),$(n,{key:1,ref:"scrollList",class:"tasks w-full h-full overflow-y-auto",loading:e.loading,onReachTop:s[0]||(s[0]=c=>e.$emit("reach-top"))},{default:d(()=>[(a(!0),i(I,null,E(e.tasks?.items,c=>(a(),$(p,{key:c.id,"model-value":c},null,8,["model-value"]))),128))]),_:1},8,["loading"])):m("",!0),e.tasks?.items?.length===0?(a(),i("div",kt,[t(g)])):m("",!0)],64)}const Vt=v(vt,[["render",yt]]),Tt="https://webhook.acedata.cloud/wan",It=w({name:"WanIndex",components:{ConfigPanel:Xe,Layout:de,RecentPanel:Vt},inject:["initialized"],data(){return{task:void 0,job:0,timer:void 0,loadingMore:!1,fetchingTasks:!1}},computed:{applicationsLoading(){return this.$store.state.wan?.status?.getApplications===D.Request},tasksLoading(){return this.$store.state.wan?.status?.getTasks===D.Request||this.fetchingTasks},credential(){return this.$store.state.wan.credential},config(){return this.$store.state.wan.config},application(){return this.$store.state.wan.application},tasks(){return this.$store.state.wan.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 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("wan/getService"),console.debug("end onGetService")},async onGetApplication(){console.debug("start onGetApplication"),await this.$store.dispatch("wan/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:h}=e||{};console.debug("limit",s,"createdAtMin",f,"createdAtMax",h),this.fetchingTasks=!0;try{await this.$store.dispatch("wan/getTasks",{limit:s,createdAtMin:f,createdAtMax:h})}finally{this.fetchingTasks=!1}},async onGenerate(){const e={...this.config,callback_url:Tt},s=this.credential?.token;if(!s){console.error("no token specified");return}V.info(this.$t("wan.message.startingTask")),J.generate(e,{token:s}).then(()=>{V.success(this.$t("wan.message.startTaskSuccess"))}).catch(f=>{f?.response?.data?.error?.code===K?V.error(this.$t("wan.message.usedUp")):V.error(this.$t("wan.message.startTaskFailed"))}).finally(async()=>{setTimeout(async()=>{await this.onGetTasks(),await this.onScrollDown()},1e3)})},getTasksScrollElement(){return this.$refs.recentPanel?.getScrollElement?.()}}});function St(e,s,f,h,b,k){const u=o("config-panel"),p=o("recent-panel"),n=o("layout");return a(),$(n,null,{config:d(()=>[t(u,{onGenerate:e.onGenerate},null,8,["onGenerate"])]),result:d(()=>[t(p,{ref:"recentPanel",loading:e.loadingMore,onReachTop:e.onReachTop},null,8,["loading","onReachTop"])]),_:1})}const Jt=v(It,[["render",St]]);export{Jt as default};
@@ -1 +1 @@
1
- import{F as x}from"./index.es-D2RJIOwI.js";import{m as A,W as O,t as E,O as N,P,a6 as z,a7 as G,w}from"./vendor-element-plus-ZfFlETcH.js";import{d as h,C as o,G as r,T as d,E as V,K as k,ai as i,D as t,R as a,Q as U,O as c,S as b,ag as y,J as v,aB as L}from"./vendor-vue-BhXato7y.js";import{_,aJ as I,aN as B}from"./index-CdkIaG4d.js";import{C as D}from"./Consumption-BCbR6ZEO.js";import{a as T}from"./price-CwH8PfMf.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-CNlWJWvL.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},J={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},M={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function W(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",J,[V(e.$slots,"config",{},void 0,!0)]),r("div",M,[V(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[V(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const H=_(K,[["render",W],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:E},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=_(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,m,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=_(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=_(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),_e={class:"field"},me={class:"title font-bold"};function fe(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",_e,[r("h2",me,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=_(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:D},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return T(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===I.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,m,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),U(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=_($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ce={class:"flex-1 min-w-0"},Ve={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ie={class:"text-xl font-bold mb-1.5"},Ee={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,m,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ce,[e.data.type?(t(),o("div",Ve,a(e.data.type),1)):c("",!0),r("h3",Ie,a(e.data.title),1),e.data.description?(t(),o("p",Ee,[U(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const Ne=_(xe,[["render",Oe]]),Pe=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),ze={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Ge={key:0,class:"flex items-center gap-2 mb-1.5"},Le=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},Je={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Me=["href"];function We(e,n,p,m,f,g){return t(),o("div",ze,[e.displayUrl?(t(),o("div",Ge,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Le),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",Je,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Me))),128))])):c("",!0)])}const He=_(Pe,[["render",We]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,m,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=_(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},_t={class:"flex-1 min-w-0"},mt={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,m,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",_t,[r("div",mt,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=_(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Vt={class:"text-xs text-gray-400 mt-1"},It={key:0},Et={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,m,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Ct,a(s.title),1),r("div",Vt,[s.source?(t(),o("span",It,a(s.source),1)):c("",!0),s.date?(t(),o("span",Et," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=_(wt,[["render",Ft]]),Nt=h({name:"PeopleAlsoAsk",components:{ElCollapse:G,ElCollapseItem:z},props:{data:{type:Array,required:!0}}}),Pt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},zt={class:"text-base font-bold mb-3"},Gt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Lt=["href"];function Bt(e,n,p,m,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Pt,[r("h3",zt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Gt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Lt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=_(Nt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Jt={class:"flex flex-wrap gap-2"},Mt=["onClick"];function Wt(e,n,p,m,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Jt,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),U(" "+a(l.query),1)],8,Mt))),128))])])}const Ht=_(Tt,[["render",Wt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:Ne,OrganicResult:He,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Ht},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===I.Request},noResults(){return this.$store.state.serp?.status?.search===I.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,C=>r("div",{key:C,class:"mb-6 animate-pulse"},n[0]||(n[0]=[L('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)]))),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=_(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:H,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===B?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,m,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const bs=_(is,[["render",cs]]);export{bs as default};
1
+ import{F as x}from"./index.es-CS-OHrjD.js";import{m as A,W as O,t as E,O as N,P,a6 as z,a7 as G,w}from"./vendor-element-plus-ZfFlETcH.js";import{d as h,C as o,G as r,T as d,E as V,K as k,ai as i,D as t,R as a,Q as U,O as c,S as b,ag as y,J as v,aB as L}from"./vendor-vue-BhXato7y.js";import{_,aJ as I,aN as B}from"./index-59WF-aDo.js";import{C as D}from"./Consumption-DTFyP44R.js";import{a as T}from"./price-DRZuZOgJ.js";import"./vendor-dayjs-CzbnksQQ.js";import"./vendor-web3-UIIclDfr.js";import"./vendor-axios-NIGUFBhG.js";import"./vendor-vue-router-8bYQCSwj.js";const K=h({name:"LayoutSerp",components:{ElDrawer:O,ElButton:A,FontAwesomeIcon:x},data(){return{drawer:!1}}}),Q={class:"main flex flex-row flex-1"},J={class:"config w-[320px] flex-none h-full overflow-y-auto bg-[var(--app-sidebar-bg)] border-r border-[var(--app-border-subtle)]"},M={class:"result h-full flex-1 flex flex-col min-w-0 overflow-x-hidden bg-[var(--app-content-bg)]"};function W(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("el-button"),u=i("el-drawer");return t(),o("div",Q,[r("div",J,[V(e.$slots,"config",{},void 0,!0)]),r("div",M,[V(e.$slots,"result",{},void 0,!0)]),d(l,{circle:"",class:"menu",onClick:n[0]||(n[0]=$=>e.drawer=!0)},{default:k(()=>[d(s,{icon:"fa-solid fa-search"})]),_:1}),d(u,{modelValue:e.drawer,"onUpdate:modelValue":n[1]||(n[1]=$=>e.drawer=$),direction:"ltr","with-header":!1,size:"340px",class:"drawer"},{default:k(()=>[V(e.$slots,"config",{},void 0,!0)]),_:3},8,["modelValue"])])}const H=_(K,[["render",W],["__scopeId","data-v-99dba970"]]),X=h({name:"QueryInput",components:{ElInput:E},computed:{query:{get(){return this.$store.state.serp?.config?.query},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e})}}}}),Y={class:"field"},Z={class:"box"},ee={class:"title font-bold"};function te(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",Y,[r("div",Z,[r("h2",ee,a(e.$t("serp.name.query")),1)]),d(s,{modelValue:e.query,"onUpdate:modelValue":n[0]||(n[0]=l=>e.query=l),rows:3,type:"textarea",class:"prompt",placeholder:e.$t("serp.placeholder.query")},null,8,["modelValue","placeholder"])])}const se=_(X,[["render",te],["__scopeId","data-v-3582b195"]]),oe=h({name:"TypeSelector",components:{ElSelect:P,ElOption:N},computed:{value:{get(){return this.$store.state.serp?.config?.type},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,type:e})}}},mounted(){this.value||(this.value="search")}}),re={class:"field"},ae={class:"title font-bold"};function ne(e,n,p,m,f,g){const s=i("el-option"),l=i("el-select");return t(),o("div",re,[r("h2",ae,a(e.$t("serp.name.type")),1),d(l,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=u=>e.value=u),class:"value"},{default:k(()=>[d(s,{value:"search",label:e.$t("serp.type.search")},null,8,["label"]),d(s,{value:"images",label:e.$t("serp.type.images")},null,8,["label"]),d(s,{value:"news",label:e.$t("serp.type.news")},null,8,["label"]),d(s,{value:"videos",label:e.$t("serp.type.videos")},null,8,["label"])]),_:1},8,["modelValue"])])}const le=_(oe,[["render",ne],["__scopeId","data-v-2913fb62"]]),ie=h({name:"CountryInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.country},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,country:e})}}},mounted(){this.value||(this.value="US")}}),ce={class:"field"},de={class:"title font-bold"};function ue(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",ce,[r("h2",de,a(e.$t("serp.name.country")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.country")},null,8,["modelValue","placeholder"])])}const pe=_(ie,[["render",ue],["__scopeId","data-v-f0672cc6"]]),he=h({name:"LanguageInput",components:{ElInput:E},computed:{value:{get(){return this.$store.state.serp?.config?.language},set(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,language:e})}}},mounted(){this.value||(this.value="en")}}),_e={class:"field"},me={class:"title font-bold"};function fe(e,n,p,m,f,g){const s=i("el-input");return t(),o("div",_e,[r("h2",me,a(e.$t("serp.name.language")),1),d(s,{modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=l=>e.value=l),class:"value",placeholder:e.$t("serp.placeholder.language")},null,8,["modelValue","placeholder"])])}const ge=_(he,[["render",fe],["__scopeId","data-v-dc1c94b7"]]),$e=h({name:"SearchPanel",components:{ElButton:A,FontAwesomeIcon:x,QueryInput:se,TypeSelector:le,CountryInput:pe,LanguageInput:ge,Consumption:D},emits:["search"],computed:{config(){return this.$store.state.serp?.config},consumption(){return T(this.config,this.service?.cost)},service(){return this.$store.state.serp?.service},searching(){return this.$store.state.serp?.status?.search===I.Request}},methods:{onSearch(){this.$emit("search")}}}),ve={class:"flex flex-col h-full"},be={class:"flex-1 overflow-y-auto p-5"},ye={class:"flex flex-col items-center justify-center px-5 pb-5"};function ke(e,n,p,m,f,g){const s=i("query-input"),l=i("type-selector"),u=i("country-input"),$=i("language-input"),S=i("consumption"),R=i("font-awesome-icon"),q=i("el-button");return t(),o("div",ve,[r("div",be,[d(s,{class:"mb-4"}),d(l,{class:"mb-4"}),d(u,{class:"mb-4"}),d($,{class:"mb-4"})]),r("div",ye,[d(S,{value:e.consumption,service:e.service},null,8,["value","service"]),d(q,{type:"primary",class:"btn w-full",round:"",loading:e.searching,onClick:e.onSearch},{default:k(()=>[d(R,{icon:"fa-solid fa-search",class:"mr-2"}),U(" "+a(e.$t("serp.button.search")),1)]),_:1},8,["loading","onClick"])])])}const we=_($e,[["render",ke]]),xe=h({name:"KnowledgeGraph",props:{data:{type:Object,required:!0}}}),Se={class:"knowledge-graph rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Re={class:"flex flex-row gap-4"},qe=["src","alt"],Ce={class:"flex-1 min-w-0"},Ve={key:0,class:"text-xs text-[var(--el-text-color-disabled)] mb-1 uppercase tracking-wide"},Ie={class:"text-xl font-bold mb-1.5"},Ee={key:1,class:"text-sm text-[var(--el-text-color-regular)] mb-3 leading-relaxed"},Ue=["href"],Ae={key:2,class:"text-sm"},je={class:"text-[var(--el-text-color-disabled)] flex-none font-medium"},Fe={class:"text-[var(--el-text-color-regular)]"};function Oe(e,n,p,m,f,g){return t(),o("div",Se,[r("div",Re,[e.data.image_url?(t(),o("img",{key:0,src:e.data.image_url,alt:e.data.title,class:"w-28 h-28 rounded-lg object-cover flex-none shadow-sm"},null,8,qe)):c("",!0),r("div",Ce,[e.data.type?(t(),o("div",Ve,a(e.data.type),1)):c("",!0),r("h3",Ie,a(e.data.title),1),e.data.description?(t(),o("p",Ee,[U(a(e.data.description)+" ",1),e.data.description_link?(t(),o("a",{key:0,href:e.data.description_link,target:"_blank",rel:"noopener noreferrer",class:"text-[var(--el-color-primary)] hover:underline ml-1"},a(e.data.description_source||"Source"),9,Ue)):c("",!0)])):c("",!0),e.data.attributes&&Object.keys(e.data.attributes).length?(t(),o("div",Ae,[(t(!0),o(b,null,y(e.data.attributes,(s,l)=>(t(),o("div",{key:l,class:"flex gap-2 mb-1 py-0.5"},[r("span",je,a(l)+":",1),r("span",Fe,a(s),1)]))),128))])):c("",!0)])])])}const Ne=_(xe,[["render",Oe]]),Pe=h({name:"OrganicResult",props:{data:{type:Object,required:!0}},data(){return{faviconFailed:!1}},computed:{hostname(){if(!this.data.link)return"";try{return new URL(this.data.link).hostname}catch{return""}},pathname(){if(!this.data.link)return"";try{const e=new URL(this.data.link).pathname;return e==="/"?"":e}catch{return""}},displayUrl(){return this.hostname},faviconUrl(){return this.faviconFailed||!this.hostname?"":`https://www.google.com/s2/favicons?domain=${this.hostname}&sz=32`}},methods:{onFaviconError(e){this.faviconFailed=!0,e.target.style.display="none"}}}),ze={class:"organic-result rounded-lg p-4 transition-all duration-200 hover:bg-[var(--el-fill-color-lighter)]"},Ge={key:0,class:"flex items-center gap-2 mb-1.5"},Le=["src","alt"],Be={class:"text-xs text-[var(--el-text-color-secondary)] truncate"},De={class:"text-xs text-[var(--el-text-color-disabled)]"},Te=["href"],Ke={key:1,class:"text-xs text-[var(--el-text-color-disabled)] mt-1"},Qe={key:2,class:"text-sm text-[var(--el-text-color-regular)] mt-1.5 leading-relaxed line-clamp-3"},Je={key:3,class:"mt-3 flex flex-wrap gap-x-4 gap-y-1"},Me=["href"];function We(e,n,p,m,f,g){return t(),o("div",ze,[e.displayUrl?(t(),o("div",Ge,[r("img",{src:e.faviconUrl,alt:e.hostname,class:"w-4 h-4 rounded-sm flex-none",loading:"lazy",onError:n[0]||(n[0]=(...s)=>e.onFaviconError&&e.onFaviconError(...s))},null,40,Le),r("span",Be,a(e.hostname),1),r("span",De,a(e.pathname),1)])):c("",!0),r("a",{href:e.data.link,target:"_blank",rel:"noopener noreferrer",class:"text-base font-semibold text-[var(--el-color-primary)] hover:underline leading-snug block"},a(e.data.title),9,Te),e.data.date?(t(),o("div",Ke,a(e.data.date),1)):c("",!0),e.data.snippet?(t(),o("p",Qe,a(e.data.snippet),1)):c("",!0),e.data.sitelinks?.length?(t(),o("div",Je,[(t(!0),o(b,null,y(e.data.sitelinks,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary-light-3)] hover:text-[var(--el-color-primary)] hover:underline transition-colors"},a(s.title),9,Me))),128))])):c("",!0)])}const He=_(Pe,[["render",We]]),Xe=h({name:"ImageResults",props:{data:{type:Array,required:!0}}}),Ye={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Ze={class:"text-base font-bold mb-3"},et={class:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3"},tt=["href"],st=["src","alt"],ot={class:"absolute inset-x-0 bottom-0 bg-gradient-to-t from-black/70 to-transparent p-2.5 opacity-0 group-hover:opacity-100 transition-opacity duration-200"},rt={class:"text-xs text-white line-clamp-2"};function at(e,n,p,m,f,g){return t(),o("div",Ye,[r("h3",Ze,a(e.$t("serp.name.imageResults")),1),r("div",et,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"group relative rounded-lg overflow-hidden bg-[var(--el-fill-color-light)] aspect-square"},[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105",loading:"lazy"},null,8,st)):c("",!0),r("div",ot,[r("span",rt,a(s.title),1)])],8,tt))),128))])])}const nt=_(Xe,[["render",at]]),lt=h({name:"VideoResults",props:{data:{type:Array,required:!0}}}),it={class:"text-base font-bold mb-3"},ct={class:"space-y-4"},dt=["href"],ut={class:"relative flex-shrink-0 w-40 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},pt=["src","alt"],ht={key:1,class:"absolute bottom-1 right-1 bg-black/80 text-white text-xs px-1 rounded"},_t={class:"flex-1 min-w-0"},mt={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},ft={class:"text-xs text-gray-400 mt-1"},gt={key:0},$t={key:1},vt={key:2},bt={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"};function yt(e,n,p,m,f,g){return t(),o("div",null,[r("h3",it,a(e.$t("serp.name.videoResults")),1),r("div",ct,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",ut,[s.image_url?(t(),o("img",{key:0,src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,pt)):c("",!0),s.duration?(t(),o("div",ht,a(s.duration),1)):c("",!0)]),r("div",_t,[r("div",mt,a(s.title),1),r("div",ft,[s.source?(t(),o("span",gt,a(s.source),1)):c("",!0),s.channel?(t(),o("span",$t," · "+a(s.channel),1)):c("",!0),s.date?(t(),o("span",vt," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",bt,a(s.snippet),1)):c("",!0)])],8,dt))),128))])])}const kt=_(lt,[["render",yt]]),wt=h({name:"NewsResults",props:{data:{type:Array,required:!0}}}),xt={class:"text-base font-bold mb-3"},St={class:"space-y-4"},Rt=["href"],qt={class:"flex-1 min-w-0"},Ct={class:"text-blue-600 group-hover:underline font-medium line-clamp-2"},Vt={class:"text-xs text-gray-400 mt-1"},It={key:0},Et={key:1},Ut={key:0,class:"text-sm text-gray-600 dark:text-gray-300 mt-1 line-clamp-2"},At={key:0,class:"flex-shrink-0 w-24 h-24 rounded overflow-hidden bg-gray-100 dark:bg-gray-800"},jt=["src","alt"];function Ft(e,n,p,m,f,g){return t(),o("div",null,[r("h3",xt,a(e.$t("serp.name.newsResults")),1),r("div",St,[(t(!0),o(b,null,y(e.data,(s,l)=>(t(),o("a",{key:l,href:s.link,target:"_blank",rel:"noopener noreferrer",class:"flex gap-4 group"},[r("div",qt,[r("div",Ct,a(s.title),1),r("div",Vt,[s.source?(t(),o("span",It,a(s.source),1)):c("",!0),s.date?(t(),o("span",Et," · "+a(s.date),1)):c("",!0)]),s.snippet?(t(),o("p",Ut,a(s.snippet),1)):c("",!0)]),s.image_url?(t(),o("div",At,[r("img",{src:s.image_url,alt:s.title,class:"w-full h-full object-cover",loading:"lazy"},null,8,jt)])):c("",!0)],8,Rt))),128))])])}const Ot=_(wt,[["render",Ft]]),Nt=h({name:"PeopleAlsoAsk",components:{ElCollapse:G,ElCollapseItem:z},props:{data:{type:Array,required:!0}}}),Pt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},zt={class:"text-base font-bold mb-3"},Gt={key:0,class:"text-sm text-[var(--el-text-color-regular)] mb-2 leading-relaxed"},Lt=["href"];function Bt(e,n,p,m,f,g){const s=i("el-collapse-item"),l=i("el-collapse");return t(),o("div",Pt,[r("h3",zt,a(e.$t("serp.name.peopleAlsoAsk")),1),d(l,null,{default:k(()=>[(t(!0),o(b,null,y(e.data,(u,$)=>(t(),v(s,{key:$,title:u.question||u.title||""},{default:k(()=>[u.snippet?(t(),o("p",Gt,a(u.snippet),1)):c("",!0),u.link?(t(),o("a",{key:1,href:u.link,target:"_blank",rel:"noopener noreferrer",class:"text-xs text-[var(--el-color-primary)] hover:underline"},a(u.title||u.link),9,Lt)):c("",!0)]),_:2},1032,["title"]))),128))]),_:1})])}const Dt=_(Nt,[["render",Bt]]),Tt=h({name:"RelatedSearches",components:{FontAwesomeIcon:x},props:{data:{type:Array,required:!0}},emits:["search"],methods:{onSearch(e){e&&this.$emit("search",e)}}}),Kt={class:"rounded-xl border border-[var(--el-border-color-lighter)] p-5 bg-[var(--el-fill-color-blank)]"},Qt={class:"text-base font-bold mb-3"},Jt={class:"flex flex-wrap gap-2"},Mt=["onClick"];function Wt(e,n,p,m,f,g){const s=i("font-awesome-icon");return t(),o("div",Kt,[r("h3",Qt,a(e.$t("serp.name.relatedSearches")),1),r("div",Jt,[(t(!0),o(b,null,y(e.data,(l,u)=>(t(),o("button",{key:u,class:"inline-flex items-center gap-1.5 px-3 py-1.5 rounded-full text-sm bg-[var(--el-fill-color-light)] text-[var(--el-text-color-regular)] hover:bg-[var(--el-color-primary-light-9)] hover:text-[var(--el-color-primary)] transition-colors cursor-pointer border-none",onClick:$=>e.onSearch(l.query)},[d(s,{icon:"fa-solid fa-magnifying-glass",class:"text-xs opacity-50"}),U(" "+a(l.query),1)],8,Mt))),128))])])}const Ht=_(Tt,[["render",Wt]]),Xt=h({name:"ResultPanel",components:{FontAwesomeIcon:x,KnowledgeGraph:Ne,OrganicResult:He,ImageResults:nt,VideoResults:kt,NewsResults:Ot,PeopleAlsoAsk:Dt,RelatedSearches:Ht},emits:["related-search"],computed:{results(){return this.$store.state.serp?.results},searching(){return this.$store.state.serp?.status?.search===I.Request},noResults(){return this.$store.state.serp?.status?.search===I.Success&&this.results&&!this.results.organic?.length&&!this.results.images?.length&&!this.results.videos?.length&&!this.results.news?.length&&!this.results.knowledge_graph?.title}},methods:{onRelatedSearch(e){this.$emit("related-search",e)}}}),Yt={class:"h-full overflow-y-auto p-6"},Zt={key:0,class:"max-w-3xl mx-auto py-8"},es={key:1,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},ts={class:"text-base"},ss={key:2,class:"max-w-3xl mx-auto"},os={key:1,class:"mb-6"},rs={key:3,class:"flex flex-col items-center justify-center py-24 text-[var(--el-text-color-disabled)]"},as={class:"text-base"};function ns(e,n,p,m,f,g){const s=i("font-awesome-icon"),l=i("knowledge-graph"),u=i("organic-result"),$=i("image-results"),S=i("video-results"),R=i("news-results"),q=i("people-also-ask"),j=i("related-searches");return t(),o("div",Yt,[e.searching?(t(),o("div",Zt,[(t(),o(b,null,y(4,C=>r("div",{key:C,class:"mb-6 animate-pulse"},n[0]||(n[0]=[L('<div class="flex items-center gap-2 mb-2"><div class="w-4 h-4 rounded-sm bg-[var(--el-fill-color-darker)]"></div><div class="h-3 w-32 rounded bg-[var(--el-fill-color-darker)]"></div></div><div class="h-4 w-3/4 rounded bg-[var(--el-fill-color-dark)] mb-2"></div><div class="h-3 w-full rounded bg-[var(--el-fill-color)] mb-1"></div><div class="h-3 w-5/6 rounded bg-[var(--el-fill-color)]"></div>',4)]))),64))])):e.noResults?(t(),o("div",es,[d(s,{icon:"fa-solid fa-face-meh",class:"text-5xl mb-4 opacity-40"}),r("p",ts,a(e.$t("serp.message.noResults")),1)])):e.results?(t(),o("div",ss,[e.results.knowledge_graph?.title?(t(),v(l,{key:0,data:e.results.knowledge_graph,class:"mb-6"},null,8,["data"])):c("",!0),e.results.organic?.length?(t(),o("div",os,[(t(!0),o(b,null,y(e.results.organic,(C,F)=>(t(),v(u,{key:F,data:C,class:"mb-1"},null,8,["data"]))),128))])):c("",!0),e.results.images?.length?(t(),v($,{key:2,data:e.results.images,class:"mb-6"},null,8,["data"])):c("",!0),e.results.videos?.length?(t(),v(S,{key:3,data:e.results.videos,class:"mb-6"},null,8,["data"])):c("",!0),e.results.news?.length?(t(),v(R,{key:4,data:e.results.news,class:"mb-6"},null,8,["data"])):c("",!0),e.results.people_also_ask?.length?(t(),v(q,{key:5,data:e.results.people_also_ask,class:"mb-6"},null,8,["data"])):c("",!0),e.results.related_searches?.length?(t(),v(j,{key:6,data:e.results.related_searches,class:"mb-6",onSearch:e.onRelatedSearch},null,8,["data","onSearch"])):c("",!0)])):(t(),o("div",rs,[d(s,{icon:"fa-solid fa-globe",class:"text-5xl mb-4 opacity-30"}),r("p",as,a(e.$t("serp.description.query")),1)]))])}const ls=_(Xt,[["render",ns]]),is=h({name:"SerpIndex",components:{Layout:H,SearchPanel:we,ResultPanel:ls},inject:["initialized"],async mounted(){await this.onGetService()},methods:{async onGetService(){console.debug("start onGetService"),await this.$store.dispatch("serp/getService"),console.debug("end onGetService")},async onSearch(){if(this.$store.state.serp?.config?.query){w.info(this.$t("serp.message.searching"));try{await this.$store.dispatch("serp/search"),w.success(this.$t("serp.message.searchSuccess"))}catch(n){n?.response?.data?.error?.code===B?w.error(this.$t("serp.message.usedUp")):w.error(this.$t("serp.message.searchFailed"))}}},async onRelatedSearch(e){this.$store.commit("serp/setConfig",{...this.$store.state.serp?.config,query:e}),await this.onSearch()}}});function cs(e,n,p,m,f,g){const s=i("search-panel"),l=i("result-panel"),u=i("layout");return t(),v(u,null,{config:k(()=>[d(s,{onSearch:e.onSearch},null,8,["onSearch"])]),result:k(()=>[d(l,{onRelatedSearch:e.onRelatedSearch},null,8,["onRelatedSearch"])]),_:1})}const bs=_(is,[["render",cs]]);export{bs as default};